:root{--color-page: #faf8f5;--color-ink-strong: #261913;--color-ink: #3a2b24;--color-muted: #8b7a70;--color-border: #eadfd6;--color-border-strong: #d6c6ba;--color-warm-panel: #f2ebe5;--color-brown: #946f58;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--shadow-soft: 0 18px 48px rgb(70 42 22 / .06)}*{box-sizing:border-box}html{min-width:320px;background:var(--color-page);color:var(--color-ink);font-family:Inter,PingFang SC,Microsoft YaHei,Noto Sans CJK SC,Arial,sans-serif;font-size:16px;line-height:1.5}::selection{background:#946f583d}body{min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}#root{min-height:100vh}.app-shell{display:grid;min-height:100vh;grid-template-columns:286px minmax(0,1fr);background:radial-gradient(circle at top left,rgb(152 116 90 / .08),transparent 340px),var(--color-page)}.app-main{min-width:0;border-left:1px solid var(--color-border)}.sidebar{position:sticky;top:0;display:flex;height:100vh;flex-direction:column;justify-content:space-between;padding:34px 28px 36px;background:#fffdfaeb}.brand h1{margin:0;color:var(--color-ink-strong);font-family:STKaiti,KaiTi,serif;font-size:38px;font-weight:600;letter-spacing:0}.brand p{margin:14px 0 0;color:var(--color-muted);font-size:14px}.side-nav{display:grid;gap:18px;margin-top:72px}.side-nav__item{position:relative;display:flex;align-items:center;gap:18px;min-height:58px;padding:0 22px;border-radius:var(--radius-md);color:var(--color-ink);font-size:20px}.side-nav__item.active{background:var(--color-warm-panel)}.side-nav__item.active:before{position:absolute;top:0;bottom:0;left:0;width:4px;border-radius:999px;background:var(--color-brown);content:""}.sidebar-love{text-align:center}.sidebar-love img{width:min(180px,75%);opacity:.78}.sidebar-love p{margin:16px 0 0;color:var(--color-muted);font-size:14px}.sidebar-logout{margin:18px auto 0}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgb(152 116 90 / .12),transparent 360px),var(--color-page)}.login-panel{width:min(440px,100%);padding:34px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fffdfaeb;box-shadow:var(--shadow-soft)}.login-brand{display:flex;align-items:center;gap:18px}.login-brand img{width:86px;height:86px;object-fit:contain}.login-brand h1{margin:0;color:var(--color-ink-strong);font-family:STKaiti,KaiTi,serif;font-size:36px;letter-spacing:0}.login-brand p{margin:8px 0 0;color:var(--color-muted)}.login-form{display:grid;gap:18px;margin-top:28px}.login-form label{display:grid;gap:10px}.login-input{position:relative}.login-input svg{position:absolute;top:50%;left:14px;color:var(--color-muted);transform:translateY(-50%)}.login-input input{padding-left:46px}.page{min-height:100vh;padding:38px 44px}.page--narrow{max-width:1180px;margin:0 auto}.page-topbar,.section-heading{display:flex;align-items:center;justify-content:space-between;gap:24px}.section-heading h2{margin:0;color:var(--color-ink-strong);font-size:32px;letter-spacing:0}.section-heading p{margin:6px 0 0;color:var(--color-muted)}.tabs{display:flex;align-items:center;gap:32px}.tab{min-height:46px;padding:0 24px;border:0;border-radius:var(--radius-md);background:transparent;color:var(--color-ink);font-size:17px}.tab--active{border:1px solid var(--color-border-strong);background:var(--color-warm-panel)}.page-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:14px}.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:46px;padding:0 20px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:#fff;color:var(--color-ink);font-weight:600}.button--primary{border-color:var(--color-brown);background:var(--color-brown);color:#fff}.button--ghost{background:#ffffffd6}.button--soft{border-color:transparent;background:var(--color-warm-panel)}.placeholder-panel{margin-top:36px;padding:42px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffb8;box-shadow:var(--shadow-soft)}.placeholder-panel h2{margin:0;font-size:24px}.placeholder-panel p{margin:12px 0 0;color:var(--color-muted)}.back-link{display:inline-flex;margin-bottom:24px;color:var(--color-ink)}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}input,select,textarea{width:100%;min-height:44px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#ffffffd1;color:var(--color-ink);outline:0}input,select{padding:0 14px}textarea{min-height:94px;resize:vertical;padding:12px 14px}input::placeholder,textarea::placeholder{color:#b9aaa0}input:focus,select:focus,textarea:focus{border-color:var(--color-brown);box-shadow:0 0 0 3px #946f581f}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-ink)}.icon-button--active{background:var(--color-warm-panel);color:var(--color-ink-strong)}.icon-button--plain{border:0;background:transparent}.text-button{display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--color-muted)}.text-button:disabled,.cart-action:disabled{cursor:not-allowed;opacity:.58}.menu-layout,.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:36px;margin-top:30px}.menu-content{min-width:0}.filter-row{display:grid;align-items:center;grid-template-columns:minmax(220px,1.1fr) repeat(3,minmax(128px,.45fr)) auto;gap:14px;padding-top:20px;border-top:1px solid var(--color-border)}.search-box{position:relative;display:block}.search-box input{padding-right:48px}.search-box svg{position:absolute;top:50%;right:14px;color:var(--color-ink);transform:translateY(-50%)}.view-switch{display:inline-flex;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff}.view-switch .icon-button{border:0;border-radius:0}.category-pills{display:flex;flex-wrap:wrap;gap:20px;margin:24px 0 28px}.pill,.choice-chip{min-height:34px;padding:0 16px;border:1px solid var(--color-border);border-radius:999px;background:#ffffffdb;color:var(--color-ink)}.pill--active{border-color:var(--color-border-strong);background:var(--color-warm-panel)}.choice-chip--active{border-color:var(--color-brown);background:var(--color-warm-panel);color:var(--color-ink-strong);font-weight:650}.dish-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:22px}.dish-card{overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#ffffffeb;box-shadow:var(--shadow-soft)}.dish-card__image{display:block;width:calc(100% - 14px);aspect-ratio:1.18 / 1;margin:7px auto 0;border-radius:7px;object-fit:cover}.dish-card__body{position:relative;padding:10px 12px 13px}.dish-card__title{display:block;margin-right:82px;color:var(--color-ink-strong);font-weight:650}.dish-card__meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.dish-card__meta span,.dish-tags span,.ingredient-tags span{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;background:#f4f0ec;color:var(--color-muted);font-size:13px}.dish-card__actions{position:absolute;right:10px;bottom:12px;display:inline-flex;gap:8px}.dish-card__actions .icon-button{width:30px;height:30px}.icon-button--favorite-active,.button--favorite-active{border-color:#e3aaa0;background:#f7e2df;color:#a84e41}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin:22px 0 0}.pagination button{min-width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-ink)}.pagination button:disabled{cursor:not-allowed;opacity:.42}.pagination .active{background:var(--color-warm-panel);border-color:var(--color-border-strong)}.result-summary{margin:-10px 0 16px;color:var(--color-muted);font-size:14px}.state-panel{display:grid;place-items:center;min-height:220px;padding:32px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);background:#ffffffb3;color:var(--color-muted);text-align:center}.state-panel--error{border-color:#ddb5a8;color:#a45f4c}.dish-cart{position:sticky;top:26px;align-self:start;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffc7;padding:24px 16px;box-shadow:var(--shadow-soft)}.dish-cart__header{display:flex;align-items:center;justify-content:space-between;gap:16px}.panel-title{display:flex;align-items:center;gap:10px}.panel-title h2{margin:0;font-size:22px}.panel-title__icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-ink-strong);font-size:22px}.dish-cart__count{display:flex;align-items:center;justify-content:center;min-height:48px;margin:22px 0 16px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-ink);font-weight:600}.cart-list{overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff}.cart-item{display:grid;align-items:center;grid-template-columns:22px 52px minmax(0,1fr) 34px;gap:10px;min-height:68px;padding:8px 10px;border-bottom:1px solid var(--color-border)}.cart-item--dragging{position:relative;z-index:2;box-shadow:0 14px 34px #462a1629}.cart-item:last-child{border-bottom:0}.cart-drag-handle{display:inline-flex;align-items:center;justify-content:center;width:22px;height:38px;border:0;background:transparent;color:var(--color-muted);cursor:grab;touch-action:none}.cart-drag-handle:active{cursor:grabbing}.cart-item img{width:52px;height:46px;border-radius:7px;object-fit:cover}.cart-item span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.cart-actions{display:grid;gap:14px;margin-top:28px}.cart-action{display:grid;justify-items:center;gap:4px;min-height:82px;padding:14px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:#ffffffdb;color:var(--color-ink)}.cart-action span{font-size:19px;font-weight:700}.cart-action small{color:var(--color-muted);max-width:220px}.cart-action--primary{background:linear-gradient(180deg,#eadbd0,#d8c4b5);border-color:#c7ad9b}.cart-tip{display:flex;gap:10px;margin-top:24px;color:var(--color-muted);font-size:14px}.cart-tip p{margin:0}.cart-empty{display:grid;place-items:center;min-height:112px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);background:#ffffffa3;color:var(--color-muted);text-align:center}.cart-message{margin-top:12px;padding:10px 12px;border-radius:var(--radius-sm);background:#f5efe9;color:var(--color-brown);font-size:14px;text-align:center}.detail-layout{margin-top:0}.detail-content{min-width:0}.dish-hero{display:grid;grid-template-columns:300px minmax(0,1fr);gap:32px;align-items:start}.dish-hero>img{width:100%;aspect-ratio:1 / 1;border-radius:var(--radius-md);object-fit:cover;box-shadow:var(--shadow-soft)}.dish-hero__title-row{display:flex;align-items:center;justify-content:space-between;gap:20px}.dish-hero h2{margin:0;color:var(--color-ink-strong);font-size:34px}.dish-tags{display:flex;gap:10px;margin:12px 0 24px}.dish-hero p{max-width:560px;margin:0;color:var(--color-ink);line-height:1.9}.trait-grid{display:grid;grid-template-columns:repeat(4,minmax(108px,1fr));gap:16px;margin-top:28px}.trait-card{min-height:138px;padding:16px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#ffffffb8;text-align:center}.trait-card div{color:#9d6c50;font-size:26px}.trait-card strong,.trait-card span,.trait-card small{display:block}.trait-card strong{margin-top:8px;color:var(--color-ink-strong);font-size:18px}.trait-card span{margin-top:8px}.trait-card small{margin-top:4px;color:var(--color-muted)}.recipe-card,.form-section,.stats-panel,.history-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#ffffffc2;box-shadow:var(--shadow-soft)}.recipe-card{margin-top:30px;padding:24px 26px}.recipe-card h3,.form-section h3{margin:0 0 16px;color:var(--color-ink-strong);font-size:19px}.recipe-steps{display:grid;gap:12px;margin:0;padding:0;list-style:none}.recipe-steps li{display:grid;grid-template-columns:28px minmax(0,1fr);gap:12px}.recipe-steps span{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:var(--color-brown);color:#fff;font-size:13px}.recipe-divider{height:1px;margin:24px 0;background:var(--color-border)}.ingredient-tags{display:flex;flex-wrap:wrap;gap:12px}.ingredient-tags b{margin-left:12px;color:var(--color-ink);font-weight:500}.detail-tip{display:flex;gap:12px;color:var(--color-muted)}.detail-tip p{margin:0}.join-cart-button{display:flex;align-items:center;justify-content:center;width:min(320px,100%);min-height:58px;margin:22px auto 0;border:0;border-radius:var(--radius-sm);background:var(--color-brown);color:#fff;font-size:20px;font-weight:700}.dish-form,.settings-grid{display:grid;gap:18px;margin-top:28px}.form-section{padding:24px}.form-section--basic{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:42px}.form-fields,.form-section label,.field-group,.step-editor,.ingredient-editor{display:grid;gap:12px}.form-section label,.field-group{color:var(--color-ink)}.form-section b{color:#c8604a}.form-section small{justify-self:end;color:var(--color-muted)}.choice-row{display:flex;flex-wrap:wrap;gap:10px}.upload-box{position:relative;display:grid;place-items:center;align-content:center;min-height:310px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-muted);text-align:center;cursor:pointer}.upload-box span{color:var(--color-brown);font-size:54px}.upload-box strong{margin-top:10px;color:var(--color-ink)}.upload-box p{margin:10px 0 0}.upload-box input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-box img{width:min(260px,86%);aspect-ratio:1.2 / 1;border-radius:var(--radius-sm);object-fit:cover;box-shadow:var(--shadow-soft)}.upload-box--filled{border-style:solid;background:#ffffffbd}.form-message{margin-top:22px;padding:12px 16px;border:1px solid #c7d8b9;border-radius:var(--radius-sm);background:#f0f6ec;color:#4f6c3d}.form-message--error{border-color:#ddb5a8;background:#fff1ee;color:#a45f4c}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.editor-row{display:grid;grid-template-columns:20px minmax(0,1fr) minmax(80px,.65fr) 34px;gap:10px;align-items:center}.step-editor .editor-row{grid-template-columns:minmax(0,1fr) 34px}.editor-row button{height:36px;border:0;background:transparent;color:var(--color-muted)}.dashed-button{min-height:42px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);background:transparent;color:var(--color-brown)}.couple-field,.toggle-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.form-footer{position:sticky;bottom:0;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;padding:18px 0 0;background:linear-gradient(180deg,rgb(250 248 245 / 0),var(--color-page) 24%)}.favorites-toolbar,.history-filters{display:grid;gap:14px;margin:28px 0}.favorites-toolbar{grid-template-columns:minmax(220px,1fr) 180px 180px}.history-filters{grid-template-columns:260px 140px 140px minmax(220px,1fr)}.history-filters button,.history-filters label{display:flex;align-items:center;gap:10px;min-height:44px;padding:0 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff}.history-filters label input{border:0;background:transparent;box-shadow:none}.stats-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 32px}.stats-panel article{display:grid;grid-template-columns:42px auto auto;align-items:center;column-gap:10px;color:#8a583e}.stats-panel strong{color:var(--color-ink-strong);font-size:22px}.stats-panel small{grid-column:2 / 4;color:var(--color-muted)}.stat-icon{font-size:34px}.history-list{display:grid;gap:20px;margin-top:28px}.history-card{display:grid;grid-template-columns:165px minmax(0,1fr) 90px;min-height:176px;overflow:hidden}.history-card__date{display:grid;align-content:start;gap:12px;padding:22px;border-right:1px solid var(--color-border)}.history-card__date strong{color:var(--color-ink-strong);font-size:18px}.history-card__date em{font-style:normal;color:var(--color-brown)}.history-card__date div{display:flex;flex-wrap:wrap;gap:8px}.history-card__date small{color:var(--color-brown)}.history-card__body{padding:22px 26px}.history-dishes{display:grid;grid-template-columns:repeat(4,minmax(92px,1fr)) 96px;gap:16px}.history-dishes figure{margin:0;text-align:center}.history-dishes img{width:100%;aspect-ratio:1.28 / 1;border-radius:var(--radius-sm);object-fit:cover}.history-dishes figcaption{margin-top:8px;color:var(--color-ink);font-size:14px}.history-count{display:grid;place-items:center;min-height:86px;border:1px dashed var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-ink)}.history-card__body p{margin:18px 0 0;color:var(--color-muted)}.history-card__actions{display:flex;align-items:end;justify-content:center;gap:12px;padding:22px}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-status{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:26px}.settings-status__item{display:grid;grid-template-columns:28px minmax(0,1fr);gap:12px;padding:16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#ffffffbd}.settings-status__item svg{margin-top:2px}.settings-status__item strong{color:var(--color-ink-strong)}.settings-status__item p{margin:4px 0 0;color:var(--color-muted);font-size:14px}.settings-status__item--ok svg{color:#5a7742}.settings-status__item--warning svg{color:#b16a48}.settings-footer{grid-column:1 / -1;justify-content:flex-end}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.app-main{border-left:0}.sidebar{position:static;height:auto;padding:18px 18px 12px;border-bottom:1px solid var(--color-border)}.brand h1{font-size:30px}.side-nav{display:flex;gap:8px;margin-top:18px;overflow-x:auto}.side-nav__item{min-height:46px;flex:0 0 auto;gap:8px;padding:0 14px;font-size:15px}.sidebar-love{display:none}.sidebar-logout{margin:12px 0 0}.page{padding:24px 18px}.page-topbar,.section-heading{align-items:flex-start;flex-direction:column}.tabs{width:100%;gap:8px;overflow-x:auto}.tab{flex:0 0 auto}.menu-layout,.detail-layout,.dish-hero,.form-section--basic,.form-grid,.favorites-toolbar,.history-filters,.stats-panel,.history-card,.settings-grid,.settings-status,.filter-row{grid-template-columns:1fr}.dish-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dish-cart{position:static}.trait-grid{grid-template-columns:repeat(2,1fr)}.history-card__date{border-right:0;border-bottom:1px solid var(--color-border)}.history-dishes{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.dish-grid,.trait-grid,.history-dishes{grid-template-columns:1fr}.page-actions,.form-footer{justify-content:stretch}.button,.form-footer .button{width:100%}}
