*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F7F5F0;--surface: #FFFFFF;--surface2: #EFECE5;--border: #E2DDD5;--border2: #CBC6BC;--text: #1E1C18;--muted: #72706A;--hint: #A8A49E;--accent: #5C4A2A;--accent-bg: #F0EAE0;--accent-hover: #4A3A1E;--tag-ingr-bg: #E8F0E0;--tag-ingr-text: #2E5014;--tag-style-bg: #E8EAF8;--tag-style-text: #282E6E;--tag-custom-bg: #FDF3E0;--tag-custom-text: #7A4A00;--tag-custom-border: #EFC98A;--red-bg: #FCEBEB;--red: #791F1F;--r: 10px;--rlg: 14px;--font-display: "Playfair Display", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif}body{font-family:var(--font-body);background-color:var(--bg);background-image:url(/bg-light.svg);background-size:220px 220px;color:var(--text);font-size:15px;line-height:1.6;min-height:100vh}html.dark body{background-image:url(/bg-dark.svg)}nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:stretch;height:52px;position:sticky;top:0;z-index:100;overflow-x:auto}.nav-brand{font-family:var(--font-display);font-size:20px;color:var(--accent);font-style:italic;display:flex;align-items:center;flex:1;letter-spacing:-.3px;white-space:nowrap;margin-right:12px;cursor:pointer;background:none;border:none;padding:0;transition:opacity .15s}.nav-brand:hover{opacity:.75}.nav-tabs{display:flex;align-items:stretch;flex:1}.nav-lang{padding:5px 10px;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .15s;flex-shrink:0;align-self:center;font-family:var(--font-body);letter-spacing:.04em}.nav-lang:hover{border-color:var(--accent);color:var(--accent)}.nav-zoom{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;flex-shrink:0;align-self:center;margin-right:8px}.nav-zoom-btn{width:28px;height:28px;border:none;background:var(--surface);color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;font-family:var(--font-body);line-height:1}.nav-zoom-btn:hover:not(:disabled){background:var(--surface2);color:var(--text)}.nav-zoom-btn:disabled{opacity:.3;cursor:default}.nav-zoom-val{font-size:11px;font-weight:600;color:var(--muted);padding:0 7px;min-width:42px;text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border);height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface);font-family:var(--font-body);-webkit-user-select:none;user-select:none}@media (max-width: 1024px){.nav-zoom{display:none}}.nav-tab{background:none;border:none;border-bottom:2px solid transparent;padding:0 14px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;margin-bottom:-1px;white-space:nowrap}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.nav-tab i{font-size:15px}.page{max-width:960px;margin:0 auto;padding:28px 24px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:var(--r);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;border:1px solid var(--border);background:var(--surface);color:var(--text)}.btn:hover{border-color:var(--border2);background:var(--surface2)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.active{background:var(--accent-bg);border-color:var(--border2);color:var(--accent)}.btn.danger{border-color:#e24b4a;color:#a32d2d}.btn.danger:hover{background:var(--red-bg)}.btn.orange{background:#e8620a;border-color:#e8620a;color:#fff}.btn.orange:hover{background:#cf5508;border-color:#cf5508}html.dark .btn.orange{background:#f07020;border-color:#f07020}html.dark .btn.orange:hover{background:#d85e10;border-color:#d85e10}.btn:disabled{opacity:.45;cursor:default}.btn i{font-size:15px}.tags{display:flex;gap:5px;flex-wrap:wrap}.tag{padding:3px 9px;border-radius:99px;font-size:11px;font-weight:500}.tag.ingr{background:var(--tag-ingr-bg);color:var(--tag-ingr-text)}.tag.style{background:var(--tag-style-bg);color:var(--tag-style-text)}.tag.custom{background:var(--tag-custom-bg);color:var(--tag-custom-text);border:1px solid var(--tag-custom-border)}.filter-section{margin-bottom:20px}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:5px;align-items:center}.filter-label{font-size:11px;font-weight:500;color:var(--hint);text-transform:uppercase;letter-spacing:.06em;margin-right:2px;flex-shrink:0}.pill{background:none;border:1px solid var(--border);padding:4px 11px;border-radius:99px;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;font-family:var(--font-body)}.pill:hover{border-color:var(--border2);color:var(--text)}.pill.active-ingr{background:var(--tag-ingr-bg);border-color:#9fe1cb;color:var(--tag-ingr-text)}.pill.active-style{background:var(--tag-style-bg);border-color:#afa9ec;color:var(--tag-style-text)}.pill.active-custom{background:var(--tag-custom-bg);border-color:var(--tag-custom-border);color:var(--tag-custom-text)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}.card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #2c24141a;border-color:var(--border2)}.card-img-wrap{position:relative;width:100%;padding-top:62%;overflow:hidden;background:var(--surface2);flex-shrink:0}.card-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.card:hover .card-img{transform:scale(1.04)}.card-img-ph{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--hint);font-size:40px}.card-fav{position:absolute;top:10px;right:10px;background:#ffffffd1;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:var(--muted);transition:all .15s}.card-fav:hover{background:#fff;color:#e24b4a}.card-fav.on{color:#e24b4a;background:#fff;box-shadow:0 0 0 2px #fff}.card-body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1}.card-title{font-family:var(--font-display);font-size:16px;font-weight:500;line-height:1.35;margin-bottom:8px;color:var(--text)}.card-meta{display:flex;gap:10px;font-size:12px;color:var(--muted);margin-bottom:10px;align-items:center;flex-wrap:wrap}.card-meta i{font-size:13px;vertical-align:-1px}.toolbar{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:160px}.search-wrap input{width:100%;padding:9px 12px 9px 38px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);font-family:var(--font-body);font-size:14px;color:var(--text);outline:none;transition:border .15s}.search-wrap input:focus{border-color:var(--accent)}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--hint);font-size:17px;pointer-events:none}.sort-select{padding:9px 32px 9px 12px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);font-family:var(--font-body);font-size:13px;color:var(--text);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A8A49E' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.sec-header h2{font-family:var(--font-display);font-size:22px}.count-badge{background:var(--surface2);border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:500;padding:2px 9px;border-radius:99px;margin-left:8px}.empty{text-align:center;padding:56px 20px;color:var(--muted)}.empty i{font-size:40px;display:block;margin-bottom:14px;color:var(--hint)}.empty p{font-size:14px;line-height:1.7}.detail-hero{width:100%;max-height:320px;object-fit:cover;border-radius:var(--rlg);margin-bottom:24px;display:block}.detail-hero-ph{width:100%;height:200px;background:var(--surface2);border-radius:var(--rlg);display:flex;align-items:center;justify-content:center;color:var(--hint);font-size:52px;margin-bottom:24px}.detail-title{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.15;margin-bottom:10px}.detail-meta{display:flex;gap:14px;font-size:13px;color:var(--muted);flex-wrap:wrap;align-items:center;margin-bottom:14px}.detail-meta span{display:flex;align-items:center;gap:5px}.detail-actions{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}.detail-cols{display:grid;grid-template-columns:240px 1fr;gap:28px}.sec-title{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--accent);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.ingr-list{list-style:none}.ingr-list li{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--border);font-size:14px}.ingr-list li:last-child{border-bottom:none}.ingr-amt{color:var(--muted);font-size:13px;flex-shrink:0;margin-left:8px}.serve-ctrl{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.serve-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text);transition:all .15s}.serve-btn:hover{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.serve-input{width:52px;height:32px;text-align:center;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);background:var(--surface);outline:none;transition:border .15s}.serve-input:focus{border-color:var(--accent)}.serve-label{font-size:13px;color:var(--muted)}.step-list{list-style:none;counter-reset:steps}.step-list li{counter-increment:steps;position:relative;padding:10px 0 10px 42px;border-bottom:1px solid var(--border);font-size:14px;line-height:1.65}.step-list li:last-child{border-bottom:none}.step-list li:before{content:counter(steps);position:absolute;left:0;top:11px;width:26px;height:26px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500}.macros-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px;margin-bottom:20px}.macro-card{background:var(--surface2);border-radius:var(--r);padding:10px 12px;text-align:center}.macro-val{font-family:var(--font-display);font-size:18px;font-weight:700;display:block}.macro-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.form-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:28px}.form-h{font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:22px}.form-sec{margin-bottom:22px}.form-sec-title{font-size:11px;font-weight:500;color:var(--hint);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.fg{display:flex;flex-direction:column;gap:5px}.fg.full{grid-column:1 / -1}.fg label{font-size:12px;font-weight:500;color:var(--muted)}.fg input,.fg select,.fg textarea{padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border .15s;width:100%}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent)}.fg textarea{resize:vertical;min-height:70px}.img-upload{border:1.5px dashed var(--border2);border-radius:var(--r);padding:24px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg)}.img-upload:hover{border-color:var(--accent);background:var(--accent-bg)}.img-upload input{display:none}.img-preview{width:100%;max-height:200px;object-fit:cover;border-radius:var(--r);display:block}.ingr-row{display:grid;grid-template-columns:1fr 110px 28px;gap:8px;align-items:center;margin-bottom:8px}.ingr-row input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border .15s;width:100%}.ingr-row input:focus{border-color:var(--accent)}.rm-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:7px;background:none;cursor:pointer;color:var(--muted);font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.rm-btn:hover{border-color:#e24b4a;color:#a32d2d;background:var(--red-bg)}.add-row-btn{width:100%;border:1.5px dashed var(--border);border-radius:var(--r);padding:8px;background:none;font-family:var(--font-body);font-size:13px;color:var(--hint);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:4px}.add-row-btn:hover{border-color:var(--accent);color:var(--accent)}.step-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:8px}.step-num{width:26px;height:26px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;flex-shrink:0;margin-top:9px}.step-row textarea{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;resize:vertical;min-height:64px;transition:border .15s}.step-row textarea:focus{border-color:var(--accent)}.tag-input-wrap{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);cursor:text;transition:border .15s;min-height:40px;align-items:center}.tag-input-wrap:focus-within{border-color:var(--accent)}.tag-input-wrap input{border:none;outline:none;font-family:var(--font-body);font-size:14px;color:var(--text);background:transparent;min-width:80px;flex:1}.tag-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:500}.tag-chip.ingr{background:var(--tag-ingr-bg);color:var(--tag-ingr-text)}.tag-chip.style{background:var(--tag-style-bg);color:var(--tag-style-text)}.tag-chip.custom{background:var(--tag-custom-bg);color:var(--tag-custom-text);border:1px solid var(--tag-custom-border)}.tag-chip button{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;padding:0;font-size:13px;line-height:1;display:flex;align-items:center}.tag-chip button:hover{opacity:1}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.plan-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.plan-header h2{font-family:var(--font-display);font-size:22px}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.day-head{padding:8px 6px;text-align:center;background:var(--surface2);border-bottom:1px solid var(--border)}.day-head .dname{font-size:11px;font-weight:500;color:var(--hint);text-transform:uppercase;letter-spacing:.05em}.meal-slot{padding:6px;border-bottom:1px solid var(--border);min-height:52px}.meal-slot-label{font-size:10px;font-weight:500;color:var(--hint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.meal-chip{background:var(--accent-bg);border-radius:6px;padding:4px 7px;font-size:11px;color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:4px;line-height:1.3}.meal-chip:hover .chip-rm,.meal-chip:hover .chip-swap{opacity:1}.chip-rm{opacity:0;background:none;border:none;cursor:pointer;color:var(--accent);font-size:13px;padding:0;line-height:1;flex-shrink:0;display:flex}.chip-swap{opacity:0;background:none;border:none;cursor:pointer;color:var(--accent);font-size:11px;padding:0;line-height:1;flex-shrink:0;display:flex}.meal-add-btn{background:none;border:none;cursor:pointer;color:var(--hint);font-size:16px;display:flex;align-items:center;justify-content:center;width:100%;padding:2px 0;transition:color .15s}.meal-add-btn:hover{color:var(--accent)}.day-head-copy{opacity:0;background:none;border:none;cursor:pointer;color:var(--hint);font-size:11px;padding:0;line-height:1;display:flex;align-items:center;transition:color .15s}.day-head:hover .day-head-copy{opacity:1}.day-head-copy:hover{color:var(--accent)}.extras-slot{padding:4px 6px}.extra-chip{display:flex;align-items:center;gap:3px;padding:2px 0;font-size:10px;color:var(--text)}.extra-chip-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.extra-chip-kcal{color:var(--muted);flex-shrink:0;font-size:9px}.extra-chip-rm{background:none;border:none;cursor:pointer;color:var(--hint);font-size:10px;padding:0;line-height:1;flex-shrink:0;display:flex;opacity:.5}.extra-chip-rm:hover{color:var(--red);opacity:1}.extras-add-btn{width:100%;background:none;border:none;cursor:pointer;color:var(--hint);font-size:11px;display:flex;align-items:center;gap:3px;padding:3px 0;transition:color .15s;justify-content:center}.extras-add-btn:hover{color:var(--accent)}.qi-macro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:8px 0}.qi-macro-grid input{padding:6px 8px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:12px;color:var(--text);background:var(--surface);outline:none;width:100%}.qi-macro-grid input:focus{border-color:var(--accent)}.qi-list{list-style:none;border:1px solid var(--border);border-radius:var(--r);max-height:200px;overflow-y:auto;margin-bottom:10px}.qi-list li{padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px;display:flex;align-items:center;gap:8px}.qi-list li:last-child{border-bottom:none}.qi-list li:hover{background:var(--surface2)}.qi-item-info{flex:1;cursor:pointer}.qi-item-name{font-weight:500}.qi-item-meta{font-size:11px;color:var(--muted);margin-top:1px}.qi-item-del{background:none;border:none;cursor:pointer;color:var(--hint);font-size:13px;padding:0;line-height:1;flex-shrink:0;opacity:.5}.qi-item-del:hover{color:var(--red);opacity:1}.copy-day-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:14px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14120e73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:300}.modal{background:var(--surface);border-radius:var(--rlg);padding:22px;width:100%;max-width:420px;border:1px solid var(--border)}.modal-h{font-family:var(--font-display);font-size:18px;font-weight:500;margin-bottom:14px}.modal-search{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;margin-bottom:10px}.modal-search:focus{border-color:var(--accent)}.modal-list{list-style:none;border:1px solid var(--border);border-radius:var(--r);max-height:240px;overflow-y:auto}.modal-list li{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;font-size:14px;display:flex;align-items:center;gap:10px;transition:background .1s}.modal-list li:last-child{border-bottom:none}.modal-list li:hover{background:var(--surface2)}.modal-list li img{width:36px;height:36px;object-fit:cover;border-radius:6px;flex-shrink:0}.modal-list li .ph{width:36px;height:36px;border-radius:6px;background:var(--surface2);display:flex;align-items:center;justify-content:center;color:var(--hint);font-size:18px;flex-shrink:0}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.tags-manager{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:24px;max-width:560px;margin:0 auto}.tags-manager h3{font-family:var(--font-display);font-size:18px;margin-bottom:4px}.tags-manager-desc{font-size:13px;color:var(--muted);margin-bottom:18px}.tag-create-row{display:flex;gap:8px;margin-bottom:20px}.tag-create-row input{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border .15s}.tag-create-row input:focus{border-color:var(--accent)}.tag-list-item{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:7px;background:var(--surface)}.tag-list-item-left{display:flex;align-items:center;gap:10px}.tag-list-item .count{font-size:12px;color:var(--hint)}.edit-tab-wrap{max-width:720px;margin:0 auto}.edit-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:22px;margin-bottom:20px}.edit-section-title{font-family:var(--font-display);font-size:17px;font-weight:500;margin-bottom:16px;display:flex;align-items:center;gap:10px}.edit-section-title i{font-size:18px;color:var(--accent)}.comment-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.comment-item{background:var(--surface2);border-radius:var(--r);padding:12px 14px;position:relative}.comment-meta{font-size:12px;color:var(--hint);margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}.comment-text{font-size:14px;color:var(--text);line-height:1.6;white-space:pre-wrap}.comment-rm{background:none;border:none;cursor:pointer;color:var(--hint);font-size:15px;padding:0;display:flex;transition:color .15s}.comment-rm:hover{color:var(--red)}.comment-add{display:flex;flex-direction:column;gap:8px}.comment-add textarea{padding:10px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;resize:vertical;min-height:80px;transition:border .15s;width:100%}.comment-add textarea:focus{border-color:var(--accent)}.recipe-select-wrap{background:var(--surface2);border-radius:var(--r);padding:14px 16px;margin-bottom:20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.recipe-select-wrap select{flex:1;min-width:200px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none}.recipe-select-wrap select:focus{border-color:var(--accent)}.ingr-edit-row{display:grid;grid-template-columns:1fr 110px 28px;gap:8px;align-items:center;margin-bottom:7px}.ingr-edit-row input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border .15s;width:100%}.ingr-edit-row input:focus{border-color:var(--accent)}.step-edit-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:8px}.step-edit-num{width:26px;height:26px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;flex-shrink:0;margin-top:9px}.step-edit-row textarea{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;resize:vertical;min-height:64px;transition:border .15s}.step-edit-row textarea:focus{border-color:var(--accent)}.save-bar{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--border);padding:14px 24px;display:flex;justify-content:flex-end;gap:10px;margin:0 -24px -28px;border-radius:0 0 var(--rlg) var(--rlg)}.import-wrap{max-width:640px;margin:0 auto}.import-drop{border:2px dashed var(--border2);border-radius:var(--rlg);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface)}.import-drop.drag{border-color:var(--accent);background:var(--accent-bg)}.import-drop input{display:none}.import-drop i{font-size:40px;color:var(--hint);display:block;margin-bottom:14px}.import-drop p{font-size:14px;color:var(--muted);line-height:1.7}.import-file-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;background:var(--surface)}.import-file-row .fname{flex:1;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-file-row .fstatus{font-size:12px;flex-shrink:0}.status-ok{color:var(--tag-ingr-text)}.status-err{color:var(--red)}.status-pending{color:var(--hint)}.preview-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;margin-bottom:10px;display:flex;gap:14px;align-items:flex-start}.preview-card img{width:60px;height:60px;object-fit:cover;border-radius:8px;flex-shrink:0}.preview-card .ph{width:60px;height:60px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;color:var(--hint);font-size:24px;flex-shrink:0}.preview-card-info{flex:1;min-width:0}.preview-card-title{font-family:var(--font-display);font-size:15px;font-weight:500;margin-bottom:4px}.preview-card-meta{font-size:12px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap}.preview-card-check{flex-shrink:0;display:flex;align-items:center;padding-top:2px}.preview-card-check input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.info-box{background:var(--accent-bg);border:1px solid var(--border2);border-radius:var(--r);padding:14px 16px;font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:24px}.info-box strong{color:var(--accent)}.info-box code{background:var(--surface2);padding:1px 6px;border-radius:4px;font-size:12px;color:var(--text)}.recipe-img-ph{background:linear-gradient(135deg,var(--surface2) 0%,var(--accent-bg) 100%);display:flex;align-items:center;justify-content:center;color:var(--border2)}.diff-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:500}.diff-easy{background:#e8f5e9;color:#2e7d32}.diff-medium{background:#fff8e1;color:#e65100}.diff-hard{background:#feebee;color:#c62828}.ingr-hint{font-size:11px;color:var(--hint);margin-bottom:8px;display:flex;align-items:center;gap:4px}.ingr-list li{cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity .15s}.ingr-list li:hover{background:var(--surface2);margin:0 -4px;padding-left:4px;padding-right:4px;border-radius:4px}.ingr-list li.checked{opacity:.45}.ingr-list li.checked>span:first-child{text-decoration:line-through}.cook-mode{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:500;display:flex;flex-direction:column;overflow:hidden}.cook-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.cook-header-title{font-family:var(--font-display);font-size:17px;font-weight:500;color:var(--accent);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cook-body{flex:1;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:40px 32px;position:relative}.cook-body-tappable{cursor:pointer;-webkit-user-select:none;user-select:none;padding:40px 96px}.cook-body-tappable:active{background:#5c4a2a0f}html.dark .cook-body-tappable:active{background:#c4956a0f}.cook-tap-hint{position:absolute;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;transition:opacity .2s}.cook-tap-left{left:24px}.cook-tap-right{right:24px}.cook-tap-hint i{font-size:64px;color:var(--accent);opacity:.1;transition:opacity .2s;display:block}.cook-body-tappable:hover .cook-tap-hint i{opacity:.28}.cook-tap-hint.tap-dimmed i{opacity:0!important}.cook-step-wrap{text-align:center;max-width:640px;width:100%;position:relative;z-index:1;pointer-events:none}.cook-step-count{font-size:12px;font-weight:600;color:var(--hint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:28px}.cook-step-text{font-size:26px;line-height:1.75;color:var(--text);font-family:var(--font-display)}.cook-ingr-wrap{width:100%;max-width:520px}.cook-done{text-align:center;position:relative;z-index:1;pointer-events:none}.cook-done i{font-size:72px;color:var(--accent);display:block;margin-bottom:20px}.cook-done h2{font-family:var(--font-display);font-size:30px;color:var(--accent);margin-bottom:12px}.cook-done p{font-size:16px;color:var(--muted);line-height:1.7}.cook-footer{padding:16px 24px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;min-height:56px;flex-shrink:0}.cook-dots{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.cook-dot{width:9px;height:9px;border-radius:50%;background:var(--border2);border:none;cursor:pointer;padding:0;transition:all .15s;flex-shrink:0}.cook-dot.active{background:var(--accent);transform:scale(1.4)}.cook-dot.past{background:var(--accent);opacity:.35}@media (max-width: 640px){.cook-step-text{font-size:20px}.cook-body-tappable{padding:28px 64px}.cook-tap-hint i{font-size:44px}}@media print{nav,.detail-actions,.serve-ctrl,.ingr-hint,.print-hide,button{display:none!important}.page{padding:16px 0;max-width:100%}.detail-hero{max-height:220px;border-radius:8px}.detail-cols{grid-template-columns:200px 1fr;gap:20px}body{font-size:13px}.detail-title{font-size:22px}.macros-row{display:none}}html.dark{--bg: #171512;--surface: #201D19;--surface2: #2A2620;--border: #3A352D;--border2: #4E4840;--text: #EDE9E3;--muted: #9E9A93;--hint: #65615A;--accent: #C4956A;--accent-bg: #2C2118;--accent-hover: #D4A57A;--tag-ingr-bg: #192819;--tag-ingr-text: #7CC870;--tag-style-bg: #18182A;--tag-style-text: #8890D0;--tag-custom-bg: #281E08;--tag-custom-text: #D0A030;--tag-custom-border:#7A5818;--red-bg: #280C0C;--red: #D85050}html.dark .diff-easy{background:#0c2210;color:#6cc860}html.dark .diff-medium{background:#281c00;color:#d09030}html.dark .diff-hard{background:#280808;color:#d04848}@media (min-width: 1440px){.page{max-width:1100px}}@media (min-width: 1920px){.page{max-width:1320px}.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.detail-cols{grid-template-columns:300px 1fr;gap:36px}.cook-step-text{font-size:30px}}@media (min-width: 2560px){.page{max-width:1600px}.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.detail-cols{grid-template-columns:340px 1fr;gap:40px}}.pin-dots{display:flex;gap:12px;justify-content:center;margin:16px 0 20px}.pin-dot{width:13px;height:13px;border-radius:50%;background:var(--border2);transition:background .15s,transform .15s}.pin-dot.filled{background:var(--accent);transform:scale(1.1)}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:240px;margin:0 auto}.pin-pad-btn{height:52px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);font-family:var(--font-body);font-size:20px;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.pin-pad-btn:hover:not(:disabled){background:var(--surface2);border-color:var(--border2)}.pin-pad-btn:active:not(:disabled){background:var(--accent-bg)}.pin-pad-btn.confirm{background:var(--accent);color:#fff;border-color:var(--accent);font-size:18px}.pin-pad-btn.confirm:hover:not(:disabled){background:var(--accent-hover)}.pin-pad-btn:disabled{opacity:.3;cursor:default}.pin-username{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--surface);outline:none;margin-bottom:12px;transition:border .15s}.pin-username:focus{border-color:var(--accent)}.pin-error{font-size:13px;color:var(--red);text-align:center;min-height:20px;margin-bottom:8px}.profile-wrap{position:relative;align-self:center;margin-left:4px}.profile-btn{padding:5px 10px;font-size:13px;font-weight:500;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);cursor:pointer;font-family:var(--font-body);transition:all .15s;display:flex;align-items:center;gap:5px;white-space:nowrap}.profile-btn:hover{border-color:var(--accent);color:var(--accent)}.profile-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);min-width:210px;box-shadow:0 6px 24px #0000002e;overflow:hidden}.profile-item{width:100%;padding:10px 16px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text);border:none;background:none;font-family:var(--font-body);transition:background .12s;text-align:left}.profile-item:hover{background:var(--surface2)}.profile-item.danger{color:var(--red)}.profile-sep{height:1px;background:var(--border)}.float-save{position:fixed;bottom:28px;right:28px;width:52px;height:52px;background:var(--accent);color:#fff;border:none;border-radius:50%;font-size:22px;cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000038;transition:transform .15s,background .15s}.float-save:hover{background:var(--accent-hover);transform:scale(1.08)}.owner-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);background:var(--surface2);border-radius:99px;padding:3px 10px}.menu-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);padding:20px;margin-bottom:16px}.menu-card-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.menu-card-name{font-family:var(--font-display);font-size:17px;font-weight:500;flex:1}.menu-entry-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border);font-size:14px}.menu-entry-row:last-child{border-bottom:none}.menu-entry-title{flex:1}.menu-entry-servings{width:48px;text-align:center;padding:4px 6px;border:1px solid var(--border);border-radius:6px;font-family:var(--font-body);font-size:13px;color:var(--text);background:var(--surface);outline:none}.menu-total{font-size:13px;color:var(--muted);margin-top:12px;padding-top:10px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.mgmt-user-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;background:var(--surface);flex-wrap:wrap}.mgmt-user-info{flex:1;min-width:0}.mgmt-user-name{font-weight:500;font-size:14px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.mgmt-user-username{font-size:12px;color:var(--muted);margin-top:1px}.shop-list{list-style:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--rlg);overflow:hidden}.shop-row{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;user-select:none;-webkit-user-select:none;border-bottom:1px solid var(--border);transition:background .12s}.shop-row:last-child{border-bottom:none}.shop-row:hover{background:var(--surface2)}.shop-check{font-size:18px;color:var(--accent);flex-shrink:0;line-height:1}.shop-name{flex:1;font-size:14px;color:var(--text)}.shop-amount{font-size:13px;font-weight:500;color:var(--muted);white-space:nowrap}.shop-expand{background:none;border:none;cursor:pointer;color:var(--hint);font-size:13px;padding:2px 6px;flex-shrink:0;transition:color .15s;line-height:1}.shop-expand:hover{color:var(--accent)}.shop-source{display:flex;justify-content:space-between;padding:5px 14px 5px 46px;background:var(--surface2);border-bottom:1px solid var(--border)}.shop-source:last-of-type{border-bottom:none}.shop-source-recipe{font-size:12px;color:var(--hint)}.shop-source-amount{font-size:12px;color:var(--muted);font-weight:500}.shop-section-title{font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:8px}.shop-section-label{font-size:11px;font-weight:500;color:var(--hint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.back-to-top{position:fixed;bottom:88px;right:28px;width:40px;height:40px;background:var(--surface);border:1px solid var(--border2);color:var(--muted);border-radius:50%;font-size:18px;cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #00000026;transition:all .15s}.back-to-top:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}.nav-dirty-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-left:2px}.macro-progress{background:var(--border);border-radius:3px;height:4px;overflow:hidden}.macro-progress-fill{height:100%;border-radius:3px;transition:width .3s}@media (max-width: 640px){.page{padding:20px 16px}nav{padding:0 10px}.nav-brand{font-size:17px}.detail-cols,.form-grid{grid-template-columns:1fr}.detail-title{font-size:22px}.sec-header h2{font-size:18px}.detail-actions{flex-wrap:wrap}.form-wrap{padding:20px 16px}.edit-section,.tags-manager{padding:16px}}
