.home{width:min(1120px,100%);min-height:100dvh;margin:0 auto;padding:22px 20px 36px}.home-top{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.brand-mark{background:var(--gray-900);width:42px;height:42px;color:var(--white);box-shadow:var(--shadow-sm);border-radius:14px;justify-content:center;align-items:center;font-size:20px;font-weight:900;display:flex}.home-library-btn{background:var(--surface);color:var(--gray-700);box-shadow:var(--shadow-xs);border:1px solid #5742281a;border-radius:999px;padding:11px 18px;font-size:14px;font-weight:700}.home-shell{grid-template-columns:minmax(0,1fr);gap:28px;display:grid}.hero{flex-direction:column;gap:22px;display:flex}.hero-kicker{color:var(--orange-500);margin-bottom:12px;font-size:15px;font-weight:800}.hero-title{letter-spacing:0;max-width:620px;margin-bottom:14px;font-size:clamp(34px,8.2vw,76px);font-weight:950;line-height:1.02}.hero-desc{max-width:520px;color:var(--gray-500);font-size:16px;font-weight:500;line-height:1.7}.mode-section{gap:14px;display:grid}.mode-card{border-radius:var(--radius-xl);text-align:left;box-shadow:var(--shadow-sm);border:1px solid #57422817;align-items:center;gap:16px;padding:18px;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;position:relative;overflow:hidden}.mode-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.mode-card:active{transform:scale(.98)}.mode-card-orange{background:linear-gradient(135deg,#fff,#fff1e8)}.mode-card-amber{background:linear-gradient(135deg,#fff,#fff7df)}.mode-card-icon{background:#ffffffbd;border:1px solid #57422812;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:58px;height:58px;font-size:34px;display:flex}.mode-card-content{flex:1;min-width:0}.mode-card-content h2{color:var(--gray-900);margin-bottom:6px;font-size:22px;font-weight:900}.mode-card-content p{color:var(--gray-700);font-size:14px;font-weight:600;line-height:1.5}.mode-card-arrow{width:34px;height:34px;color:var(--orange-500);background:#ffffffb8;border-radius:999px;justify-content:center;align-items:center;font-size:20px;font-weight:800;display:flex}.home-aside{gap:14px;display:grid}.hero-visual{min-height:184px;box-shadow:var(--shadow-sm);background:radial-gradient(circle at 50% 52%,#f36b2a3d,#0000 34%),linear-gradient(145deg,#fffc,#fff8f2c7);border:1px solid #57422814;border-radius:28px;justify-content:center;align-items:center;display:flex}.hero-bowl{background:linear-gradient(135deg,#fff8ef 0%,#ffe2c7 100%);border-radius:34px;justify-content:center;align-items:center;width:112px;height:112px;display:flex;position:relative;transform:rotate(-4deg);box-shadow:0 18px 42px #f36b2a2e,inset 0 2px 8px #fffc}.hero-emoji{z-index:2;font-size:58px;animation:3s ease-in-out infinite floatBowl;position:relative}@keyframes floatBowl{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero-steam{gap:16px;display:flex;position:absolute;top:12px}.hero-steam span{background:#f36b2a40;border-radius:2px;width:4px;height:20px;animation:2s infinite steamUp}.hero-steam span:nth-child(2){height:28px;animation-delay:.4s}.hero-steam span:nth-child(3){height:16px;animation-delay:.8s}@keyframes steamUp{0%{opacity:0;transform:translateY(0)scaleY(1)}50%{opacity:.55}to{opacity:0;transform:translateY(-20px)scaleY(2)}}.aside-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid #57422814;padding:22px}.aside-label{color:var(--green-500);margin-bottom:10px;font-size:13px;font-weight:900}.aside-card h2{margin-bottom:10px;font-size:24px;font-weight:900}.aside-card p{color:var(--gray-500);font-size:14px;font-weight:600;line-height:1.7}.home-stats{flex-wrap:wrap;gap:8px;display:flex}.home-stats span{color:var(--gray-500);background:#ffffffb8;border:1px solid #57422814;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}@media (width>=760px){.home{padding:34px 34px 56px}.home-shell{grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);align-items:center;gap:44px}.hero{gap:28px}.hero-visual{min-height:260px}.hero-bowl{width:132px;height:132px}.hero-emoji{font-size:66px}.mode-section{max-width:560px}}.rcard{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid #57422814;margin-bottom:8px;padding:28px 22px 22px;position:relative;overflow:hidden}.rcard:before{content:"";pointer-events:none;background:radial-gradient(circle,#f36b2a12 0%,#0000 70%);border-radius:50%;width:140px;height:140px;position:absolute;top:-60px;right:-40px}.rcard:after{content:"";pointer-events:none;background:radial-gradient(circle,#2f9b690d 0%,#0000 70%);border-radius:50%;width:80px;height:80px;position:absolute;bottom:-30px;left:-20px}.rcard-badge{background:linear-gradient(135deg, var(--orange-500), var(--red-500));color:#fff;letter-spacing:1px;border-radius:999px;align-items:center;gap:6px;margin-bottom:20px;padding:8px 22px;font-size:15px;font-weight:800;display:inline-flex;box-shadow:0 6px 20px #f36b2a4d}.rcard-icon-row{align-items:center;gap:14px;margin-bottom:18px;display:flex}.rcard-icon-circle{background:linear-gradient(135deg, var(--orange-50), #ffe8d8);border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:30px;display:flex;box-shadow:inset 0 2px 4px #fffc}.rcard-name-col{flex:1;min-width:0}.rcard-name-col h2{word-break:break-all;letter-spacing:0;margin-bottom:8px;font-size:24px;font-weight:900}.rcard-tags{gap:8px;display:flex}.rtag{border-radius:999px;padding:4px 12px;font-size:13px;font-weight:700}.rtag-rating{background:var(--orange-50);color:var(--orange-500)}.rtag-dist{background:var(--gray-100);color:var(--gray-700)}.rcard-addr{background:linear-gradient(135deg, var(--gray-50), #fff8f280);border-radius:14px;align-items:flex-start;gap:10px;margin-bottom:20px;padding:14px 16px;display:flex}.rcard-addr p{color:var(--gray-700);font-size:14px;line-height:1.6}.rcard-actions{gap:10px;display:flex}.ract{border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 6px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.ract:active{transform:scale(.95)}.ract-outline{background:var(--gray-50);color:var(--gray-700)}.ract-outline:active{background:var(--orange-50)}.ract-primary{background:var(--gray-900);color:#fff;box-shadow:0 4px 14px #19171433}.ract-primary:active{background:var(--gray-700)}.ract span{font-size:22px}.single-page{width:min(760px,100%);margin:0 auto;padding:24px 20px 40px}.single-header{margin-bottom:22px}.single-header .page-title{margin-bottom:4px}.location-pill{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #57422814;align-items:center;gap:10px;margin-bottom:20px;padding:12px 14px 12px 16px;display:flex}.loc-dot{background:var(--green-500);border-radius:50%;flex-shrink:0;width:8px;height:8px}.loc-text{color:var(--gray-700);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:500;overflow:hidden}.loc-refresh{background:var(--gray-50);width:36px;height:36px;color:var(--gray-500);border-radius:999px;font-size:20px}.manual-box{background:var(--orange-50);border-radius:var(--radius-lg);border:1.5px dashed var(--orange-300);margin-bottom:16px;padding:18px}.manual-box p{color:var(--gray-700);margin-bottom:10px;font-size:14px;font-weight:500}.manual-row{gap:8px;display:flex}.manual-input{border:1.5px solid var(--gray-300);background:#fff;border-radius:28px;outline:none;flex:1;padding:12px 16px;font-family:inherit;font-size:15px}.manual-input:focus{border-color:var(--orange-500)}.cta-btn{box-shadow:var(--shadow-orange);margin-bottom:20px}.error-box{background:var(--surface);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm);border-left:4px solid var(--red-500);margin-bottom:16px;padding:18px}.history-area{margin-top:28px}.history-toggle{color:var(--gray-500);text-align:left;background:0 0;width:100%;padding:10px 0;font-size:14px;font-weight:600}.history-list{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid #57422814;overflow:hidden}.history-empty{text-align:center;color:var(--gray-500);padding:24px;font-size:14px}.history-row{border-bottom:1px solid var(--gray-100);align-items:center;padding:12px 16px;display:flex}.history-row:last-child{border-bottom:none}.h-name{flex:1;font-size:14px;font-weight:600}.h-time{color:var(--gray-500);margin-right:8px;font-size:12px}.h-del{color:var(--gray-300);background:0 0;border-radius:50%;padding:4px 8px;font-size:14px}.h-del:active{color:var(--red-500);background:var(--red-100)}@media (width>=760px){.single-page{padding-top:34px}}.number-picker{justify-content:space-between;align-items:center;padding:10px 0;display:flex}.number-picker__label{color:var(--gray-900);font-size:17px;font-weight:700}.number-picker__controls{align-items:center;gap:20px;display:flex}.number-picker__btn{background:var(--gray-100);width:40px;height:40px;color:var(--gray-700);border-radius:50%;justify-content:center;align-items:center;font-size:22px;font-weight:600;transition:all .2s;display:flex}.number-picker__btn:active:not(:disabled){background:var(--orange-500);color:#fff;transform:scale(.9)}.number-picker__btn:disabled{color:var(--gray-300);cursor:not-allowed}.number-picker__value{color:var(--orange-500);text-align:center;min-width:28px;font-size:26px;font-weight:800}.rccard{background:linear-gradient(175deg, var(--surface) 0%, #fff8f2b3 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #5742280f;border-left:5px solid var(--orange-500);margin-bottom:16px;padding:22px 20px 18px;position:relative}.rccard:before{content:"";background:var(--orange-300);opacity:.4;border-radius:50%;width:8px;height:8px;position:absolute;top:10px;right:16px}.rccard-child{border-left-color:var(--green-500);background:linear-gradient(175deg,#ffffffe6 0%,#f5fcf6d9 100%)}.rccard-child:before{background:var(--green-500)}.rccard-head{gap:14px;margin-bottom:18px;display:flex}.rccard-emoji-bg{background:linear-gradient(135deg, var(--orange-50), #ffe8d8);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:28px;display:flex;box-shadow:inset 0 2px 4px #fffc}.rccard-child .rccard-emoji-bg{background:linear-gradient(135deg, var(--green-100), #e0f5e8)}.rccard-head-info{flex:1;min-width:0}.rccard-head-info h3{letter-spacing:0;margin-bottom:8px;font-size:21px;font-weight:900}.rccard-chips{flex-wrap:wrap;gap:6px;display:flex}.chip{border-radius:999px;padding:4px 12px;font-size:12px;font-weight:700}.chip-time{background:var(--gray-100);color:var(--gray-700)}.chip-taste,.chip-audience{background:var(--orange-50);color:var(--orange-500)}.chip-audience-child{background:var(--green-100);color:var(--green-500)}.rccard-section{margin-bottom:16px}.rccard-section:last-child{margin-bottom:0}.rccard-section h4{color:var(--gray-700);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px;font-size:14px;font-weight:800}.rccard-ingredients{flex-wrap:wrap;gap:8px;display:flex}.ing-badge{color:var(--gray-700);background:#fff;border:1px solid #5742281a;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;box-shadow:0 1px 3px #00000008}.rccard-child .ing-badge{background:#fff;border-color:#2f9b6926}.rccard-steps{flex-direction:column;gap:12px;display:flex}.step-row{color:var(--gray-700);align-items:flex-start;gap:14px;font-size:14px;line-height:1.7;display:flex}.step-num{background:var(--gray-900);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:1px;font-size:12px;font-weight:800;display:flex}.rccard-child .step-num{background:var(--green-500)}.family-page{width:min(860px,100%);margin:0 auto;padding:24px 20px 44px}.family-header{margin-bottom:20px}.family-header .page-title{margin-bottom:4px}.family-card{margin-bottom:14px}.family-divider{background:var(--gray-100);height:1px;margin:4px 0}.family-summary{text-align:center;color:var(--orange-500);border-top:1px solid var(--gray-100);justify-content:center;align-items:center;gap:6px;margin-top:8px;padding-top:12px;font-size:14px;font-weight:600;display:flex}.flabel{margin-bottom:14px;font-size:15px;font-weight:700}.taste-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.taste-btn{border-radius:var(--radius);background:var(--gray-50);border:2px solid #0000;flex-direction:column;flex:1;align-items:center;padding:14px 6px;transition:all .2s;display:flex}.taste-active{border-color:var(--orange-500);background:var(--white);box-shadow:var(--shadow)}.taste-label{color:var(--gray-700);margin-bottom:2px;font-size:15px;font-weight:700}.taste-active .taste-label{color:var(--orange-500)}.taste-desc{color:var(--gray-500);font-size:11px}.error-box{border-radius:var(--radius);text-align:center;border-left:4px solid var(--red-500);background:#fff;margin-bottom:16px;padding:18px}.error-box p{color:var(--red-500);font-size:15px;font-weight:500}.loading-area{text-align:center;padding:40px 0}.loading-area p{color:var(--gray-500);margin-top:12px;font-size:15px}.meal-result{margin-top:24px}.meal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.meal-header h2{font-size:24px;font-weight:800}.meal-group{margin-bottom:12px}.meal-group h3{margin-bottom:14px;padding-left:4px;font-size:18px;font-weight:700}@media (width>=820px){.family-page{padding-top:34px}.family-page>.card,.family-page>.btn,.family-page>.error-box,.family-page>.loading-area{max-width:620px}.meal-result{grid-template-columns:1fr 1fr;align-items:start;gap:18px;display:grid}.meal-header{grid-column:1/-1}}.custom-page{width:min(980px,100%);margin:0 auto;padding:24px 20px 44px}.custom-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.form-card{margin-bottom:20px}.form-card h3{margin-bottom:20px;font-size:18px;font-weight:700}.fg{margin-bottom:14px}.fg label{color:var(--gray-900);margin-bottom:6px;font-size:14px;font-weight:700;display:block}.fg input,.fg select,.fg textarea{border:1.5px solid var(--gray-300);background:var(--gray-50);border-radius:12px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--orange-500);background:#fff}.fg textarea{resize:vertical;min-height:70px}.fr{gap:12px;display:flex}.fr .fg{flex:1}.chips{gap:8px;display:flex}.chip{border:1.5px solid var(--gray-300);color:var(--gray-700);background:#fff;border-radius:24px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.chip-on{border-color:var(--orange-500);background:var(--orange-50);color:var(--orange-500)}.fchecks{gap:20px;display:flex}.fcheck{color:var(--gray-700);cursor:pointer;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.fcheck input[type=checkbox]{width:20px;height:20px;accent-color:var(--orange-500)}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.fbtn{border:1.5px solid var(--gray-300);color:var(--gray-700);background:#fff;border-radius:24px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.fbtn-on{border-color:var(--orange-500);background:var(--orange-50);color:var(--orange-500)}.fcount{color:var(--gray-500);margin-left:auto;font-size:13px}.rlist-item{align-items:center;gap:12px;margin-bottom:10px;padding:16px;display:flex}.rlist-info{flex:1}.rlist-info h4{align-items:center;gap:8px;margin-bottom:6px;font-size:17px;font-weight:700;display:flex}.preset-badge{background:var(--orange-50);color:var(--orange-500);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.rlist-meta{color:var(--gray-500);flex-wrap:wrap;gap:6px;font-size:12px;display:flex}.rlist-meta span{background:var(--gray-100);border-radius:8px;padding:2px 8px}.del-btn{opacity:.3;background:0 0;padding:8px;font-size:22px;transition:opacity .2s}.del-btn:hover{opacity:1}.empty-state{text-align:center;color:var(--gray-500);padding:60px 20px}.empty-emoji{margin-bottom:12px;font-size:48px}@media (width>=760px){.custom-page{padding-top:34px}.custom-page>.rlist-item{vertical-align:top;width:calc(50% - 7px);display:inline-flex}.form-card{max-width:720px}}:root{--orange-500:#f36b2a;--orange-400:#ff8a4c;--orange-300:#ffc49c;--orange-100:#fff0e6;--orange-50:#fff8f2;--red-500:#d84a3a;--red-100:#fff0ef;--amber-500:#d99319;--amber-100:#fff6dd;--green-500:#2f9b69;--green-100:#eaf8f0;--gray-900:#191714;--gray-700:#4d4741;--gray-500:#7b756f;--gray-300:#d8d2cc;--gray-100:#efeae5;--gray-50:#faf7f3;--white:#fff;--bg:#f7f2ec;--surface:#ffffffdb;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--shadow-xs:0 1px 2px #20170c0d;--shadow-sm:0 6px 16px #20170c12;--shadow:0 12px 28px #20170c17;--shadow-lg:0 18px 44px #20170c1f;--shadow-xl:0 28px 70px #20170c29;--shadow-orange:0 12px 26px #f36b2a3d}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(180deg, #ffffffbf, #f7f2ece6 38%, var(--bg)), radial-gradient(circle at 16% 12%, #ff8a4c1f, transparent 24%), radial-gradient(circle at 84% 10%, #2f9b6917, transparent 22%);color:var(--gray-900);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.app{width:100%;min-height:100dvh;margin:0 auto}button{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;outline:none;font-family:inherit}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:3px;outline:3px solid #f36b2a40}a{color:inherit;text-decoration:none}.btn{border-radius:var(--radius);letter-spacing:0;justify-content:center;align-items:center;gap:8px;min-height:50px;padding:14px 28px;font-size:15px;font-weight:700;transition:all .2s;display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(135deg, var(--orange-500), #ff8e45);color:#fff;box-shadow:var(--shadow-orange)}.btn-primary:active{box-shadow:0 2px 10px #ff7a2f4d}.btn-secondary{background:var(--white);color:var(--gray-700);border:1.5px solid var(--gray-300)}.btn-secondary:active{background:var(--gray-100)}.btn-lg{border-radius:var(--radius-xl);padding:18px 36px;font-size:18px}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #57422814;padding:20px}.page-title{color:var(--gray-900);letter-spacing:0;font-size:28px;font-weight:900}.page-subtitle{color:var(--gray-500);font-size:14px;font-weight:500}.back-btn{color:var(--gray-500);background:0 0;align-items:center;gap:6px;margin-bottom:4px;padding:8px 0;font-size:14px;font-weight:600;display:inline-flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}70%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.anim-fade-up{animation:.5s fadeUp}.anim-scale-in{animation:.4s scaleIn}.anim-pop{animation:.5s cubic-bezier(.175,.885,.32,1.275) popIn}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background:#0006;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--white);border-radius:24px 24px 0 0;width:100%;max-width:480px;padding:28px 24px 36px;animation:.35s fadeUp}.modal-sheet h3{text-align:center;margin-bottom:20px;font-size:18px;font-weight:800}.modal-sheet button{border-radius:var(--radius);background:var(--gray-100);width:100%;color:var(--gray-700);margin-bottom:8px;padding:16px;font-size:16px;font-weight:600;transition:all .2s;display:block}.modal-sheet button:active{background:var(--orange-500);color:#fff}.modal-sheet .cancel-btn{color:var(--gray-500)!important;background:0 0!important;font-weight:500!important}.toast{background:var(--gray-900);color:#fff;z-index:1000;box-shadow:var(--shadow-lg);white-space:nowrap;border-radius:28px;padding:14px 28px;font-size:14px;font-weight:600;animation:.3s fadeUp;position:fixed;top:24px;left:50%;transform:translate(-50%)}.loading-dots{justify-content:center;gap:8px;display:flex}.dot{background:var(--orange-400);border-radius:50%;width:10px;height:10px}.dot:first-child{animation:1.4s infinite dotAnim}.dot:nth-child(2){animation:1.4s .2s infinite dotAnim}.dot:nth-child(3){animation:1.4s .4s infinite dotAnim}@keyframes dotAnim{0%,80%,to{opacity:.3;transform:scale(.4)}40%{opacity:1;transform:scale(1)}}@media (width>=768px){.page-title{font-size:34px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
