*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background:#f0f2f5}#root{width:100%;min-height:100vh;margin:0;padding:0}.meal-menu-editor{flex:1;display:flex;flex-direction:column;gap:8px}.dishes-list{flex:1;display:flex;flex-direction:column;gap:6px;min-height:70px;padding:8px;background:#f8f9fa;border-radius:6px;border:2px dashed #e8e8e8}.dishes-list.breakfast-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;align-items:start}.dishes-list.breakfast-layout{display:flex;flex-direction:column;gap:6px;align-items:stretch}.dishes-list:empty:before{content:"点击下方按钮添加菜品";color:#999;font-style:italic;font-size:13px;text-align:center;width:100%;line-height:56px}.dish-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#fff;border-radius:6px;border:1px solid #e8e8e8;transition:all .2s}.breakfast-grid .dish-item{padding:6px 8px;min-width:0;width:100%;flex:none;border-radius:6px;background:#fff;border:1px solid #e8e8e8;display:flex;align-items:center}.breakfast-layout .dish-item{padding:6px 10px;min-width:auto;width:100%;flex:none;border-radius:6px;background:#fff;border:1px solid #e8e8e8}.dish-item:hover{border-color:#1890ff;box-shadow:0 2px 4px #1890ff1a}.dish-content{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.breakfast-grid .dish-content{gap:8px;align-items:center;flex:1;min-width:0}.breakfast-layout .dish-content{gap:12px;align-items:flex-start}.dish-image,.breakfast-layout .dish-image{display:none}.dish-image img{width:100%;height:100%;object-fit:cover}.dish-image-placeholder{font-size:20px;color:#bfbfbf}.dish-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.breakfast-grid .dish-info{gap:2px;flex-direction:column;align-items:flex-start;flex:1;min-width:0}.breakfast-layout .dish-info{gap:4px;flex-direction:column;align-items:flex-start}.dish-bottom-info{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.breakfast-grid .dish-bottom-info{margin-top:2px;margin-left:0;gap:0;justify-content:space-between}.breakfast-layout .dish-bottom-info{margin-top:4px;margin-left:0;gap:0}.dish-name{font-size:14px;font-weight:500;color:#262626;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.breakfast-grid .dish-name{font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.breakfast-layout .dish-name{font-size:14px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:none}.dish-category-tag{align-self:flex-start;margin:0}.breakfast-grid .dish-category-tag{font-size:11px;padding:1px 4px;line-height:1.1;border-radius:3px;display:inline-block}.breakfast-layout .dish-category-tag{font-size:12px;padding:2px 6px;line-height:1.2;border-radius:4px;display:inline-block}.delete-dish-btn{opacity:.6;transition:opacity .2s}.delete-dish-btn:hover{opacity:1}.breakfast-grid .delete-dish-btn{font-size:11px;width:auto;height:auto;padding:2px;border-radius:3px;background:transparent}.breakfast-layout .delete-dish-btn{font-size:12px;width:auto;height:auto;padding:4px;border-radius:4px;background:transparent}.add-dish-btn{width:100%;height:32px;font-size:13px;font-weight:500;border-style:dashed;border-color:#1890ff;border-width:2px;color:#1890ff;transition:all .2s ease;border-radius:6px;background:#fff}.add-dish-btn:hover{border-color:#40a9ff;color:#40a9ff;background:#f0f8ff;box-shadow:0 2px 8px #1890ff26}.dish-menu-item{padding:4px 8px;cursor:pointer;border-radius:4px;transition:background-color .2s ease;font-size:13px}.dish-menu-item:hover{background-color:#f0f8ff;color:#1890ff}.ant-dropdown-menu{max-height:300px;overflow-y:auto;border-radius:8px;box-shadow:0 4px 12px #00000026}.ant-dropdown-menu-submenu-title{font-weight:600;color:#1890ff}@media (max-width: 768px){.dishes-list{min-height:50px;padding:6px}.dish-tag{font-size:11px;margin:1px 0}.add-dish-btn{height:24px;font-size:11px}.dish-menu-item{padding:3px 6px;font-size:12px}}.day-menu-editor{height:100%;display:flex;flex-direction:column;gap:16px}.meal-section{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:8px;padding:12px;border:1px solid #e8e8e8;min-height:120px}.meal-title{font-size:15px;font-weight:700;margin-bottom:12px;padding:8px 12px;border-radius:6px;display:flex;align-items:center;text-transform:uppercase;letter-spacing:.5px}.meal-section:nth-child(1) .meal-title{color:#ff4d4f;background:linear-gradient(135deg,#fff1f0,#ffeded);border-left:4px solid #ff4d4f}.meal-section:nth-child(2) .meal-title{color:#1890ff;background:linear-gradient(135deg,#e6f7ff,#f0f8ff);border-left:4px solid #1890ff}.meal-section:nth-child(3) .meal-title{color:#52c41a;background:linear-gradient(135deg,#f6ffed,#f0fff0);border-left:4px solid #52c41a}.meal-divider{margin:16px 0!important;border-color:#e8e8e8}@media (max-width: 768px){.meal-title{font-size:13px;padding:3px 6px;margin-bottom:6px}.meal-divider{margin:8px 0!important}}.week-menu-editor{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:100%}.workdays-grid{display:grid;grid-template-columns:repeat(5,minmax(280px,1fr));gap:12px;width:100%;max-width:100%;grid-auto-rows:max-content;align-items:start;overflow-x:auto}.day-menu-card{min-height:500px;border-radius:8px;border:2px solid #1890ff;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column}.day-menu-card .ant-card-head{background:linear-gradient(135deg,#1890ff,#40a9ff);border-bottom:none;padding:12px 16px;min-height:auto}.day-menu-card .ant-card-head-title{padding:0;color:#fff;font-weight:600}.day-card-title{display:flex;flex-direction:column;align-items:center;gap:4px}.weekday{font-size:16px;font-weight:700;letter-spacing:1px}.date{font-size:12px;opacity:.9;font-weight:400}.day-menu-card .ant-card-body{padding:16px;flex:1;background:#fafafa}@media (max-width: 1400px){.workdays-grid{gap:12px}}@media (max-width: 1200px){.week-menu-editor{padding:16px}.workdays-grid{gap:10px}}@media (max-width: 768px){.week-menu-editor{padding:12px}.workdays-grid{grid-template-columns:repeat(2,1fr);gap:12px}.day-menu-card .ant-card-body{padding:12px}.day-card-title{gap:2px}.weekday{font-size:14px}.date{font-size:11px}}@media (max-width: 576px){.workdays-grid{grid-template-columns:1fr;gap:16px}}.dish-library-manager .ant-modal-body{padding:24px}.manager-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.add-dish-form{background:#fafafa;padding:16px;border-radius:8px;margin-bottom:20px;border:1px solid #d9d9d9}.add-dish-form .ant-form{margin:0;display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end}.add-dish-form .ant-form-item{margin-bottom:16px;flex:0 0 auto}.add-dish-form .ant-form-item:last-child{margin-bottom:16px}.dish-library-layout{display:flex;height:60vh;gap:16px}.category-sidebar{width:280px;background:#fafafa;border-radius:8px;border:1px solid #e8e8e8;overflow:hidden}.category-title{padding:12px 16px;background:#1890ff;color:#fff;font-weight:600;font-size:14px}.category-list{max-height:calc(60vh - 48px);overflow-y:auto;padding:8px 0}.category-item{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.category-item:hover{background:#e6f7ff;color:#1890ff}.category-item.active{background:#e6f7ff;color:#1890ff;border-left-color:#1890ff;font-weight:600}.category-group{margin-bottom:8px}.parent-category{padding:6px 16px;font-size:12px;font-weight:600;color:#666;background:#f0f0f0;border-bottom:1px solid #e8e8e8}.sub-category{padding-left:32px!important;font-size:13px}.category-name{flex:1}.category-count{font-size:12px;color:#999;background:#f0f0f0;padding:2px 6px;border-radius:10px}.category-item.active .category-count{background:#1890ff;color:#fff}.dishes-content{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:8px;border:1px solid #e8e8e8;overflow:hidden}.dishes-header{padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e8e8e8}.dishes-header h3{margin:0;font-size:16px;font-weight:600;color:#1890ff}.dishes-list-container{flex:1;overflow-y:auto;padding:8px}.ant-list-item{padding:12px 0;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.ant-list-item:hover{background-color:#fafafa;border-radius:4px;padding-left:8px;padding-right:8px}.ant-list-item:last-child{border-bottom:none}.ant-list-item-meta-title{margin-bottom:4px;font-weight:500}.ant-list-item-meta-description{color:#666;font-size:13px}.ant-list-item-action{margin-left:16px}.ant-list-item-action li{padding:0 4px}.ant-list-item-action .ant-btn{border:none;box-shadow:none;padding:4px 8px;height:auto}.ant-list-item-action .ant-btn:hover{background-color:#f0f0f0;border-radius:4px}.ant-list-item-action .ant-btn.ant-btn-dangerous:hover{background-color:#fff2f0;color:#ff4d4f}@media (max-width: 768px){.dish-library-manager .ant-modal{width:95%!important;max-width:none}.dish-library-manager .ant-modal-body{padding:16px}.add-dish-form{padding:12px}.add-dish-form .ant-form{flex-direction:column}.add-dish-form .ant-form-item{margin-right:0;margin-bottom:12px;width:100%}.add-dish-form .ant-form-item:last-child{margin-bottom:0}.add-dish-form .ant-input,.add-dish-form .ant-select{width:100%}.dish-tabs .ant-tabs-content-holder{max-height:300px}.ant-list-item{padding:8px 0}.ant-list-item-action{margin-left:8px}}.export-menu-modal .ant-modal-body{padding:24px}.export-content{display:flex;flex-direction:column;gap:24px}.menu-preview{background:#fafafa;padding:16px;border-radius:8px;border:1px solid #d9d9d9}.menu-preview h4{margin:0 0 12px;color:#1890ff;font-weight:600}.preview-info{display:flex;flex-direction:column;gap:8px}.preview-info p{margin:0;font-size:14px;color:#666}.preview-info strong{color:#333;font-weight:600}.format-selection h4{margin:0 0 16px;color:#1890ff;font-weight:600}.format-options{display:flex;flex-direction:column;gap:12px}.format-option{width:100%!important;height:auto!important;padding:0!important;border-radius:8px!important;overflow:hidden}.format-option .ant-radio-button-wrapper{width:100%;height:auto;padding:16px;border-radius:8px;border:1px solid #d9d9d9;background:#fff;transition:all .2s ease}.format-option .ant-radio-button-wrapper:hover{border-color:#1890ff;background:#f0f8ff}.format-option .ant-radio-button-wrapper-checked{border-color:#1890ff;background:#e6f7ff;color:#1890ff}.format-content{display:flex;flex-direction:column;gap:8px;width:100%}.format-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:16px}.format-header .anticon{font-size:20px}.format-label{color:inherit}.format-description{font-size:13px;color:#666;font-weight:400;margin-left:28px}.format-option .ant-radio-button-wrapper-checked .format-description{color:#1890ff}.export-progress{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;background:#f0f8ff;border-radius:8px;border:1px solid #d9d9d9}.export-progress span{color:#1890ff;font-weight:500}.export-preview{max-height:500px;overflow-y:auto;border:1px solid #e8e8e8;border-radius:6px;background:#f9f9f9;padding:10px}.preview-content{transform:scale(.6);transform-origin:top left;width:166.67%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}@media (max-width: 768px){.export-menu-modal .ant-modal{width:95%!important;max-width:none}.export-menu-modal .ant-modal-body{padding:16px}.export-content{gap:16px}.menu-preview,.format-option .ant-radio-button-wrapper{padding:12px}.format-header{font-size:14px}.format-header .anticon{font-size:18px}.format-description{font-size:12px;margin-left:26px}.preview-info{gap:6px}.preview-info p{font-size:13px}}.menu-planner{min-height:100vh}.menu-planner-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #00000026;padding:8px 16px;position:sticky;top:0;z-index:100;width:100%}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;margin:0}.header-left{display:flex;align-items:center;gap:12px;flex:0 0 auto}.header-center{display:flex;flex-direction:column;justify-content:center;align-items:center;flex:1;gap:6px}.header-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.menu-title-section{text-align:center}.week-selector{display:flex;align-items:center;gap:2px;background:#f8f9fa;border-radius:6px;padding:2px;border:1px solid #e8e8e8}.week-display{font-size:11px;font-weight:600;color:#1890ff;padding:3px 6px;background:#fff;border-radius:4px;min-width:120px;text-align:center;white-space:nowrap;border:1px solid #d9d9d9}.header-icon{font-size:24px;color:#1890ff}.header-info{display:flex;flex-direction:column;gap:4px}.header-title{margin:0!important;color:#1890ff;font-weight:600;font-size:20px}.menu-subtitle{display:flex;flex-direction:column;gap:2px}.menu-title{font-size:14px;font-weight:500;color:#1890ff}.menu-dates{font-size:12px;color:#8c8c8c}.header-actions{display:flex;gap:8px;justify-self:end}.menu-planner-content{background:#f0f2f5;min-height:calc(100vh - 56px)}.content-wrapper{width:100%;max-width:100%;margin:0;padding:16px}@media (max-width: 768px){.header-content{flex-direction:column;height:auto;padding:12px 0;gap:12px}.header-left{flex-direction:column;text-align:center;gap:8px}.header-title{font-size:18px!important}.header-actions{flex-wrap:wrap;justify-content:center}.content-wrapper{padding:16px}.menu-header{padding:16px;text-align:center}.menu-info{flex-direction:column;gap:8px;align-items:center}}.app{min-height:100vh;background:#f0f2f5;width:100%;margin:0;padding:0}.app .ant-layout{min-height:100vh;background:#f0f2f5;width:100%}.app .ant-layout-header{background:#fff;box-shadow:0 2px 8px #0000001a;padding:0;width:100%}.app .ant-layout-content{padding:24px;width:100%}
