*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#faf8f5;color:#333}a{text-decoration:none;color:inherit}.app-wrapper{padding-bottom:70px;min-height:100vh}.tab-bar{position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;display:flex;border-top:1px solid #f0f0f0;z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:color .2s;color:#999}.tab-item.active{color:#e8603c}.tab-svg{width:22px;height:22px}.tab-label{font-size:10px;margin-top:2px}.page{max-width:560px;margin:0 auto;padding:16px}.brand{text-align:center;padding:12px 0 8px}.brand-text{font-size:24px;font-weight:700;color:#e8603c;letter-spacing:2px}.search-bar{display:flex;align-items:center;background:#f2f2f2;border-radius:24px;padding:10px 16px;margin:8px 0 16px;cursor:pointer}.search-bar input{flex:1;border:none;background:none;outline:none;font-size:14px}.search-icon{margin-right:8px;font-size:14px}.search-hint{color:#999;font-size:14px}.cat-grid{display:flex;justify-content:space-around;flex-wrap:wrap;margin-bottom:16px;padding:8px 0}.cat-entry{display:flex;flex-direction:column;align-items:center;cursor:pointer;width:16%;min-width:60px}.cat-icon{width:48px;height:48px;background:#fff3ef;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#e8603c;margin-bottom:4px;transition:all .2s}.cat-entry:hover .cat-icon{transform:scale(1.1);background:#e8603c;color:#fff}.cat-name{font-size:12px;color:#666}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-title{font-size:17px;font-weight:600;color:#333}.sort-tabs{display:flex;gap:16px}.sort-tabs span{font-size:13px;color:#999;padding:2px 0;cursor:pointer}.sort-tabs span.active{color:#e8603c;font-weight:600;border-bottom:2px solid #e8603c}.recipe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.recipe-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000a;cursor:pointer;transition:transform .2s,box-shadow .2s}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.card-img{width:100%;height:140px;object-fit:cover;display:block}.card-cover{width:100%;height:140px;background:linear-gradient(135deg,#fff3ef,#fce4d6);display:flex;align-items:center;justify-content:center}.cover-text{font-size:20px;font-weight:700;color:#e8603c;opacity:.6;max-width:80%;text-align:center;word-break:break-all}.card-body{padding:8px 10px 10px}.card-title{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.card-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.card-author{font-size:12px;color:#999}.card-stats{font-size:12px;color:#bbb}.fab{position:fixed;right:20px;bottom:76px;width:48px;height:48px;background:#e8603c;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #e8603c66;cursor:pointer;z-index:99;font-size:24px;color:#fff;font-weight:300;transition:transform .2s}.fab:hover{transform:scale(1.1)}.btn{display:inline-block;padding:10px 24px;border-radius:8px;border:none;cursor:pointer;font-size:14px;transition:opacity .2s}.btn-primary{background:#e8603c;color:#fff}.btn-outline{background:transparent;border:1px solid #e8603c;color:#e8603c}.btn:hover{opacity:.85}.empty{text-align:center;padding:60px 0;color:#999;font-size:14px}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:999}.login-modal{background:#fff;border-radius:12px;padding:32px;width:360px;max-width:90vw}.login-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;margin-bottom:12px;font-size:14px;outline:none}.login-input:focus{border-color:#e8603c}.tag{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag-selected{background:#fff3ef;color:#e8603c;border:1px solid #e8603c;cursor:pointer}.tag-popular{background:#fff;color:#333;border:1px solid #eee;cursor:pointer}.tag-popular.chosen{background:#fff3ef;color:#e8603c;border-color:#e8603c}.tag-history{background:#f5f5f5;color:#666;cursor:pointer}.match-btn{background:#fff3ef;color:#e8603c;text-align:center;padding:14px;border-radius:10px;font-size:16px;font-weight:600;margin:16px 0;cursor:pointer;transition:opacity .2s}.match-btn:hover{opacity:.85}.match-btn.disabled{opacity:.5;cursor:not-allowed}.result-card{display:flex;gap:12px;background:#fff;border-radius:12px;padding:12px;cursor:pointer;transition:box-shadow .2s}.result-card:hover{box-shadow:0 4px 12px #00000014}.result-img{width:100px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0}.result-info{flex:1;display:flex;flex-direction:column;justify-content:space-between}.result-title{font-size:15px;font-weight:600}.result-meta{font-size:12px;color:#999}.match-good{font-size:12px;color:#67c23a}.match-miss{font-size:12px;color:#e6a23c;margin-left:8px}.profile-header{padding:24px 16px 16px;background:#fff;border-radius:0 0 16px 16px;margin-bottom:12px}.profile-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.nickname{font-size:22px;font-weight:700;color:#222}.join-time{font-size:12px;color:#bbb;margin-top:4px}.avatar-circle{width:64px;height:64px;background:#f2f2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px}.follow-row{display:flex;align-items:center;gap:20px}.follow-item{display:flex;flex-direction:column;align-items:center;cursor:pointer}.follow-num{font-size:18px;font-weight:700;color:#222}.follow-label{font-size:12px;color:#999}.profile-actions{display:flex;gap:8px;margin-left:auto}.action-pill{padding:6px 14px;border-radius:16px;font-size:12px;background:#f5f5f5;color:#333;cursor:pointer;transition:background .2s}.action-pill:hover{background:#eee}.stats-card{display:flex;justify-content:space-around;background:#fff;margin:0 0 12px;border-radius:12px;padding:16px 0}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-num{font-size:20px;font-weight:700;color:#e8603c}.stat-label{font-size:12px;color:#999;margin-top:2px}.tab-row{display:flex;border-bottom:1px solid #f0f0f0;margin-bottom:12px}.tab-row-item{flex:1;text-align:center;padding:12px 0;font-size:14px;color:#999;cursor:pointer;position:relative}.tab-row-item.active{color:#e8603c;font-weight:600}.tab-row-item.active:after{content:"";position:absolute;bottom:0;left:30%;width:40%;height:2px;background:#e8603c;border-radius:1px}.status-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:12px;border-radius:10px;margin-bottom:8px;cursor:pointer}.status-item:hover{box-shadow:0 2px 8px #0000000a}.status-left{flex:1;min-width:0}.status-title{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-meta{font-size:12px;color:#bbb;margin-top:2px}.status-data{display:flex;gap:10px;font-size:12px;color:#999;margin-top:4px}.status-badge{font-size:12px;padding:3px 10px;border-radius:12px;flex-shrink:0;margin-left:8px}.status-badge.approved{background:#f0f9eb;color:#67c23a}.status-badge.rejected{background:#fef0f0;color:#f56c6c}.status-badge.pending{background:#fdf6ec;color:#e6a23c}.recipe-detail{max-width:560px;margin:0 auto;padding:16px}.recipe-detail h1{font-size:22px;margin-bottom:8px}.detail-tags{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.detail-tag{background:#fff3ef;color:#e8603c;padding:4px 12px;border-radius:12px;font-size:12px}.section-label{font-size:16px;font-weight:600;margin:20px 0 10px;padding-left:10px;border-left:3px solid #e8603c}.ingredient-list{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ingredient-item{display:flex;justify-content:space-between;padding:8px 10px;background:#faf8f5;border-radius:8px;font-size:13px}.ingredient-item span:last-child{color:#e8603c}.step-item{display:flex;gap:12px;margin-bottom:14px}.step-num{width:26px;height:26px;background:#e8603c;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.step-content{flex:1;line-height:1.7;font-size:14px}.tips-box{background:#fff3ef;padding:14px;border-radius:8px;margin-top:16px;font-size:13px;line-height:1.6}.author-card{display:flex;align-items:center;gap:12px;background:#fff;padding:12px;border-radius:12px;margin:12px 0}.author-avatar{width:44px;height:44px;background:#f2f2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;cursor:pointer}.author-info{flex:1}.author-name{font-size:14px;font-weight:600;cursor:pointer}.author-fans{font-size:12px;color:#999}.follow-btn{padding:5px 14px;border-radius:16px;font-size:12px;cursor:pointer;border:none;transition:all .2s}.follow-btn.following{background:#f5f5f5;color:#999}.follow-btn.not-following{background:#e8603c;color:#fff}.action-bar{display:flex;gap:10px;margin:16px 0}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:10px;border-radius:10px;border:1px solid #eee;background:#fff;cursor:pointer;font-size:13px;transition:all .2s}.action-btn.active{background:#fff3ef;border-color:#e8603c;color:#e8603c}.action-btn:hover{border-color:#e8603c}.comment-input-row{display:flex;gap:8px;margin-bottom:16px}.comment-input-row input{flex:1;border:1px solid #eee;border-radius:20px;padding:8px 14px;font-size:13px;outline:none}.comment-input-row input:focus{border-color:#e8603c}.comment-input-row button{background:#e8603c;color:#fff;border:none;border-radius:20px;padding:8px 16px;cursor:pointer;font-size:13px}.comment-item{padding:10px 0;border-bottom:1px solid #f5f5f5}.comment-item .c-author{font-weight:600;font-size:13px}.comment-item .c-time{color:#999;font-size:11px;margin-left:8px}.comment-item .c-text{margin-top:4px;line-height:1.6;font-size:13px}.data-row{display:flex;gap:16px;font-size:12px;color:#999;margin:8px 0}.form-group{margin-bottom:14px}.form-group label{display:block;font-weight:600;margin-bottom:4px;font-size:13px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px;border:1px solid #ddd;border-radius:8px;font-size:13px;outline:none}.form-group textarea{min-height:70px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#e8603c}.bottom-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:999;display:flex;align-items:flex-end;justify-content:center}.bottom-modal-content{background:#fff;width:100%;max-width:560px;border-radius:16px 16px 0 0;padding:20px;max-height:60vh;overflow-y:auto}.modal-title{font-size:17px;font-weight:600;text-align:center;margin-bottom:16px}.user-row{display:flex;align-items:center;gap:12px;padding:8px 0;cursor:pointer}.user-avatar-sm{width:36px;height:36px;background:#f2f2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px}.user-name-sm{font-size:14px;font-weight:600}.user-meta-sm{font-size:12px;color:#999}.login-tip{text-align:center;padding:80px 0}.tip-emoji{font-size:48px;display:block;margin-bottom:12px}.tip-text{color:#999;font-size:14px;display:block;margin-bottom:16px}@media (max-width: 480px){.page{padding:12px}.recipe-grid{gap:8px}.card-img,.card-cover,.card-cover-text{height:120px}.ingredient-list{grid-template-columns:1fr}}.card-cover-text{height:160px;border-radius:10px 10px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;box-sizing:border-box;position:relative;overflow:hidden}.card-cover-text .cover-cat{position:absolute;top:8px;left:8px;background:#ffffff40;color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-cover-text .cover-title{color:#fff;font-size:20px;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.2);text-align:center;line-height:1.3;max-width:100%;word-break:break-all}.card-cover-text .cover-meta{display:flex;gap:6px;margin-top:8px}.card-cover-text .cover-meta span{background:#fff3;color:#fff;font-size:11px;padding:2px 8px;border-radius:8px}.step-edit-item{margin-bottom:10px;padding:10px;background:#fafafa;border-radius:8px}.step-img-upload{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px dashed #ccc;border-radius:6px;font-size:12px;color:#999;cursor:pointer}.step-img-upload:hover{border-color:#e8603c;color:#e8603c}.cover-upload{display:inline-flex;align-items:center;gap:4px;padding:12px 20px;border:2px dashed #ddd;border-radius:8px;font-size:13px;color:#999;cursor:pointer}.cover-upload:hover{border-color:#e8603c;color:#e8603c}.detail-cover-text{width:100%;height:220px;border-radius:12px;margin-bottom:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;box-sizing:border-box;position:relative}.detail-cover-text .cover-cat-label{position:absolute;top:12px;left:12px;background:#ffffff40;color:#fff;font-size:12px;padding:3px 10px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.detail-cover-text .cover-big-title{color:#fff;font-size:28px;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.2);text-align:center}.detail-cover-text .cover-tags{display:flex;gap:8px;margin-top:12px}.detail-cover-text .cover-tags span{background:#fff3;color:#fff;font-size:12px;padding:3px 10px;border-radius:10px}.img-preview-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;cursor:pointer}.img-preview-full{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;cursor:default}.img-preview-close{position:fixed;top:16px;right:20px;color:#fff;font-size:36px;cursor:pointer;line-height:1;opacity:.8}.img-preview-close:hover{opacity:1}
