:root{--bg: #fdf6ee;--bg-grad: radial-gradient(1200px 600px at 100% -10%, #ffe9d6 0%, transparent 55%), radial-gradient(900px 500px at -10% 0%, #ffe1e1 0%, transparent 45%), #fdf6ee;--surface: #ffffff;--surface-2: #fbf4ec;--text: #221b16;--muted: #8a7f76;--primary: #f97316;--primary-d: #ea580c;--primary-soft: #ffedd9;--danger: #e1483a;--border: #efe6dc;--shadow-sm: 0 1px 2px rgba(60, 40, 20, .06);--shadow: 0 10px 30px -12px rgba(120, 70, 30, .25);--radius: 18px;--radius-sm: 12px;--nav-h: 66px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg-grad);background-attachment:fixed;-webkit-font-smoothing:antialiased}h1,h2,h3{margin:0;line-height:1.2}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.app{min-height:100%}.app__main{max-width:760px;margin:0 auto;padding:20px 16px calc(var(--nav-h) + 28px)}.page{animation:fade .25s ease}@keyframes fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.page__header{margin-bottom:18px}.page__titlebar{display:flex;align-items:center;justify-content:space-between;gap:12px}.page__title{font-size:28px;font-weight:800;letter-spacing:-.02em}.page__actions{display:flex;align-items:center;gap:8px}.muted{color:var(--muted)}.hint-text{color:var(--muted);font-size:14px;margin:10px 2px}.nav{position:fixed;left:50%;transform:translate(-50%);bottom:14px;width:min(calc(100% - 28px),460px);height:var(--nav-h);display:flex;justify-content:space-around;align-items:center;background:#ffffffd9;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:6px;z-index:50}.nav__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--muted);padding:8px 4px;border-radius:16px;transition:color .15s,background .15s}.nav__item.active{color:var(--primary-d);background:var(--primary-soft)}.nav__item--add.active{color:#fff;background:var(--primary)}.nav__item svg{width:22px;height:22px}.btn{border:1px solid transparent;border-radius:999px;padding:11px 18px;font-size:15px;font-weight:700;transition:transform .08s ease,background .15s,box-shadow .15s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--primary);color:#fff;box-shadow:0 8px 18px -8px var(--primary)}.btn--primary:hover:not(:disabled){background:var(--primary-d)}.btn--soft{background:var(--primary-soft);color:var(--primary-d)}.btn--ghost{background:transparent;color:var(--muted);border-color:var(--border)}.btn--danger-ghost{background:transparent;color:var(--danger);border-color:#f3d6d2}.btn--block{width:100%}.icon-btn{border:1px solid var(--border);background:var(--surface);color:var(--muted);width:38px;height:38px;border-radius:12px;font-size:18px;display:inline-flex;align-items:center;justify-content:center}.icon-btn--sm{width:30px;height:30px;border-radius:9px;font-size:18px;line-height:1}.link-button{background:none;border:none;color:var(--primary-d);font-weight:600;padding:6px 0}.field{display:block;margin-bottom:14px}.field__label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;color:#4b4039}.field__hint{font-weight:500;color:var(--muted)}.field__input{width:100%;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);padding:12px 14px;font-size:16px;color:var(--text);transition:border .15s,box-shadow .15s}.field__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.field__textarea{resize:vertical;line-height:1.5}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.line-edit{display:flex;flex-direction:column;gap:8px}.line-edit__row{display:flex;align-items:flex-start;gap:8px}.line-edit__num{flex:none;width:26px;height:26px;margin-top:7px;border-radius:50%;background:var(--primary-soft);color:var(--primary-d);font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center}.line-edit__input{flex:1;min-width:0;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);padding:10px 12px;font:inherit;font-size:16px;color:var(--text);line-height:1.4;resize:none;overflow:hidden;transition:border .15s,box-shadow .15s}.line-edit__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.line-edit__del{flex:none;width:30px;height:30px;margin-top:5px;border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:9px;font-size:13px;line-height:1}.line-edit__del:hover{color:var(--danger);border-color:#f3d6d2}.line-edit__add{align-self:flex-start;margin-top:2px;border:1px dashed #e3d4c3;background:transparent;color:var(--primary-d);font-weight:700;font-size:14px;padding:8px 14px;border-radius:999px}.line-edit__add:hover{border-color:var(--primary);background:var(--primary-soft)}.search{margin-top:14px}.form-error{color:var(--danger);background:#fdecea;border:1px solid #f6d4cf;padding:10px 12px;border-radius:12px;font-size:14px;margin:12px 0}.login{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.login__card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:26px;padding:32px 26px;box-shadow:var(--shadow);text-align:center}.login__logo{width:72px;height:72px;border-radius:20px;box-shadow:var(--shadow-sm)}.login__title{font-size:26px;font-weight:800;margin:16px 0 6px;letter-spacing:-.02em}.login__subtitle{color:var(--muted);font-size:15px;margin:0 0 22px;line-height:1.5}.login__form{text-align:left}.segmented{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:4px;margin-top:14px}.segmented button{border:none;background:transparent;color:var(--muted);font-weight:700;font-size:14px;padding:8px 16px;border-radius:999px}.segmented button.is-active{background:var(--surface);color:var(--primary-d);box-shadow:var(--shadow-sm)}.url-bar{display:flex;gap:8px;margin:4px 0}.url-bar .field__input{flex:1}.extract-note{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;font-size:14px;margin:14px 0}.extract-note--good{background:#eafaf0;border:1px solid #c7eed7;color:#1d7a47}.extract-note--warn{background:#fff6e6;border:1px solid #f6e2bd;color:#97631a}.badge{text-transform:uppercase;font-size:10px;font-weight:800;letter-spacing:.05em;background:#0000000f;padding:3px 7px;border-radius:6px}.raw-box{margin:8px 0 4px}.raw-box__pre{white-space:pre-wrap;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px;font-size:13px;max-height:220px;overflow:auto}.recipe-form{margin-top:8px}.recipe-form__image{height:160px;border-radius:var(--radius);background-size:cover;background-position:center;margin-bottom:16px;border:1px solid var(--border)}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.chips{display:flex;gap:8px;overflow-x:auto;padding:14px 2px 4px;scrollbar-width:none}.chips::-webkit-scrollbar{display:none}.chips--static{flex-wrap:wrap;overflow:visible}.chip{border:1px solid var(--border);background:var(--surface);color:var(--muted);font-weight:600;font-size:13px;padding:7px 13px;border-radius:999px;white-space:nowrap}.chip.is-active{background:var(--primary);border-color:var(--primary);color:#fff}.chip__count{opacity:.7;font-size:11px}.chip--tag{color:var(--primary-d);background:var(--primary-soft);border-color:transparent}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (min-width: 560px){.grid{grid-template-columns:repeat(3,1fr)}}.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);text-align:left;transition:transform .12s ease,box-shadow .15s}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.card--selectable{font:inherit;color:inherit;padding:0}.card.is-selected{outline:3px solid var(--primary)}.card__media{position:relative;aspect-ratio:4 / 3;background:linear-gradient(135deg,#ffe6cf,#ffd9d9);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}.card__media-fallback{font-size:34px;opacity:.6}.card__source{position:absolute;top:8px;left:8px;background:#0000008c;color:#fff;font-size:10px;font-weight:700;text-transform:uppercase;padding:3px 7px;border-radius:6px}.card__check{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;background:#ffffffe6;border:2px solid var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--primary-d)}.card__check.is-on{background:var(--primary);color:#fff}.card__body{padding:11px 12px 13px}.card__title{font-size:15px;font-weight:700;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card__meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:7px;font-size:12px;color:var(--muted)}.empty{text-align:center;padding:48px 20px}.empty__emoji{font-size:52px}.empty h2{margin:14px 0 8px;font-size:20px}.empty .btn{margin-top:18px;display:inline-block}.select-bar{position:fixed;left:50%;transform:translate(-50%);bottom:calc(var(--nav-h) + 22px);width:min(calc(100% - 28px),560px);display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:10px 12px;z-index:40}.select-bar__count{font-weight:700;font-size:14px}.back-link{background:none;border:none;color:var(--muted);font-weight:600;padding:0 0 12px;font-size:15px}.detail__hero{height:220px;border-radius:var(--radius);background-size:cover;background-position:center;margin-bottom:16px;box-shadow:var(--shadow-sm)}.detail__title{font-size:26px;font-weight:800;letter-spacing:-.02em}.detail__meta{display:flex;flex-wrap:wrap;gap:14px;margin:10px 0;color:var(--muted);font-size:14px;align-items:center}.detail__source{color:var(--primary-d);font-weight:600}.detail__desc{color:#5b5048;line-height:1.6;margin:8px 0 0}.detail__actions{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 6px}.detail__section{margin-top:26px}.detail__heading{font-size:18px;font-weight:800;margin-bottom:12px}.ingredient-list{list-style:none;padding:0;margin:0}.ingredient-list li{padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;font-size:15px}.step-list{padding:0;margin:0;list-style:none;counter-reset:step}.step-list li{position:relative;padding:4px 0 18px 44px;line-height:1.55;counter-increment:step}.step-list li:before{content:counter(step);position:absolute;left:0;top:0;width:30px;height:30px;border-radius:50%;background:var(--primary-soft);color:var(--primary-d);font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center}.step-list li:not(:last-child):after{content:"";position:absolute;left:15px;top:32px;bottom:4px;width:2px;background:var(--border)}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.section-head .detail__heading{margin-bottom:0}.link-button--danger{color:var(--danger)}.mini-form{margin-top:12px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:10px}.version-note{margin-top:14px;padding:14px 16px;background:var(--primary-soft);border:1px solid #f7dcc1;border-radius:var(--radius-sm)}.version-note__text{margin:0;line-height:1.6;white-space:pre-wrap;color:#5b4636}.version-note__meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;font-size:12px;color:var(--muted)}.version-note__actions{display:flex;gap:14px}.version-note__actions .link-button{padding:0;font-size:13px}.comment-list{list-style:none;padding:0;margin:0 0 4px}.comment{padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:9px}.comment__head{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.comment__author{font-weight:700;color:var(--primary-d)}.comment__date:before{content:"· "}.comment__del{margin-left:auto;background:none;border:none;color:var(--muted);font-size:13px;padding:2px 4px;line-height:1}.comment__del:hover{color:var(--danger)}.comment__text{margin:5px 0 0;line-height:1.5;white-space:pre-wrap}.comment-form{margin-top:14px;display:flex;flex-direction:column;gap:10px}.comment-form__row{display:flex;gap:10px;align-items:center}.comment-form__row .field__input{flex:1}.comment__img{display:block;margin-top:8px;max-width:100%;max-height:280px;border-radius:12px;border:1px solid var(--border)}.section-head__actions{display:flex;align-items:center;gap:16px}.section-tag{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--primary-d);background:var(--primary-soft);padding:4px 9px;border-radius:7px}.chip__star{color:#f5b301;font-weight:800}.version-note__img{display:block;width:100%;max-height:260px;object-fit:cover;border-radius:12px;margin-bottom:10px}.stars{display:inline-flex;gap:2px;line-height:1}.stars .star{background:none;border:none;padding:0 1px;font-size:22px;color:#e2d6c8}.stars.stars--static .star{font-size:15px}.stars .star.is-on{color:#f5b301}.rating-pill{font-size:13px;font-weight:800;color:#b8860b}.cook-rate{display:flex;align-items:center;gap:12px}.cook-list{list-style:none;padding:0;margin:4px 0 0}.cook{padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:9px}.cook__head{display:flex;align-items:center;gap:10px}.cook__by{font-size:12px;color:var(--muted)}.cook__head .comment__del{margin-left:auto}.cook__note{margin:6px 0 0;line-height:1.5;white-space:pre-wrap}.photo-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.photo-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-weight:700;font-size:14px;padding:9px 14px;border-radius:999px;cursor:pointer;white-space:nowrap}.photo-btn:hover{color:var(--primary-d);border-color:var(--primary)}.photo-thumb{position:relative;display:inline-block}.photo-thumb img{width:56px;height:56px;object-fit:cover;border-radius:10px;border:1px solid var(--border);display:block}.photo-thumb--lg img{width:110px;height:110px}.photo-thumb button{position:absolute;top:-7px;right:-7px;width:22px;height:22px;border-radius:50%;background:var(--danger);color:#fff;border:2px solid #fff;font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center}.diff{margin-top:16px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.diff__pickers{display:flex;align-items:center;gap:10px}.diff__pickers .field__input{flex:1}.diff__vs{font-weight:800;color:var(--muted);font-size:13px}.diff__legend{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin:10px 0 4px}.diff__swatch{width:14px;height:14px;border-radius:4px;background:#fff6e6;border:1px solid #f6e2bd;display:inline-block}.diff__section-title{font-size:14px;font-weight:800;margin:14px 0 8px}.diff__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.diff__col-title{font-size:12px;font-weight:800;color:var(--primary-d);margin-bottom:6px}.diff__list{margin:0;padding-left:18px;font-size:13px}.diff__line{padding:3px 4px;line-height:1.4;border-radius:5px}.diff__line.is-changed{background:#fff6e6}.shopping-list{list-style:none;padding:0;margin:16px 0 0}.shopping-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:9px}.shopping-item__main{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer}.shopping-item__main input{width:20px;height:20px;accent-color:var(--primary);flex-shrink:0}.shopping-item__label{font-size:15px}.shopping-item.is-checked .shopping-item__label{text-decoration:line-through;color:var(--muted)}.shopping-item__sources{font-size:11px;color:var(--muted);background:var(--surface-2);padding:3px 8px;border-radius:7px;max-width:38%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
