body{margin:0}.header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.header-logo{color:var(--color-primary);letter-spacing:-.5px;font-size:22px;font-weight:700}.header-nav{align-items:center;gap:16px;display:flex}.header-favorites-link{color:var(--color-text-secondary);align-items:center;gap:6px;font-size:14px;font-weight:500;transition:color .15s;display:flex}.header-favorites-link:hover{color:var(--color-primary)}.header-heart-icon{font-size:16px}.header-favorites-count{background-color:var(--color-primary);color:#fff;text-align:center;border-radius:10px;min-width:18px;padding:2px 6px;font-size:11px;font-weight:700;line-height:1}.search-bar{width:100%}.search-input .ant-input{background-color:var(--color-surface)}.search-input.ant-input-affix-wrapper{border-color:var(--color-border);border-radius:10px}.search-input.ant-input-affix-wrapper:hover,.search-input.ant-input-affix-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px #8b735526}.filter-panel{flex-direction:column;gap:16px;display:flex}.filter-row--selects{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.filter-row--controls{grid-template-columns:1fr 1fr auto auto 148px;align-items:start;gap:12px;display:grid}.filter-group{flex-direction:column;gap:6px;min-width:0;display:flex}.filter-group--toggle{flex-direction:column;align-items:center;gap:8px}.filter-group--reset{justify-content:flex-end;align-self:end}.filter-label{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;align-items:baseline;gap:4px;font-size:12px;font-weight:500;display:flex;overflow:hidden}.filter-label-num{font-variant-numeric:tabular-nums;min-width:62px;color:var(--color-primary);font-weight:600;display:inline-block}.filter-select{width:100%}.filter-reset-btn{border-color:var(--color-border);width:100%;color:var(--color-text-secondary)}.filter-reset-btn:hover{border-color:var(--color-primary)!important;color:var(--color-primary)!important}@media (width<=1100px){.filter-row--selects{grid-template-columns:repeat(2,1fr)}.filter-row--controls{grid-template-columns:1fr 1fr auto auto}.filter-group--reset{grid-column:1/-1}.filter-reset-btn{width:auto}}@media (width<=640px){.filter-row--selects,.filter-row--controls{grid-template-columns:1fr 1fr}.filter-group--toggle{flex-direction:row;align-items:center;gap:10px}.filter-group--reset{grid-column:1/-1}}@media (width<=420px){.filter-row--selects,.filter-row--controls{grid-template-columns:1fr}}.recipe-card-link{height:100%;display:block}.recipe-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;flex-direction:column;height:100%;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.recipe-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.recipe-card-image-wrap{aspect-ratio:4/3;background:var(--color-tag-bg);flex-shrink:0;width:100%;position:relative;overflow:hidden}.recipe-card-heart{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ccc;cursor:pointer;background:#ffffffe0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:15px;transition:color .15s,transform .15s;display:flex;position:absolute;top:10px;right:10px;box-shadow:0 1px 4px #00000026}.recipe-card-heart:hover{color:#8b7355;transform:scale(1.1)}.recipe-card-heart--active{color:#8b7355}.recipe-card-image{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.recipe-card:hover .recipe-card-image{transform:scale(1.04)}.recipe-card-body{flex-direction:column;flex:1;gap:8px;padding:16px;display:flex}.recipe-card-tags{flex-wrap:wrap;gap:6px;display:flex}.recipe-card-tag{border:none;border-radius:6px;margin:0;padding:2px 8px;font-size:11px;font-weight:500}.recipe-card-tag--meal{background-color:var(--color-tag-bg);color:var(--color-primary)}.recipe-card-tag--veg{color:#2e7d32;background-color:#e8f5e9}.recipe-card-tag--vegan{color:#00695c;background-color:#e0f2f1}.recipe-card-title{color:var(--color-text);margin:0;font-size:15px;font-weight:600;line-height:1.35}.recipe-card-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin:0;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.recipe-card-meta{border-top:1px solid var(--color-border);gap:14px;margin-top:auto;padding-top:10px;display:flex}.recipe-card-meta-item{color:var(--color-text-secondary);align-items:center;gap:5px;font-size:12px;display:flex}.recipe-card-meta-item .anticon{color:var(--color-primary)}.recipe-list{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.recipe-list-empty{text-align:center;grid-column:1/-1;padding:80px 24px}.recipe-list-empty-title{color:var(--color-text);margin:0 0 8px;font-size:18px;font-weight:600}.recipe-list-empty-hint{color:var(--color-text-secondary);margin:0;font-size:14px}@media (width<=1100px){.recipe-list{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.recipe-list{grid-template-columns:1fr}}.home-page{flex-direction:column;flex:1;display:flex}.home-hero{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 24px 36px;display:flex}.home-hero-title{color:var(--color-text);letter-spacing:-.5px;margin:0;font-size:32px;font-weight:700}.home-hero-subtitle{color:var(--color-text-secondary);margin:0 0 8px;font-size:16px}.home-hero .search-bar{width:100%;max-width:640px}.home-content{flex-direction:column;gap:28px;width:100%;max-width:1400px;margin:0 auto;padding:28px 24px 48px;display:flex}.home-filters{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:20px}.home-results-count{color:var(--color-text-secondary);margin-bottom:16px;font-size:14px}@media (width<=768px){.home-hero-title{font-size:24px}.home-hero{padding:32px 16px 24px}.home-content{padding:20px 16px 40px}}.recipe-detail{max-width:900px;margin:0 auto;padding:32px 24px 64px}.recipe-detail-back{margin-bottom:24px}.recipe-detail-back-btn{color:var(--color-text-secondary);cursor:pointer;box-shadow:none;background:0 0;border:none;outline:none;align-items:center;gap:6px;padding:4px 0;font-size:14px;transition:color .15s;display:inline-flex}.recipe-detail-back-btn:hover{color:var(--color-primary)}.recipe-detail-hero{aspect-ratio:16/7;background:var(--color-tag-bg);border-radius:16px;width:100%;margin-bottom:24px;position:relative;overflow:hidden}.recipe-detail-hero-img{object-fit:cover;width:100%;height:100%;display:block}.recipe-detail-hero-overlay{background:linear-gradient(#0000 0%,#0000001a 45%,#0000009e 100%);flex-direction:column;justify-content:flex-end;padding:24px;display:flex;position:absolute;inset:0}.recipe-detail-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;text-transform:uppercase;letter-spacing:.5px;background-color:#ffffff38;border-radius:6px;align-self:flex-start;margin-bottom:8px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.recipe-detail-title{color:#fff;text-shadow:0 1px 4px #0000004d;margin:0;font-size:30px;font-weight:700;line-height:1.2}.recipe-detail-heart{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ccc;cursor:pointer;background:#ffffffe0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-size:18px;transition:color .15s,transform .15s;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #0003}.recipe-detail-heart:hover{color:#8b7355;transform:scale(1.1)}.recipe-detail-heart--active{color:#8b7355}.recipe-detail-description{color:var(--color-text-secondary);margin:0 0 28px;font-size:16px;line-height:1.7}.recipe-detail-stats{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:40px;display:flex;overflow:hidden}.recipe-detail-stat{border-right:1px solid var(--color-border);flex-direction:column;flex:1;align-items:center;gap:3px;padding:18px 12px;display:flex}.recipe-detail-stat:last-child{border-right:none}.stat-icon{color:var(--color-primary);margin-bottom:2px;font-size:18px}.stat-value{color:var(--color-text);white-space:nowrap;font-size:20px;font-weight:700}.stat-label{color:var(--color-text-secondary);font-size:11px}.recipe-detail-content{grid-template-columns:1fr 2fr;gap:40px;display:grid}.recipe-detail-section-title{color:var(--color-text);margin:0 0 16px;font-size:18px;font-weight:700}.ingredients-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.ingredient-item{align-items:baseline;gap:6px;font-size:14px;display:flex}.ingredient-name{color:var(--color-text)}.ingredient-dots{border-bottom:1px dotted var(--color-border);flex:1;min-width:12px}.ingredient-amount{color:var(--color-text-secondary);white-space:nowrap;font-size:13px}.steps-list{flex-direction:column;gap:18px;margin:0;padding:0;list-style:none;display:flex}.step-item{align-items:flex-start;gap:14px;display:flex}.step-number{background-color:var(--color-primary);color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.step-text{color:var(--color-text);padding-top:3px;font-size:15px;line-height:1.65}@media (width<=768px){.recipe-detail{padding:20px 16px 48px}.recipe-detail-hero{aspect-ratio:4/3;border-radius:12px}.recipe-detail-title{font-size:22px}.recipe-detail-stats{flex-wrap:wrap}.recipe-detail-stat{flex:calc(50% - 1px)}.recipe-detail-content{grid-template-columns:1fr;gap:28px}}.recipe-page{background-color:var(--color-bg);flex:1}.favorites-page{max-width:1200px;margin:0 auto;padding:40px 24px 64px}.favorites-header{margin-bottom:32px}.favorites-title{color:var(--color-text);margin:0 0 12px;font-size:28px;font-weight:700}.favorites-notice{color:var(--color-text-secondary);align-items:center;gap:8px;margin:0;font-size:13px;display:flex}.favorites-notice-icon{color:var(--color-text-secondary);flex-shrink:0;font-size:13px}.favorites-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.favorites-empty{text-align:center;color:var(--color-text-secondary);padding:80px 24px}.favorites-empty-icon{opacity:.4;margin-bottom:16px;font-size:56px;display:block}.favorites-empty p{color:var(--color-text);margin:0 0 8px;font-size:18px;font-weight:600}.favorites-empty-hint{max-width:320px;font-size:14px;color:var(--color-text-secondary)!important;margin:0 auto!important;font-weight:400!important}:root{--color-bg:#faf8f5;--color-surface:#fff;--color-primary:#8b7355;--color-primary-hover:#7a6349;--color-text:#2d2a26;--color-text-secondary:#8c8580;--color-border:#e8e4dc;--color-tag-bg:#f0ede6;--shadow-card:0 2px 8px #0000000f;--shadow-card-hover:0 8px 24px #0000001a}*,:before,:after{box-sizing:border-box}body{background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}a{color:inherit;text-decoration:none}#root{flex-direction:column;min-height:100vh;display:flex}
