*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--bg: #141414;--bg-card: #1e1e1e;--bg-input: #2a2a2a;--bg-hover: #333;--text: #e8e6e1;--text-muted: #8a8780;--accent: #d4a843;--accent-hover: #c49a35;--accent-glow: rgba(212, 168, 67, .15);--danger: #c0392b;--success: #27ae60;--border: rgba(255,255,255,.06);--border-subtle: rgba(255,255,255,.04);--radius: 14px;--radius-sm: 10px}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 22px;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s,transform .1s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--accent);color:#1a1a1a}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:#ffffff1a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.85}.btn-ghost{background:transparent;color:var(--accent);padding:8px 12px}.btn-ghost:hover{background:var(--accent-glow)}.btn-sm{padding:7px 14px;font-size:.85rem}input,textarea,select{width:100%;padding:12px 16px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input::placeholder,textarea::placeholder{color:var(--text-muted)}label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:500;color:var(--text-muted)}.app{display:flex;flex-direction:column;min-height:100dvh}.header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:8px;font-size:1.3rem;font-weight:700;color:var(--accent)!important;text-decoration:none!important;letter-spacing:-.3px}.logo-icon{width:30px;height:30px;object-fit:contain;border-radius:0;border:none}.header-right{display:flex;align-items:center;gap:14px}.see-all-sticky-header{display:flex;align-items:center;gap:12px;margin:-20px -20px 8px;padding:12px 20px;position:sticky;top:53px;background:var(--bg);z-index:10;border-bottom:1px solid var(--border)}.community-page{padding-bottom:20px}.community-section{margin-bottom:28px}.community-section-title{font-size:1.15rem;font-weight:700;margin-bottom:12px;letter-spacing:-.2px}.tonights-pick{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s}.tonights-pick:active{transform:scale(.985)}.tonights-pick-img{width:100%;height:220px;object-fit:cover;display:block}.tonights-pick-placeholder{background:var(--bg-card)}.tonights-pick-overlay{position:absolute;bottom:0;left:0;right:0;padding:16px 20px;background:linear-gradient(transparent,#000000d9)}.tonights-pick-overlay h3{font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:4px}.tonights-pick-tags{display:flex;gap:6px;margin-top:6px}.tonights-pick-tags .tag{background:#ffffff26;color:#fff}.tonights-pick-add{position:absolute;top:10px;left:10px;width:32px;height:32px;font-size:1.3rem;z-index:2}.community-scroll-row{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:8px;scrollbar-width:none}.community-scroll-row::-webkit-scrollbar{display:none}.community-scroll-card{flex-shrink:0;width:160px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;scroll-snap-align:start;transition:transform .15s,border-color .2s;position:relative}.community-scroll-card:hover{border-color:#ffffff1a}.community-scroll-card:active{transform:scale(.97)}.scroll-card-img{width:100%;height:110px;object-fit:cover;display:block}.scroll-card-placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-input)}.scroll-card-body{padding:8px 10px 10px}.scroll-card-title{font-size:.82rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.scroll-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.scroll-card-tags .tag{font-size:.6rem;padding:1px 6px}.scroll-card-add{position:absolute;top:6px;left:6px;width:26px;height:26px;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}.scroll-card-add:hover{background:#000000b3;color:#fff}.scroll-card-add.added{background:var(--accent);color:#1a1a1a}.scroll-card-add.added:hover{background:#00000080;color:#fff}.see-all-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:160px;color:var(--accent);font-size:.9rem;font-weight:600}.see-all-card:hover{background:var(--accent-glow)}.community-see-all-btn{width:100%;margin-top:8px}.shared-card-wrap{display:flex;flex-direction:column}.shared-card-footer{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);margin-top:-14px}.shared-card-wrap .recipe-card{border-radius:var(--radius) var(--radius) 0 0}.shared-by{font-size:.8rem;color:var(--text-muted);font-style:italic}.private-toggle{display:flex;flex-direction:row;align-items:center;gap:8px;cursor:pointer}.private-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}.private-toggle span:first-of-type{font-size:.95rem;font-weight:500;color:var(--text)}.private-hint{font-size:.8rem;color:var(--text-muted)}.admin-link{display:flex;align-items:center;color:var(--accent)!important;opacity:.8;transition:opacity .15s}.admin-link:hover{opacity:1;text-decoration:none!important}.user-name{font-size:.85rem;color:var(--text-muted)}.admin-page h1{font-size:1.6rem;font-weight:700;margin-bottom:8px}.admin-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:24px}.invite-form{display:flex;gap:8px;margin-bottom:16px}.invite-form input{flex:1}.invite-list{margin-top:24px}.invite-list h2{font-size:1rem;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.admin-empty{color:var(--text-muted);font-size:.9rem}.invite-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.invite-info{display:flex;align-items:center;gap:10px}.invite-email{font-size:.95rem}.invite-status{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:100px}.invite-status.pending{background:#d4a8431f;color:var(--accent)}.invite-status.registered{background:#27ae601f;color:var(--success)}.main{flex:1;padding:20px 20px 90px;max-width:800px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));background:var(--bg-card);border-top:1px solid var(--border);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.7rem;color:var(--text-muted);text-decoration:none!important;padding:4px 16px;-webkit-tap-highlight-color:transparent;transition:color .2s}.nav-item.active{color:var(--accent)}.nav-item svg{display:block}.nav-add{background:var(--accent);color:#1a1a1a!important;border-radius:50%;width:52px;height:52px;padding:0;margin-top:-20px;justify-content:center;box-shadow:0 4px 16px #d4a8434d}.nav-add span{display:none}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px;background:var(--bg)}.auth-card{width:100%;max-width:400px}.auth-title{font-size:2.2rem;font-weight:800;color:var(--accent);text-align:center;margin-bottom:6px;letter-spacing:-.5px}.auth-subtitle{text-align:center;color:var(--text-muted);margin-bottom:36px;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-footer{text-align:center;margin-top:28px;color:var(--text-muted);font-size:.875rem}.error-msg{background:#c0392b1f;color:var(--danger);padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;border:1px solid rgba(192,57,43,.2)}.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:4px 16px;margin-bottom:24px;transition:border-color .2s}.search-bar:focus-within{border-color:var(--accent)}.search-bar svg{flex-shrink:0;color:var(--text-muted)}.search-bar input{background:transparent;border:none;padding:12px 0;box-shadow:none}.search-bar input:focus{border-color:transparent;box-shadow:none}.search-clear-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);flex-shrink:0;display:flex;align-items:center}.search-clear-btn:hover{color:var(--text)}.search-bar-with-mode{display:flex;gap:6px;align-items:stretch}.search-bar-with-mode .search-bar{flex:1;margin-bottom:0}.search-mode-select{background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);color:#1a1a1a;font-size:.7rem;font-weight:600;padding:0 6px;cursor:pointer;white-space:nowrap;max-width:85px}.search-mode-select:focus{outline:none}.filter-chips-wrapper{position:relative;margin:10px 0 14px}.filter-chips{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-chips::-webkit-scrollbar{display:none}.filter-chips-fade{position:absolute;right:0;top:0;bottom:0;width:48px;display:flex;align-items:center;justify-content:flex-end;padding-right:2px;background:linear-gradient(to right,transparent,var(--bg, #1a1a1a) 70%);pointer-events:none;opacity:0;transition:opacity .2s}.filter-chips-fade svg{opacity:.45;color:var(--text-muted)}.filter-chips-wrapper.has-overflow .filter-chips-fade{opacity:1}.filter-chip{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;color:var(--text-muted);font-size:.78rem;font-weight:500;padding:5px 14px;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent;outline:none;white-space:nowrap;flex-shrink:0}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#1a1a1a;font-weight:600}.sticky-header{position:sticky;top:49px;z-index:10;background:var(--bg);padding-top:16px;padding-bottom:4px}.recipe-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 500px){.recipe-grid{grid-template-columns:repeat(2,1fr)}}.recipe-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .15s,border-color .2s,box-shadow .2s}.recipe-card:hover{border-color:#ffffff1a;box-shadow:0 2px 12px #0000004d}.recipe-card:active{transform:scale(.985)}.recipe-card-img{width:100%;height:160px;object-fit:cover;display:block}.recipe-card-placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-input)}.recipe-card-img-wrap{position:relative}.favorite-star{position:absolute;top:8px;left:8px;width:32px;height:32px;border-radius:50%;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#ffffff80;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}.favorite-star:hover{background:#000000a6;color:#fffc}.favorite-star.active{color:var(--accent)}.favorite-star.active:hover{color:var(--accent-hover)}.recipe-card-body{padding:12px 16px}.recipe-card-title{font-size:1rem;font-weight:600;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.recipe-card-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-muted)}.recipe-card-ratings{display:flex;flex-direction:column;align-items:flex-end;margin-left:auto;gap:1px}.recipe-card-rating{display:inline-flex;align-items:center;gap:2px;font-weight:600;color:var(--star-filled);font-size:.75rem;white-space:nowrap}.recipe-card-rating-you{gap:1px}.recipe-card-rating-label{font-weight:400;opacity:.6;font-size:.65rem}.recipe-card-tags{display:flex;gap:5px;margin-top:6px;flex-wrap:wrap}.tag{display:inline-block;padding:2px 9px;background:var(--accent-glow);color:var(--accent);border-radius:100px;font-size:.7rem;font-weight:500;letter-spacing:.2px}.source-badge{padding:2px 8px;border-radius:100px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.source-manual{background:#27ae601f;color:var(--success)}.source-url{background:#3498db1f;color:#5dade2}.source-video{background:#9b59b61f;color:#af7ac5}.source-image{background:#e67e221f;color:#e67e22}.recipe-detail-img-container{position:relative;margin-bottom:4px}.detail-creator-badge{position:absolute;bottom:10px;left:10px;display:inline-flex;align-items:center;gap:3px;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--star-filled);font-size:.85rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-sm)}.detail-creator-badge-label{font-weight:400;opacity:.7;font-size:.75rem;color:#ccc}.detail-menu-wrap{position:absolute;bottom:10px;right:10px}.detail-menu-btn{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#fff;border-radius:var(--radius-sm);padding:4px 6px;cursor:pointer;display:flex;align-items:center}.detail-menu-wrap .recipe-dropdown{right:0;bottom:100%;top:auto;margin-bottom:4px}.detail-difficulty-badge{position:absolute;bottom:10px;right:10px;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:.8rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-sm)}.recipe-detail-img{display:block;width:100%;max-height:340px;object-fit:cover;border-radius:var(--radius);box-shadow:0 2px 10px #0000004d}.recipe-img-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;height:180px;background:var(--bg-card);border:2px dashed rgba(255,255,255,.08);border-radius:var(--radius);cursor:pointer;color:var(--text-muted);font-size:.85rem;transition:border-color .2s,color .2s}.recipe-img-upload-placeholder:hover{border-color:var(--accent);color:var(--accent)}.image-picker-section{margin-bottom:16px}.image-picker-actions{display:flex;gap:8px;margin-bottom:12px}.recipe-img-upload-placeholder-compact{display:flex;flex-direction:row;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-input);border:1px dashed rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.recipe-img-upload-placeholder-compact:hover{border-color:var(--accent);color:var(--accent)}.image-suggestions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media (max-width: 500px){.image-suggestions{grid-template-columns:repeat(2,1fr)}}.image-suggestion{position:relative;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;transition:border-color .15s}.image-suggestion:hover{border-color:var(--accent)}.image-suggestion img{width:100%;height:100px;object-fit:cover;display:block}.image-suggestion-loading{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem}.unsplash-credit{grid-column:1 / -1;text-align:center;font-size:.7rem;color:var(--text-muted);margin-top:4px}.unsplash-credit a{color:var(--text-muted);text-decoration:underline}.recipe-img-change-btn{position:absolute;bottom:12px;right:12px;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);padding:7px 14px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:background .2s;color:#fff;font-size:.8rem;font-weight:500}.recipe-img-change-btn:hover{background:#000000d9}.recipe-added-by-row{display:flex;align-items:center;justify-content:space-between;margin:0 0 2px}.recipe-added-by{font-size:.8rem;color:var(--text-muted);font-style:italic;margin:0}.btn-add-copy{font-size:.75rem;padding:3px 10px;background:var(--accent);color:#1a1a1a;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer}.btn-add-copy:disabled{opacity:.5}.copy-status-wrap{display:flex;align-items:center;gap:4px}.copy-added-badge{display:inline-flex;align-items:center;gap:3px;font-size:.75rem;color:#7cb580;font-weight:600}.copy-menu-wrap{position:relative}.copy-menu-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;opacity:.6}.copy-menu-btn:hover{opacity:1}.recipe-toolbar{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}.recipe-toolbar-top{display:flex;justify-content:space-between;align-items:center}.recipe-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.recipe-detail-header h1{font-size:1.85rem;font-weight:700;line-height:1.2;letter-spacing:-.3px;flex:1;min-width:0}.recipe-actions{display:flex;align-items:center;gap:6px}.recipe-actions .btn-sm{padding:6px 12px;font-size:.8rem}.recipe-menu-wrap{position:relative}.recipe-menu-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:6px 8px;display:flex;align-items:center;width:auto;transition:all .15s}.recipe-menu-btn:hover{color:var(--text);border-color:#ffffff1f}.recipe-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-card);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);min-width:120px;z-index:50;box-shadow:0 8px 24px #00000080;animation:popupFade .15s ease;overflow:hidden}.recipe-dropdown button{display:block;width:100%;padding:10px 16px;background:none;border:none;color:var(--text);font-size:.9rem;text-align:left;cursor:pointer;transition:background .1s}.recipe-dropdown button:hover{background:var(--bg-hover)}.recipe-dropdown .dropdown-danger{color:var(--danger)}.recipe-dropdown .dropdown-danger:hover{background:#c0392b1a}.grocery-toast{padding:10px 16px;background:#27ae601f;border:1px solid rgba(39,174,96,.2);color:var(--success);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;margin-bottom:12px}.grocery-toast.error{background:#c0392b1f;border-color:#c0392b33;color:var(--danger)}.share-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}.share-form{display:flex;gap:8px}.share-form input{flex:1}.share-success{color:var(--success);font-size:.85rem;margin-top:8px}.share-error{color:var(--danger);font-size:.85rem;margin-top:8px}.recipe-description{color:var(--text-muted);margin-bottom:20px;line-height:1.6;font-size:.95rem}.recipe-meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.meta-chip{display:flex;flex-direction:column;align-items:center;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.05rem;font-weight:600}.meta-label{font-size:.65rem;color:var(--text-muted);font-weight:400;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.recipe-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.source-link{display:inline-flex;align-items:center;gap:4px;font-size:.875rem;margin-bottom:28px;color:var(--accent);opacity:.85;transition:opacity .15s}.source-link:hover{opacity:1}.source-images-popup{display:flex;flex-direction:column;gap:12px;margin-top:12px;margin-bottom:24px}.source-image{width:100%;max-height:500px;object-fit:contain;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border)}.source-link-url{color:#5dade2}.source-link-video{color:#af7ac5}.source-link-manual{color:var(--success)}.source-link-image{color:#e67e22}.detail-tab-toggle{display:flex;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-bottom:20px}.detail-tab-btn{flex:1;padding:10px 0;background:var(--card-bg);border:none;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.detail-tab-btn.active{background:var(--accent);color:#1a1a1a}.recipe-section{margin-bottom:36px}.recipe-section h2{font-size:1.2rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border);color:var(--text);letter-spacing:-.2px}.ingredients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.ingredients-header h2{margin:0;padding:0;border-bottom:none}.ingredients-header-left{display:flex;align-items:center;gap:8px}.btn-grocery-add{font-size:.7rem;padding:3px 8px;background:var(--accent);color:#1a1a1a;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer}.btn-grocery-add:disabled{opacity:.5}.ingredients-header-actions{display:flex;align-items:center;gap:8px}.ingredients-header .detail-toggle{margin-bottom:0;margin-top:0}.ingredients-list{list-style:none}.ingredients-list li{padding:10px 0;border-bottom:1px solid var(--border-subtle)}.ingredient-text{font-size:1rem;color:var(--text);line-height:1.4}.ingredient-text strong{color:var(--accent);font-weight:600}.ingredient-note{color:var(--text-muted);font-size:.88em;font-style:italic}.convertible-unit{position:relative;display:inline}.unit-btn{background:none;border:none;border-bottom:1px dashed var(--accent);color:inherit;font:inherit;padding:0;cursor:pointer;transition:color .15s;width:auto}.unit-btn:hover,.unit-btn:focus{color:var(--accent);outline:none;box-shadow:none}.conversion-popup{position:absolute;top:calc(100% + 6px);left:0;background:var(--bg-card);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);padding:8px 0;min-width:140px;z-index:50;box-shadow:0 8px 24px #00000080;animation:popupFade .15s ease}@keyframes popupFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.conversion-header{padding:4px 14px 8px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border)}.conversion-option{padding:8px 14px;font-size:.9rem;color:var(--text);white-space:nowrap}.conversion-option:hover{background:var(--accent-glow)}.serving-dial{display:flex;flex-direction:column;align-items:center;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm)}.dial-controls{display:flex;align-items:center;gap:8px}.dial-btn{width:24px;height:24px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:transparent;color:var(--text);font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}.dial-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.dial-value{font-size:1.1rem;font-weight:700;min-width:24px;text-align:center}.scale-badge{font-size:.75rem;font-weight:400;color:var(--accent);margin-left:8px}.instructions-list{padding-left:24px}.instructions-list li{padding:14px 0;line-height:1.65;border-bottom:1px solid var(--border-subtle)}.cook-mode-btn{width:100%;margin-bottom:16px;padding:14px;font-size:1rem}.recipe-notes-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.recipe-notes-section h2{border-bottom:none;padding-bottom:0;margin-bottom:10px}.recipe-notes-text{color:var(--text-muted);line-height:1.7;font-size:.95rem;white-space:pre-wrap}.cook-mode{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:1000;display:flex;flex-direction:column;overflow:hidden}.cook-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.cook-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;width:auto}.cook-close:hover{color:var(--text)}.cook-title{flex:1;font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.cook-ingredients-toggle{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:6px 8px;display:flex;width:auto;transition:all .15s}.cook-ingredients-toggle:hover,.cook-ingredients-toggle.active{color:var(--accent);border-color:var(--accent);background:var(--accent-glow)}.cook-progress{height:4px;background:var(--bg-card);flex-shrink:0}.cook-progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.cook-ingredients-panel{background:var(--bg-card);border-bottom:1px solid var(--border);padding:16px 20px;max-height:40vh;overflow-y:auto;flex-shrink:0;animation:slideDown .2s ease}@keyframes slideDown{0%{max-height:0;opacity:0;padding:0 20px}to{max-height:40vh;opacity:1}}.cook-ingredients-panel h3{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.cook-ingredients-panel ul{list-style:none}.cook-ingredients-panel li{padding:6px 0;font-size:.9rem;border-bottom:1px solid var(--border-subtle);color:var(--text)}.cook-ingredients-panel li strong{color:var(--accent)}.cook-ing-note{color:var(--text-muted);font-size:.85em;font-style:italic}.cook-step-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;overflow-y:auto;text-align:center}.cook-step-counter{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:20px}.cook-step-text{font-size:1.4rem;line-height:1.6;color:var(--text);max-width:600px}.cook-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;padding-bottom:max(16px,env(safe-area-inset-bottom));background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0}.cook-nav-btn{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 16px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .15s;width:auto}.cook-nav-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.cook-nav-btn:disabled{opacity:.3;cursor:not-allowed}.cook-done-btn{background:var(--accent);color:#1a1a1a;border-color:var(--accent)}.cook-done-btn:hover{background:var(--accent-hover)!important;color:#1a1a1a!important}.cook-step-dots{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:center;max-width:200px}.cook-dot{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff26;cursor:pointer;padding:0;transition:all .15s}.cook-dot.done{background:var(--accent);opacity:.4}.cook-dot.active{background:var(--accent);opacity:1;width:10px;height:10px}.cook-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.recipe-form-page h1{font-size:1.5rem;margin-bottom:20px}.import-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:24px}.import-section h3{font-size:.85rem;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.3px}.import-row{display:flex;gap:8px}.import-row input{flex:1}.import-row .btn{flex-shrink:0}.import-divider{display:flex;align-items:center;gap:12px;margin:14px 0;color:var(--text-muted);font-size:.8rem}.import-divider:before,.import-divider:after{content:"";flex:1;height:1px;background:var(--border)}.import-image-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:var(--bg-input);border:1px dashed rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:border-color .2s,color .2s}.import-image-btn:hover{border-color:var(--accent);color:var(--accent)}.form-image-section{margin-bottom:4px}.image-options-picker{margin-top:12px}.image-options-preview{margin-bottom:12px;border-radius:10px;overflow:hidden}.image-options-preview img{width:100%;display:block;object-fit:cover;max-height:300px}.image-options-label{font-size:.8rem;color:var(--text-muted);margin:0 0 8px}.image-options-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.image-option{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .15s}.image-option.selected{border-color:var(--accent)}.image-option img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.form-image-upload-small{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:.75rem;color:var(--text-muted);cursor:pointer;text-decoration:underline}.form-image-upload-small:hover{color:var(--text)}.image-option-check{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#1a1a1a;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.form-image-preview{position:relative}.form-image-preview img{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius);display:block}.form-image-change{position:absolute;bottom:10px;right:10px;display:flex;flex-direction:row;align-items:center;gap:6px;padding:7px 14px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);color:#fff;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.form-image-change:hover{background:#000000e6}.form-image-upload{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:10px;width:100%;height:100px;background:var(--bg-card);border:2px dashed rgba(255,255,255,.08);border-radius:var(--radius);cursor:pointer;color:var(--text-muted);font-size:.9rem;transition:border-color .2s,color .2s}.form-image-upload:hover{border-color:var(--accent);color:var(--accent)}.recipe-form{display:flex;flex-direction:column;gap:20px}.form-row-thirds{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.list-field{border:1px solid var(--border);border-radius:var(--radius);padding:16px}.list-field legend{font-weight:600;font-size:.9rem;padding:0 8px}:root{--star-filled: #f5a623;--star-empty: #3a3a3a}.star-rating{display:flex;align-items:center;gap:6px;line-height:1}.star-rating-stars{display:flex;gap:2px}.star-rating-label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.star-rating-value{font-size:.75rem;color:var(--text-muted);font-weight:600}.star.interactive{cursor:pointer;transition:transform .1s;-webkit-tap-highlight-color:transparent}.star.interactive:hover{transform:scale(1.2)}.star-rating-sm .star-rating-label,.star-rating-sm .star-rating-value{font-size:.65rem}.star-rating-lg .star-rating-label{font-size:.85rem;font-weight:600;color:var(--text)}.star-rating-lg .star-rating-stars{gap:4px}.star-rating-stars svg{display:block}.rating-with-clear{display:flex;flex-direction:column;gap:2px}.rating-clear-btn{background:none;border:none;color:var(--text-muted);font-size:.65rem;cursor:pointer;padding:0;text-decoration:underline;opacity:.7;align-self:flex-start}.rating-clear-btn:hover{opacity:1;color:var(--danger, #e74c3c)}.recipe-ratings-section{display:flex;flex-direction:row;align-items:center;gap:12px;flex-wrap:wrap}.rate-prompt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.rate-prompt-card{background:var(--bg-card);border-radius:var(--radius);padding:24px;max-width:340px;width:90%;text-align:center}.rate-prompt-card h3{margin:0 0 12px;font-size:1.1rem}.rate-prompt-card .star-rating{justify-content:center;margin-bottom:16px}.rate-prompt-actions{display:flex;gap:12px;justify-content:center}.unit-system-toggle{display:flex;gap:0;margin-bottom:14px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;width:fit-content}.toggle-btn{padding:6px 18px;background:var(--bg-input);color:var(--text-muted);border:none;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;width:auto}.toggle-btn:not(:last-child){border-right:1px solid var(--border)}.toggle-btn.active{background:var(--accent);color:#1a1a1a}.toggle-btn:hover:not(.active){background:var(--bg-hover)}.ingredient-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.ing-qty{width:60px;flex-shrink:0}.ing-unit,.ing-unit-custom{width:85px;flex-shrink:0}.ing-name{flex:1;min-width:80px}.ing-note{width:80px;flex-shrink:0;font-size:.85rem}@media (max-width: 500px){.ingredient-row{flex-wrap:wrap}.ing-qty{width:25%}.ing-unit,.ing-unit-custom{width:calc(35% - 6px)}.ing-name{width:calc(100% - 40px)}.ing-note{width:calc(50% - 6px)}}.list-item-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.list-item-row input,.list-item-row textarea{flex:1}.step-num{font-weight:600;color:var(--accent);font-size:.9rem;flex-shrink:0;width:24px}.btn-remove{background:transparent;border:none;color:var(--danger);font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;opacity:.6}.btn-remove:hover{opacity:1}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state p:first-child{font-size:1.25rem;margin-bottom:8px}.empty-hint{font-size:.875rem}.page-title{font-size:1.5rem;font-weight:800;margin:0 0 12px;text-align:center;letter-spacing:-.5px}.mealprep-page h1{font-size:1.6rem;font-weight:700;margin-bottom:8px;letter-spacing:-.3px}.mealprep-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:28px;line-height:1.5}.mealprep-section{margin-bottom:32px}.mealprep-section h2{font-size:1.1rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.mealprep-hint{color:var(--text-muted);font-size:.8rem;margin-bottom:12px;text-align:center}.mealprep-recipe-list{display:flex;flex-direction:column;gap:8px}.mealprep-recipe-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,border-color .2s}.mealprep-recipe-item:active{transform:scale(.99)}.mealprep-recipe-item.selected{border-color:var(--accent);background:var(--accent-glow)}.mealprep-recipe-check{flex-shrink:0}.mealprep-recipe-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0}.mealprep-recipe-thumb-empty{display:flex;align-items:center;justify-content:center;background:var(--bg-input);color:var(--text-muted)}.checkbox{width:24px;height:24px;border:2px solid rgba(255,255,255,.15);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.checkbox.checked{background:var(--accent);border-color:var(--accent)}.mealprep-recipe-info{flex:1;min-width:0}.mealprep-recipe-title{font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.mealprep-meals-input{display:flex;align-items:center;gap:8px;flex-shrink:0}.mealprep-meals-input label{font-size:.8rem;color:var(--text-muted);flex-direction:row}.mealprep-meals-input input{width:60px;padding:8px;text-align:center;font-size:.9rem}.random-picks-row{display:flex;justify-content:center;gap:24px}.stepper-field{display:flex;flex-direction:column;align-items:center;gap:6px}.stepper-label{font-size:.8rem;color:var(--text-muted);text-align:center}.stepper-controls{display:flex;align-items:center;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;width:fit-content}.stepper-btn{background:var(--bg-input);border:none;padding:8px 12px;cursor:pointer;color:var(--text);display:flex;align-items:center}.stepper-btn:hover{background:var(--bg-hover)}.stepper-btn:active{background:var(--accent);color:#1a1a1a}.stepper-value{padding:8px 16px;font-size:1rem;font-weight:600;min-width:40px;text-align:center;border-left:1px solid var(--border);border-right:1px solid var(--border)}.mealprep-summary{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:20px}.mealprep-summary h3{font-size:.8rem;color:var(--text-muted);margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:7px 0;font-size:.9rem}.summary-meals{color:var(--accent);font-weight:600;font-size:.85rem}.btn-generate{width:100%;padding:16px;font-size:1.1rem;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:8px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite;flex-shrink:0}.share-target-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:20px}.share-target-loading,.share-target-error{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.share-target-loading .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%}.grocery-page h1{font-size:1.6rem;font-weight:700;letter-spacing:-.3px}.grocery-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.grocery-progress{font-size:.85rem;color:var(--text-muted)}.progress-bar{height:6px;background:var(--bg-card);border-radius:3px;margin-bottom:24px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.meal-summary-details{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:24px}.meal-summary-details summary{padding:14px 16px;cursor:pointer;font-size:.9rem;color:var(--text-muted);font-weight:500}.meal-summary-details[open] summary{border-bottom:1px solid var(--border)}.meal-summary-list{padding:8px 16px}.meal-summary-item{display:flex;justify-content:space-between;padding:7px 0;font-size:.85rem}.meal-summary-meta{color:var(--text-muted)}.grocery-category{margin-bottom:24px}.category-header{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--accent);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(212,168,67,.15)}.grocery-item{display:grid;grid-template-columns:28px 1fr 90px minmax(80px,130px);align-items:center;gap:8px;padding:14px 0;border-bottom:1px solid var(--border-subtle);transition:opacity .15s;-webkit-tap-highlight-color:transparent}.grocery-item:active{opacity:.7}.grocery-item.checked{opacity:.4}.grocery-item-name{font-size:.95rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grocery-item.checked .grocery-item-name{text-decoration:line-through}.grocery-item-qty{font-size:.82rem;font-weight:600;color:var(--accent);text-align:center;white-space:nowrap;justify-self:center}.grocery-item-qty:not(:empty){padding:4px 8px;background:var(--accent-glow);border-radius:6px}.grocery-item-recipe{font-size:.75rem;color:var(--text-muted);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grocery-add-form{display:flex;gap:8px;margin-bottom:16px}.grocery-add-name{flex:1}.grocery-add-qty{width:70px;flex-shrink:0}.grocery-add-form .btn{flex-shrink:0;padding:7px 14px}.grocery-checked-section{margin-top:12px}.grocery-checked-divider{display:flex;align-items:center;gap:12px;padding:16px 0 8px;color:var(--text-muted);font-size:.8rem;font-weight:500}.grocery-checked-divider:before,.grocery-checked-divider:after{content:"";flex:1;height:1px;background:var(--border)}.grocery-filter{margin-bottom:20px}.grocery-filter select{width:100%;padding:10px 14px;font-size:.85rem}@media (max-width: 420px){.grocery-item{grid-template-columns:28px 1fr 70px;grid-template-rows:auto auto}.grocery-item-recipe{grid-column:2 / -1;text-align:left;font-size:.7rem;margin-top:-4px}}.duplicate-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.duplicate-card{background:var(--bg-card);border-radius:var(--radius);padding:24px;max-width:360px;width:100%}.duplicate-card h3{margin-bottom:8px;font-size:1.1rem}.duplicate-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:16px}.duplicate-preview{display:flex;align-items:center;gap:12px;background:var(--bg-input);border-radius:var(--radius-sm);padding:10px;margin-bottom:20px}.duplicate-preview-img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.duplicate-preview-title{font-weight:600;font-size:.9rem}.duplicate-actions{display:flex;flex-direction:column;gap:8px}.duplicate-actions .btn{width:100%;text-align:center}.description-urls-list{display:flex;flex-direction:column;gap:6px;margin:12px 0}.description-url-link{display:flex;align-items:center;gap:6px;padding:10px 12px;background:var(--surface-2, #2a2a2a);border-radius:8px;color:var(--accent, #6daedb);font-size:.9rem;text-decoration:none;word-break:break-all}.description-url-link:hover{background:var(--surface-3, #333)}.description-url-link svg{flex-shrink:0;opacity:.6}.missing-measurements-hint{font-size:.8rem;color:var(--text-muted, #999);margin:8px 0 16px}.difficulty-easy{color:#7cb580}.difficulty-medium{color:#c9a24d}.difficulty-hard{color:#c07070}.nutrition-section{margin-top:8px}.nutrition-per-serving{font-size:.75rem;font-weight:400;color:var(--text-muted)}.nutrition-macros{display:flex;gap:8px;margin-bottom:12px}.nutrition-macro{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm)}.nutrition-value{font-size:1.2rem;font-weight:700;color:var(--text)}.nutrition-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
