:root{--bg: #efece2;--card: #fbfaf5;--ink: #29271f;--ink-soft: #6e6a5b;--accent: #3e6b4f;--accent-deep: #2c4f3a;--accent-soft: #e1eadc;--amber: #a5722e;--amber-soft: #f1e6d0;--gold: #c9952c;--shadow: 0 4px 16px rgba(80, 76, 56, .1);--shadow-lift: 0 10px 28px rgba(80, 76, 56, .18);--radius: 18px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Nunito,Segoe UI,system-ui,sans-serif;line-height:1.55}h1,h2,h3{font-family:Fraunces,Georgia,serif;margin:0}button{font-family:inherit;cursor:pointer}.app{max-width:1100px;margin:0 auto;padding:24px 20px 120px}.header{position:relative;display:grid;grid-template-columns:1.25fr .75fr;min-height:330px;margin:12px 0 28px;background:var(--accent-deep);border-radius:30px;overflow:hidden;box-shadow:var(--shadow-lift)}.header:before{content:"";position:absolute;width:280px;height:280px;left:-110px;bottom:-190px;border:1px solid rgba(255,255,255,.13);border-radius:50%;box-shadow:0 0 0 35px #ffffff09,0 0 0 70px #ffffff06}.hero-copy{position:relative;z-index:1;align-self:center;padding:clamp(34px,6vw,68px)}.header h1{color:#fffdf5;font-size:clamp(3.1rem,7vw,5.4rem);font-weight:700;line-height:.95;letter-spacing:-.045em}.hero-eyebrow,.filter-eyebrow{color:#e3bd72;font-size:.76rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;margin:0 0 12px}.dedication{display:inline-block;color:#f5d99d;font-family:Fraunces,Georgia,serif;font-size:1rem;font-weight:600;margin:22px 0 0;padding-top:14px;border-top:1px solid rgba(255,255,255,.2)}.tagline{color:#d9e2d8;font-size:1.08rem;margin:20px 0 0;max-width:570px}.hero-feature{position:relative;display:flex;align-items:flex-end;justify-content:center;min-height:330px;padding:34px;background:linear-gradient(145deg,#dbe5ca,#b8cb9d);overflow:hidden}.hero-sun{position:absolute;top:28px;right:34px;color:#d5a84d;font-size:3.4rem;line-height:1}.hero-bowl{position:absolute;top:62px;display:flex;align-items:flex-end;justify-content:center;width:190px;height:135px;font-size:3.4rem;letter-spacing:-18px;padding-right:18px;border-bottom:54px solid #f5e7c9;border-radius:0 0 95px 95px;filter:drop-shadow(0 12px 12px rgba(57,75,48,.18))}.hero-bowl span:nth-child(2){transform:translateY(-14px) rotate(-12deg)}.hero-count{position:relative;z-index:1;display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;color:var(--accent-deep);background:#fffdf5b8;border:1px solid rgba(255,255,255,.55);border-radius:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hero-count strong{font-family:Fraunces,Georgia,serif;font-size:2.3rem;line-height:1}.hero-count span{max-width:130px;font-size:.85rem;font-weight:800;line-height:1.25}.random-panel{display:grid;grid-template-columns:minmax(220px,.72fr) minmax(0,1.28fr);align-items:center;gap:24px;margin-bottom:22px;padding:22px;color:var(--ink);background:linear-gradient(135deg,var(--amber-soft),#f6efdf);border:1px solid #dfcfad;border-radius:22px;box-shadow:var(--shadow)}.random-copy h2{color:var(--accent-deep);font-size:1.65rem;line-height:1.1}.random-copy p:last-child{color:var(--ink-soft);font-size:.9rem;margin:7px 0 0}.random-controls{display:grid;gap:10px}.meal-options{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.meal-option{min-height:44px;padding:8px;color:var(--ink-soft);font-size:.82rem;font-weight:800;background:#fffdf9b8;border:1px solid #dfcfad;border-radius:11px;transition:all .15s}.meal-option span{display:block;font-size:1.15rem;line-height:1.1}.meal-option:hover,.meal-option.active{color:#fff;background:var(--amber);border-color:var(--amber)}.random-button{display:flex;align-items:center;justify-content:space-between;min-height:46px;padding:10px 15px;color:#fff;font-size:.9rem;font-weight:800;background:var(--accent-deep);border:0;border-radius:12px;transition:background .15s,transform .15s}.random-button:hover{background:var(--accent);transform:translateY(-1px)}.random-button span{font-size:1.2rem}.filter-panel{position:sticky;top:10px;z-index:20;margin-bottom:24px;padding:18px;background:#fbfaf5f0;border:1px solid #ded8c5;border-radius:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.filter-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:14px}.filter-heading h2{color:var(--accent-deep);font-size:1.55rem;line-height:1}.filter-eyebrow{color:var(--amber);margin-bottom:5px}.result-count{color:var(--ink-soft);font-size:.86rem;margin:0}.result-count strong{color:var(--accent-deep);font-size:1.1rem}.filter-status{display:flex;align-items:center;gap:10px}.filter-reset{min-height:32px;padding:5px 10px;color:var(--accent-deep);font-size:.76rem;font-weight:800;background:var(--accent-soft);border:1px solid #c8d9c2;border-radius:8px}.filter-reset:hover{background:#d3e2cd}.search-wrap{position:relative;display:block}.search{width:100%;padding:13px 74px 13px 46px;font-size:1rem;font-family:inherit;color:var(--ink);background:#f3efe3;border:1.5px solid transparent;border-radius:14px;outline:none;transition:border-color .15s,box-shadow .15s}.search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-icon{position:absolute;z-index:1;top:50%;left:17px;color:var(--accent-deep);font-size:1.35rem;line-height:1;transform:translateY(-54%)}.search-clear{position:absolute;top:50%;right:9px;padding:5px 10px;color:var(--accent-deep);font-size:.78rem;font-weight:800;background:var(--accent-soft);border:0;border-radius:8px;transform:translateY(-50%)}.tabs{display:flex;gap:7px;margin-top:12px;padding-bottom:1px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#c8c0a9 transparent}.tabs::-webkit-scrollbar{height:5px}.tabs::-webkit-scrollbar-thumb{background:#c8c0a9;border-radius:99px}.tab{flex:0 0 auto;display:flex;align-items:center;gap:8px;min-height:42px;padding:8px 9px 8px 13px;color:var(--ink-soft);font-size:.86rem;font-weight:700;background:transparent;border:1px solid #ddd8c6;border-radius:11px;transition:all .15s}.tab:hover{border-color:var(--accent);color:var(--accent-deep)}.tab small{min-width:24px;padding:2px 6px;color:var(--ink-soft);font-size:.7rem;background:#eae5d4;border-radius:7px}.tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.tab.active small{color:var(--accent-deep);background:#fff}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}.card-hero{position:relative;display:flex;align-items:center;justify-content:center;height:130px}.card-emoji{font-size:3.4rem;filter:drop-shadow(0 4px 6px rgba(0,0,0,.12));transition:transform .18s}.card:hover .card-emoji{transform:scale(1.12) rotate(-4deg)}.fav-btn{position:absolute;top:10px;right:10px;width:36px;height:36px;font-size:1.15rem;line-height:1;color:var(--accent-deep);background:#fffdf9d9;border:none;border-radius:50%;box-shadow:0 2px 6px #0000001f;transition:transform .15s}.fav-btn:hover{transform:scale(1.12)}.fav-btn.fav-on{color:#fff;background:var(--accent)}.card-body{padding:14px 16px 18px}.card-category{display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);background:var(--amber-soft);padding:3px 10px;border-radius:999px;margin-bottom:8px}.card-title{font-size:1.12rem;font-weight:600;line-height:1.3;margin-bottom:10px}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{font-size:.8rem;font-weight:700;color:var(--ink-soft);background:#eae5d4;padding:4px 11px;border-radius:999px}.chip-kcal{color:var(--accent-deep);background:var(--accent-soft)}.chip-protein{color:var(--amber);background:var(--amber-soft)}.chip-serves{color:#50613e;background:#e0e8d4}.serving-size{margin-top:9px;color:var(--ink-soft);font-size:.84rem;line-height:1.4}.detail-serving{margin-top:5px;font-size:.95rem}.empty{text-align:center;color:var(--ink-soft);font-size:1.05rem;padding:60px 20px}.empty p{margin:0 0 14px}.footer{text-align:center;color:var(--ink-soft);font-size:.9rem;padding-top:36px}.detail{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-top:12px;animation:rise .25s ease}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}.detail-hero{position:relative;display:flex;align-items:center;justify-content:center;height:200px}.detail-emoji{font-size:5.5rem;filter:drop-shadow(0 6px 10px rgba(0,0,0,.14))}.back-btn{position:absolute;top:14px;left:14px;padding:8px 16px;font-size:.92rem;font-weight:700;color:var(--ink);background:#fffdf9e6;border:none;border-radius:999px;box-shadow:0 2px 6px #0000001f}.back-btn:hover{background:#fff}.detail-fav{top:14px;right:14px;width:42px;height:42px;font-size:1.3rem}.detail-body{padding:26px clamp(18px,5vw,44px) 38px}.detail-title{font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;margin:8px 0 14px}.detail-section{margin-top:30px}.detail-section h3{font-size:1.25rem;font-weight:600}.section-hint{color:var(--ink-soft);font-size:.88rem;margin:4px 0 12px}.ingredient-list{list-style:none;margin:12px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.ingredient-list li{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:#f3efe3;border-radius:12px;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.ingredient-list li:hover{background:var(--accent-soft)}.ingredient-list li.checked{color:var(--ink-soft);text-decoration:line-through;background:var(--amber-soft)}.checkbox{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin-top:1px;font-size:.85rem;font-weight:800;color:#fff;background:#fff;border:2px solid #c4bda6;border-radius:7px;transition:all .15s}.checked .checkbox{background:var(--amber);border-color:var(--amber)}.steps-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.progress-label{font-size:.88rem;font-weight:700;color:var(--ink-soft)}.progress-track{height:8px;background:#e6e0cf;border-radius:999px;margin:10px 0 18px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--amber));border-radius:999px;transition:width .3s ease}.step-list{list-style:none;margin:0;padding:0}.step-list li{display:flex;gap:14px;padding:14px 0;border-bottom:1px dashed #ded8c5}.step-list li:last-child{border-bottom:none}.step-list li.done p{color:var(--ink-soft);text-decoration:line-through}.step-check{flex-shrink:0;width:34px;height:34px;font-size:.95rem;font-weight:800;color:var(--accent-deep);background:var(--accent-soft);border:2px solid transparent;border-radius:50%;transition:all .15s}.step-check:hover{border-color:var(--accent)}li.done .step-check{color:#fff;background:var(--amber)}.step-content{flex:1}.step-content p{margin:5px 0 0}.timer-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.timer-start{padding:7px 14px;font-size:.86rem;font-weight:700;color:var(--accent-deep);background:var(--accent-soft);border:1.5px solid #c2d4bc;border-radius:999px;transition:all .15s}.timer-start:hover{color:#fff;background:var(--accent);border-color:var(--accent)}.tip-box{margin-top:32px;padding:18px 22px;background:var(--amber-soft);border-left:5px solid var(--amber);border-radius:12px}.tip-box strong{display:block;color:var(--amber);margin-bottom:6px}.tip-box p{margin:0}.source-line{margin-top:22px;font-size:.85rem;color:var(--ink-soft)}.source-line a{color:var(--accent-deep);font-weight:700}.timer-dock{position:fixed;bottom:18px;right:18px;z-index:50;display:flex;flex-direction:column;gap:10px;max-width:320px;width:calc(100vw - 36px)}.timer-card{background:var(--card);border:2px solid #ddd8c6;border-radius:14px;box-shadow:var(--shadow-lift);padding:12px 14px}.timer-card.timer-done{border-color:var(--accent);animation:pulse 1s ease infinite}@keyframes pulse{0%,to{box-shadow:var(--shadow-lift)}50%{box-shadow:0 0 0 6px var(--accent-soft)}}.timer-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.timer-label{font-size:.78rem;font-weight:700;color:var(--ink-soft);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.timer-close{flex-shrink:0;width:24px;height:24px;font-size:.75rem;color:var(--ink-soft);background:#eae5d4;border:none;border-radius:50%}.timer-close:hover{color:#fff;background:var(--accent)}.timer-clock{font-family:Fraunces,Georgia,serif;font-size:1.7rem;font-weight:700;color:var(--accent-deep);margin:4px 0;font-variant-numeric:tabular-nums}.timer-track{height:6px;background:#e6e0cf;border-radius:999px;overflow:hidden;margin-bottom:10px}.timer-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--amber));transition:width .5s linear}.timer-actions{display:flex;gap:8px}.timer-actions button{flex:1;padding:6px 10px;font-size:.84rem;font-weight:700;color:var(--ink);background:#eae5d4;border:none;border-radius:9px;transition:background .15s}.timer-actions button:hover{background:var(--accent-soft)}@media(max-width:780px){.app{padding-top:16px}.header{grid-template-columns:1fr;min-height:auto;margin-top:0;border-radius:24px}.hero-copy{padding:42px 32px 34px}.hero-feature{min-height:175px;padding:18px}.hero-bowl{top:5px;left:28px;width:145px;height:102px;font-size:2.6rem;border-bottom-width:42px}.hero-sun{top:14px;right:22px;font-size:2.5rem}.hero-count{width:min(300px,calc(100% - 150px));margin-left:auto}.random-panel{grid-template-columns:1fr;gap:16px}.filter-panel{position:static}}@media(max-width:540px){.app{padding:10px 10px 140px}.header{border-radius:22px}.hero-copy{padding:31px 21px 26px}.header h1{font-size:clamp(2.7rem,16vw,4rem)}.tagline{font-size:.96rem;margin-top:15px}.dedication{margin-top:17px}.hero-feature{min-height:138px;padding:12px}.hero-bowl{top:-2px;left:12px;width:112px;height:80px;font-size:2rem;border-bottom-width:33px}.hero-sun{top:9px;right:13px;font-size:1.8rem}.hero-count{width:calc(100% - 95px);margin-left:95px;padding:10px 12px}.hero-count strong{font-size:1.9rem}.hero-count span{max-width:none;font-size:.76rem}.random-panel{margin-bottom:14px;padding:16px;border-radius:17px}.random-copy h2{font-size:1.35rem}.meal-options{grid-template-columns:repeat(2,minmax(0,1fr))}.meal-option{min-height:48px}.random-button{min-height:50px}.filter-panel{padding:14px;border-radius:17px}.filter-heading{display:block}.filter-heading h2{font-size:1.3rem}.filter-status{justify-content:space-between;margin-top:10px}.search{min-height:48px;font-size:16px}.tabs{margin-right:-14px;padding-right:14px}.tab{min-height:44px}.grid{grid-template-columns:1fr;gap:14px}.card-hero{height:112px}.detail{margin-top:0;border-radius:16px}.detail-hero{height:145px}.detail-emoji{font-size:4.3rem}.back-btn{min-height:42px;padding:8px 12px;font-size:.8rem}.detail-body{padding:21px 15px 30px}.detail-section{margin-top:25px}.ingredient-list{grid-template-columns:1fr}.ingredient-list li{min-height:46px}.step-list li{gap:10px}.step-check{width:38px;height:38px}.timer-start{min-height:42px}.timer-dock{right:10px;bottom:10px;width:calc(100vw - 20px);max-width:none}}
