*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{line-height:1.2}button{font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}@media (max-width: 768px){body{font-size:14px}}.search-bar{position:relative;width:100%;max-width:400px}.search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;background-color:#fff;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3498db}.search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.5rem;color:#7f8c8d;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.search-clear:hover{color:#2c3e50}.search-loading{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#7f8c8d;font-size:1.25rem;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@media (max-width: 768px){.search-bar{max-width:none}}.recipe-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:box-shadow .2s;display:flex;flex-direction:column}.recipe-card:hover{box-shadow:0 4px 12px #0000001a}.recipe-card-title{margin:0 0 .75rem;font-size:1.25rem;color:#2c3e50}.recipe-card-description{margin:0 0 1rem;color:#7f8c8d;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.recipe-card-actions{display:flex;gap:.5rem;margin-top:auto}.btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color .2s;text-decoration:none;display:inline-block}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}@media (max-width: 768px){.recipe-card{padding:1rem}.recipe-card-title{font-size:1.125rem}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-container p{margin-top:1rem;color:#7f8c8d}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{text-align:center;padding:3rem;background-color:#fee;border:1px solid #fcc;border-radius:8px;margin:2rem auto;max-width:500px}.error-icon{font-size:2rem;margin-bottom:1rem}.error-message p{color:#c0392b;margin:0 0 1rem}.error-message .btn{margin-top:1rem}.recipe-browser{padding:1rem}.recipe-browser-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.recipe-browser-header h2{margin:0;color:#2c3e50}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.no-recipes{text-align:center;padding:3rem;color:#7f8c8d}.no-recipes p{margin:.5rem 0}@media (max-width: 768px){.recipe-browser{padding:.5rem}.recipe-browser-header{flex-direction:column;align-items:stretch}.recipe-grid{grid-template-columns:1fr;gap:1rem}}.timed-dish-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;transition:box-shadow .2s}.timed-dish-card:hover{box-shadow:0 4px 12px #0000001a}.dish-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.dish-header h3{margin:0;font-size:1.25rem;color:#2c3e50;flex:1}.anylist-badge{background-color:#e3f2fd;color:#1976d2;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.dish-short-name{font-size:.875rem;color:#7f8c8d;margin:-.5rem 0 1rem;font-style:italic}.dish-info{display:flex;gap:1rem;margin-bottom:1rem;color:#7f8c8d;font-size:.875rem}.dish-steps{flex:1;margin-bottom:1rem}.step-preview{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid #f0f0f0;font-size:.875rem}.step-preview:last-child{border-bottom:none}.step-num{font-weight:500;color:#7f8c8d;min-width:20px}.step-desc{flex:1;color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.step-time{color:#95a5a6;font-size:.75rem}.more-steps{margin:.5rem 0 0;color:#95a5a6;font-size:.875rem;font-style:italic}.dish-actions{display:flex;gap:.5rem;margin-top:auto}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}@media (max-width: 768px){.timed-dish-card{padding:1rem}.dish-header h3{font-size:1.125rem}.dish-actions{flex-wrap:wrap}}.timed-dishes{padding:1rem}.timed-dishes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.timed-dishes-header h2{margin:0;color:#2c3e50}.timed-dishes-actions{display:flex;gap:1rem;align-items:center}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-tab{padding:.5rem 1rem;border:1px solid #ddd;border-radius:20px;background:#fff;color:#555;cursor:pointer;font-size:.9rem;transition:all .2s}.filter-tab:hover{border-color:#3498db;color:#3498db}.filter-tab.active{background:#3498db;border-color:#3498db;color:#fff}.dishes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.no-dishes{text-align:center;padding:3rem;color:#7f8c8d}.no-dishes p{margin:.5rem 0}@media (max-width: 768px){.timed-dishes{padding:.5rem}.timed-dishes-header{flex-direction:column;align-items:stretch}.filter-tabs{justify-content:center}.filter-tab{padding:.4rem .8rem;font-size:.85rem}.dishes-grid{grid-template-columns:1fr;gap:1rem}}.step-table-container{width:100%;margin-top:1rem}.step-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #ddd;border-radius:4px;overflow:hidden;table-layout:fixed}.step-table-container{overflow-x:visible;width:100%}.step-table th{background-color:#f8f9fa;padding:.75rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #dee2e6;font-size:.875rem}.step-table td{padding:0;border-bottom:1px solid #e9ecef;position:relative}.step-table tr:hover{background-color:#f8f9fa}.action-header,.step-table th:nth-child(1),.step-table td:nth-child(1){width:50px}.action-cell{width:50px;text-align:center;padding:.25rem}.step-actions{display:flex;align-items:center;gap:.25rem;justify-content:center}.drag-handle{cursor:grab;color:#6c757d;font-size:1rem;-webkit-user-select:none;user-select:none;padding:.25rem;border-radius:2px}.drag-handle:hover{background-color:#e9ecef;color:#495057}.dragging{opacity:.5;background-color:#f8f9fa}.drag-over{border-top:2px solid #3498db}.empty-drop-zone{height:60px}.empty-drop-zone.drag-over{background-color:#e3f2fd;border:2px dashed #3498db}.empty-message{text-align:center;color:#6c757d;font-style:italic;padding:1rem}.drop-zone-last{height:20px}.drop-zone-last:hover{background-color:#f0f8ff}.drop-zone-last.drag-over .drop-zone-indicator{border-top:2px solid #3498db}.drop-zone-indicator{padding:0;height:20px}.step-table th:nth-child(2),.step-table td:nth-child(2){width:auto;min-width:800px}.description-cell{vertical-align:top;padding-top:.5rem;padding-bottom:.5rem}.step-table th:nth-child(3),.step-table td:nth-child(3){width:70px}.step-table th:nth-child(4),.step-table td:nth-child(4){width:70px}.step-table th:nth-child(5),.step-table td:nth-child(5){width:70px}@media (min-width: 1920px){.step-table th:nth-child(2),.step-table td:nth-child(2){min-width:1000px}}@media (min-width: 2560px){.step-table th:nth-child(2),.step-table td:nth-child(2){min-width:1400px}}.btn-remove{background:none;border:none;color:#dc3545;font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem;width:30px;height:30px;border-radius:4px;transition:background-color .2s}.btn-remove:hover{background-color:#dc3545;color:#fff}.cell-input,.cell-textarea{width:100%;padding:.5rem .75rem;border:none;background:transparent;font-size:.875rem;font-family:inherit;outline:none;cursor:default}.cell-textarea{resize:vertical;min-height:auto;height:auto;line-height:1.5;overflow-y:hidden;transition:height .15s ease;white-space:pre-wrap;word-wrap:break-word}.cell-input.editing,.cell-textarea.editing{background-color:#fff;box-shadow:inset 0 0 0 2px #3498db;cursor:text}.cell-input.number{text-align:center}.cell-input.text{text-align:left}.cell-checkbox{cursor:pointer;width:18px;height:18px;margin:0}td.focused{background-color:#e3f2fd}td.has-error{background-color:#fee;border:1px solid #f99}td.has-error .cell-input,td.has-error .cell-textarea{background-color:#fee}td.has-error.focused{background-color:#fdd}.cell-input:focus,.cell-textarea:focus{box-shadow:inset 0 0 0 2px #3498db;outline:none}.table-actions{margin-top:1rem;display:flex;justify-content:space-between;align-items:center}.keyboard-hints{display:flex;gap:1.5rem;font-size:.75rem;color:#6c757d}.keyboard-hints span{display:flex;align-items:center;gap:.25rem}@media (max-width: 768px){.step-table{font-size:.75rem;table-layout:auto}.step-table th,.cell-input{padding:.5rem;font-size:.75rem}.step-table th,.step-table td{width:auto!important;min-width:unset!important}.keyboard-hints{display:none}}@media print{.action-cell,.action-header,.table-actions{display:none}td.focused{background-color:transparent;outline:none}.cell-input{padding:.25rem}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 1rem;color:#2c3e50}.modal-content p{margin:0 0 1rem;color:#333;line-height:1.6}.modal-explanation{font-size:.9rem;color:#666;background-color:#f8f9fa;padding:1rem;border-radius:4px;border-left:3px solid #3498db}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}@media (max-width: 480px){.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.timed-dish-editor{max-width:calc(100% - 1rem);margin:0 auto;padding:.5rem}.timed-dish-editor.with-recipe-pane{max-width:calc(100% - 1rem);padding:.5rem}@media (min-width: 1920px){.timed-dish-editor{max-width:calc(100% - 1.5rem)}.timed-dish-editor.with-recipe-pane{max-width:calc(100% - 1.5rem);margin:0 auto;padding:.5rem .75rem}}@media (min-width: 2560px){.timed-dish-editor{max-width:calc(100% - 2rem)}.timed-dish-editor.with-recipe-pane{max-width:calc(100% - 2rem);padding:.5rem 1rem}}.editor-content{display:flex;gap:.75rem;align-items:flex-start}.recipe-pane{flex:0 0 450px;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:calc(100vh - 200px);overflow-y:auto;position:sticky;top:1rem}@media (min-width: 1920px){.recipe-pane{flex:0 0 500px}}@media (min-width: 2560px){.recipe-pane{flex:0 0 550px}}.recipe-pane h3{margin:0 0 1.5rem;color:#2c3e50;border-bottom:2px solid #3498db;padding-bottom:.5rem}.recipe-details h4{margin:0 0 1rem;color:#34495e}.recipe-section{margin-bottom:1.5rem}.recipe-section h5{margin:0 0 .75rem;color:#2c3e50;font-size:1.1rem;font-weight:600}.collapsible-header{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:.5rem}.collapsible-header:hover{color:#3498db}.collapsible-header .arrow{display:inline-block;transition:transform .2s ease;font-size:.8rem}.collapsible-header .arrow.expanded{transform:rotate(90deg)}.ingredients-list{list-style:none;padding:0;margin:0}.ingredients-list li{padding:.25rem 0 .25rem 1.25rem;position:relative}.ingredients-list li:before{content:"•";position:absolute;left:0;color:#3498db;font-weight:700}.preparation-steps{margin:0;padding-left:1.5rem}.preparation-steps li{margin-bottom:.75rem;line-height:1.6}.recipe-note{background-color:#f8f9fa;padding:1rem;border-radius:4px;margin:0;font-style:italic;border-left:3px solid #3498db}.recipe-metadata{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}.recipe-metadata p{margin:.25rem 0;color:#555}.editor-form{flex:1;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;min-width:0;overflow-x:auto}.form-group{margin-bottom:1.5rem}.form-help{display:block;margin-top:.25rem;font-size:.875rem;color:#7f8c8d}.input-with-action{display:flex;gap:.5rem}.input-with-action input{flex:1}.input-with-action .btn-sm{white-space:nowrap}.generating-indicator{font-size:.875rem;color:#3498db;font-weight:400}.anylist-info{background-color:#e3f2fd;padding:.75rem;border-radius:4px;margin-bottom:1.5rem;color:#1976d2}.steps-section{margin-top:2rem;width:100%}.steps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.steps-header h3{margin:0;color:#2c3e50}.steps-actions{display:flex;gap:.5rem}.steps-list{display:flex;flex-direction:column;gap:1rem}.generating-steps{text-align:center;padding:2rem;background-color:#f5f5f5;border-radius:8px}.generating-steps p{margin-top:1rem;color:#7f8c8d}.multi-table-container{display:flex;flex-direction:column;gap:2rem;margin-top:1rem}.sub-dish-table,.finishing-steps-table{width:100%}.sub-dish-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem;background-color:#e3f2fd;border-radius:4px}.sub-dish-name-input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-weight:500}.sub-dish-name-input:focus{outline:none;border-color:#1976d2}.finishing-steps-table h4{margin:0 0 1rem;color:#7b1fa2;font-size:1.125rem;padding:.5rem;background-color:#f3e5f5;border-radius:4px;text-align:center}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}@media (max-width: 1023px){.editor-content{flex-direction:column}.recipe-pane{display:none}.timed-dish-editor.with-recipe-pane{max-width:1200px}}@media (max-width: 768px){.timed-dish-editor{padding:.5rem}.editor-header{flex-direction:column;align-items:stretch;gap:1rem}.editor-actions{justify-content:flex-end}.editor-form{padding:1rem}.multi-table-container{flex-direction:column;gap:1rem}.steps-actions{flex-wrap:wrap;gap:.5rem}}.cook-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;transition:box-shadow .2s}.cook-card:hover{box-shadow:0 4px 12px #0000001a}.cook-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.cook-header h3{margin:0;font-size:1.25rem;color:#2c3e50;flex:1}.cook-date{font-size:.875rem;color:#7f8c8d;white-space:nowrap}.cook-info{margin-bottom:1rem;color:#555}.cook-info p{margin:.25rem 0}.service-time{font-size:.875rem}.cook-stats{font-size:.875rem;color:#7f8c8d}.cook-dishes{flex:1;margin-bottom:1rem;font-size:.875rem}.cook-dishes strong{display:block;margin-bottom:.25rem;color:#555}.cook-dishes ul{margin:0;padding-left:1.25rem;list-style:disc}.cook-dishes li{margin:.25rem 0;color:#666}.more-dishes{font-style:italic;color:#95a5a6}.cook-actions{display:flex;gap:.5rem;margin-top:auto}@media (max-width: 768px){.cook-card{padding:1rem}.cook-header h3{font-size:1.125rem}.cook-actions{flex-wrap:wrap}}.cooks{padding:1rem}.cooks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.cooks-header h2{margin:0;color:#2c3e50}.cooks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.no-cooks{text-align:center;padding:3rem;color:#7f8c8d}.no-cooks p{margin:.5rem 0}@media (max-width: 768px){.cooks{padding:.5rem}.cooks-header{flex-direction:column;align-items:stretch}.cooks-grid{grid-template-columns:1fr;gap:1rem}}.service-time-input{display:flex;align-items:center;gap:.5rem}.service-time-field{width:120px;padding:.5rem;font-size:.9rem;border:1px solid #ddd;border-radius:4px;background:#fff}.service-time-field:focus{outline:none;border-color:#3498db}.service-time-field::placeholder{color:#bdc3c7;font-style:italic}.service-time-field:disabled{background:#f5f5f5;cursor:not-allowed}.service-time-preview{font-size:.85rem;color:#7f8c8d;white-space:nowrap}.quick-add-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.quick-add-modal{background:#fff;border-radius:8px;width:90%;max-width:400px;box-shadow:0 4px 20px #00000026}.quick-add-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e0e0e0}.quick-add-header h3{margin:0;font-size:1.1rem;color:#2c3e50}.quick-add-body{padding:1.25rem}.quick-add-body .form-group{margin-bottom:1rem}.quick-add-body .form-group:last-of-type{margin-bottom:0}.quick-add-body label{display:block;margin-bottom:.5rem;font-weight:500;color:#2c3e50}.quick-add-body input[type=text],.quick-add-body input[type=number]{width:100%;padding:.75rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;box-sizing:border-box}.quick-add-body input[type=text]:focus,.quick-add-body input[type=number]:focus{outline:none;border-color:#3498db}.suggestions{margin:1rem 0;padding:.75rem;background:#f8f9fa;border-radius:4px}.suggestions-label{margin:0 0 .5rem;font-size:.85rem;color:#7f8c8d}.suggestion-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .75rem;margin-bottom:.25rem;background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;text-align:left;transition:all .15s}.suggestion-item:last-child{margin-bottom:0}.suggestion-item:hover{border-color:#3498db;background:#ebf5fb}.suggestion-item.one-time{border-left:3px solid #27ae60}.suggestion-name{flex:1;color:#2c3e50}.one-time-badge{font-size:.7rem;padding:.15rem .4rem;background:#27ae60;color:#fff;border-radius:3px;margin-left:.5rem}.no-matches{margin:.75rem 0;padding:.5rem;background:#f0f0f0;border-radius:4px;font-size:.9rem;color:#7f8c8d;text-align:center}.error-message{margin:.75rem 0 0;padding:.5rem;background:#fdecea;color:#c0392b;border-radius:4px;font-size:.9rem}.service-time-group{padding:.75rem;background:#f8f9fa;border-radius:4px}.service-time-group label{margin-bottom:.5rem}.service-time-hint{display:block;margin-top:.5rem;font-size:.8rem;color:#7f8c8d}.quick-add-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #e0e0e0;background:#f8f9fa;border-radius:0 0 8px 8px}.dish-selector{position:relative;margin-bottom:1rem}.selector-row{display:flex;gap:.5rem;align-items:stretch}.search-container{position:relative;flex:1}.quick-add-btn{white-space:nowrap;padding:.75rem 1rem}.search-container input{width:100%;padding:.75rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;background-color:#fff}.search-container input:focus{outline:none;border-color:#3498db}.dish-dropdown{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 4px 4px;box-shadow:0 4px 6px #0000001a;z-index:100}.dropdown-item{padding:.75rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.dropdown-item:hover{background-color:#f8f9fa}.dropdown-item:last-child{border-bottom:none}.dropdown-item.loading,.dropdown-item.no-results{color:#7f8c8d;cursor:default;text-align:center}.dropdown-item.loading:hover,.dropdown-item.no-results:hover{background-color:transparent}.dish-name{font-weight:500;color:#2c3e50;margin-bottom:.25rem}.dish-short-name{font-weight:400;color:#7f8c8d;font-size:.875em}.dish-meta{font-size:.875rem;color:#7f8c8d}.anylist-indicator{color:#3498db}.one-time-badge{display:inline-block;font-size:.7rem;padding:.1rem .4rem;background:#27ae60;color:#fff;border-radius:3px;margin-left:.5rem;vertical-align:middle}.dropdown-item.one-time{border-left:3px solid #27ae60}.create-link{display:block;margin-top:.5rem;background:none;border:none;color:#3498db;cursor:pointer;font-size:.9rem;text-decoration:underline}.create-link:hover{color:#2980b9}.time-input-container{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem;border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-background)}.time-input-field{width:2.5rem;padding:.25rem;border:none;background:transparent;text-align:center;font-size:1rem;outline:none}.time-input-field:focus{background-color:var(--color-background-secondary);border-radius:2px}.time-input-field::-webkit-inner-spin-button,.time-input-field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.time-input-field[type=number]{-moz-appearance:textfield}.time-separator{color:var(--color-text-secondary);font-weight:700}.time-input-ampm{padding:.25rem .5rem;border:none;background:transparent;font-size:.9rem;cursor:pointer;outline:none}.time-input-ampm:focus{background-color:var(--color-background-secondary);border-radius:2px}.time-input-field::placeholder{color:var(--color-text-secondary);opacity:.5}.blocked-time-ranges{margin-top:2rem;padding:1.5rem;background-color:var(--color-background-secondary);border-radius:8px}.blocked-time-ranges h4{margin:0 0 .5rem;color:var(--color-text-primary)}.blocked-time-ranges .help-text{margin:0 0 1rem;color:var(--color-text-secondary);font-size:.9rem}.add-range-form{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.add-range-form .range-separator{color:var(--color-text-secondary);font-weight:500;margin:0 .5rem}.ranges-list{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.ranges-list h5{margin:0 0 .5rem;font-size:.9rem;color:var(--color-text-secondary)}.range-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;margin-bottom:.5rem;background-color:var(--color-background);border-radius:4px;border:1px solid var(--color-border)}.range-item span{font-weight:500}.cook-dish-edit-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.cook-dish-edit-modal{background:#fff;border-radius:8px;width:95%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h3{margin:0;font-size:1.2rem;color:#2c3e50}.close-btn{background:none;border:none;font-size:1.5rem;color:#7f8c8d;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:#2c3e50}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.error-message{margin-bottom:1rem;padding:.75rem;background:#fdecea;color:#c0392b;border-radius:4px}.dish-service-time{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:4px}.dish-service-time label{display:block;font-weight:500;margin-bottom:.5rem;color:#2c3e50}.service-time-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#7f8c8d}.dish-summary{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;font-size:.9rem;color:#7f8c8d}.dish-summary .separator{color:#bdc3c7}.steps-list{overflow-x:auto}.steps-edit-table{width:100%;border-collapse:collapse;font-size:.9rem}.steps-edit-table th{text-align:left;padding:.75rem .5rem;background:#f8f9fa;border-bottom:2px solid #e0e0e0;font-weight:500;color:#2c3e50;white-space:nowrap}.steps-edit-table td{padding:.5rem;border-bottom:1px solid #f0f0f0;vertical-align:middle}.steps-edit-table tr:hover{background:#fafafa}.subdish-col{font-size:.85rem;color:#7f8c8d;white-space:nowrap}.description-col{width:50%}.step-description-input{width:100%;padding:.4rem;font-size:.9rem;border:1px solid #ddd;border-radius:3px}.step-description-input:focus{outline:none;border-color:#3498db}.duration-col{width:80px}.step-duration-input{width:70px;padding:.4rem;font-size:.9rem;border:1px solid #ddd;border-radius:3px;text-align:center}.step-duration-input:focus{outline:none;border-color:#3498db}.checkbox-col{text-align:center;width:60px}.checkbox-col input[type=checkbox]{width:18px;height:18px;cursor:pointer}.delete-col{width:40px;text-align:center}.delete-step-btn{background:none;border:none;color:#bdc3c7;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;line-height:1;border-radius:3px;transition:color .15s,background .15s}.delete-step-btn:hover{color:#e74c3c;background:#fdecea}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e0e0e0;background:#f8f9fa;border-radius:0 0 8px 8px}.btn-warning{background:#f39c12;color:#fff;border:none}.btn-warning:hover:not(:disabled){background:#e67e22}.btn-warning:disabled{background:#bdc3c7;cursor:not-allowed}@media (max-width: 600px){.cook-dish-edit-modal{width:100%;height:100%;max-height:100%;border-radius:0}.modal-footer{flex-wrap:wrap}.modal-footer .btn{flex:1;min-width:120px}}.cook-editor{max-width:1000px;margin:0 auto;padding:1rem;overflow:visible}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.editor-header h2{margin:0;color:#2c3e50}.editor-actions{display:flex;gap:.5rem}.editor-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:visible}.form-row{display:flex;gap:1.5rem;margin-bottom:1.5rem}.form-group{flex:1}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#2c3e50}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3498db}.dishes-section{margin-top:2rem;overflow:visible}.dishes-section h3{margin:0 0 1rem;color:#2c3e50}.selected-dishes{margin-top:2rem}.selected-dishes h4{margin:0 0 1rem;color:#555}.selected-dish-card{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:1rem}.dish-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.dish-card-info h5{margin:0 0 .25rem;color:#2c3e50}.dish-card-info .dish-meta{font-size:.85rem;color:#7f8c8d}.dish-card-actions{display:flex;gap:.5rem}.dish-service-time-row{display:flex;align-items:center;gap:.75rem;padding-top:.75rem;border-top:1px solid #e9ecef}.dish-service-time-row label{font-size:.9rem;color:#555;white-space:nowrap}.default-service-hint{font-size:.85rem;color:#95a5a6;font-style:italic}@media (max-width: 768px){.cook-editor{padding:.5rem}.editor-header{flex-direction:column;align-items:stretch;gap:1rem}.editor-actions{justify-content:flex-end}.editor-form{padding:1rem}.form-row{flex-direction:column;gap:1rem}.steps-table{font-size:.75rem}}.gantt-chart-container{margin-top:2rem;padding:1rem;background:#f8f9fa;border-radius:8px;width:100%;box-sizing:border-box}.gantt-chart-container h3{margin:0 0 1.5rem;color:#2c3e50}.gantt-chart{position:relative;background:#fff;border:1px solid #dee2e6;border-radius:4px;overflow-x:hidden;overflow-y:visible;min-height:200px;width:100%}@media (max-width: 480px){.gantt-chart{overflow-x:auto}}.service-time-vertical-line{position:absolute;top:0;bottom:0;width:2px;z-index:1;pointer-events:none}.service-line-label{position:absolute;top:30px;right:5px;transform:translate(0);white-space:nowrap;font-size:.75rem;font-weight:600;padding:2px 6px;border-radius:3px;background:#fff;box-shadow:0 1px 3px #0000001a;z-index:20}.service-line-label.main{color:#e74c3c;border:1px solid #e74c3c}.service-line-label.early{color:#e67e22;border:1px solid #e67e22}.service-time-vertical-line.main-service{background:linear-gradient(to bottom,#e74c3c 0% 60px,#e74c3c40 60px)}.service-time-vertical-line.early-service{background:linear-gradient(to bottom,#f39c12 0% 60px,#f39c1240 60px)}.gantt-timeline{display:flex;height:60px;border-bottom:2px solid #dee2e6;background:#f8f9fa;min-width:100%;position:relative}.gantt-timeline-spacer{width:20%;min-width:150px;max-width:200px;flex-shrink:0}.gantt-timeline-content{flex:1;position:relative;min-width:0;padding-right:65px}.time-marker{position:absolute;top:0;bottom:0;width:1px;background:#e9ecef}.time-label{position:absolute;top:5px;left:50%;transform:translate(-50%);font-size:.75rem;color:#6c757d;white-space:nowrap}.gantt-rows{min-height:150px;padding:1rem 0}.gantt-row{display:flex;align-items:center;min-height:40px;margin-bottom:.5rem;position:relative}.gantt-row-label{width:20%;min-width:150px;max-width:200px;padding:0 1rem;font-size:.875rem;font-weight:500;color:#495057;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-row-bars{flex:1;position:relative;height:30px;min-width:0;padding-right:65px}.gantt-bar{position:absolute;height:100%;border-radius:4px;display:flex;align-items:center;padding:0 .5rem;overflow:hidden;cursor:pointer;transition:opacity .2s,transform .2s}.gantt-bar:hover{opacity:.9;transform:scale(1.02);z-index:5}.gantt-bar.hands-on{box-shadow:0 1px 3px #0003}.gantt-bar.passive{border:2px dashed rgba(0,0,0,.2)}.gantt-bar-text{font-size:.75rem;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-bar.passive .gantt-bar-text{color:#2c3e50}.gantt-legend{display:flex;gap:2rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6c757d}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.hands-on{background:#3498db;box-shadow:0 1px 3px #0003}.legend-color.passive{background:#3498db66;border:2px dashed rgba(0,0,0,.2)}.blocked-time-range{position:absolute;top:0;bottom:0;background:#e74c3c33;border-left:2px solid #e74c3c;border-right:2px solid #e74c3c;z-index:5;box-sizing:border-box}.blocked-time-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:700;color:#e74c3c;text-transform:uppercase;letter-spacing:1px;white-space:nowrap;text-shadow:0 0 3px white}.legend-color.blocked{background:#e74c3c33;border:2px solid #e74c3c}.gantt-bar.buffer{background:#95a5a6!important;border:2px dashed #7f8c8d;font-style:italic}.gantt-bar.conflict{border:3px solid #e74c3c!important;box-shadow:0 0 5px #e74c3c80}.gantt-bar.buffer .gantt-bar-text{color:#2c3e50}.legend-color.buffer{background:#95a5a6;border:2px dashed #7f8c8d}.legend-color.conflict{background:#3498db;border:3px solid #e74c3c}.service-time-diff{display:block;font-size:.625rem;font-weight:400;opacity:.8}@media (max-width: 768px){.gantt-timeline-spacer{width:25%;min-width:100px}.gantt-row-label{width:25%;min-width:100px;font-size:.75rem;padding:0 .5rem}.gantt-bar-text,.time-label{font-size:.625rem}.service-time-label,.early-service-time-label{font-size:.625rem;padding:1px 4px}.service-time-diff{font-size:.5rem}}@media (max-width: 480px){.gantt-timeline-spacer{width:30%;min-width:80px}.gantt-row-label{width:30%;min-width:80px;font-size:.625rem}}@media print{.gantt-chart-container{page-break-inside:avoid}.gantt-chart{overflow-x:visible}}.cook-view{max-width:1200px;margin:0 auto;padding:1rem}.view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.view-header h1{margin:0 0 .5rem;color:#2c3e50}.cook-details{color:#7f8c8d;font-size:1.125rem;margin:0}.multiple-service-times{margin-top:1rem;padding:1rem;background-color:#e8f4fd;border-radius:4px}.service-times-header{margin:0 0 .5rem;font-weight:600;color:#2c3e50}.service-times-list{margin:0;padding-left:1.5rem;list-style-type:disc}.service-times-list li{color:#495057;margin-bottom:.25rem}.view-actions{display:flex;gap:.5rem}.schedule-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;box-sizing:border-box;overflow:hidden}.schedule-container h2{margin:0 0 1.5rem;color:#2c3e50}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.schedule-header h2{margin:0}.show-buffers-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.show-buffers-toggle input[type=checkbox]{cursor:pointer}.schedule-table{width:100%;border-collapse:collapse;margin-bottom:2rem}.schedule-table th{background-color:#f8f9fa;padding:.75rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #dee2e6}.schedule-table td{padding:.75rem;border-bottom:1px solid #e9ecef}.schedule-table tr:hover{background-color:#f8f9fa}.schedule-table tr.hands-on{background-color:#fff9e6}.schedule-table tr.hands-on:hover{background-color:#fff5d6}.schedule-table tr.buffer-step{background-color:#e8f4fd;font-style:italic}.schedule-table tr.buffer-step:hover{background-color:#d4e9f7}.schedule-table tr.has-conflict{background-color:#ffe8e8}.schedule-table tr.has-conflict:hover{background-color:#ffd4d4}.conflict-icon{color:#e74c3c;font-weight:700;margin-right:.25rem}.time-cell{font-weight:500;white-space:nowrap}.item-cell{font-weight:500;color:#2c3e50}.step-number{text-align:center;color:#7f8c8d}.description-cell{max-width:400px}.duration-cell{white-space:nowrap;text-align:center}.do-ahead-cell{text-align:center;color:#27ae60}.hands-on-cell{text-align:center;color:#e67e22}.early-service-row{background-color:#fef3e5;font-style:italic}.early-service-row:hover{background-color:#fde8d1}.early-service-notice{color:#f39c12;font-weight:500}.schedule-summary{background-color:#f8f9fa;padding:1rem;border-radius:4px;display:flex;gap:2rem}.schedule-summary p{margin:0;color:#555}@media print{@page{margin:.25in;size:auto}.view-actions,.show-buffers-toggle,.gantt-chart-container,.schedule-summary{display:none!important}.cook-view{padding:0;max-width:100%;margin:0}.view-header{margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #333}.view-header h1{font-size:1.5rem;margin:0 0 .25rem}.cook-details{font-size:1rem;margin:0}.multiple-service-times{margin-top:.5rem;padding:.5rem;background-color:transparent;border:1px solid #ccc}.service-times-header{font-size:.9rem;margin-bottom:.25rem}.service-times-list{font-size:.85rem;margin:0}.service-times-list li{margin-bottom:.1rem}.schedule-container{box-shadow:none;padding:0;border-radius:0}.schedule-header{margin-bottom:.5rem}.schedule-container h2{font-size:1.1rem;margin:0 0 .5rem}.schedule-table{width:100%;font-size:.85rem;margin-bottom:0;border-collapse:collapse}.schedule-table th{padding:.4rem .5rem;font-size:.85rem;background-color:#f0f0f0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;border:1px solid #333}.schedule-table td{padding:.35rem .5rem;line-height:1.3;border:1px solid #ccc}.description-cell{max-width:none}.schedule-table tr.hands-on{background-color:#f5f5f5!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.schedule-table tr.buffer-step{background-color:#e8e8e8!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.schedule-table tr.early-service-row{background-color:#fff8e8!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.schedule-table tr:hover{background-color:inherit}.schedule-table{page-break-inside:auto}.schedule-table tr{page-break-inside:avoid;page-break-after:auto}.schedule-table thead{display:table-header-group}}@media (max-width: 768px){.cook-view{padding:.5rem}.view-header{flex-direction:column;gap:1rem}.view-header h1{font-size:1.25rem}.cook-details{font-size:.95rem}.schedule-container{padding:.75rem}.schedule-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1rem}.schedule-header h2{font-size:1.1rem}.schedule-table{font-size:.8rem}.schedule-table th,.schedule-table td{padding:.4rem .35rem}.schedule-table th.hands-on-header,.schedule-table .sub-dish-cell,.schedule-table .do-ahead-cell,.schedule-table .hands-on-cell,.schedule-table th:nth-child(2),.schedule-table th:nth-child(5),.schedule-table th:nth-child(6){display:none}.description-cell{max-width:none}.item-cell{max-width:80px;word-wrap:break-word}.time-cell{font-size:.85rem}.schedule-summary{flex-direction:column;gap:.5rem;padding:.75rem;font-size:.85rem}.gantt-chart-container{display:none}}.calendar-page{padding:1rem;max-width:1400px;margin:0 auto}.calendar-header{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem}.calendar-header h1{margin:0;flex-shrink:0}.calendar-nav{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.week-range{font-weight:500;padding:0 1rem;white-space:nowrap}.today-btn{font-weight:600}.calendar-actions{margin-left:auto}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;min-height:500px}.calendar-day{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;min-height:200px;display:flex;flex-direction:column}.calendar-day.today{border-color:var(--primary-color, #007bff);border-width:2px}.calendar-day.empty{background:var(--empty-bg, #f9f9f9)}.day-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-bottom:1px solid var(--border-color, #e0e0e0);background:var(--header-bg, #f5f5f5);border-radius:7px 7px 0 0}.calendar-day.today .day-header{background:var(--primary-color, #007bff);color:#fff}.day-name{font-weight:600;text-transform:uppercase;font-size:.75rem}.day-date{font-size:1.25rem;font-weight:700}.day-content{flex:1;padding:.5rem;overflow-y:auto}.no-steps{color:var(--muted-color, #999);font-size:.875rem;text-align:center;padding:1rem}.day-steps{display:flex;flex-direction:column;gap:.5rem}.calendar-step{background:var(--step-bg, #f0f7ff);border-left:3px solid var(--primary-color, #007bff);border-radius:4px;padding:.5rem;cursor:pointer;transition:all .15s ease;font-size:.8rem}.calendar-step:hover{background:var(--step-hover-bg, #e0f0ff);transform:translate(2px)}.calendar-step.hands-on{border-left-color:var(--accent-color, #ff9800);background:var(--hands-on-bg, #fff9e6)}.calendar-step.hands-on:hover{background:var(--hands-on-hover-bg, #fff3cc)}.step-time{font-weight:600;color:var(--primary-color, #007bff);margin-bottom:.25rem}.calendar-step.hands-on .step-time{color:var(--accent-color, #ff9800)}.step-info{display:flex;flex-direction:column;gap:.15rem}.step-cook-name{font-weight:600;font-size:.7rem;color:var(--muted-color, #666);text-transform:uppercase}.step-item{font-weight:500}.step-description{color:var(--text-secondary, #555);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.step-meta{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--muted-color, #888);margin-top:.25rem}.hands-on-badge{background:var(--accent-color, #ff9800);color:#fff;padding:.1rem .3rem;border-radius:3px;font-weight:600;font-size:.65rem;text-transform:uppercase}.calendar-summary{margin-top:1.5rem;padding:1rem;background:var(--card-bg, #fff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px}.calendar-summary h3{margin:0 0 .5rem}.calendar-summary p{margin:.25rem 0;color:var(--text-secondary, #555)}@media (max-width: 1200px){.calendar-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.calendar-header{flex-direction:column;align-items:stretch}.calendar-nav{justify-content:center}.calendar-actions{margin-left:0;text-align:center}.calendar-grid{grid-template-columns:repeat(2,1fr)}.calendar-day{min-height:150px}}@media (max-width: 480px){.calendar-grid{grid-template-columns:1fr}}@media print{.calendar-header{margin-bottom:.5rem}.calendar-nav,.calendar-actions{display:none}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:.25rem}.calendar-day{min-height:auto;page-break-inside:avoid}.calendar-step{font-size:.7rem;padding:.25rem}}.settings-page{padding:1rem;max-width:800px;margin:0 auto}.settings-page h1{margin-bottom:1.5rem}.settings-section{margin-bottom:2rem}.settings-section h2{margin-bottom:.5rem;font-size:1.25rem}.section-description{color:var(--text-secondary, #666);margin-bottom:1rem;font-size:.9rem}.current-prompt-info{background:var(--primary-light, #e3f2fd);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.95rem}.prompt-list{display:flex;flex-direction:column;gap:1rem}.prompt-card{border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:1rem;background:var(--card-bg, #fff);transition:border-color .2s,box-shadow .2s}.prompt-card:hover{border-color:var(--primary-color, #007bff)}.prompt-card.active{border-color:var(--success-color, #28a745);border-width:2px;background:var(--success-light, #f0fff4)}.prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.prompt-header h3{margin:0;font-size:1.1rem}.prompt-version{background:var(--muted-bg, #f5f5f5);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:600;color:var(--text-secondary, #666)}.prompt-meta{display:flex;gap:1rem;font-size:.8rem;color:var(--text-muted, #999);margin-bottom:.5rem}.prompt-description{font-size:.9rem;color:var(--text-secondary, #666);margin-bottom:.75rem}.prompt-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.active-badge{background:var(--success-color, #28a745);color:#fff;padding:.4rem .8rem;border-radius:4px;font-size:.85rem;font-weight:600}.error-message{background:var(--error-light, #ffebee);color:var(--error-color, #d32f2f);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.success-message{background:var(--success-light, #e8f5e9);color:var(--success-color, #2e7d32);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.no-prompts{text-align:center;color:var(--text-muted, #999);padding:2rem}.loading{text-align:center;padding:2rem;color:var(--text-secondary, #666)}.recipe-proxy-page{max-width:800px;margin:0 auto;padding:1rem}.recipe-proxy-page h1{margin-bottom:.5rem}.page-description{color:#666;margin-bottom:1.5rem}.extract-form{margin-bottom:1.5rem}.url-input-group{display:flex;gap:.5rem}.url-input{flex:1;padding:.75rem 1rem;font-size:1rem;border:2px solid #ddd;border-radius:6px}.url-input:focus{outline:none;border-color:#007bff}.url-input:disabled{background:#f5f5f5}.error-message{background:#fee;color:#c00;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.result-card{background:#e8f5e9;border:1px solid #4caf50;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.result-card h3{color:#2e7d32;margin:0 0 .75rem}.result-details{margin-bottom:1rem}.result-details p{margin:.25rem 0}.result-urls{background:#fff;border-radius:6px;padding:1rem}.url-row{margin-bottom:.5rem}.url-row label{display:block;font-weight:600;margin-bottom:.25rem}.url-copy-group{display:flex;gap:.5rem;align-items:center}.url-copy-group code{flex:1;background:#f5f5f5;padding:.5rem;border-radius:4px;font-size:.85rem;overflow-x:auto}.url-hint{margin:.5rem 0 0;font-size:.85rem;color:#666}.extraction-queue,.completed-jobs{margin-top:1.5rem;margin-bottom:1.5rem}.extraction-queue h2,.completed-jobs h2{margin-bottom:.75rem;font-size:1.1rem}.job-list{display:flex;flex-direction:column;gap:.5rem}.job-card{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border:1px solid #ddd;border-radius:6px;gap:1rem}.job-card.pending{background:#fff8e1;border-color:#ffcc02}.job-card.processing{background:#e3f2fd;border-color:#2196f3}.job-card.completed{background:#e8f5e9;border-color:#4caf50}.job-card.failed{background:#ffebee;border-color:#f44336}.job-info{flex:1;min-width:0}.job-url{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.job-status{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.status-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:4px;font-weight:500}.status-badge.pending{background:#fff3cd;color:#856404}.status-badge.processing{background:#cce5ff;color:#004085}.status-badge.completed{background:#d4edda;color:#155724}.status-badge.failed{background:#f8d7da;color:#721c24}.job-progress{font-size:.8rem;color:#666}.job-error{font-size:.8rem;color:#c62828}.job-actions{display:flex;gap:.5rem;flex-shrink:0}.import-queue{margin-top:2rem}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.queue-header h2{margin:0}.filter-tabs{display:flex;gap:.25rem;background:#f0f0f0;padding:.25rem;border-radius:8px}.filter-tab{padding:.5rem 1rem;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s}.filter-tab:hover{color:#333}.filter-tab.active{background:#fff;color:#007bff;box-shadow:0 1px 3px #0000001a}.bulk-actions{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#e3f2fd;border-radius:8px;margin-bottom:1rem}.selection-count{font-weight:600;color:#1565c0}.select-all-row{padding:.5rem 0;margin-bottom:.5rem;border-bottom:1px solid #eee}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#666}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.recipe-checkbox{display:flex;align-items:center;padding-right:.75rem}.recipe-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.imported-badge{background:#4caf50;color:#fff;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.recipe-card.imported{background:#f8fff8;border-color:#c8e6c9}.btn-success{background:#4caf50;color:#fff}.btn-success:hover:not(:disabled){background:#43a047}.recent-recipes h2{border-bottom:1px solid #eee;padding-bottom:.5rem;margin-bottom:1rem}.no-recipes{color:#666;font-style:italic}.recipe-list{display:flex;flex-direction:column;gap:.75rem}.recipe-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.recipe-info{flex:1;min-width:0}.recipe-info h3{margin:0 0 .25rem;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recipe-meta{display:flex;gap:1rem;font-size:.85rem;color:#666;margin-bottom:.25rem}.source-type{background:#e3f2fd;color:#1565c0;padding:.125rem .5rem;border-radius:4px;font-size:.75rem}.source-link{font-size:.85rem}.recipe-actions{display:flex;gap:.5rem;flex-shrink:0}.btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-small{padding:.375rem .75rem;font-size:.8rem}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.loading{text-align:center;padding:2rem;color:#666}@media (max-width: 600px){.url-input-group,.recipe-card{flex-direction:column}.recipe-actions{width:100%;justify-content:flex-end}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#2c3e50;color:#fff;padding:1rem;box-shadow:0 2px 4px #0000001a}.app-header h1{margin:0 0 1rem;font-size:1.5rem}.app-nav{display:flex;gap:1rem;flex-wrap:wrap}.app-nav a{color:#ecf0f1;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.app-nav a:hover{background-color:#ffffff1a}.app-nav a.active{background-color:#3498db}.app-main{flex:1;padding:1rem;max-width:1200px;margin:0 auto;width:100%;overflow:visible}@media (max-width: 768px){.app-header h1{font-size:1.25rem}.app-nav{font-size:.875rem}.app-nav a{padding:.375rem .75rem}}@media print{.app-header{display:none!important}.app-main{padding:0;max-width:100%}}
