*,*:before,*:after{box-sizing:border-box}html{scroll-padding-bottom:5rem;overscroll-behavior-y:auto;scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{display:none}#root{width:100%}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;font-weight:400;--primary: #2563eb;--primary-light: #dbeafe;--primary-glow: rgba(37, 99, 235, .12);--bg-color: #f0f4f8;--text-main: #0f172a;--text-muted: #64748b;--card-bg: rgba(255, 255, 255, .85);--card-border: rgba(0, 0, 0, .08);color-scheme:light;color:var(--text-main);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100dvh;position:relative;overflow-x:hidden;overscroll-behavior-y:auto;background-image:radial-gradient(circle at 15% 50%,rgba(37,99,235,.07),transparent 30%),radial-gradient(circle at 85% 20%,rgba(99,179,237,.1),transparent 30%)}body:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100dvh;background:radial-gradient(ellipse at 60% 0%,rgba(37,99,235,.08),transparent 60%);z-index:-1;pointer-events:none}h1{font-size:4rem;line-height:1.1;font-weight:800;letter-spacing:-1.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.2em}h2{font-size:1.5rem;font-weight:600;margin-top:0;margin-bottom:1.5rem;color:var(--text-main);border-bottom:1px solid var(--card-border);padding-bottom:.75rem}.navbar{position:fixed;top:0;left:0;right:0;height:56px;display:flex;align-items:center;padding:0 1.5rem;gap:1.5rem;background:#ffffffe6;border-bottom:1px solid rgba(0,0,0,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:1000}.navbar-brand{font-size:1.1rem;font-weight:800;letter-spacing:-.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1}.nav-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .2s,background .2s;white-space:nowrap}.nav-link:hover{color:var(--text-main);background:#0000000d}.nav-link.active{color:var(--primary);background:var(--primary-light)}.nav-logout{background:none;border:none;cursor:pointer;font-family:inherit;margin-left:auto}.mobile-nav-link.nav-logout{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:inherit;color:#ef4444}.mobile-nav-link.nav-logout:hover{background:#ef444414;color:#ef4444}.nav-logout:hover{color:#ef4444!important;background:#ef444414!important}.hamburger{display:none;background:none;border:none;color:var(--text-main);cursor:pointer;padding:.4rem;border-radius:8px;margin-left:auto;transition:background .2s}.hamburger:hover{background:#0000000d}.navbar-page-title{display:none;position:absolute;left:50%;transform:translate(-50%);font-size:1rem;font-weight:700;letter-spacing:-.3px;color:var(--text-main);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.mobile-menu{display:none;position:absolute;top:56px;left:0;right:0;background:#fffffffa;border-bottom:1px solid rgba(0,0,0,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-direction:column;padding:.75rem;gap:.25rem;opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s;pointer-events:none}.mobile-menu.open{opacity:1;transform:translateY(0);pointer-events:all}.mobile-nav-link{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-radius:10px;font-size:1rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s}.mobile-nav-link:hover{color:var(--text-main);background:#0000000a}.mobile-nav-link.active{color:var(--primary);background:var(--primary-light)}@media(max-width:640px){.navbar-links{display:none}.hamburger{display:flex;align-items:center;justify-content:center}.mobile-menu{display:flex}.navbar-page-title{display:block}}.shopping-list-container{width:100%;margin-top:0;display:flex;flex-direction:column;gap:1rem}.shopping-list{display:flex;flex-direction:column;gap:.5rem;min-height:50vh}.shopping-item-wrapper{position:relative;border-radius:10px;background:transparent}.shopping-item-wrapper.is-dragging-wrapper{z-index:10}.swipe-delete-background{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#ef4444;border-radius:10px;display:flex;align-items:center;justify-content:flex-end;padding-right:1.5rem;z-index:0}.shopping-item{display:flex;align-items:center;padding:.75rem 1rem;background:#ffffffb3;border:1px solid rgba(0,0,0,.06);border-radius:10px;gap:.75rem;transition:background .15s,border-color .15s,transform .3s cubic-bezier(.175,.885,.32,1.275);position:relative;z-index:1}.shopping-item.is-swiping{transition:none!important}.shopping-item:hover{background:#fff;border-color:#2563eb26}.shopping-item-wrapper.is-dragging-wrapper .shopping-item{background:#2563eb14;border-color:#2563eb40;box-shadow:0 6px 20px #2563eb1f}.shopping-item.is-completed{opacity:.5}.shopping-item.is-completed .item-title{text-decoration:line-through;color:var(--text-muted)}.drag-handle{cursor:grab;color:var(--text-muted);opacity:.35;display:flex;align-items:center;justify-content:center;padding:.6rem;margin:-.35rem -.5rem -.35rem -.85rem;transition:opacity .2s}.drag-handle:hover,.shopping-item:hover .drag-handle{opacity:.8}.drag-handle:active{cursor:grabbing}.toggle-button{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:color .2s,transform .1s}.toggle-button:hover{color:var(--primary)}.toggle-button:active{transform:scale(.9)}.check-icon{color:#16a34a}.item-content{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.item-title{font-size:1rem;text-align:left;color:var(--text-main);transition:color .2s;word-break:break-word;overflow-wrap:anywhere;white-space:normal;cursor:text}.item-source{display:inline-flex;align-items:center;gap:.25rem;width:fit-content;margin-top:-.05rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.item-source--ai{color:#6d28d9}.item-source--manual{color:#64748b}.item-countdown{display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.2px}.delete-button{background:none;border:none;padding:.25rem;cursor:pointer;color:#94a3b8;opacity:0;transition:opacity .2s,color .2s;display:flex;align-items:center;justify-content:center}.shopping-item:hover .delete-button{opacity:.6}.delete-button:hover{opacity:1!important;color:#dc2626}.item-edit-input{flex:1;background:transparent;border:none;border-bottom:2px solid rgba(37,99,235,.3);color:var(--text-main);font-size:1rem;font-family:inherit;padding:0;outline:none;min-width:0;border-radius:0}@media(max-width:640px){.delete-button{display:none}}.add-item-form{display:flex;align-items:center;gap:.75rem}.add-item-form:focus-within{border-color:#2563eb66;box-shadow:0 0 0 3px #2563eb1a}.add-button{background:none;border:none;padding:0;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s}.add-button:not(:disabled):hover{color:var(--primary)}.add-button:disabled{opacity:.4;cursor:not-allowed}.add-input{flex:1;background:transparent;border:none;color:var(--text-main);font-size:1rem;padding:.5rem 0;outline:none;min-width:0;word-break:break-word;overflow-wrap:anywhere}.add-input::placeholder{color:#94a3b8}.loading,.error{padding:2rem;text-align:center;color:var(--text-muted)}.error{color:#dc2626}.sort-button{background:none;border:none;padding:.25rem;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s,transform .2s;flex-shrink:0}.sort-button:hover:not(:disabled){color:#7c3aed;transform:scale(1.15)}.shuffle-button:hover:not(:disabled){color:#ea580c;transform:scale(1.15)}.sort-button:disabled{cursor:not-allowed}@keyframes sparkle-spin{0%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) scale(1.25);opacity:.7}to{transform:rotate(360deg) scale(1);opacity:1}}.sort-button--sorting{color:#7c3aed!important;animation:sparkle-spin 1s linear infinite}@keyframes sort-shimmer{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.shopping-list--sorting .shopping-item{animation:sort-shimmer 1.2s ease-in-out infinite;pointer-events:none}.shopping-list--sorting .shopping-item:nth-child(2){animation-delay:.1s}.shopping-list--sorting .shopping-item:nth-child(3){animation-delay:.2s}.shopping-list--sorting .shopping-item:nth-child(4){animation-delay:.3s}.shopping-list--sorting .shopping-item:nth-child(5){animation-delay:.4s}.shopping-list--sorting .shopping-item:nth-child(6){animation-delay:.5s}@keyframes comment-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sort-comment{display:flex;align-items:flex-start;gap:.5rem;padding:.65rem .85rem;background:#7c3aed14;border:1px solid rgba(124,58,237,.2);border-radius:10px;animation:comment-fade-in .25s ease-out;font-size:.85rem;color:#5b21b6;line-height:1.4}.sort-comment__icon{flex-shrink:0;font-size:.9rem;margin-top:1px}.sort-comment__text{flex:1}.sort-comment__dismiss{background:none;border:none;cursor:pointer;color:#7c3aed;font-size:1.1rem;line-height:1;padding:0 0 0 .25rem;opacity:.6;transition:opacity .15s;flex-shrink:0}.sort-comment__dismiss:hover{opacity:1}.settings-page{width:100%}.settings-description{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.settings-alert{padding:1rem;border-radius:12px;margin-bottom:1.5rem;font-size:.95rem;font-weight:500;display:flex;align-items:center}.settings-alert.success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.settings-alert.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.settings-loading{color:var(--text-muted);padding:3rem 0;text-align:center;font-size:1rem;font-weight:500}.settings-sections{display:grid;gap:1rem}.settings-editor{display:grid;gap:.9rem;padding:1rem;border-radius:16px;background:var(--card-bg);border:1px solid var(--card-border);box-shadow:0 12px 30px #0f172a0f}.settings-editor__header{display:grid;gap:.3rem}.settings-editor__title{margin:0;font-size:1.05rem;line-height:1.2}.settings-editor__description{margin:0;color:var(--text-muted);font-size:.92rem;line-height:1.55}.settings-textarea{width:100%;min-height:320px;padding:1rem;border:1px solid var(--card-border);border-radius:12px;background-color:var(--card-bg);color:var(--text-main);font-family:monospace;font-size:.95rem;line-height:1.6;resize:vertical;margin-bottom:1.5rem;box-sizing:border-box;transition:all .2s ease;box-shadow:0 2px 4px var(--card-border)}.settings-textarea:focus{outline:none;border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 2px var(--primary-light),0 4px 6px var(--card-border)}.settings-autosave{margin:0;font-size:.88rem;color:var(--text-muted);min-height:1.2em}.settings-autosave.is-saving{color:var(--primary);font-weight:600}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{background:#fff;border:1px solid var(--card-border);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:380px;box-shadow:0 1px 8px #0000000f,0 4px 24px #0000000a}.login-logo{font-size:1.1rem;font-weight:800;letter-spacing:-.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem;-webkit-user-select:none;user-select:none}.login-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;color:var(--text-main);margin:0 0 1.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--card-border)}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-field label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.login-field input{padding:.6rem .85rem;border-radius:8px;border:1px solid var(--card-border);background:var(--bg-color);color:var(--text-main);font-size:.975rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.login-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.login-error{color:#dc2626;font-size:.875rem;margin:0;padding:.5rem .75rem;background:#dc26260f;border-radius:8px;border-left:3px solid #dc2626}.login-btn{padding:.65rem;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:.975rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .15s;margin-top:.25rem}.login-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:var(--text-muted);font-size:1rem}.meal-plans-page{display:grid;gap:.9rem}.meal-plan-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.meal-plan-toolbar__title{margin:0;border:0;padding:0}.meal-plan-toolbar__button{min-height:42px;padding:.7rem .9rem;border-radius:12px;border:0;background:var(--primary);color:#fff;font:inherit;font-weight:700;cursor:pointer;box-shadow:0 12px 22px #2563eb2e}.meal-plan-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:.95rem;box-shadow:0 12px 30px #0f172a0f}.meal-plan-card--form{position:relative;overflow:hidden}.meal-plan-card--form:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(37,99,235,.08),transparent 45%);pointer-events:none}.meal-plan-card__header{display:flex;gap:.75rem;justify-content:space-between;align-items:flex-start;margin-bottom:.7rem}.meal-plan-card__header--stacked{align-items:center}.meal-plan-card__header h2{margin:0;border:0;padding:0}.meal-plan-card__actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.meal-plan-card__ai{display:inline-flex;align-items:center;gap:.35rem;min-height:38px;padding:.42rem .72rem;border-radius:10px;border:1px solid rgba(124,58,237,.18);background:#7c3aed14;color:#6d28d9;font:inherit;font-weight:700;font-size:.9rem;line-height:1;cursor:pointer}.meal-plan-card__ai:hover:not(:disabled){background:#7c3aed1f}.meal-plan-card__ai:disabled{opacity:.65;cursor:not-allowed}.meal-plan-card__ai--running{animation:meal-plan-ai-pulse 1.1s ease-in-out infinite}@keyframes meal-plan-ai-pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.meal-plan-card__delete{display:inline-flex;align-items:center;justify-content:center;width:38px;min-height:38px;padding:0;border-radius:10px;border:1px solid rgba(220,38,38,.18);background:#dc262614;color:#b91c1c;font:inherit;cursor:pointer}.meal-plan-eyebrow{margin:0 0 .25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary)}.meal-plan-description,.meal-slot__participants{margin:0;color:var(--text-muted);font-size:.88rem}.meal-plan-form{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.meal-plan-form label{display:grid;gap:.35rem;font-size:.84rem;font-weight:600;color:var(--text-main)}.meal-plan-form input,.meal-plan-form select,.meal-plan-form button{min-height:40px;border-radius:10px;border:1px solid rgba(148,163,184,.45);padding:.65rem .8rem;font:inherit}.meal-plan-form input,.meal-plan-form select{background:#ffffffeb;color:var(--text-main)}.meal-plan-form__actions{display:flex;align-items:end}.meal-plan-form button{cursor:pointer;background:var(--primary);color:#fff;font-weight:700;box-shadow:0 12px 22px #2563eb2e}.meal-plan-feedback{margin:.45rem 0 0;font-weight:600;font-size:.88rem}.meal-plan-feedback--error{color:#b91c1c}.meal-plan-feedback--success{color:#047857}.meal-plan-sync-modal__comment{margin:0;padding:.7rem .85rem;border-radius:12px;background:#2563eb14;border:1px solid rgba(37,99,235,.15);color:var(--text-main);font-size:.9rem;line-height:1.5}.meal-plan-sync-summary{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.meal-plan-sync-summary__item{display:grid;gap:.1rem;padding:.75rem .8rem;border-radius:12px;background:#f1f5f9d1;border:1px solid rgba(148,163,184,.25)}.meal-plan-sync-summary__item strong{font-size:1.2rem;line-height:1;color:var(--text-main)}.meal-plan-sync-summary__item span{font-size:.82rem;color:var(--text-muted)}.meal-plan-sync-modal__grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.meal-plan-sync-modal__section{display:grid;gap:.45rem}.meal-plan-sync-modal__section h3{margin:0;font-size:.92rem;color:var(--text-main)}.meal-plan-sync-modal__empty{margin:0;color:var(--text-muted);font-size:.88rem}.meal-plan-sync-list{display:grid;gap:.35rem}.meal-plan-sync-item{display:grid;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:.55rem;padding:.65rem .75rem;border-radius:12px;background:#ffffffc7;border:1px solid rgba(148,163,184,.25);cursor:pointer}.meal-plan-sync-item input{margin:0;accent-color:var(--primary)}.meal-plan-sync-item__title{min-width:0;word-break:break-word;overflow-wrap:anywhere;color:var(--text-main);font-weight:600}.meal-plan-sync-item__badge{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.meal-plan-sync-item--removal .meal-plan-sync-item__badge{color:#b91c1c}.meal-plan-sync-item--addition .meal-plan-sync-item__badge{color:#047857}.meal-plan-sync-item--modification .meal-plan-sync-item__badge{color:#6d28d9}.meal-plan-sync-item__arrow{margin:0 .35rem;color:var(--text-muted);font-weight:800}.meal-plan-sync-item.is-selected{border-color:#2563eb5c;background:#dbeafe80}.meal-plan-sync-modal__actions{margin-top:.2rem}.meal-plan-sync-modal__apply{min-width:170px}.meal-plan-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:grid;place-items:center;padding:.75rem}.meal-plan-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.meal-plan-modal__content{position:relative;width:min(720px,calc(100vw - 1rem));max-height:calc(100dvh - 1rem);overflow:auto}.meal-plan-sync-modal{width:min(880px,calc(100vw - 1rem))}.meal-plan-modal__close{border:0;background:#94a3b82e;color:var(--text-main);width:36px;height:36px;border-radius:999px;font-size:1.25rem;line-height:1;cursor:pointer}.meal-plan-list{display:grid;gap:.75rem}.meal-plan-days{display:grid;gap:.55rem}.meal-plan-shared{display:grid;gap:.35rem;margin-bottom:.6rem}.meal-plan-shared__grid{display:grid;gap:.45rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.meal-plan-day,.meal-plan-shared__status{padding:.34rem .42rem .34rem .18rem;border-radius:14px;background:linear-gradient(180deg,#ffffffd1,#f8fafcad);border:1px solid rgba(148,163,184,.24);box-shadow:0 8px 22px #0f172a0a}.meal-plan-day--today{border-color:#2563eb73;box-shadow:inset 0 0 0 1px #2563eb2e;background:linear-gradient(180deg,#dbeafeb8,#ffffffc2)}.meal-plan-day__layout{display:grid;grid-template-columns:max-content minmax(0,1fr);column-gap:.12rem;align-items:center;min-width:0}.meal-plan-day__rail{display:flex;align-items:center;justify-content:flex-start;min-width:0;padding:0}.meal-plan-day__rail-label{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.18rem;transform:none}.meal-plan-day__date-rotated{font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-main);writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap}.meal-plan-day__content{flex:1 1 auto;display:flex;flex-direction:column;gap:.45rem;min-width:0}.meal-plan-day__content>*{margin:0}.meal-plan-day__badge{display:inline-flex;align-items:center;min-height:20px;padding:.05rem .45rem;border-radius:999px;background:#2563eb24;color:var(--primary);font-size:.68rem;font-weight:800;letter-spacing:.03em}.meal-plan-day__meals{display:grid;gap:.45rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.meal-slot{padding:.5rem .6rem;border-radius:12px;background:#dbeafe75;border:1px solid rgba(96,165,250,.28)}.meal-slot--shared{padding:.55rem .65rem;background:#f1f5f9b8;border-color:#94a3b840}.meal-slot--inactive{background:#f1f5f9bf;border-color:#94a3b838}.meal-slot--nearest{border-color:#0ea5e980;box-shadow:0 0 0 1px #0ea5e92e;background:linear-gradient(180deg,#e0f2fee6,#ffffffe6)}.meal-slot__label{display:flex;align-items:center;justify-content:flex-start;gap:.4rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);margin-bottom:.2rem}.meal-slot__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.22rem}.meal-slot__header .meal-slot__label{margin-bottom:0;flex:0 0 auto}.meal-slot__title{font-size:.92rem;font-weight:700;color:var(--text-main);margin-bottom:.15rem}.meal-slot__input{width:100%;min-height:36px;margin-bottom:0;padding:.22rem .38rem;border-radius:10px;border:1px solid rgba(148,163,184,.4);background:#fffffff2;color:var(--text-main);font:inherit;line-height:1.35;resize:vertical}.meal-slot__input--shared{margin-bottom:0;min-height:38px}.meal-slot__participants-editor{display:flex;flex-wrap:wrap;gap:.2rem}.meal-slot__participants-editor--inline{justify-content:flex-end;flex:1 1 auto}.meal-slot__participants--inline{margin:0;padding-top:.02rem;font-size:.74rem;font-weight:600;color:var(--text-muted)}.meal-slot__participant-option{display:inline-flex;align-items:center;gap:0;padding:.12rem .28rem;border-radius:999px;background:#ffffffb8;border:1px solid rgba(148,163,184,.3);color:var(--text-muted);font-size:.74rem;cursor:pointer;line-height:1.1;white-space:nowrap;box-shadow:none}.meal-slot__participant-option.is-selected{background:#2563eb1f;border-color:#2563eb47;color:var(--primary)}.meal-slot__participant-option.is-selected span{color:var(--text-main)}@media(max-width:640px){.meal-plan-shared__grid,.meal-plan-day__meals{grid-template-columns:1fr}.meal-plan-day{padding:.28rem .34rem .28rem .12rem}.meal-plan-day__layout{grid-template-columns:max-content minmax(0,1fr);column-gap:.08rem;align-items:center}.meal-plan-day__date-rotated{font-size:.58rem;letter-spacing:.05em}.meal-plan-day__meals{gap:.38rem}}.meal-plan-empty{padding:.9rem;text-align:center;color:var(--text-muted);border:1px dashed rgba(148,163,184,.45);border-radius:14px;background:#ffffff94}.meal-plan-confirm-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.meal-plan-confirm-actions__secondary,.meal-plan-confirm-actions__danger{min-height:40px;padding:.65rem .9rem;border-radius:10px;font:inherit;font-weight:700;cursor:pointer}.meal-plan-confirm-actions__secondary{border:1px solid rgba(148,163,184,.35);background:#ffffffeb;color:var(--text-main)}.meal-plan-confirm-actions__danger{border:1px solid rgba(220,38,38,.18);background:#dc2626;color:#fff}@media(max-width:768px){.meal-plan-toolbar,.meal-plan-card__header,.meal-plan-card__header--stacked{flex-direction:column;align-items:stretch}.meal-plan-card__actions,.meal-plan-confirm-actions,.meal-plan-form__actions{justify-content:stretch}.meal-plan-sync-modal__actions{flex-direction:column}.meal-plan-sync-modal__apply{min-width:0}}@media(max-width:640px){.meal-plans-page{gap:.75rem}.meal-plan-card,.meal-plan-modal__content{padding:.8rem;border-radius:14px}.meal-plan-toolbar__title{font-size:1.15rem;line-height:1.15}.meal-plan-toolbar__button{width:100%;justify-content:center}.meal-plan-form{grid-template-columns:1fr}.meal-plan-day__meals{grid-template-columns:1fr;gap:.5rem}.meal-plan-day{padding:.34rem .34rem .34rem .02rem}.meal-slot{padding:.65rem .7rem}.meal-slot__label{flex-wrap:wrap}.meal-slot__participants-editor{display:flex;flex-wrap:wrap}.meal-slot__participant-option{border-radius:10px;width:auto}.meal-plan-card__delete,.meal-plan-modal__close{width:36px;min-height:36px;height:36px}.meal-plan-sync-item{grid-template-columns:18px minmax(0,1fr)}.meal-plan-sync-item__badge{grid-column:2;justify-self:start}}.main-content{min-height:100dvh;padding-top:56px;display:flex;align-items:flex-start;justify-content:center;padding-bottom:5rem}.app{max-width:900px;width:90%;margin:0 auto;display:flex;flex-direction:column;align-items:stretch;padding-top:2.5rem}.page{width:100%;display:flex;flex-direction:column;gap:1.5rem}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;color:var(--text-main);margin:0}.card{margin-top:1rem;padding:2rem;width:100%;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;box-shadow:0 1px 8px #0000000f,0 4px 24px #0000000a;text-align:left}.card p{margin:1rem 0;font-size:1.05rem;color:var(--text-muted);display:flex;flex-direction:column;gap:.25rem}.card p strong{color:var(--text-main);font-size:.85rem;text-transform:uppercase;letter-spacing:1px}.status-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:8px;background-color:#10b981;box-shadow:0 0 10px #10b981}@media(max-width:640px){.app{padding-top:.5rem}.page-title{display:none}.add-item-form{left:0;right:0;width:100%;border-radius:0;border-left:none;border-right:none;border-bottom:none}}.add-item-form{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:90%;max-width:900px;border-top:1px solid rgba(0,0,0,.1);border-bottom:none;border-radius:12px 12px 0 0;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.75rem 1rem;box-shadow:0 -2px 12px #00000012;z-index:100}
