*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #faf6f0;--cream-dark: #f2ebe0;--brown: #2c1a0e;--brown-mid: #6b4226;--terra: oklch(55% .12 40);--terra-light: oklch(88% .07 40);--terra-dark: oklch(42% .12 40);--warm-gray: #9b8b7e;--border: #e0d4c5;--shadow-sm: 0 2px 8px rgba(44,26,14,.08);--shadow-md: 0 4px 20px rgba(44,26,14,.12);--shadow-lg: 0 8px 40px rgba(44,26,14,.18);--radius: 16px;--radius-sm: 10px}html,body,#root{height:100%;background:var(--cream);color:var(--brown);font-family:Lato,sans-serif;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.font-serif{font-family:Playfair Display,serif}.font-hand{font-family:Caveat,cursive}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.anim-fade-up{animation:fadeUp .35s ease both}.anim-fade-in{animation:fadeIn .25s ease both}.app-shell{display:flex;flex-direction:column;min-height:100vh}.top-nav{position:sticky;top:0;z-index:100;background:var(--cream);border-bottom:1px solid var(--border);padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.nav-logo{font-family:Caveat,cursive;font-size:28px;font-weight:700;color:var(--terra);letter-spacing:-.5px;flex-shrink:0;cursor:pointer;background:none;border:none;padding:0}.nav-logo span{color:var(--brown)}.nav-search{flex:1;max-width:420px;position:relative}.nav-search input{width:100%;background:var(--cream-dark);border:1.5px solid transparent;border-radius:24px;padding:9px 16px 9px 40px;font-family:Lato,sans-serif;font-size:16px;color:var(--brown);transition:all .2s;outline:none}.nav-search input:focus{border-color:var(--terra);background:#fff}.nav-search input::placeholder{color:var(--warm-gray)}.nav-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--warm-gray);pointer-events:none}.nav-actions{display:flex;gap:8px;align-items:center}.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:24px;border:none;cursor:pointer;font-family:Lato,sans-serif;font-size:14px;font-weight:700;transition:all .2s}.nav-btn-primary{background:var(--terra);color:#fff}.nav-btn-primary:hover{background:var(--terra-dark);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.nav-btn-ghost{background:transparent;color:var(--brown-mid);border:1.5px solid var(--border)}.nav-btn-ghost:hover{background:var(--cream-dark);border-color:var(--terra-light)}.nav-btn-ghost.active{background:var(--terra-light);border-color:var(--terra);color:var(--terra-dark)}.nav-user-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--cream-dark);color:var(--brown-mid);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0}.nav-user-btn:hover{background:var(--terra-light);border-color:var(--terra);color:var(--terra-dark)}.nav-search-toggle{display:none;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--cream-dark);color:var(--brown-mid);align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0}.nav-search-toggle:hover{background:var(--terra-light);border-color:var(--terra);color:var(--terra-dark)}.nav-cookbook-switcher{position:relative;flex-shrink:0}.nav-cookbook-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;border:1.5px solid var(--border);background:var(--cream-dark);color:var(--brown-mid);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;white-space:nowrap;max-width:180px}.nav-cookbook-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-cookbook-btn:hover,.nav-cookbook-btn.active{background:var(--terra-light);border-color:var(--terra);color:var(--terra-dark)}.nav-cookbook-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:180px;background:#fff;border:1.5px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md, 0 4px 16px rgba(0,0,0,.12));overflow:hidden;z-index:200}.nav-cookbook-option{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:none;border:none;text-align:left;font-size:14px;color:var(--brown-mid);cursor:pointer;transition:background .15s}.nav-cookbook-option:hover{background:var(--cream-dark)}.nav-cookbook-option.current{color:var(--terra-dark);font-weight:600}.nav-cookbook-option svg{flex-shrink:0;color:var(--terra)}.main-content{flex:1;padding:32px 24px 80px;max-width:1280px;margin:0 auto;width:100%}.page-header{margin-bottom:28px}.page-title{font-family:Playfair Display,serif;font-size:clamp(28px,4vw,40px);font-weight:700;color:var(--brown);line-height:1.2}.page-subtitle{font-family:Caveat,cursive;font-size:18px;color:var(--terra);margin-top:4px}.filter-bar{display:flex;gap:10px;margin-bottom:24px;align-items:center;overflow:hidden}.filter-categories{display:flex;gap:10px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;align-items:center}.filter-categories::-webkit-scrollbar{display:none}.filter-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.filter-chip{height:36px;padding:0 16px;border-radius:24px;border:1.5px solid var(--border);background:#fff;color:var(--brown-mid);font-family:Lato,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s;white-space:nowrap;display:inline-flex;align-items:center;-moz-appearance:none;appearance:none;-webkit-appearance:none;box-sizing:border-box}.filter-chip:hover{border-color:var(--terra-light);background:var(--terra-light);color:var(--terra-dark)}.filter-chip.active{background:var(--terra);border-color:var(--terra);color:#fff}.layout-toggle{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:#fff;color:var(--warm-gray);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0}.layout-toggle:hover{background:var(--cream-dark);color:var(--terra);border-color:var(--terra-light)}.grid-big{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}@media(max-width:560px){.grid-big{grid-template-columns:1fr}}.grid-list{display:flex;flex-direction:column;gap:12px}.recipe-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:all .22s;box-shadow:var(--shadow-sm);touch-action:manipulation}@media(hover:hover){.recipe-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--terra-light)}}.card-img{width:100%;aspect-ratio:4/3;background:var(--cream-dark);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.card-img-big{aspect-ratio:16/10}.card-img img{width:100%;height:100%;object-fit:cover}.card-img-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--warm-gray)}.card-img-placeholder svg{opacity:.4}.card-img-placeholder span{font-family:Caveat,cursive;font-size:13px}.card-fav{position:absolute;top:10px;right:10px;background:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .18s;color:var(--terra);font-size:16px;opacity:0}.card-fav.is-fav{opacity:1}@media(hover:hover){.recipe-card:hover .card-fav{opacity:1}.card-fav:hover{transform:scale(1.15)}}.card-body{padding:16px}.card-category{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--terra);margin-bottom:6px}.card-title{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--brown);line-height:1.3;margin-bottom:8px}.card-desc{font-size:13px;color:var(--warm-gray);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;gap:12px;font-size:12px;color:var(--warm-gray);align-items:center}.card-meta svg{flex-shrink:0}.card-rating{color:var(--terra);font-size:12px;margin-left:auto}.card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.card-tag{background:var(--cream-dark);color:var(--brown-mid);font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px}.recipe-card-list{display:flex;align-items:center;gap:16px;padding:14px 16px}.recipe-card-list .card-img{width:72px;height:72px;border-radius:var(--radius-sm);flex-shrink:0;aspect-ratio:1}.recipe-card-list .card-body{padding:0;flex:1;min-width:0}.recipe-card-list .card-title{font-size:16px;margin-bottom:4px}.recipe-card-list .card-desc{margin-bottom:6px;-webkit-line-clamp:1}.detail-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--brown-mid);font-family:Lato,sans-serif;font-size:14px;font-weight:700;cursor:pointer;margin-bottom:24px;padding:0;transition:color .15s}.detail-back:hover{color:var(--terra)}.detail-hero{border-radius:var(--radius);overflow:hidden;margin-bottom:32px;background:var(--cream-dark)}.detail-hero-img{width:100%;max-height:420px;object-fit:cover;display:block}.detail-hero-placeholder{height:280px;display:flex;align-items:center;justify-content:center;color:var(--warm-gray);flex-direction:column;gap:12px}.detail-hero-placeholder span{font-family:Caveat,cursive;font-size:16px}.detail-header{margin-bottom:24px}.detail-category{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--terra);margin-bottom:8px}.detail-title{font-family:Playfair Display,serif;font-size:clamp(26px,4vw,40px);font-weight:700;color:var(--brown);line-height:1.2;margin-bottom:12px}.detail-desc{font-size:16px;color:var(--brown-mid);line-height:1.6;margin-bottom:16px}.detail-meta{display:flex;flex-wrap:wrap;gap:20px;font-size:14px;color:var(--warm-gray);padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:24px}.detail-meta-item{display:flex;align-items:center;gap:6px}.detail-rating{color:var(--terra)}.detail-actions{display:flex;gap:10px;margin-bottom:32px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:24px;border:none;cursor:pointer;font-family:Lato,sans-serif;font-size:14px;font-weight:700;transition:all .18s}.btn-primary{background:var(--terra);color:#fff}.btn-primary:hover{background:var(--terra-dark);transform:translateY(-1px)}.btn-secondary{background:var(--cream-dark);color:var(--brown-mid)}.btn-secondary:hover{background:var(--border)}.btn-ghost{background:transparent;color:var(--brown-mid);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--cream-dark)}.btn-icon{width:40px;height:40px;padding:0;justify-content:center}.btn-danger{background:#fee2e2;color:#991b1b}.btn-danger:hover{background:#fca5a5}.btn-cooked{background:#dcfce7;color:#166534}.btn-cooked:hover{background:#bbf7d0}.detail-section{margin-bottom:36px}.detail-section-title{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:var(--brown);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--terra-light)}.portion-calc{display:flex;align-items:center;gap:12px;background:var(--cream-dark);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:20px;width:fit-content}.portion-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:#fff;color:var(--brown-mid);font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.portion-btn:hover{border-color:var(--terra);color:var(--terra)}.portion-count{font-family:Caveat,cursive;font-size:22px;font-weight:700;color:var(--brown);min-width:28px;text-align:center}.portion-label{font-size:14px;color:var(--warm-gray)}.ingredient-list{list-style:none}.ingredient-group-header{font-family:Caveat,cursive;font-size:18px;font-weight:700;color:var(--terra);padding:8px 0 4px;margin-top:12px;border-bottom:1px dashed var(--terra-light);margin-bottom:4px}.ingredient-row{display:flex;align-items:baseline;gap:8px;padding:8px 0;border-bottom:1px solid var(--cream-dark);font-size:15px}.ingredient-row:last-child{border-bottom:none}.ingredient-amount{font-weight:700;color:var(--brown);min-width:48px}.ingredient-amount--unscalable{color:var(--terra-dark);background:#fee2e2;border-radius:4px;padding:0 4px}.ingredient-unit{color:var(--warm-gray);min-width:32px;font-size:13px}.ingredient-name{color:var(--brown)}.steps-list{list-style:none;display:flex;flex-direction:column;gap:16px}.step-item{display:flex;gap:16px;align-items:flex-start}.step-number{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Playfair Display,serif;font-size:15px;font-weight:700}.step-text{font-size:15px;line-height:1.6;color:var(--brown);padding-top:5px}.detail-source{background:var(--cream-dark);border-radius:var(--radius-sm);padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:14px;color:var(--brown-mid)}.detail-source a{color:var(--terra);font-weight:700;text-decoration:none}.detail-source a:hover{text-decoration:underline}.detail-notes{background:var(--terra-light);border-radius:var(--radius-sm);padding:16px 20px;font-family:Caveat,cursive;font-size:18px;color:var(--brown);line-height:1.5;border-left:3px solid var(--terra)}.form-header{margin-bottom:32px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:6px}.form-group-full{grid-column:1 / -1}.form-label{font-size:13px;font-weight:700;color:var(--brown-mid);text-transform:uppercase;letter-spacing:.5px}.form-input,.form-textarea,.form-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-family:Lato,sans-serif;font-size:16px;color:var(--brown);background:#fff;outline:none;transition:border-color .18s;width:100%}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--terra)}.form-textarea{resize:vertical;min-height:80px}.import-bar{display:flex;gap:10px;margin-bottom:32px;padding:16px;background:var(--cream-dark);border-radius:var(--radius-sm)}.import-bar input{flex:1}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-title-sm{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--brown)}.ingredient-editor{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.ingredient-editor-row{display:flex;gap:8px;align-items:center}.ingredient-editor-row .form-input{flex:1}.ingredient-editor-row .form-input:first-child{max-width:80px}.ingredient-editor-row .form-input:nth-child(2){max-width:80px}.ingredient-editor-row .ingredient-group-input{background:var(--terra-light);border-color:var(--terra-light);font-family:Caveat,cursive;font-size:17px;max-width:none;flex:1}.drag-handle{width:28px;height:34px;flex-shrink:0;border-radius:var(--radius-sm);border:1.5px solid transparent;background:transparent;color:var(--warm-gray);cursor:grab;display:flex;align-items:center;justify-content:center;touch-action:none}.drag-handle:active{cursor:grabbing}.drop-indicator{height:3px;border-radius:2px;background:var(--terra);margin:-4px 0}.ingredient-editor-row.is-dragging{opacity:.35}.icon-btn{width:34px;height:34px;flex-shrink:0;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:#fff;color:var(--warm-gray);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{border-color:#fca5a5;color:#ef4444;background:#fee2e2}.icon-btn-add{border-color:var(--terra-light);color:var(--terra);background:var(--terra-light)}.icon-btn-add:hover{background:var(--terra);color:#fff;border-color:var(--terra)}.steps-editor{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.step-editor-row{display:flex;gap:10px;align-items:flex-start}.step-num-badge{width:28px;height:28px;flex-shrink:0;border-radius:50%;background:var(--terra-light);color:var(--terra-dark);display:flex;align-items:center;justify-content:center;font-family:Playfair Display,serif;font-size:13px;font-weight:700;margin-top:6px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;flex-wrap:wrap}.planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:32px}@media(max-width:900px){.planner-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:560px){.planner-grid{grid-template-columns:repeat(2,1fr)}}.planner-day{background:#fff;border-radius:var(--radius);border:1.5px solid var(--border);padding:10px;min-height:100px;display:flex;flex-direction:column;gap:6px;transition:border-color .18s}.planner-day.today{border-color:var(--terra);background:#ffeee7;background:oklch(96% .04 40)}.planner-day-header{display:flex;align-items:baseline;gap:5px}.planner-day-name{font-family:Caveat,cursive;font-size:16px;font-weight:700;color:var(--terra)}.planner-day-date{font-size:11px;color:var(--warm-gray)}.planner-recipe-chip{display:flex;align-items:center;justify-content:space-between;background:var(--cream-dark);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;color:var(--brown);gap:6px;cursor:pointer;transition:background .15s}.planner-recipe-chip:hover{background:var(--border)}.planner-recipe-chip span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}@media(max-width:560px){.planner-recipe-chip{align-items:flex-start}.planner-recipe-chip span{white-space:normal;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}}.planner-add-btn{display:flex;align-items:center;gap:4px;background:none;border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;color:var(--warm-gray);cursor:pointer;transition:all .15s;width:100%}.planner-add-btn:hover{border-color:var(--terra);color:var(--terra);background:var(--terra-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c1a0e66;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s ease}.modal{background:var(--cream);border-radius:var(--radius);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden}.modal-header{padding:20px 20px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:Playfair Display,serif;font-size:20px;font-weight:700;color:var(--brown)}.modal-close{background:none;border:none;cursor:pointer;color:var(--warm-gray);padding:4px}.modal-search{padding:12px 20px;border-bottom:1px solid var(--border)}.search-input{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px;font-family:Lato,sans-serif;font-size:15px;color:var(--brown);background:#fff;outline:none;transition:border-color .18s}.search-input:focus{border-color:var(--terra)}.search-input::placeholder{color:var(--warm-gray)}.modal-list{overflow-y:auto;flex:1}.modal-recipe-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--cream-dark)}.modal-recipe-item:hover{background:var(--cream-dark)}.modal-recipe-item-title{font-weight:700;font-size:14px;color:var(--brown)}.modal-recipe-item-meta{font-size:12px;color:var(--warm-gray)}.grocery-list{display:flex;flex-direction:column;gap:20px}.grocery-category-name{font-family:Caveat,cursive;font-size:20px;font-weight:700;color:var(--terra);margin-bottom:8px}.grocery-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--cream-dark);font-size:15px;cursor:pointer;transition:opacity .18s}.grocery-item.checked{opacity:.45;text-decoration:line-through}.grocery-checkbox{width:20px;height:20px;border-radius:6px;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}.grocery-item.checked .grocery-checkbox{background:var(--terra);border-color:var(--terra);color:#fff}.grocery-amount{font-weight:700;color:var(--brown);min-width:60px}.grocery-name{color:var(--brown);flex:1}.planner-tabs{display:flex;gap:4px;margin-bottom:24px}.planner-tab{padding:8px 20px;border-radius:24px;border:1.5px solid var(--border);background:#fff;color:var(--brown-mid);font-family:Lato,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .18s}.planner-tab.active{background:var(--terra);border-color:var(--terra);color:#fff}.settings-tabs{display:flex;gap:4px;margin-bottom:0;border-bottom:2px solid var(--border);padding-bottom:0}.settings-tab{padding:10px 18px;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:transparent;color:var(--warm-gray);font-family:Lato,sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:color .18s,border-color .18s;border-radius:0;white-space:nowrap}.settings-tab:hover{color:var(--brown-mid)}.settings-tab.active{color:var(--terra-dark);border-bottom-color:var(--terra)}.settings-panel{background:#fff;border:1.5px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);padding:28px 24px}.settings-card{background:var(--cream);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:16px}.settings-list-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--cream);border:1.5px solid var(--border);border-radius:var(--radius-sm)}.settings-add-row{display:flex;gap:8px;flex-wrap:wrap}.settings-info-row{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--cream);border:1.5px solid var(--border);border-radius:var(--radius-sm)}.settings-info-label{font-size:13px;color:var(--warm-gray);font-weight:700;text-transform:uppercase;letter-spacing:.4px}.settings-info-value{font-size:14px;color:var(--brown);font-weight:700;display:flex;align-items:center;gap:8px}.settings-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;background:var(--terra-light);color:var(--terra-dark);padding:2px 7px;border-radius:10px}.settings-subtab{padding:6px 16px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--brown-mid);font-family:Lato,sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .18s}.settings-subtab:hover{background:var(--cream);border-color:var(--terra-light);color:var(--terra-dark)}.settings-subtab.active{background:var(--terra);border-color:var(--terra);color:#fff}.page-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--warm-gray);font-size:15px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--terra);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}.empty-state{text-align:center;padding:60px 24px;color:var(--warm-gray)}.empty-state svg{opacity:.3;margin-bottom:16px}.empty-state h3{font-family:Playfair Display,serif;font-size:22px;color:var(--brown);margin-bottom:8px}.empty-state p{font-size:14px}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--brown);color:#fff;padding:10px 20px;border-radius:24px;font-size:14px;font-weight:700;box-shadow:var(--shadow-md);animation:fadeUp .25s ease both;pointer-events:all}.toast-success{background:#166534}.toast-error{background:#991b1b}.tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom));background:var(--cream);border-top:1px solid var(--border);z-index:100;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom)}@media(max-width:640px){.tab-bar{display:flex}.top-nav{flex-wrap:wrap;height:auto;padding:8px 16px;gap:8px}.top-nav .nav-search{display:none;order:3;flex:0 0 100%;max-width:100%}.top-nav.search-open .nav-search{display:block}.top-nav .nav-actions .nav-btn{display:none}.nav-search-toggle{display:flex}.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.nav-search input{font-size:16px}.nav-cookbook-btn{max-width:130px}.nav-cookbook-menu{left:auto;right:0}}.tab-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--warm-gray);font-family:Lato,sans-serif;font-size:11px;font-weight:700;padding:8px 16px;border-radius:var(--radius-sm);transition:color .15s;flex:1}.tab-btn.active{color:var(--terra)}.tab-btn-add{width:48px;height:48px;flex:none;border-radius:50%;background:var(--terra);color:#fff!important;box-shadow:var(--shadow-md);padding:0;display:flex;align-items:center;justify-content:center}.img-upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:all .18s;color:var(--warm-gray);background:var(--cream-dark)}.img-upload-area:hover,.img-upload-area.drag-over{border-color:var(--terra);background:var(--terra-light);color:var(--terra-dark)}.img-preview{position:relative;border-radius:var(--radius);overflow:hidden}.img-preview img{width:100%;max-height:240px;object-fit:cover;display:block}.img-preview-remove{position:absolute;top:8px;right:8px;background:#2c1a0e99;border:none;border-radius:50%;width:28px;height:28px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.img-preview-remove:hover{background:#991b1bcc}
