:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}*{box-sizing:border-box}:root{--primary-color: #d24400;--primary-dark: #a33500;--bg-color: #f5f5f5;--card-bg: #ffffff;--text-color: #333333;--text-muted: #666666;--border-color: #e0e0e0;--success-color: #4caf50;--warning-color: #ff9800;--error-color: #f44336;--sidebar-width: 350px}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-color);color:var(--text-color);line-height:1.5}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden;max-width:100vw}.app-header{background:var(--card-bg);border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.app-header h1{margin:0;font-size:1.5rem;color:var(--primary-color)}.app-nav{display:flex;gap:.5rem}.nav-btn{padding:.5rem 1rem;border:none;background:transparent;cursor:pointer;font-size:1rem;color:var(--text-muted);border-radius:4px;transition:all .2s}.nav-btn:hover{background:var(--bg-color)}.nav-btn.active{background:var(--primary-color);color:#fff}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.upload-container{max-width:600px;margin:2rem auto;padding:2rem}.upload-section{padding:1rem;border-bottom:1px solid var(--border-color)}.upload-zone{border:2px dashed var(--border-color);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--card-bg)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--primary-color);background:#fff5f0}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-text{color:var(--text-muted);margin:0}.progress-section{margin-top:1rem}.progress-bar{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);transition:width .3s}.progress-message{font-size:.875rem;color:var(--text-muted);margin-top:.5rem}.progress-message.success{color:#4caf50;font-weight:500}.success-message{margin-top:1rem;padding:.75rem;background:#e8f5e9;color:var(--success-color);border-radius:4px}.error-message{margin-top:1rem;padding:.75rem;background:#ffebee;color:var(--error-color);border-radius:4px}.global-error{position:fixed;top:60px;left:0;right:0;padding:.75rem 1rem;background:#ffebee;color:var(--error-color);text-align:center;z-index:100;border-bottom:1px solid var(--error-color)}.clear-btn{margin-top:1rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--error-color);color:var(--error-color);border-radius:4px;cursor:pointer;font-size:.875rem}.clear-btn:hover{background:var(--error-color);color:#fff}.recipes-layout{display:flex;flex:1;overflow:hidden}.recipes-sidebar{width:var(--sidebar-width);background:var(--card-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.recipe-main{flex:1;overflow-y:auto;padding:2rem}.mobile-back-btn{display:none}.recipe-list-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.recipe-list-empty{padding:2rem;text-align:center;color:var(--text-muted)}.search-filters{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.search-input,.category-select{padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem}.search-input:focus,.category-select:focus{outline:none;border-color:var(--primary-color)}.recipe-count{padding:.5rem 1rem;font-size:.75rem;color:var(--text-muted);background:var(--bg-color)}.recipe-list{flex:1;overflow-y:auto}.recipe-list-item{display:flex;gap:1rem;padding:1rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .2s}.recipe-list-item:hover{background:var(--bg-color)}.recipe-list-item.selected{background:#fff5f0;border-left:3px solid var(--primary-color)}.recipe-thumbnail{width:60px;height:60px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg-color)}.recipe-thumbnail img{width:100%;height:100%;object-fit:cover}.recipe-thumbnail .no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.recipe-info{flex:1;min-width:0}.recipe-name{margin:0 0 .25rem;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recipe-categories{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.25rem}.category-tag{font-size:.625rem;padding:.125rem .375rem;background:var(--bg-color);border-radius:2px;color:var(--text-muted)}.recipe-rating{font-size:.75rem;color:#ffc107}.recipe-detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.recipe-detail{max-width:800px;margin:0 auto}.recipe-header{display:flex;gap:2rem;margin-bottom:2rem}.recipe-main-image{width:250px;height:250px;object-fit:cover;border-radius:8px}.recipe-header-info h2{margin:0 0 1rem;color:var(--primary-color)}.recipe-meta{display:flex;flex-wrap:wrap;gap:1rem;margin:1rem 0;font-size:.875rem;color:var(--text-muted);align-items:center}.servings-input-inline{display:flex;align-items:center;gap:.5rem}.portions-field-small{width:60px;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem}.portions-field-small:focus{outline:none;border-color:var(--primary-color)}.recipe-source{font-size:.875rem;color:var(--text-muted)}.recipe-source a{color:var(--primary-color)}.recipe-content{display:grid;grid-template-columns:1fr 2fr;gap:2rem;margin-bottom:2rem}.recipe-ingredients h3,.recipe-directions h3,.recipe-notes h3{color:var(--primary-color);margin-top:0}.recipe-ingredients ul{padding-left:1.25rem;margin:0}.recipe-ingredients li{margin-bottom:.5rem}.directions-text p{margin:0 0 .5rem}.recipe-notes{grid-column:1 / -1;padding:1rem;background:var(--bg-color);border-radius:4px}.assessment-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-top:2rem}.assessment-section h3{margin-top:0;color:var(--primary-color)}.assess-prompt{text-align:center;padding:2rem}.assess-btn{padding:.75rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.assess-btn:hover:not(:disabled){background:var(--primary-dark)}.assess-btn:disabled{opacity:.5;cursor:not-allowed}.config-warning{font-size:.875rem;color:var(--warning-color);margin-top:1rem}.assessing-indicator{display:flex;flex-direction:column;align-items:center;padding:2rem;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.assessment-display{display:flex;flex-direction:column;gap:1.5rem}.scores-row{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.dietary-tooltip-container{position:relative;display:inline-flex;margin-left:.35rem}.dietary-tooltip-trigger{background:none;border:none;padding:0;font-size:.9rem;cursor:pointer;color:var(--text-muted);line-height:1;opacity:.7;transition:opacity .2s}.dietary-tooltip-trigger:hover{opacity:1}.dietary-tooltip-backdrop{position:fixed;inset:0;z-index:99}.dietary-tooltip-popover{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.75rem 1rem;z-index:100;min-width:150px;max-width:250px}.dietary-tooltip-arrow{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:12px;height:12px;background:var(--card-bg);border-left:1px solid var(--border-color);border-top:1px solid var(--border-color);transform:translate(-50%) rotate(45deg)}.dietary-tooltip-popover ul{margin:0;padding-left:1rem;font-size:.8rem;color:var(--text-color)}.dietary-tooltip-popover li{margin-bottom:.25rem}.dietary-tooltip-popover li:last-child{margin-bottom:0}.health-score{display:flex;flex-direction:column;align-items:center;gap:.5rem}.score-circle{width:80px;height:80px;border:4px solid;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-value{font-size:2rem;font-weight:700;line-height:1;color:var(--text-color)}.score-label{font-size:.75rem;color:var(--text-muted)}.score-text{font-weight:500}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.nutrient-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--bg-color);border-radius:8px}.nutrient-value{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.nutrient-unit{font-size:.75rem;color:var(--text-muted)}.nutrient-label{font-size:.875rem;margin-top:.25rem}.assessment-list h4{margin:0 0 .5rem}.assessment-list ul{margin:0;padding-left:1.25rem}.assessment-list li{margin-bottom:.25rem}.assessment-list.benefits h4{color:var(--success-color)}.assessment-list.warnings h4{color:var(--warning-color)}.assessment-timestamp{font-size:.75rem;color:var(--text-muted);text-align:right}.health-summary{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.health-summary p{margin:0;font-size:1rem;line-height:1.5;color:var(--text-color)}.score-circle.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s;background:var(--card-bg);color:inherit;font:inherit;padding:0}.score-circle.clickable:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.score-circle.clickable.active{transform:scale(1.05);box-shadow:0 0 0 3px #d244004d}.optimization-section{background:var(--bg-color);border-radius:8px;padding:1rem 1.25rem;margin-top:1rem;border-left:3px solid var(--primary-color)}.optimization-section h4{margin:0 0 .75rem;display:flex;justify-content:space-between;align-items:center;color:var(--primary-color);font-size:.95rem}.close-optimization{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.close-optimization:hover{color:var(--text-color)}.optimization-loading{display:flex;align-items:center;gap:.75rem;color:var(--text-muted);font-size:.875rem}.spinner.small{width:20px;height:20px;border-width:2px}.optimization-summary{margin:0 0 .75rem;font-size:.9rem;color:var(--text-color);font-style:italic}.optimization-suggestions{margin:0;padding-left:1.25rem}.optimization-suggestions li{margin-bottom:.5rem;font-size:.875rem;line-height:1.4}.optimization-suggestions li:last-child{margin-bottom:0}.reanalyze-btn{margin-bottom:1rem;padding:.5rem 1rem;background:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.875rem;color:var(--text-muted)}.reanalyze-btn:hover:not(:disabled){background:var(--border-color)}.reanalyze-btn:disabled{opacity:.5;cursor:not-allowed}.settings-container{max-width:600px;margin:0 auto;padding:2rem;overflow-y:auto;flex:1}.settings-container h2{color:var(--primary-color)}.settings-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.settings-section h3{margin-top:0}.settings-description{color:var(--text-muted);font-size:.875rem}.api-key-input{margin:1.5rem 0}.api-key-input label{display:block;margin-bottom:.5rem;font-weight:500}.input-group{display:flex;gap:.5rem}.api-key-field{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;font-family:monospace}.api-key-field:focus{outline:none;border-color:var(--primary-color)}.toggle-visibility{padding:.75rem;background:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer}.current-key{font-size:.75rem;color:var(--text-muted);margin-top:.5rem;font-family:monospace}.save-btn{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.save-btn:hover:not(:disabled){background:var(--primary-dark)}.save-btn:disabled{opacity:.5;cursor:not-allowed}.dietary-input,.system-prompt-input{margin:1.5rem 0}.dietary-input label,.system-prompt-input label{display:block;margin-bottom:.5rem;font-weight:500}.system-prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.system-prompt-header label{margin-bottom:0}.reset-btn{padding:.25rem .5rem;font-size:.75rem;background:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-muted)}.reset-btn:hover{background:var(--border-color)}.dietary-field,.system-prompt-field{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;font-family:inherit;resize:vertical}.dietary-field:focus,.system-prompt-field:focus{outline:none;border-color:var(--primary-color)}.settings-hint{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.api-help{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.api-help h4{margin-top:0;margin-bottom:1rem}.api-help ol,.api-help ul{padding-left:1.25rem;margin:.5rem 0}.api-help a{color:var(--primary-color)}.tutorial-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.tutorial-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.tutorial-section h5{margin:0 0 .5rem;color:var(--text-color);font-size:.95rem}.tutorial-section li{margin-bottom:.25rem}.tutorial-note{margin-top:.75rem;padding:.75rem;background:#e3f2fd;border-radius:4px;font-size:.875rem;color:#1565c0}.disclaimer{font-size:.875rem;color:var(--text-muted);background:var(--bg-color);padding:1rem;border-radius:4px}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-color)}.sidebar-tab{flex:1;padding:.75rem;border:none;background:var(--bg-color);cursor:pointer;font-size:.875rem;color:var(--text-muted);transition:all .2s}.sidebar-tab:hover{background:var(--card-bg)}.sidebar-tab.active{background:var(--card-bg);color:var(--primary-color);font-weight:500;border-bottom:2px solid var(--primary-color)}.ingredient-search{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:1rem}.ingredient-search h3{margin:0 0 1rem;color:var(--primary-color);font-size:1rem}.ingredient-search .search-input{width:100%;margin-bottom:1rem}.ingredient-list{flex:1;overflow-y:auto}.ingredient-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;border-radius:4px;transition:background .2s}.ingredient-item:hover{background:var(--bg-color)}.ingredient-item .ingredient-name{flex:1;font-size:.875rem;text-transform:capitalize}.ingredient-item .ingredient-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-color);padding:.125rem .5rem;border-radius:10px;min-width:24px;text-align:center}.ingredient-stats{padding-top:.75rem;margin-top:.75rem;border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted);text-align:center}.no-results{padding:2rem;text-align:center;color:var(--text-muted)}.ingredient-recipes{flex:1;display:flex;flex-direction:column;overflow:hidden}.back-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:.5rem 0;font-size:.875rem;text-align:left}.back-btn:hover{text-decoration:underline}.selected-ingredient-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-color);border-radius:4px;margin-bottom:.75rem}.selected-ingredient-header .ingredient-name{font-weight:500;text-transform:capitalize}.selected-ingredient-header .recipe-count{font-size:.75rem;color:var(--text-muted)}.ingredient-recipe-list{flex:1;overflow-y:auto}.ingredient-recipe-item{padding:.75rem;cursor:pointer;border-bottom:1px solid var(--border-color);font-size:.875rem;transition:background .2s}.ingredient-recipe-item:hover{background:var(--bg-color);color:var(--primary-color)}.paste-recipe{max-width:800px;margin:0 auto;padding:2rem;overflow-y:auto;flex:1}.paste-recipe-input{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.paste-recipe-input h3{margin-top:0;color:var(--primary-color)}.paste-description{color:var(--text-muted);font-size:.875rem;margin-bottom:1rem}.url-input-section{margin-bottom:1rem}.url-input-section label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem}.url-input-group{display:flex;gap:.5rem}.url-field{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem}.url-field:focus{outline:none;border-color:var(--primary-color)}.fetch-btn{padding:.75rem 1.25rem;background:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;white-space:nowrap}.fetch-btn:hover:not(:disabled){background:var(--primary-dark)}.fetch-btn:disabled{opacity:.5;cursor:not-allowed}.input-divider{display:flex;align-items:center;margin:1rem 0;color:var(--text-muted);font-size:.75rem}.input-divider:before,.input-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.input-divider span{padding:0 1rem}.image-upload-section{margin-bottom:1rem}.image-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;color:var(--text-muted)}.image-upload-zone.compact{flex-direction:row;padding:.75rem 1rem;gap:.5rem}.image-upload-zone:hover{border-color:var(--primary-color);background:#fff5f0}.image-upload-zone .upload-icon{font-size:2rem}.image-upload-zone.compact .upload-icon{font-size:1.25rem}.image-preview{position:relative;display:inline-block}.image-preview.compact{display:flex;align-items:center;gap:.75rem}.image-preview img{max-width:100%;max-height:300px;border-radius:8px;border:1px solid var(--border-color)}.image-preview.compact img{max-height:60px;max-width:80px}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;padding:.5rem 1rem;background:#000000b3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.75rem}.image-preview.compact .remove-image-btn{position:static;padding:.25rem .5rem;background:transparent;color:var(--text-muted);border:1px solid var(--border-color)}.remove-image-btn:hover{background:#000000e6}.image-preview.compact .remove-image-btn:hover{background:var(--bg-color);color:var(--primary-color);border-color:var(--primary-color)}.recipe-text-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;font-family:inherit}.recipe-text-input:focus{outline:none;border-color:var(--primary-color)}.action-row{display:flex;gap:1rem;align-items:center;margin-top:1rem}.portions-input-inline{flex:1;display:flex;align-items:center;gap:.5rem}.portions-input-inline label{font-size:.875rem;color:var(--text-muted);white-space:nowrap}.portions-field{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;width:80px}.portions-field:focus{outline:none;border-color:var(--primary-color)}.action-row .assess-btn{flex:1}.clear-btn-inline{padding:.75rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;cursor:pointer;color:var(--text-muted)}.clear-btn-inline:hover{background:var(--bg-color);border-color:var(--error-color);color:var(--error-color)}.clear-paste-btn{margin-top:.75rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;cursor:pointer;color:var(--text-muted)}.clear-paste-btn:hover{background:var(--bg-color);border-color:var(--text-muted)}.paste-assessment{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.paste-assessment h3{margin-top:0;color:var(--primary-color)}.parsed-recipe{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.parsed-recipe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.parsed-recipe-header h4{margin:0;color:var(--primary-color);font-size:1.1rem}.edit-recipe-btn{padding:.25rem .75rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;font-size:.75rem;cursor:pointer;color:var(--text-muted)}.edit-recipe-btn:hover{background:var(--bg-color);border-color:var(--primary-color);color:var(--primary-color)}.parsed-recipe-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--text-muted);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.parsed-recipe-meta span{display:flex;align-items:center;gap:.25rem}.parsed-recipe-ingredients,.parsed-recipe-instructions{margin-bottom:1rem}.parsed-recipe-ingredients h5,.parsed-recipe-instructions h5{margin:0 0 .5rem;font-size:.9rem;color:var(--text-color)}.parsed-recipe-ingredients ul{margin:0;padding-left:1.25rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.25rem}.parsed-recipe-ingredients li{font-size:.85rem;color:var(--text-muted);line-height:1.4}.parsed-recipe-instructions ol{margin:0;padding-left:1.25rem}.parsed-recipe-instructions li{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin-bottom:.5rem}.detected-dish{margin-bottom:1rem}.detected-dish h4{margin:0;font-size:1.25rem;color:var(--text-color)}.detected-ingredients{background:var(--bg-color);border-radius:6px;padding:1rem;margin-bottom:1.5rem}.detected-ingredients h5{margin:0 0 .75rem;font-size:.9rem;color:var(--text-color)}.detected-ingredients ul{margin:0;padding-left:1.25rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.25rem}.detected-ingredients li{font-size:.85rem;color:var(--text-muted);line-height:1.4}@media(max-width:768px){.app-header{padding:.75rem 1rem}.app-header h1{font-size:1.1rem}.nav-btn{padding:.4rem .75rem;font-size:.875rem}.paste-recipe{padding:1rem;overflow-x:hidden}.paste-recipe-input{padding:1rem;overflow:hidden}.url-input-group{flex-direction:column}.url-field,.fetch-btn{width:100%}.action-row{flex-wrap:wrap}.portions-input-inline{flex:1 1 100%;margin-bottom:.5rem}.action-row .assess-btn{flex:1 1 auto}.clear-btn-inline{flex:0 0 auto}.paste-assessment{padding:1rem;overflow:hidden}.detected-dish h4{word-wrap:break-word;overflow-wrap:break-word}.recipes-layout{flex-direction:column;height:calc(100vh - 60px)}.recipes-sidebar{width:100%;flex:1;min-height:0;max-height:none}.recipe-main,.recipes-layout.has-selection .recipes-sidebar{display:none}.recipes-layout.has-selection .recipe-main{display:block;flex:1;padding:1rem;overflow-y:auto}.mobile-back-btn{display:block;margin-bottom:1rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;cursor:pointer;color:var(--primary-color)}.recipes-sidebar .upload-section{display:none}.recipes-sidebar .sidebar-tabs{border-bottom:1px solid var(--border-color)}.recipe-detail-empty{min-height:150px}.recipe-header{flex-direction:column;gap:1rem}.recipe-main-image{width:100%;height:200px}.recipe-content{grid-template-columns:1fr;gap:1rem}.recipe-detail{padding-bottom:2rem}.upload-section{padding:.75rem}.upload-zone{padding:1rem}.upload-icon{font-size:2rem;margin-bottom:.5rem}.upload-text{font-size:.875rem}.sidebar-tabs{flex-shrink:0}.assessment-section{padding:1rem}.nutrition-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.nutrient-card{padding:.75rem .5rem}.nutrient-value{font-size:1.25rem}}.install-banner{position:fixed;top:0;left:0;right:0;background:var(--primary-color);color:#fff;padding:.625rem 1rem;display:flex;align-items:center;justify-content:center;gap:.75rem;z-index:1001;font-size:.875rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.install-banner-text{flex:1;text-align:center}.install-banner-btn{background:#fff;color:var(--primary-color);border:none;padding:.375rem .75rem;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer}.install-banner-close{background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:0;line-height:1;opacity:.8}.install-banner-close:hover{opacity:1}.desktop-ios-toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;max-width:320px;z-index:100;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-icon{font-size:1.25rem;flex-shrink:0}.toast-text{font-size:.8rem;color:var(--text-color);line-height:1.4}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--text-muted);padding:0;line-height:1;flex-shrink:0;margin-left:auto}.toast-close:hover{color:var(--text-color)}.install-prompt-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:1rem}.install-prompt{background:#fff;border-radius:16px 16px 0 0;padding:1.5rem;max-width:400px;width:100%;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.install-prompt-header h3{margin:0;color:var(--primary-color)}.install-prompt-header .close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.install-prompt p{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.install-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.install-step{display:flex;align-items:flex-start;gap:.75rem}.step-number{width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.step-text{font-size:.875rem;line-height:1.5}.share-icon,.add-icon,.menu-icon{display:inline-flex;align-items:center;vertical-align:middle;margin:0 .25rem;color:#007aff}.install-prompt-actions{display:flex;gap:.75rem}.remind-btn,.got-it-btn{flex:1;padding:.75rem;border-radius:8px;font-size:.875rem;cursor:pointer}.remind-btn{background:var(--bg-color);border:1px solid var(--border-color);color:var(--text-color)}.got-it-btn{background:var(--primary-color);border:none;color:#fff}.remind-btn:hover{background:var(--border-color)}.got-it-btn:hover{background:var(--primary-dark)}.ingredient-item{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.25rem}.ingredient-text{flex:1}.ingredient-cart{flex-shrink:0;display:flex;align-items:center;gap:.25rem}.cart-search-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-color);background:var(--card-bg);cursor:pointer;font-size:1.125rem;line-height:1;color:var(--primary-color);display:flex;align-items:center;justify-content:center;transition:all .2s}.cart-search-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.cart-spinner{font-size:.75rem;color:var(--text-muted)}.cart-results-backdrop{position:fixed;inset:0;background:#0006;z-index:100}.cart-results-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:101;background:var(--card-bg);border-radius:12px;box-shadow:0 8px 32px #0003;width:min(90vw,400px);max-height:80vh;overflow-y:auto}.cart-popup-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);font-size:.85rem;gap:.5rem}.cart-popup-header span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.cart-popup-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--text-muted);flex-shrink:0;padding:0 .25rem}.cart-product-list{list-style:none;margin:0;padding:0}.cart-product-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-color)}.cart-product-item:last-child{border-bottom:none}.cart-product-item:hover{background:var(--hover-bg, #f5f5f5)}.cart-product-img{width:48px;height:48px;object-fit:contain;border-radius:6px;flex-shrink:0}.cart-product-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.cart-product-name{font-size:.85rem;font-weight:500}.cart-product-meta{font-size:.75rem;color:var(--text-muted);display:flex;gap:.5rem}.cart-product-price{font-weight:600;color:var(--primary-color)}.cart-no-results{font-size:.75rem;color:var(--text-muted)}.cart-added{font-size:.75rem;color:var(--success-color);font-weight:500}.cart-error{font-size:.75rem;color:var(--error-color);cursor:help}.cart-message{margin-top:.75rem;padding:.5rem .75rem;background:#e8f5e9;color:var(--success-color);border-radius:4px;font-size:.875rem}@media(display-mode:standalone){.app-header{padding-top:env(safe-area-inset-top,0)}body{padding-bottom:env(safe-area-inset-bottom,0)}}
