*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f5f0;--bg2:#ede9e1;--border:#e0ddd6;--border2:#d0ccc4;--text:#2c2c2a;--text2:#888780;--text3:#b4b2a9;--textGhost:#c8c4bc;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html{height:100%;overflow:hidden}body{background:var(--bg);width:100%;height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;font-weight:400;line-height:1.5;overflow:hidden}#root{flex-direction:column;width:100%;max-width:420px;height:100%;margin:0 auto;display:flex;position:relative;overflow:hidden}.label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);font-size:10px;font-weight:400}.label-dark{letter-spacing:1.5px;text-transform:uppercase;color:var(--text);font-size:10px;font-weight:400}.page{scrollbar-width:none;flex:1;min-height:0;padding-bottom:16px;overflow:hidden auto}.page::-webkit-scrollbar{display:none}.section-header{justify-content:space-between;align-items:center;padding:16px 16px 0;display:flex}.separator{background:var(--border);height:.5px;margin:0}.bottom-nav{background:var(--bg);border-top:.5px solid var(--border);width:100%;padding:12px 0 max(12px, env(safe-area-inset-bottom));flex-shrink:0;justify-content:space-around;display:flex}.bottom-nav button{cursor:pointer;font-family:var(--font);letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);background:0 0;border:none;border-bottom:1px solid #0000;padding:4px 16px;font-size:10px;transition:color .15s}.bottom-nav button.active{color:var(--text);border-bottom-color:var(--text)}.sub-nav{flex-wrap:wrap;gap:0;padding:8px 16px;display:flex}.sub-nav button{cursor:pointer;font-family:var(--font);letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);white-space:nowrap;background:0 0;border:none;padding:6px 16px 6px 0;font-size:10px}.sub-nav button.active{color:var(--text)}.chip{border:.5px solid var(--border2);letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);cursor:pointer;font-size:10px;font-family:var(--font);white-space:nowrap;background:0 0;padding:4px 10px;line-height:1.4;display:inline-block}.chip.active,.chip:hover{border-color:var(--text);color:var(--text)}.checkbox{border:.5px solid var(--textGhost);cursor:pointer;appearance:none;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:13px;height:13px;display:inline-flex;position:relative}.checkbox:checked{background:var(--text);border-color:var(--text)}.checkbox:checked:after{content:"";border-left:1px solid var(--bg);border-bottom:1px solid var(--bg);width:5px;height:3px;display:block;transform:rotate(-45deg)translateY(-1px)}.toggle{flex-shrink:0;width:28px;height:14px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--border);cursor:pointer;border-radius:7px;transition:background .2s;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--text)}.toggle-track:after{content:"";background:var(--bg);border-radius:50%;width:10px;height:10px;transition:transform .2s;position:absolute;top:2px;left:2px}.toggle input:checked+.toggle-track:after{transform:translate(14px)}.input{border:none;border-bottom:.5px solid var(--border);width:100%;font-family:var(--font);color:var(--text);background:0 0;outline:none;padding:10px 0;font-size:13px}.input::placeholder{color:var(--textGhost)}.input:focus{border-bottom-color:var(--border2)}.input-naked{font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:13px}.input-naked::placeholder{color:var(--textGhost)}.search-bar{border-bottom:.5px solid var(--border);padding:12px 16px}.search-bar input{font-family:var(--font);color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:13px}.search-bar input::placeholder{color:var(--textGhost)}.action-link{cursor:pointer;font-family:var(--font);letter-spacing:1.5px;text-transform:uppercase;color:var(--text);white-space:nowrap;background:0 0;border:none;flex-shrink:0;padding:0;font-size:10px}.action-link.muted{color:var(--text2)}.action-link:disabled{color:var(--textGhost);cursor:default}.recipe-item{border-bottom:.5px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.recipe-item:hover{background:var(--bg2)}.recipe-item-left{flex:1;min-width:0}.recipe-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.recipe-item-meta{letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-top:2px;font-size:10px}.recipe-item-right{letter-spacing:1px;text-transform:uppercase;color:var(--text3);text-align:right;flex-shrink:0;margin-left:12px;font-size:10px}.page-header{border-bottom:.5px solid var(--border);justify-content:space-between;align-items:baseline;padding:20px 16px 12px;display:flex}.page-header h1{letter-spacing:1.5px;text-transform:uppercase;color:var(--text);font-size:10px;font-weight:400}.page-header-count{letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-size:10px}.recipe-photo{aspect-ratio:4/3;background:var(--bg2);width:100%;overflow:hidden}.recipe-photo img{object-fit:cover;width:100%;height:100%}.recipe-title-section{border-bottom:.5px solid var(--border);padding:20px 16px 12px}.recipe-title{color:var(--text);margin-bottom:10px;font-size:15px;font-weight:400}.tags-row{flex-wrap:wrap;gap:6px;display:flex}.meta-band{border-bottom:.5px solid var(--border);scrollbar-width:none;align-items:flex-start;gap:0;padding:12px 16px;display:flex;overflow-x:auto}.meta-band::-webkit-scrollbar{display:none}.meta-item{border-right:.5px solid var(--border);flex:1;min-width:0;padding:0 12px}.meta-item:first-child{padding-left:0}.meta-item:last-child{border-right:none}.meta-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);margin-bottom:3px;font-size:9px}.meta-value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.section{border-bottom:.5px solid var(--border);padding:16px}.section-title{letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);margin-bottom:12px;font-size:10px}.ing-row{border-bottom:.5px solid var(--border);align-items:center;gap:10px;padding:6px 0;display:flex}.ing-row:last-child{border-bottom:none}.ing-name{flex:1;font-size:13px}.ing-name.checked{color:var(--text3);text-decoration:line-through}.step-row{border-bottom:.5px solid var(--border);gap:12px;padding:12px 0;display:flex}.step-row:last-child{border-bottom:none}.step-num{letter-spacing:1px;text-transform:uppercase;color:var(--text3);flex-shrink:0;min-width:20px;padding-top:2px;font-size:10px}.step-text{color:var(--text);font-size:13px;line-height:1.6}.cta-bar{background:var(--bg);border-top:.5px solid var(--border);flex-direction:column;gap:8px;padding:12px 16px;display:flex;position:sticky;bottom:57px}.modal-overlay{z-index:200;background:#2c2c2a66;justify-content:center;align-items:center;padding:24px 0;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border:.5px solid var(--border);flex-direction:column;width:100%;max-width:420px;max-height:85dvh;display:flex}.modal-header{border-bottom:.5px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px;display:flex}.modal-title{letter-spacing:1.5px;text-transform:uppercase;color:var(--text);font-size:10px}.modal-body{flex:1;overflow-y:auto}.modal-footer{border-top:.5px solid var(--border);flex-shrink:0;padding:12px 16px}.form-field{border-bottom:.5px solid var(--border);padding:14px 16px}.form-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);margin-bottom:8px;font-size:10px;display:block}.form-row{align-items:flex-start;gap:16px;display:flex}.loading{letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);text-align:center;padding:32px 16px;font-size:10px}.error-banner{background:var(--bg2);border-bottom:.5px solid var(--border);letter-spacing:1px;text-transform:uppercase;color:var(--text2);padding:12px 16px;font-size:10px}.planning-week{flex-direction:column;display:flex}.planning-day{border-bottom:.5px solid var(--border)}.planning-day-header{align-items:center;gap:8px;padding:10px 16px;display:flex}.planning-day-name{letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);min-width:60px;font-size:10px}.planning-day-name.today{color:var(--text)}.planning-slot{border-top:.5px solid var(--border);align-items:center;gap:12px;padding:8px 16px;display:flex}.planning-slot-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);flex-shrink:0;min-width:36px;font-size:9px}.planning-slot-content{color:var(--text);flex:1;font-size:12px}.planning-slot-empty button{cursor:pointer;font-family:var(--font);letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);background:0 0;border:none;padding:0;font-size:10px}.planning-slot-empty button:hover{color:var(--text)}.progress-bar{background:var(--border);height:1px;margin:0 16px}.progress-fill{background:var(--text);height:1px;transition:width .3s}.rayon-header{letter-spacing:2px;text-transform:uppercase;color:var(--text3);padding:14px 16px 6px;font-size:9px}.course-item{border-bottom:.5px solid var(--border);align-items:center;gap:12px;padding:10px 16px;display:flex}.course-item-content{flex:1;min-width:0}.course-item-name{color:var(--text);font-size:13px}.course-item-name.checked{color:var(--text3);text-decoration:line-through}.course-item-meta{letter-spacing:.5px;color:var(--text3);margin-top:2px;font-size:10px}.collapsible-header{cursor:pointer;border-bottom:.5px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.collapsible-icon{color:var(--text3);font-size:10px;transition:transform .2s}.collapsible-icon.open{transform:rotate(180deg)}@keyframes shimmer{0%{opacity:.4}50%{opacity:.7}to{opacity:.4}}.skeleton{background:var(--bg2);animation:1.4s ease-in-out infinite shimmer}.skeleton-line{background:var(--bg2);height:13px;margin:10px 16px;animation:1.4s ease-in-out infinite shimmer}.back-btn{cursor:pointer;font-family:var(--font);letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);border:none;border-bottom:.5px solid var(--border);text-align:left;background:0 0;align-items:center;gap:6px;width:100%;padding:14px 16px;font-size:10px;display:flex}.back-btn:hover{color:var(--text)}
