:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #e9ecef;--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-inverse: #ffffff;--color-border: #dddddd;--color-link-primary: #007bff;--color-link-success: #28a745;--color-button-primary: #28a745;--color-button-secondary: #007bff;--color-button-danger: #dc3545;--color-shadow: rgba(0, 0, 0, .1)}[data-theme=dark]{--color-bg-primary: #1a1a1a;--color-bg-secondary: #2d2d2d;--color-bg-tertiary: #3a3a3a;--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-text-inverse: #1a1a1a;--color-border: #444444;--color-link-primary: #4da3ff;--color-link-success: #5ac772;--color-button-primary: #5ac772;--color-button-secondary: #4da3ff;--color-button-danger: #f76c6c;--color-shadow: rgba(0, 0, 0, .3)}body{margin:0;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:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.token-status-container{padding:15px;margin:20px 0;border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg-secondary)}.token-status-section{margin-bottom:15px}.token-status-valid{color:var(--color-link-success)}.token-status-expired{color:var(--color-button-danger)}.token-status-note{font-size:.9em;color:var(--color-text-secondary)}.token-status-button{padding:8px 16px;background-color:var(--color-button-secondary);color:var(--color-text-inverse);border:none;border-radius:4px;cursor:pointer;margin-top:10px;transition:opacity .2s ease}.token-status-button:hover:not(:disabled){opacity:.9}.token-status-button:disabled{background-color:var(--color-text-secondary);cursor:not-allowed;opacity:.6}.token-status-error{margin-top:10px;padding:8px;background-color:var(--color-bg-tertiary);color:var(--color-button-danger);border-radius:4px;font-size:.9em}.ingredient-group-manager{margin:20px 0}.ingredient-group-manager-label{display:block;font-weight:600;margin-bottom:12px;color:var(--color-text-primary);font-size:16px}.group-management{background:var(--color-bg-secondary);padding:16px;border-radius:8px;margin-bottom:20px;border:1px solid var(--color-border)}.group-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.group-item{background:var(--color-bg-primary);padding:12px;border-radius:6px;border:1px solid var(--color-border)}.group-display{display:flex;align-items:center;gap:12px}.group-name{flex:1;font-weight:500;color:var(--color-text-primary)}.group-edit-button,.group-remove-button{padding:6px 12px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;font-size:14px;transition:all .2s}.group-edit-button:hover{background:var(--color-bg-secondary);border-color:var(--color-border)}.group-remove-button{color:var(--color-button-danger);border-color:var(--color-button-danger)}.group-remove-button:hover{background:var(--color-button-danger);color:var(--color-text-inverse)}.group-edit{display:flex;gap:8px;align-items:center}.group-name-edit-input{flex:1;padding:8px 12px;border:2px solid var(--color-link-success);border-radius:4px;font-size:14px;background:var(--color-bg-primary);color:var(--color-text-primary)}.group-save-button,.group-cancel-button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:opacity .2s}.group-save-button{background:var(--color-button-secondary);color:var(--color-text-inverse)}.group-save-button:hover{opacity:.9}.group-cancel-button{background:var(--color-bg-tertiary);color:var(--color-text-inverse)}.group-cancel-button:hover{opacity:.9}.group-add{display:flex;gap:8px;align-items:center}.group-name-input{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:4px;font-size:14px;background:var(--color-bg-primary);color:var(--color-text-primary)}.group-name-input:focus{outline:none;border-color:var(--color-link-success)}.group-add-button{padding:8px 16px;border:none;border-radius:4px;background:var(--color-button-primary);color:var(--color-text-inverse);cursor:pointer;font-weight:500;transition:opacity .2s}.group-add-button:hover:not(:disabled){opacity:.9}.group-add-button:disabled{opacity:.5;cursor:not-allowed}.group-ingredients-section{margin-bottom:24px;padding:16px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px}.group-section-title{margin:0 0 12px;color:var(--color-text-primary);font-size:16px;font-weight:600;padding-bottom:8px;border-bottom:2px solid var(--color-border)}.ingredient-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.ingredient-item{background:var(--color-bg-secondary);padding:12px;border-radius:6px;border:1px solid var(--color-border)}.ingredient-row{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr 1.2fr auto;gap:8px;align-items:center}.ingredient-name-input,.ingredient-quantity-input,.ingredient-unit-input,.ingredient-notes-input,.ingredient-group-select{padding:8px 12px;border:1px solid var(--color-border);border-radius:4px;font-size:14px;background:var(--color-bg-primary);color:var(--color-text-primary)}.ingredient-name-input{min-width:0}.ingredient-quantity-input,.ingredient-unit-input,.ingredient-notes-input{width:100%}.ingredient-group-select{width:100%;cursor:pointer}.ingredient-name-input:focus,.ingredient-quantity-input:focus,.ingredient-unit-input:focus,.ingredient-notes-input:focus,.ingredient-group-select:focus{outline:none;border-color:var(--color-link-success)}.ingredient-remove-button{padding:8px 16px;border:1px solid var(--color-button-danger);border-radius:4px;background:var(--color-bg-primary);color:var(--color-button-danger);cursor:pointer;font-size:14px;font-weight:500;white-space:nowrap;transition:all .2s}.ingredient-remove-button:hover{background:var(--color-button-danger);color:var(--color-text-inverse)}.ingredient-add-button,.ingredient-add-button-small{padding:10px 20px;border:none;border-radius:4px;background:var(--color-button-secondary);color:var(--color-text-inverse);cursor:pointer;font-weight:500;font-size:14px;transition:opacity .2s}.ingredient-add-button:hover,.ingredient-add-button-small:hover{opacity:.9}.ingredient-add-button-small{padding:8px 16px;font-size:13px}@media(max-width:768px){.ingredient-row{grid-template-columns:1fr;gap:8px}.group-display{flex-wrap:wrap}.group-add{flex-direction:column}.group-name-input{width:100%}}.instruction-input-container{margin:1.5rem 0}.instruction-input-label{display:block;margin-bottom:.75rem;color:var(--color-text-primary);font-weight:600;font-size:1rem}.instruction-list{margin-bottom:1rem}.instruction-item{margin-bottom:1rem;padding:1rem;background-color:var(--color-bg-secondary);border-radius:6px;border:1px solid var(--color-border)}.instruction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.instruction-header-left{display:flex;align-items:center;gap:.5rem}.instruction-move-buttons{display:flex;gap:2px}.instruction-move-button{background:none;border:1px solid var(--color-border);border-radius:4px;padding:2px 6px;cursor:pointer;font-size:.65rem;line-height:1;color:var(--color-text-secondary);transition:color .2s ease,border-color .2s ease}.instruction-move-button:hover:not(:disabled){color:var(--color-text-primary);border-color:var(--color-text-primary)}.instruction-move-button:disabled{opacity:.3;cursor:not-allowed}.instruction-number{font-weight:600;color:var(--color-text-primary);font-size:1rem}.instruction-text-input,.instruction-image-input{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9rem;transition:border-color .2s ease;font-family:inherit;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.instruction-text-input{margin-bottom:.5rem;resize:vertical}.instruction-text-input:focus,.instruction-image-input:focus{outline:none;border-color:var(--color-link-success)}.instruction-remove-button{padding:.5rem .75rem;background-color:var(--color-button-danger);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:opacity .2s ease;white-space:nowrap}.instruction-remove-button:hover{opacity:.9}.instruction-add-button{padding:.75rem 1.5rem;background-color:var(--color-button-secondary);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:.95rem;font-weight:500;cursor:pointer;transition:opacity .2s ease;width:100%}.instruction-add-button:hover{opacity:.9}.instruction-image-section{margin-top:.75rem}.instruction-image-preview{position:relative;display:inline-block;max-width:100%}.instruction-image{max-width:100%;max-height:300px;border-radius:6px;border:1px solid var(--color-border);display:block}.instruction-image-remove{margin-top:.5rem;padding:.5rem 1rem;background-color:var(--color-button-danger);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:opacity .2s ease}.instruction-image-remove:hover{opacity:.9}.instruction-image-upload{margin-top:.5rem}.instruction-file-label{display:block;cursor:pointer}.instruction-file-input{display:none}.instruction-file-button{display:inline-block;padding:.75rem 1.25rem;background-color:var(--color-link-success);color:var(--color-text-inverse);border-radius:4px;font-size:.9rem;font-weight:500;transition:opacity .2s ease;cursor:pointer}.instruction-file-label:hover .instruction-file-button{opacity:.9}.instruction-file-label input:disabled+.instruction-file-button{background-color:var(--color-text-secondary);cursor:not-allowed;opacity:.6}.instruction-upload-progress{margin-top:.5rem;display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.9rem}.instruction-upload-spinner{width:16px;height:16px;border:2px solid var(--color-bg-tertiary);border-top:2px solid var(--color-link-success);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.instruction-upload-error{margin-top:.5rem;padding:.5rem;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-button-danger);font-size:.85rem}.instruction-insert-button{display:block;width:100%;padding:6px;margin-top:.75rem;background:none;border:1px dashed var(--color-border);border-radius:4px;color:var(--color-text-secondary);font-size:.8rem;cursor:pointer;opacity:0;transition:opacity .2s ease}.instruction-item:hover .instruction-insert-button,.instruction-insert-button:focus{opacity:1}@media(max-width:768px){.instruction-item{padding:.75rem}.instruction-image{max-height:200px}.instruction-file-button{padding:.6rem 1rem;font-size:.85rem}}.tag-input-container{margin-bottom:1.5rem}.tag-input-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.tag-input-wrapper{position:relative}.tag-input-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);min-height:42px}.tag-input-chips:focus-within{outline:2px solid var(--accent-color);outline-offset:-1px}.tag-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;background-color:var(--accent-color);color:#fff;border-radius:16px;font-size:.875rem;line-height:1.25rem}.tag-chip-text{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-chip-remove{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:1.25rem;line-height:1;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.tag-chip-remove:hover{background-color:#0003}.tag-input-field{flex:1;min-width:120px;border:none;outline:none;background:transparent;padding:.25rem;font-size:1rem;color:var(--text-primary)}.tag-input-field::placeholder{color:var(--text-secondary)}.tag-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto;z-index:1000}.tag-suggestion-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:background-color .15s}.tag-suggestion-item:hover,.tag-suggestion-item-selected{background-color:var(--hover-bg)}.tag-suggestion-name{font-weight:500;color:var(--text-primary)}.tag-suggestion-count{font-size:.75rem;color:var(--text-secondary)}.tag-suggestion-loading{padding:.5rem .75rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.tag-input-help{margin-top:.5rem;font-size:.8125rem;color:var(--text-secondary)}.recipe-form-container{max-width:600px;margin:0 auto;padding:20px}.recipe-form-error{color:var(--color-button-danger);margin-bottom:10px;padding:10px;background-color:var(--color-bg-tertiary);border-radius:4px;border:1px solid var(--color-border)}.recipe-form-field{margin-bottom:15px}.recipe-form-field-large{margin-bottom:20px}.recipe-form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px}@media(max-width:768px){.recipe-form-row{grid-template-columns:1fr}}.recipe-form-label{display:block;margin-bottom:5px;font-weight:700;color:var(--color-text-primary)}.recipe-form-input{width:100%;padding:10px;border-radius:4px;border:1px solid var(--color-border);font-size:16px;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.recipe-form-textarea{width:100%;padding:10px;border-radius:4px;border:1px solid var(--color-border);font-size:16px;resize:vertical;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.recipe-form-button{width:100%;padding:12px;background-color:var(--color-button-primary);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:opacity .2s ease}.recipe-form-button:hover:not(:disabled){opacity:.9}.recipe-form-button:disabled{background-color:var(--color-text-secondary);cursor:not-allowed;opacity:.6}.recipe-form-buttons{display:flex;gap:10px;margin-top:20px}.recipe-form-button-secondary{background-color:var(--color-text-secondary);flex:1}.recipe-form-button-secondary:hover:not(:disabled){opacity:.9}.recipe-form-buttons .recipe-form-button{flex:1}.ingredient-filter-container{margin-bottom:1.5rem}.ingredient-filter-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.ingredient-filter-wrapper{position:relative}.ingredient-filter-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);min-height:42px}.ingredient-filter-chips:focus-within{outline:2px solid var(--accent-color);outline-offset:-1px}.ingredient-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;background-color:#10b981;color:#fff;border-radius:16px;font-size:.875rem;line-height:1.25rem}.ingredient-chip-text{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ingredient-chip-remove{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:1.25rem;line-height:1;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.ingredient-chip-remove:hover{background-color:#0003}.ingredient-filter-field{flex:1;min-width:120px;border:none;outline:none;background:transparent;padding:.25rem;font-size:1rem;color:var(--text-primary)}.ingredient-filter-field::placeholder{color:var(--text-secondary)}.ingredient-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto;z-index:1000}.ingredient-suggestion-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;cursor:pointer;transition:background-color .15s}.ingredient-suggestion-item:hover,.ingredient-suggestion-item-selected{background-color:var(--hover-bg)}.ingredient-suggestion-name{font-weight:500;color:var(--text-primary)}.ingredient-suggestion-count{font-size:.75rem;color:var(--text-secondary)}.ingredient-suggestion-loading{padding:.5rem .75rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.ingredient-filter-help{margin-top:.5rem;font-size:.8125rem;color:var(--text-secondary)}.recipe-detail-loading{text-align:center;padding:40px}.recipe-detail-error{color:var(--color-button-danger);padding:20px;background-color:var(--color-bg-tertiary);border-radius:4px;border:1px solid var(--color-border);margin:20px auto;max-width:600px}.recipe-detail-not-found{text-align:center;padding:40px;max-width:600px;margin:0 auto}.recipe-detail-back-button{display:inline-block;padding:10px 20px;background-color:var(--color-button-secondary);color:var(--color-text-inverse);text-decoration:none;border-radius:4px;transition:opacity .2s ease}.recipe-detail-back-button:hover{opacity:.9}.recipe-detail-container{max-width:800px;margin:0 auto;padding:20px}@media(max-width:600px){.recipe-detail-article{padding:20px 16px}}.recipe-detail-nav{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.recipe-detail-nav-right{display:flex;gap:10px;align-items:center}.recipe-detail-back-btn{padding:8px 16px;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;margin-right:10px;color:var(--color-text-primary);transition:opacity .2s ease}.recipe-detail-back-btn:hover{opacity:.8}.recipe-detail-edit-btn{padding:8px 16px;background-color:var(--color-button-primary);color:var(--color-text-inverse);text-decoration:none;border-radius:4px;font-size:14px;transition:opacity .2s}.recipe-detail-edit-btn:hover{opacity:.9}.recipe-detail-delete-btn{padding:8px 16px;background-color:var(--color-button-danger);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:opacity .2s}.recipe-detail-delete-btn:hover:not(:disabled){opacity:.9}.recipe-detail-delete-btn:disabled{opacity:.6;cursor:not-allowed}.recipe-detail-nav-link{color:var(--color-link-primary);text-decoration:none}.recipe-detail-article{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;padding:36px 40px;box-shadow:0 2px 4px var(--color-shadow)}.recipe-detail-header{margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.recipe-detail-title{font-size:36px;color:var(--color-text-primary);margin:0 0 16px;line-height:1.2}.recipe-detail-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.recipe-detail-author,.recipe-detail-dates{font-size:14px;color:var(--color-text-secondary)}.recipe-detail-date-separator{margin-left:15px}.recipe-detail-section{margin-bottom:44px}.recipe-detail-section-title{font-size:22px;color:var(--color-text-primary);margin:0 0 20px;padding-bottom:10px;border-bottom:2px solid var(--color-border)}.recipe-detail-description{font-size:16px;line-height:1.6;color:var(--color-text-secondary);white-space:pre-wrap}.recipe-detail-tags{display:flex;flex-wrap:wrap;gap:8px}.recipe-detail-tag{display:inline-block;padding:6px 12px;background-color:var(--color-link-success);color:var(--color-text-inverse);border-radius:16px;font-size:14px;font-weight:500;line-height:1.25}.recipe-detail-sidebar-ingredient-right{display:flex;align-items:center;gap:4px;white-space:nowrap}.recipe-detail-sidebar-ingredient-unit--clickable{cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.recipe-detail-sidebar-ingredient-unit--clickable:hover{color:var(--color-link-primary)}.recipe-detail-sidebar-ingredient-icons{display:inline-flex;align-items:center;gap:0;margin-left:2px}.recipe-detail-sidebar-suggestion-icon{color:var(--color-link-primary)!important}.recipe-detail-sidebar-history-icon{color:var(--color-text-secondary)!important}.recipe-detail-sidebar-ingredient--has-suggestion{background-color:var(--color-bg-tertiary);border-radius:4px;padding:6px 4px;margin:0 -4px}.recipe-detail-unit-popover{padding:12px;min-width:180px;max-width:240px}.recipe-detail-unit-popover-title{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.recipe-detail-unit-popover-list{list-style:none;padding:0;margin:0}.recipe-detail-unit-popover-option{display:block;width:100%;padding:6px 8px;border:none;background:none;cursor:pointer;text-align:left;font-size:14px;border-radius:4px;color:var(--color-text-primary)}.recipe-detail-unit-popover-option:hover{background-color:var(--color-bg-secondary)}.recipe-detail-unit-popover-option--selected{background-color:var(--color-bg-tertiary);font-weight:600}.recipe-detail-unit-popover-system{font-size:12px;color:var(--color-text-secondary)}.recipe-detail-unit-popover-result{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border);font-weight:700;color:var(--color-link-success);font-size:15px}.recipe-detail-suggestion-popover{padding:12px;max-width:300px}.recipe-detail-suggestion-popover-item{margin-bottom:12px}.recipe-detail-suggestion-popover-item:last-child{margin-bottom:0}.recipe-detail-suggestion-popover-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}.recipe-detail-suggestion-popover-user{font-weight:500;font-size:13px;color:var(--color-text-primary)}.recipe-detail-suggestion-popover-date{font-size:12px;color:var(--color-text-secondary)}.recipe-detail-suggestion-popover-content{font-size:14px;color:var(--color-text-primary);margin-bottom:8px}.recipe-detail-suggestion-popover-notes{font-size:13px;font-style:italic;color:var(--color-text-secondary);margin-top:4px}.recipe-detail-suggestion-popover-actions{display:flex;gap:8px}.recipe-detail-history-popover{padding:12px;max-width:320px;max-height:400px;overflow-y:auto}.recipe-detail-history-popover-title{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.recipe-detail-history-popover-item{margin-bottom:10px;padding:8px;background-color:var(--color-bg-secondary);border-radius:4px;font-size:13px}.recipe-detail-history-popover-item:last-child{margin-bottom:0}.recipe-detail-history-popover-header{display:flex;justify-content:space-between;margin-bottom:4px;padding-bottom:4px;border-bottom:1px solid var(--color-border)}.recipe-detail-history-popover-user{font-weight:500;color:var(--color-text-primary)}.recipe-detail-history-popover-date{font-size:12px;color:var(--color-text-secondary)}.recipe-detail-history-popover-changes{display:flex;flex-direction:column;gap:2px}.recipe-detail-history-popover-before,.recipe-detail-history-popover-after{font-size:13px;color:var(--color-text-secondary)}.recipe-detail-history-popover-before strong,.recipe-detail-history-popover-after strong{color:var(--color-text-primary);margin-right:4px}.recipe-detail-sidebar-toggle-icon{display:inline-flex;vertical-align:middle;margin-left:4px}.recipe-detail-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;padding:24px;background-color:var(--color-bg-secondary);border-radius:8px}.recipe-detail-info-item{display:flex;flex-direction:column;gap:4px}.recipe-detail-info-label{font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.recipe-detail-info-value{font-size:18px;font-weight:700;color:var(--color-text-primary)}.recipe-detail-instructions-list{list-style:none;padding:0;margin:0;counter-reset:instruction-counter}.recipe-detail-instruction-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;padding:20px;background-color:var(--color-bg-secondary);border-radius:8px;counter-increment:instruction-counter}.recipe-detail-instruction-item:before{content:counter(instruction-counter);flex-shrink:0;width:34px;height:34px;background-color:var(--color-link-success);color:var(--color-text-inverse);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.recipe-detail-instruction-text{font-size:16px;line-height:1.7;color:var(--color-text-primary);flex:1}.recipe-detail-instruction-image{margin-top:12px}.recipe-detail-instruction-image img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 2px 8px var(--color-shadow)}@media(max-width:600px){.recipe-detail-instruction-item{flex-direction:column}}.recipe-detail-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.recipe-detail-dialog{background-color:var(--color-bg-primary);border-radius:8px;padding:30px;max-width:500px;width:90%;box-shadow:0 4px 20px #0000004d}.recipe-detail-dialog h2{margin:0 0 15px;font-size:24px;color:var(--color-text-primary)}.recipe-detail-dialog p{margin:0 0 20px;color:var(--color-text-secondary);line-height:1.6}.recipe-detail-error-message{padding:12px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-button-danger);border-radius:4px;color:var(--color-button-danger);margin-bottom:20px;font-size:14px}.recipe-detail-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.recipe-detail-dialog-cancel{padding:10px 20px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:14px;transition:opacity .2s}.recipe-detail-dialog-cancel:hover:not(:disabled){opacity:.8}.recipe-detail-dialog-cancel:disabled{opacity:.6;cursor:not-allowed}.recipe-detail-dialog-confirm{padding:10px 20px;background-color:var(--color-button-danger);color:var(--color-text-inverse);border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:opacity .2s}.recipe-detail-dialog-confirm:hover:not(:disabled){opacity:.9}.recipe-detail-dialog-confirm:disabled{opacity:.6;cursor:not-allowed}.recipe-detail-log-session-btn{padding:12px 24px;background-color:var(--color-link-success);color:var(--color-text-inverse);border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;transition:opacity .2s ease;width:100%;max-width:300px;display:block;margin:0 auto}.recipe-detail-log-session-btn:hover{opacity:.9}.recipe-detail-cooking-log{display:flex;flex-direction:column;gap:16px}.recipe-detail-cooking-session{background-color:var(--color-bg-secondary);border-radius:8px;padding:20px;border-left:4px solid var(--color-link-success)}.recipe-detail-cooking-session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:12px}.recipe-detail-cooking-session-date{font-size:16px;font-weight:600;color:var(--color-text-primary)}.recipe-detail-cooking-session-rating{font-size:18px}.recipe-detail-cooking-session-details{display:flex;gap:16px;margin-bottom:12px;flex-wrap:wrap}.recipe-detail-cooking-session-time{font-size:14px;color:var(--color-text-secondary);background-color:var(--color-bg-tertiary);padding:6px 12px;border-radius:4px}.recipe-detail-cooking-session-notes{font-size:15px;line-height:1.6;color:var(--color-text-primary);white-space:pre-wrap;font-style:italic}.recipe-detail-suggestion-accept,.recipe-detail-suggestion-reject{padding:4px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:opacity .2s ease}.recipe-detail-suggestion-accept{background-color:#28a745;color:#fff}.recipe-detail-suggestion-accept:hover{opacity:.9}.recipe-detail-suggestion-reject{background-color:#dc3545;color:#fff}.recipe-detail-suggestion-reject:hover{opacity:.9}.recipe-detail-suggestions{margin-top:10px;padding-left:20px}.recipe-detail-suggestion{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-left:3px solid var(--color-button-primary);border-radius:4px;padding:10px;margin-bottom:8px}.recipe-detail-suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.9rem}.recipe-detail-suggestion-user{font-weight:500;color:var(--color-text-primary)}.recipe-detail-suggestion-date{font-size:.85rem;color:var(--color-text-secondary)}.recipe-detail-suggestion-content{margin-bottom:8px;color:var(--color-text-primary)}.recipe-detail-suggestion-actions{display:flex;gap:8px}.recipe-detail-history{margin-top:8px}.recipe-detail-history-toggle{background:none;border:none;color:var(--color-link-primary);cursor:pointer;font-size:13px;padding:4px 0;display:flex;align-items:center;gap:4px}.recipe-detail-history-toggle:hover{text-decoration:underline}.recipe-detail-history-list{margin-top:8px;padding-left:16px;border-left:2px solid var(--color-border)}.recipe-detail-history-item{margin-bottom:12px;padding:8px 12px;background-color:var(--color-bg-primary);border-radius:4px;font-size:13px}.recipe-detail-history-header{display:flex;justify-content:space-between;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--color-border)}.recipe-detail-history-user{font-weight:500;color:var(--color-text-primary)}.recipe-detail-history-date{font-size:12px;color:var(--color-text-secondary)}.recipe-detail-history-changes{display:flex;flex-direction:column;gap:4px}.recipe-detail-history-before,.recipe-detail-history-after{font-size:13px;color:var(--color-text-secondary)}.recipe-detail-history-before strong,.recipe-detail-history-after strong{color:var(--color-text-primary);margin-right:4px}.recipe-detail-cooking-mode{display:grid;grid-template-columns:280px 1fr;gap:0 32px}.recipe-detail-cooking-mode .recipe-detail-header{grid-column:1 / -1}.recipe-detail-main-content{min-width:0}.recipe-detail-sidebar{position:sticky;top:20px;align-self:start;max-height:calc(100vh - 40px);overflow-y:auto;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:20px}.recipe-detail-sidebar-title{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--color-link-success)}.recipe-detail-sidebar-note{font-size:13px;color:var(--color-text-secondary);font-style:italic;margin:0 0 12px}.recipe-detail-sidebar-group{margin-bottom:16px}.recipe-detail-sidebar-group:last-child{margin-bottom:0}.recipe-detail-sidebar-group-title{font-size:14px;font-weight:600;color:var(--color-text-secondary);margin:0 0 8px;padding-bottom:4px;border-bottom:1px dashed var(--color-border)}.recipe-detail-sidebar-list{list-style:none;padding:0;margin:0}.recipe-detail-sidebar-ingredient{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:4px 8px;padding:6px 0;border-bottom:1px solid var(--color-border);font-size:14px}.recipe-detail-sidebar-ingredient:last-child{border-bottom:none}.recipe-detail-sidebar-ingredient-name{font-weight:500;color:var(--color-text-primary);flex:1;min-width:0}.recipe-detail-sidebar-ingredient-amount{font-weight:600;color:var(--color-link-success);white-space:nowrap;font-size:13px}.recipe-detail-sidebar-ingredient-notes{width:100%;font-size:12px;color:var(--color-text-secondary);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.recipe-detail-cooking-mode{display:block}.recipe-detail-sidebar--mobile{position:static;max-height:none;margin-bottom:24px}.recipe-detail-sidebar--mobile .recipe-detail-sidebar-title{cursor:pointer;display:flex;align-items:center;justify-content:space-between;-webkit-user-select:none;user-select:none}}.editable-section-actions{display:flex;gap:8px;margin-top:12px;padding-top:8px;border-top:1px solid var(--color-border)}.editable-section-save{padding:6px 16px;background:var(--color-primary, #1976d2);color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer}.editable-section-save:hover{opacity:.9}.editable-section-save:disabled{opacity:.5;cursor:not-allowed}.editable-section-cancel{padding:6px 16px;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:4px;font-size:13px;cursor:pointer}.editable-section-cancel:hover{background:var(--color-bg-secondary)}.editable-section-error{margin-top:8px;padding:8px 12px;background:var(--color-bg-secondary);color:var(--color-error, #dc2626);border:1px solid var(--color-error, #dc2626);border-radius:4px;font-size:13px}.recipe-detail-title-input{width:100%;font-size:2rem;font-weight:700;font-family:inherit;padding:4px 8px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);box-sizing:border-box}.recipe-detail-description-input{width:100%;font-size:1rem;font-family:inherit;padding:8px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);margin-top:8px;box-sizing:border-box;resize:vertical}.recipe-detail-info-input{width:80px;padding:4px 8px;font-size:.9rem;font-family:inherit;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary)}.inline-ingredient-editor{padding:4px 0}.inline-ingredient-editor-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.inline-ingredient-editor-row{display:grid;grid-template-columns:1fr 60px 60px 1fr 24px;gap:4px;align-items:center}.inline-ingredient-editor-row input{padding:4px 6px;font-size:13px;font-family:inherit;border:1px solid var(--color-border);border-radius:3px;background:var(--color-bg-primary);color:var(--color-text-primary);min-width:0}.inline-ingredient-editor-remove{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:18px;padding:0;line-height:1}.inline-ingredient-editor-remove:hover{color:#dc2626}.inline-ingredient-editor-add{margin-top:8px;padding:4px 12px;background:transparent;border:1px dashed var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;font-size:13px;width:100%}.inline-ingredient-editor-add:hover{border-color:var(--color-primary, #1976d2);color:var(--color-primary, #1976d2)}.inline-instruction-editor{padding:4px 0}.inline-instruction-editor-list{padding-left:20px;margin:0;display:flex;flex-direction:column;gap:16px}.inline-instruction-editor-step{padding:8px 0}.inline-instruction-editor-step-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.inline-instruction-editor-header-left{display:flex;align-items:center;gap:6px}.inline-instruction-editor-move-buttons{display:flex;gap:2px}.inline-instruction-editor-move-button{background:none;border:1px solid var(--color-border);border-radius:3px;padding:1px 4px;cursor:pointer;font-size:.55rem;line-height:1;color:var(--color-text-secondary);transition:color .2s ease,border-color .2s ease}.inline-instruction-editor-move-button:hover:not(:disabled){color:var(--color-text-primary);border-color:var(--color-text-primary)}.inline-instruction-editor-move-button:disabled{opacity:.3;cursor:not-allowed}.inline-instruction-editor-step-num{font-weight:600;font-size:13px;color:var(--color-text-secondary)}.inline-instruction-editor-remove{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:18px;padding:0;line-height:1}.inline-instruction-editor-remove:hover{color:#dc2626}.inline-instruction-editor-text{width:100%;padding:8px;font-size:.95rem;font-family:inherit;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text-primary);box-sizing:border-box;resize:vertical}.inline-instruction-editor-image{margin-top:8px}.inline-instruction-editor-image-preview img{max-width:200px;border-radius:4px;display:block}.inline-instruction-editor-image-remove{margin-top:4px;padding:2px 8px;background:transparent;border:1px solid var(--color-border);border-radius:3px;font-size:12px;color:var(--color-error, #dc2626);cursor:pointer}.inline-instruction-editor-file-input{display:none}.inline-instruction-editor-upload-label{cursor:pointer}.inline-instruction-editor-upload-btn{display:inline-block;padding:4px 12px;background:transparent;border:1px dashed var(--color-border);border-radius:4px;color:var(--color-text-secondary);font-size:13px}.inline-instruction-editor-upload-btn:hover{border-color:var(--color-primary, #1976d2);color:var(--color-primary, #1976d2)}.inline-instruction-editor-upload-error{margin-top:4px;color:#dc2626;font-size:12px}.inline-instruction-editor-insert-button{display:block;width:100%;padding:4px;margin-top:8px;background:none;border:1px dashed var(--color-border);border-radius:4px;color:var(--color-text-secondary);font-size:12px;cursor:pointer;opacity:0;transition:opacity .2s ease}.inline-instruction-editor-step:hover .inline-instruction-editor-insert-button,.inline-instruction-editor-insert-button:focus{opacity:1}.inline-instruction-editor-add{margin-top:12px;padding:6px 16px;background:transparent;border:1px dashed var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;font-size:13px;width:100%}.inline-instruction-editor-add:hover{border-color:var(--color-primary, #1976d2);color:var(--color-primary, #1976d2)}.cooking-session-form-container{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:20px;margin:20px 0}.cooking-session-form-container h3{margin-top:0;margin-bottom:15px;color:var(--color-text-primary)}.cooking-session-form-error{color:var(--color-button-danger);background-color:#dc35451a;padding:10px;border-radius:4px;margin-bottom:15px}.cooking-session-form-field,.cooking-session-form-field-large{margin-bottom:15px}.cooking-session-form-label{display:block;margin-bottom:5px;color:var(--color-text-primary);font-weight:500}.cooking-session-form-input,.cooking-session-form-select,.cooking-session-form-textarea{width:100%;padding:8px;background-color:var(--color-bg-primary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:4px;font-family:inherit}.cooking-session-form-textarea{resize:vertical;min-height:80px}.cooking-session-form-buttons{display:flex;gap:10px;margin-top:20px}.cooking-session-form-button{flex:1;padding:10px 20px;background-color:var(--color-button-primary);color:var(--color-text-inverse);border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:opacity .2s ease}.cooking-session-form-button:hover:not(:disabled){opacity:.9}.cooking-session-form-button:disabled{cursor:not-allowed;opacity:.6}.cooking-session-form-button-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.cooking-session-form-button-secondary:hover:not(:disabled){background-color:var(--color-bg-secondary)}.cooking-session-form-toggle-suggestions{background:none;border:none;color:var(--color-button-primary);cursor:pointer;padding:8px 0;font-size:.95rem;text-align:left;width:100%;transition:opacity .2s ease}.cooking-session-form-toggle-suggestions:hover{opacity:.8}.cooking-session-form-suggestions{margin-top:15px;padding:15px;background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px}.cooking-session-form-suggestions-hint{margin:0 0 15px;font-size:.9rem;color:var(--color-text-secondary)}.cooking-session-form-ingredient-suggestion{margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid var(--color-border)}.cooking-session-form-ingredient-suggestion:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.cooking-session-form-ingredient-name{font-weight:500;margin-bottom:8px;color:var(--color-text-primary)}.cooking-session-form-ingredient-current{font-weight:400;font-size:.9rem;color:var(--color-text-secondary);margin-left:8px}.cooking-session-form-ingredient-inputs{display:grid;grid-template-columns:1fr 1fr 2fr;gap:8px}.cooking-session-form-input-small{width:100%}
