:root{--color-text: #1a1a1a;--color-text-secondary: #666666;--color-text-muted: #999999;--color-accent: #5a8f7b;--color-accent-hover: #4a7d6a;--color-accent-light: #e8f0ec;--color-bg: #ffffff;--color-bg-subtle: #fafafa;--color-bg-muted: #f5f5f5;--color-border: #e0e0e0;--color-border-light: #f0f0f0;--color-danger: #c45d3a;--color-danger-light: #fdf2ef;--font-sans: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-serif: Georgia, "Times New Roman", serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg-muted);color:var(--color-text);line-height:1.6}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#1a1a2e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-md);background:linear-gradient(135deg,var(--color-bg-subtle) 0%,var(--color-accent-light) 100%)}.login-card{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:0 4px 24px #00000014;width:100%;max-width:400px}.login-card h1{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--color-text);margin-bottom:var(--space-xs);text-align:center}.subtitle{text-align:center;color:var(--color-text-muted);font-size:.95rem;margin-bottom:var(--space-xl)}.form-group{margin-bottom:var(--space-lg)}.form-group label{display:block;font-weight:500;margin-bottom:var(--space-sm);color:var(--color-text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.form-group input{width:100%;padding:var(--space-md);font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s;background:var(--color-bg)}.form-group input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.form-group input:disabled{background-color:var(--color-bg-muted);cursor:not-allowed}.login-button{width:100%;padding:var(--space-md);font-size:1rem;font-weight:600;color:#fff;background-color:var(--color-accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .2s}.login-button:hover:not(:disabled){background-color:var(--color-accent-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:var(--space-lg);text-align:center;color:var(--color-text-muted);font-size:.85rem}.error-message{background:var(--color-danger-light);color:var(--color-danger);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.9rem;border-left:3px solid var(--color-danger)}.dashboard{max-width:800px;margin:0 auto;padding:var(--space-md);min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) 0;margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.dashboard-header h1{font-family:var(--font-serif);font-size:1.75rem;font-weight:400;color:var(--color-text);margin-bottom:var(--space-xs)}.dashboard-header p{color:var(--color-text-muted);font-size:.9rem}.header-actions{display:flex;align-items:center;gap:var(--space-md)}.logout-button{padding:var(--space-sm) var(--space-md);font-size:.85rem;font-weight:500;color:var(--color-text-muted);background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.logout-button:hover{border-color:var(--color-danger);color:var(--color-danger);background:transparent}.google-connection{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.google-connection .status-dot{width:8px;height:8px;border-radius:50%;background:#28a745}.connect-google-button{padding:.5rem 1rem;font-size:.85rem;font-weight:500;background:#4285f4;color:#fff;border:none;border-radius:6px;cursor:pointer;white-space:nowrap}.connect-google-button:hover{background:#3367d6}.disconnect-button{padding:.25rem .5rem;font-size:.8rem;background:transparent;color:#666;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer}.disconnect-button:hover{border-color:#d32f2f;color:#d32f2f}.google-status.loading{color:#999}.dashboard-content{display:flex;flex-direction:column;gap:1.5rem}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr}}.status-card,.info-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.status-card h2,.info-card h2{font-size:1.1rem;margin-bottom:1rem;color:#1a1a2e}.health p{margin-bottom:.5rem}.error{color:#d32f2f;background:#ffebee;padding:.75rem;border-radius:8px}.info-card p{margin-bottom:.75rem;line-height:1.6}.artifacts-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.section-title h2{font-size:1.1rem;margin-bottom:.5rem;color:#1a1a2e}.section-title .hint{color:#999;font-size:.9rem}.paste-button{padding:.625rem 1.25rem;font-size:.95rem;white-space:nowrap;flex-shrink:0}.artifacts-list{display:flex;flex-direction:column;gap:.75rem}.artifacts-list.empty{text-align:center;padding:2rem 1rem;color:#666}.artifacts-list.empty .hint{color:#999;font-size:.9rem;margin-top:.5rem}.artifact-card{background:#f9f9f9;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s;border:2px solid transparent}.artifact-card:hover{background:#f0f0f0;border-color:#1a1a2e}.artifact-preview{font-size:.95rem;line-height:1.5;color:#333;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.artifact-meta{display:flex;justify-content:space-between;font-size:.85rem;color:#999}.artifact-extract-btn{margin-top:.75rem;padding:.4rem .8rem;font-size:.85rem;background:#1a1a2e;color:#fff;border:none;border-radius:6px;cursor:pointer;width:100%}.artifact-extract-btn:hover:not(:disabled){background:#2d2d4a}.artifact-extract-btn:disabled{opacity:.6;cursor:not-allowed}.artifact-status{font-size:.8rem;padding:.15rem .5rem;border-radius:4px}.status-not-extracted{background:#f0f0f0;color:#666}.status-has-pending{background:#fff3cd;color:#856404}.status-all-approved{background:#d4edda;color:#155724}.status-all-rejected{background:#f8d7da;color:#721c24}.status-mixed{background:#e2e3e5;color:#383d41}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000}.modal-content{background:#fff;border-radius:16px;padding:1.5rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 24px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-size:1.25rem;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#666;padding:0;width:32px;height:32px}.modal-close:hover{color:#1a1a2e}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions-top{display:flex;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.modal-content textarea{width:100%;min-height:300px;resize:vertical;font-family:inherit}.char-count{text-align:right;font-size:.85rem;color:#999;margin-top:.25rem}button{padding:var(--space-sm) var(--space-lg);font-size:.95rem;font-weight:500;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .2s;background-color:var(--color-accent);color:#fff}button:hover:not(:disabled){background-color:var(--color-accent-hover)}button:disabled{opacity:.6;cursor:not-allowed}button.button-secondary{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border)}button.button-secondary:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background-color:var(--color-bg)}button.button-danger{background-color:var(--color-danger)}button.button-danger:hover:not(:disabled){background-color:#b84c2f}.artifact-detail{max-width:800px}.artifact-metadata{display:flex;justify-content:space-between;font-size:.9rem;color:#666;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.artifact-content-wrapper{max-height:50vh;overflow-y:auto;background:#f9f9f9;border-radius:8px;padding:1rem;margin-bottom:1rem}.artifact-content{font-family:inherit;font-size:.95rem;line-height:1.6;color:#333;white-space:pre-wrap;word-wrap:break-word;margin:0}.proposals-section{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e0e0e0}.proposals-section h3{font-size:1.1rem;margin-bottom:1rem;color:#1a1a2e}.proposal-card{background:#f9f9f9;border-radius:8px;padding:1rem;margin-bottom:.75rem;border-left:4px solid #1a1a2e}.proposal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.proposal-type{display:inline-block;background:#1a1a2e;color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;text-transform:uppercase}.proposal-confidence{font-size:.9rem;color:#666}.proposal-card h4{font-size:1rem;margin-bottom:.5rem;color:#1a1a2e}.proposal-ambiguities{background:#fff3cd;padding:.5rem;border-radius:4px;font-size:.9rem;margin-bottom:.5rem;color:#856404}.proposal-data{background:#fff;padding:.75rem;border-radius:4px;font-size:.85rem;overflow-x:auto;margin:0}.proposal-badges{display:flex;gap:.5rem;align-items:center}.proposal-status{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.status-pending{background:#fff3cd;color:#856404}.status-approved{background:#d4edda;color:#155724}.status-rejected{background:#f8d7da;color:#721c24}.pending-badge{margin-left:.5rem;background:#fff3cd;color:#856404;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:400}.proposal-card.proposal-approved{border-left-color:#28a745;opacity:.8}.proposal-card.proposal-rejected{border-left-color:#dc3545;opacity:.6}.proposal-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #e0e0e0}.button-approve{background-color:#28a745;color:#fff;padding:.5rem 1rem;font-size:.9rem}.button-approve:hover:not(:disabled){background-color:#218838}.button-reject{background-color:#fff;color:#dc3545;border:2px solid #dc3545;padding:.5rem 1rem;font-size:.9rem}.button-reject:hover:not(:disabled){background-color:#dc3545;color:#fff}.extract-prompt{text-align:center;padding:2rem;background:#f9f9f9;border-radius:8px;margin-bottom:1rem}.extract-prompt p{margin-bottom:1rem;color:#666}.queue-section{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 1px 4px #0000000f;border:1px solid var(--color-border-light)}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.queue-header h2{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0;text-transform:uppercase;letter-spacing:.5px}.queue-count{background:#fef3c7;color:#b45309;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);font-size:.8rem;font-weight:600}.queue-empty{text-align:center;padding:var(--space-xl) var(--space-md);color:var(--color-text-muted)}.queue-empty .hint{color:var(--color-text-muted);font-size:.85rem;margin-top:var(--space-sm)}.queue-list{display:flex;flex-direction:column;gap:var(--space-md)}.queue-item{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--space-md);border-left:3px solid var(--color-accent)}.queue-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.queue-type{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.queue-type-event{background:#e3f2fd;color:#1565c0}.queue-type-task{background:#f3e5f5;color:#7b1fa2}.queue-confidence{font-size:.85rem;color:#666}.queue-item-title{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0 0 .25rem}.queue-item-summary{font-size:.9rem;color:#666;margin:0 0 .5rem}.queue-item-ambiguities{background:#fff3cd;color:#856404;padding:.4rem .6rem;border-radius:4px;font-size:.85rem;margin-bottom:.75rem}.queue-item-actions{display:flex;gap:.5rem}.conflict-warning{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:1rem;margin-bottom:1rem}.conflict-warning h3{color:#856404;font-size:1rem;margin-bottom:.5rem}.conflict-warning p{color:#856404;margin-bottom:.5rem}.conflict-warning ul{list-style:none;padding:0;margin:0 0 1rem}.conflict-warning li{background:#fff;border-radius:4px;padding:.5rem;margin-bottom:.5rem;font-size:.9rem}.conflict-warning li strong{color:#1a1a2e}.conflict-actions{display:flex;gap:.5rem}.calendar-section,.tasks-section{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 1px 4px #0000000f;border:1px solid var(--color-border-light)}.section-header-simple{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.section-header-simple h2{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0;text-transform:uppercase;letter-spacing:.5px}.event-count,.task-count{background:var(--color-accent-light);color:var(--color-accent);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);font-size:.8rem;font-weight:600}.task-count{background:#f3e8ff;color:#7c3aed}.calendar-empty,.tasks-empty{text-align:center;padding:var(--space-xl) var(--space-md);color:var(--color-text-muted)}.calendar-empty .hint,.tasks-empty .hint{color:var(--color-text-muted);font-size:.85rem;margin-top:var(--space-sm)}.events-list,.tasks-list{display:flex;flex-direction:column;gap:var(--space-sm)}.event-card{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);border-left:3px solid var(--color-accent)}.event-card.past{opacity:.6;border-left-color:var(--color-text-muted)}.event-date{font-size:.85rem;color:var(--color-accent);font-weight:500;margin-bottom:var(--space-xs)}.event-card.past .event-date{color:var(--color-text-muted)}.event-card.google-event{border-left-color:#4285f4}.event-card.proposal-event{border-left-color:#28a745}.event-source-badge{margin-left:.5rem;padding:.1rem .4rem;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase}.event-source-badge.synced{background:#28a745;color:#fff}.event-source-badge.not-synced{background:#ffc107;color:#333}.event-card.not-synced{border-left-color:#ffc107}.sync-button{margin-top:.5rem;padding:.3rem .6rem;font-size:.8rem;background:#4285f4;color:#fff;border:none;border-radius:4px;cursor:pointer}.sync-button:hover:not(:disabled){background:#3367d6}.sync-button:disabled{opacity:.6;cursor:not-allowed}.calendar-hint{font-size:.85rem;color:#666;margin-bottom:1rem;font-style:italic}.event-title{font-size:1rem;font-weight:600;color:#1a1a2e}.event-location{font-size:.85rem;color:#666;margin-top:.25rem}.task-card{display:flex;align-items:flex-start;gap:.75rem;background:#f9f9f9;border-radius:8px;padding:.75rem 1rem}.task-card.overdue{border-left:4px solid #dc3545}.task-card.completed{opacity:.6}.task-checkbox{width:24px;height:24px;min-width:24px;border:2px solid #ccc;border-radius:50%;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;padding:0;transition:all .2s}.task-checkbox:hover:not(:disabled){border-color:#28a745;background:#d4edda}.task-checkbox.checked{background:#28a745;border-color:#28a745;color:#fff;cursor:default}.task-content{flex:1}.task-title{font-size:1rem;color:#1a1a2e}.task-card.completed .task-title{text-decoration:line-through;color:#666}.task-due{font-size:.85rem;color:#666;margin-top:.25rem}.task-due.overdue{color:#dc3545;font-weight:500}.past-events,.completed-tasks{margin-top:1rem}.past-events summary,.completed-tasks summary{cursor:pointer;color:#666;font-size:.9rem;padding:.5rem 0}.past-events summary:hover,.completed-tasks summary:hover{color:#1a1a2e}.past-events .events-list,.completed-tasks .tasks-list{margin-top:.75rem}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #e0e0e0;padding-bottom:1rem}.mode-btn{flex:1;padding:.5rem 1rem;font-size:.9rem;background:#f5f5f5;border:2px solid transparent;color:#666;border-radius:6px}.mode-btn.active{background:#1a1a2e;color:#fff}.mode-btn:hover:not(.active):not(:disabled){background:#e0e0e0}.image-drop-zone{border:2px dashed #ccc;border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background:#fafafa}.image-drop-zone:hover{border-color:#1a1a2e;background:#f5f5f5}.image-drop-zone:focus{outline:none;border-color:#1a1a2e}.image-drop-zone p{margin:0;color:#666}.image-drop-zone .hint{margin-top:.5rem;font-size:.85rem;color:#999}.image-preview-container{position:relative;background:#f5f5f5;border-radius:8px;padding:1rem;text-align:center}.image-preview{max-width:100%;max-height:300px;border-radius:4px;box-shadow:0 2px 8px #0000001a}.remove-image-btn{margin-top:.75rem;padding:.5rem 1rem;font-size:.85rem;background:#f5f5f5;color:#666;border:1px solid #ccc}.remove-image-btn:hover:not(:disabled){background:#e0e0e0;color:#333}.artifact-card-image{border-left:4px solid #9c27b0}.artifact-preview-image{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}.image-icon{width:48px;height:48px;background:#f3e5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#9c27b0}.image-label{font-size:.95rem;color:#9c27b0;font-weight:500}.artifact-image{max-width:100%;max-height:60vh;display:block;margin:0 auto;border-radius:4px}@media (max-width: 600px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{width:100%;flex-direction:column;gap:.5rem}.header-actions button,.connect-google-button,.google-connection{width:100%;justify-content:center}.logout-button{align-self:stretch}.section-header{flex-direction:column;align-items:stretch}.paste-button{width:100%}.modal-overlay{padding:0;align-items:stretch}.modal-content{max-height:100vh;height:100vh;max-width:100%;border-radius:0;display:flex;flex-direction:column}.modal-header{flex-shrink:0;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.modal-content>div:last-child{flex:1;display:flex;flex-direction:column;overflow:hidden}.modal.editorial .modal-content>div:last-child,.modal.editorial .modal-content.editorial-content>div{display:block;overflow:visible;flex:none}.modal.editorial textarea{max-height:200px;overflow-y:auto;overscroll-behavior:contain;resize:none}.modal.editorial .recipe-edit-form textarea{max-height:180px}.modal-content .form-group{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.modal-content textarea{flex:1;min-height:150px;font-size:16px}.modal-content .mode-toggle{flex-shrink:0}.modal-actions{flex-shrink:0;padding-top:1rem;border-top:1px solid #e0e0e0;margin-top:auto}.image-preview-container{flex:1;overflow-y:auto;min-height:0}.image-drop-zone{flex:1;min-height:200px;display:flex;flex-direction:column;justify-content:center}}.add-button-primary{width:100%;padding:var(--space-md);font-size:1rem;font-weight:600;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;margin-bottom:var(--space-md);transition:background-color .2s}.add-button-primary:hover{background:var(--color-accent-hover)}.uploads-section{margin-top:1.5rem}.uploads-section summary{cursor:pointer;color:#666;font-size:.9rem;padding:.75rem 0;border-top:1px solid #e0e0e0}.uploads-section summary:hover{color:#1a1a2e}.uploads-section[open] summary{margin-bottom:1rem}.connect-inbox-button{width:100%;padding:.75rem;font-size:1rem;background:#fff;color:#666;border:2px dashed #ccc;border-radius:8px;cursor:pointer;margin-bottom:1rem}.connect-inbox-button:hover{border-color:#1a1a2e;color:#1a1a2e}.inbox-connection{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.inbox-connection.connected{border-left:4px solid #28a745}.inbox-info{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.inbox-email{font-weight:500;color:#1a1a2e}.inbox-last-poll{font-size:.85rem;color:#666}.inbox-actions{display:flex;gap:.5rem}.poll-button{flex:1;padding:.5rem 1rem;font-size:.9rem;background:#1a1a2e;color:#fff}.disconnect-button{padding:.5rem 1rem;font-size:.9rem;background:#fff;color:#666;border:1px solid #ccc}.disconnect-button:hover:not(:disabled){color:#dc3545;border-color:#dc3545}.poll-result{margin-top:.75rem;padding:.5rem;background:#f5f5f5;border-radius:4px;font-size:.9rem;color:#666}.poll-result.has-new{background:#d4edda;color:#155724}.poll-errors{margin-top:.5rem}.poll-error{color:#dc3545;font-size:.85rem}input,textarea,select{font-size:16px}@supports (-webkit-touch-callout: none){input,textarea,select{font-size:16px!important}}.main-nav{display:flex;gap:0;margin-bottom:var(--space-lg);background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-xs);box-shadow:0 1px 4px #0000000f;border:1px solid var(--color-border-light)}.main-nav-button{flex:1;padding:var(--space-sm) var(--space-lg);font-size:.95rem;font-weight:500;background:transparent;color:var(--color-text-secondary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.main-nav-button.active{background:var(--color-accent);color:#fff}.main-nav-button:hover:not(.active){background:var(--color-bg-muted)}.recipes-page{display:flex;flex-direction:column;gap:1.5rem}.recipes-tabs{display:flex;gap:0;background:#f5f5f5;border-radius:8px;padding:.25rem}.recipes-tab{flex:1;padding:.625rem 1rem;font-size:.95rem;font-weight:500;background:transparent;color:#666;border:none;border-radius:6px;cursor:pointer}.recipes-tab.active{background:#fff;color:#1a1a2e;box-shadow:0 1px 3px #0000001a}.recipe-list{background:var(--color-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 1px 4px #0000000f;border:1px solid var(--color-border-light)}.recipe-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.recipe-list-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;color:var(--color-text);margin:0}.add-recipe-button{padding:var(--space-sm) var(--space-md);font-size:.85rem;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm)}.add-recipe-button:hover{background:var(--color-accent-hover)}.category-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-light)}.category-pill{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:.85rem;font-weight:500;background:var(--color-bg-muted);color:var(--color-text-secondary);border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s}.category-pill:hover:not(.active){background:var(--color-border-light)}.category-pill.active{color:#fff;border-color:transparent}.category-pill.favorites{background:#fef2f2;color:#dc2626}.category-pill.favorites.active{background:#dc2626;color:#fff}.category-pill.clear{background:transparent;color:var(--color-text-muted);border:1px dashed var(--color-border)}.category-pill.clear:hover{color:var(--color-text-secondary);border-color:var(--color-text-muted)}.category-icon{font-size:.9rem}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.recipe-card{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all .2s;border:1px solid var(--color-border-light)}.recipe-card:hover{background:var(--color-bg);border-color:var(--color-accent);box-shadow:0 2px 8px #5a8f7b26}.recipe-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm)}.recipe-title{font-family:var(--font-serif);font-size:1.1rem;font-weight:400;color:var(--color-text);margin:0;flex:1;line-height:1.3}.recipe-title-original{font-size:.8rem;color:var(--color-text-muted);font-style:italic;margin:var(--space-xs) 0 0 0}.recipe-description{font-size:.85rem;color:var(--color-text-secondary);margin:var(--space-sm) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.recipe-meta{display:flex;flex-wrap:wrap;gap:var(--space-md);margin:var(--space-sm) 0;font-size:.8rem;color:var(--color-text-muted)}.meta-item{display:inline-flex;align-items:center;gap:var(--space-xs)}.recipe-categories{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.recipe-category-tag{display:inline-flex;align-items:center;gap:.15rem;padding:.15rem .4rem;font-size:.7rem;font-weight:500;color:#fff;border-radius:var(--radius-sm)}.tag-icon{font-size:.75rem}.favorite-button{background:transparent;border:none;font-size:1.2rem;padding:var(--space-xs);cursor:pointer;color:var(--color-border);line-height:1}.favorite-button:hover{color:#e53e3e;background:transparent}.favorite-button.is-favorite{color:#e53e3e}.add-recipe-modal{max-width:700px;max-height:90vh;display:flex;flex-direction:column}.add-recipe-modal .modal-content{max-width:700px;flex:1;overflow-y:auto}.add-recipe-modal .review-content{overflow-y:visible}.source-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--space-md)}.source-tab{flex:1;padding:var(--space-sm) var(--space-md);font-size:.9rem;font-weight:500;background:var(--color-bg-muted);color:var(--color-text-secondary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.source-tab.active{background:var(--color-accent);color:#fff}.source-tab:hover:not(.active){background:var(--color-border-light)}.image-input,.url-input,.text-input{margin-bottom:1rem}.select-image-button{width:100%;padding:1rem;background:#f5f5f5;color:#666;border:2px dashed #ccc;border-radius:8px}.select-image-button:hover{border-color:#1a1a2e;color:#1a1a2e}.image-input .image-preview{margin-top:1rem;text-align:center}.image-input .image-preview img{max-width:100%;max-height:250px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.image-previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-top:1rem;max-height:250px;overflow-y:auto;padding:.5rem;background:#f8f8f8;border-radius:8px}.image-preview-item{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 1px 3px #0000001a}.image-preview-item img{width:100%;height:100%;object-fit:cover}.image-preview-item .remove-image-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;padding:0;opacity:0;transition:opacity .15s ease}.image-preview-item:hover .remove-image-btn{opacity:1}@media (hover: none){.image-preview-item .remove-image-btn{opacity:1}}.recipe-url-input,.recipe-text-input{width:100%;padding:.75rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px}.recipe-text-input{min-height:200px;resize:vertical}.input-hint{margin-top:.5rem;font-size:.85rem;color:#999}.extract-button{background:#1a1a2e;color:#fff}.review-content{position:relative}.top-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem;background:#f5f5f5;border-radius:8px;position:sticky;top:0;z-index:10}.top-actions .back-button{background:#fff;color:#1a1a2e;border:1px solid #ccc}.top-actions .save-button{background:#22c55e;color:#fff}.confidence-badge{padding:.35rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;color:#fff}.extraction-warnings{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.warnings-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;color:#92400e}.warning-icon{font-size:1.1rem}.extraction-warnings ul{margin:0;padding-left:1.5rem;color:#78350f}.extraction-warnings li{margin:.25rem 0;font-size:.9rem}.recipe-preview{background:#f9f9f9;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.recipe-preview h3{font-size:1.2rem;margin:0 0 .5rem;color:#1a1a2e}.recipe-preview .original-title{font-size:.9rem;color:#999;font-style:italic;margin:0 0 .75rem}.recipe-preview .description{font-size:.95rem;color:#666;margin-bottom:1rem}.recipe-meta-preview{display:flex;gap:1rem;margin-bottom:1rem;font-size:.85rem;color:#666}.ingredients-preview,.instructions-preview{margin-top:1rem}.ingredients-preview h4,.instructions-preview h4{font-size:.95rem;margin-bottom:.5rem;color:#1a1a2e}.ingredients-preview ul,.instructions-preview ol{margin:0;padding-left:1.25rem}.ingredients-preview ul.ingredients-two-column{display:grid;grid-template-columns:1fr 1fr;gap:.25rem 1rem;padding-left:0;list-style:none}.ingredients-preview li,.instructions-preview li{font-size:.9rem;color:#666;margin-bottom:.25rem}.ingredients-two-column li{display:flex;flex-wrap:wrap;gap:.25rem}.ingredients-two-column .ing-amount{font-weight:500;color:#1a1a2e;min-width:60px}.ingredients-two-column .ing-name{flex:1}.ingredients-preview .original{color:#999;font-size:.85rem;width:100%}.ingredient-group-preview{margin-bottom:.75rem}.ingredient-group-preview .group-label{font-size:.85rem;font-weight:600;color:#666;margin:.5rem 0 .25rem;font-style:italic}.ingredients-preview .more,.instructions-preview .more{color:#999;font-style:italic}@media (max-width: 500px){.ingredients-preview ul.ingredients-two-column{grid-template-columns:1fr}}.category-selection{margin-bottom:1rem}.category-selection h4{font-size:.95rem;margin-bottom:.75rem;color:#1a1a2e}.category-chips{display:flex;flex-wrap:wrap;gap:.5rem}.category-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;font-size:.85rem;font-weight:500;background:#f5f5f5;color:#666;border:2px solid transparent;border-radius:20px;cursor:pointer}.category-chip:hover:not(.selected){background:#e8e8e8}.category-chip.selected{color:#fff}.recipe-detail-modal{max-width:800px}.recipe-detail-modal .modal-content.recipe-content{max-height:none;overflow-y:visible}.recipe-detail-modal .modal-header{flex-wrap:wrap;gap:.5rem}.recipe-detail-modal .header-left{flex:1;min-width:200px}.recipe-detail-modal .header-left h2{margin-bottom:.25rem}.language-toggle{padding:.3rem .75rem;font-size:.8rem;background:#f5f5f5;color:#666;border:1px solid #ccc;border-radius:4px}.language-toggle:hover{background:#e8e8e8}.header-actions{display:flex;align-items:center;gap:.5rem}.recipe-content .recipe-description{font-size:1rem;color:#666;margin-bottom:1rem}.recipe-content .recipe-categories{margin-bottom:1rem}.category-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;font-size:.8rem;font-weight:500;color:#fff;border-radius:4px;margin-right:.35rem}.recipe-meta-info{display:flex;gap:1.5rem;padding:1rem;background:#f9f9f9;border-radius:8px;margin-bottom:1.5rem}.recipe-meta-info .meta-item{display:flex;flex-direction:column;align-items:center}.recipe-meta-info .meta-label{font-size:.8rem;color:#999;text-transform:uppercase}.recipe-meta-info .meta-value{font-size:1.1rem;font-weight:600;color:#1a1a2e}.recipe-section{margin-bottom:1.5rem}.recipe-section h3{font-size:1.1rem;color:#1a1a2e;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.ingredients-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.ingredients-section .section-header h3{margin:0;border:none;padding:0}.add-to-shopping-button{padding:.4rem .75rem;font-size:.8rem;background:#28a745;color:#fff}.add-to-shopping-button:hover{background:#218838}.ingredients-list{list-style:none;padding:0;margin:0}.ingredient-item{display:flex;gap:.75rem;padding:.5rem 0;border-bottom:1px solid #f0f0f0}.ingredient-amount{min-width:80px;color:#666;font-size:.9rem}.ingredient-name{flex:1;font-size:.95rem;color:#333}.ingredient-group{margin-bottom:1rem}.ingredient-group:last-child{margin-bottom:0}.ingredient-group-header{font-size:.95rem;font-weight:600;color:#1a1a2e;margin:.75rem 0 .5rem;padding-bottom:.25rem;border-bottom:1px dashed #ccc}.ingredient-group:first-child .ingredient-group-header{margin-top:0}.instructions-list{padding-left:1.5rem;margin:0}.instruction-step{padding:.5rem 0;line-height:1.6;color:#333}.notes-section p{background:#fff9e6;padding:1rem;border-radius:8px;border-left:4px solid #ffc107;color:#666}.recipe-actions{padding-top:1rem;border-top:1px solid #e0e0e0}.delete-button{background:transparent;color:#dc3545;border:2px solid #dc3545;padding:.5rem 1rem;font-size:.9rem}.delete-button:hover{background:#dc3545;color:#fff}.confirm-delete{display:flex;align-items:center;gap:.75rem}.confirm-delete span{color:#dc3545;font-weight:500}.confirm-yes{background:#dc3545;color:#fff;padding:.4rem .75rem;font-size:.85rem}.confirm-no{background:#f5f5f5;color:#666;padding:.4rem .75rem;font-size:.85rem}.recipe-edit-form{display:flex;flex-direction:column;gap:1rem}.edit-title-input{font-size:1.25rem;font-weight:600;padding:.5rem;border:2px solid #e0e0e0;border-radius:8px;width:100%}.edit-section{display:flex;flex-direction:column;gap:.5rem}.edit-section label{font-size:.9rem;font-weight:500;color:#666}.edit-section textarea,.edit-section input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;font-family:inherit}.edit-section textarea{resize:vertical}.edit-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.edit-field{display:flex;flex-direction:column;gap:.35rem}.edit-field label{font-size:.85rem;font-weight:500;color:#666}.edit-field input,.edit-field select{padding:.6rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem}.edit-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.edit-button{padding:.4rem .75rem;font-size:.85rem;background:#f5f5f5;color:#1a1a2e;border:1px solid #ccc}.edit-button:hover{background:#e8e8e8}.recipe-source-info{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.source-tag,.cuisine-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .75rem;background:#f0f0f0;color:#666;font-size:.85rem;border-radius:16px}.difficulty-tag{padding:.35rem .75rem;font-size:.85rem;font-weight:500;border-radius:16px}.difficulty-easy{background:#d4edda;color:#155724}.difficulty-medium{background:#fff3cd;color:#856404}.difficulty-hard{background:#f8d7da;color:#721c24}.comments-section{margin-top:2rem}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.comment{background:#f9f9f9;border-radius:8px;padding:.75rem 1rem}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.comment-author{font-weight:600;color:#1a1a2e;font-size:.9rem}.comment-date{font-size:.8rem;color:#999}.comment-delete{margin-left:auto;background:transparent;color:#999;border:none;font-size:1.1rem;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.comment-delete:hover{color:#dc3545;background:transparent}.comment-content{font-size:.95rem;color:#444;margin:0;white-space:pre-wrap}.no-comments{color:#999;font-style:italic;font-size:.9rem}.add-comment{display:flex;gap:.5rem}.add-comment textarea{flex:1;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;font-family:inherit;resize:none}.add-comment button{padding:.75rem 1rem;background:#1a1a2e;color:#fff;white-space:nowrap}.add-comment button:disabled{background:#ccc}.shopping-list-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014}.shopping-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.shopping-list-header h2{font-size:1.25rem;color:#1a1a2e;margin:0}.new-list-button{padding:.5rem 1rem;font-size:.9rem}.list-tabs{display:flex;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0;overflow-x:auto}.list-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;background:#f5f5f5;color:#666;border:none;border-radius:6px;cursor:pointer;white-space:nowrap}.list-tab.active{background:#1a1a2e;color:#fff}.list-tab .item-count{font-size:.8rem;opacity:.8}.new-list-form{display:flex;gap:.5rem;margin-bottom:1rem}.new-list-form input{flex:1;padding:.5rem .75rem;border:2px solid #e0e0e0;border-radius:6px}.new-list-form button{padding:.5rem 1rem;font-size:.9rem}.add-item-row{display:flex;gap:.5rem;margin-bottom:1.5rem}.add-item-row input{flex:1;padding:.5rem .75rem;border:2px solid #e0e0e0;border-radius:6px}.add-item-row button{padding:.5rem 1rem;font-size:.9rem}.from-recipes-button{background:#f5f5f5;color:#666;border:1px solid #ccc}.from-recipes-button:hover{background:#e8e8e8}.items-by-category{display:flex;flex-direction:column;gap:1.5rem}.category-group{border-bottom:1px solid #f0f0f0;padding-bottom:1rem}.category-header{font-size:.9rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.75rem;letter-spacing:.5px}.item-list{list-style:none;padding:0;margin:0}.shopping-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f5f5f5}.shopping-item.checked{opacity:.5}.item-checkbox{display:flex;align-items:center;gap:.75rem;flex:1;cursor:pointer}.item-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.item-name{flex:1;font-size:.95rem;color:#333}.shopping-item.checked .item-name{text-decoration:line-through}.item-amount{font-size:.85rem;color:#888;margin-left:.5rem}.delete-item-button{background:transparent;border:none;color:#ccc;font-size:1.25rem;padding:.25rem;cursor:pointer;line-height:1}.delete-item-button:hover{color:#dc3545}.empty-list{text-align:center;padding:2rem;color:#999}.list-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}.clear-checked-button{background:#f5f5f5;color:#666;border:1px solid #ccc;padding:.5rem 1rem;font-size:.9rem}.delete-list-button{background:transparent;color:#dc3545;border:1px solid #dc3545;padding:.5rem 1rem;font-size:.9rem}.delete-list-button:hover{background:#dc3545;color:#fff}.add-from-recipes-modal{max-width:500px}.recipe-select-list{list-style:none;padding:0;margin:0;max-height:300px;overflow-y:auto}.recipe-select-list li{padding:.5rem 0;border-bottom:1px solid #f0f0f0}.recipe-select-list label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.recipe-select-list input[type=checkbox]{width:18px;height:18px}.empty-state{text-align:center;padding:3rem 1rem;color:#666}.empty-state p{margin-bottom:1rem}.add-first-button{padding:.75rem 1.5rem}.modal{background:var(--color-bg);border-radius:var(--radius-lg);max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000026;width:100%;max-width:600px}.modal .modal-header{padding:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;background:var(--color-bg);z-index:10;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal .modal-header h2{font-family:var(--font-serif);font-weight:400}.modal .modal-content{padding:var(--space-lg);box-shadow:none;border-radius:0;max-height:none;overflow-y:visible}.modal .modal-actions{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light);margin-top:0}@media (max-width: 600px){.recipe-grid{grid-template-columns:1fr}.category-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.75rem;-webkit-overflow-scrolling:touch}.category-pill{flex-shrink:0}.recipe-meta-info{flex-wrap:wrap;gap:1rem}.add-item-row{flex-wrap:wrap}.add-item-row input{width:100%;flex:none}.add-item-row button{flex:1}.list-tabs{flex-wrap:nowrap;-webkit-overflow-scrolling:touch}}.modal.editorial{max-width:800px;background:var(--color-bg)}.modal.editorial .modal-header.editorial-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.modal.editorial .modal-content.editorial-content{padding:var(--space-lg);max-width:720px;margin:0 auto}.back-link{background:none;border:none;color:var(--color-accent);font-size:.9rem;font-weight:500;padding:var(--space-xs) 0;cursor:pointer}.back-link:hover{color:var(--color-accent-hover);background:none}.header-actions .icon-btn{background:none;border:none;font-size:1.5rem;padding:var(--space-xs);color:var(--color-text-muted);cursor:pointer;line-height:1}.header-actions .icon-btn:hover{color:var(--color-text);background:none}.header-actions .icon-btn.favorite.is-favorite{color:#e53e3e}.header-actions .text-btn{background:none;border:none;color:var(--color-accent);font-size:.9rem;font-weight:500;padding:var(--space-xs) var(--space-sm);cursor:pointer}.header-actions .text-btn:hover{color:var(--color-accent-hover);background:none}.recipe-title-section{text-align:center;margin-bottom:var(--space-lg)}.recipe-title-editorial{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--color-text);margin:0 0 var(--space-xs) 0;line-height:1.2}.recipe-source{font-size:.9rem;color:var(--color-text-muted);margin:0 0 var(--space-sm) 0;font-style:italic}.recipe-meta-line{display:flex;justify-content:center;gap:var(--space-lg);font-size:.85rem;color:var(--color-text-secondary);margin-top:var(--space-sm)}.recipe-meta-line span{display:inline-flex;align-items:center;gap:var(--space-xs)}.recipe-meta-line .difficulty{text-transform:capitalize}.language-toggle-editorial{background:var(--color-bg-muted);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.75rem;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);margin-top:var(--space-sm);cursor:pointer}.language-toggle-editorial:hover{background:var(--color-bg-subtle)}.recipe-divider{height:1px;background:var(--color-border-light);margin:var(--space-lg) 0}.recipe-intro{display:flex;gap:var(--space-lg);align-items:flex-start}.recipe-thumbnail{flex-shrink:0;width:120px;height:120px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;position:relative;box-shadow:0 2px 8px #0000001a}.recipe-thumbnail img{width:100%;height:100%;object-fit:cover}.recipe-thumbnail .expand-hint{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#fff;font-size:.7rem;text-align:center;padding:var(--space-xs);opacity:0;transition:opacity .2s}.recipe-thumbnail:hover .expand-hint{opacity:1}.recipe-images-row{display:flex;gap:var(--space-sm);flex-wrap:wrap}.recipe-images-row .recipe-thumbnail{width:100px;height:100px}.recipe-images-row .recipe-thumbnail:first-child{width:120px;height:120px}.recipe-description-editorial{flex:1;font-size:1rem;color:var(--color-text-secondary);line-height:1.6;margin:0}.recipe-two-column{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-xl)}.recipe-column{min-width:0}.section-title{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0 0 var(--space-md) 0;letter-spacing:.5px;text-transform:uppercase}.ingredient-group-editorial{margin-bottom:var(--space-md)}.ingredient-group-title{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--space-sm) 0;font-style:italic}.ingredients-list-editorial{list-style:none;padding:0;margin:0}.ingredient-item-editorial{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background-color .15s}.ingredient-item-editorial:hover{background-color:var(--color-bg-subtle)}.ingredient-item-editorial.selected{background-color:var(--color-accent-light)}.ingredient-check{width:18px;height:18px;min-width:18px;border:2px solid var(--color-border);border-radius:50%;margin-top:2px;transition:all .15s}.ingredient-check.checked{background-color:var(--color-accent);border-color:var(--color-accent);position:relative}.ingredient-check.checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.7rem;font-weight:700}.ingredient-text{flex:1;font-size:.9rem;line-height:1.4}.ingredient-text .ing-amount{font-weight:600;color:var(--color-text);margin-right:var(--space-xs)}.ingredient-text .ing-unit{color:var(--color-text-secondary);margin-right:var(--space-xs)}.ingredient-text .ing-name{color:var(--color-text)}.shopping-actions{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light)}.selection-count{font-size:.85rem;color:var(--color-accent);font-weight:500}.method-list-editorial{list-style:none;padding:0;margin:0;counter-reset:method-counter}.method-step{display:flex;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light)}.method-step:last-child{border-bottom:none}.step-number{flex-shrink:0;width:28px;height:28px;background-color:var(--color-accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600}.step-text{flex:1;font-size:.95rem;line-height:1.6;color:var(--color-text)}.recipe-notes-section{margin-bottom:var(--space-lg)}.notes-text{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;padding:var(--space-md);background:#fffbeb;border-left:3px solid #f59e0b;border-radius:var(--radius-sm)}.recipe-comments-section{margin-bottom:var(--space-lg);padding-bottom:var(--space-xl)}.muted{color:var(--color-text-muted);font-size:.9rem;font-style:italic}.comments-list-editorial{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.comment-editorial{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--space-md)}.comment-meta{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.comment-author{font-weight:600;font-size:.85rem;color:var(--color-text)}.comment-date{font-size:.8rem;color:var(--color-text-muted)}.comment-editorial .comment-delete{margin-left:auto;background:none;border:none;color:var(--color-text-muted);font-size:1.1rem;padding:0;cursor:pointer;line-height:1}.comment-editorial .comment-delete:hover{color:var(--color-danger);background:none}.comment-text{font-size:.9rem;color:var(--color-text-secondary);line-height:1.5;margin:0;white-space:pre-wrap}.add-comment-editorial{display:flex;gap:var(--space-sm)}.add-comment-editorial textarea{flex:1;padding:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;resize:none}.recipe-footer{text-align:center}.confirm-delete-editorial{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.confirm-delete-editorial span{color:var(--color-danger);font-weight:500}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-md)}.image-modal{position:relative;max-width:90vw;max-height:90vh}.image-modal img{max-width:100%;max-height:85vh;border-radius:var(--radius-md);box-shadow:0 8px 32px #0000004d}.image-modal-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:var(--space-xs)}.image-modal-close:hover{color:#ccc;background:none}.image-modal-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-top:var(--space-md)}.image-nav-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.image-nav-btn:hover{background:#ffffff4d}.image-counter{color:#fff;font-size:.9rem}.edit-images-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.edit-image-item{position:relative;width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden}.edit-image-item img{width:100%;height:100%;object-fit:cover}.delete-image-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.delete-image-btn:hover{background:var(--color-danger)}.add-image-btn{width:80px;height:80px;border:2px dashed var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);cursor:pointer;color:var(--color-text-muted);font-size:.75rem;transition:all .2s}.add-image-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.add-image-btn .plus-icon{font-size:1.5rem;line-height:1}.btn-primary{background-color:var(--color-accent);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-primary:hover:not(:disabled){background-color:var(--color-accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary-sm{background-color:var(--color-accent);color:#fff;border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;cursor:pointer}.btn-primary-sm:hover:not(:disabled){background-color:var(--color-accent-hover)}.btn-primary-sm:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:var(--color-bg-muted);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:500;cursor:pointer}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg-subtle)}.btn-link{background:none;border:none;color:var(--color-accent);font-size:.85rem;padding:var(--space-xs);cursor:pointer}.btn-link:hover{color:var(--color-accent-hover);background:none;text-decoration:underline}.btn-link-danger{background:none;border:none;color:var(--color-danger);font-size:.9rem;padding:var(--space-xs);cursor:pointer}.btn-link-danger:hover{background:none;text-decoration:underline}.btn-danger{background-color:var(--color-danger);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:500;cursor:pointer}.btn-danger:hover:not(:disabled){background-color:#b84c2f}@media (max-width: 768px){.recipe-title-editorial{font-size:1.5rem}.recipe-two-column{grid-template-columns:1fr;gap:var(--space-lg)}.recipe-intro{flex-direction:column;align-items:center;text-align:center}.recipe-thumbnail{width:150px;height:150px}.recipe-meta-line{flex-wrap:wrap;gap:var(--space-sm)}.modal.editorial .modal-content.editorial-content{padding:var(--space-md)}.shopping-actions{flex-wrap:wrap}.modal.editorial{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;max-height:100%;border-radius:0;display:flex;flex-direction:column;overflow:hidden}.modal.editorial .modal-header.editorial-header{flex-shrink:0;border-radius:0;position:sticky;top:0;z-index:10;background:var(--color-bg)}.modal.editorial .modal-content.editorial-content{flex:1 1 auto;overflow-y:scroll!important;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:120px;min-height:0}.modal.editorial .modal-content.editorial-content>div{overflow:visible}.modal.editorial .recipe-edit-form{padding-bottom:var(--space-xl);overflow:visible}.modal.editorial .recipe-edit-form .edit-actions{display:none}}@media (max-width: 480px){.recipe-title-editorial{font-size:1.3rem}.section-title{font-size:1rem}.step-number{width:24px;height:24px;font-size:.75rem}.recipe-thumbnail{width:120px;height:120px}}.image-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-bg-muted);color:var(--color-text-muted);font-size:.875rem;width:100%;height:100%;min-height:80px;border-radius:var(--radius-sm)}.image-placeholder.large{min-height:200px;font-size:1rem}
