:root{--bg: #F5EFE6;--paper: #FAF6EE;--ink: #2B231A;--ink-soft: #5A4D3F;--ink-mute: #8A7B68;--rule: #E3D6BD;--rule-soft: #ECE2CE;--serif: "Instrument Serif", "Iowan Old Style", Georgia, serif;--mono: "Geist Mono", ui-monospace, "SF Mono", monospace;--r-card: 18px;--r-pill: 999px;--content-max: 1280px;--content-pad: 20px;--detail-max: 800px}@media(min-width:600px){:root{--content-pad: 32px}}@media(min-width:900px){:root{--content-pad: 48px}}@media(min-width:1200px){:root{--content-pad: 72px}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--mono);font-size:13px;line-height:1.5;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-height:100vh}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}ul,ol{margin:0;padding:0;list-style:none}h1,h2,h3{margin:0;font-weight:400}.content-wrap{max-width:var(--content-max);margin:0 auto;padding-left:var(--content-pad);padding-right:var(--content-pad)}.detail-wrap{max-width:var(--detail-max);margin:0 auto;padding-left:var(--content-pad);padding-right:var(--content-pad)}.list-sticky{position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--rule)}.app-header{padding:18px 0 10px}@media(min-width:768px){.app-header{padding:24px 0 14px}}.app-header-top{display:flex;align-items:center;justify-content:space-between;gap:16px}.add-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--rule);background:var(--paper);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s,border-color .12s}.add-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.app-logo-wrap{display:flex;flex-direction:column;gap:2px;font-weight:400}.app-logo{display:block;height:40px;width:auto;object-fit:contain;object-position:left center}@media(min-width:600px){.app-logo{height:48px}}@media(min-width:900px){.app-logo{height:56px}}.app-logo-sub{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);padding-left:2px}.search-wrap{padding:4px 0 8px}.search-field{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--ink-mute);pointer-events:none;flex-shrink:0}.search-input{width:100%;height:40px;padding:0 36px 0 34px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-pill);font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--ink);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .14s,box-shadow .14s}.search-input::placeholder{color:var(--ink-mute)}.search-input::-webkit-search-cancel-button{display:none}.search-input:focus{border-color:var(--ink-soft);box-shadow:0 0 0 3px #2b231a12}.search-clear{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--rule);border:none;cursor:pointer;color:var(--ink-soft);transition:background .12s}.search-clear:hover{background:var(--rule-soft)}.sort-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;gap:12px}.recipe-count{display:inline-flex;align-items:baseline;gap:5px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}.recipe-count-num{color:var(--ink);font-weight:500}.sort-control{position:relative}.sort-trigger{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--rule);font-size:12px;color:var(--ink-soft);transition:border-color .12s,color .12s}.sort-trigger:hover{border-color:var(--ink-soft);color:var(--ink)}.sort-trigger .sort-lab{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}.sort-trigger .sort-val{font-weight:500;color:var(--ink)}.sort-trigger svg{opacity:.6;margin-left:-2px}.sort-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:4px;box-shadow:0 14px 30px -10px #2b231a2e;z-index:20;display:flex;flex-direction:column;gap:1px}.sort-menu-item{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-radius:8px;font-size:13px;color:var(--ink-soft);text-align:left;transition:background .1s,color .1s}.sort-menu-item:hover{background:var(--bg);color:var(--ink)}.sort-menu-item.active{color:var(--ink);font-weight:500}.filter-wrap{position:relative;padding-top:6px;padding-bottom:2px}.filter-wrap:before,.filter-wrap:after{content:"";position:absolute;top:0;bottom:0;width:24px;pointer-events:none;z-index:2}.filter-wrap:before{left:0;background:linear-gradient(to right,var(--bg) 0%,transparent 100%)}.filter-wrap:after{right:0;background:linear-gradient(to left,var(--bg) 0%,transparent 100%)}@media(min-width:768px){.filter-wrap:before,.filter-wrap:after{display:none}}.filter-row{display:flex;gap:8px;padding:4px 0 10px;overflow-x:auto;scrollbar-width:none}@media(min-width:768px){.filter-row{flex-wrap:wrap;overflow-x:visible}}.filter-row::-webkit-scrollbar{display:none}.chip{padding:7px 14px;border-radius:var(--r-pill);background:transparent;border:1px solid var(--rule);font-size:13px;color:var(--ink-soft);white-space:nowrap;transition:background .12s,color .12s,border-color .12s;flex-shrink:0}.chip:hover{border-color:var(--ink-soft)}.chip-active{background:var(--ink);color:var(--bg);border-color:var(--ink)}@keyframes card-in{0%{opacity:0;transform:translateY(22px) scale(.93)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes card-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.88) translateY(10px)}}.list-body{padding-bottom:48px}.recipe-grid{display:grid;gap:16px;padding:24px 0 8px;grid-template-columns:1fr}@media(min-width:560px){.recipe-grid{grid-template-columns:repeat(2,1fr);gap:20px}}@media(min-width:900px){.recipe-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.recipe-grid{grid-template-columns:repeat(4,1fr)}}.recipe-grid>li{animation:card-in .48s cubic-bezier(.34,1.56,.64,1) both}.recipe-grid>li.card-leaving{animation:card-out .26s ease-in both;pointer-events:none}.recipe-card{width:100%;text-align:left;background:var(--paper);border-radius:var(--r-card);overflow:hidden;border:1px solid var(--rule-soft);display:block;transition:transform .16s ease,box-shadow .16s ease,border-color .16s}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px -12px #2b231a2e;border-color:var(--rule)}.recipe-card:has(.recipe-card-tap:active){transform:translateY(0)}.recipe-card-tap{display:block;width:100%;text-align:left;background:none;border:none;padding:0;cursor:pointer;-webkit-appearance:none}.recipe-card-body-main{padding:14px 16px 12px}.recipe-cover{position:relative;overflow:hidden;display:flex;align-items:center;padding:10px 14px}.recipe-cover-card{height:36px}.recipe-cover-strip{height:48px;padding:0;view-transition-name:recipe-strip}.recipe-cover-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.18) 0 1px,transparent 1px 9px);pointer-events:none}.recipe-cover-tag{position:relative;display:inline-flex;align-items:center;gap:8px}.recipe-cover-dot{width:8px;height:8px;border-radius:50%;opacity:.85;flex-shrink:0}.recipe-cover-label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.75}.strip-inner{display:flex;justify-content:space-between;align-items:center;max-width:var(--detail-max);margin:0 auto;padding:0 var(--content-pad);height:100%;width:100%}.recipe-cover-votes{position:relative;display:inline-flex;gap:12px;align-items:center}.recipe-cover-votes .vote{color:inherit;opacity:.85}.recipe-card-body{padding:14px 16px}.recipe-card-title{font-family:var(--serif);font-size:22px;line-height:1.1;letter-spacing:-.01em;margin-bottom:10px;text-wrap:balance}@media(min-width:900px){.recipe-card-title{font-size:24px}}.recipe-card-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px 14px;border-top:1px solid var(--rule-soft)}.recipe-card-author{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}.recipe-card-votes{display:inline-flex;gap:12px;align-items:center;color:var(--ink-mute)}.vote{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:11px;letter-spacing:.02em}.vote svg{opacity:.75}.vote-up{color:var(--ink-soft)}.vote-down{color:var(--ink-mute)}.vote-btn{background:none;border:none;padding:3px 5px;margin:-3px -5px;cursor:pointer;border-radius:6px;transition:background .12s,color .12s}.vote-btn:hover{background:var(--rule-soft)}.vote-btn.voted{color:var(--ink)}.vote-btn.voted svg{opacity:1}.submit-card{display:flex;align-items:center;gap:14px;width:100%;margin:8px 0 4px;padding:16px 18px;background:var(--paper);border:1px dashed var(--ink-mute);border-radius:var(--r-card);text-align:left;color:var(--ink);transition:background .12s,border-color .12s,transform .12s}.submit-card:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);border-style:solid}.submit-card:active{transform:translateY(1px)}.submit-card-icon{width:36px;height:36px;border-radius:50%;background:var(--bg);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;flex-shrink:0}.submit-card:hover .submit-card-icon{background:var(--bg);border-color:var(--bg)}.submit-card-body{flex:1;min-width:0}.submit-card-title{font-family:var(--serif);font-size:20px;line-height:1.1;letter-spacing:-.01em}.submit-card-sub{font-size:10.5px;color:var(--ink-mute);margin-top:4px;line-height:1.4}.submit-card:hover .submit-card-sub{color:#f5efe6b3}.submit-card-arrow{opacity:.5}.app-foot{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;padding:16px 0 24px;font-family:var(--mono);font-size:10px;color:var(--ink-mute);letter-spacing:.16em;text-transform:uppercase}.app-foot-updated{opacity:.6}.detail-topbar{position:sticky;top:0;z-index:10;padding:14px 0;background:linear-gradient(180deg,var(--bg) 70%,transparent 100%)}.detail-topbar-inner{display:flex;justify-content:space-between;align-items:center;max-width:var(--detail-max);margin:0 auto;padding:0 var(--content-pad)}.back-btn,.print-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--rule);font-size:13px;color:var(--ink-soft);transition:background .12s,color .12s}.back-btn:hover,.print-btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.detail-topbar-left{display:flex;align-items:center;gap:10px}.detail-topbar-icon{width:32px;height:32px;border-radius:8px;object-fit:contain}.detail-head{padding:24px 0 0}.detail-title{font-family:var(--serif);font-size:38px;line-height:1.05;letter-spacing:-.015em;text-wrap:balance}@media(min-width:600px){.detail-title{font-size:48px}}.detail-author{margin-top:10px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}.detail-desc{margin:14px 0 0;font-size:12.5px;line-height:1.6;color:var(--ink-soft);text-wrap:pretty;max-width:56ch}.controls-card{margin:20px 0 0;background:var(--paper);border:1px solid var(--rule);border-radius:var(--r-card);padding:2px 14px}.controls-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 0;flex-wrap:wrap;row-gap:10px}.control-label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}.controls-divider{height:1px;background:var(--rule-soft)}.quantity-cluster{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.qty-unit-toggle{display:inline-flex;background:var(--bg);border:1px solid var(--rule);border-radius:var(--r-pill);padding:3px;gap:2px}.qty-unit-toggle button{padding:7px 12px;border-radius:var(--r-pill);font-size:12px;font-weight:500;color:var(--ink-soft);transition:background .12s,color .12s;line-height:1}.qty-unit-toggle button.active{background:var(--ink);color:var(--bg)}.stepper{display:inline-flex;align-items:center;background:var(--bg);border:1px solid var(--rule);border-radius:var(--r-pill);padding:4px}.stepper button{width:32px;height:32px;border-radius:50%;font-size:18px;color:var(--ink);transition:background .12s;display:inline-flex;align-items:center;justify-content:center}.stepper button:hover:not(:disabled){background:var(--ink);color:var(--bg)}.stepper button:disabled{opacity:.3;cursor:not-allowed}.stepper-value{min-width:60px;text-align:center;padding:0 8px}.stepper-num{font-family:var(--mono);font-size:13px;font-weight:500;line-height:1;display:inline-flex;align-items:baseline;gap:4px;justify-content:center;color:var(--ink)}.stepper-unit{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-mute);font-weight:400}.unit-toggle{display:inline-flex;background:var(--bg);border:1px solid var(--rule);border-radius:var(--r-pill);padding:3px;gap:2px}.unit-toggle button{padding:7px 12px;border-radius:var(--r-pill);font-size:12px;font-weight:500;color:var(--ink-soft);transition:background .12s,color .12s;line-height:1}.unit-toggle button.active{background:var(--ink);color:var(--bg)}.section{padding:32px 0 0}.section-title{font-family:var(--serif);font-size:26px;line-height:1;letter-spacing:-.01em;margin-bottom:16px}.ingredient-list{display:flex;flex-direction:column}.ingredient{display:grid;grid-template-columns:24px 96px 1fr;gap:12px;align-items:baseline;padding:12px 0;border-top:1px solid var(--rule-soft)}.ingredient:last-child{border-bottom:1px solid var(--rule-soft)}.ingredient-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--ink-mute);background:transparent;display:inline-flex;align-items:center;justify-content:center;transition:background .12s;flex-shrink:0;align-self:center}.ingredient-check:hover{background:#2b231a0d}.ingredient-done .ingredient-check{background:currentColor}.ingredient-done .ingredient-check svg path{stroke:var(--paper)}.ingredient-done .ingredient-qty,.ingredient-done .ingredient-name{opacity:.4;text-decoration:line-through;text-decoration-color:var(--ink-mute)}.ingredient-qty{font-family:var(--mono);font-size:13px;color:var(--ink);display:flex;gap:4px;align-items:baseline;flex-wrap:wrap}.qty-num{font-weight:500}.qty-unit{color:var(--ink-mute);font-size:11px;letter-spacing:.04em}.ingredient-name{font-size:12.5px;line-height:1.4;color:var(--ink)}.opt{color:var(--ink-mute);font-style:italic;font-size:12px}.tip{margin:32px 0 0;padding:16px 18px;border-left:2px solid;background:var(--paper);border-radius:0 var(--r-card) var(--r-card) 0}.tip-lab{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px}.tip-text{font-size:12px;line-height:1.6;color:var(--ink-soft);font-style:italic;text-wrap:pretty}.detail-foot{margin:40px 0;padding-top:20px;border-top:1px solid var(--rule);text-align:center}.back-link{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}.back-link:hover{color:var(--ink)}@media(prefers-reduced-motion:no-preference){@keyframes vt-fade-out{to{opacity:0}}@keyframes vt-fade-in{0%{opacity:0}}::view-transition-old(root){animation:.22s ease-in both vt-fade-out}::view-transition-new(root){animation:.38s cubic-bezier(.2,0,0,1) .1s both vt-fade-in}html.nav-back::view-transition-old(root){animation:.2s ease-in both vt-fade-out}html.nav-back::view-transition-new(root){animation:.32s cubic-bezier(.2,0,0,1) 70ms both vt-fade-in}::view-transition-old(recipe-strip),::view-transition-new(recipe-strip){animation-duration:.42s;animation-timing-function:cubic-bezier(.4,0,.2,1)}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2b231a73;z-index:100;opacity:0;pointer-events:none;transition:opacity .3s ease}.drawer-backdrop-open{opacity:1;pointer-events:auto}.submit-drawer{position:fixed;z-index:101;background:var(--bg);display:flex;flex-direction:column;transition:transform .38s cubic-bezier(.4,0,.2,1)}@media(max-width:767px){.submit-drawer{bottom:0;left:0;right:0;max-height:92dvh;border-radius:20px 20px 0 0;box-shadow:0 -8px 40px -8px #2b231a33;transform:translateY(100%)}.submit-drawer-open{transform:translateY(0)}}@media(min-width:768px){.submit-drawer{top:0;right:0;bottom:0;width:480px;border-left:1px solid var(--rule);box-shadow:-12px 0 40px -12px #2b231a2e;transform:translate(100%)}.submit-drawer-open{transform:translate(0)}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--rule);flex-shrink:0}.drawer-title{font-family:var(--serif);font-size:28px;letter-spacing:-.01em}.drawer-close{width:32px;height:32px;border-radius:50%;border:1px solid var(--rule);background:var(--paper);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:background .12s,color .12s;flex-shrink:0}.drawer-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.drawer-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:22px;-webkit-overflow-scrolling:touch}.drawer-body::-webkit-scrollbar{width:4px}.drawer-body::-webkit-scrollbar-thumb{background:var(--rule);border-radius:2px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--rule);flex-shrink:0}.form-field{display:flex;flex-direction:column;gap:8px}.form-label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);display:flex;align-items:baseline;gap:8px}.form-label-error{color:#9a2b3a}.form-label-hint{font-size:10px;letter-spacing:.04em;text-transform:none;color:var(--ink-mute);font-style:italic;opacity:.8}.form-optional{font-size:10px;letter-spacing:.04em;text-transform:none;opacity:.6}.form-input{width:100%;padding:10px 14px;border:1px solid var(--rule);border-radius:10px;background:var(--paper);font:inherit;font-size:13px;color:var(--ink);transition:border-color .15s;-webkit-appearance:none}.form-input:focus{outline:none;border-color:var(--ink-soft)}.form-input::placeholder{color:var(--ink-mute)}.form-input-error{border-color:#c8636b}.form-textarea{resize:vertical;min-height:72px;line-height:1.55}.form-error{font-size:11px;color:#9a2b3a;letter-spacing:.02em}.category-chips{display:flex;flex-wrap:wrap;gap:8px}.ingredient-rows{display:flex;flex-direction:column;gap:8px}.ing-row{display:grid;grid-template-columns:72px 80px 1fr auto;gap:6px;align-items:center}.ing-amount,.ing-unit,.ing-name{padding:9px 10px;border:1px solid var(--rule);border-radius:8px;background:var(--paper);font:inherit;font-size:13px;color:var(--ink);transition:border-color .15s;-webkit-appearance:none}.ing-amount{text-align:right}.ing-amount::-webkit-inner-spin-button,.ing-amount::-webkit-outer-spin-button{opacity:0}.ing-amount:focus,.ing-unit:focus,.ing-name:focus{outline:none;border-color:var(--ink-soft)}.ing-amount::placeholder,.ing-name::placeholder{color:var(--ink-mute)}.ing-amount:disabled{opacity:.35}.ing-remove{width:28px;height:28px;border-radius:50%;border:1px solid var(--rule);background:transparent;display:flex;align-items:center;justify-content:center;color:var(--ink-mute);flex-shrink:0;transition:background .12s,color .12s,border-color .12s}.ing-remove:hover{background:#f4c9c9;color:#9a2b3a;border-color:#c8636b}.add-ingredient-btn{display:inline-flex;align-items:center;gap:7px;margin-top:4px;padding:8px 14px;border-radius:var(--r-pill);border:1px dashed var(--ink-mute);font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-mute);transition:border-color .12s,color .12s,background .12s;align-self:flex-start}.add-ingredient-btn:hover{border-color:var(--ink-soft);color:var(--ink);background:var(--paper);border-style:solid}.submit-btn{width:100%;padding:13px 20px;border-radius:var(--r-pill);background:var(--ink);color:var(--bg);font-family:var(--mono);font-size:13px;letter-spacing:.06em;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s}.submit-btn:hover{opacity:.88}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.drawer-cancel-btn{width:100%;padding:13px 20px;border-radius:var(--r-pill);border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);font-family:var(--mono);font-size:13px;letter-spacing:.06em;transition:border-color .12s,color .12s}.drawer-cancel-btn:hover{border-color:var(--ink-soft);color:var(--ink)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin .7s linear infinite}.success-view{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;text-align:center;gap:12px}.success-check{width:56px;height:56px;border-radius:50%;background:var(--paper);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:8px}.success-title{font-family:var(--serif);font-size:32px;letter-spacing:-.01em}.success-name{font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink-soft);margin:0}.success-sub{font-size:12px;color:var(--ink-mute);margin:0 0 16px}.success-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px}@media print{body{background:#fff!important}.list-sticky,.detail-topbar,.back-link,.back-btn,.print-btn,.recipe-cover{display:none!important}.recipe-grid{grid-template-columns:repeat(2,1fr)!important}}
