:root{color:#3f3328;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f1dd;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,system-ui,sans-serif;font-weight:500;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}#root{min-height:100svh}.app-shell{--bg:#f8f1dd;--surface:#fff8e7;--surface-alt:#f3e2b8;--primary:#7fb069;--primary-dark:#4f7f52;--accent:#f2c94c;--pink:#f6a6a6;--wood:#b98558;--wood-dark:#7a5137;--text:#3f3328;--muted:#7d6b5b;--danger:#d96c5f;--border:#d9c7a3;--shadow:0 14px 0 #7a51371f, 0 18px 34px #3f33281f;min-height:100svh;color:var(--text);background:radial-gradient(circle at 8% 12%,#7fb06947 0 120px,#0000 121px),radial-gradient(circle at 92% 4%,#f2c94c4d 0 110px,#0000 111px),radial-gradient(circle at 84% 88%,#f6a6a638 0 160px,#0000 161px),linear-gradient(#f8f1dd 0%,#f4e6c2 100%);padding:28px;position:relative;overflow:hidden}.island-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.bubble{background:#fff8e775;border:2px solid #b9855838;border-radius:42% 58% 48% 52%/55% 45%;place-items:center;width:84px;height:84px;font-size:30px;animation:5s ease-in-out infinite floaty;display:grid;position:absolute}.bubble-a{bottom:10%;left:6%}.bubble-b{animation-delay:-1.5s;top:24%;right:8%}.bubble-c{animation-delay:-3s;bottom:5%;right:22%}.wood-sign,.layout-grid,.tab-bar{z-index:1;width:min(1180px,100%);margin-inline:auto;position:relative}.wood-sign{border:3px solid var(--wood-dark);color:#fff8e7;background:linear-gradient(90deg, #ffffff1a, transparent 22% 78%, #ffffff1a), repeating-linear-gradient(0deg, #7a513700 0 13px, #7a513729 14px 16px), var(--wood);box-shadow:0 10px 0 var(--wood-dark), 0 22px 36px #3f332833;border-radius:30px;justify-content:space-between;align-items:center;gap:24px;padding:24px 28px;display:flex}.wood-sign h1,.wood-sign p{margin:0}.wood-sign h1{letter-spacing:-.06em;text-shadow:0 2px #7a513761;font-size:clamp(2rem,5vw,4.6rem);line-height:1}.eyebrow{color:var(--primary-dark);letter-spacing:.12em;text-transform:uppercase;margin:0 0 6px;font-size:.78rem;font-weight:800}.wood-sign .eyebrow{color:#ffefb1}.status-board{text-align:right;background:#3f332829;border:2px dashed #fff8e7b3;border-radius:22px;min-width:180px;padding:16px}.status-board strong,.status-board span{display:block}.status-board strong{font-size:1.55rem}.status-board span{opacity:.86}.tab-bar{border:2px solid var(--border);background:#fff8e7b8;border-radius:999px;gap:12px;margin-top:24px;padding:8px;display:flex;box-shadow:0 10px 24px #3f332814}.tab-bar button,button,.import-button{font:inherit}.tab-bar button{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:999px;flex:1;padding:12px 18px;font-weight:800}.tab-bar button.active{color:var(--text);background:var(--accent);box-shadow:inset 0 -4px #7a51372e}.layout-grid{grid-template-columns:320px minmax(0,1fr);align-items:start;gap:22px;margin-top:22px;display:grid}.panel,.dish-card,.dish-form{border:2px solid var(--border);box-shadow:var(--shadow);background:#fff8e7eb;border-radius:28px}.panel{padding:22px}.filter-panel{position:sticky;top:20px}.section-heading{align-items:flex-start;gap:12px;margin-bottom:18px;display:flex}.section-heading>span{background:var(--surface-alt);border-radius:16px;place-items:center;width:42px;height:42px;display:grid}h2,h3,p{margin-top:0}h2{margin-bottom:6px;font-size:clamp(1.35rem,2.5vw,2rem);line-height:1.1}h3{margin:10px 0;font-size:1.35rem}p{color:var(--muted)}.field-label{color:var(--text);gap:8px;margin-bottom:16px;font-weight:800;display:grid}input,select,textarea{box-sizing:border-box;border:2px solid var(--border);width:100%;color:var(--text);background:#fffdf4;border-radius:18px;outline:0;padding:12px 14px}textarea{resize:vertical;min-height:88px}input:focus,select:focus,textarea:focus,button:focus-visible,.import-button:focus-within{outline-offset:2px;outline:3px solid #7fb06957}.chip-group{margin:18px 0}.chip-group>span{margin-bottom:8px;font-weight:900;display:block}.chip-group>div,.tag-list,.button-row,.pref-row,.recent-strip{flex-wrap:wrap;gap:8px;display:flex}.chip-group button,.tag-list span,.category-badge{border:2px solid var(--border);color:var(--muted);background:#fffdf4;border-radius:999px;padding:7px 11px;font-size:.88rem;font-weight:800}.chip-group button{cursor:pointer}.chip-group button.active,.category-badge{color:var(--primary-dark);background:#e6f0d6;border-color:#7fb0698c}.today-column,.menu-column{gap:22px;display:grid}.hero-card{min-height:270px;position:relative;overflow:hidden}.note-card{transform:rotate(-.6deg)}.hero-card:after{content:"🍲";opacity:.16;font-size:5.2rem;position:absolute;bottom:12px;right:24px}.hero-card h2{font-size:clamp(2.4rem,7vw,5.6rem)}.picker-card,.menu-toolbar,.dish-card-top,.dish-footer,.form-header,.form-actions{justify-content:space-between;align-items:center;gap:16px;display:flex}.primary-button,.secondary-button,.ghost-button,.danger-button,.shuffle-button,.import-button{cursor:pointer;border:2px solid #0000;border-radius:999px;padding:12px 18px;font-weight:900;text-decoration:none;transition:transform .15s,box-shadow .15s,filter .15s}.primary-button,.shuffle-button{color:var(--text);background:var(--accent);box-shadow:inset 0 -5px #7a51372e,0 8px #7a51371f}.secondary-button{color:#fff8e7;background:var(--primary);box-shadow:inset 0 -5px #4f7f5257,0 8px #4f7f521f}.ghost-button,.import-button{color:var(--text);border-color:var(--border);background:#fffdf4}.danger-button{color:#fff;background:var(--danger)}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.danger-button:hover,.shuffle-button:hover,.import-button:hover{filter:saturate(1.04);transform:translateY(-2px)}.primary-button:active,.secondary-button:active,.ghost-button:active,.danger-button:active,.shuffle-button:active,.import-button:active{transform:translateY(2px)scale(.99)}.shuffle-button{border-radius:44% 56% 50% 50%/55% 45%;min-width:150px;min-height:150px;font-size:1.18rem}button:disabled{cursor:not-allowed;opacity:.58}.result-card{border-color:#7fb069b8;animation:.19s ease-out pop-in}.result-card.confirmed{background:linear-gradient(145deg,#fff8e7,#eff6dc)}.result-card strong{margin:6px 0 12px;font-size:clamp(2.2rem,6vw,4.8rem);line-height:1;display:block}.result-card ul{color:var(--muted);margin:0 0 14px;padding-left:20px}.recent-card{background:#f3e2b8db}.recent-strip span{color:var(--muted);background:#fff8e7d1;border-radius:999px;padding:8px 12px;font-weight:800}.dish-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.dish-card{min-height:230px;transform:rotate(var(--tilt,0deg));padding:18px;transition:transform .16s,box-shadow .16s;position:relative}.dish-card:nth-child(3n+1){--tilt:-.4deg}.dish-card:nth-child(3n+2){--tilt:.5deg}.dish-card:hover{transform:translateY(-2px) rotate(var(--tilt,0deg));box-shadow:0 18px #7a51371a,0 24px 38px #3f332826}.icon-button,.text-button{color:var(--primary-dark);cursor:pointer;background:0 0;border:0;font-weight:900}.icon-button{background:#f2c94c42;border-radius:14px;place-items:center;width:38px;height:38px;font-size:1.3rem;display:grid}.pref-pill{border:2px solid var(--border);cursor:pointer;background:#fffdf4;border-radius:999px;padding:8px 10px;font-weight:900}.pref-pill.want{background:#ffe9e7;border-color:#f6a6a6e0}.pref-pill.avoid{color:#8f3f35;background:#ffe1dc;border-color:#d96c5f99}.pref-pill.neutral{border-color:var(--border);color:var(--muted)}.dish-note{min-height:42px;margin:14px 0}.dish-footer{color:var(--muted);margin-top:14px;font-size:.92rem}.empty-state{justify-items:start;gap:10px;display:grid}.empty-state strong{font-size:1.4rem}.modal-backdrop{z-index:20;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#3f332857;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.dish-form{background:var(--surface);width:min(680px,100%);max-height:min(860px,92svh);padding:24px;overflow:auto}.form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-actions{justify-content:flex-end;margin-top:18px}.hint{margin:-8px 0 12px;font-size:.9rem}.fab{z-index:10;border:3px solid var(--wood-dark);width:62px;height:62px;color:var(--text);background:var(--accent);box-shadow:0 8px 0 var(--wood-dark), 0 18px 28px #3f33282e;cursor:pointer;border-radius:50%;place-items:center;font-size:2rem;font-weight:900;display:grid;position:fixed;bottom:26px;right:26px}.toast{z-index:30;border:2px solid var(--wood-dark);max-width:min(520px,100% - 36px);color:var(--surface);background:var(--wood-dark);opacity:0;border-radius:999px;padding:12px 18px;transition:transform .18s,opacity .18s;position:fixed;bottom:28px;left:50%;transform:translate(-50%,120px);box-shadow:0 14px 28px #3f33283d}.toast.show{opacity:1;transform:translate(-50%)}.import-button{position:relative;overflow:hidden}.import-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.wrap{flex-wrap:wrap}@keyframes pop-in{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes floaty{0%,to{transform:translateY(0)rotate(-4deg)}50%{transform:translateY(-12px)rotate(4deg)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important}}@media (width<=920px){.app-shell{padding:16px}.wood-sign,.layout-grid,.picker-card,.menu-toolbar,.form-header,.form-actions{flex-direction:column;align-items:stretch}.status-board{text-align:left}.layout-grid{grid-template-columns:1fr}.filter-panel{position:static}.dish-grid{grid-template-columns:1fr}.shuffle-button{border-radius:28px;width:100%;min-height:84px}.form-grid,.form-grid.two{grid-template-columns:1fr}.note-card,.dish-card{transform:none}}@media (width<=520px){.wood-sign{border-radius:24px;padding:20px}.tab-bar{border-radius:24px;flex-direction:column}.panel,.dish-card,.dish-form{border-radius:22px}.button-row>*,.form-actions>*{width:100%}.fab{bottom:18px;right:18px}}
