:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;background-color:#f4f5f7;color:#1f2933}.app-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.search-header{padding:1.5rem 2rem;background:#fff;border-bottom:1px solid #dfe3e8;display:flex;flex-direction:column;gap:.75rem}.search-header h1{margin:0;font-size:1.75rem;font-weight:600}.header-top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap}.search-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-header input[type=search]{font-size:1rem;padding:.75rem 1rem;border-radius:.75rem;border:1px solid #cbd2d9;background:#f8fafc;transition:border-color .2s ease,box-shadow .2s ease;flex:1 1 260px}.search-header input[type=search]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133;background:#fff}.filter-select{flex:0 1 180px;min-width:150px;font-size:.95rem;padding:.7rem .9rem;border-radius:.75rem;border:1px solid #cbd2d9;background:linear-gradient(180deg,#fff,#f5f7fa);color:#1f2933;transition:border-color .2s ease,box-shadow .2s ease}.filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133;background:#fff}.add-recipe-button{border:none;background:#6366f1;color:#fff;font-size:.95rem;font-weight:600;padding:.7rem 1.1rem;border-radius:.75rem;cursor:pointer;transition:background .2s ease,transform .2s ease}.add-recipe-button:hover{background:#4f46e5;transform:translateY(-1px)}.add-recipe-button:active{transform:translateY(0)}.add-recipe-button:disabled{background:#a5b4fc;cursor:not-allowed;transform:none}.search-status{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;font-size:.95rem;color:#52616b}.view-toggle{display:flex;flex-wrap:wrap;gap:.6rem}.view-toggle-button{border:1px solid #e2e8f0;background:#f8fafc;color:#475569;padding:.4rem .85rem;border-radius:999px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.view-toggle-button:hover{background:#e0e7ff;border-color:#c7d2fe;color:#4338ca}.view-toggle-button.active{background:#6366f1;border-color:#6366f1;color:#fff}.error{color:#b42318}.content{flex:1 1 auto;display:grid;grid-template-columns:minmax(300px,1fr) minmax(480px,2.5fr) minmax(300px,1fr);gap:1px;background:#dfe3e8;min-height:0;overflow:hidden}.results-pane,.details-pane,.planner-pane{background:#fff;overflow:hidden;min-height:0}.results-pane{display:flex;flex-direction:column}.results-pane .scroll-container{flex:1;overflow-y:auto;padding-right:.25rem}.results-pane .scroll-container::-webkit-scrollbar{width:6px}.results-pane .scroll-container::-webkit-scrollbar-thumb{background:#94a3b899;border-radius:999px}.planner-pane{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1rem;border-left:1px solid #eef1f4}.planner-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap}.planner-header-text{display:flex;flex-direction:column;gap:.3rem}.planner-header-text h2{margin:0;font-size:1.35rem}.planner-message{font-size:.85rem;color:#047857;background:#ecfdf5;border-radius:999px;padding:.25rem .6rem}.planner-subtitle{margin:0;font-size:.9rem;color:#64748b}.planner-date-controls{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;color:#475569}.planner-date-controls label{font-weight:600}.planner-date-picker{display:inline-flex;align-items:center;gap:.4rem}.planner-date-picker input[type=date]{font:inherit;padding:.4rem .6rem;border-radius:.6rem;border:1px solid #cbd2d9;background:#fff}.planner-date-picker input[type=date]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f12e}.planner-nav-button{border:none;background:#e0e7ff;color:#4338ca;width:32px;height:32px;border-radius:.6rem;font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.planner-nav-button:hover{background:#c7d2fe}.planner-status-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;min-height:1.25rem}.planner-status{font-size:.82rem;color:#64748b}.planner-error{font-size:.82rem;color:#b42318}.planner-list{list-style:none;padding:0;margin:0;display:grid;gap:.85rem}.planner-list-item{position:relative;transition:transform .18s ease}.planner-list-item.drop-target:before{content:"";position:absolute;top:-.6rem;left:.75rem;right:.75rem;height:6px;border-radius:999px;background:linear-gradient(90deg,#6366f1,#22d3ee);box-shadow:0 6px 16px -8px #6366f1cc;z-index:1}.planner-list-item.drop-target .planner-card{border-color:#6366f1;background:#eef2ff;box-shadow:0 14px 30px -18px #6366f173}.planner-list-item.drop-target .planner-card:after{content:"Release to drop";position:absolute;top:-1.35rem;left:50%;transform:translate(-50%);background:#6366f1;color:#fff;font-size:.65rem;letter-spacing:.01em;padding:.2rem .6rem;border-radius:999px;box-shadow:0 6px 18px -10px #6366f1a6;white-space:nowrap}.empty-state{padding:1.5rem;color:#52616b}.results-list{list-style:none;padding:0;margin:0}.results-list li+li{border-top:1px solid #eef1f4}.result-item{width:100%;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .15s ease,transform .15s ease}.result-item:hover{background:#f0f4ff;transform:translate(2px)}.result-item.active{background:#6366f114;border-left:4px solid #6366f1;padding-left:calc(1.25rem - 4px)}.result-media{flex:0 0 88px;height:88px;overflow:hidden;border-radius:.9rem;background:#e5e7eb;display:flex;align-items:center;justify-content:center}.result-media img{width:100%;height:100%;object-fit:cover}.result-media--placeholder{font-size:.75rem;color:#6b7280;padding:.5rem;text-align:center}.result-info{display:flex;flex-direction:column;gap:.4rem;flex:1;min-width:0}.result-item h2{margin:0;font-size:1.05rem;font-weight:600;color:#111827;line-height:1.3}.result-item h2 mark,.result-item h2 span mark{background:#fef08a;padding:0 .1em;border-radius:.2em}.result-meta{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.85rem;color:#52616b}.result-meta span{display:inline-flex;align-items:center;gap:.35rem}.planner-card{border:1px solid #5d0fd38d;border-radius:1rem;padding:.5rem;background:#f8fafc;box-shadow:0 10px 24px -20px #0f172a73;display:flex;flex-direction:column;gap:.25rem;cursor:grab;position:relative;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.planner-card:active{cursor:grabbing}.planner-card.dragging{border-color:#6366f1;box-shadow:0 14px 32px -18px #6366f173;background:#eef2ff;opacity:.92;transform:translateY(2px)}.planner-card.empty{background:#fff;border-style:dashed;color:#94a3b8;cursor:default}.planner-card-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.planner-card-heading{display:flex;flex-direction:column}.planner-card-day{font-size:.95rem;font-weight:600;color:#1f2933;display:inline-flex;align-items:baseline;gap:.5rem}.planner-card-date{font-size:.8rem;color:#64748b;font-weight:500}.planner-card-header-actions{display:flex;align-items:center;gap:.6rem}.planner-clear{border:none;background:transparent;color:#ef4444;font-size:.85rem;cursor:pointer;padding:.25rem .4rem;border-radius:.5rem;transition:background .2s ease}.planner-clear:hover{background:#ef44441f}.planner-card-body{display:flex;gap:.75rem;align-items:center}.planner-card-media{flex:0 0 64px;height:64px;border-radius:.75rem;overflow:hidden;background:#e2e8f0;display:flex;align-items:center;justify-content:center}.planner-card-media img{width:100%;height:100%;object-fit:cover}.planner-card-placeholder{font-size:.75rem;color:#64748b;padding:.5rem;text-align:center}.planner-card-info{flex:1;display:flex;flex-direction:column;gap:.35rem}.planner-card-info h3{margin:0;font-size:1rem;color:#1f2933;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.planner-card-link{font-size:.85rem;color:#4f46e5;text-decoration:none;border:none;background:transparent;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem}.planner-card-link:hover{text-decoration:underline}.planner-card-chef{font-size:.8rem;color:#64748b}.planner-card-empty{font-size:.85rem;color:#64748b}.planner-card-empty strong{color:#1f2933}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:1000}.modal-card{background:#fff;border-radius:1rem;padding:2rem;width:min(480px,100%);box-shadow:0 24px 48px -20px #0f172a8c;display:flex;flex-direction:column;gap:1.25rem}.modal-card h2{margin:0;font-size:1.5rem}.modal-subtitle{margin:0;font-size:.95rem;color:#64748b}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-form input[type=url]{font-size:1rem;padding:.75rem 1rem;border-radius:.75rem;border:1px solid #cbd2d9;background:#fff}.modal-form input[type=url]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.modal-error{margin:0;font-size:.9rem;color:#b42318}.modal-header-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.modal-header-row h2{margin:0;font-size:1.5rem}.modal-choice-actions{display:flex;flex-direction:column;gap:.75rem}.modal-choice-button{border:none;background:#eef2ff;color:#4338ca;font-weight:600;padding:.75rem 1rem;border-radius:.9rem;cursor:pointer;text-align:left;transition:background .2s ease,transform .2s ease}.modal-choice-button:hover{background:#dbe4ff;transform:translateY(-1px)}.modal-field{display:flex;flex-direction:column;gap:.35rem}.modal-field input,.modal-field textarea{font-size:1rem;padding:.65rem .85rem;border-radius:.75rem;border:1px solid #cbd2d9;background:#fff}.modal-field input:focus,.modal-field textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.modal-form textarea{resize:vertical;min-height:120px}.modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.modal-button{border:none;border-radius:.75rem;padding:.6rem 1.1rem;font-weight:600;cursor:pointer;transition:background .2s ease,color .2s ease}.modal-button.secondary{background:#e2e8f0;color:#1f2933}.modal-button.secondary:hover{background:#cbd5f5}.modal-button.primary{background:#6366f1;color:#fff}.modal-button.primary:hover{background:#4f46e5}.modal-button:disabled{cursor:not-allowed;opacity:.7}.recipe-editor-modal{width:min(720px,100%);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;gap:0}.recipe-editor-header{padding:1.5rem 1.75rem 1rem;border-bottom:1px solid #eef1f4;background:#f8fafc}.recipe-editor-body{padding:1.5rem 1.75rem 1.75rem;overflow:auto}.recipe-editor-form{gap:1rem}.recipe-editor-ingredients{min-height:180px;resize:vertical}.recipe-editor-instructions{min-height:220px;resize:vertical}.recipe-editor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.notes-modal{background:#fff;border-radius:1.25rem;width:min(960px,100%);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 28px 60px -32px #0f172a99}.notes-modal-header{padding:1.75rem 2rem 1.25rem;background:#f8fafc;border-bottom:1px solid #eef1f4;display:flex;flex-direction:column;gap:.35rem}.notes-modal-label{margin:0;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:#64748b}.notes-modal-header h2{margin:0;font-size:1.6rem}.notes-modal-subtitle{margin:0;font-size:.95rem;color:#64748b}.notes-modal-body{padding:1.5rem 2rem 2rem;display:grid;grid-template-columns:minmax(220px,1fr) minmax(340px,2fr);gap:1.5rem;overflow:auto}.notes-modal-meta{border-radius:1rem;border:1px solid #e2e8f0;background:#fff;padding:1rem;display:flex;flex-direction:column;gap:.85rem;box-shadow:0 10px 22px -18px #0f172a59}.notes-modal-media{width:100%;height:180px;border-radius:.9rem;overflow:hidden;background:#e2e8f0;display:flex;align-items:center;justify-content:center}.notes-modal-image{width:100%;height:100%;object-fit:cover}.notes-modal-placeholder{font-size:.85rem;color:#64748b;text-align:center;padding:.75rem}.notes-modal-meta-details h3{margin:0;font-size:1.1rem;color:#1f2933}.notes-modal-tags{margin-top:.6rem;display:flex;flex-wrap:wrap;gap:.4rem}.notes-modal-empty{font-size:.95rem;color:#64748b;line-height:1.5}.notes-modal-empty p{margin:0 0 .5rem}.notes-modal-form{display:flex;flex-direction:column;gap:1rem;min-height:100%}.notes-modal-editor{display:flex;flex-direction:column;gap:.5rem;flex:1}.notes-modal-editor textarea{min-height:280px;resize:vertical;flex:1;font-size:1rem;line-height:1.55;padding:.9rem 1rem}.notes-modal-helper{margin:0;font-size:.85rem;color:#94a3b8}.notes-modal-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.75rem;border-top:1px solid #eef1f4}.notes-modal-status{font-size:.85rem;color:#64748b}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.details-pane{padding:2rem 2.5rem;display:flex;flex-direction:column;gap:1.5rem}.loading{color:#52616b}.recipe-card{background:#fff;border-radius:1rem;box-shadow:0 12px 30px -20px #0f172a66;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.recipe-card header{display:grid;grid-template-columns:minmax(200px,300px) 1fr;gap:1.5rem;align-items:start}.recipe-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:2rem;align-items:start}.recipe-image{width:100%}.recipe-image img{width:100%;height:260px;object-fit:cover;border-radius:1.25rem;box-shadow:0 12px 32px -18px #0f172a59}.recipe-summary{display:flex;flex-direction:column;gap:.5rem}.recipe-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.favorite-button{border:none;background:#eef2ff;color:#4338ca;font-size:1.4rem;border-radius:999px;width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background .2s ease}.favorite-button:hover{background:#e0e7ff;transform:translateY(-1px)}.favorite-button.active{background:#fde2e4;color:#e11d48}.recipe-card h2{margin:0;font-size:2rem;line-height:1.2}.meta{margin:.5rem 0;color:#52616b}.meta strong{color:#1f2933}.meta-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .65rem;border-radius:999px;font-size:.75rem;background:#f0f4ff;color:#3948ab;text-transform:capitalize}.description{margin:0;font-size:1rem;color:#3d4852}.ingredients-section h3{margin:0 0 .75rem;font-size:1.2rem}.ingredients-section ul{padding-left:1.25rem;margin:0;display:grid;gap:.5rem}.instructions-section h3{margin:0 0 .75rem;font-size:1.2rem}.instructions-section ol{padding-left:1.4rem;margin:0;display:grid;gap:.6rem}.instructions-empty{display:grid;gap:.35rem;color:#64748b;font-size:.95rem}.instructions-empty p{margin:0}.instructions-status{font-size:.85rem;color:#475569}.notes-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #eceff4}.notes-section--inline{margin-top:1rem;padding-top:.75rem}.notes-section h3{margin:0 0 .75rem;font-size:1.1rem}.notes-body p{margin:0 0 .5rem;font-size:.98rem;color:#3d4852}.notes-body p:last-of-type{margin-bottom:0}.recipe-footer{display:flex;justify-content:flex-end;align-items:center;gap:.75rem}.primary-link{display:inline-flex;align-items:center;gap:.5rem;background:#6366f1;color:#fff;padding:.65rem 1.2rem;border-radius:.75rem;font-weight:600;text-decoration:none;transition:background .2s ease,transform .2s ease}.primary-link:hover{background:#4f46e5;transform:translateY(-1px)}.secondary-link{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1rem;border-radius:.75rem;border:1px solid #c7d2fe;background:#eef2ff;color:#4338ca;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease}.secondary-link:hover{background:#e0e7ff;border-color:#6366f1}.secondary-link:disabled{opacity:.6;cursor:not-allowed}.empty-details{margin:auto;text-align:center;color:#52616b}@media(max-width:960px){.content{grid-template-columns:1fr}.details-pane{padding:1.5rem}.recipe-card header{display:flex;flex-direction:column;gap:1.5rem}.recipe-body{grid-template-columns:1fr}.recipe-image{max-width:none}.recipe-image img{width:100%;height:auto;max-height:320px}.search-row{flex-direction:column;align-items:stretch}.search-header input[type=search],.filter-select{width:100%;flex:1 1 auto}.add-recipe-button{width:100%}.result-item{flex-direction:row;align-items:flex-start}.result-media{flex-basis:72px;height:72px}.planner-pane{border-left:none;border-top:1px solid #eef1f4;padding:1.25rem 1.5rem}.planner-header{align-items:flex-start}.planner-date-controls{width:100%}.planner-date-picker{justify-content:space-between}.planner-status-row{flex-direction:column;align-items:flex-start}.planner-card-body{flex-direction:row;align-items:flex-start}.planner-card-header-actions{gap:.5rem}.modal-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.notes-modal-body{grid-template-columns:1fr}.recipe-editor-body{padding:1.25rem 1.5rem 1.5rem}}@media(max-width:640px){.planner-date-picker{flex-direction:column;align-items:stretch}.planner-date-picker input[type=date]{width:100%}.planner-card-body{flex-direction:column;align-items:stretch}.planner-card-media{width:100%;height:160px}.modal-grid{grid-template-columns:1fr}.modal-header-row{flex-direction:column;align-items:flex-start;gap:.75rem}.modal-choice-actions{gap:.6rem}.notes-modal-header{padding:1.5rem}.notes-modal-body{padding:1.25rem 1.5rem 1.5rem}.notes-modal-footer{flex-direction:column;align-items:stretch}.notes-modal-footer .modal-actions{justify-content:flex-end}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:inherit;background:inherit;color:inherit}button{font:inherit}ul{list-style:none;padding:0;margin:0}a{color:inherit}
