:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-panel{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:20px}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:32px;height:32px}.close-btn:hover{color:#c62828}.modal-body{padding:20px}.form-row{margin-bottom:15px}.form-row input,.form-row select,.form-row textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box}.form-row label{display:inline-block;margin-right:10px;font-weight:500}.add-btn{width:100%;padding:12px;background:#43a047;color:#fff;border:none;border-radius:6px;font-size:16px;cursor:pointer;margin-bottom:20px}.add-btn:hover{background:#2e7d32}.add-btn:disabled{background:#ccc;cursor:not-allowed}.allergy-table{width:100%;border-collapse:collapse}.allergy-table th,.allergy-table td{padding:10px;text-align:left;border-bottom:1px solid #eee}.allergy-table th{background:#f5f5f5;font-weight:600}.delete-btn{background:none;border:none;color:#c62828;cursor:pointer;font-weight:600}.delete-btn:hover{text-decoration:underline}.settings-overlay{position:fixed;inset:0;z-index:999}.settings-menu{position:fixed;top:60px;right:20px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;width:280px;z-index:1000;overflow:hidden}.menu-section{padding:8px 0}.menu-header{padding:8px 16px;font-size:12px;color:#666;font-weight:600;text-transform:uppercase}.menu-item{padding:12px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s}.menu-item:hover{background:#f5f5f5}.menu-item.disabled{cursor:default;color:#666}.menu-item.disabled:hover{background:transparent}.menu-item.danger{color:#c62828}.menu-item.danger:hover{background:#fee}.user-email{font-size:13px;color:#333}.menu-separator{height:1px;background:#eee;margin:4px 0}.language-list{display:flex;flex-direction:column;gap:4px}.language-option{display:flex;align-items:center;padding:14px 16px;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;position:relative}.language-option:hover{background:#f5f5f5}.language-option input[type=radio]{margin-right:12px;cursor:pointer}.language-option input[type=radio]:checked+.language-name{font-weight:600;color:#1e88e5}.language-name{flex:1;font-size:15px}.check-mark{color:#43a047;font-size:18px;font-weight:700}.save-btn{width:100%;padding:14px;background:#1e88e5;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;margin-top:20px;font-weight:600}.save-btn:hover{background:#1565c0}.pref-section{margin-bottom:24px}.pref-section h3{font-size:16px;margin:0 0 16px;color:#333}.pref-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f9f9f9;border-radius:8px;margin-bottom:12px}.pref-info{flex:1}.pref-label{font-size:15px;font-weight:500;color:#333;margin-bottom:4px}.pref-description{font-size:13px;color:#666}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;margin-left:12px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.toggle-slider{background-color:#43a047}input:checked+.toggle-slider:before{transform:translate(24px)}.info-box{background:#f0f9ff;padding:12px 16px;border-radius:8px;margin:20px 0}.info-box p{margin:0;font-size:14px;color:#555}.save-btn{width:100%;padding:14px;background:#43a047;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;font-weight:600}.save-btn:hover{background:#2e7d32}.card{display:inline-block;width:100%;position:relative;background:#fff;margin:0 0 8px;padding:0;border-radius:16px;overflow:hidden;break-inside:avoid;-webkit-column-break-inside:avoid;box-shadow:0 1px 3px #0000001f}.card:hover{box-shadow:0 4px 12px #00000026}.add-to-plan-btn{position:absolute;top:6px;right:6px;z-index:10;width:24px;height:24px;padding:0;background:#ffffffe6;border:none;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000001a;transition:transform .2s}.add-to-plan-btn.added{background:transparent;box-shadow:none}.add-to-plan-btn:hover{transform:scale(1.1)}.add-to-plan-btn svg{width:100%;height:100%}.card-title{margin:8px 10px 6px;padding:0;font-size:16px;font-weight:600;line-height:1.35;color:#333;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden;text-align:left}.card-image{width:100%;height:auto;display:block;aspect-ratio:4 / 5;object-fit:cover;border-radius:0;border:none;background:#e9e9ec;cursor:zoom-in;margin:0;padding:0;transition:opacity .25s ease,filter .25s ease}.card-footer{display:flex;align-items:center;gap:8px;padding:0 10px 10px}.author{flex:1;color:#666;font-size:14px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-btn{margin-left:auto;border:none;background:none;font-size:18px;cursor:pointer;padding:0;line-height:1}.fav-btn:hover{transform:scale(1.1)}.fav-btn:disabled{cursor:not-allowed;opacity:.5}.action-btn-card{border:none;background:none;font-size:16px;cursor:pointer;padding:2px;line-height:1;opacity:.8;transition:opacity .2s}.action-btn-card:hover{opacity:1;transform:scale(1.1)}.fav-count{margin-right:0;font-size:13px;color:#666;font-weight:500}.recipe-detail-modal{position:fixed;inset:0;z-index:12000;display:flex;background:#000000b3}.xpm{position:absolute;inset:0;display:flex;flex-direction:column;background:#fff;color:#111}@media(prefers-color-scheme:dark){.xpm{background:#0b0b0c;color:#f5f5f5}}.xpm-header{position:sticky;top:0;z-index:2;height:48px;display:flex;align-items:center;gap:10px;padding:0 12px;border-bottom:1px solid rgba(0,0,0,.08);background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media(prefers-color-scheme:dark){.xpm-header{border-bottom:1px solid rgba(255,255,255,.08);background:#121214e6}}.xpm-header .xpm-btn{border:none;background:none;cursor:pointer;font-size:20px;line-height:1;padding:6px;color:inherit}.xpm-header .xpm-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.xpm-header .grow{flex:1}.xpm-body{position:relative;flex:1;overflow:auto;-webkit-overflow-scrolling:touch}.xpm-section{padding:16px;border-top:1px solid rgba(0,0,0,.06)}@media(prefers-color-scheme:dark){.xpm-section{border-top:1px solid rgba(255,255,255,.08)}}.xpm-media{width:100%;aspect-ratio:4/5;background:#e9e9ec;overflow:hidden}.xpm-media img{width:100%;height:100%;object-fit:cover;display:block}.xpm-section h3{font-size:18px;font-weight:700;margin:0 0 8px}.xpm-section h4{margin:0 0 12px;font-size:16px;font-weight:600}.xpm-kv{display:flex;flex-wrap:wrap;gap:6px 12px}.xpm-kv .kv{font-size:13px;color:#666}@media(prefers-color-scheme:dark){.xpm-kv .kv{color:#999}}.xpm-list{list-style:none;padding:0;margin:0}.xpm-list li{padding:4px 0;border-bottom:1px dotted rgba(0,0,0,.08)}@media(prefers-color-scheme:dark){.xpm-list li{border-bottom:1px dotted rgba(255,255,255,.12)}}.xpm-list li label{display:flex;align-items:center;gap:8px;cursor:pointer}.xpm-list input[type=checkbox]{width:16px;height:16px}.xpm-list .weight{opacity:.8}.xpm-list.xpm-inline2{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.xpm-list.xpm-inline2 li{display:block!important;border-bottom:0!important;padding:0!important;margin:0!important;width:auto!important}.xpm-list.xpm-inline2 li label{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;background:#0000000a;border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:4px 8px}@media(prefers-color-scheme:dark){.xpm-list.xpm-inline2 li label{background:#ffffff0f;border-color:#ffffff2e}}.stepsBox{margin-top:8px}.stepsBox ol{padding-left:20px}.stepsBox li{margin:8px 0;line-height:1.6}.muted{font-size:14px;color:#666}@media(prefers-color-scheme:dark){.muted{color:#999}}.xpm-comments{background:#f8f8f8}@media(prefers-color-scheme:dark){.xpm-comments{background:#0f0f10}}.xpm-comments .commentList{margin-top:12px}.empty-comments{text-align:center;padding:40px 20px}.empty-comments .empty-icon{font-size:48px;margin-bottom:12px;opacity:.3}.empty-comments .empty-text{font-size:14px;color:#999}.comment-card{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06)}@media(prefers-color-scheme:dark){.comment-card{border-bottom:1px solid rgba(255,255,255,.08)}}.comment-card:last-child{border-bottom:none}.comment-avatar{flex-shrink:0}.comment-avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover;background:#e0e0e0}.comment-content{flex:1;min-width:0}.comment-header{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}.comment-author{font-size:14px;font-weight:600;color:#333}@media(prefers-color-scheme:dark){.comment-author{color:#e0e0e0}}.comment-time{font-size:12px;color:#999}.comment-text{font-size:14px;line-height:1.6;color:#333;margin-bottom:8px;word-break:break-word}@media(prefers-color-scheme:dark){.comment-text{color:#ddd}}.comment-images{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}.comment-images img{width:60px;height:60px;border-radius:4px;object-fit:cover;cursor:pointer;transition:transform .2s;border:1px solid rgba(0,0,0,.1)}@media(prefers-color-scheme:dark){.comment-images img{border-color:#ffffff1a}}.comment-images img:hover{transform:scale(1.1)}.comment-actions-row{display:flex;gap:16px;align-items:center}.action-btn{display:inline-flex;align-items:center;gap:4px;border:none;background:none;padding:0;cursor:pointer;font-size:13px;color:#666;transition:color .2s}.action-btn:hover{color:#333}@media(prefers-color-scheme:dark){.action-btn{color:#999}.action-btn:hover{color:#ddd}}.action-btn .icon{font-size:16px}.action-btn .count,.action-btn .text{font-size:13px}.like-btn.liked,.like-btn.liked:hover{color:#ff2442}.loading-comments{text-align:center;padding:20px;font-size:14px;color:#999}.comment-input-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.06)}@media(prefers-color-scheme:dark){.comment-input-section{border-top:1px solid rgba(255,255,255,.08)}}.login-prompt{text-align:center;padding:24px;background:#f8f8f8;border-radius:12px}@media(prefers-color-scheme:dark){.login-prompt{background:#1a1a1c}}.login-prompt .prompt-text{font-size:14px;color:#666}@media(prefers-color-scheme:dark){.login-prompt .prompt-text{color:#999}}.comment-input-box{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:12px}@media(prefers-color-scheme:dark){.comment-input-box{background:#1a1a1c;border-color:#333}}.comment-input-box textarea{width:100%;border:none;outline:none;font-size:14px;line-height:1.6;resize:none;font-family:inherit;background:transparent;color:inherit}.comment-input-box textarea::placeholder{color:#999}.input-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.input-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:#f0f0f0;cursor:pointer;font-size:18px;transition:background .2s}.input-icon-btn:hover{background:#e0e0e0}@media(prefers-color-scheme:dark){.input-icon-btn{background:#2a2a2c}.input-icon-btn:hover{background:#3a3a3c}}.file-count{font-size:12px;color:#666;flex:1}@media(prefers-color-scheme:dark){.file-count{color:#999}}.send-btn{padding:6px 16px;border:none;border-radius:16px;background:#ff2442;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.send-btn:hover:not(:disabled){background:#e81d3a}.send-btn:disabled{opacity:.5;cursor:not-allowed}.comment-image-previews{display:flex;gap:8px;margin-bottom:8px;overflow-x:auto;padding-bottom:4px}.comment-image-previews .preview-item{position:relative;width:60px;height:60px;flex-shrink:0}.comment-image-previews img{width:100%;height:100%;object-fit:cover;border-radius:4px}.comment-image-previews .remove-preview{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:#00000080;color:#fff;border:none;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.image-viewer-overlay{position:fixed;inset:0;z-index:15000;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-viewer-container{position:relative;max-width:100vw;max-height:100vh;padding:20px;display:flex;align-items:center;justify-content:center}.image-viewer-container img{max-width:100%;max-height:100vh;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;animation:zoomIn .3s ease-out}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.image-viewer-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border:none;background:transparent;color:#fff;font-size:32px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1;padding:0;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.5)}.image-viewer-close:hover{transform:rotate(90deg) scale(1.15);text-shadow:0 4px 12px rgba(0,0,0,.8)}.image-viewer-close:active{transform:rotate(90deg) scale(1);transition:all .1s}@media(prefers-color-scheme:dark){.image-viewer-close{color:#fff}}.modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:3000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:20px}@media(max-width:600px){.modal{align-items:flex-end;padding:0}}.modal-panel{background:#fff;width:600px;max-width:100%;max-height:90vh;border-radius:12px;box-shadow:0 8px 30px #0003;display:flex;flex-direction:column;overflow:hidden}@media(max-width:600px){.modal-panel{width:100vw;height:90vh;max-height:90vh;border-radius:12px 12px 0 0}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee;background:#fff;flex-shrink:0}.modal-header h4{margin:0;font-size:18px;font-weight:600}.modal-close{background:transparent;border:none;font-size:20px;line-height:1;padding:8px;color:#666;cursor:pointer}.modal-body{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}.form-section{margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:6px}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#1e88e5;outline:none}.inline-group{display:flex!important;gap:12px;flex-direction:row!important;flex-wrap:nowrap!important;width:100%}.inline-field{flex:1 1 0;min-width:0;width:0}.inline-field label{font-size:13px;color:#666;margin-bottom:6px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-field input,.inline-field select{width:100%;box-sizing:border-box}.image-upload-area{display:flex;gap:10px;align-items:center}.image-upload-area input{flex:1}.thumb-preview{width:100%;height:auto;max-height:300px;object-fit:contain;background:#f9f9f9;border-radius:8px;margin-top:8px;border:1px solid #eee;display:block}.ing-section{margin-bottom:24px;background:#f9f9f9;padding:12px;border-radius:10px;border:1px solid #eee}.ing-section h5{margin:0 0 10px;font-size:14px;color:#555;text-transform:uppercase;letter-spacing:.5px}.ing-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ing-row input:first-child{flex:1;min-width:0}.ing-del{width:28px;height:28px;border:none;background:#ffebee;color:#c62828;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;flex-shrink:0}.ing-add-btn{width:100%;padding:8px;background:#fff;border:1px dashed #ccc;border-radius:8px;color:#666;font-size:14px;cursor:pointer;margin-top:4px}.ing-add-btn:hover{background:#f0f0f0}.steps-editor{min-height:150px;font-family:inherit;line-height:1.6}.helper-text{font-size:12px;color:#888;margin-top:4px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;padding:16px;border-top:1px solid #eee;background:#fff;gap:12px;flex-shrink:0}.btn-cancel{background:#f5f5f5;color:#333;border:none;padding:10px 16px;border-radius:8px;font-size:14px;cursor:pointer;font-weight:500}.btn-save{background:#1e88e5;color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:14px;cursor:pointer;font-weight:600}.btn-delete{background:transparent;color:#e53935;border:1px solid #ffebee;padding:8px 12px;border-radius:8px;font-size:13px;cursor:pointer;margin-right:auto}@media(prefers-color-scheme:dark){.modal-panel,.modal-header,.modal-footer{background:#1e1e1e;border-color:#333}.modal-header h4{color:#eee}.modal-close{color:#aaa}.form-group label,.ing-section h5{color:#bbb}.form-group input,.form-group select,.form-group textarea{background:#2d2d2d;border-color:#444;color:#fff}.ing-section{background:#252525;border-color:#333}.ing-add-btn{background:#2d2d2d;border-color:#444;color:#aaa}.ing-del{background:#3e2727;color:#ef5350}.btn-cancel{background:#333;color:#ddd}}.recipe-list-container{padding:20px;max-width:1200px;margin:0 auto}.recipe-list-container h3{margin:0 10px 10px;font-size:18px;font-weight:600}.recipe-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin:8px 10px 10px}.recipe-tabs{display:flex;align-items:center;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{border:none;background:#f5f5f5;color:#666;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap}.tab:hover{background:#e9e9e9}.tab.active{background:#1e88e5;color:#fff;font-weight:600}.btn-create-recipe{border:none;border-radius:20px;padding:8px 16px;background:#e53935;color:#fff;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:4px}.btn-create-recipe:hover{background:#c62828;transform:translateY(-1px);box-shadow:0 2px 8px #e539354d}.recipe-list.xhs-on{column-count:2;column-gap:4px;padding:0 8px}@media(min-width:560px){.recipe-list.xhs-on{column-count:3}}@media(min-width:900px){.recipe-list.xhs-on{column-count:4}}.recipe-loading{text-align:center;padding:40px 20px;color:#666;font-size:14px}.empty-state{text-align:center;padding:60px 20px;color:#888}.empty-state p{font-size:16px;margin-bottom:20px}.load-more-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;color:#666;font-size:14px}.loading-spinner{width:16px;height:16px;border:2px solid #e0e0e0;border-top-color:#1e88e5;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:560px){.recipe-list-container{padding:12px}.recipe-list-container h3{font-size:16px}.tabs{gap:6px}.tab{padding:6px 12px;font-size:13px}.btn-create-recipe{padding:5px 10px;font-size:13px}.recipe-list.xhs-on{padding:0 6px}.load-more-indicator{padding:16px;font-size:13px}}.day-card{width:100%;background:#fff;border:1px solid #ddd;border-radius:8px;padding:0 8px 0 4px;display:flex;flex-direction:row;align-items:center;gap:4px;transition:box-shadow .2s,background .2s;min-height:72px}.day-card.drag-over{background:#e3f2fd;box-shadow:0 4px 12px #1e88e54d}.day-info{display:flex;flex-direction:column;align-items:center;min-width:55px;padding-left:4px;gap:2px}.day-header{font-size:14px;font-weight:600;color:#333;margin:0}.total-calories{color:#666;font-size:10px;white-space:nowrap}.day-meals{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:row;gap:1px;overflow-x:auto;overflow-y:hidden;min-height:70px;align-items:center;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.day-meals::-webkit-scrollbar{height:4px}.day-meals::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.day-meals::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.day-meals::-webkit-scrollbar-thumb:hover{background:#999}.empty-message{width:100%;text-align:center;color:#999;font-size:13px;padding:8px}.meal-item{position:relative;width:70px;height:70px;flex-shrink:0;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001f}.meal-thumb{width:100%;height:100%;object-fit:cover;display:block}.meal-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:none;background:#fffffff2;color:#c62828;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:all .2s;z-index:2;opacity:1}@media(hover:hover)and (pointer:fine){.meal-remove{opacity:0}.meal-item:hover .meal-remove{opacity:1}}.meal-remove:hover{background:#fff;transform:scale(1.1)}.meal-remove:active{transform:scale(.95)}.meal-drag-handle{position:absolute;bottom:4px;left:4px;width:24px;height:24px;border-radius:4px;background:#fffffff2;color:#666;font-size:16px;line-height:1;cursor:move;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:all .2s;z-index:2;opacity:.7}@media(hover:hover)and (pointer:fine){.meal-drag-handle{opacity:0}.meal-item:hover .meal-drag-handle{opacity:1}}@media(hover:none)and (pointer:coarse){.meal-drag-handle{opacity:.7}}@media(max-width:768px){.meal-drag-handle{opacity:.7!important}}.meal-drag-handle:hover{background:#fff;transform:scale(1.1)}.meal-drag-handle:active{transform:scale(.95)}.day-actions{display:flex;flex-direction:column;gap:6px;min-width:65px;flex-shrink:0}.btn-plan,.btn-complete,.btn-next{padding:4px 6px;border:none;border-radius:4px;font-size:11px;cursor:pointer;transition:all .2s;white-space:nowrap;width:100%}.btn-plan{background:#1e88e5;color:#fff}.btn-plan:hover{background:#1565c0}.btn-complete{background:#43a047;color:#fff}.btn-complete:hover{background:#2e7d32}.btn-next{background:#1e88e5;color:#fff}.btn-next:hover{background:#1565c0}@keyframes slideUpOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.day-card.slide-up-out{position:absolute!important;width:calc(100% - 20px);animation:slideUpOut .5s ease-out forwards;z-index:100}.day-card.is-pinned{outline:2px dashed rgba(0,0,0,.15);border-radius:10px}@media(max-width:560px){.meal-item{width:70px;height:70px}.btn-plan,.btn-complete,.btn-next{font-size:13px;padding:6px 8px}}.week-board-container{margin:12px auto;max-width:1100px;width:100%;padding:0 10px}.week-board{display:flex;flex-direction:column;gap:10px;margin-top:6px}.week-board-container.only-pinned .week-board{display:none}.pinned-day-host{position:fixed;top:40px;left:0;right:0;z-index:1000;background:#fafafa;border-bottom:1px solid #ddd;padding:10px;box-shadow:0 4px 12px #00000026;pointer-events:none}.pinned-wrapper{position:relative;max-width:1100px;margin:0 auto;pointer-events:none}.pinned-wrapper>.day-card{pointer-events:auto}.unpin-btn{position:absolute;bottom:4px;right:4px;padding:4px 8px;border-radius:4px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s;pointer-events:auto;font-size:11px;white-space:nowrap;min-width:55px}.unpin-btn svg{width:18px!important;height:18px!important;display:block;flex-shrink:0}.unpin-btn.locked{color:#e53935}.unpin-btn:hover{background:#f5f5f5;transform:scale(1.05)}.top-bar{background:#fff;border-bottom:1px solid #e0e0e0;padding:0 8px 2px;position:sticky;top:0;z-index:100;box-shadow:0 1px 2px #0000000d}.top-bar-content{max-width:100%;display:flex;align-items:center;gap:8px;padding:4px 0}.date-display{padding:4px 8px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.date-display:hover{background:#e0e0e0}.date-display:active{background:#d0d0d0;transform:scale(.98)}.search-input{flex:1;padding:4px 12px;border:1px solid #ddd;border-radius:16px;font-size:13px;min-width:0}.search-input:focus{outline:none;border-color:#1e88e5}.search-input::placeholder{color:#999;font-size:13px}.btn-settings{padding:4px 12px;background:#fff;border:1px solid #ddd;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.btn-settings:hover{background:#f5f5f5}.user-email{font-size:13px;color:#666;padding:4px 8px;background:#f5f5f5;border-radius:6px;white-space:nowrap;flex-shrink:0}.btn-signin,.btn-signout{padding:4px 12px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.btn-signin{background:#1e88e5;color:#fff}.btn-signin:hover{background:#1976d2}.btn-signout{background:#f5f5f5;color:#666}.btn-signout:hover{background:#e0e0e0}@media(max-width:768px){.top-bar-content{gap:4px}.search-input{font-size:12px}.search-input::placeholder{font-size:12px}.date-display,.btn-settings,.user-email,.btn-signin,.btn-signout{font-size:12px;padding:3px 6px}}@media(max-width:560px){.top-bar{padding:0 4px 2px}.user-email{max-width:120px;overflow:hidden;text-overflow:ellipsis}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -1px 4px #00000014;z-index:100;padding:0}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 0;background:none;border:none;cursor:pointer;transition:all .2s;gap:4px}.nav-icon{font-size:20px;line-height:1}.nav-label{font-size:12px;color:#666}.nav-item.active{background:#f0f9ff}.nav-item.active .nav-label{color:#1e88e5;font-weight:600}.nav-item:hover:not(.active){background:#f5f5f5}.App{padding-bottom:60px}@media(max-width:560px){.nav-icon{font-size:18px}.nav-label{font-size:11px}.nav-item{padding:6px 0}.App{padding-bottom:54px}}.auth-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.auth-modal{background:#fff;border-radius:12px;padding:32px;max-width:400px;width:100%;position:relative;box-shadow:0 4px 24px #00000026}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;color:#666;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.auth-modal-close:hover{background:#f0f0f0}.auth-modal h2{margin:0 0 24px;font-size:24px;font-weight:600;color:#333}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:#333}.form-group input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#1e88e5}.forgot-password-link{text-align:right;margin-top:-8px}.forgot-password-link button{background:none;border:none;color:#1e88e5;font-size:13px;cursor:pointer;padding:0;text-decoration:none}.forgot-password-link button:hover{text-decoration:underline;color:#1976d2}.auth-message{padding:10px 12px;border-radius:8px;font-size:14px}.auth-message.error{background:#ffebee;color:#c62828}.auth-message.success{background:#e8f5e9;color:#2e7d32}.auth-submit{padding:12px;background:#1e88e5;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.auth-submit:hover:not(:disabled){background:#1976d2}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.oauth-section{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 12px;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;color:#333}.oauth-btn:hover:not(:disabled){background:#f5f5f5;border-color:#999}.oauth-btn:disabled{opacity:.6;cursor:not-allowed}.oauth-btn.google:hover:not(:disabled){border-color:#4285f4}.oauth-btn.facebook:hover:not(:disabled){border-color:#1877f2}.oauth-btn.github:hover:not(:disabled){border-color:#333}.divider{position:relative;text-align:center;margin:20px 0;color:#999;font-size:13px}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#ddd}.divider:before{left:0}.divider:after{right:0}.divider span{background:#fff;padding:0 10px}.auth-switch{margin-top:16px;text-align:center;font-size:14px;color:#666}.auth-switch button{background:none;border:none;color:#1e88e5;font-size:14px;cursor:pointer;padding:0;margin-left:4px;text-decoration:underline}.auth-switch button:hover{color:#1976d2}.inspire-container{padding:0 20px;max-width:1100px;margin:0 auto}.inspire-header{margin:12px 0}.inspire-header h3{margin:0 0 6px;font-size:18px;font-weight:700}.inspire-tip{font-size:12px;color:#666;margin-bottom:6px}.inspire-toolbar{display:flex;align-items:center;gap:10px;margin:6px 0}.inspire-clear-all{border:1px solid #bbb;background:#eee;border-radius:999px;padding:6px 10px;cursor:pointer;font-size:14px;transition:background .15s}.inspire-clear-all:hover{background:#e0e0e0}.inspire-selected-info{font-size:12px;color:#666}.tag-groups{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px;margin:10px 0}.tag-group{background:#fff;border:1px solid #ddd;border-radius:12px;overflow:hidden}.tg-header{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fafafa;border-bottom:1px solid #eee}.tg-title{font-weight:600;flex:1;font-size:14px}.tg-clear-btn{font-size:12px;padding:4px 8px;border:none;background:#efefef;border-radius:999px;cursor:pointer;transition:background .15s}.tg-clear-btn:hover{background:#e0e0e0}.tg-body{padding:10px;display:flex;flex-wrap:wrap;gap:8px}.tag-btn{border:1px solid #bbb;background:#eee;padding:6px 12px;border-radius:999px;cursor:pointer;font-size:14px;font-weight:400;line-height:1;-webkit-user-select:none;user-select:none;transition:all .15s}.tag-btn:hover{background:#e0e0e0}.tag-btn.active{background:#4a90e2;color:#fff;font-weight:600;border-color:#357abd}.inspire-results{margin-top:20px}.inspire-empty{margin:20px 0;text-align:center;color:#666;font-size:14px}.inspire-results.xhs-on{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;align-items:start}@media(max-width:640px){.inspire-results.xhs-on{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}}.inspire-loading{text-align:center;padding:40px 20px;color:#666}.household-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.household-modal{background:#fff;width:90%;max-width:500px;border-radius:12px;box-shadow:0 4px 12px #00000026;overflow:hidden;animation:modal-slide-up .3s ease-out}@keyframes modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.hh-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.hh-header h3{margin:0;font-size:18px;font-weight:600}.hh-close-btn{background:none;border:none;font-size:20px;color:#999;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.hh-close-btn:hover{background:#f0f0f0;color:#333}.hh-body{padding:20px}.hh-section{margin-bottom:24px}.hh-section:last-child{margin-bottom:0}.hh-title{font-size:14px;font-weight:600;color:#333;margin-bottom:10px}.hh-input{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:6px;font-size:14px;margin-bottom:8px}.hh-select{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:6px;background:#fff;font-size:14px;margin-bottom:8px;min-width:200px}.hh-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.hh-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.hh-btn-primary{background:#1890ff;color:#fff}.hh-btn-primary:hover{background:#40a9ff}.hh-btn-danger{background:#ff4d4f;color:#fff}.hh-btn-danger:hover{background:#ff7875}.hh-code-wrap{margin:10px 0;text-align:center;background:#f5f5f5;padding:15px;border-radius:8px}.hh-code-display{font-size:28px;font-weight:700;font-family:monospace;letter-spacing:4px;color:#1890ff;margin-bottom:8px}.hh-hint{font-size:12px;color:#888;margin-top:4px}.hh-divider{height:1px;background:#eee;margin:16px 0}.hh-error{color:#ff4d4f;font-size:12px;margin-top:4px}.hh-success{color:#52c41a;font-size:12px;margin-top:4px}.owner-info-row{margin-bottom:8px;font-size:14px}.hh-hint-error{color:#ff4d4f;font-weight:700;animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0}#root{margin:0;padding:0;max-width:none;width:100%}.App{margin:0;padding:0 0 60px;min-height:100vh}
