:root{--bg: #f4f2ec;--surface: #ffffff;--surface-2: #faf9f5;--ink: #1f2421;--ink-soft: #5b6560;--ink-faint: #97a09a;--line: #e8e5dc;--brand: #2f7a4d;--brand-soft: #e4efe7;--accent-amber: #ea8a0c;--radius: 18px;--radius-sm: 12px;--shadow: 0 1px 2px rgba(31, 36, 33, .04), 0 6px 18px rgba(31, 36, 33, .06);--shadow-lg: 0 2px 6px rgba(31, 36, 33, .06), 0 12px 30px rgba(31, 36, 33, .1);--maxw: 480px;--tabbar-h: 64px;--header-h: 60px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}ul{margin:0;padding:0;list-style:none}.app{max-width:var(--maxw);margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--bg);position:relative;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:20;background:#f4f2ecd9;backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line);padding-top:env(safe-area-inset-top)}.app-header-inner{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 18px}.header-clock{font-size:22px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;color:var(--ink)}.brand{display:flex;align-items:center;gap:11px}.brand-dot{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--brand),#3fa468);box-shadow:inset 0 0 0 2px #ffffff40;flex:none}.brand h1{font-size:16px;line-height:1.1}.brand p{margin:1px 0 0;font-size:12.5px;color:var(--ink-soft)}.app-main{flex:1;padding:16px 16px calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 18px)}.view{animation:fade .22s ease}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:30;max-width:var(--maxw);margin:0 auto;height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);display:grid;grid-template-columns:repeat(3,1fr);background:#ffffffeb;backdrop-filter:blur(14px) saturate(1.5);-webkit-backdrop-filter:blur(14px) saturate(1.5);border-top:1px solid var(--line)}.tabbar-btn{border:none;background:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--ink-faint);font-size:11px;font-weight:600;letter-spacing:.01em;transition:color .15s ease,transform .1s ease}.tabbar-btn span{line-height:1}.tabbar-btn.active{color:var(--brand)}.tabbar-btn:active{transform:scale(.92)}.section{margin-bottom:18px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:4px 2px 10px}.section-head h2{font-size:17px}.section-sub{font-size:12.5px;color:var(--ink-soft);font-weight:500}.pill{display:inline-flex;align-items:center;font-size:12px;font-weight:600;padding:4px 11px;border-radius:999px;background:var(--surface);color:var(--ink-soft);border:1px solid var(--line)}.pill-week{background:var(--brand);color:#fff;border-color:var(--brand)}.now-tags{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin:2px 2px 18px}.tag-select-wrap{position:relative;display:inline-flex}.tag-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 26px 6px 13px;box-shadow:var(--shadow);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235b6560' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 9px center;transition:transform .1s ease}.tag-select:active{transform:scale(.96)}.tag-today{border:1px solid var(--brand);background:var(--brand);color:#fff;font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:999px;box-shadow:var(--shadow);transition:transform .1s ease}.tag-today:active{transform:scale(.95)}.meal-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;border:1px solid rgba(232,229,220,.7)}.meal-card-highlight{border:1.5px solid var(--brand);box-shadow:var(--shadow-lg)}.meal-card-muted{background:var(--surface-2)}.section-past{opacity:.82}.section-sub-accent{color:var(--brand);font-weight:700}.meal-card-head{margin-bottom:12px}.slot-tag{display:flex;align-items:center;gap:8px;margin-bottom:6px}.slot-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--brand)}.slot-time{font-size:11.5px;font-weight:600;color:var(--ink-faint)}.dish{font-size:19px;line-height:1.2;letter-spacing:-.02em}.portions{display:flex;flex-direction:column;gap:2px}.portion-row{display:flex;align-items:center;gap:11px;padding:8px 0;border-top:1px solid var(--line)}.portion-row:first-child{border-top:none}.portion-text{display:flex;flex-direction:column;min-width:0}.portion-name{font-size:11.5px;font-weight:600;color:var(--ink-faint)}.portion-detail{font-size:14.5px;font-weight:500;color:var(--ink)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:700;flex:none;box-shadow:inset 0 0 0 1.5px #ffffff4d}.avatar-photo,.avatar-family{overflow:hidden;border:2px solid var(--brand);background:#fff;box-shadow:0 1px 3px #1f242124}.avatar-photo img{width:100%;height:100%;object-fit:cover;object-position:center 26%;display:block}.avatar-family{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.avatar-family img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}.prep{display:flex;align-items:flex-start;gap:9px;margin-top:12px;padding:11px 12px;background:var(--brand-soft);border-radius:var(--radius-sm);color:#235c3a}.prep svg{margin-top:1px;flex:none}.prep div{display:flex;flex-direction:column}.prep-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;opacity:.7}.prep-detail{font-size:14px;font-weight:600;line-height:1.35}.person-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.person-strip-5{grid-template-columns:repeat(5,1fr);gap:6px}.person-strip-5 .person-chip{padding:10px 2px}.person-strip-5 .person-chip-name{font-size:11px}.person-chip{display:flex;flex-direction:column;align-items:center;gap:6px;padding:11px 4px;border:1.5px solid transparent;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);transition:transform .1s ease}.person-chip:active{transform:scale(.95)}.person-chip-name{font-size:12px;font-weight:600;color:var(--ink-soft)}.person-chip.active .person-chip-name{color:var(--ink)}.person-banner{display:flex;align-items:center;gap:13px;padding:14px 16px;border-radius:var(--radius);margin-bottom:16px}.person-banner h2{font-size:20px}.person-banner p{margin:2px 0 0;font-size:12.5px;font-weight:500;color:var(--ink-soft)}.day-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:18px}.day-chip{position:relative;padding:9px 0;border-radius:10px;border:1px solid var(--line);background:var(--surface);font-size:11px;font-weight:700;letter-spacing:.02em;color:var(--ink-soft);transition:transform .1s ease}.day-chip.active{color:#fff;background:var(--brand);border-color:var(--brand)}.day-chip:active{transform:scale(.94)}.day-today-dot{position:absolute;top:4px;right:5px;width:5px;height:5px;border-radius:50%;background:var(--accent-amber)}.day-chip.active .day-today-dot{background:#fff}.person-timeline{display:flex;flex-direction:column;gap:10px}.person-meal{display:flex;gap:13px;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:13px 15px;border-left:3px solid var(--accent)}.person-meal-time{display:flex;flex-direction:column;width:74px;flex:none}.person-meal-slot{font-size:12px;font-weight:700;color:var(--ink);line-height:1.2}.person-meal-clock{font-size:11px;font-weight:600;color:var(--ink-faint)}.person-meal-body{display:flex;flex-direction:column;min-width:0}.person-meal-dish{font-size:13px;font-weight:600;color:var(--ink-soft)}.person-meal-portion{font-size:15px;font-weight:600;color:var(--ink);line-height:1.3}.person-meal-note{font-size:12.5px;font-weight:500;color:var(--ink-soft);line-height:1.3;margin-top:1px}.section-head-control{align-items:center;flex-wrap:wrap;gap:8px}.head-controls{display:flex;align-items:center;gap:7px}.family-timeline{display:flex;flex-direction:column;gap:11px}.family-meal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:13px 15px;border-left:3px solid var(--brand)}.family-meal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.family-meal-time{display:flex;flex-direction:column}.family-eaters{display:flex}.family-eaters .avatar{margin-left:-7px;border-width:1.5px}.family-eaters .avatar:first-child{margin-left:0}.family-meal-dish{font-size:16px;font-weight:700;letter-spacing:-.01em;margin:9px 0 0}.family-meal .prep{margin-top:9px}.grocery-week{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden;border:1px solid rgba(232,229,220,.7)}.grocery-week.coming{border:1.5px solid var(--brand);box-shadow:var(--shadow-lg)}.grocery-week-head{width:100%;border:none;background:none;display:flex;align-items:center;justify-content:space-between;padding:15px 16px;text-align:left}.grocery-week.coming .grocery-week-head{background:var(--brand-soft)}.grocery-week-title{display:flex;flex-direction:column;gap:2px}.week-kind{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint)}.week-kind.coming{color:var(--brand)}.grocery-week-title h2{font-size:18px}.grocery-count{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--ink-soft)}.chevron{font-size:20px;line-height:1;transform:rotate(90deg);transition:transform .2s ease;color:var(--ink-faint)}.chevron.open{transform:rotate(-90deg)}.grocery-cats{padding:4px 16px 14px}.grocery-actions{display:flex;gap:8px;padding:12px 16px 2px}.share-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:inherit;font-size:13px;font-weight:600;padding:9px 13px;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--ink);text-decoration:none;transition:transform .1s ease}.share-btn:active{transform:scale(.96)}.share-btn.whatsapp{background:#25d366;border-color:#25d366;color:#fff;flex:1}.share-btn.copy{min-width:96px}.grocery-cat{padding:12px 0;border-top:1px solid var(--line)}.grocery-cat-head{display:flex;align-items:center;gap:9px;margin-bottom:9px}.grocery-cat-emoji{font-size:17px}.grocery-cat-name{font-size:14px;font-weight:700;flex:1}.grocery-cat-count{font-size:11.5px;font-weight:600;color:var(--ink-faint);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:2px 9px}.grocery-items{display:flex;flex-direction:column;gap:2px}.grocery-item{display:flex;align-items:flex-start;gap:10px;padding:5px 0 5px 4px;font-size:14px;color:var(--ink)}.check{margin-top:3px;width:15px;height:15px;border-radius:5px;border:1.5px solid var(--line);background:var(--surface-2);flex:none}@media (min-width: 520px){.app{box-shadow:0 0 0 1px var(--line)}}
