: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;min-height:100dvh;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;min-height:100dvh;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;min-height:100dvh}.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)}.home-link{text-decoration:none;color:inherit}.home-link:hover h1{color:var(--color-accent)}.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;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;overflow:hidden}.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}.list-selection-modal{max-width:400px}.list-selection-modal .modal-header h3{font-size:1.1rem;margin:0;color:#1a1a2e}.list-selection-modal .modal-body{display:flex;flex-direction:column;gap:.5rem}.list-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.list-option{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.list-option:hover{background:#e8e8e8;border-color:#ccc}.list-option .list-name{font-weight:500;color:#1a1a2e}.list-option .list-count{font-size:.85rem;color:#666}.new-list-option{background:#fff;border-style:dashed;color:#4a6fa5;justify-content:center}.new-list-option:hover{background:#f0f4f8}.new-list-form{display:flex;flex-direction:column;gap:.5rem}.new-list-form input{padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.new-list-buttons{display:flex;gap:.5rem}.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-detail-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0}.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}.queue-item-edit{display:flex;flex-direction:column;gap:.75rem;padding-top:.5rem}.edit-field{display:flex;flex-direction:column;gap:.25rem}.edit-field label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.edit-field input[type=text],.edit-field input[type=date],.edit-field input[type=time]{padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;background:var(--color-bg)}.edit-field input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-light)}.edit-field-row{display:flex;gap:.75rem}.edit-field-row .edit-field{flex:1}.edit-field-checkbox{display:flex;align-items:center}.edit-field-checkbox label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text);cursor:pointer}.edit-field-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.conflict-warning{background:linear-gradient(135deg,#fff8e1,#fff3cd);border:2px solid #ffc107;border-radius:12px;padding:1.25rem;margin-bottom:1rem;box-shadow:0 2px 8px #ffc10733}.conflict-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.conflict-icon{font-size:1.25rem}.conflict-warning h3{color:#856404;font-size:1rem;font-weight:600;margin:0}.conflict-proposal{color:#5d4e37;margin-bottom:.75rem;font-size:.95rem}.conflict-list{list-style:none;padding:0;margin:0 0 .75rem}.conflict-list li{background:#fff;border-radius:8px;padding:.75rem;margin-bottom:.5rem;border-left:3px solid #dc3545}.conflict-event-title{font-weight:600;color:#1a1a2e;margin-bottom:.25rem}.conflict-event-time{font-size:.85rem;color:#666}.conflict-hint{font-size:.85rem;color:#6d5f4e;font-style:italic;margin-bottom:1rem}.conflict-actions{display:flex;gap:.5rem;flex-wrap:wrap}.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}.event-actions{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.event-actions button{padding:.3rem .6rem;font-size:.8rem;min-height:32px}.event-edit{display:flex;flex-direction:column;gap:.75rem}.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-delete{width:28px;height:28px;min-width:28px;border:none;border-radius:50%;background:transparent;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding:0;transition:all .2s}.task-delete:hover:not(:disabled){background:var(--color-danger-light);color:var(--color-danger)}.task-delete:disabled{opacity:.5;cursor:not-allowed}.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;touch-action:none;overscroll-behavior:none}.modal-content{max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;max-width:100%;border-radius:0;display:flex;flex-direction:column;overflow:hidden}.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-content.artifact-detail{touch-action:none;overflow:hidden!important}.modal-content.artifact-detail .artifact-detail-body{flex:1;overflow-y:scroll!important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;display:block;min-height:0;max-height: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}}body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.main-nav,.dashboard-header,.modal-header{padding-left:max(var(--space-md),env(safe-area-inset-left));padding-right:max(var(--space-md),env(safe-area-inset-right))}.modal-actions,.list-actions{padding-bottom:max(var(--space-md),env(safe-area-inset-bottom))}.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;text-decoration:none;text-align:center}.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;text-decoration:none;text-align:center}.recipes-tab.active{background:#fff;color:#1a1a2e;box-shadow:0 1px 3px #0000001a}.recipe-list{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:none;border:none}.recipe-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.recipe-header-actions{display:flex;align-items:center;gap:var(--space-md)}.recipe-list-header h2{font-family:var(--font-serif);font-size:1.1rem;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-xs);margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light)}.category-pill{display:inline-flex;align-items:center;gap:.15rem;padding:.2rem .5rem;font-size:.8rem;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(200px,1fr));gap:var(--space-sm)}.recipe-card{background:var(--color-bg-subtle);border-radius:var(--radius-sm);padding:var(--space-sm);cursor:pointer;transition:all .15s;border:1px solid var(--color-border-light)}.recipe-card:hover{background:var(--color-bg);border-color:var(--color-accent);box-shadow:0 1px 4px #5a8f7b1f}.recipe-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-xs)}.recipe-title{font-family:var(--font-serif);font-size:.95rem;font-weight:500;color:var(--color-text);margin:0;flex:1;line-height:1.25}.recipe-title-original{font-size:.75rem;color:var(--color-text-muted);font-style:italic;margin:2px 0 0}.recipe-description{font-size:.8rem;color:var(--color-text-secondary);margin:var(--space-xs) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.recipe-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-xs) 0;font-size:.75rem;color:var(--color-text-muted)}.meta-item{display:inline-flex;align-items:center;gap:2px}.recipe-categories{display:flex;flex-wrap:wrap;gap:3px;margin-top:var(--space-xs)}.recipe-category-tag{display:inline-flex;align-items:center;gap:.1rem;padding:.1rem .3rem;font-size:.65rem;font-weight:500;color:#fff;border-radius:3px}.tag-icon{font-size:.65rem}.favorite-button{background:transparent;border:none;font-size:1rem;padding:2px;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}.label-with-action{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.restore-btn{background:none;border:none;color:#06c;font-size:.8rem;cursor:pointer;padding:.25rem .5rem;text-decoration:underline}.restore-btn:hover{color:#049}.warning-text{font-size:.8rem;color:#c60;margin:.25rem 0 0}.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:1rem;box-shadow:0 2px 8px #00000014}.shopping-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.shopping-list-header h2{font-size:1.1rem;color:#1a1a2e;margin:0}.new-list-button{padding:.4rem .75rem;font-size:.85rem}.list-tabs{display:flex;gap:.4rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0;overflow-x:auto}.list-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.85rem;background:#f5f5f5;color:#666;border:none;border-radius:6px;cursor:pointer;white-space:nowrap;min-height:44px}.list-tab.active{background:#1a1a2e;color:#fff}.list-tab-content{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.list-tab-name{font-weight:500}.list-tab-date{font-size:.7rem;opacity:.7}.list-tab .item-count{font-size:.75rem;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:.4rem;margin-bottom:1rem}.add-item-row input{flex:1;padding:.4rem .6rem;border:2px solid #e0e0e0;border-radius:6px;font-size:16px}.add-item-row button{padding:.4rem .75rem;font-size:.85rem}.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}.category-group{margin-top:.75rem}.category-group:first-child{margin-top:0}.category-header{font-size:.7rem;font-weight:600;color:#999;text-transform:uppercase;margin-bottom:.25rem;letter-spacing:.5px}.item-list{list-style:none;padding:0;margin:0}.shopping-item{display:flex;align-items:center;justify-content:space-between;padding:2px .5rem;margin:0 -.5rem;min-height:44px;transition:background-color .15s}.shopping-item:active{background-color:#f5f5f5}.shopping-item.checked{opacity:.6}.item-checkbox{display:flex;align-items:center;gap:.5rem;flex:1;cursor:pointer;padding:0}.item-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.item-name{flex:1;font-size:.875rem;color:#333}.shopping-item.checked .item-name{text-decoration:line-through}.item-amount{font-size:.8rem;color:#888;margin-left:.4rem}.item-prep,.bulk-item-prep{font-size:.8rem;color:#666;font-style:italic}.delete-item-button{background:transparent;border:none;color:#ccc;font-size:1.25rem;padding:.25rem;cursor:pointer;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.delete-item-button:hover{color:#dc3545}.delete-item-button:focus{outline:none}.delete-item-button:active{color:#dc3545;transform:scale(.95)}@media(hover:none){.delete-item-button:hover{color:#bbb}.delete-item-button:active{color:#dc3545}}.empty-list{text-align:center;padding:1.5rem;color:#999}.list-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid #e0e0e0}.clear-checked-button{background:#f5f5f5;color:#666;border:1px solid #ccc;padding:.4rem .75rem;font-size:.85rem}.delete-list-button{background:transparent;color:#dc3545;border:1px solid #dc3545;padding:.4rem .75rem;font-size:.85rem}.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}.ingredient-select-actions{display:flex;gap:1rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.text-button{background:none;border:none;color:var(--color-accent);cursor:pointer;padding:.25rem;font-size:.85rem}.text-button:hover{text-decoration:underline}.ingredient-select-list{list-style:none;padding:0;margin:0;max-height:50vh;overflow-y:auto}.ingredient-select-item{display:flex;flex-direction:column;padding:.4rem 0;border-bottom:1px solid #f5f5f5;min-height:44px;justify-content:center}.ingredient-select-item label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.ingredient-select-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0}.ingredient-select-name{flex:1;font-size:.9rem}.ingredient-select-amount{font-size:.8rem;color:#666}.ingredient-select-source{font-size:.7rem;color:#999;margin-left:1.6rem;margin-top:.15rem}.bulk-add-modal{max-width:500px}.bulk-add-button{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius);padding:.5rem 1rem;cursor:pointer;font-size:.9rem;min-height:44px}.bulk-add-button:hover{opacity:.9}.bulk-input-hint{color:#666;font-size:.85rem;margin-bottom:.75rem;line-height:1.4}.bulk-input-textarea{width:100%;min-height:150px;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:16px;font-family:inherit;resize:vertical;box-sizing:border-box}.bulk-input-textarea:focus{outline:none;border-color:var(--color-accent)}.bulk-error{color:var(--color-error, #dc3545);font-size:.85rem;margin-top:.5rem}.bulk-select-actions{display:flex;gap:1rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.bulk-items-list{max-height:50vh;overflow-y:auto}.bulk-category-group{margin-bottom:1rem}.bulk-category-header{font-size:.8rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;padding-bottom:.25rem;border-bottom:1px solid #e0e0e0}.bulk-category-group ul{list-style:none;padding:0;margin:0}.bulk-item-row{padding:.4rem 0;border-bottom:1px solid #f5f5f5;min-height:44px;display:flex;align-items:center}.bulk-item-row label{display:flex;align-items:center;gap:.5rem;cursor:pointer;flex:1}.bulk-item-row input[type=checkbox]{width:18px;height:18px;flex-shrink:0}.bulk-item-name{flex:1;font-size:.9rem}.bulk-item-amount{font-size:.8rem;color:#666;margin-left:auto}.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){.category-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--space-xs);-webkit-overflow-scrolling:touch}.category-pill{flex-shrink:0}.recipe-meta-info{flex-wrap:wrap;gap:.5rem}.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:700px;background:var(--color-bg)}.modal.editorial .modal-header.editorial-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light)}.modal.editorial .modal-content.editorial-content{padding:var(--space-sm) var(--space-md);max-width:680px;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-sm)}.recipe-title-editorial{font-family:var(--font-serif);font-size:1.5rem;font-weight:500;color:var(--color-text);margin:0 0 2px;line-height:1.2}.recipe-source{font-size:.8rem;color:var(--color-text-muted);margin:0 0 var(--space-xs) 0;font-style:italic}.recipe-source a{color:var(--color-accent);text-decoration:none}.recipe-source a:hover{text-decoration:underline}.recipe-meta-line{display:flex;justify-content:center;gap:var(--space-md);font-size:.8rem;color:var(--color-text-secondary);margin-top:var(--space-xs)}.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-toggles{display:flex;justify-content:center;gap:var(--space-xs);margin-top:var(--space-sm);flex-wrap:wrap}.toggle-btn{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);cursor:pointer}.toggle-btn:hover{background:var(--color-bg-subtle)}.servings-control{display:inline-flex;align-items:center;gap:var(--space-xs)}.servings-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:1rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.servings-btn:hover:not(:disabled){background:var(--color-bg-muted)}.servings-btn:disabled{opacity:.3;cursor:not-allowed}.servings-value{min-width:1.5em;text-align:center;font-weight:500}.reset-servings{background:none;border:none;color:var(--color-text-secondary);font-size:.7rem;cursor:pointer;padding:0;margin-left:var(--space-xs)}.reset-servings:hover{text-decoration:underline}.recipe-divider{height:1px;background:var(--color-border-light);margin:var(--space-sm) 0}.recipe-intro{display:flex;gap:var(--space-sm);align-items:flex-start}.recipe-thumbnail{flex-shrink:0;width:90px;height:90px;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;position:relative;box-shadow:0 1px 4px #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-xs);flex-wrap:wrap}.recipe-images-row .recipe-thumbnail{width:70px;height:70px}.recipe-images-row .recipe-thumbnail:first-child{width:90px;height:90px}.recipe-description-editorial{flex:1;font-size:.9rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.recipe-two-column{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-md)}.recipe-column{min-width:0}.section-title{font-family:var(--font-serif);font-size:.9rem;font-weight:600;color:var(--color-text);margin:0 0 var(--space-xs) 0;letter-spacing:.3px;text-transform:uppercase}.ingredient-group-editorial{margin-bottom:var(--space-xs)}.ingredient-group-title{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--space-xs) 0;font-style:italic}.ingredients-list-editorial{list-style:none;padding:0;margin:0}.ingredient-item-editorial{display:flex;align-items:center;gap:var(--space-sm);padding:.625rem .5rem;margin:0 -.5rem;border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background-color .15s;min-height:44px}.ingredient-item-editorial:hover{background-color:var(--color-bg-subtle)}.ingredient-item-editorial:active,.ingredient-item-editorial.selected{background-color:var(--color-accent-light)}.ingredient-check{width:22px;height:22px;min-width:22px;border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;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:.75rem;font-weight:700}.ingredient-text{flex:1;font-size:.8rem;line-height:1.35}.ingredient-text .ing-amount{font-weight:600;color:var(--color-text);margin-right:3px}.ingredient-text .ing-unit{color:var(--color-text-secondary);margin-right:3px}.ingredient-text .ing-name{color:var(--color-text)}.shopping-actions{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);padding-top:var(--space-xs);border-top:1px solid var(--color-border-light)}.selection-count{font-size:.8rem;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-sm);padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-light)}.method-step:last-child{border-bottom:none}.step-number{flex-shrink:0;width:20px;height:20px;background-color:var(--color-accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.step-text{flex:1;font-size:.85rem;line-height:1.5;color:var(--color-text)}.recipe-notes-section{margin-bottom:var(--space-sm)}.notes-text{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5;padding:var(--space-sm);background:#fffbeb;border-left:2px solid #f59e0b;border-radius:var(--radius-sm)}.nyt-similar-section{margin-bottom:var(--space-sm)}.nyt-links{display:flex;flex-direction:column;gap:var(--space-xs)}.nyt-link{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:#fafafa;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);text-decoration:none;font-size:.9rem;text-transform:capitalize;transition:all .15s ease;min-height:44px}.nyt-link:hover{background:#f0f0f0;border-color:var(--color-border-hover);color:var(--color-primary)}.nyt-link:active{background:#e8e8e8}.nyt-arrow{color:var(--color-text-muted);font-size:1rem;transition:transform .15s ease}.nyt-link:hover .nyt-arrow{transform:translate(2px);color:var(--color-primary)}.recipe-comments-section{margin-bottom:var(--space-sm);padding-bottom:var(--space-md)}.muted{color:var(--color-text-muted);font-size:.8rem;font-style:italic}.comments-list-editorial{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}.comment-editorial{background:var(--color-bg-subtle);border-radius:var(--radius-sm);padding:var(--space-sm)}.comment-meta{display:flex;align-items:center;gap:var(--space-xs);margin-bottom:2px}.comment-author{font-weight:600;font-size:.8rem;color:var(--color-text)}.comment-date{font-size:.75rem;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:.8rem;color:var(--color-text-secondary);line-height:1.4;margin:0;white-space:pre-wrap}.add-comment-editorial{display:flex;gap:var(--space-xs)}.add-comment-editorial textarea{flex:1;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;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;inset: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-list{padding:var(--space-xs) var(--space-sm)}.recipe-list-header{margin-bottom:var(--space-xs)}.category-filters{gap:3px;margin-bottom:var(--space-xs);padding-bottom:var(--space-xs)}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-xs)}.recipe-card{padding:var(--space-xs)}.recipe-title{font-size:.9rem}.recipe-description{font-size:.75rem;margin:2px 0}.recipe-meta{font-size:.7rem;gap:var(--space-xs)}.recipe-title-editorial{font-size:1.25rem}.recipe-two-column{grid-template-columns:1fr;gap:var(--space-sm)}.recipe-intro{flex-direction:row;align-items:flex-start;text-align:left}.recipe-thumbnail{width:80px;height:80px}.recipe-meta-line{flex-wrap:wrap;gap:var(--space-xs)}.modal.editorial .modal-content.editorial-content{padding:var(--space-xs) var(--space-sm)}.shopping-actions{flex-wrap:wrap}.section-title{font-size:.85rem;margin-bottom:var(--space-xs)}.ingredient-item-editorial{padding:3px 0}.method-step{padding:3px 0;gap:var(--space-xs)}.step-number{width:18px;height:18px;font-size:.65rem}.step-text{font-size:.8rem}.recipe-divider{margin:var(--space-xs) 0}.modal.editorial{position:fixed;inset: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);padding:var(--space-xs) var(--space-sm)}.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:80px;min-height:0}.modal.editorial .modal-content.editorial-content>div{overflow:visible}.modal.editorial .recipe-edit-form{padding-bottom:var(--space-lg);overflow:visible}.modal.editorial .recipe-edit-form .edit-actions{display:none}.modal.editorial .header-actions{flex-direction:row;width:auto}.modal.editorial .header-actions button{width:auto}}@media(max-width:480px){.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.recipe-title-editorial{font-size:1.15rem}.section-title{font-size:.8rem}.step-number{width:16px;height:16px;font-size:.6rem}.recipe-thumbnail{width:70px;height:70px}.ingredient-text,.step-text{font-size:.75rem}}.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}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body{background:#fff!important;margin:0!important;padding:0!important}body.printing-recipe #root>*:not(:last-child){display:none!important}body.printing-recipe .app-container,body.printing-recipe .recipes-page,body.printing-recipe .app-header,body.printing-recipe .tabs,body.printing-recipe .bottom-nav,body.printing-recipe .recipe-grid,body.printing-recipe .recipes-header,body.printing-recipe .modal-header,body.printing-recipe .editorial-header,body.printing-recipe .shopping-actions,body.printing-recipe .recipe-footer,body.printing-recipe .recipe-comments-section,body.printing-recipe .add-comment-editorial,body.printing-recipe .recipe-toggles,body.printing-recipe .image-modal-overlay,body.printing-recipe .back-link,body.printing-recipe .header-actions,body.printing-recipe .ingredient-check,body.printing-recipe .confirm-delete-editorial,body.printing-recipe .btn-link-danger{display:none!important}body.printing-recipe .modal-overlay{display:block!important;position:static!important;background:#fff!important;padding:0!important;margin:0!important;width:100%!important;height:auto!important;overflow:visible!important}body.printing-recipe .modal.recipe-detail-modal,body.printing-recipe .modal.editorial{display:block!important;position:static!important;width:100%!important;max-width:none!important;height:auto!important;max-height:none!important;margin:0!important;padding:0!important;border:none!important;border-radius:0!important;box-shadow:none!important;overflow:visible!important;background:#fff!important}body.printing-recipe .modal-content.recipe-content,body.printing-recipe .modal-content.editorial-content{display:block!important;overflow:visible!important;padding:0!important;max-height:none!important;height:auto!important}.recipe-title-section{text-align:left!important;margin-bottom:1.5rem!important;padding-bottom:.75rem!important;border-bottom:2px solid #333!important}.recipe-title-editorial{font-size:24pt!important;margin-bottom:.25rem!important;color:#000!important}.recipe-source{font-size:11pt!important;color:#444!important;margin:.25rem 0!important}.recipe-meta-line{font-size:10pt!important;color:#666!important;gap:1rem!important;justify-content:flex-start!important;margin-top:.5rem!important}.recipe-meta-line span:after{content:"•";margin-left:1rem;color:#999}.recipe-meta-line span:last-child:after{content:none}.recipe-divider{display:none!important}.recipe-intro{margin:1rem 0!important;page-break-inside:avoid!important}.recipe-description-editorial{font-size:11pt!important;line-height:1.5!important;color:#333!important;font-style:italic!important}.recipe-images-row,.recipe-thumbnail{display:none!important}.recipe-two-column{display:grid!important;grid-template-columns:35% 65%!important;gap:2rem!important;margin-top:1rem!important}.recipe-column{padding:0!important}.section-title{font-size:14pt!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.5px!important;margin-bottom:.75rem!important;padding-bottom:.25rem!important;border-bottom:1px solid #ccc!important;color:#000!important}.ingredients-column{background:#f9f9f9!important;padding:1rem!important;border-radius:4px!important}.ingredient-group-editorial{margin-bottom:.75rem!important}.ingredient-group-title{font-size:10pt!important;font-weight:600!important;margin-bottom:.25rem!important;color:#444!important}.ingredients-list-editorial{list-style:none!important;padding:0!important;margin:0!important}.ingredient-item-editorial{font-size:10pt!important;line-height:1.6!important;padding:.15rem 0!important;border:none!important;background:transparent!important}.ingredient-text{display:inline!important}.ing-amount{font-weight:600!important}.ing-unit{margin-right:.25rem!important}.ing-name{color:#333!important}.method-list-editorial{list-style:none!important;padding:0!important;margin:0!important;counter-reset:step!important}.method-step{font-size:11pt!important;line-height:1.6!important;margin-bottom:.75rem!important;padding-left:0!important;display:flex!important;gap:.75rem!important;page-break-inside:avoid!important}.step-number{display:flex!important;width:20px!important;height:20px!important;background:#333!important;color:#fff!important;border-radius:50%!important;font-size:9pt!important;font-weight:600!important;flex-shrink:0!important;align-items:center!important;justify-content:center!important}.step-text{flex:1!important;color:#333!important}.recipe-notes-section{margin-top:1.5rem!important;padding-top:1rem!important;border-top:1px solid #ddd!important;page-break-inside:avoid!important}.notes-text{font-size:10pt!important;font-style:italic!important;color:#555!important}.recipe-title-section,.recipe-intro,.ingredients-column,.method-column,.recipe-notes-section{page-break-inside:avoid!important}@page{size:A4 portrait;margin:2cm 1.5cm}}.user-role-badge{display:inline-block;padding:.15em .5em;border-radius:var(--radius-sm);font-size:.7rem;font-weight:500;text-transform:uppercase;background:var(--color-bg-muted);color:var(--color-text-secondary);margin-left:.5rem;vertical-align:middle}.user-management{max-width:900px;margin:0 auto;padding:var(--space-lg)}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.user-management-header h2{font-family:var(--font-serif);font-size:1.5rem;font-weight:400;color:var(--color-text)}.user-form{background:var(--color-bg);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg);border:1px solid var(--color-border)}.user-form h3{font-size:1.1rem;font-weight:500;margin-bottom:var(--space-md);color:var(--color-text)}.user-form .form-group{margin-bottom:var(--space-md)}.user-form .form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.user-form .form-group input,.user-form .form-group select{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit}.user-form .form-group select{background:var(--color-bg)}.user-form .form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-lg)}.user-form .cancel-button{padding:var(--space-sm) var(--space-md);background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem}.user-form .save-button{padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem}.user-form .save-button:disabled{opacity:.6;cursor:not-allowed}.users-list{background:var(--color-bg);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border)}.users-list table{width:100%;border-collapse:collapse}.users-list th,.users-list td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--color-border-light)}.users-list th{background:var(--color-bg-subtle);font-weight:500;font-size:.875rem;color:var(--color-text-secondary)}.users-list tr:last-child td{border-bottom:none}.users-list tr.inactive{opacity:.6}.users-list .current-user-badge{color:var(--color-accent);font-size:.8rem;font-weight:500}.role-badge{display:inline-block;padding:.2em .6em;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:uppercase}.role-badge.role-admin{background:#fee2e2;color:#b91c1c}.role-badge.role-member{background:#e0f2fe;color:#0369a1}.role-badge.role-viewer{background:#f3f4f6;color:#6b7280}.status-badge{display:inline-block;padding:.2em .6em;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fef3c7;color:#92400e}.users-list .actions{display:flex;gap:var(--space-xs);flex-wrap:wrap}.users-list .actions button{padding:.25rem .5rem;font-size:.75rem;border-radius:var(--radius-sm);cursor:pointer;border:1px solid}.users-list .edit-button{background:var(--color-bg);border-color:var(--color-accent);color:var(--color-accent)}.users-list .deactivate-button{background:var(--color-bg);border-color:#f59e0b;color:#b45309}.users-list .activate-button{background:var(--color-bg);border-color:#10b981;color:#059669}.users-list .delete-button{background:var(--color-bg);border-color:var(--color-danger);color:var(--color-danger)}.role-legend{margin-top:var(--space-lg);padding:var(--space-md);background:var(--color-bg-subtle);border-radius:var(--radius-md);font-size:.875rem}.role-legend h4{font-size:.9rem;font-weight:500;margin-bottom:var(--space-sm);color:var(--color-text-secondary)}.role-legend ul{list-style:none;margin:0;padding:0}.role-legend li{margin-bottom:var(--space-xs);color:var(--color-text-secondary)}.role-legend li strong{color:var(--color-text)}@media(max-width:768px){.user-management{padding:var(--space-md)}.user-management-header{flex-direction:column;gap:var(--space-md);align-items:flex-start}.users-list{overflow-x:auto}.users-list table{min-width:600px}.users-list .actions{flex-direction:column}}.home-page{min-height:100vh;min-height:100dvh;background:var(--color-bg-muted);padding:var(--space-lg);padding-top:max(var(--space-lg),env(safe-area-inset-top));padding-bottom:max(var(--space-xl),env(safe-area-inset-bottom))}.home-header{display:flex;justify-content:space-between;align-items:center;max-width:800px;margin:0 auto var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.home-header h1{font-family:var(--font-serif);font-size:1.75rem;font-weight:400;color:var(--color-text);margin-bottom:var(--space-xs)}.home-header .welcome-text{color:var(--color-text-muted);font-size:.9rem}.home-content{max-width:800px;margin:0 auto}.tools-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}.tool-card{display:flex;align-items:center;gap:var(--space-lg);background:var(--color-bg);padding:var(--space-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);text-decoration:none;color:inherit;transition:all .2s ease;min-height:100px}.tool-card:hover{border-color:var(--color-accent);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.tool-card.coming-soon{opacity:.6;cursor:default}.tool-card.coming-soon:hover{border-color:var(--color-border-light);box-shadow:none;transform:none}.tool-icon{width:48px;height:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-accent-light);border-radius:var(--radius-md);color:var(--color-accent)}.tool-icon svg{width:24px;height:24px}.tool-info{flex:1}.tool-info h2{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;color:var(--color-text)}.tool-info p{font-size:.9rem;color:var(--color-text-muted);margin-bottom:.5rem}.tool-stats{display:flex;gap:var(--space-md);flex-wrap:wrap}.tool-stats .stat{font-size:.8rem;color:var(--color-text-secondary);background:var(--color-bg-muted);padding:.2rem .5rem;border-radius:var(--radius-sm)}.tool-stats .stat.highlight{background:var(--color-accent-light);color:var(--color-accent);font-weight:500}.tool-arrow{width:24px;height:24px;flex-shrink:0;color:var(--color-text-muted)}.tool-arrow svg{width:24px;height:24px}.tool-card.coming-soon .tool-icon{background:var(--color-bg-muted);color:var(--color-text-muted)}.tool-card.coming-soon .tool-arrow{display:none}@media(min-width:600px){.tools-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:599px){.home-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.home-header .header-actions{width:100%;flex-direction:column}.tool-card{padding:var(--space-md);gap:var(--space-md)}.tool-icon{width:40px;height:40px}.tool-icon svg{width:20px;height:20px}}.bulk-upload-link{font-size:.8rem;color:var(--color-text-secondary);text-decoration:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all .2s}.bulk-upload-link:hover{color:var(--color-accent);background-color:var(--color-bg-subtle)}.bulk-upload-page{min-height:100vh;min-height:100dvh;background-color:var(--color-bg);display:flex;flex-direction:column}.bulk-upload-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.bulk-upload-header .back-link{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem}.bulk-upload-header .back-link:hover{color:var(--color-accent)}.bulk-upload-header h1{margin:0;font-size:1.25rem;font-weight:600}.bulk-upload-content{display:grid;grid-template-columns:1fr 320px;gap:var(--space-lg);padding:var(--space-lg);flex:1;max-width:1400px;margin:0 auto;width:100%}.staging-panel,.actions-panel{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.panel-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-subtle)}.panel-header h2{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.upload-zone{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.upload-button{padding:var(--space-sm) var(--space-md);background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background-color .2s;min-height:44px}.upload-button:hover{background-color:var(--color-accent-dark)}.upload-hint{font-size:.85rem;color:var(--color-text-secondary)}.url-input-zone{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.url-input-zone input{flex:1;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;min-height:44px}.url-input-zone button{padding:var(--space-sm) var(--space-md);background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;min-height:44px}.url-input-zone button:hover:not(:disabled){background-color:var(--color-bg)}.url-input-zone button:disabled{opacity:.5;cursor:not-allowed}.staged-section{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.staged-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}.staged-header h3{margin:0;font-size:.9rem;font-weight:600}.staged-actions{display:flex;gap:var(--space-sm)}.staged-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm)}.staged-image{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .15s}.staged-image img{width:100%;height:100%;object-fit:cover}.staged-image.selected{border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb),.3)}.staged-image .image-checkbox{position:absolute;top:4px;left:4px;width:20px;height:20px;background-color:#fff;border:2px solid var(--color-border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--color-accent)}.staged-image.selected .image-checkbox{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.staged-image .remove-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;background-color:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity .15s}.staged-image:hover .remove-btn{opacity:1}.groups-section{padding:var(--space-md) var(--space-lg)}.groups-section h3{margin:0 0 var(--space-md) 0;font-size:.9rem;font-weight:600}.groups-list{display:flex;flex-direction:column;gap:var(--space-sm)}.recipe-group{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background-color:var(--color-bg-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.recipe-group.processing{opacity:.7}.recipe-group.saved{background-color:#22c55e1a;border-color:#22c55e4d}.recipe-group.error{background-color:#ef44441a;border-color:#ef44444d}.group-preview{flex-shrink:0}.images-preview{display:flex;position:relative;width:50px;height:40px}.images-preview img{position:absolute;width:35px;height:35px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid white;box-shadow:0 1px 3px #0003}.images-preview img:nth-child(1){left:0}.images-preview img:nth-child(2){left:8px}.images-preview img:nth-child(3){left:16px}.images-preview .more-count{position:absolute;right:0;bottom:0;background-color:var(--color-accent);color:#fff;font-size:.65rem;padding:2px 4px;border-radius:3px}.url-preview{display:flex;align-items:center;gap:var(--space-xs);max-width:200px}.url-icon{font-size:1.2rem}.url-text{font-size:.75rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-info{flex:1;min-width:0}.group-info .status{font-size:.8rem;font-weight:500;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-info .status.pending{color:var(--color-text-secondary)}.group-info .status.processing{color:var(--color-accent)}.group-info .status.extracted{color:var(--color-text)}.group-info .status.saved{color:#22c55e}.group-info .status.error{color:#ef4444}.group-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.action-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);cursor:pointer;font-size:.9rem;transition:all .15s;min-height:44px}.action-btn:hover:not(:disabled){background-color:var(--color-bg-subtle)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.small{padding:var(--space-xs) var(--space-sm);font-size:.75rem;min-height:32px}.action-btn.large{width:100%;padding:var(--space-md);font-size:1rem;font-weight:500}.action-btn.primary{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.action-btn.primary:hover:not(:disabled){background-color:var(--color-accent-dark)}.action-btn.success{background-color:#22c55e;border-color:#22c55e;color:#fff}.action-btn.success:hover:not(:disabled){background-color:#16a34a}.action-btn.danger{color:#ef4444;border-color:#ef4444}.action-btn.danger:hover:not(:disabled){background-color:#ef44441a}.actions-panel{height:fit-content;position:sticky;top:80px}.status-summary{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.status-summary .stat{font-size:.85rem;padding:var(--space-xs) 0;color:var(--color-text-secondary)}.status-summary .stat.saved{color:#22c55e}.status-summary .stat.error{color:#ef4444}.action-buttons{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md) var(--space-lg)}.help-text{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light)}.help-text h4{margin:0 0 var(--space-sm) 0;font-size:.8rem;color:var(--color-text-secondary)}.help-text ol{margin:0;padding-left:var(--space-lg);font-size:.8rem;color:var(--color-text-secondary);line-height:1.6}.review-modal{max-width:700px;width:95%;max-height:90vh;max-height:90dvh;overflow-y:auto}.review-modal .modal-content{padding:var(--space-lg)}.review-images{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-sm);margin-bottom:var(--space-md)}.review-images img{height:120px;width:auto;border-radius:var(--radius-md);flex-shrink:0}.review-modal .confidence-badge{display:inline-block;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);color:#fff;font-size:.8rem;font-weight:500;margin-bottom:var(--space-md)}.review-modal .extraction-warnings{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);font-size:.85rem}.review-modal .extraction-warnings ul{margin:var(--space-sm) 0 0 0;padding-left:var(--space-lg)}.recipe-meta-preview{display:flex;gap:var(--space-md);font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-md)}.ingredients-preview,.instructions-preview{margin-bottom:var(--space-md)}.ingredients-preview h4,.instructions-preview h4{margin:0 0 var(--space-sm) 0;font-size:.9rem}.ingredients-preview ul,.instructions-preview ol{margin:0;padding-left:var(--space-lg);font-size:.85rem;line-height:1.6}.category-selection h4{margin:0 0 var(--space-sm) 0;font-size:.9rem}@media(max-width:900px){.bulk-upload-content{display:block;padding:var(--space-md);padding-bottom:0}.staging-panel{margin-bottom:var(--space-md);padding-bottom:160px}.actions-panel{position:fixed;inset:auto 0 0;height:auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:100;box-shadow:0 -4px 20px #00000026;background:var(--color-surface)}.actions-panel .panel-header,.actions-panel .help-text{display:none}.actions-panel .status-summary{padding:var(--space-sm) var(--space-md);display:flex;flex-wrap:wrap;gap:var(--space-sm);border-bottom:none}.actions-panel .status-summary .stat{padding:0;font-size:.8rem}.actions-panel .action-buttons{padding:var(--space-sm) var(--space-md);padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom));gap:var(--space-sm)}.actions-panel .action-btn.large{width:100%;padding:var(--space-sm) var(--space-md)}}@media(max-width:480px){.bulk-upload-header{padding:var(--space-sm) var(--space-md)}.bulk-upload-header h1{font-size:1rem}.staged-grid{grid-template-columns:repeat(4,1fr)}.upload-zone{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.upload-hint{text-align:center}.url-input-zone{flex-direction:column}.url-input-zone button{width:100%}}.meal-planner{padding:var(--space-md) 0}.meal-planner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.meal-planner-header h2{font-family:var(--font-serif);font-size:1.5rem;font-weight:400}.meal-planner-actions{display:flex;align-items:center;gap:var(--space-sm)}.selection-count{font-size:.9rem;color:var(--color-text-secondary)}.meal-planner-weeks{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.meal-week{display:flex;flex-direction:column;gap:var(--space-sm)}.week-label{font-family:var(--font-serif);font-size:1rem;font-weight:400;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.meal-week-days{display:flex;flex-direction:column;gap:var(--space-sm)}.meal-day{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:80px;display:flex;flex-direction:row;transition:all .2s ease}.meal-day.past{opacity:.5;background:var(--color-bg-muted)}.meal-day.today{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-light)}.meal-day.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.meal-day-header{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--space-sm);border-right:1px solid var(--color-border-light);background:var(--color-bg-subtle);border-radius:var(--radius-md) 0 0 var(--radius-md);min-width:70px;gap:var(--space-xs)}.day-name{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.day-date{font-size:.75rem;color:var(--color-text-secondary)}.selection-checkbox{width:20px;height:20px;border:2px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;background:var(--color-bg)}.selection-checkbox.checked{background:var(--color-accent);border-color:var(--color-accent)}.meal-day-content{flex:1;padding:var(--space-xs);display:flex;flex-direction:column;gap:var(--space-xs)}.meal-entry{display:flex;align-items:center;justify-content:space-between;background:var(--color-accent-light);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.8rem}.meal-title{flex:1;word-break:break-word;line-height:1.3;color:var(--color-text);text-decoration:none}.meal-title:hover{color:var(--color-accent)}.meal-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 var(--space-xs);opacity:0;transition:opacity .2s}.meal-entry:hover .meal-remove{opacity:1}.meal-remove:hover{color:var(--color-danger)}.add-meal-btn{background:none;border:1px dashed var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs);font-size:.75rem;color:var(--color-text-muted);cursor:pointer;transition:all .2s;margin-top:auto}.add-meal-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-light)}.meal-planner-loading,.meal-planner-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md)}.recipe-picker-modal{background:var(--color-bg);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.recipe-picker-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);position:relative}.recipe-picker-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;margin-bottom:var(--space-xs)}.recipe-picker-date{font-size:.9rem;color:var(--color-text-secondary)}.recipe-picker-search{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light);position:relative;display:flex;gap:var(--space-sm);align-items:center}.recipe-picker-search input{flex:1;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem}.recipe-picker-search input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.recipe-picker-add-new{padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .2s}.recipe-picker-add-new:hover{background:var(--color-accent-hover)}.search-spinner{position:absolute;right:calc(var(--space-lg) + var(--space-md));top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.recipe-picker-content{flex:1;overflow-y:auto;padding:var(--space-md) 0}.recipe-picker-section-label{padding:var(--space-xs) var(--space-lg);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted)}.recipe-picker-list{display:flex;flex-direction:column}.recipe-picker-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:none;border:none;text-align:left;cursor:pointer;transition:background .2s;width:100%;color:var(--color-text);font-family:inherit}.recipe-picker-item:hover{background:var(--color-bg-subtle)}.recipe-picker-title{flex:1;font-size:.95rem}.recipe-picker-meta{font-size:.8rem;color:var(--color-text-muted);background:var(--color-bg-muted);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.recipe-picker-loading,.recipe-picker-empty{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--color-text-muted)}@media(max-width:768px){.meal-planner-weeks{grid-template-columns:1fr;gap:var(--space-xl)}.meal-planner-header{flex-direction:column;align-items:flex-start}.meal-planner-actions{width:100%;flex-wrap:wrap}.meal-planner-actions button{flex:1;min-width:120px}}@media(max-width:480px){.meal-day{flex-direction:column}.meal-day-header{flex-direction:row;border-right:none;border-bottom:1px solid var(--color-border-light);border-radius:var(--radius-md) var(--radius-md) 0 0;min-width:unset}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-lg);padding-top:10vh;z-index:1000;overflow-y:auto}.meal-plan-picker-modal{background:var(--color-bg);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:0 8px 32px #0003}.meal-plan-picker-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);position:relative}.meal-plan-picker-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;margin-bottom:var(--space-xs)}.meal-plan-picker-header p{font-size:.9rem;color:var(--color-text-secondary);margin:0}.meal-plan-picker-days{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:var(--space-md);max-height:60vh;overflow-y:auto}.meal-plan-picker-week{display:flex;flex-direction:column;gap:var(--space-xs)}.meal-plan-picker-week-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-xs)}.meal-plan-day-btn{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-family:inherit;min-height:44px;color:var(--color-text)}.meal-plan-day-btn:hover:not(:disabled){border-color:var(--color-accent);background:var(--color-accent-light)}.meal-plan-day-btn:disabled{opacity:.5;cursor:not-allowed}.meal-plan-day-btn.today{border-color:var(--color-accent);background:var(--color-accent-light)}.meal-plan-day-btn .day-info{display:flex;flex-direction:column;align-items:flex-start}.meal-plan-day-btn .day-name{font-weight:600;font-size:.8rem;color:var(--color-text)}.meal-plan-day-btn .day-date{font-size:.75rem;color:var(--color-text-secondary)}.meal-indicators{display:flex;gap:3px;align-items:center}.meal-dot{width:8px;height:8px;border-radius:2px;background:var(--color-accent)}.meal-dot-more{font-size:.65rem;color:var(--color-text-muted);margin-left:2px}.meal-plan-day-btn.has-recipe{background:var(--color-accent-light);border-color:var(--color-accent)}.already-added-indicator{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-accent)}.already-added-indicator .check-mark{font-size:.9rem;font-weight:600}.already-added-indicator .already-text{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.meal-plan-status{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-accent-light);border-radius:var(--radius-md)}.meal-plan-label{font-size:.8rem;font-weight:500;color:var(--color-text-secondary)}.meal-plan-date-tag{font-size:.75rem;font-weight:500;color:var(--color-accent-hover);background:var(--color-bg);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--color-accent)}.ingredient-picker-modal{background:var(--color-bg);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.ingredient-picker-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);position:relative}.ingredient-picker-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;margin-bottom:var(--space-xs)}.ingredient-picker-subtitle{font-size:.9rem;color:var(--color-text-secondary)}.ingredient-picker-name{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border-light)}.ingredient-picker-name label{display:block;font-weight:500;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.ingredient-picker-name input{width:100%;padding:var(--space-sm) var(--space-md);font-size:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit}.ingredient-picker-name input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.ingredient-picker-actions{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--color-border-light);background:var(--color-bg-subtle)}.selection-info{font-size:.85rem;color:var(--color-text-secondary)}.btn-link{background:none;border:none;color:var(--color-accent);font-size:.85rem;cursor:pointer;padding:0;font-family:inherit}.btn-link:hover{text-decoration:underline}.ingredient-picker-list{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-lg)}.ingredient-category{margin-bottom:var(--space-lg)}.ingredient-category:last-child{margin-bottom:0}.category-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border-light)}.ingredient-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-xs) 0;cursor:pointer}.ingredient-item input[type=checkbox]{margin-top:2px;width:16px;height:16px;cursor:pointer;accent-color:var(--color-accent)}.ingredient-name{flex:1;font-size:.9rem;color:var(--color-text)}.ingredient-amount{font-size:.85rem;color:var(--color-text-secondary);white-space:nowrap}.ingredient-recipes{font-size:.75rem;color:var(--color-text-muted);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ingredient-picker-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light);background:var(--color-bg-subtle)}.ingredient-picker-loading,.ingredient-picker-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-md)}@media(max-width:480px){.ingredient-picker-modal{max-height:100vh;max-width:100%;border-radius:0}.ingredient-item{flex-wrap:wrap}.ingredient-recipes{width:100%;max-width:none;margin-left:24px}}.holidays-section{padding:var(--space-md)}.holidays-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.holidays-header h2{font-family:var(--font-serif);font-size:1.5rem;font-weight:400}.section-description{color:var(--color-text-secondary);font-size:.9rem;margin-top:var(--space-xs)}.filters-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.filter-select,.filter-input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-bg)}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--color-accent)}.filter-input{flex:1;min-width:200px}.quick-actions{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.quick-action-button{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-sm);background:var(--color-accent);color:#fff;font-size:.9rem;cursor:pointer;transition:background .2s}.quick-action-button:hover{background:var(--color-accent-hover)}.quick-action-button.secondary{background:var(--color-bg-muted);color:var(--color-text);border:1px solid var(--color-border)}.quick-action-button.secondary:hover{background:var(--color-border-light)}.hotels-list{display:grid;gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.hotel-card{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:box-shadow .2s,transform .2s}.hotel-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.hotel-card.status-shortlisted{border-left:4px solid var(--color-accent)}.hotel-card.status-booked{border-left:4px solid #4caf50}.hotel-card.status-ruled-out{opacity:.6;border-left:4px solid var(--color-text-muted)}.hotel-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.hotel-card-header h3{font-size:1.1rem;font-weight:500;margin:0}.status-badge{font-size:.75rem;padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-bg-muted);color:var(--color-text-secondary);text-transform:capitalize}.status-badge.shortlisted{background:var(--color-accent-light);color:var(--color-accent)}.status-badge.booked{background:#e8f5e9;color:#2e7d32}.status-badge.ruled-out{background:var(--color-bg-muted);color:var(--color-text-muted)}.hotel-card-meta{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-sm);font-size:.85rem;color:var(--color-text-secondary)}.hotel-card-meta span{background:var(--color-bg-subtle);padding:2px 6px;border-radius:var(--radius-sm)}.hotel-scores{font-size:.85rem;color:var(--color-accent);margin-bottom:var(--space-sm)}.hotel-card-footer{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-muted);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light)}.hotel-card-footer .price{font-weight:500;color:var(--color-text)}.platforms-list{display:grid;gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.platform-card{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-md)}.platform-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.platform-header h3{font-size:1rem;font-weight:500;margin:0}.platform-rating{color:#f5a623;font-size:.9rem;margin-left:var(--space-sm)}.open-site-button{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:transparent;color:var(--color-accent);font-size:.85rem;cursor:pointer;transition:all .2s}.open-site-button:hover{background:var(--color-accent);color:#fff}.platform-meta{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-sm)}.platform-meta .category{font-size:.75rem;padding:2px 6px;border-radius:var(--radius-sm);background:var(--color-accent-light);color:var(--color-accent)}.platform-meta .category.secondary{background:var(--color-bg-muted);color:var(--color-text-secondary)}.platform-card .regions{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.platform-card .description{font-size:.85rem;color:var(--color-text);margin-bottom:var(--space-xs)}.platform-card .notes{font-size:.85rem;color:var(--color-accent);font-style:italic}.platform-card .last-searched{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-sm)}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--color-text-secondary)}.loading{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary)}@media(max-width:768px){.holidays-header{flex-direction:column;align-items:flex-start}.hotels-list,.platforms-list{grid-template-columns:1fr}.filters-row{flex-direction:column}.filter-input{min-width:auto}}.detail-page-header{margin-bottom:var(--space-lg)}.detail-page-header .back-link{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;display:inline-block;margin-bottom:var(--space-sm)}.detail-page-header .back-link:hover{color:var(--color-accent)}.detail-page-header h2{margin:0;color:var(--color-text-primary)}.detail-form{max-width:800px}.form-section{background:var(--color-bg-card);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden}.section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--color-bg-muted);border:none;cursor:pointer;font-size:1rem;font-weight:600;color:var(--color-text-primary);text-align:left;transition:background .2s}.section-header:hover{background:var(--color-border-light)}.section-header.expanded{border-bottom:1px solid var(--color-border-light)}.toggle-icon{font-size:1.2rem;color:var(--color-text-secondary)}.section-content{padding:var(--space-lg)}.form-row{margin-bottom:var(--space-md)}.form-row:last-child{margin-bottom:0}.form-row label{display:block;font-size:.85rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.form-row input,.form-row select,.form-row textarea{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);font-size:.95rem;background:var(--color-bg-page);color:var(--color-text-primary);transition:border-color .2s}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--color-accent)}.form-row textarea{resize:vertical;min-height:60px}.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.scores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}.score-item{display:flex;flex-direction:column;gap:var(--space-xs)}.score-item label{font-size:.8rem;color:var(--color-text-secondary)}.score-input{display:flex;gap:4px}.score-btn{width:32px;height:32px;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);background:var(--color-bg-page);color:var(--color-text-secondary);font-size:.9rem;cursor:pointer;transition:all .2s}.score-btn:hover{background:var(--color-bg-muted)}.score-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.score-total{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-light);font-weight:600;color:var(--color-text-primary)}.form-actions{display:flex;gap:var(--space-md);align-items:center;margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border-light)}.save-button{padding:var(--space-sm) var(--space-xl);background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.save-button:hover:not(:disabled){background:var(--color-accent-hover)}.save-button:disabled{opacity:.6;cursor:not-allowed}.delete-button{padding:var(--space-sm) var(--space-lg);background:transparent;color:var(--color-danger);border:1px solid var(--color-danger);border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:all .2s}.delete-button:hover{background:var(--color-danger);color:#fff}.cancel-link{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;margin-left:auto}.cancel-link:hover{color:var(--color-text-primary)}@media(max-width:600px){.form-row.two-col,.scores-grid{grid-template-columns:1fr}.form-actions{flex-direction:column;align-items:stretch}.cancel-link{margin-left:0;text-align:center}}.dashboard-intro{color:var(--color-text-secondary);margin-bottom:1.5rem;font-size:.95rem}.availability-section{margin-bottom:2rem}.availability-section h3{font-size:1.1rem;color:var(--color-text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.availability-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.availability-card{background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:1rem;transition:box-shadow .2s}.availability-card:hover{box-shadow:0 2px 8px #0000001a}.availability-card.urgency-overdue{border-left:4px solid #dc3545}.availability-card.urgency-due{border-left:4px solid #ffc107}.availability-card.urgency-ok{border-left:4px solid #28a745}.availability-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.availability-card .property-name{font-weight:600;color:var(--color-text-primary);text-decoration:none;font-size:1rem}.availability-card .property-name:hover{color:var(--color-accent)}.availability-card .card-detail{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:.25rem}.availability-card .check-info{margin:.75rem 0;padding:.5rem;background:var(--color-bg-subtle);border-radius:4px;font-size:.85rem}.availability-card .last-check{margin-bottom:.25rem}.availability-card .never-checked{color:#dc3545;font-weight:500}.availability-card .booking-window{color:var(--color-text-secondary)}.availability-card .card-actions{display:flex;gap:.5rem;margin-top:.75rem}.availability-card .check-button{flex:1;background:var(--color-accent);color:#fff;border:none;padding:.5rem .75rem;border-radius:4px;font-size:.85rem;cursor:pointer}.availability-card .check-button:hover{background:var(--color-accent-hover)}.availability-card .history-button{background:var(--color-bg-muted);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.5rem .75rem;border-radius:4px;font-size:.85rem;cursor:pointer}.availability-card .history-button:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;padding:1.5rem;max-width:450px;width:100%;max-height:90vh;overflow-y:auto}.modal-content.modal-wide{max-width:600px}.modal-content h3{margin:0 0 .25rem;font-size:1.2rem}.modal-subtitle{color:var(--color-text-secondary);margin:0 0 1rem;font-size:.9rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.modal-actions .save-button{flex:1;background:var(--color-accent);color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer}.modal-actions .save-button:hover{background:var(--color-accent-hover)}.modal-actions .save-button:disabled{background:#ccc;cursor:not-allowed}.modal-actions .cancel-button{background:var(--color-bg-muted);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.75rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer}.modal-actions .cancel-button:hover{background:var(--color-bg-subtle)}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{padding:.75rem;background:var(--color-bg-subtle);border-radius:6px;border-left:3px solid var(--color-border)}.history-date{font-weight:500;font-size:.9rem;margin-bottom:.25rem}.history-details{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.85rem}.history-range{color:var(--color-text-secondary)}.availability-badge{padding:.15rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.availability-badge.available{background:#d4edda;color:#155724}.availability-badge.unavailable{background:#f8d7da;color:#721c24}.price-found{color:var(--color-accent);font-weight:500}.history-notes{margin-top:.5rem;font-size:.85rem;color:var(--color-text-secondary);font-style:italic}.empty-message{color:var(--color-text-muted);font-style:italic;padding:1rem;text-align:center}.tab-button.availability-link{text-decoration:none;margin-left:auto;background:var(--color-bg-subtle);border:1px solid var(--color-border)}.tab-button.availability-link:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}@media(max-width:600px){.availability-grid{grid-template-columns:1fr}.modal-content{padding:1rem}.tab-button.availability-link{margin-left:0}}
