.app{width:100%}.header{text-align:center;background:#fff;border-radius:20px;margin-bottom:30px;padding:30px;position:relative;box-shadow:0 10px 30px #0003}.lang-toggle{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:20px;padding:10px 20px;font-size:1em;font-weight:700;transition:all .3s;position:absolute;top:20px;right:20px;box-shadow:0 3px 10px #667eea4d}.lang-toggle:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea80}[dir=ltr] .lang-toggle{left:20px;right:auto}.title{color:#667eea;flex-wrap:wrap;justify-content:center;align-items:center;gap:15px;margin-bottom:10px;font-size:2.5em;display:flex}.emoji{font-size:1.2em}.subtitle{color:#666;font-size:1.1em}.search-container{margin-bottom:20px}.search-input{border:3px solid #fff;border-radius:15px;outline:none;width:100%;padding:15px 20px;font-size:1.1em;transition:all .3s;box-shadow:0 5px 15px #0000001a}.search-input:focus{border-color:#667eea;box-shadow:0 5px 20px #667eea4d}.categories-container{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:20px;display:flex}.category-btn{cursor:pointer;color:#666;background:#fff;border:2px solid #e0e0e0;border-radius:25px;padding:10px 20px;font-size:1em;font-weight:500;transition:all .3s}.category-btn:hover{color:#667eea;border-color:#667eea;transform:translateY(-2px)}.category-btn.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#0000;box-shadow:0 5px 15px #667eea4d}.recipe-count{color:#667eea;background:#fff;border-radius:20px;margin-bottom:20px;padding:10px 20px;font-weight:700;display:inline-block;box-shadow:0 3px 10px #0000001a}.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px;margin-bottom:30px;display:grid}.recipe-card{cursor:pointer;background:#fff;border-radius:15px;padding:25px;transition:all .3s;box-shadow:0 5px 15px #0000001a}.recipe-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003}.recipe-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:15px;display:flex}.edit-category-btn{cursor:pointer;background:#f0f4ff;border:2px solid #667eea;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:35px;height:35px;font-size:1.2em;transition:all .2s;display:flex}.edit-category-btn:hover{background:#667eea;transform:scale(1.1)}.recipe-categories{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.recipe-category-badge{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;padding:4px 12px;font-size:.75em;font-weight:700;display:inline-block}.recipe-name{color:#333;margin:0;font-size:1.4em}.recipe-source-link{color:#667eea;white-space:nowrap;background:#f0f4ff;border-radius:15px;margin-top:8px;padding:5px 12px;font-size:.85em;text-decoration:none;transition:all .2s;display:inline-block}.recipe-source-link:hover{color:#fff;background:#667eea}.recipe-meta{color:#666;gap:15px;margin-bottom:10px;font-size:.95em;display:flex}.recipe-date{color:#999;font-size:.85em}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{background:#fff;border-radius:20px;width:100%;max-width:700px;max-height:90vh;padding:40px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0006}.modal-close{cursor:pointer;background:#f0f0f0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5em;transition:all .2s;display:flex;position:absolute;top:15px;left:15px}.modal-close:hover{background:#e0e0e0;transform:rotate(90deg)}.modal-title{color:#667eea;margin-bottom:15px;padding-left:50px;font-size:2em}.modal-source-link{color:#667eea;background:#f0f4ff;border-radius:20px;margin-bottom:20px;padding:8px 16px;font-size:.95em;text-decoration:none;transition:all .2s;display:inline-block}.modal-source-link:hover{color:#fff;background:#667eea}.modal-meta{color:#666;gap:20px;margin-bottom:30px;font-size:1em;display:flex}.modal-section{margin-bottom:30px}.section-title{color:#333;align-items:center;gap:8px;margin-bottom:15px;font-size:1.3em;display:flex}.ingredients-list,.notes-list{padding:0;list-style:none}.ingredients-list li,.notes-list li{background:#f8f9fa;border-right:4px solid #667eea;border-radius:10px;margin-bottom:8px;padding:10px 15px}.instructions-list{padding-right:25px}.instructions-list li{border-bottom:1px solid #eee;margin-bottom:10px;padding:12px 0;line-height:1.6}.instructions-list li:last-child{border-bottom:none}.empty-state{text-align:center;background:#fff;border-radius:20px;padding:60px 20px}.empty-emoji{margin-bottom:15px;font-size:4em}.empty-text{color:#666;font-size:1.2em}.loading-container{color:#fff;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:50vh;display:flex}.loading-spinner{border:5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.edit-modal-content{background:#fff;border-radius:20px;width:100%;max-width:500px;padding:30px;position:relative;box-shadow:0 20px 60px #0006}.edit-modal-title{color:#667eea;margin-bottom:10px;padding-right:40px;font-size:1.5em}.edit-modal-recipe-name{color:#666;background:#f8f9fa;border-radius:10px;margin-bottom:25px;padding:10px;font-size:1.1em}.category-options{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.category-option-btn{cursor:pointer;color:#666;background:#fff;border:2px solid #e0e0e0;border-radius:20px;padding:10px 20px;font-size:1em;transition:all .2s}.category-option-btn:hover{color:#667eea;border-color:#667eea;transform:translateY(-2px)}.category-option-btn.selected{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#0000;font-weight:700}.category-option-btn.new-category-btn{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;font-weight:700}.category-option-btn.new-category-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.new-category-input-container{flex-direction:column;gap:10px;margin-top:15px;display:flex}.new-category-inputs{flex-direction:column;gap:10px;display:flex}.new-category-input{border:2px solid #667eea;border-radius:15px;outline:none;flex:1;padding:12px 18px;font-size:1em;transition:all .3s}.new-category-input:focus{border-color:#764ba2;box-shadow:0 3px 10px #667eea33}.save-new-category-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#51cf66 0%,#2f9e44 100%);border:none;border-radius:15px;padding:12px 25px;font-size:1em;font-weight:700;transition:all .3s}.save-new-category-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #51cf664d}.save-new-category-btn:disabled{opacity:.5;cursor:not-allowed}.edit-modal-hint{color:#666;text-align:center;margin-bottom:15px;font-size:.9em;font-style:italic}.done-editing-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:15px;width:100%;margin-top:20px;padding:15px;font-size:1.1em;font-weight:700;transition:all .3s}.done-editing-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@media (width<=768px){.title{font-size:1.8em}.recipes-grid{grid-template-columns:1fr}.modal-content{padding:25px}.modal-title{padding-left:40px;font-size:1.5em}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{max-width:1200px;margin:0 auto}
