@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Jost:wght@300;400;500&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--cream:#f2efe9;--cream-dark:#e8e4dc;--stone:#9c9589;--stone-dark:#6b6560;--ink:#1c1a17;--accent:#c4a882;--white:#fafaf8;--red:#c0392b;--green:#5a7a5a;--radius:6px;--shadow:0 1px 3px #00000014}body{background:var(--cream);color:var(--ink);min-height:100vh;font-family:Jost,sans-serif;font-weight:300}.login-screen{background:var(--cream);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.login-brand{color:var(--ink);letter-spacing:-.02em;margin-bottom:6px;font-family:Cormorant Garamond,serif;font-size:3.5rem;font-style:italic;font-weight:300}.login-tagline{letter-spacing:.15em;text-transform:uppercase;color:var(--stone);margin-bottom:48px;font-size:.75rem}.login-card{background:var(--white);border-radius:12px;width:100%;max-width:380px;padding:40px;box-shadow:0 2px 20px #0000000f}.login-card h2{color:var(--ink);margin-bottom:8px;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:400}.login-card p{color:var(--stone);margin-bottom:28px;font-size:.8rem;line-height:1.5}.form-group{margin-bottom:16px}.form-group label{letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-bottom:6px;font-size:.7rem;display:block}.form-group input{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);width:100%;color:var(--ink);outline:none;padding:12px 14px;font-family:Jost,sans-serif;font-size:.9rem;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.pin-input{letter-spacing:.3em;text-align:center;font-size:1.2rem!important}.btn-primary{background:var(--ink);width:100%;color:var(--white);border-radius:var(--radius);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:none;margin-top:8px;padding:13px;font-family:Jost,sans-serif;font-size:.8rem;transition:opacity .2s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.login-switch{text-align:center;color:var(--stone);margin-top:20px;font-size:.8rem}.login-switch button{color:var(--ink);cursor:pointer;background:0 0;border:none;font-family:Jost,sans-serif;font-size:.8rem;text-decoration:underline}.error-msg{color:var(--red);text-align:center;margin-top:10px;font-size:.78rem}.setup-screen{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.setup-card{background:var(--white);border-radius:12px;width:100%;max-width:480px;padding:40px;box-shadow:0 2px 20px #0000000f}.setup-card h2{margin-bottom:6px;font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:400}.setup-card p{color:var(--stone);margin-bottom:28px;font-size:.8rem}.section-list{margin-bottom:16px;list-style:none}.section-list li{background:var(--cream);border-radius:var(--radius);justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 12px;font-size:.9rem;display:flex}.section-list li button{color:var(--stone);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:1rem;line-height:1}.section-list li button:hover{color:var(--red)}.add-section-row{gap:8px;margin-bottom:24px;display:flex}.add-section-row input{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);color:var(--ink);outline:none;flex:1;padding:10px 12px;font-family:Jost,sans-serif;font-size:.85rem}.add-section-row input:focus{border-color:var(--accent)}.btn-add{background:var(--ink);color:var(--white);border-radius:var(--radius);cursor:pointer;border:none;padding:10px 16px;font-family:Jost,sans-serif;font-size:.8rem}.app{background:var(--cream);flex-direction:column;max-width:680px;min-height:100vh;margin:0 auto;display:flex}.header{background:var(--cream);padding:20px 20px 0}.header-top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.header-left{align-items:center;gap:20px;display:flex}.logo{color:var(--ink);letter-spacing:-.01em;font-family:Cormorant Garamond,serif;font-size:1.6rem;font-style:italic;font-weight:300}.header-date{letter-spacing:.08em;color:var(--stone);text-transform:uppercase;font-size:.72rem}.header-right{align-items:center;gap:12px;display:flex}.btn-sections{border:1px solid var(--cream-dark);letter-spacing:.08em;text-transform:uppercase;color:var(--stone-dark);cursor:pointer;background:0 0;border-radius:20px;padding:5px 14px;font-family:Jost,sans-serif;font-size:.72rem;transition:all .2s}.btn-sections:hover{background:var(--cream-dark);color:var(--ink)}.btn-settings{cursor:pointer;color:var(--stone);background:0 0;border:none;align-items:center;padding:4px;transition:color .2s;display:flex}.btn-settings:hover{color:var(--ink)}.covers-bar{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:16px;margin-bottom:4px;padding:10px 16px;display:flex}.covers-label{letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-right:4px;font-size:.68rem}.covers-group{align-items:center;gap:8px;display:flex}.covers-group span{color:var(--stone);letter-spacing:.05em;font-size:.72rem}.covers-input{border:1px solid var(--cream-dark);background:var(--cream);text-align:center;width:52px;color:var(--ink);border-radius:4px;outline:none;padding:4px 8px;font-family:Jost,sans-serif;font-size:.85rem}.covers-input:focus{border-color:var(--accent)}.covers-divider{background:var(--cream-dark);width:1px;height:20px}.nav{border-bottom:1px solid var(--cream-dark);background:var(--cream);gap:0;padding:0 20px;display:flex}.nav-tab{letter-spacing:.06em;color:var(--stone);cursor:pointer;text-transform:capitalize;background:0 0;border:none;flex:1;padding:14px 0;font-family:Jost,sans-serif;font-size:.8rem;transition:color .2s}.nav-tab.active{color:var(--ink);box-shadow:inset 0 -2px 0 var(--ink);font-weight:500}.nav-tab:hover:not(.active){color:var(--stone-dark)}.content{flex:1;padding:20px;overflow-y:auto}.prep-section{margin-bottom:24px}.prep-section-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.prep-section-title{letter-spacing:.12em;text-transform:uppercase;color:var(--stone);font-size:.68rem}.btn-add-item{color:var(--stone);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:1.1rem;line-height:1;transition:color .2s}.btn-add-item:hover{color:var(--ink)}.prep-item{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:12px;margin-bottom:6px;padding:10px 12px;transition:opacity .2s;display:flex}.prep-item.checked{opacity:.45}.prep-checkbox{border:1.5px solid var(--cream-dark);cursor:pointer;background:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .2s;display:flex}.prep-checkbox.checked{background:var(--ink);border-color:var(--ink);color:var(--white);font-size:.6rem}.prep-item-name{flex:1;font-size:.88rem}.prep-item-amount{color:var(--stone);font-size:.78rem}.prep-allergens{flex-wrap:wrap;gap:4px;display:flex}.allergen-tag{letter-spacing:.05em;background:var(--cream-dark);color:var(--stone-dark);text-transform:uppercase;border-radius:10px;padding:2px 6px;font-size:.6rem}.prep-item-actions{opacity:0;gap:6px;transition:opacity .2s;display:flex}.prep-item:hover .prep-item-actions{opacity:1}.btn-icon{cursor:pointer;color:var(--stone);background:0 0;border:none;padding:2px;font-size:.8rem;transition:color .2s}.btn-icon:hover{color:var(--ink)}.btn-icon.danger:hover{color:var(--red)}.all-done{text-align:center;color:var(--stone);letter-spacing:.05em;padding:32px;font-size:.85rem}.inline-form{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:8px;padding:14px}.inline-form-row{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.inline-form input,.inline-form select,.inline-form textarea{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);min-width:120px;color:var(--ink);outline:none;flex:1;padding:8px 10px;font-family:Jost,sans-serif;font-size:.82rem}.inline-form textarea{resize:vertical;flex:none;width:100%;min-height:80px}.inline-form input:focus,.inline-form select:focus,.inline-form textarea:focus{border-color:var(--accent)}.inline-form-actions{justify-content:flex-end;gap:8px;display:flex}.btn-save{background:var(--ink);color:var(--white);border-radius:var(--radius);letter-spacing:.06em;cursor:pointer;border:none;padding:7px 18px;font-family:Jost,sans-serif;font-size:.75rem}.btn-cancel{color:var(--stone);border:1px solid var(--cream-dark);border-radius:var(--radius);letter-spacing:.06em;cursor:pointer;background:0 0;padding:7px 18px;font-family:Jost,sans-serif;font-size:.75rem}.allergen-picker{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.allergen-btn{border:1px solid var(--cream-dark);background:var(--cream);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;color:var(--stone-dark);border-radius:12px;padding:3px 10px;font-family:Jost,sans-serif;font-size:.68rem;transition:all .15s}.allergen-btn.selected{background:var(--ink);border-color:var(--ink);color:var(--white)}.search-bar{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;display:flex}.search-bar input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-family:Jost,sans-serif;font-size:.85rem}.search-bar svg{color:var(--stone);flex-shrink:0}.recipe-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;margin-bottom:10px;padding:16px;transition:box-shadow .2s}.recipe-card:hover{box-shadow:0 2px 10px #0000001a}.recipe-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.recipe-card-title{color:var(--ink);font-family:Cormorant Garamond,serif;font-size:1.1rem;font-weight:400}.recipe-category{letter-spacing:.08em;text-transform:uppercase;color:var(--stone);background:var(--cream);border-radius:10px;padding:3px 8px;font-size:.65rem}.recipe-card-meta{color:var(--stone);gap:12px;font-size:.75rem;display:flex}.recipe-detail{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.recipe-detail-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.recipe-detail-title{font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:400}.recipe-detail-actions{gap:8px;display:flex}.back-btn{color:var(--stone);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:16px;padding:0;font-family:Jost,sans-serif;font-size:.78rem;display:flex}.back-btn:hover{color:var(--ink)}.recipe-section-title{letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-top:18px;margin-bottom:10px;font-size:.65rem}.ingredients-list{list-style:none}.ingredients-list li{border-bottom:1px solid var(--cream);justify-content:space-between;padding:7px 0;font-size:.85rem;display:flex}.ingredient-amount{color:var(--stone);font-size:.8rem}.portion-scaler{background:var(--cream);border-radius:var(--radius);align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;display:flex}.portion-scaler span{letter-spacing:.06em;text-transform:uppercase;color:var(--stone);font-size:.72rem}.portion-scaler input{border:1px solid var(--cream-dark);background:var(--white);text-align:center;border-radius:4px;outline:none;width:56px;padding:5px 8px;font-family:Jost,sans-serif;font-size:.85rem}.method-text{color:var(--stone-dark);white-space:pre-wrap;font-size:.85rem;line-height:1.7}.modal-overlay{z-index:100;background:#1c1a1780;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:12px;width:100%;max-width:520px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 8px 40px #00000026}.modal h3{margin-bottom:6px;font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:400}.modal p{color:var(--stone);margin-bottom:20px;font-size:.78rem;line-height:1.5}.scan-tabs{gap:8px;margin-bottom:20px;display:flex}.scan-tab{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);letter-spacing:.06em;cursor:pointer;color:var(--stone-dark);flex:1;padding:9px;font-family:Jost,sans-serif;font-size:.75rem;transition:all .15s}.scan-tab.active{background:var(--ink);border-color:var(--ink);color:var(--white)}.upload-zone{border:2px dashed var(--cream-dark);border-radius:var(--radius);text-align:center;cursor:pointer;margin-bottom:16px;padding:32px;transition:border-color .2s}.upload-zone:hover{border-color:var(--accent)}.upload-zone p{color:var(--stone);margin:0;font-size:.82rem}.upload-zone .upload-icon{margin-bottom:8px;font-size:2rem;display:block}.scan-textarea{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);width:100%;color:var(--ink);resize:vertical;outline:none;min-height:140px;margin-bottom:16px;padding:12px;font-family:Jost,sans-serif;font-size:.82rem}.scan-textarea:focus{border-color:var(--accent)}.scanning-indicator{background:var(--cream);border-radius:var(--radius);color:var(--stone-dark);align-items:center;gap:10px;margin-bottom:16px;padding:14px;font-size:.8rem;display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.scanning-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:1.2s infinite pulse}.menu-item-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:12px;margin-bottom:8px;padding:14px 16px;display:flex}.menu-item-body{flex:1}.menu-item-name{margin-bottom:3px;font-family:Cormorant Garamond,serif;font-size:1.05rem;font-weight:400}.menu-item-desc{color:var(--stone);margin-bottom:6px;font-size:.78rem;line-height:1.4}.menu-item-footer{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.portion-badge{color:var(--stone-dark);background:var(--cream);letter-spacing:.04em;border-radius:10px;padding:2px 8px;font-size:.65rem}.notes-category{margin-bottom:24px}.notes-category-title{letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-bottom:10px;font-size:.65rem}.note-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:12px;margin-bottom:8px;padding:14px 16px;display:flex}.note-card.pinned{border-left:2px solid var(--accent)}.note-body{flex:1}.note-content{margin-bottom:4px;font-size:.85rem;line-height:1.5}.note-time{color:var(--stone);font-size:.68rem}.note-actions{opacity:0;gap:6px;transition:opacity .2s;display:flex}.note-card:hover .note-actions{opacity:1}.new-note-form{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;padding:14px}.new-note-form textarea{width:100%;color:var(--ink);resize:none;background:0 0;border:none;outline:none;min-height:60px;margin-bottom:10px;font-family:Jost,sans-serif;font-size:.85rem}.new-note-footer{justify-content:space-between;align-items:center;gap:8px;display:flex}.new-note-footer select{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);color:var(--stone-dark);outline:none;padding:6px 10px;font-family:Jost,sans-serif;font-size:.78rem}.sections-modal{background:var(--white);border-radius:12px;width:100%;max-width:400px;padding:28px;box-shadow:0 8px 40px #00000026}.sections-modal h3{margin-bottom:20px;font-family:Cormorant Garamond,serif;font-size:1.3rem;font-weight:400}.section-edit-item{align-items:center;gap:8px;margin-bottom:8px;display:flex}.section-edit-item input{border:1px solid var(--cream-dark);border-radius:var(--radius);background:var(--cream);color:var(--ink);outline:none;flex:1;padding:8px 10px;font-family:Jost,sans-serif;font-size:.85rem}.btn-fab{background:var(--ink);width:48px;height:48px;color:var(--white);cursor:pointer;z-index:50;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;transition:transform .2s;display:flex;position:fixed;bottom:80px;right:20px;box-shadow:0 4px 14px #0003}.btn-fab:hover{transform:scale(1.08)}.empty-state{text-align:center;color:var(--stone);padding:48px 20px}.empty-state p{margin-bottom:16px;font-size:.85rem}.flex{display:flex}.flex-1{flex:1}.gap-8{gap:8px}.mt-8{margin-top:8px}.mb-0{margin-bottom:0}.category-filter{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.category-btn{border:1px solid var(--cream-dark);background:var(--white);letter-spacing:.05em;cursor:pointer;color:var(--stone-dark);border-radius:14px;padding:4px 12px;font-family:Jost,sans-serif;font-size:.72rem;transition:all .15s}.category-btn.active{background:var(--ink);border-color:var(--ink);color:var(--white)}.loading{text-align:center;color:var(--stone);letter-spacing:.08em;padding:48px;font-size:.82rem}
