:root{--color-bg-start: #0f172a;--color-bg-end: #1e293b;--color-primary: 250, 100%, 70%;--color-secondary: 180, 100%, 70%;--color-accent: 330, 100%, 70%;--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--text-main: #f8fafc;--text-muted: #94a3b8;--success: #10b981}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Noto Sans SC,sans-serif;background:#0f172a;color:var(--text-main);min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;overflow-x:hidden}.background-gradient{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:radial-gradient(circle at 20% 20%,rgba(var(--color-primary),.15),transparent 60%),radial-gradient(circle at 80% 80%,rgba(var(--color-accent),.15),transparent 60%);pointer-events:none}#app{max-width:1200px;margin:0 auto;padding:1rem;width:100%;display:flex;flex-direction:column;gap:1rem;flex-grow:1}header.header-container{display:flex;flex-direction:column;gap:.8rem;margin-bottom:0}.header-title-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}.site-logo{height:3rem;width:auto;object-fit:contain}.header-title-row h1{font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:0;letter-spacing:-1px;line-height:1.1;white-space:nowrap}.header-title-row .subtitle{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.header-title-row .active-pref-tag{margin-left:auto}.header-controls-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.grid-container{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem;perspective:1000px}.dish-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;position:relative;overflow:hidden;height:100%;min-height:200px}.dish-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px -10px #00000080;border-color:#ffffff40;background:#ffffff14}.dish-card.accepted{border-color:#10b981;background:#10b98126;box-shadow:0 0 30px -10px #10b9814d}.dish-info h3{font-size:1.4rem;font-weight:700;margin-bottom:.5rem;color:#fff}.dish-desc{color:var(--text-muted);font-size:.95rem;line-height:1.5}.tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.tag{font-size:.75rem;padding:.2rem .6rem;border-radius:99px;background:#ffffff1a;color:var(--text-muted)}.card-actions{display:flex;justify-content:flex-end;gap:.8rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--glass-border);z-index:2}.icon-btn{background:#0003;border:1px solid transparent;color:var(--text-muted);cursor:pointer;width:40px;height:40px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:#fff3;color:#fff;transform:scale(1.1)}.icon-btn.active-favorite{color:#f43f5e;background:#f43f5e26;border-color:#f43f5e4d}.icon-btn.active-dislike{color:#ef4444;background:#ef44441a;border-color:#ef444433}.icon-btn.active-accept{color:#10b981;background:#10b98126;border-color:#10b9814d}.icon-btn.top-right{position:absolute;top:1rem;right:1rem;z-index:10;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-color:#ffffff1a}.icon-btn.top-right:hover{background:#fff3;border-color:#ffffff4d}.action-bar{position:sticky;bottom:2rem;display:flex;justify-content:center;align-items:center;gap:1.5rem;padding:1rem 1.5rem;background:#0f172ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:1px solid var(--glass-border);margin:0 auto;width:fit-content;z-index:100;box-shadow:0 10px 30px -10px #00000080}.btn{padding:.8rem 1.8rem;border-radius:99px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.6rem;font-family:inherit;white-space:nowrap}.btn.primary{background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));color:#0f172a;box-shadow:0 4px 20px rgba(var(--color-primary),.4)}.btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(var(--color-primary),.5)}.btn.secondary{background:#ffffff14;color:#e2e8f0;border:1px solid var(--glass-border)}.btn.secondary:hover{background:#ffffff26;border-color:#ffffff4d}.btn.secondary.active-favorite-mode{background:linear-gradient(135deg,#f43f5e4d,#db27774d);border-color:#f43f5e80;color:#fff;box-shadow:0 4px 20px #f43f5e66}.btn.secondary.active-favorite-mode:hover{background:linear-gradient(135deg,#f43f5e66,#db277766);box-shadow:0 8px 25px #f43f5e80}.btn.ghost{background:transparent;border:1px solid var(--glass-border);color:var(--text-muted)}.btn.ghost:hover{border-color:#fff;color:#fff}.settings-wrapper{position:relative;display:flex;align-items:center}.settings-menu{position:absolute;bottom:100%;right:0;margin-bottom:1rem;background:#1e293b;border:1px solid var(--glass-border);border-radius:12px;padding:.5rem;display:flex;flex-direction:column;gap:.2rem;width:200px;opacity:0;left:50%;transform:translate(-50%) translateY(10px);pointer-events:none;transition:all .2s ease;box-shadow:0 10px 30px #00000080;z-index:101}.settings-menu:after{content:"";position:absolute;top:100%;left:0;width:100%;height:1.5rem}.settings-wrapper:hover .settings-menu{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.settings-item{padding:.8rem 1rem;color:var(--text-muted);cursor:pointer;border-radius:8px;transition:background .2s;font-size:.9rem;text-align:left;background:transparent;border:none;width:100%}.settings-item:hover{background:#ffffff1a;color:#fff}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}#recipe-modal{z-index:3100}#recipe-modal .modal-content{z-index:3101}.modal.visible{opacity:1;pointer-events:auto}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-content{position:relative;z-index:1000;width:94%;max-width:960px;background:#1e293b;border-radius:20px;padding:1.5rem 2rem;box-shadow:0 25px 50px -12px #0009;border:1px solid rgba(255,255,255,.1);transform:translateY(30px) scale(.95);transition:all .3s cubic-bezier(.19,1,.22,1);max-height:85vh;overflow-y:auto}.modal.visible .modal-content{transform:translateY(0) scale(1)}.close-modal{position:absolute;top:1.5rem;right:1.5rem;background:#ffffff1a;border:none;font-size:1.2rem;width:36px;height:36px;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.close-modal:hover{background:#fff3}.modal-header-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.modal-header-row #modal-title{font-size:1.6rem;margin-bottom:0;color:#fff;flex-grow:1}.modal-header-row .close-modal{position:static;flex-shrink:0}.modal-actions{display:flex;gap:.5rem;flex-shrink:0}.modal-actions .icon-btn{background:#0003;border:1px solid transparent;color:var(--text-muted);cursor:pointer;width:36px;height:36px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-actions .icon-btn:hover{background:#fff3;color:#fff;transform:scale(1.1)}.modal-actions .icon-btn.active-favorite{color:#f43f5e;background:#f43f5e26;border-color:#f43f5e4d}.modal-actions .icon-btn.active-dislike{color:#ef4444;background:#ef44441a;border-color:#ef444433}.modal-actions .icon-btn.active-accept{color:#10b981;background:#10b98126;border-color:#10b9814d}#modal-title{font-size:1.6rem;margin-bottom:.5rem;color:#fff}.recipe-section{margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--glass-border)}.dish-description{color:var(--text-muted);font-size:.9rem;margin-bottom:.8rem;padding-bottom:0;border-bottom:none}.recipe-text-area{line-height:1.8;color:#cbd5e1}.recipe-text-area pre{white-space:pre-wrap;word-wrap:break-word;font-family:Noto Sans SC,sans-serif;font-size:.95rem;background:#0003;padding:1.2rem;border-radius:12px;border:1px solid var(--glass-border)}.hidden{display:none!important}.glass-input{width:100%;min-height:150px;background:#0000004d;border:1px solid var(--glass-border);border-radius:12px;color:#fff;padding:1rem;font-family:inherit;resize:vertical;outline:none;transition:border-color .2s}.glass-input:focus{border-color:hsl(var(--color-primary))}.modal-footer{margin-top:1.5rem;display:flex;gap:1rem;justify-content:flex-end}.btn.small{padding:.5rem 1rem;font-size:.9rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .5s ease forwards}.list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--glass-border);color:var(--text-muted)}.list-item:last-child{border-bottom:none}.list-item-title{color:#fff;font-weight:600}.clickable{cursor:pointer;transition:background .2s}.clickable:hover{background:#ffffff0d}.delete-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;margin-left:10px;display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-btn:hover{color:#ef4444;background:#ef44441a}.list-empty{text-align:center;padding:2rem;color:var(--text-muted)}@media (max-width: 1200px){.grid-container{grid-template-columns:repeat(4,1fr)}}@media (max-width: 900px){.grid-container{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.grid-container{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){#app{padding:1rem}.grid-container{grid-template-columns:1fr}header h1{font-size:2rem}.action-bar{width:95%;gap:.5rem;padding:.8rem;flex-wrap:wrap}.btn{padding:.6rem 1rem;font-size:.9rem}.settings-menu{right:0;left:auto}}.recipe-meta-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.8rem}.meta-tag{font-size:.75rem;padding:.25rem .6rem;border-radius:4px;background:#ffffff14;color:var(--text-muted);border:1px solid var(--glass-border)}.meta-tag.cuisine{background:rgba(var(--color-primary),.15);color:hsl(var(--color-primary));border-color:rgba(var(--color-primary),.3)}.meta-tag.method{background:rgba(var(--color-secondary),.15);color:hsl(var(--color-secondary));border-color:rgba(var(--color-secondary),.3)}.meta-tag.time{background:#10b98126;color:#10b981;border-color:#10b9814d}.meta-tag.difficulty{background:#fbbf2426;color:#fbbf24;border-color:#fbbf244d}.meta-tag.cost{background:#ef444426;color:#ef4444;border-color:#ef44444d}.meta-tag.spicy{background:#ef444433;color:#f87171}.recipe-section-block{margin-bottom:.8rem;padding-bottom:.8rem;border-bottom:1px solid var(--glass-border)}.recipe-section-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.recipe-section-title{color:#94a3b8;font-size:.8rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.recipe-materials{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.8rem}.recipe-materials-col h4{color:#94a3b8;font-size:.75rem;font-weight:600;margin-bottom:.4rem;text-transform:uppercase}.materials-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.3rem}.materials-list li{font-size:.85rem;color:#e2e8f0;background:#0003;padding:.3rem .6rem;border-radius:4px}.materials-list li .amount{color:var(--text-muted);margin-left:.3rem}.recipe-steps-compact{list-style:none;padding:0;margin:0}.recipe-steps-compact li{display:flex;align-items:flex-start;gap:.6rem;padding:.5rem 0;border-bottom:1px dashed rgba(255,255,255,.05);font-size:.9rem;color:#cbd5e1;line-height:1.5}.recipe-steps-compact li:last-child{border-bottom:none}.step-num{flex-shrink:0;width:20px;height:20px;background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));color:#0f172a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem}.recipe-tips-compact{background:#00000026;padding:.6rem .8rem;border-radius:8px;margin-top:.6rem;font-size:.8rem;color:var(--text-muted);line-height:1.5}.recipe-tips-compact strong{color:hsl(var(--color-accent))}.recipe-story-compact{font-size:.8rem;color:#64748b;font-style:italic;padding:.5rem 0;border-top:1px dashed var(--glass-border);margin-top:.6rem}.no-recipe,.loading-recipe{text-align:center;padding:2rem;color:var(--text-muted);font-size:1rem}.loading-recipe:after{content:"";display:inline-block;width:16px;height:16px;margin-left:8px;border:2px solid var(--text-muted);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.recipe-materials{grid-template-columns:1fr}.recipe-meta-tags{gap:.3rem}}#recipe-text{font-family:Inter,Noto Sans SC,sans-serif;color:var(--text-main);white-space:normal}.custom-recipe-pre{white-space:pre-wrap;word-wrap:break-word;font-family:Noto Sans SC,sans-serif;font-size:.95rem;background:#0003;padding:1.2rem;border-radius:12px;border:1px solid var(--glass-border);color:#cbd5e1}.recipe-header{margin-bottom:.5rem}.recipe-desc-text{font-size:1rem;color:#94a3b8;line-height:1.6;margin-bottom:.8rem}.recipe-header-badges{display:flex;gap:.5rem;flex-wrap:wrap}.recipe-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:99px;font-size:.8rem;font-weight:500;line-height:1.25;border:1px solid transparent}.badge-red-outline{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.badge-green{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge-yellow{background:#fef9c3;color:#854d0e;border-color:#fde047}.badge-red{background:#fee2e2;color:#991b1b;border-color:#fecaca}.badge-gray{background:#f1f5f9;color:#334155;border-color:#e2e8f0}.badge-secondary{font-size:.75rem;padding:.2rem .6rem}.badge-red-light{background:#fef2f2;color:#b91c1c;border-color:#fee2e2}.badge-amber-light{background:#fffbeb;color:#b45309;border-color:#fef3c7}.recipe-meta-grid{display:flex;justify-content:space-between;gap:.5rem;padding:.75rem 0;border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);margin-bottom:1rem}.recipe-meta-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;flex:1;text-align:center;padding:.5rem .25rem;background:#ffffff08;border-radius:8px}.meta-icon svg{width:18px;height:18px}.icon-orange{color:#ea580c}.icon-green{color:#16a34a}.icon-red{color:#dc2626}.icon-blue{color:#2563eb}.icon-inline svg{width:16px;height:16px;vertical-align:text-bottom;margin-right:4px}.text-red{color:#dc2626}.text-orange{color:#ea580c}.text-blue{color:#2563eb}.text-green{color:#16a34a}.text-amber{color:#d97706}.icon-purple{color:#a855f7}.icon-yellow{color:#eab308}.meta-text{font-size:.85rem;color:#e2e8f0;font-weight:500;white-space:nowrap}.recipe-tags-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.5rem}.recipe-separator{height:1px;background:var(--glass-border);margin:1.5rem 0}.recipe-main-grid{display:grid;grid-template-columns:1fr 2fr;gap:2rem}.recipe-col-left{display:flex;flex-direction:column;gap:1.5rem}.group-title{font-size:1rem;font-weight:600;color:#f8fafc;margin-bottom:.8rem;display:flex;align-items:center}.materials-list-vertical{display:flex;flex-direction:column;gap:.5rem}.material-row{display:flex;justify-content:space-between;padding:.5rem .8rem;background:#ffffff0d;border-radius:6px;align-items:center}.material-name{color:#e2e8f0;font-size:.9rem}.material-amount{color:#94a3b8;font-size:.85rem}.equipment-list{display:flex;flex-wrap:wrap;gap:.5rem}.equipment-tag{font-size:.8rem;padding:.2rem .6rem;border-radius:6px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8}.recipe-col-right{display:flex;flex-direction:column;align-items:center}.recipe-col-right .group-title{width:100%;text-align:center;justify-content:center}.steps-list{display:flex;flex-direction:column;gap:1.2rem;width:fit-content;max-width:100%}.step-item{display:flex;gap:1rem;align-items:flex-start}.step-number{flex-shrink:0;width:28px;height:28px;background:#dc2626;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;margin-top:2px}.step-desc{color:#e2e8f0;line-height:1.6;font-size:.95rem}.recipe-footer-grid{display:grid;gap:1rem}.recipe-footer-grid.cols-2{grid-template-columns:1fr 1fr}.recipe-footer-grid.cols-1{grid-template-columns:1fr}.tip-card{padding:1rem;border-radius:10px;border:1px solid transparent}.tip-green{background:#dcfce71a;border-color:#4ade8033}.text-green-dark{color:#86efac}.tip-green .tip-title{color:#4ade80}.tip-blue{background:#eff6ff1a;border-color:#60a5fa33}.text-blue-dark{color:#93c5fd}.tip-blue .tip-title{color:#60a5fa}.tip-amber{background:#fffbeb1a;border-color:#fbbf2433}.text-amber-dark{color:#fcd34d}.tip-amber .tip-title{color:#fbbf24}.tip-red{background:#fef2f21a;border-color:#f8717133}.text-red-dark{color:#fca5a5}.tip-red .tip-title{color:#f87171}.tip-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.tip-icon svg{width:16px;height:16px}.tip-title{font-weight:600;font-size:.9rem}.tip-content{font-size:.85rem;line-height:1.5}@media (max-width: 768px){.recipe-meta-grid{grid-template-columns:1fr 1fr}.recipe-main-grid{grid-template-columns:1fr;gap:1.5rem}.recipe-footer-grid.cols-2{grid-template-columns:1fr}}.user-note-section{margin-top:1rem}.user-note-section .group-title{margin-bottom:.5rem}.text-purple{color:#a855f7}.note-title{font-size:1rem;font-weight:600;color:#a855f7;margin-bottom:.5rem}.search-wrapper{margin-top:0;display:flex;justify-content:flex-end;flex-shrink:0}.search-box{display:flex;align-items:center;gap:.4rem;padding:.5rem .5rem .5rem 1rem;width:260px;border-radius:99px;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);transition:all .3s ease}.search-box:focus-within{border-color:hsl(var(--color-primary));box-shadow:0 0 0 3px rgba(var(--color-primary),.15);background:#ffffff14}.search-icon{flex-shrink:0;color:var(--text-muted);transition:color .2s}.search-box:focus-within .search-icon{color:hsl(var(--color-primary))}#search-input{flex-grow:1;background:transparent;border:none;outline:none;color:var(--text-main);font-size:1rem;font-family:inherit}#search-input::placeholder{color:var(--text-muted);opacity:.7}.search-clear{flex-shrink:0;background:#ffffff1a;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.search-clear:hover{background:#ffffff1a;color:var(--text-main)}.search-wrapper{position:relative;z-index:2000}.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:800px;max-width:95vw;max-height:80vh;overflow-y:auto;background:#0f172a;background:#0f172ae6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 40px #00000080,0 0 0 1px #0003;border-radius:12px;padding:1.2rem;opacity:0;transform:translateY(-5px);pointer-events:none;transition:all .2s cubic-bezier(.16,1,.3,1);display:none}.search-dropdown.visible{display:block!important;opacity:1;transform:translateY(0);pointer-events:auto}.search-section{margin-bottom:1.2rem}.search-section:last-child{margin-bottom:0}.search-section-title{font-size:.75rem;color:var(--text-muted);margin-bottom:.6rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.search-tags-grid{display:flex;flex-wrap:wrap;gap:.5rem}.search-tag-chip{font-size:.85rem;padding:.3rem .7rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.05);border-radius:6px;color:var(--text-main);cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.search-tag-chip:hover{background:#ffffff1f;transform:translateY(-1px);border-color:#ffffff26}.search-tag-chip.cuisine{color:#93c5fd;background:#3b82f61a;border-color:#3b82f633}.search-tag-chip.cuisine:hover{background:#3b82f633}.search-tag-chip.ingredient{color:#86efac;background:#22c55e1a;border-color:#22c55e33}.search-tag-chip.ingredient:hover{background:#22c55e33}@media (max-width: 600px){.search-wrapper{margin-top:1rem}.search-box{padding:.6rem 1rem}#search-input{font-size:.9rem}.plan-day{margin-bottom:1.5rem;border-bottom:1px solid var(--glass-border);padding-bottom:1rem}.plan-day:last-child{border-bottom:none}.plan-day-title{color:hsl(var(--color-primary));margin-bottom:.5rem;font-size:1rem;font-weight:700}.plan-day-dishes{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.8rem}.plan-dish-item{background:#ffffff0d;padding:.6rem .8rem;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:.9rem;border:1px solid transparent;transition:all .2s}.plan-dish-item:hover{background:#ffffff1a;border-color:#fff3}.plan-dish-cat-tag{font-size:.75rem;padding:2px 6px;border-radius:4px;background:#334155;color:#94a3b8;margin-left:8px;flex-shrink:0}.plan-dish-cat-tag.meat{color:#f87171;background:#f8717126}.plan-dish-cat-tag.veg{color:#4ade80;background:#4ade8026}.plan-dish-cat-tag.soup{color:#60a5fa;background:#60a5fa26}.plan-dish-cat-tag.cold{color:#2dd4bf;background:#2dd4bf26}}.personalized-form-container{padding:.5rem 0}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--glass-border)}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section h3{font-size:1.1rem;color:#fff;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.form-group-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1rem}.form-group-row.three-cols{grid-template-columns:1fr 1fr 1fr}.form-group-row.four-cols{grid-template-columns:1fr 1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.85rem;color:var(--text-muted)}.glass-input-sm,.glass-select,.glass-input-xs{background:#0003;border:1px solid var(--glass-border);border-radius:8px;padding:.6rem .8rem;color:#fff;font-family:inherit;font-size:.95rem;outline:none;transition:all .2s;width:100%}.glass-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .8rem center;background-size:1rem;padding-right:2.5rem}.glass-select option{background:#1e293b;color:#fff}.glass-input-sm:focus,.glass-select:focus,.glass-input-xs:focus{border-color:hsl(var(--color-primary));background:#0000004d}.glass-input-xs{width:80px;padding:.4rem .6rem;display:inline-block}.radio-group{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}.radio-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;background:#ffffff0d;padding:.5rem 1rem;border-radius:99px;border:1px solid transparent;transition:all .2s}.radio-item:hover{background:#ffffff1a}.radio-item input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:2px solid var(--text-muted);border-radius:50%;position:relative;outline:none;margin:0}.radio-item input[type=radio]:checked{border-color:hsl(var(--color-primary))}.radio-item input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:hsl(var(--color-primary));border-radius:50%}.radio-item:has(input:checked){background:rgba(var(--color-primary),.15);border-color:rgba(var(--color-primary),.3)}.radio-label{font-size:.95rem;color:#fff}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.8rem;background:#0003;padding:1rem;border-radius:8px;border:1px solid var(--glass-border);max-height:200px;overflow-y:auto}.checkbox-group-row{display:flex;flex-wrap:wrap;gap:1.5rem;padding:.5rem 0}.checkbox-item{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-item input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:1px solid var(--text-muted);border-radius:3px;position:relative;background:#ffffff0d}.checkbox-item input[type=checkbox]:checked{background:hsl(var(--color-primary));border-color:hsl(var(--color-primary))}.checkbox-item input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;color:#000;font-weight:700}@media (max-width: 768px){.form-group-row,.form-group-row.three-cols,.form-group-row.four-cols{grid-template-columns:1fr;gap:.8rem}.radio-group{flex-direction:column;align-items:flex-start;gap:.8rem}}.ingredient-chips{display:flex;flex-wrap:wrap;gap:.5rem}.ingredient-chip{display:inline-block;padding:.3rem .7rem;font-size:.85rem;background:#ffffff14;border:1px solid var(--glass-border);border-radius:99px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.ingredient-chip:hover{background:#ffffff26;border-color:#ffffff4d;color:#fff}.ingredient-chip.selected{background:hsl(var(--color-primary));border-color:hsl(var(--color-primary));color:#0f172a;font-weight:500}.active-pref-tag{display:flex;align-items:center;gap:.5rem;padding:.5rem .8rem;background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));border-radius:99px;animation:fadeInUp .3s ease}.active-pref-tag .pref-name{font-size:.9rem;font-weight:600;color:#0f172a;white-space:nowrap}.active-pref-tag .pref-clear-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#0003;border:none;cursor:pointer;color:#0f172a;padding:0;transition:all .2s}.active-pref-tag .pref-clear-btn:hover{background:#0006}.action-hint{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:99px;color:#10b981;font-size:.85rem;font-weight:500;animation:pulse-hint 2s ease-in-out infinite}.action-hint svg{flex-shrink:0}@keyframes pulse-hint{0%,to{opacity:1}50%{opacity:.6}}.pref-modal{max-width:700px;max-height:90vh;display:flex;flex-direction:column}.pref-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.pref-title-group{display:flex;align-items:center;gap:.5rem}.pref-title-group h2{margin:0;font-size:1.2rem}.pref-name-display{font-size:.9rem;color:var(--text-muted)}.pref-name-display:not(:empty):before{content:"|";margin-right:.5rem}.pref-header-right{display:flex;align-items:center;gap:.5rem}.glass-select-sm{padding:.4rem 2rem .4rem .8rem;font-size:.85rem;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;color:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.glass-select-sm option,.glass-select option{background:#1e293b;color:#fff;padding:.5rem}.btn.icon-only{padding:.4rem .6rem;font-size:1rem;background:transparent;border:none}.chip-grid{display:flex;flex-wrap:wrap;gap:.5rem}.chip-grid label,.chip-item{display:inline-flex;align-items:center;padding:.4rem .8rem;background:#ffffff14;border:1px solid var(--glass-border);border-radius:99px;cursor:pointer;transition:all .2s;font-size:.85rem}.chip-grid label:hover,.chip-item:hover{background:#ffffff26}.chip-grid input[type=checkbox],.chip-item input[type=checkbox]{display:none}.chip-grid input[type=checkbox]:checked+span,.chip-item input[type=checkbox]:checked+span,.chip-grid label:has(input:checked),.chip-item:has(input:checked){background:hsl(var(--color-primary));border-color:hsl(var(--color-primary));color:#0f172a}.number-stepper-row{display:flex;gap:2rem}.number-stepper{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.number-stepper label{font-size:.85rem;color:var(--text-muted)}.stepper-controls{display:flex;align-items:center;gap:0;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;overflow:hidden}.stepper-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:600;background:transparent;border:none;color:#fff;cursor:pointer;transition:background .2s}.stepper-btn:hover{background:#ffffff1a}.stepper-input{width:50px;text-align:center;font-size:1.1rem;font-weight:600;background:transparent;border:none;border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);color:#fff;padding:.5rem 0}.stepper-input::-webkit-inner-spin-button,.stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ingredient-prefs-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.ingredient-pref-col{display:flex;flex-direction:column;gap:.5rem}.ingredient-label{font-size:.9rem;font-weight:500}.likes-label{color:#10b981}.dislikes-label{color:#ef4444}.quick-select-label{font-size:.8rem;color:var(--text-muted);margin-top:.5rem}.more-options-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem;margin:1rem 0;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:99px;cursor:pointer;transition:all .2s;font-size:.9rem;color:var(--text-muted)}.more-options-toggle:hover{background:#ffffff1a;color:#fff}.more-options-toggle .toggle-arrow{transition:transform .3s}.more-options-toggle.expanded .toggle-arrow{transform:rotate(180deg)}.more-options-content{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.filter-item{display:flex;flex-direction:column;gap:.5rem}.filter-item label{font-size:.85rem;color:var(--text-muted)}.duration-options{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.duration-option{display:inline-flex;align-items:center;cursor:pointer}.duration-option input[type=radio]{display:none}.duration-label{padding:.4rem .8rem;background:#ffffff14;border:1px solid var(--glass-border);border-radius:99px;font-size:.85rem;transition:all .2s}.duration-option:hover .duration-label{background:#ffffff26}.duration-option input[type=radio]:checked+.duration-label{background:hsl(var(--color-primary));border-color:hsl(var(--color-primary));color:#0f172a;font-weight:500}.duration-hint{font-size:.85rem;color:var(--text-muted);margin-top:.8rem}.pref-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--glass-border);gap:1rem}.pref-name-input-group{display:flex;align-items:center;gap:.5rem;flex:1;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:8px;padding:.5rem 1rem;max-width:250px}.pref-icon{font-size:1rem}.pref-name-input{flex:1;background:transparent;border:none;color:#fff;font-size:.95rem;outline:none}.pref-name-input::placeholder{color:var(--text-muted)}.pref-actions{display:flex;gap:.75rem}.pref-actions .btn{display:flex;align-items:center;gap:.4rem}@media (max-width: 768px){.pref-modal{max-width:95vw}.pref-header{flex-direction:column;gap:.75rem;align-items:flex-start}.pref-header-right{flex-wrap:wrap}.number-stepper-row{flex-wrap:wrap;gap:1rem}.ingredient-prefs-row,.filter-row{grid-template-columns:1fr}.pref-footer{flex-direction:column;gap:1rem}.pref-name-input-group{max-width:100%;width:100%}.pref-actions{width:100%;justify-content:stretch}.pref-actions .btn{flex:1}}.btn.secondary.highlight{background:#f59e0b33;border-color:#f59e0b;color:#fbbf24;animation:pulse-save 1.5s ease-in-out infinite}@keyframes pulse-save{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 6px #f59e0b00}}.quick-tags-container{flex-shrink:0;margin-left:auto}.quick-tags-scroll{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:.25rem 0}.quick-tags-scroll::-webkit-scrollbar{display:none}.quick-tag-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem 1rem;background:#ffffff14;border:1px solid var(--glass-border);border-radius:99px;color:var(--text-muted);font-size:.85rem;font-family:inherit;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .3s ease}.quick-tag-btn:hover{background:#ffffff26;border-color:#ffffff4d;color:#fff;transform:translateY(-2px)}.quick-tag-btn.active{background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));border-color:transparent;color:#0f172a;font-weight:600;box-shadow:0 4px 15px rgba(var(--color-primary),.3)}.quick-tag-btn.active:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--color-primary),.4)}@media (max-width: 900px){.header-controls-row{flex-wrap:wrap}.quick-tags-container{width:100%;order:10;margin-top:.5rem}.search-wrapper{order:5}}@media (max-width: 600px){.header-title-row{flex-direction:column;align-items:flex-start;gap:.2rem}.header-controls-row{flex-direction:column;align-items:stretch;gap:.8rem}.search-wrapper,.search-box,.quick-tags-container{width:100%}.quick-tags-scroll{gap:.4rem}.quick-tag-btn{padding:.4rem .8rem;font-size:.8rem}}.ingredient-label-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.3rem}.mode-toggle-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:#ffffff14;border:1px solid var(--glass-border);border-radius:99px;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.mode-toggle-btn:hover{background:#ffffff1f;color:var(--text-main)}.mode-toggle-btn .toggle-icon{transition:transform .2s ease}.mode-toggle-btn[data-mode=require]{background:linear-gradient(135deg,hsl(var(--color-primary)),hsl(var(--color-secondary)));border-color:transparent;color:#0f172a;font-weight:600}.mode-toggle-btn[data-mode=require] .toggle-icon{transform:rotate(90deg)}
