*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fffbf5;margin:0;padding:0}#root{width:100%;max-width:480px;min-height:100vh;margin:0 auto}*{box-sizing:border-box;margin:0;padding:0}:root{--red:#c44d34;--red-hover:#a83a25;--red-light:#f5e1db;--red-subtle:#fdf3ef;--amber:#d4912e;--amber-light:#fdf0db;--brown:#3d2b1f;--brown-light:#8b7355;--cream:#fdf8f2;--cream-alt:#f7f0e6;--white:#fff;--gray-100:#f5f2ed;--gray-200:#ebe5db;--gray-400:#a09888;--gray-600:#6b6058;--gray-800:#3d342d;--radius:16px;--radius-sm:12px;--radius-xs:8px;--radius-full:9999px;--nav-height:64px;--font-serif:"Georgia", "Noto Serif SC", "Source Han Serif SC", "STSong", "SimSun", serif;--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif}body{font-family:var(--font-sans);background:var(--cream);color:var(--brown);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.app{background:var(--cream);width:100%;max-width:480px;min-height:100vh;margin:0 auto;position:relative}.page{padding-bottom:calc(var(--nav-height) + 24px)}.app-header{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(180%);background:#fdf8f2b8;border-bottom:1px solid #ebe5db80;padding:14px 16px;position:sticky;top:0}.app-header .header-content{align-items:center;gap:12px;display:flex}.app-header .back-btn{color:var(--gray-600);border-radius:var(--radius-full);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:2px;padding:6px 12px 6px 4px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s;display:flex}.app-header .back-btn:hover{background:var(--gray-100)}.app-header .back-btn:active{transform:scale(.96)}.app-header h1{color:var(--brown);flex:1;font-size:17px;font-weight:600}.app-header .share-btn{color:var(--gray-600);border-radius:var(--radius-full);flex-shrink:0;align-items:center;padding:6px 8px;transition:background .15s;display:flex}.app-header .share-btn:hover{background:var(--gray-100)}.app-header .share-btn:active{transform:scale(.96)}.home-hero{text-align:center;flex-direction:column;align-items:center;padding:32px 16px 24px;display:flex}.hero-logo{background:var(--white);border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:18px;padding:8px;display:flex;overflow:hidden;box-shadow:0 4px 20px #3d2b1f1a}.hero-logo img{object-fit:contain;width:100%;height:100%}.hero-title{font-family:var(--font-serif);color:var(--brown);letter-spacing:.02em;font-size:28px;font-weight:700;line-height:1.3}.hero-subtitle{color:var(--gray-600);margin-top:6px;font-size:13px;font-weight:400}.section{padding:0 16px 28px}.section-header{justify-content:space-between;align-items:baseline;margin-bottom:14px;display:flex}.section-title{font-family:var(--font-serif);color:var(--brown);letter-spacing:.02em;font-size:19px;font-weight:700}.section-more{color:var(--red);padding:4px 0;font-size:13px;font-weight:600;transition:opacity .15s}.section-more:hover{opacity:.7}.banner-section{padding-top:0;padding-bottom:24px}.banner-container{position:relative}.banner-track{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:16px;margin:0 -16px;padding:0 16px;display:flex;overflow-x:auto}.banner-track::-webkit-scrollbar{display:none}.banner-card{scroll-snap-align:center;border-radius:var(--radius);aspect-ratio:16/9;-webkit-backdrop-filter:blur(16px)saturate(180%);background:#ffffff73;border:1px solid #fff6;flex:0 0 calc(100vw - 64px);max-width:416px;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;box-shadow:0 8px 32px #3d2b1f1a}.banner-card:active{transform:scale(.98)}.banner-img{background:var(--cream-alt);position:absolute;inset:0}.banner-img img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.banner-card:hover .banner-img img{transform:scale(1.05)}.banner-overlay{background:linear-gradient(#3d2b1f0d 0%,#3d2b1f33 60%,#3d2b1fbf 100%);position:absolute;inset:0}.banner-content{color:#fff;padding:20px 20px 18px;position:absolute;bottom:0;left:0;right:0}.banner-badge{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-full);letter-spacing:.06em;text-transform:uppercase;background:#fff3;border:1px solid #ffffff40;margin-bottom:8px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-block}.banner-title{font-family:var(--font-serif);text-shadow:0 2px 8px #0000004d;margin-bottom:6px;font-size:20px;font-weight:700;line-height:1.3}.banner-meta{flex-wrap:wrap;gap:6px;display:flex}.banner-tag{-webkit-backdrop-filter:blur(4px);border-radius:var(--radius-full);background:#ffffff26;border:1px solid #fff3;padding:2px 8px;font-size:11px;font-weight:500}.banner-dots{justify-content:center;gap:8px;margin-top:14px;display:flex}.banner-dot{background:var(--gray-200);border-radius:50%;width:8px;height:8px;padding:0;transition:all .3s}.banner-dot.active{background:var(--red);border-radius:4px;width:24px}.category-section{padding-top:4px}.category-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.category-card{-webkit-backdrop-filter:blur(12px)saturate(180%);border-radius:var(--radius);text-align:center;background:#ffffff8c;border:1px solid #ffffff59;flex-direction:column;align-items:center;gap:10px;padding:20px 10px 18px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 12px #3d2b1f0f}.category-card:before{content:"";opacity:0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.category-card:hover:before{opacity:1}.category-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #3d2b1f14}.category-card:active{transform:scale(.97)}.cat-icon{border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.cat-icon svg{width:26px;height:26px}.cat-info{flex-direction:column;align-items:center;gap:2px;display:flex}.cat-name{color:var(--brown);font-size:14px;font-weight:600}.cat-count{color:var(--gray-400);font-size:11px;font-weight:400}.recipe-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.recipe-card{-webkit-backdrop-filter:blur(12px)saturate(180%);border-radius:var(--radius);background:#ffffff8c;border:1px solid #ffffff59;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 2px 12px #3d2b1f0f}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #3d2b1f14}.recipe-card:active{transform:scale(.97)}.recipe-card-img{aspect-ratio:4/3;background:var(--cream-alt);overflow:hidden}.recipe-card-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.recipe-card:hover .recipe-card-img img{transform:scale(1.05)}.recipe-card-body{padding:10px 12px 12px}.recipe-card-body h4{color:var(--brown);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.recipe-card-meta{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.meta-tag{background:var(--red-subtle);color:var(--red);border-radius:var(--radius-full);letter-spacing:.02em;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.meta-tag.flavor{background:var(--amber-light);color:var(--amber)}.category-recipe-list{padding:0 16px}.list-title{color:var(--brown);margin-bottom:12px;padding-top:4px;font-size:14px;font-weight:600}.list-title .count{color:var(--gray-400);font-weight:400}.recipe-row{border-bottom:1px solid var(--gray-200);align-items:center;gap:12px;padding:12px 0;transition:background .15s;display:flex}.recipe-row:last-child{border-bottom:none}.recipe-row:active{background:var(--gray-100);border-radius:var(--radius-xs);margin:0 -16px;padding-left:16px;padding-right:16px}.recipe-row-img{border-radius:var(--radius-xs);background:var(--cream-alt);flex-shrink:0;width:64px;height:64px;overflow:hidden}.recipe-row-img img{object-fit:cover;width:100%;height:100%}.recipe-row-info{flex:1;min-width:0}.recipe-row-info h4{color:var(--brown);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.recipe-row-tags{gap:6px;margin-top:4px;display:flex}.ingredients-preview{color:var(--gray-400);white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:12px;overflow:hidden}.recipe-row-arrow{color:var(--gray-400);flex-shrink:0}.recipe-hero{aspect-ratio:16/10;background:var(--cream-alt);position:relative;overflow:hidden}.recipe-hero img{object-fit:cover;width:100%;height:100%}.hero-overlay{color:#fff;background:linear-gradient(#0000,#3d2b1fb3);padding:24px 16px 16px;position:absolute;bottom:0;left:0;right:0}.hero-overlay h2{font-family:var(--font-serif);text-shadow:0 2px 8px #0000004d;margin-bottom:8px;font-size:22px;font-weight:700}.hero-tags{flex-wrap:wrap;gap:8px;display:flex}.hero-tags .tag{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-full);background:#fff3;border:1px solid #ffffff40;padding:4px 12px;font-size:12px;font-weight:600}.recipe-content{padding:0 16px}.recipe-meta{border-bottom:1px solid var(--gray-200);flex-wrap:wrap;gap:12px;padding:16px 0;display:flex}.meta-item{flex-direction:column;gap:2px;display:flex}.meta-label{color:var(--gray-400);font-size:11px;font-weight:500}.meta-value{color:var(--brown);font-size:14px;font-weight:600}.recipe-section{border-bottom:1px solid var(--gray-200);padding:20px 0}.recipe-section:last-child{border-bottom:none}.recipe-section-title{font-family:var(--font-serif);color:var(--brown);margin-bottom:14px;font-size:17px;font-weight:700}.ingredients-list{flex-wrap:wrap;gap:8px;list-style:none;display:flex}.ingredient-item{background:var(--gray-100);border-radius:var(--radius-full);color:var(--brown);align-items:center;gap:6px;padding:6px 14px;font-size:13px;display:flex}.ingredient-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:6px;height:6px}.steps-list{flex-direction:column;gap:12px;list-style:none;display:flex}.step-item{align-items:flex-start;gap:12px;display:flex}.step-number{background:var(--red);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.step-text{color:var(--brown);padding-top:3px;font-size:14px;line-height:1.7}.step-section-title{font-family:var(--font-serif);color:var(--red);border-bottom:1px dashed var(--gray-300);margin:16px 0 8px;padding-bottom:6px;font-size:15px;font-weight:700}.step-section-title:first-child{margin-top:0}.related-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.related-card{transition:transform .2s;display:block}.related-card:hover{transform:translateY(-2px)}.related-card:active{transform:scale(.96)}.related-img{aspect-ratio:1;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(10px)saturate(180%);background:#ffffff73;border:1px solid #ffffff59;width:100%;margin-bottom:8px;overflow:hidden;box-shadow:0 4px 16px #3d2b1f14}.related-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.related-card:hover .related-img img{transform:scale(1.05)}.related-info{text-align:center}.related-info h4{color:var(--brown);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:13px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.related-info .meta-tag{font-size:10px}.search-input-area{background:var(--white);border-bottom:1px solid var(--gray-200);padding:12px 16px}.search-input-wrap{align-items:center;display:flex;position:relative}.search-input-icon{width:18px;height:18px;color:var(--gray-400);pointer-events:none;position:absolute;left:12px}.search-input-wrap input{border:1px solid var(--gray-200);border-radius:var(--radius-full);background:var(--gray-100);width:100%;color:var(--brown);outline:none;padding:10px 40px;font-size:14px;transition:border-color .15s,background .15s}.search-input-wrap input:focus{border-color:var(--red);background:var(--white)}.search-input-wrap input::placeholder{color:var(--gray-400)}.search-clear{color:var(--gray-400);border-radius:50%;padding:6px;transition:background .15s;position:absolute;right:8px}.search-clear:hover{background:var(--gray-200)}.search-info{color:var(--gray-400);padding:12px 16px 4px;font-size:13px}.search-hints{padding:24px 16px}.hint-label{color:var(--gray-400);margin-bottom:12px;font-size:13px}.hint-chips{flex-wrap:wrap;gap:8px;display:flex}.hint-chip{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-full);color:var(--brown);padding:6px 16px;font-size:13px;transition:all .15s}.hint-chip:hover{border-color:var(--red);color:var(--red);background:var(--red-subtle)}.category-tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:99;background:#fdf8f2b8;border-bottom:1px solid #ebe5db80;gap:6px;padding:10px 16px;display:flex;position:sticky;top:48px;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.cat-tab{border-radius:var(--radius-full);color:var(--gray-600);background:var(--gray-100);white-space:nowrap;flex-shrink:0;padding:6px 16px;font-size:13px;font-weight:500;transition:all .15s}.cat-tab.active{background:var(--red);color:#fff;font-weight:600}.cat-tab:hover:not(.active){background:var(--gray-200)}.filter-bar{align-items:center;gap:8px;padding:10px 16px;display:flex}.filter-toggle{border-radius:var(--radius-full);color:var(--gray-600);background:var(--white);border:1px solid var(--gray-200);align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.filter-toggle.active,.filter-toggle.has-filters{border-color:var(--red);color:var(--red);background:var(--red-subtle)}.filter-clear{color:var(--gray-400);padding:4px 8px;font-size:12px;transition:color .15s}.filter-clear:hover{color:var(--red)}.filter-panel{flex-direction:column;gap:16px;padding:0 16px 16px;display:flex}.filter-group{flex-direction:column;gap:8px;display:flex}.filter-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.filter-chips{flex-wrap:wrap;gap:6px;display:flex}.filter-chip{border-radius:var(--radius-full);color:var(--gray-600);background:var(--white);border:1px solid var(--gray-200);padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.filter-chip.active{background:var(--red);color:#fff;border-color:var(--red)}.filter-chip:hover:not(.active){border-color:var(--red);color:var(--red)}.filter-result-count{color:var(--gray-400);padding:8px 16px 4px;font-size:13px}.all-recipes-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:0 16px 16px;display:grid}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);-webkit-backdrop-filter:blur(20px)saturate(180%);padding:0 12px;padding-bottom:env(safe-area-inset-bottom,0);z-index:200;background:#ffffffb8;border-top:1px solid #ebe5db80;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{border-radius:var(--radius-xs);color:var(--gray-400);flex-direction:column;align-items:center;gap:3px;padding:6px 16px;transition:color .15s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item span{font-size:10px;font-weight:500}.nav-item.active{color:var(--red)}.nav-item:active{transform:scale(.92)}.not-found-content{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 16px;display:flex}.not-found-content h2{color:var(--gray-600);font-size:18px}.btn-primary{background:var(--red);color:#fff;border-radius:var(--radius-full);padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s;display:inline-block}.btn-primary:hover{background:var(--red-hover)}.empty-state{text-align:center;color:var(--gray-400);padding:40px 16px;font-size:14px}@media (width>=640px){.app,.bottom-nav{max-width:640px}.banner-card{flex:0 0 400px;max-width:400px}.category-grid,.recipe-grid{grid-template-columns:repeat(3,1fr);gap:14px}.related-grid{grid-template-columns:repeat(3,1fr);gap:16px}.all-recipes-grid{grid-template-columns:repeat(3,1fr);gap:14px}}@media (width>=1024px){.app,.bottom-nav{max-width:960px}.banner-card{flex:0 0 500px;max-width:500px}.category-grid{grid-template-columns:repeat(3,1fr);gap:16px}.recipe-grid{grid-template-columns:repeat(4,1fr);gap:16px}.related-grid{grid-template-columns:repeat(3,1fr);gap:18px}.all-recipes-grid{grid-template-columns:repeat(4,1fr);gap:16px}}@media (width>=1280px){.app,.bottom-nav{max-width:1200px}.banner-card{flex:0 0 560px;max-width:560px}.recipe-grid,.all-recipes-grid{grid-template-columns:repeat(4,1fr)}}.share-content{flex-direction:column;align-items:center;gap:20px;padding:20px 16px;display:flex}.share-card{aspect-ratio:3/4;border-radius:var(--radius);background:var(--cream-alt);width:100%;max-width:360px;overflow:hidden;box-shadow:0 8px 32px #3d2b1f26}.share-image{object-fit:cover;width:100%;height:100%;display:block}.share-image-placeholder{background:var(--cream-alt);width:100%;height:100%;color:var(--gray-400);justify-content:center;align-items:center;font-size:14px;display:flex}.share-save-tip{color:var(--gray-500);text-align:center;margin:0;font-size:13px}.share-qrcode{flex-direction:column;align-items:center;gap:8px;display:flex}.share-qrcode img{border-radius:var(--radius-sm);border:1px solid var(--gray-200);background:#fff;width:160px;height:160px;padding:8px}.share-qrcode p{color:var(--gray-500);font-size:12px}.share-url-box{background:var(--gray-100);border-radius:var(--radius-sm);align-items:center;gap:10px;width:100%;max-width:360px;padding:12px 16px;display:flex}.share-url-text{color:var(--gray-600);word-break:break-all;flex:1;font-size:12px;line-height:1.4}.copy-btn{border-radius:var(--radius-full);background:var(--red);color:#fff;cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.copy-btn:hover{opacity:.9}.copy-btn:active{transform:scale(.96)}.copy-btn.copied{background:#2d8b4e}
