*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #FAF7F2;--bg2: #F2EDE4;--card: #FFFFFF;--border: #E2DAD0;--border2: #CEC4B8;--text: #1C1814;--text2: #6B6259;--text3: #A09890;--accent: #B85C2C;--accent2: #E8874A;--green: #4A7C59;--yellow: #C9973A;--shadow: 0 2px 12px rgba(0,0,0,.07);--shadow-lg: 0 8px 32px rgba(0,0,0,.1);--sidebar-w: 220px;--radius: 10px;--radius-sm: 6px}[data-theme=dark]{--bg: #18161A;--bg2: #221F26;--card: #27242B;--border: #3A3540;--border2: #4A4555;--text: #F0EBE3;--text2: #B8AFA6;--text3: #786E6A;--shadow: 0 2px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 32px rgba(0,0,0,.4)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-line{border-radius:4px;background:linear-gradient(90deg,var(--border) 25%,var(--bg2) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear}.skeleton-card{pointer-events:none}.skeleton-title{height:18px;width:70%;margin-bottom:10px}.skeleton-stars{height:12px;width:80px;margin-bottom:8px}.skeleton-meta{height:11px;width:120px;margin-bottom:12px}.skeleton-chips{display:flex;gap:6px;margin-bottom:10px}.skeleton-chip{height:24px;width:60px;border-radius:20px;background:linear-gradient(90deg,var(--border) 25%,var(--bg2) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear}.skeleton-btn{height:30px;width:100px;border-radius:var(--radius-sm)}.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px}.nutrition-box{background:var(--bg2);border-radius:var(--radius-sm);padding:8px 6px;text-align:center}.nutrition-value{font-size:15px;font-weight:700;color:var(--accent)}.nutrition-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.settings-appearance-row{display:flex;align-items:center;justify-content:space-between}.theme-toggle{width:44px;height:24px;border-radius:12px;border:none;background:var(--border2);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.theme-toggle.active{background:var(--accent)}.theme-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;display:block}.theme-toggle.active .theme-toggle-thumb{transform:translate(20px)}html,body{height:100%;overflow-x:hidden;overscroll-behavior-x:none;touch-action:pan-y;max-width:100vw}body{font-family:Archivo,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%;overflow-x:hidden;max-width:100vw}.app-layout{display:flex;height:100vh;height:100dvh;overflow:hidden;max-width:100vw}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior-x:none;overscroll-behavior-y:contain;touch-action:pan-y;background:var(--bg);min-width:0}.sidebar{width:var(--sidebar-w);background:var(--text);color:#fff;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;padding-bottom:24px}.sidebar-brand{display:flex;align-items:center;gap:14px;padding:32px 20px 24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:8px}.sidebar-brand-icon{font-size:26px}.sidebar-brand-logo{width:48px;height:48px;object-fit:contain;border-radius:10px;flex-shrink:0}.sidebar-brand-text{font-family:Cormorant Garamond,Georgia,serif;font-size:24px;font-weight:700;letter-spacing:.02em;color:#fff}.sidebar-nav{list-style:none;padding:0 10px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);text-decoration:none;color:#fff9;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;position:relative}.sidebar-link:hover{background:#ffffff12;color:#ffffffe6}.sidebar-link.active{background:#ffffff1f;color:#fff}.sidebar-icon{font-size:16px;flex-shrink:0}.sidebar-label{flex:1}.sidebar-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:1px 6px;border-radius:20px;min-width:20px;text-align:center}.bottom-tabs{display:none}.page{padding:32px 32px 80px;max-width:1100px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{font-family:Cormorant Garamond,Georgia,serif;font-size:34px;font-weight:600;color:var(--text);line-height:1.1}.page-subtitle{color:var(--text2);font-size:.95rem;margin-bottom:1.5rem;max-width:560px;line-height:1.5}.week-header-meta{font-size:13px;color:var(--text2);margin-top:4px;margin-bottom:4px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:Cormorant Garamond,Georgia,serif;font-size:22px;font-weight:600}button{font-family:inherit;cursor:pointer;border:none;background:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;transition:background .15s,color .15s,opacity .15s;white-space:nowrap;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#a34f23}.btn-secondary{background:var(--bg2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg2)}.btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:#fee2e2}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-full{width:100%;justify-content:center}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);font-size:12px;color:var(--text3);transition:background .15s,color .15s;flex-shrink:0}.btn-icon:hover{background:var(--bg2);color:var(--text)}.link-btn{background:none;border:none;color:var(--accent);text-decoration:underline;cursor:pointer;font-family:inherit;font-size:inherit}.form-group{display:flex;flex-direction:column;gap:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-label{font-size:12.5px;font-weight:500;color:var(--text2);letter-spacing:.02em}.required{color:var(--accent)}.form-input{padding:9px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:inherit;font-size:13.5px;color:var(--text);background:var(--card);transition:border-color .15s,box-shadow .15s;outline:none;width:100%}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b85c2c1f}.form-textarea{padding:9px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:inherit;font-size:13.5px;color:var(--text);background:var(--card);resize:vertical;transition:border-color .15s,box-shadow .15s;outline:none;width:100%;line-height:1.5}.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b85c2c1f}.form-select{padding:9px 32px 9px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:inherit;font-size:13.5px;color:var(--text);background:var(--card);cursor:pointer;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%236B6259' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b85c2c1f}.form-error{padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);color:#dc2626;font-size:13px}.field-error{font-size:12.5px;color:var(--accent);margin-top:4px}.input-error{border-color:var(--accent)!important}.form-info{padding:8px 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);color:var(--green);font-size:13px}.form-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:8px;border-top:1px solid var(--border);margin-top:8px}.ing-input-row{display:flex;gap:8px}.ing-input-row .form-input{flex:1}.range-input{width:100%;accent-color:var(--accent);cursor:pointer}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text3);margin-top:2px}.chip-row{display:flex;flex-wrap:wrap;gap:5px}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text2);white-space:normal;word-break:break-word;max-width:100%}.chip-more{color:var(--text3);font-style:italic}.chip-removable{padding-right:4px}.chip-remove{font-size:10px;color:var(--text3);padding:0 2px;cursor:pointer;border:none;background:none;line-height:1}.chip-remove:hover{color:var(--accent)}.chip-match{background:#f0fdf4;border-color:#bbf7d0;color:var(--green);font-weight:500}.tag-row{display:flex;flex-wrap:wrap;gap:4px}.tag{display:inline-block;padding:2px 8px;background:var(--bg2);border-radius:20px;font-size:11.5px;color:var(--text3);font-weight:500;letter-spacing:.02em}.controls-bar{display:flex;gap:10px;margin-bottom:14px;align-items:center}.search-input{flex:1;min-width:0}.tag-filter-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.filter-pill{padding:5px 12px;border-radius:20px;font-size:12.5px;font-weight:500;border:1px solid var(--border2);color:var(--text2);background:var(--card);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.filter-pill:hover{background:var(--bg2)}.filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag-toggle-row{display:flex;flex-wrap:wrap;gap:6px}.tag-toggle{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--border2);color:var(--text2);background:var(--card);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.tag-toggle:hover{background:var(--bg2)}.tag-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}.meal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.meal-card{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .2s;position:relative;display:flex;flex-direction:column;min-height:220px}.meal-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.meal-card-body{padding:16px 16px 12px;flex:1;display:flex;flex-direction:column;gap:8px}.meal-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.meal-name{font-family:Cormorant Garamond,Georgia,serif;font-size:19px;font-weight:600;color:var(--text);line-height:1.2;flex:1}.meal-meta{font-size:12.5px;color:var(--text2);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.meal-meta strong{color:var(--text)}.times-cooked-row{display:inline-flex;align-items:center;gap:4px}.times-cooked-btn{width:18px;height:18px;border-radius:50%;border:1px solid var(--border);background:var(--bg2);color:var(--text2);cursor:pointer;font-size:12px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background .12s,color .12s;flex-shrink:0}.times-cooked-btn:hover:not(:disabled){background:var(--border2);color:var(--text)}.times-cooked-btn:disabled{opacity:.3;cursor:default}.meal-card-footer{padding:10px 16px;border-top:1px solid var(--border)}.btn-week{font-size:12px;font-weight:500;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border2);color:var(--text2);background:transparent;cursor:pointer;transition:all .15s}.btn-week:hover{background:var(--bg2);border-color:var(--accent);color:var(--accent)}.btn-week-active{background:#f0fdf4;border-color:var(--green);color:var(--green);font-weight:600}.btn-week-active:hover{background:#dcfce7;color:#2d6b3f;border-color:#2d6b3f}.btn-week-active-full{background:#f0fdf4;color:var(--green);border:1px solid var(--green);padding:9px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;cursor:default;opacity:.85}.url-ribbon{position:absolute;top:0;right:0;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;letter-spacing:.06em;border-bottom-left-radius:var(--radius-sm);z-index:1}.cooldown-bar-track{height:3px;background:var(--border);width:100%}.cooldown-bar-fill{height:100%;width:100%;transition:background-color .5s ease}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c181473;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:28px;position:relative}.modal-sm{max-width:400px}.modal-send{max-width:620px}.modal-install{max-width:400px;text-align:center}.install-header{margin-bottom:24px}.install-app-icon{font-size:40px;margin-bottom:10px}.install-title{font-size:1.3rem;font-weight:700;color:var(--text);margin:0 0 8px;font-family:Cormorant Garamond,Georgia,serif}.install-subtitle{font-size:14px;color:var(--text2);margin:0;line-height:1.5}.install-steps{list-style:none;padding:0;margin:0 0 20px;text-align:left;display:flex;flex-direction:column;gap:12px}.install-step{display:flex;align-items:flex-start;gap:12px}.install-step-num{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}.install-step-text{font-size:14px;color:var(--text);line-height:1.5}.install-icon{font-style:normal;font-size:15px}.install-dont-show{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);cursor:pointer;margin-bottom:16px;justify-content:center}.install-dont-show input{width:15px;height:15px;cursor:pointer;accent-color:var(--accent)}.modal-detail{max-width:540px;padding:0;display:flex;flex-direction:column;overflow:hidden}.modal-detail .detail-body{flex:1;overflow-y:auto;overscroll-behavior-y:contain;touch-action:pan-y}.modal-form{max-width:560px}.modal-close{position:absolute;top:14px;right:14px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text3);font-size:18px;cursor:pointer;background:none;border:none;transition:background .15s,color .15s}.modal-close:hover{background:var(--bg2);color:var(--text)}.modal-title{font-family:Cormorant Garamond,Georgia,serif;font-size:24px;font-weight:600;margin-bottom:20px}.meal-form{display:flex;flex-direction:column;gap:18px}.detail-header{margin-bottom:20px}.detail-title{font-family:Cormorant Garamond,Georgia,serif;font-size:28px;font-weight:600;margin-bottom:6px;line-height:1.2}.detail-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;padding:16px;background:var(--bg2);border-radius:var(--radius-sm)}.stat-box{text-align:center}.stat-value{font-family:Cormorant Garamond,Georgia,serif;font-size:22px;font-weight:600;color:var(--text);line-height:1;margin-bottom:2px}.stat-label{font-size:11px;color:var(--text3);font-weight:500;letter-spacing:.04em;text-transform:uppercase}.source-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--accent);text-decoration:none;margin-bottom:16px}.source-link:hover{text-decoration:underline}.detail-section{margin-bottom:16px}.detail-section-label{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.notes-quote{font-style:italic;color:var(--text2);border-left:3px solid var(--accent2);padding:6px 0 6px 14px;font-size:13.5px;line-height:1.6}.detail-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border);margin-top:4px}.detail-footer-right{display:flex;gap:8px}.btn-edit{border:1px solid var(--border2);color:var(--text);background:transparent;padding:7px 14px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s}.btn-edit:hover{background:var(--bg2)}.detail-sticky-actions{display:flex;align-items:center;gap:8px}.dup-warning{font-size:.85rem;color:var(--yellow);margin-top:4px}.randomize-success{font-size:13px;color:var(--green);font-weight:500;margin-bottom:10px}.page-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.manual-add-row{display:flex;gap:10px;margin-bottom:20px}.manual-add-input{flex:1}.badge-added{font-size:10.5px;color:var(--text3);margin-left:4px;flex-shrink:0;font-style:italic}.shop-item-remove{margin-left:auto;background:none;border:none;color:var(--text3);cursor:pointer;font-size:15px;padding:0 2px;line-height:1;flex-shrink:0;transition:color .15s}.shop-item-remove:hover{color:var(--accent)}.detail-sticky-bar{flex-shrink:0;z-index:10;background:var(--card);border-bottom:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;border-radius:var(--radius) var(--radius) 0 0}.detail-exit-btn{color:var(--text2)}.btn-in-week{background:transparent;color:var(--green);border:1px solid var(--green);padding:9px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;cursor:default;opacity:.9}.detail-body{padding:24px 28px 36px}.delete-zone{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.btn-delete-recipe{width:100%;padding:10px;border:1px solid var(--accent);color:var(--accent);background:transparent;border-radius:8px;font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s}.btn-delete-recipe:hover{background:#b85c2c0f}.delete-confirm-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.delete-confirm-text{font-size:13.5px;color:var(--text2);flex:1}.url-import-section{margin-bottom:20px}.url-import-bar{border:2px dashed var(--border2);border-radius:var(--radius);padding:16px 20px;background:var(--bg2)}.url-import-label{display:block;font-size:12px;font-weight:600;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.url-import-row{display:flex;gap:10px}.url-import-input{flex:1}.import-preview{margin-top:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.import-name-input{display:block;width:100%;font-family:Cormorant Garamond,Georgia,serif;font-size:1.3rem;font-weight:600;color:var(--text);background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;padding:2px 0 4px;margin-bottom:8px;outline:none;transition:border-color .15s}.import-name-input:focus{border-bottom-color:var(--border2);box-shadow:none}.import-name-input::placeholder{color:var(--text3)}.import-rating-row{margin-bottom:10px}.import-section{margin-bottom:14px}.import-section-label{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}.import-preview-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--text2)}.import-description{font-size:13px;color:var(--text2);margin-bottom:10px;line-height:1.5}.import-preview-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border)}.import-divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--text3);font-size:12px}.import-divider:before,.import-divider:after{content:"";flex:1;height:1px;background:var(--border2)}.photo-file-input{display:none}.photo-upload-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border:2px dashed var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text2);font-size:14px;font-family:var(--font-body);cursor:pointer;transition:border-color .15s,color .15s;width:100%;justify-content:center}.photo-upload-btn:hover{border-color:var(--accent);color:var(--accent)}.photo-upload-row{width:100%}.photo-selected-row{display:flex;align-items:center;gap:10px;padding:8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.photo-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0}.photo-filename{flex:1;font-size:13px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-thumb-placeholder{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--bg);border-radius:6px;border:1px solid var(--border);flex-shrink:0}.multi-photo-selected{display:flex;flex-direction:column;gap:10px}.multi-photo-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.multi-photo-item{position:relative;flex-shrink:0}.multi-photo-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}.multi-photo-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--text);color:var(--card);border:none;font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;opacity:.75;transition:opacity .15s}.multi-photo-remove:hover{opacity:1}.multi-photo-badge{position:absolute;bottom:3px;left:3px;background:#0000008c;color:#fff;font-size:10px;font-weight:600;border-radius:3px;padding:1px 4px;line-height:1.3}.multi-photo-add{width:72px;height:72px;border-radius:8px;border:2px dashed var(--border2);background:var(--bg);color:var(--text3);font-size:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,color .15s;flex-shrink:0}.multi-photo-add:hover{border-color:var(--accent);color:var(--accent)}.multi-photo-add.disabled{opacity:.4;cursor:default;pointer-events:none}.multi-photo-actions{display:flex;gap:8px;align-items:center}.recipe-attachment{margin:10px 0 4px}.recipe-photo-link{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px 6px 6px;background:var(--bg);transition:border-color .15s}.recipe-photo-link:hover{border-color:var(--accent)}.recipe-photo-thumb{width:52px;height:52px;object-fit:cover;border-radius:5px;flex-shrink:0}.recipe-photo-label{font-size:13px;color:var(--accent)}.recipe-attachment-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--accent);text-decoration:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;background:var(--bg);transition:border-color .15s}.recipe-attachment-link:hover{border-color:var(--accent)}.photo-gallery-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.photo-thumb-wrap{position:relative;flex-shrink:0}.photo-thumb-grid{width:72px;height:72px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);display:block}.photo-thumb-remove{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--text);color:var(--card);border:none;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0}.photo-thumb-remove:hover{background:#e05252}.recipe-photo-gallery{display:flex;flex-wrap:wrap;gap:8px}.recipe-photo-gallery-item{display:block;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);transition:border-color .15s}.recipe-photo-gallery-item:hover{border-color:var(--accent)}.recipe-photo-gallery-thumb{width:90px;height:90px;object-fit:cover;display:block}.import-status-line,.import-fallback-msg{color:var(--text3);font-size:.85rem;font-style:italic;margin-top:8px}@keyframes fadeOut{0%,60%{opacity:1}to{opacity:0}}.import-success-msg{color:var(--green);font-size:.85rem;font-weight:500;margin-top:8px;animation:fadeOut 2s ease forwards}.meal-cook-time{font-size:.8rem;color:var(--text3);margin-bottom:2px}.instruction-list{list-style:none;display:flex;flex-direction:column;gap:0}.instruction-step{display:flex;gap:12px;align-items:flex-start;padding-bottom:12px}.instruction-num{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}.instruction-step-text{font-size:.95rem;line-height:1.6;color:var(--text);padding-left:0}.step-optional{font-style:italic;color:var(--text3)}.instruction-empty{font-size:13px;color:var(--text3);font-style:italic}.reimport-hint{margin-top:10px;font-size:12.5px;font-style:italic;color:var(--text3);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.reimport-btn{font-size:12px;font-style:normal;color:var(--accent);background:none;border:1px solid var(--accent);border-radius:4px;padding:2px 8px;cursor:pointer;font-weight:500;white-space:nowrap}.reimport-btn:hover{background:var(--accent);color:#fff}.form-hint{font-size:11.5px;color:var(--text3);margin-top:4px}.week-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.week-list{display:flex;flex-direction:column;gap:12px;touch-action:pan-y}.week-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.week-card-main{padding:16px;display:flex;flex-direction:column;gap:8px}.week-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.week-card-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-top:4px}.week-card-expand-btns{display:flex;gap:6px;margin-top:6px}.week-card-expand-btn{font-size:12px;font-family:inherit;color:var(--text2);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 9px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.week-card-expand-btn:hover,.week-card-expand-btn.active{background:var(--bg2);border-color:var(--border2);color:var(--text)}.week-card-expandable{margin-top:8px;padding:12px;background:var(--bg2);border-radius:8px}.week-instr-list{list-style:none;display:flex;flex-direction:column;gap:0}.week-instr-step{display:flex;gap:12px;align-items:flex-start;padding-bottom:12px}.week-instr-step .instruction-step-text{font-size:.9rem;color:var(--text2);line-height:1.6}.remove-btn{color:var(--text3)}.remove-btn:hover{color:#dc2626;background:#fef2f2}.planner-controls{margin-bottom:24px;display:flex;flex-direction:column;gap:16px}.planner-results{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.planner-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;overflow:hidden}.planner-rank{width:44px;flex-shrink:0;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Cormorant Garamond,Georgia,serif;font-size:22px;font-weight:700}.planner-card-body{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.planner-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.planner-card-footer{display:flex;align-items:center;gap:10px;padding-top:4px}.planner-shopping{margin-top:8px}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:24px}.shop-card{padding:16px}.shop-card-title{font-size:12px;font-weight:700;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.shop-item-list{list-style:none;display:flex;flex-direction:column;gap:4px}.shop-item{display:flex;align-items:center;gap:8px;padding:5px 0;cursor:pointer;transition:color .15s;border-radius:4px}.shop-item:hover{color:var(--accent)}.shop-item.checked .shop-item-label{text-decoration:line-through;color:var(--text3)}.shop-checkbox{width:16px;height:16px;border:1.5px solid var(--border2);border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--green);transition:background .15s,border-color .15s;background:var(--card)}.shop-item.checked .shop-checkbox{background:var(--green);border-color:var(--green);color:#fff}.shop-item-label{font-size:13.5px}.shop-category{margin-bottom:16px}.shop-category-label{font-size:12px;font-weight:600;color:var(--text3);letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}.by-recipe-section{border-top:1px solid var(--border);padding-top:16px}.by-recipe-toggle{font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;background:none;border:none;padding:4px 0;margin-bottom:12px}.by-recipe-toggle:hover{color:var(--text)}.by-recipe-content{display:flex;flex-direction:column;gap:16px}.by-recipe-meal{padding-bottom:16px;border-bottom:1px solid var(--border)}.by-recipe-meal:last-child{border-bottom:none}.by-recipe-meal-name{font-family:Cormorant Garamond,Georgia,serif;font-size:17px;font-weight:600;margin-bottom:8px}.shop-section{margin-bottom:32px}.shop-section-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:14px}.shop-section-toggle{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:0;width:100%;text-align:left;font-family:var(--font-body)}.shop-section-toggle:hover{color:var(--text2)}.shop-section-chevron{font-size:14px;color:var(--text3);transition:transform .15s}.by-recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.by-recipe-card{padding:16px}.by-recipe-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.by-recipe-card-toggle{flex:1;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;padding:0;text-align:left;font-family:var(--font-body);min-width:0}.by-recipe-card-toggle:hover .by-recipe-card-name{color:var(--accent)}.by-recipe-card-name{font-family:Cormorant Garamond,Georgia,serif;font-size:1.1rem;font-weight:600;color:var(--text)}.by-recipe-links{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.by-recipe-source-link{font-size:12px;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:3px}.by-recipe-source-link:hover{text-decoration:underline}.by-recipe-photos{display:flex;gap:6px;flex-wrap:wrap}.by-recipe-photo-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid var(--border);display:block}.qty-loading{font-size:11.5px;color:var(--text3);font-style:italic}.modal-rand{max-width:560px}.rand-filter-note{font-size:12px;color:var(--text3);margin-bottom:12px}.rand-filter-note strong{color:var(--accent)}.rand-results{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}.rand-results-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.rand-result-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.rand-result-card:last-of-type{border-bottom:none}.rand-result-info{flex:1;min-width:0}.rand-result-name{font-family:Cormorant Garamond,Georgia,serif;font-size:16px;font-weight:600;color:var(--text);margin-bottom:4px}.rand-result-meta{display:flex;align-items:center;gap:10px;margin-bottom:2px}.rand-result-cook{font-size:12px;color:var(--text3)}.shop-action-row{display:flex;gap:8px;margin-bottom:16px}.send-format-tabs{display:flex;gap:6px;margin-bottom:14px}.send-format-tab{flex:1;padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg2);color:var(--text2);font-size:.85rem;font-family:var(--font-body);cursor:pointer;transition:all .15s}.send-format-tab:hover{background:var(--bg3, var(--border));color:var(--text)}.send-format-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.send-consolidating{font-size:.82rem;color:var(--text3);font-style:italic;margin-bottom:8px}.send-preview{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;font-size:12.5px;line-height:1.6;white-space:pre-wrap;max-height:320px;overflow-y:auto;margin-bottom:16px;color:var(--text);font-family:Archivo,monospace}.send-actions{display:flex;flex-wrap:wrap;gap:8px}.auth-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.auth-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:400px}.auth-brand{text-align:center;margin-bottom:28px}.auth-brand-icon{display:block;font-size:40px;margin-bottom:10px}.auth-brand-logo{width:64px;height:64px;object-fit:contain;border-radius:14px;margin:0 auto 12px;display:block}.auth-title{font-family:Cormorant Garamond,Georgia,serif;font-size:32px;font-weight:600;color:var(--text);margin-bottom:4px}.auth-subtitle{font-size:13px;color:var(--text3)}.auth-form{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.auth-toggle{text-align:center;font-size:13px;color:var(--text2)}.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.auth-tab{flex:1;padding:10px 12px;font-size:13.5px;font-weight:500;background:var(--bg2);color:var(--text2);border:none;cursor:pointer;transition:background .15s,color .15s}.auth-tab:first-child{border-right:1px solid var(--border)}.auth-tab.active{background:var(--text);color:#fff}.auth-tab:hover:not(.active){background:var(--border);color:var(--text)}.auth-optional-label{display:flex;align-items:center;gap:7px}.auth-optional-badge{font-size:10px;font-weight:500;color:var(--text3);background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:1px 7px;text-transform:uppercase;letter-spacing:.04em}.auth-invite-input{font-family:Courier New,monospace;font-size:20px;font-weight:700;letter-spacing:.2em;text-align:center;text-transform:uppercase}.auth-field-hint{display:block;margin-top:5px;font-size:11.5px;color:var(--text3);line-height:1.45}.auth-fine-print{margin-top:12px;font-size:11.5px;color:var(--text3);text-align:center;line-height:1.5}.password-input-wrap{position:relative;display:flex;align-items:center}.password-input-wrap .form-input{padding-right:44px;width:100%}.password-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;padding:4px;font-size:16px;color:var(--text3);line-height:1;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--text2)}.auth-link{display:block;width:100%;margin-top:10px;background:none;border:none;color:var(--accent);font-size:13.5px;text-align:center;cursor:pointer;padding:4px 0;font-family:var(--font-body);text-decoration:underline;text-underline-offset:2px}.auth-link:hover{opacity:.8}.auth-forgot-hint{color:var(--text2);font-size:14px;margin-bottom:16px;line-height:1.5}.auth-forgot-sent{display:flex;flex-direction:column;gap:12px}.auth-info-box{padding:12px 14px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm);color:var(--green);font-size:14px;line-height:1.5;text-align:center}[data-theme=dark] .auth-card{background:#1e1b22;border-color:#3a3540}[data-theme=dark] .auth-tab{background:#27242b;color:#9e9494}[data-theme=dark] .auth-tab.active{background:var(--accent);color:#fff}[data-theme=dark] .auth-tab:hover:not(.active){background:#322f38;color:#d0c8c0}[data-theme=dark] .auth-tab:first-child{border-right-color:#3a3540}[data-theme=dark] .auth-subtitle{color:#9e9494}[data-theme=dark] .form-label{color:#c0b8b0}[data-theme=dark] .auth-card .form-input{background:#14121a;border-color:#3a3540;color:#f0ebe3}[data-theme=dark] .auth-card .form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b85c2c40}[data-theme=dark] .auth-card .form-input::placeholder{color:#5a5258}[data-theme=dark] .password-toggle{color:#786e6a}[data-theme=dark] .password-toggle:hover{color:#b8afa6}[data-theme=dark] .auth-info-box{background:#1a2e1a;border-color:#2d5a2d;color:#6bcb77}.sidebar-spacer{flex:1}.sidebar-bottom{padding:10px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-settings-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--radius-sm);background:none;border:none;color:#fff9;font-size:13.5px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;text-align:left}.sidebar-settings-btn:hover{background:#ffffff12;color:#ffffffe6}[data-theme=dark] .sidebar{background:#141218}[data-theme=dark] .sidebar-brand{border-bottom-color:#ffffff0f}[data-theme=dark] .sidebar-link{color:#ffffff8c}[data-theme=dark] .sidebar-link:hover{background:#ffffff14;color:#ffffffe6}[data-theme=dark] .sidebar-link.active{background:#ffffff1f;color:#fff}[data-theme=dark] .sidebar-settings-btn{color:#ffffff8c}[data-theme=dark] .sidebar-settings-btn:hover{background:#ffffff14;color:#ffffffe6}[data-theme=dark] .sidebar-bottom{border-top-color:#ffffff0f}.modal-settings{max-width:480px}.settings-section{padding:18px 0;border-top:1px solid var(--border)}.settings-section:first-of-type{border-top:none;padding-top:4px}.settings-section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin:0 0 10px}.settings-desc{font-size:13px;color:var(--text2);line-height:1.55;margin:0 0 14px}.share-app-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.settings-desc code{font-size:12px;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 5px}.hh-code-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}.hh-code-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:8px}.hh-code-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.hh-code{font-family:Courier New,monospace;font-size:22px;font-weight:700;letter-spacing:.15em;color:var(--text)}.hh-code-hint{display:block;font-size:12px;color:var(--text3);line-height:1.4}.hh-members{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.hh-member{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm)}.hh-member-avatar{font-size:18px;flex-shrink:0}.hh-member-info{flex:1;display:flex;flex-direction:column;gap:2px}.hh-member-name{font-size:13.5px;font-weight:500;color:var(--text)}.hh-member-since{font-size:11.5px;color:var(--text3)}.hh-leave-confirm{margin-top:12px;padding:12px 14px;background:#fff8f0;border:1px solid #f5c6a0;border-radius:var(--radius-sm);font-size:13px;color:var(--text2)}.hh-leave-confirm p{margin:0 0 10px}.hh-leave-btns{display:flex;gap:8px}.hh-name-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.hh-name-display{flex:1;font-size:14px;font-weight:500;color:var(--text1)}.hh-name-empty{font-style:italic;font-weight:400;color:var(--text3)}.hh-name-edit-row{display:flex;gap:8px;align-items:center;margin-bottom:6px}.hh-name-edit-row .form-input{flex:1}.hh-join-row{display:flex;gap:8px;align-items:flex-start}.hh-join-input{flex:1;font-family:Courier New,monospace;font-size:18px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-align:center}.settings-signout{padding-bottom:4px}.settings-build-time{text-align:center;font-size:11px;color:var(--text3);padding:12px 0 4px;border-top:1px solid var(--border);margin-top:8px}.onboarding-overlay{z-index:400}.onboarding-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:380px;padding:40px 32px 32px;text-align:center}.onboarding-brand{font-size:44px;margin-bottom:12px;line-height:1}.onboarding-title{font-family:Cormorant Garamond,Georgia,serif;font-size:26px;font-weight:600;color:var(--text);margin:0 0 10px}.onboarding-desc{font-size:14px;color:var(--text2);line-height:1.55;margin:0 0 24px}.onboarding-join-section{margin-bottom:20px;text-align:left}.onboarding-join-label{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--text2);margin-bottom:8px}.onboarding-join-row{display:flex;gap:8px}.onboarding-error{margin-top:8px}.onboarding-skip{display:block;width:100%;margin-top:4px;font-size:13.5px}.onboarding-joined{padding:20px 0}.onboarding-joined-icon{display:block;font-size:40px;color:var(--accent);margin-bottom:12px}.onboarding-joined-text{font-size:18px;font-weight:600;color:var(--text);margin:0 0 4px}.onboarding-joined-sub{font-size:13px;color:var(--text3);margin:0}.loading-screen{height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center}.spinner-wrap{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:32px;height:32px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{width:22px;height:22px;border-width:2px}.pull-indicator{display:flex;justify-content:center;padding:12px 0 4px;animation:fade-in .15s ease}.refresh-btn{font-size:1.2rem;line-height:1;padding:6px 10px;min-width:36px}.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}.empty-icon{font-size:40px;margin-bottom:12px}.empty-text{font-size:14px;color:var(--text3);max-width:320px;margin:0 auto}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.fade-up{animation:fadeUp .3s ease both}.slide-up{animation:slideUp .22s ease both}.fade-in{animation:fadeIn .2s ease both}.page-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.meal-count-pill{background:var(--bg2);color:var(--text2);font-size:.85rem;border-radius:20px;padding:4px 12px;display:inline-block;vertical-align:middle;font-family:var(--font-body);font-weight:400;line-height:1.4}.shop-copy-note{color:var(--text3);font-size:.8rem;font-style:italic;margin-top:4px;margin-bottom:2px}.shop-clear-confirm{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-top:8px;display:flex;flex-direction:column;gap:12px}.shop-clear-text{font-size:.9rem;color:var(--text2);line-height:1.5}.shop-clear-btns{display:flex;gap:10px;flex-wrap:wrap}.cat-qty-dot{color:var(--text3);font-style:italic}@media (max-width: 900px){.meal-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.sidebar{display:none}.bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:60px;background:#1e1b18;border-top:1px solid rgba(255,255,255,.1);z-index:200;padding-bottom:env(safe-area-inset-bottom,0)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;height:60px;padding:6px 4px;text-decoration:none;color:#ffffff80;gap:3px;position:relative;transition:color .15s}.tab-item.active{color:#fff}.tab-btn{background:none;border:none;cursor:pointer}.tab-icon{font-size:1.3rem;line-height:1;height:24px;display:flex;align-items:center;justify-content:center}.tab-label{font-size:.65rem;line-height:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px}.tab-badge{position:absolute;top:4px;right:calc(50% - 16px);background:var(--accent);color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:10px;min-width:14px;text-align:center}.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.page{padding:20px 16px calc(100px + env(safe-area-inset-bottom,0px))}.page-title{font-size:1.4rem}.modal-overlay{align-items:flex-start;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none}.modal{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;max-width:100%;border-radius:0;padding:20px;overflow-y:auto;overflow-x:hidden}.modal-sm,.modal-send,.modal-detail,.modal-form,.modal-rand{max-width:100%}.modal-detail{overflow:hidden;padding:0;height:calc(100vh - 60px - env(safe-area-inset-bottom,0px));height:calc(100dvh - 60px - env(safe-area-inset-bottom,0px));max-height:calc(100vh - 60px - env(safe-area-inset-bottom,0px));max-height:calc(100dvh - 60px - env(safe-area-inset-bottom,0px))}.detail-sticky-bar{border-radius:0;flex-wrap:wrap;gap:6px;padding:10px 14px}.detail-sticky-actions{flex-wrap:wrap;gap:6px}.detail-sticky-actions .btn{font-size:12px;padding:7px 11px}.form-input,.form-textarea,.form-select,.search-input,.manual-add-input,.import-name-input{font-size:16px}.form-row,.meal-grid,.shop-grid,.by-recipe-grid{grid-template-columns:1fr}.controls-bar{flex-wrap:wrap}.controls-bar .search-input{flex-basis:100%}.tag-filter-row{flex-wrap:nowrap;overflow-x:auto;overscroll-behavior-x:contain;touch-action:pan-x;padding-bottom:4px;-webkit-mask-image:linear-gradient(to right,black 88%,transparent 100%);mask-image:linear-gradient(to right,black 88%,transparent 100%)}.week-actions{flex-direction:column}.week-card{width:100%}.shop-action-row{gap:6px}.shop-action-row .btn{flex:1;font-size:.9rem;padding:10px 8px;justify-content:center;text-align:center}.page-header-actions{flex-wrap:wrap;justify-content:flex-end}.detail-stats{grid-template-columns:repeat(3,1fr);gap:8px}.stat-value{font-size:18px}.url-import-row{flex-direction:column}.manual-add-row{flex-wrap:nowrap}.shop-action-row .btn{font-size:.82rem;padding:10px 6px}.cook-topbar{padding:12px 14px;flex-wrap:wrap;gap:8px}.cook-step-text{font-size:22px}.cook-nav{flex-direction:row;gap:10px}.cook-body{flex-direction:column}.cook-ing-panel{max-height:200px;overflow-y:auto}}.detail-section-label-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:8px}.detail-section-label-row .detail-section-label{margin-bottom:0}.serving-scaler{display:flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px}.scaler-btn{background:none;border:none;cursor:pointer;font-size:18px;color:var(--accent);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s}.scaler-btn:hover:not(:disabled){background:var(--border)}.scaler-btn:disabled{color:var(--text3);cursor:default}.scaler-value{font-size:13px;font-weight:600;color:var(--text);min-width:48px;text-align:center}.scaler-original{font-weight:400;color:var(--text3);font-size:12px}.serving-scaler-sm{padding:2px 6px;gap:4px}.serving-scaler-sm .scaler-btn{font-size:15px;width:20px;height:20px}.serving-scaler-sm .scaler-value{font-size:12px;min-width:40px}.shop-serving-scaler{flex-shrink:0}.servings-select{flex-shrink:0;width:auto}.week-day-section{margin-bottom:28px}.week-day-section-header{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}.week-day-col{display:flex;flex-direction:column}.week-day-col:last-child{border-right:none}.week-day-today .week-day-header{background:var(--accent);color:#fff}.week-day-header{background:var(--bg2);border-bottom:1px solid var(--border);padding:8px 10px;text-align:center}.week-day-name{display:block;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:inherit}.week-day-date{display:block;font-size:11px;color:inherit;opacity:.75;margin-top:1px}.week-day-meals{flex:1;padding:8px;display:flex;flex-direction:column;gap:8px}.week-day-meals .meal-card{font-size:12px;margin:0}.week-day-empty{color:var(--text3);font-size:18px;text-align:center;padding:16px 0;opacity:.4}.week-unassigned{margin-top:8px;margin-bottom:24px}.week-unassigned-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:14px}.day-selector-row{margin:6px 0}.day-selector{font-size:12px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text2);cursor:pointer;width:100%}.day-selector:focus{outline:none;border-color:var(--accent)}.cooking-for-bar{display:flex;justify-content:flex-end;margin-bottom:20px}.cooking-for-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow)}.cooking-for-label{font-size:13px;color:var(--text2)}.cooking-for-count{font-size:17px;font-weight:700;color:var(--text);min-width:22px;text-align:center}.cooking-for-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.cooking-for-btn:hover:not(:disabled){background:var(--border2)}.cooking-for-btn:disabled{opacity:.3;cursor:default}@media (max-width: 640px){.cooking-for-bar{justify-content:stretch}.cooking-for-pill{width:100%;justify-content:center}.cooking-for-btn{width:40px;height:40px;font-size:18px}}.meal-name-row{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.scale-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;color:var(--text3);background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 5px;white-space:nowrap;flex-shrink:0}.scale-toggle-row{display:flex;align-items:center;gap:8px;margin:4px 0}.scale-toggle-label{font-size:12px;color:var(--text3)}.scale-toggle{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:2px}.scale-toggle-btn{padding:3px 10px;font-size:12px;font-weight:600;border:none;background:transparent;color:var(--text3);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:all .15s;white-space:nowrap}.scale-toggle-btn.active{background:var(--card);color:var(--accent);box-shadow:0 1px 3px #00000026}.cook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column}.cook-dark{background:#1a1218;color:#f0ebe3}.cook-light{background:var(--bg);color:var(--text)}.cook-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.cook-dark .cook-topbar{border-color:#ffffff14}.cook-light .cook-topbar{border-color:var(--border)}.cook-close{background:none;border:1px solid currentColor;border-radius:var(--radius-sm);color:inherit;opacity:.6;padding:6px 12px;font-size:13px;cursor:pointer;transition:opacity .15s}.cook-close:hover{opacity:1}.cook-title-row{padding:16px 20px 8px;text-align:center;flex-shrink:0}.cook-meal-name{display:block;font-family:Cormorant Garamond,Georgia,serif;font-size:clamp(18px,4vw,28px);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cook-scaled-note{display:block;font-size:11px;opacity:.6;margin-top:4px}.cook-topbar-right{display:flex;align-items:center;gap:8px}.cook-ing-toggle,.cook-theme-toggle{background:none;border:1px solid currentColor;border-radius:var(--radius-sm);color:inherit;opacity:.7;padding:6px 10px;font-size:13px;cursor:pointer;transition:opacity .15s}.cook-ing-toggle:hover,.cook-theme-toggle:hover{opacity:1}.cook-progress-track{height:3px;background:#ffffff1a;flex-shrink:0}.cook-light .cook-progress-track{background:var(--border)}.cook-progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.cook-body{flex:1;display:flex;overflow:hidden}.cook-ing-panel{width:260px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.08);overflow-y:auto;padding:20px 16px}.cook-light .cook-ing-panel{border-color:var(--border)}.cook-ing-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.5;margin-bottom:12px}.cook-ing-list{list-style:none;display:flex;flex-direction:column;gap:4px}.cook-ing-item{display:flex;align-items:center;gap:8px;padding:6px 4px;cursor:pointer;border-radius:4px;font-size:14px;transition:opacity .15s}.cook-ing-item:hover{opacity:.8}.cook-ing-checked{opacity:.4;text-decoration:line-through}.cook-ing-check{width:18px;height:18px;border:1.5px solid currentColor;border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;opacity:.6}.cook-ing-checked .cook-ing-check{background:var(--green);border-color:var(--green);color:#fff;opacity:1}.cook-step-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 48px;gap:24px;overflow-y:auto}.cook-step-counter{font-size:13px;letter-spacing:.08em;opacity:.5;text-transform:uppercase}.cook-optional-badge{background:var(--yellow);color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:20px}.cook-step-text{font-size:26px;line-height:1.55;text-align:center;max-width:680px}.cook-step-optional{color:var(--yellow);font-style:normal}.cook-nav{display:flex;align-items:center;gap:16px;margin-top:8px}.cook-nav-btn{padding:12px 28px;font-size:15px;font-weight:600;border-radius:var(--radius);cursor:pointer;border:1.5px solid currentColor;background:none;color:inherit;opacity:.7;transition:opacity .15s,background .15s}.cook-nav-btn:hover:not(:disabled){opacity:1}.cook-nav-btn:disabled{opacity:.25;cursor:default}.cook-nav-next{background:var(--accent);color:#fff;border-color:var(--accent);opacity:1}.cook-nav-next:hover{background:var(--accent2);border-color:var(--accent2)}.cook-nav-done{background:var(--green);color:#fff;border-color:var(--green);opacity:1}.cook-no-steps{flex:1;display:flex;align-items:center;justify-content:center;opacity:.4;font-size:18px}.cook-timer{display:flex;align-items:center;gap:10px;background:#ffffff14;border-radius:var(--radius);padding:10px 16px;font-size:15px}.cook-light .cook-timer{background:var(--bg2);border:1px solid var(--border)}.cook-timer-done{background:#4a7c5933}.cook-timer-icon{font-size:18px}.cook-timer-time{font-family:Cormorant Garamond,Georgia,serif;font-size:24px;font-weight:700;min-width:72px;text-align:center}.cook-timer-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.cook-timer-btn:hover{background:var(--accent2)}.cook-timer-reset{background:none;color:inherit;opacity:.5;border:1px solid currentColor}.cook-timer-reset:hover{opacity:.8;background:none}.cook-timer-done-label{color:var(--green);font-weight:700;font-size:14px}.btn-cook{background:var(--bg2);color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.btn-cook:hover{background:var(--border);color:var(--text)}.nutrition-label-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:8px}.nutrition-label-row .form-label{margin-bottom:0}.nutrition-autofill-btn{font-size:12px;padding:5px 12px;color:var(--accent);border-color:var(--accent)}.nutrition-autofill-btn:hover{background:var(--accent);color:#fff}.hh-remove-btn{color:#e05252;border-color:#e05252}.hh-remove-btn:hover{background:#e05252;color:#fff}.hh-remove-confirm{width:100%;margin-top:8px}.btn-danger{background:#e05252;color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover:not(:disabled){background:#c94040}.btn-danger:disabled{opacity:.6;cursor:default}.photo-carousel{display:flex;align-items:center;gap:8px;width:100%;-webkit-user-select:none;user-select:none}.carousel-img-wrap{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg2);min-height:180px;max-height:320px}.carousel-photo-img{width:100%;max-height:320px;object-fit:contain;display:block}.carousel-btn{background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:50%;width:36px;height:36px;flex-shrink:0;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s}.carousel-btn:hover{background:var(--border2)}.carousel-counter{text-align:center;font-size:12px;color:var(--text3);margin-top:6px}
