:root{--canvas: #FFFAF0;--surface-soft: #FAF5E8;--surface-card: #F5F0E0;--surface-strong: #EBE6D6;--hairline: #E5E5E5;--hairline-soft: #F0F0F0;--ink: #36202B;--ink-strong: #1A1A1A;--body: #3A3A3A;--muted: #6A6A6A;--muted-soft: #9A9A9A;--pink-primary: #C13E66;--pink-primary-active: #A23355;--pink-soft-bg: #FCE7EE;--pink-tint: #FFF0F4;--accent-mint: #A4D4C5;--accent-mint-bg: #E8F2EC;--accent-mint-ink: #2D5526;--accent-peach: #FFB084;--accent-peach-bg: #FFEDDF;--accent-peach-ink: #8C5615;--accent-coral: #FF6B5A;--accent-lavender: #B8A4ED;--accent-ochre: #E8B94A;--accent-error: #DC3246;--accent-error-bg: #FCE8EB;--accent-error-ink: #8A1F2E;--accent-success: #22C55E;--accent-warning: #F59E0B;--on-primary: #FFFFFF;--on-dark: #FFFFFF;--shade-overlay-strong: rgba(54, 32, 43, .86);--shade-overlay-medium: rgba(54, 32, 43, .55);--shade-overlay-soft: rgba(54, 32, 43, .2);--space-xxs: 4px;--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-xxl: 48px;--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-pill: 9999px;--radius-card: var(--radius-lg);--touch-target: 44px;--shadow-soft: 0 1px 2px rgba(54, 32, 43, .04), 0 2px 8px rgba(54, 32, 43, .06);--shadow-lift: 0 4px 12px rgba(54, 32, 43, .08), 0 1px 3px rgba(54, 32, 43, .06);--shadow-pop: 0 8px 24px rgba(54, 32, 43, .12), 0 2px 6px rgba(54, 32, 43, .08);--shadow-card: var(--shadow-soft);--shadow-card-hover: var(--shadow-lift);--font-stack: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--pink-bg: var(--canvas);--pink-soft: var(--hairline);--pink-deep: var(--pink-primary);--pink-text: var(--pink-primary-active);--plum: var(--ink);--plum-soft: var(--muted);--cream: var(--canvas);--peach: var(--accent-peach-bg);--sage: var(--accent-mint-bg);--sage-text: var(--accent-mint-ink);--amber-bg: var(--accent-peach-bg);--amber-text: var(--accent-peach-ink);--line: var(--hairline-soft);--grad-sandwich: linear-gradient(135deg, #FFD9B0, #FFC080);--grad-pinwheel: linear-gradient(135deg, #FCE3E8, #F8B4C0);--grad-quesadilla: linear-gradient(135deg, #FFE0A0, #FFC050);--grad-bento: linear-gradient(135deg, #DDEAD6, #B5D4A8);--grad-thermos: linear-gradient(135deg, #FFD2C2, #FFB298);--grad-pasta: linear-gradient(135deg, #FFF0C0, #FFD680);--grad-rice-grain: linear-gradient(135deg, #F5E6CC, #E5C896);--grad-mini-muffin: linear-gradient(135deg, #FBE4CB, #F5C28E);--grad-breakfast-for-lunch: linear-gradient(135deg, #FFEEC2, #FFD080);--grad-dippable: linear-gradient(135deg, #E0DDF5, #C0BBE5);--grad-hidden-veggie: linear-gradient(135deg, #DDEAD6, #B5D4A8);--grad-vietnamese: linear-gradient(135deg, #ffd5c2 0%, #ffb088 100%);--grad-chinese: linear-gradient(135deg, #fce4cf 0%, #f29c66 100%);--grad-korean: linear-gradient(135deg, #ffd9d9 0%, #ff9aa2 100%);--grad-japanese: linear-gradient(135deg, #e6dfff 0%, #b8a6ff 100%);--grad-thai: linear-gradient(135deg, #fff2c2 0%, #ffd166 100%);--grad-american: linear-gradient(135deg, #d6eaff 0%, #8ab8e6 100%);--grad-other: linear-gradient(135deg, #ece4d6 0%, #c8b89e 100%)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-stack);color:var(--ink);background:var(--canvas);-webkit-font-smoothing:antialiased;font-feature-settings:"cv11";font-synthesis:none;font-size:16px;line-height:1.55}h1{font-size:28px;font-weight:600;line-height:1.2;letter-spacing:-.4px;color:var(--ink);margin:0 0 var(--space-md)}h2{font-size:22px;font-weight:600;line-height:1.25;letter-spacing:-.3px;color:var(--ink);margin:0 0 var(--space-md)}h3{font-size:17px;font-weight:600;line-height:1.35;letter-spacing:-.1px;color:var(--ink);margin:var(--space-md) 0 var(--space-xs)}h4{font-size:14px;font-weight:600;line-height:1.4;color:var(--muted);margin:0 0 var(--space-xs)}p{margin:0 0 var(--space-sm);color:var(--body)}button{font-family:inherit;cursor:pointer}a{color:var(--pink-deep)}input,textarea,select{font-family:inherit}.label-caps{font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.recipe-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.recipe-card-on-plan{outline:2px solid var(--accent-mint);outline-offset:-2px;box-shadow:0 0 0 4px #a4d4c540,var(--shadow-soft)}.recipe-on-plan-pill{position:absolute;bottom:8px;left:8px;padding:3px 9px;background:var(--accent-mint-bg);color:var(--accent-mint-ink);border-radius:var(--radius-pill);font-size:10.5px;font-weight:700;letter-spacing:.2px;box-shadow:0 1px 3px #00000014;pointer-events:none;transition:opacity .15s ease}.recipe-title-pill{position:absolute;top:8px;left:8px;max-width:calc(100% - 60px);padding:5px 10px;background:#ffffff8c;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-md);box-shadow:0 2px 6px #0000001a;pointer-events:none;transition:opacity .15s ease}.recipe-title-name{font-size:13.5px;line-height:1.25;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.4)}.recipe-title-main{font-weight:700;letter-spacing:-.1px}.recipe-title-sub{font-weight:500;font-size:10px;color:var(--body);letter-spacing:0}.recipe-title-source{font-size:10.5px;font-weight:500;color:var(--muted);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipe-source-pill{position:absolute;bottom:8px;right:8px;padding:3px 8px;background:#ffffff80;backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.45);border-radius:var(--radius-pill);font-size:10.5px;font-weight:600;color:var(--ink);max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 1px 4px #00000014;pointer-events:none;transition:opacity .15s ease}.recipe-card-action{opacity:0;transition:opacity .15s,transform .15s,background .15s}.recipe-card-action:hover{background:var(--pink-deep)!important;color:#fff!important;transform:scale(1.05)}@media (hover: hover) and (pointer: fine){.recipe-card:hover .recipe-card-action{opacity:1}}@media (hover: none){.recipe-card-action{opacity:.85}}.recipe-image-wrap{position:relative;overflow:hidden}.recipe-hover-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#140e12d1,#140e12f0);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);color:#fff;padding:14px 16px;display:flex;flex-direction:column;justify-content:flex-start;gap:6px;transform:translateY(100%);opacity:0;transition:transform .22s ease,opacity .22s ease;pointer-events:none}.recipe-hover-name{font-size:15px;line-height:1.25;letter-spacing:-.1px}.recipe-hover-main{font-weight:700}.recipe-hover-sub{font-weight:500;font-size:12px;opacity:.85}.recipe-hover-source{font-size:11px;font-weight:500;opacity:.7;margin-top:-2px;margin-bottom:4px}.recipe-hover-time{font-size:12.5px;font-weight:600;opacity:.95;letter-spacing:.1px}.recipe-hover-desc{font-size:12.5px;opacity:.92;line-height:1.5;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden;flex:1}.recipe-hover-add{margin-top:auto}@media (hover: hover) and (pointer: fine){.recipe-card{transition:transform .2s ease,box-shadow .2s ease}.recipe-card:hover{transform:scale(1.01);box-shadow:var(--shadow-lift)}.recipe-card:hover .recipe-hover-overlay{transform:translateY(0);opacity:1;transition:transform .22s ease .2s,opacity .22s ease .2s}.recipe-card:hover .recipe-title-pill,.recipe-card:hover .recipe-source-pill,.recipe-card:hover .recipe-on-plan-pill{opacity:0;transition:opacity .15s ease}.recipe-card:hover .recipe-top-cluster>span{opacity:0;transition:opacity .15s ease}}.detail-grid{display:block}@media (min-width: 900px){.detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start}.detail-image-col{position:sticky;top:80px}}.detail-photo-wrap{position:relative;border-radius:var(--radius-card);overflow:hidden}.detail-photo-controls{position:absolute;right:10px;bottom:10px;display:none;gap:6px;padding:6px;background:#ffffffeb;border-radius:var(--radius-pill);box-shadow:var(--shadow-lift);opacity:0;transition:opacity .1s ease;pointer-events:none;z-index:3}.detail-photo-ctrl-btn{width:34px;height:34px;border-radius:var(--radius-pill);border:none;background:#fff;font-size:15px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--plum);transition:background .12s ease,transform .12s ease}.detail-photo-ctrl-btn:hover{background:var(--pink-soft);transform:scale(1.05)}.detail-photo-ctrl-btn:disabled{opacity:.5;cursor:default}.detail-photo-url-bar{position:absolute;left:10px;right:10px;bottom:56px;display:flex;gap:6px;padding:8px;background:#fffffff5;border-radius:var(--radius-sm);box-shadow:var(--shadow-lift);z-index:4}.detail-photo-url-input{flex:1;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--hairline);font-size:13px}.detail-photo-url-save{padding:6px 12px;border-radius:var(--radius-sm);background:var(--pink-primary);color:#fff;border:none;font-weight:600;font-size:12px}.detail-photo-url-save:disabled{opacity:.5}.detail-photo-url-cancel{width:28px;border:none;background:transparent;color:var(--plum-soft);font-size:14px;cursor:pointer}.detail-photo-edit-icon{position:absolute;right:12px;bottom:12px;width:40px;height:40px;border-radius:var(--radius-pill);border:none;background:#ffffffe6;color:var(--plum);font-size:18px;box-shadow:var(--shadow-lift);display:inline-flex;align-items:center;justify-content:center;z-index:3;cursor:pointer}.detail-photo-busy{position:absolute;inset:0;background:#ffffff8c;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--plum);z-index:5}.detail-photo-error{position:absolute;left:10px;right:10px;bottom:10px;background:var(--accent-error);color:var(--on-primary);font-size:12px;padding:6px 10px;border-radius:var(--radius-sm);z-index:6}@media (hover: hover) and (pointer: fine){.detail-photo-controls{display:inline-flex}.detail-photo-wrap:hover .detail-photo-controls,.detail-photo-wrap:focus-within .detail-photo-controls{opacity:1;pointer-events:auto}.detail-photo-edit-icon{display:none}}.detail-photo-sheet-backdrop{position:fixed;inset:0;background:var(--shade-overlay-medium);z-index:50;animation:fadeIn .15s ease}.detail-photo-sheet{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);padding:16px 16px calc(16px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:8px;z-index:51;box-shadow:0 -8px 24px var(--shade-overlay-soft);animation:slideUp .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.detail-photo-sheet-btn{padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--hairline);background:#fff;color:var(--plum);font-size:15px;font-weight:600;text-align:left;cursor:pointer}.detail-photo-sheet-btn.primary{background:var(--pink-primary);color:var(--on-primary);border-color:var(--pink-primary)}.detail-photo-sheet-btn.ghost{border-color:transparent;color:var(--plum-soft);text-align:center}.detail-photo-sheet-btn.cancel{border-color:transparent;background:var(--pink-bg);text-align:center;margin-top:4px}.detail-photo-sheet-btn:disabled{opacity:.5;cursor:default}.detail-photo-sheet-input{padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--hairline);font-size:15px}.detail-stat-bar{display:flex;flex-wrap:wrap;gap:0;margin:12px 0 14px;padding:10px 0;border-top:1px solid var(--pink-soft);border-bottom:1px solid var(--pink-soft)}.detail-stat{display:flex;flex-direction:column;gap:2px;padding:0 14px;border-left:1px solid var(--pink-soft);min-width:70px}.detail-stat:first-child{border-left:none;padding-left:0}.detail-stat-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--plum-soft);font-weight:600}.detail-stat-value{font-size:14px;font-weight:600;color:var(--plum)}.detail-meta-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:8px}.recipe-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}@media (min-width: 700px){.recipe-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}}@media (min-width: 1100px){.recipe-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.more-filters-toggle{padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--hairline);background:#fff;color:var(--ink);font-size:12px;font-weight:600;display:inline-flex;align-items:center;height:44px;cursor:pointer}.more-filters-count-badge{display:inline-flex;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:var(--radius-pill);background:var(--pink-primary);color:var(--on-primary);font-size:10px;align-items:center;justify-content:center}.more-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px;overflow:hidden;max-height:0;opacity:0;margin-top:0;transition:max-height .2s ease,opacity .18s ease,margin-top .2s ease}.more-filters.open{max-height:200px;opacity:1;margin-top:8px}@media (max-width: 600px){.more-filters-toggle,.more-filters-count-badge{font-size:11px}}.shopping-section-head{font-size:13px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:6px 0}.settings-card-head{font-size:13px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:0 0 var(--space-md)}.add-to-plan-modal{position:fixed;inset:0;z-index:200;background:#36202b8c;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.add-to-plan-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:640px;box-shadow:var(--shadow-pop)}.add-to-plan-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);gap:var(--space-md)}.add-to-plan-close{background:transparent;border:none;cursor:pointer;font-size:24px;line-height:1;color:var(--muted);padding:4px 8px;border-radius:var(--radius-sm)}.add-to-plan-week-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);gap:var(--space-sm)}.add-to-plan-nav-btn{width:36px;height:36px;background:#fff;color:var(--ink);border:1px solid var(--hairline);border-radius:var(--radius-md);font-size:14px;cursor:pointer}.add-to-plan-week-label{font-weight:600;font-size:14px;color:var(--ink)}.add-to-plan-grid{display:grid;gap:6px}.add-to-plan-day-head{text-align:center;padding:6px 4px}.add-to-plan-mt-label{display:flex;align-items:center;justify-content:flex-start;padding:0 4px}.add-to-plan-cell{min-height:56px;padding:8px 6px;background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--radius-md);font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;text-align:center;font-family:inherit}.add-to-plan-cell:hover{background:var(--pink-tint);border-color:var(--pink-primary)}.add-to-plan-cell-same{background:var(--accent-mint-bg);color:var(--accent-mint-ink);border-color:transparent;cursor:default}.add-to-plan-cell-same:hover{background:var(--accent-mint-bg);border-color:transparent}.add-to-plan-cell-other{background:#fff;color:var(--muted)}@media (max-width: 600px){.add-to-plan-grid{gap:4px}.add-to-plan-cell{min-height:48px;padding:6px 4px;font-size:11px}}.recipe-hover-add{align-self:flex-start;margin-top:var(--space-xs);padding:7px 12px;border-radius:var(--radius-md);background:var(--pink-primary);color:var(--on-primary);border:none;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;pointer-events:auto}.recipe-hover-add:hover{background:var(--pink-primary-active)}.detail-photo-wrap.focus-mode{cursor:crosshair}.detail-photo-wrap.focus-mode:before{content:"Click where the food is";position:absolute;top:12px;left:50%;transform:translate(-50%);background:var(--shade-overlay-strong);color:#fff;padding:6px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;z-index:20;pointer-events:none;white-space:nowrap}.detail-photo-wrap.focus-mode .detail-photo-controls,.detail-photo-wrap.focus-mode .detail-photo-edit-icon{display:none}.detail-photo-ctrl-btn.active{background:var(--pink-primary);color:var(--on-primary)}
