/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@import "https://unpkg.com/@phosphor-icons/web@2.1.1/src/regular/style.css";@import "https://unpkg.com/@phosphor-icons/web@2.1.1/src/fill/style.css";@import "https://unpkg.com/@phosphor-icons/web@2.1.1/src/duotone/style.css";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", sans-serif;--font-serif:"New York", "Literata", "Iowan Old Style", "Charter", Georgia, serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-indigo-500:oklch(58.5% .233 277.117);--color-indigo-600:oklch(51.1% .262 276.966);--color-indigo-700:oklch(45.7% .24 277.023);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-white:#fff;--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--font-weight-medium:500;--font-weight-bold:700;--radius-sm:8px;--radius-md:12px;--radius-lg:22px;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#f5f1ea;--color-bg-2:#ede7db;--color-card:#fff;--color-ink:#1c1917;--color-ink-2:#57534e;--color-ink-3:#78716c;--color-line:#e7e1d7;--color-accent:#b85c38;--color-accent-soft:#fbeee6;--color-tag-bg:#efe9dd;--color-tag-ink:#4b4339;--color-good:#4d7c4f;--color-cook-dark:#1c1917;--color-cook-amber:#e8a05c;--tint-accent-soft:#b85c3824;--tint-accent-medium:#b85c382e;--color-danger:#9a3b2a;--color-danger-ink:#6b2a1e;--color-danger-bg:#fdecea;--tint-danger-line:#9a3b2a40;--radius-card:14px;--tab-bar-height:72px;--duration-fast:.15s;--shadow-card:0 10px 40px #1c191714, 0 2px 6px #1c19170a;--shadow-card-lg:0 20px 60px #1c19171a, 0 4px 12px #1c19170a;--shadow-accent:0 8px 24px #b85c3866;--shadow-btn:0 6px 18px #b85c3847}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*,:before,:after{box-sizing:border-box;-webkit-font-smoothing:antialiased}html,body{margin:0;padding:0;overflow-x:clip}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-ink);min-height:100dvh}h1,h2,h3{letter-spacing:-.02em}a{color:inherit;text-decoration:none}ul,ol{margin:0;padding:0;list-style:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes timer-glow{0%,to{box-shadow:0 0 #e8a05c00,inset 0 0 0 1px #e8a05c8c}50%{box-shadow:0 0 28px 2px #e8a05c66,inset 0 0 0 1px #e8a05cbf}}@keyframes timer-flash{0%{opacity:0}20%{opacity:1}to{opacity:0}}}@layer components{.app-shell{min-height:100dvh;display:flex}.app-sidebar{background:var(--color-bg-2);border-right:1px solid var(--color-line);flex-direction:column;flex-shrink:0;gap:28px;width:240px;height:100dvh;padding:28px 16px;display:none;position:sticky;top:0;overflow-y:auto}@media (min-width:768px){.app-sidebar{display:flex}}.sidebar-brand{align-items:center;gap:10px;padding:0 12px;display:flex}.sidebar-brand-mark{border-radius:var(--radius-sm);background:var(--color-accent-soft);width:32px;height:32px;color:var(--color-accent);flex-shrink:0;justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex}.sidebar-brand-mark i{font-size:20px;line-height:1}.sidebar-brand-name{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--color-ink);font-size:18px;font-weight:500}.sidebar-nav-group{flex-direction:column;gap:2px;display:flex}.sidebar-nav-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-ink-3);padding:0 12px 8px;font-size:10px;font-weight:600}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--color-ink-2);cursor:pointer;transition:background var(--duration-fast), color var(--duration-fast);align-items:center;gap:10px;padding:9px 12px;font-size:14px;font-weight:500;display:flex}.sidebar-nav-item:hover{color:var(--color-ink);background:#1c19170f}.sidebar-nav-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.sidebar-nav-item.active{background:var(--color-ink);color:#fff}.sidebar-nav-item .nav-icon{opacity:.8;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:24px;display:flex}.sidebar-nav-item.active .nav-icon{opacity:1}.sidebar-nav-count{color:var(--color-ink-3);margin-left:auto;font-size:11px;font-weight:500}.sidebar-nav-item.active .sidebar-nav-count{color:#fff9}.sidebar-footer{border-top:1px solid var(--color-line);align-items:center;gap:10px;margin-top:auto;padding:12px;display:flex}.user-avatar{background:var(--color-bg-2);width:32px;height:32px;color:var(--color-accent);font-family:var(--font-serif);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-style:italic;font-weight:500;display:flex}.user-name{font-size:13px;font-weight:600;line-height:1.2}.user-plan{color:var(--color-ink-3);font-size:11px}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}.app-main-inner{padding:20px 16px 100px}@media (min-width:768px){.app-main-inner{padding:32px 48px 48px}}.tab-bar{padding:10px 0 env(safe-area-inset-bottom,16px);border-top:1px solid var(--color-line);background:var(--color-card);z-index:50;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}@media (min-width:768px){.tab-bar{display:none}}.tab-bar-item{color:var(--color-ink-3);cursor:pointer;flex-direction:column;align-items:center;gap:4px;padding:4px 16px;font-size:10px;font-weight:500;display:flex}.tab-bar-item.active{color:var(--color-accent)}.tab-bar-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.tab-bar-item>i{font-size:26px;line-height:1}.tab-bar-item svg{width:26px;height:26px}.fab{right:18px;bottom:calc(68px + env(safe-area-inset-bottom,0px));background:var(--color-accent);color:#fff;width:54px;height:54px;box-shadow:var(--shadow-accent);z-index:40;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:28px;font-weight:300;display:flex;position:fixed}.fab:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}@media (min-width:768px){.fab{display:none}}@media (max-width:767px){#sentry-feedback{--actor-inset:auto 0 calc(var(--tab-bar-height) - 12px + env(safe-area-inset-bottom,0px)) auto}}.surface{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-card)}.surface--lg{border-radius:var(--radius-lg)}.surface--shadow{box-shadow:var(--shadow-card)}.dropdown-panel{z-index:20;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:6px}.dropdown-item{border-radius:var(--radius-sm);color:var(--color-ink);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;display:flex}.dropdown-item:hover,.dropdown-item:focus-visible{background:var(--color-bg-2);outline:none}.dropdown-item--danger{color:var(--color-danger)}.dropdown-item--danger:hover{color:#8a2f22;background:#fbe9e4}.empty-state{text-align:center;max-width:520px;margin:24px auto;padding:48px 20px}@media (min-width:768px){.empty-state{margin-top:40px;padding:72px 24px}}.empty-state--boxed{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);max-width:none;margin:0;padding:56px 28px}@media (min-width:768px){.empty-state--boxed{margin-top:0;padding:56px 28px}}.empty-state--filtered{padding-top:40px;padding-bottom:40px}.empty-state .empty-mark{background:var(--color-accent-soft);width:56px;height:56px;color:var(--color-accent);border-radius:999px;justify-content:center;align-items:center;margin-bottom:18px;display:inline-flex}.empty-state .empty-mark i{font-size:26px;line-height:1}.empty-state--boxed .empty-mark{width:64px;height:64px;font-size:28px}.empty-state .empty-title{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--color-ink);margin:0 0 10px;font-size:clamp(22px,3vw,28px);font-weight:500;line-height:1.2}.empty-state--boxed .empty-title{margin-bottom:8px;font-size:24px}.empty-state .empty-lead,.empty-state .empty-desc{color:var(--color-ink-2);max-width:38ch;margin:0 auto 24px;font-size:14px;line-height:1.55}.empty-state--boxed .empty-desc{max-width:420px;margin-bottom:20px}.empty-state .empty-sub{color:var(--color-ink-2);margin:0 0 18px;font-size:13px;line-height:1.6}.empty-state .empty-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:inline-flex}.empty-filter-chip{background:var(--color-tag-bg);color:var(--color-tag-ink);white-space:nowrap;border-radius:999px;margin:0 2px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.form-actions{justify-content:flex-end;align-items:center;gap:8px;margin-top:24px;display:flex}.form-actions--split{flex-wrap:wrap;justify-content:flex-start;gap:16px}.error-summary{border-radius:var(--radius-md);margin-bottom:16px;padding:12px 14px;font-size:13px}.error-summary--soft{background:var(--color-danger-bg);border:1px solid var(--tint-danger-line);color:var(--color-danger-ink)}.error-summary--soft h3{letter-spacing:.08em;text-transform:uppercase;color:var(--color-danger);margin:0 0 6px;font-size:12px;font-weight:700}.error-summary--soft ul{margin:0;padding-left:18px}.error-summary--soft a{color:inherit;text-decoration:underline}.error-summary--hard{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;margin-bottom:20px;padding:12px 16px}.error-summary--hard h3{margin-bottom:6px;font-weight:600}.error-summary--hard ul{padding-left:20px;list-style:outside}.accent-banner{background:var(--color-accent-soft);border:1px solid var(--tint-accent-medium);border-radius:var(--radius-md);align-items:center;gap:14px;padding:12px 14px;display:flex}.accent-banner-icon{border-radius:var(--radius-sm);background:var(--tint-accent-soft);width:36px;height:36px;color:var(--color-accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--duration-fast);background:var(--color-accent);color:#fff;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn:hover{opacity:.9}.btn:active{opacity:.8}.btn:disabled,.btn[disabled]{opacity:.45;cursor:not-allowed}.btn:disabled:hover,.btn[disabled]:hover{opacity:.45}.btn-secondary{background:var(--color-card);color:var(--color-ink);border:1px solid var(--color-line)}.btn-ghost{color:var(--color-ink-2);border:1px solid var(--color-line);background:0 0}.btn-icon{border-radius:var(--radius-md);border:1px solid var(--color-line);background:var(--color-card);width:48px;height:48px;color:var(--color-ink-2);cursor:pointer;transition:background var(--duration-fast);justify-content:center;align-items:center;font-size:16px;display:flex}.btn-icon:hover{background:var(--color-bg-2)}.btn-circle{cursor:pointer;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;font-weight:500;display:flex}.search-input{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);color:var(--color-ink-3);cursor:text;width:100%;transition:border-color var(--duration-fast);align-items:center;gap:8px;padding:10px 14px;font-family:inherit;font-size:14px;display:flex}.search-input:focus-within{border-color:var(--color-accent);outline:none}@media (min-width:768px){.search-input{width:280px}}.url-input{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);color:var(--color-ink);word-break:break-all;width:100%;padding:14px 16px;font-family:inherit;font-size:13px}.url-input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.form-control,.recipe-form select{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);width:100%;color:var(--color-ink);box-sizing:border-box;max-width:100%;padding:10px 12px;font-family:inherit;font-size:14px;display:block}.recipe-form select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M3 4.5L6 7.5L9 4.5' stroke='%2378716c' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.recipe-form select::-ms-expand{display:none}.recipe-form select:focus,.form-control:focus{border-color:var(--color-accent);outline:none}textarea.form-control{resize:vertical;min-height:72px;line-height:1.5}.nested-row textarea.form-control{min-height:40px;padding-top:9px;padding-bottom:9px}.recipe-form{max-width:760px;margin-left:auto;margin-right:auto}.recipe-form label{color:var(--color-ink-2);margin-bottom:6px;font-size:13px;font-weight:500;display:inline-block}.recipe-form .field-lead-label{margin-bottom:0}.recipe-form label abbr[title]{color:var(--color-accent);border:0;margin-right:2px;font-weight:700;text-decoration:none}.form-section{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-card);margin-bottom:20px;padding:20px}.form-section .section-title{font-family:var(--font-serif);letter-spacing:normal;text-transform:none;color:var(--color-ink);border-bottom:1px solid var(--color-line);margin:0 0 16px;padding-bottom:12px;font-size:22px;font-weight:500;line-height:1.2}.form-grid-3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.nested-list{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.nested-row{align-items:flex-start;gap:8px;display:flex}.nested-row-fields{flex-wrap:wrap;flex:1;gap:8px;display:flex}.nested-row-fields .mb-5{margin-bottom:0}.field-qty{width:80px}.field-unit{width:96px}.field-grow{flex:1;min-width:160px}.field-category{width:104px}.field-lead-part{width:72px}.field-hidden{display:none!important}.field-modifier .form-control{border-color:#0000;border-bottom:1px dashed var(--color-line);color:var(--color-ink-2);background:0 0;border-radius:0;padding-left:4px;padding-right:4px;font-size:13px}.field-modifier .form-control::placeholder{color:var(--color-ink-3);font-style:italic}.field-modifier .form-control:focus{border-bottom-style:solid;border-bottom-color:var(--color-accent);color:var(--color-ink)}.nested-row>.nested-row-fields>*{align-self:flex-start}.step-row{flex-direction:column;align-items:stretch;gap:8px;display:flex}.step-row-header{flex-wrap:wrap;align-items:center;gap:8px 10px;min-height:40px;display:flex}.step-row-header .field-category,.step-row-header .field-category.mb-5{flex:auto;min-width:0;max-width:180px;margin:0}.step-row-header .field-category .form-control{width:100%;height:40px;margin:0}@media (min-width:640px){.step-row-header .field-category,.step-row-header .field-category.mb-5{flex:none;width:104px;max-width:none}}.step-row-number{background:var(--color-accent-soft);width:28px;height:28px;color:var(--color-accent);font-family:var(--font-serif);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:inline-flex}.step-row-header .nested-row-remove{width:40px;height:40px;margin-left:auto}.step-row-body.mb-5{margin-bottom:0}.step-row-body .form-control{width:100%}.field-lead{flex-wrap:wrap;flex-basis:100%;order:1;align-items:center;gap:4px 6px;padding-left:36px;display:inline-flex}@media (min-width:640px){.field-lead{flex-wrap:nowrap;flex-basis:auto;order:0;padding-left:0}}.field-lead-input{text-align:center;width:48px;height:36px;padding-left:4px;padding-right:4px;font-size:14px}.field-lead-prefix,.field-lead-suffix{color:var(--color-ink-2);font-size:13px;font-weight:500}.field-lead-unit{color:var(--color-ink-3);margin-right:2px;font-size:12px;font-weight:500}.form-section>.btn-add-row{border:1px dashed var(--color-line);color:var(--color-accent);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast);background:0 0;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.form-section>.btn-add-row:hover,.form-section>.btn-add-row:focus-visible{background:var(--color-accent-soft);border-color:var(--color-accent);border-style:solid;outline:none}.form-photo-field{flex-direction:column;gap:12px;display:flex}.form-photo-label{color:var(--color-ink);margin-bottom:-4px;font-size:13px;font-weight:600}.photo-picker-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.photo-strip{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.photo-tile{aspect-ratio:4/3;border:1px solid var(--color-line);border-radius:var(--radius-card);background:var(--color-bg-2);cursor:pointer;font:inherit;color:inherit;text-align:left;transition:border-color var(--duration-fast), transform var(--duration-fast);padding:0;position:relative;overflow:hidden}.photo-tile:hover{border-color:var(--color-ink-3)}.photo-tile:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.photo-tile.is-hero{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.photo-tile.is-removed{opacity:.45}.photo-tile.is-removed .photo-tile-remove,.photo-tile.is-removed .photo-tile-hero{display:none}.photo-tile.is-removed:after{content:"Tap to bring back";letter-spacing:.06em;text-transform:uppercase;color:var(--color-card);text-align:center;background:#1c1917b3;padding:6px 8px;font-size:11px;font-weight:600;position:absolute;inset:auto 0 0}.photo-tile-img{object-fit:cover;width:100%;height:100%;display:block}.photo-tile-hero{background:var(--color-accent);color:#fff;letter-spacing:.04em;border-radius:999px;align-items:center;gap:4px;padding:4px 9px 4px 7px;font-size:11px;font-weight:600;display:none;position:absolute;top:8px;left:8px}.photo-tile-hero i{font-size:12px}.photo-tile.is-hero .photo-tile-hero{display:inline-flex}.photo-tile-remove{color:#fff;cursor:pointer;width:30px;height:30px;transition:background var(--duration-fast);background:#1c1917b8;border:0;border-radius:999px;justify-content:center;align-items:center;font-size:14px;display:inline-flex;position:absolute;top:8px;right:8px}.photo-tile-remove:hover{background:var(--color-stoneware-ink,#1c1917)}.photo-tile-remove:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.photo-tile-new-flag{font-family:var(--font-serif);color:var(--color-card);text-shadow:0 1px 6px #1c191780;font-size:13px;font-style:italic;position:absolute;bottom:8px;left:10px}.photo-tile--letter{background:var(--color-card);flex-direction:column;align-items:stretch;display:flex}.photo-tile-monogram{border-radius:0;flex:1;justify-content:center;align-items:center;display:flex}.photo-tile-monogram .recipe-thumb-monogram{font-size:clamp(48px,9vw,72px)}.photo-tile-letter-label{color:var(--color-ink-2);text-align:center;border-top:1px solid var(--color-line);background:var(--color-card);padding:8px 10px 10px;font-size:12px;font-weight:600}.photo-tile--letter .photo-tile-hero{background:var(--color-accent)}label.photo-tile--add{border:1.5px dashed var(--color-accent);color:var(--color-accent);background:0 0;flex-direction:row;justify-content:center;align-items:center;gap:8px;margin-bottom:0;font-size:13px;font-weight:600;display:inline-flex}.photo-tile--add i{font-size:20px;line-height:1}.photo-tile--add:hover{background:var(--color-accent-soft);border-style:solid}.photo-picker-input:focus-visible+.photo-strip .photo-tile--add,.photo-tile--add:focus-within{outline:2px solid var(--color-accent);outline-offset:2px}.nested-row-remove{border-radius:var(--radius-md);border:1px solid var(--color-line);background:var(--color-card);width:44px;height:44px;color:var(--color-ink-3);cursor:pointer;flex-shrink:0;font-size:18px;line-height:1}.nested-row-remove:hover{color:#c0392b;border-color:#c0392b}.nested-row-remove:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.nested-row-undo{background:var(--color-bg-2);border:1px dashed var(--color-line);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:10px 12px 10px 14px;animation:.2s ease-out nested-undo-in;display:flex}.nested-row-undo-label{color:var(--color-ink-2);font-size:13px}.nested-row-undo-btn{background:var(--color-card);border:1px solid var(--color-line);color:var(--color-accent);border-radius:var(--radius-sm);cursor:pointer;min-height:36px;padding:6px 14px;font-size:13px;font-weight:600}.nested-row-undo-btn:hover,.nested-row-undo-btn:focus-visible{border-color:var(--color-accent);background:var(--color-accent-soft);outline:none}@keyframes nested-undo-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.nested-row-undo{animation:none}}.profile-divider{border:0;border-top:1px solid var(--color-line);margin:40px 0 32px}.form-section-hint{color:var(--color-ink-2);margin:-4px 0 16px;font-size:13px;line-height:1.5}.btn-sm{padding:6px 12px;font-size:12px}.recipe-actions{gap:8px;margin-bottom:16px;display:flex}.flash-stack{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;max-width:min(420px,100vw - 32px);display:flex;position:fixed;top:16px;right:16px}body.native-app .flash-stack{display:none}.flash{border-radius:var(--radius-md);pointer-events:auto;padding:10px 14px;font-size:13px;animation:4s forwards flash-slide;box-shadow:0 6px 20px #00000014}.flash-notice{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.flash-alert{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}@keyframes flash-slide{0%{opacity:0;transform:translate(120%)}8%{opacity:1;transform:translate(0)}88%{opacity:1;transform:translate(0)}to{opacity:0;visibility:hidden;transform:translate(120%)}}@media (prefers-reduced-motion:reduce){.flash{animation:4s forwards flash-fade}@keyframes flash-fade{0%,90%{opacity:1}to{opacity:0;visibility:hidden}}}.tag-editor{flex-direction:column;gap:12px;display:flex}.tag-editor-list{flex-wrap:wrap;gap:6px;min-height:8px;display:flex}.tag-editor-list:empty:before{content:"No tags yet.";color:var(--color-ink-3);font-size:13px;font-style:italic}.tag-editor-chip{background:var(--color-accent-soft);color:var(--color-accent);border-radius:999px;align-items:center;gap:6px;padding:4px 4px 4px 12px;font-size:12px;font-weight:500;display:inline-flex}.tag-editor-remove{color:inherit;cursor:pointer;background:0 0;border:0;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:16px;line-height:1;display:inline-flex}.tag-editor-remove:hover,.tag-editor-remove:focus-visible{background:#0000000f;outline:none}.tag-editor-input-row{align-items:stretch;gap:8px;display:flex}.tag-editor-combo{flex:1;min-width:0;position:relative}.tag-editor-input{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);width:100%;color:var(--color-ink);box-sizing:border-box;min-width:0;padding:10px 12px;font-family:inherit;font-size:14px}.tag-editor-input:focus{border-color:var(--color-accent);outline:none}.tag-editor-add{flex-shrink:0}.tag-editor-suggestions{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);z-index:20;max-height:240px;margin:0;padding:4px;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 6px 20px #00000014}.tag-editor-suggestion{color:var(--color-ink);cursor:pointer;border-radius:6px;padding:8px 10px;font-size:14px}.tag-editor-suggestion.is-active,.tag-editor-suggestion:hover{background:var(--color-tag-bg)}.form-section--quiet{border:0;border-top:1px solid var(--color-line);background:0 0;border-radius:0;margin-bottom:0;padding:24px 0 8px}.form-section--quiet .section-eyebrow{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-3);border:0;align-items:center;gap:8px;margin:0 0 18px;padding:0;font-size:11px;font-weight:600;display:flex}.form-section--quiet .section-eyebrow i{color:var(--color-ink-3);font-size:14px;line-height:1}.profile-detail-list{grid-template-columns:1fr;gap:16px 24px;margin:0;display:grid}@media (min-width:560px){.profile-detail-list{grid-template-columns:180px 1fr;align-items:baseline;gap:14px 32px}}.profile-detail-list dt{color:var(--color-ink-3);margin:0;font-size:13px;font-weight:400}.profile-detail-list dd{font-family:var(--font-serif);color:var(--color-ink);word-break:break-word;margin:0;font-size:18px;font-weight:500;line-height:1.3}@media (min-width:560px){.profile-detail-list dd{font-size:19px}}.profile-export{flex-direction:column;gap:18px;display:flex}.profile-export-lead{font-family:var(--font-serif);color:var(--color-ink-2);max-width:56ch;margin:0;font-size:16px;font-style:italic;line-height:1.55}.profile-export-meta{grid-template-columns:repeat(auto-fit,minmax(140px,max-content));gap:4px 32px;margin:0;display:grid}.profile-export-meta dt{letter-spacing:.1em;text-transform:uppercase;color:var(--color-ink-3);grid-row:1;margin:0;font-size:11px;font-weight:600}.profile-export-meta dd{font-family:var(--font-serif);color:var(--color-ink);grid-row:2;margin:0;font-size:22px;font-weight:500;line-height:1.2}.profile-export-actions{flex-wrap:wrap;gap:10px;display:flex}.profile-export-actions .btn{align-items:center;gap:8px;display:inline-flex}.profile-export-footnote{color:var(--color-ink-3);align-items:center;gap:8px;margin:0;font-size:13px;line-height:1.5;display:flex}.profile-export-footnote i{flex-shrink:0;font-size:14px}.profile-footer{border-top:1px solid var(--color-line);justify-content:flex-start;margin-top:32px;padding-top:20px;display:flex}.profile-footer .btn-signout{color:var(--color-ink-3);cursor:pointer;border-radius:var(--radius-md);transition:color var(--duration-fast);background:0 0;border:0;align-items:center;gap:8px;padding:8px 4px;font-size:13px;display:inline-flex}.profile-footer .btn-signout:hover,.profile-footer .btn-signout:focus-visible{color:var(--color-ink);outline:none}.profile-footer .btn-signout:focus-visible{box-shadow:0 0 0 2px var(--color-accent)}.profile-footer .btn-signout i{font-size:14px;line-height:1}.chip{background:var(--color-tag-bg);color:var(--color-tag-ink);white-space:nowrap;cursor:pointer;transition:background var(--duration-fast), color var(--duration-fast);border-radius:999px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}@media (min-width:768px){.chip{padding:7px 14px;font-size:13px}}a.chip:hover:not(.active),label.chip:hover:not(.active){background:var(--color-bg-2);color:var(--color-ink)}.chip.active{background:var(--color-ink);color:#fff}.chip-toggle{-webkit-user-select:none;user-select:none}.chip-toggle-input{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.chip-toggle:has(.chip-toggle-input:focus-visible){outline:2px solid var(--color-accent);outline-offset:2px}.chip.manual,.chip.suggested{background:var(--color-accent-soft);color:var(--color-accent)}.tag{color:var(--color-ink-2);background:var(--color-tag-bg);white-space:nowrap;border-radius:999px;align-items:center;padding:2px 7px;font-size:10px;font-weight:500;display:inline-flex}@media (min-width:768px){.tag{padding:3px 9px;font-size:11px}}.tag.manual{background:var(--color-accent-soft);color:var(--color-accent)}.filter-row{scrollbar-width:none;-ms-overflow-style:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-row::-webkit-scrollbar{display:none}@media (min-width:768px){.filter-row{flex-wrap:wrap;margin-bottom:24px;padding-bottom:0;overflow-x:visible}}.tag-more{position:relative}.tag-more>summary{list-style:none}.tag-more>summary::-webkit-details-marker{display:none}.tag-more-caret{opacity:.7;font-size:10px}.tag-more-badge{min-width:16px;height:16px;color:var(--color-ink);background:#fff;border-radius:999px;justify-content:center;align-items:center;padding:0 5px;font-size:11px;font-weight:600;display:inline-flex}.tag-more-panel{z-index:60;max-height:min(60vh,360px);padding:8px;position:fixed;top:auto;left:12px;right:12px;overflow-y:auto}@media (min-width:768px){.tag-more-panel{z-index:20;min-width:220px;max-height:320px;position:absolute;top:calc(100% + 6px);left:0;right:auto}}.tag-more-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.tag-more-option{cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:6px 8px;display:flex}.tag-more-option:hover{background:var(--color-tag-bg)}.tag-more-option input[type=checkbox]{accent-color:var(--color-ink)}.page-header{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}@media (min-width:768px){.page-header{flex-direction:row;justify-content:space-between;align-items:flex-end;margin-bottom:24px}}.page-title{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-size:28px;font-weight:500;line-height:1.15}@media (min-width:768px){.page-title{font-size:34px}}.page-sub{color:var(--color-ink-3);margin:4px 0 0;font-size:13px}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar>.search-input{flex:220px;min-width:0}.toolbar>.btn{margin-left:auto}@media (min-width:768px){.toolbar>.search-input{flex:none}.toolbar>.btn{margin-left:0}}.section-head{letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-3);padding:8px 0 10px;font-size:11px;font-weight:600}.section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--color-ink-2);margin:0 0 12px;font-size:12px;font-weight:700}.breadcrumb{color:var(--color-ink-3);flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:12px;font-size:12px;display:flex}.breadcrumb a{color:var(--color-ink-3);transition:color var(--duration-fast)}.breadcrumb a:hover{color:var(--color-ink)}.breadcrumb .sep{margin:0 2px}.recipe-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (min-width:640px){.recipe-grid{gap:20px}}@media (min-width:1024px){.recipe-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1400px){.recipe-grid{grid-template-columns:repeat(4,1fr)}}.card{background:var(--color-card);border-radius:var(--radius-lg);border:1px solid var(--color-line);color:inherit;flex-direction:column;text-decoration:none;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.card:hover{box-shadow:var(--shadow-card);transform:translateY(-1px)}.card:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.card-img{aspect-ratio:4/3;background:var(--color-bg-2);width:100%;overflow:hidden}.card-img .recipe-thumb-monogram{font-size:clamp(48px,12vw,96px)}.card-body{flex-direction:column;flex:1;padding:10px 12px 12px;display:flex}.card-title{color:var(--color-ink);margin:0 0 6px;font-size:14px;font-weight:600;line-height:1.3}.card-meta{flex-wrap:wrap;gap:4px;max-height:22px;margin-bottom:8px;display:flex;overflow:hidden}.card-foot{color:var(--color-ink-3);border-top:1px solid var(--color-line);flex-wrap:wrap;align-items:center;gap:6px;margin-top:auto;padding-top:8px;font-size:11px;display:flex}.card-foot .sep{color:var(--color-line)}@media (min-width:640px){.card-body{padding:16px 18px 18px}.card-title{margin:0 0 8px;font-size:16px}.card-meta{gap:6px;margin-bottom:10px}.card-foot{gap:10px;padding-top:10px;font-size:12px}}.recipe-show-layout{flex-direction:column;gap:28px;display:flex}.recipe-masthead{padding:8px 0 0}.recipe-show-title{font-family:var(--font-serif);letter-spacing:-.025em;color:var(--color-ink);max-width:22ch;margin:0 0 10px;font-size:clamp(32px,6vw,52px);font-weight:500;line-height:1.05}.recipe-source{color:var(--color-ink-2);margin:0 0 20px;font-size:13px}.recipe-source a{color:var(--color-accent);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1.5px}.recipe-source a:hover{text-decoration-thickness:2px}.recipe-shape{font-family:var(--font-serif);color:var(--color-ink);flex-wrap:wrap;align-items:baseline;gap:0 10px;margin:0 0 18px;font-size:clamp(17px,2.2vw,22px);font-style:italic;font-weight:400;line-height:1.4;display:flex}.recipe-shape .shape-part{align-items:baseline;gap:8px;display:inline-flex}.recipe-shape .shape-label{font-family:var(--font-sans);letter-spacing:.1em;text-transform:uppercase;color:var(--color-ink-2);font-size:10px;font-style:normal;font-weight:600}.recipe-shape .shape-val{color:var(--color-ink)}.recipe-shape .shape-sep{color:var(--color-ink-3);padding:0 4px;font-style:normal}.recipe-tags-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.recipe-photo{flex-direction:column;gap:12px;margin:0;display:flex}.recipe-photo>img{aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-card);background:var(--color-bg-2);width:100%;box-shadow:var(--shadow-card);display:block}@media (min-width:900px){.recipe-photo>img{aspect-ratio:16/9;max-height:520px}}.recipe-photo-strip{scrollbar-width:none;gap:8px;margin:0;padding:0;list-style:none;display:flex;overflow-x:auto}.recipe-photo-strip::-webkit-scrollbar{display:none}.recipe-photo-thumb{border-radius:var(--radius-md);background:var(--color-bg-2);border:1px solid var(--color-line);cursor:pointer;width:64px;height:48px;transition:transform var(--duration-fast), border-color var(--duration-fast);padding:0;display:block;overflow:hidden}.recipe-photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.recipe-photo-thumb:hover{border-color:var(--color-accent);transform:translateY(-1px)}.recipe-photo-thumb.is-active{border-color:var(--color-accent);border-width:1.5px}.recipe-photo-thumb:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (min-width:768px){.recipe-photo-thumb{width:80px;height:60px}}@media (prefers-reduced-motion:reduce){.recipe-photo-thumb{transition:none}}.recipe-primary-action{flex-direction:column;gap:10px;display:flex}@media (min-width:900px){.recipe-primary-action{flex-direction:row;align-items:center;gap:12px}}.btn-cook{background:var(--color-accent);color:#fff;border-radius:var(--radius-card);letter-spacing:.01em;cursor:pointer;width:100%;box-shadow:var(--shadow-btn);transition:transform var(--duration-fast), box-shadow var(--duration-fast);border:none;justify-content:center;align-items:center;gap:10px;padding:16px 20px;font-size:15px;font-weight:600;display:flex}.btn-cook:hover{box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-cook:active{transform:translateY(0)}@media (min-width:900px){.btn-cook{align-self:flex-start;width:auto;padding:14px 28px}}.recipe-secondary-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.overflow-menu{margin-left:auto;position:relative}.overflow-menu>summary{cursor:pointer;list-style:none}.overflow-menu>summary::-webkit-details-marker{display:none}.overflow-menu-trigger{min-width:36px;padding:8px 10px}.overflow-menu-trigger i{font-size:18px}.overflow-menu-panel{min-width:180px;max-width:calc(100vw - 24px);position:absolute;top:calc(100% + 6px);right:0}.overflow-menu form{margin:0;display:block}.recipe-body{grid-template-columns:1fr;gap:32px;display:grid}@media (min-width:900px){.recipe-body{grid-template-columns:minmax(260px,1fr) minmax(0,1.4fr);align-items:start;gap:56px}.recipe-body-side{scrollbar-width:thin;max-height:calc(100vh - 48px);position:sticky;top:24px;overflow-y:auto}}.recipe-notes{background:var(--color-bg-2);border-radius:var(--radius-md);margin-bottom:24px;padding:14px 16px}.recipe-notes .section-title{margin-bottom:6px}.recipe-notes p{font-family:var(--font-serif);color:var(--color-ink);margin:0;font-size:15px;font-style:italic;line-height:1.55}.recipe-ingredients-block{margin:0}.recipe-ingredients-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px;display:flex}.recipe-ingredients-head .section-title{margin:0}.recipe-ingredients-head .cook-scale-btn{background:var(--color-surface-2,#0000001a);color:var(--color-ink)}.recipe-ingredients-head .cook-scale-btn:hover{background:#00000029}.recipe-ingredients-head .serves-badge{background:var(--color-surface-2,#0000000f);color:var(--color-ink)}.recipe-ingredients-head .serves-original{color:var(--color-ink-soft,#0000008c)}.ingredient-list{margin:0;padding:0;list-style:none}.ingredient-list li{border-bottom:1px solid var(--color-line);color:var(--color-ink);gap:14px;padding:10px 0;font-size:14px;line-height:1.45;display:flex}.ingredient-list li:last-child{border-bottom:none}.ingredient-qty{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.01em;flex-shrink:0;min-width:72px;padding-top:1px;font-size:12.5px;font-weight:500}.ingredient-body{flex:1;min-width:0}.ingredient-mod{color:var(--color-ink-2)}.recipe-steps-block{margin:0}.steps-list{counter-reset:step;margin:0;padding:0;list-style:none}.steps-list li{border-bottom:1px solid var(--color-line);gap:18px;padding:18px 0;font-size:15px;line-height:1.65;display:flex}.steps-list li:last-child{border-bottom:none}.step-number{font-family:var(--font-serif);color:var(--color-accent);letter-spacing:-.01em;font-variant-numeric:lining-nums;flex-shrink:0;min-width:44px;padding-top:4px;font-size:28px;font-style:italic;font-weight:500;line-height:1}.step-body{min-width:0;color:var(--color-ink);flex:1;max-width:65ch}@media (min-width:768px){.steps-list li{padding:22px 0}.step-number{min-width:56px;font-size:32px}}.sort-menu{position:relative}.sort-menu>summary{cursor:pointer;list-style:none}.sort-menu>summary::-webkit-details-marker{display:none}.sort-menu-trigger{white-space:nowrap;align-items:center;gap:8px;padding:10px 14px;display:inline-flex}.sort-menu-label{color:var(--color-ink);font-size:13px;font-weight:500}.sort-menu-caret{opacity:.7;font-size:10px;line-height:1}.sort-menu-panel{min-width:200px;max-width:calc(100vw - 24px);position:absolute;top:calc(100% + 6px);right:0}@media (max-width:768px){.sort-menu-panel{left:0}}.sort-menu-item.is-current{color:var(--color-accent)}.sort-menu-check{color:var(--color-accent);margin-left:auto;font-size:13px;line-height:1}.btn-plus{margin-right:2px;font-size:16px;font-weight:500;line-height:1}.pagination{flex-wrap:nowrap;justify-content:center;align-items:center;gap:4px;margin-top:32px;display:flex}.pagination-pages{align-items:center;gap:2px;margin:0;padding:0;list-style:none;display:flex}.pagination-link,.pagination-nav{border-radius:var(--radius-sm);min-width:36px;height:36px;color:var(--color-ink-2);transition:background var(--duration-fast), border-color var(--duration-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:4px;padding:0 8px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.pagination-nav span{display:none}@media (min-width:640px){.pagination{gap:8px}.pagination-pages{gap:4px}.pagination-link,.pagination-nav{padding:0 10px}.pagination-nav span{display:inline}}.pagination-link:hover,.pagination-nav:hover{background:var(--color-bg-2);color:var(--color-ink)}.pagination-page.is-current .pagination-link{background:var(--color-accent);color:#fff;cursor:default}.pagination-page.is-current .pagination-link:hover{background:var(--color-accent);color:#fff}.pagination-gap .pagination-link{color:var(--color-ink-3);cursor:default}.pagination-gap .pagination-link:hover{background:0 0}.import-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:0 0 6px;font-size:24px;font-weight:500}.import-sub{color:var(--color-ink-2);margin:0 0 22px;font-size:13px}.import-status{color:var(--color-good);align-items:center;gap:8px;margin-bottom:12px;font-size:12px;font-weight:500;display:flex}.import-status-dot{background:var(--color-good);border-radius:50%;flex-shrink:0;width:8px;height:8px}.preview-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-card);margin-bottom:14px;padding:14px}.preview-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.preview-thumb{border-radius:var(--radius-sm);background:var(--color-bg-2);flex-shrink:0;width:42px;height:42px}.preview-title{font-size:13px;font-weight:600;line-height:1.2}.preview-site{color:var(--color-ink-3);margin-top:2px;font-size:11px}.tag-suggest-label{color:var(--color-ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:11px;font-weight:600}.tag-suggest{flex-wrap:wrap;gap:6px;display:flex}.import-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:24px;box-shadow:0 2px 6px #1c191708}.import-failed{max-width:560px;margin:32px auto 0}@media (min-width:768px){.import-failed{margin-top:48px;padding:56px 32px}}.import-failed .empty-title{max-width:24ch;margin-left:auto;margin-right:auto}.import-failed-message{font-family:var(--font-serif);color:var(--color-ink-2);max-width:44ch;margin:0 auto 18px;font-size:16px;font-style:italic;line-height:1.55}.import-failed-source{background:var(--color-bg-2,#ede7db);border-radius:999px;align-items:baseline;gap:8px;max-width:100%;margin:0 auto 24px;padding:8px 14px;display:inline-flex}.import-failed-source-label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);font-size:10px;font-weight:600}.import-failed-source-url{font-family:var(--font-mono,ui-monospace, SFMono-Regular, Menlo, monospace);color:var(--color-ink-2);text-overflow:ellipsis;white-space:nowrap;max-width:36ch;font-size:12.5px;overflow:hidden}.btn-ghost-link{color:var(--color-ink-2);text-decoration:underline;-webkit-text-decoration-color:var(--color-line);-webkit-text-decoration-color:var(--color-line);text-decoration-color:var(--color-line);text-underline-offset:4px;background:0 0;border:0;align-items:center;padding:10px 4px;font-size:13px;font-weight:500;transition:color .16s cubic-bezier(.22,1,.36,1),text-decoration-color .16s cubic-bezier(.22,1,.36,1);display:inline-flex}.btn-ghost-link:hover{color:var(--color-ink);-webkit-text-decoration-color:var(--color-ink-2);-webkit-text-decoration-color:var(--color-ink-2);text-decoration-color:var(--color-ink-2)}.btn-ghost-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:4px}.field-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-ink-2);margin:0 0 10px;font-size:11px;font-weight:700}.url-row{gap:10px;margin-bottom:4px;display:flex}.url-row .url-input{background:var(--color-bg);cursor:text;flex:1;align-items:center;gap:10px;margin:0;display:flex}.url-row .url-input .glyph{color:var(--color-ink-3);display:inline-flex}.url-input-field{font-family:var(--font-mono);color:var(--color-ink);background:0 0;border:0;outline:none;flex:1;min-width:0;font-size:13px}.url-input-field::placeholder{color:var(--color-ink-3)}.divider{color:var(--color-ink-3);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:14px;margin:22px 0;font-size:12px;font-weight:600;display:flex}.divider:before,.divider:after{content:"";background:var(--color-line);flex:1;height:1px}.dropzone{border:1.5px dashed var(--color-line);background:var(--color-bg);text-align:center;color:var(--color-ink-2);cursor:pointer;transition:border-color var(--duration-fast), background var(--duration-fast);border-radius:14px;padding:28px 20px;display:block}.dropzone:hover,.dropzone.is-dragover{border-color:var(--color-accent);background:var(--color-accent-soft)}.dropzone .dz-icon{background:var(--color-accent-soft);width:44px;height:44px;color:var(--color-accent);border-radius:12px;justify-content:center;align-items:center;margin-bottom:10px;font-size:20px;display:inline-flex}.dropzone h4{color:var(--color-ink);margin:0 0 4px;font-size:15px;font-weight:600}.dropzone p{color:var(--color-ink-3);margin:0;font-size:12px;line-height:1.5}.dropzone .choose{color:var(--color-accent);margin-top:12px;font-size:13px;font-weight:600;display:inline-block}.dropzone-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.import-manual-link{text-align:center;color:var(--color-ink-3);margin:18px 0 0;font-size:13px}.import-manual-link a{color:var(--color-accent);margin-left:6px;font-weight:600;text-decoration:none}.import-manual-link a:hover{text-decoration:underline}.processing{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);text-align:center;padding:64px 32px}.processing .spinner{border:3px solid var(--color-line);border-top-color:var(--color-accent);border-radius:50%;width:44px;height:44px;margin:0 auto 18px;animation:.9s linear infinite import-spin}@keyframes import-spin{to{transform:rotate(360deg)}}.processing h2{font-family:var(--font-serif);letter-spacing:-.01em;margin:0 0 6px;font-size:24px;font-weight:500}.processing p{color:var(--color-ink-3);margin:0;font-size:13px}.is-hidden{display:none!important}.import-photo-strip{margin-top:14px}.import-photo-strip.is-empty{display:none}.photo-submit-row{left:0;right:0;bottom:calc(62px + env(safe-area-inset-bottom,0px));z-index:5;background:linear-gradient(to top, var(--color-bg) 75%, transparent);pointer-events:none;padding:12px 16px;position:fixed}.photo-submit-row>*{pointer-events:auto}.photo-submit-row .btn{width:100%;padding:14px 22px;font-size:15px}.photo-submit-row.is-empty{display:none}[data-controller~=import-form]:has(.photo-submit-row:not(.is-empty)){padding-bottom:88px}@media (min-width:768px){.photo-submit-row{box-shadow:none;background:0 0;border-top:0;justify-content:flex-end;margin-top:14px;padding:0;display:flex;position:static}.photo-submit-row .btn{width:auto;padding:12px 22px;font-size:14px}.photo-submit-row{pointer-events:auto}[data-controller~=import-form]:has(.photo-submit-row:not(.is-empty)){padding-bottom:0}}.import-banner{max-width:760px;margin:0 auto 20px;padding:14px 18px}.import-banner .accent-banner-icon{border-radius:var(--radius-sm);background:var(--color-accent);color:#fff;width:32px;height:32px;font-size:15px}.import-banner .b-body{color:var(--color-ink-2);flex:1;font-size:13px;line-height:1.5}.import-banner .b-body strong{color:var(--color-ink);font-weight:600}.import-banner .b-body code{font-family:var(--font-mono);color:var(--color-ink);background:#fff9;border-radius:4px;padding:1px 6px;font-size:12px}html:has(body.cook-body),body.cook-body{background:var(--color-cook-dark);overscroll-behavior:none}body.cook-body{position:fixed;inset:0}.cook-mode{background:var(--color-cook-dark);color:#f5f1ea;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.cook-mode:after{content:"";pointer-events:none;z-index:50;opacity:0;position:absolute;inset:0;box-shadow:inset 0 0 0 2px #e8a05cd9,inset 0 0 80px 20px #e8a05c59}.cook-mode.is-timer-just-fired:after{animation:.38s cubic-bezier(.22,1,.36,1) forwards timer-flash}.cook-layout{flex-direction:column;flex:1;min-height:0;display:flex}@media (min-width:768px){.cook-layout{flex:1;grid-template-columns:220px 1fr 320px;min-height:100dvh;display:grid;overflow:visible}}.cook-sidebar{background:#ffffff08;border-right:1px solid #ffffff14;flex-direction:column;padding:32px 20px;display:none}@media (min-width:768px){.cook-sidebar{display:flex}}.cook-sidebar-title{letter-spacing:.14em;text-transform:uppercase;color:#a8a29e;margin-bottom:28px;padding:0 12px;font-size:10px;font-weight:600}.cook-step-list{flex-direction:column;gap:10px;display:flex}.cook-step-item{color:#a8a29e;cursor:pointer;transition:background var(--duration-fast), color var(--duration-fast);border-radius:8px;gap:12px;padding:10px 12px;font-size:13px;line-height:1.45;display:flex}.cook-step-item:hover{color:#d6d3d1;background:#ffffff0a}.cook-step-item .step-n{font-family:var(--font-serif);color:#78716c;flex-shrink:0;width:18px;font-size:14px;font-style:italic;line-height:1.55}.cook-step-item.done{color:#78716c}.cook-step-item.done .step-n{color:var(--color-good);font-style:normal}.cook-step-item.active{color:#f5f1ea;background:#e8a05c24}.cook-step-item.active .step-n{color:var(--color-cook-amber);font-size:16px;font-weight:500}.cook-exit{color:#a8a29e;cursor:pointer;transition:color var(--duration-fast);align-items:center;gap:8px;margin-top:auto;padding:10px 12px;font-size:13px;display:flex}.cook-exit:hover{color:#f5f1ea}.cook-main{flex:1;grid-template-rows:auto auto minmax(0,1fr) auto auto auto;grid-template-columns:minmax(0,1fr);row-gap:0;min-width:0;min-height:0;padding:24px 20px 20px;display:grid;position:relative}@media (min-width:768px){.cook-main{min-height:100dvh;padding:56px 64px 40px}}.cook-top{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:4px 12px;display:grid}@media (min-width:768px){.cook-top{column-gap:20px}}.cook-recipe-name{font-family:var(--font-serif);color:var(--color-cook-amber);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:15px;font-weight:500;line-height:1.25;overflow:hidden}@media (min-width:768px){.cook-recipe-name{white-space:normal;font-size:18px}}.cook-elapsed{color:#a8a29e;white-space:nowrap;font-variant-numeric:tabular-nums;justify-self:end;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}@media (min-width:768px){.cook-elapsed{gap:8px;font-size:13px}}.cook-elapsed-dot{background:var(--color-cook-amber);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-dot}.cook-close-btn{cursor:pointer;color:#f5f1ea;background:#ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;text-decoration:none;display:flex}@media (min-width:768px){.cook-close-btn{display:none}}body.native-app .cook-close-btn{display:none}body.native-app .cook-main{padding-top:64px}.cook-progress{grid-template-rows:44px auto;grid-template-columns:auto 1fr auto;align-items:center;gap:10px 12px;margin-bottom:32px;display:grid;position:relative}@media (min-width:768px){.cook-progress{gap:14px 20px;margin-bottom:48px}}.cook-progress:after{content:"";background:#ffffff14;border-radius:2px;grid-area:2/1/auto/-1;height:3px}.cook-progress-fill{background:var(--color-cook-amber);height:3px;transition:width var(--duration-base,.3s) cubic-bezier(.22, 1, .36, 1);z-index:1;border-radius:2px;grid-area:2/1/auto/-1;justify-self:start}.cook-progress-count{letter-spacing:.16em;text-transform:uppercase;color:#a8a29e;font-variant-numeric:tabular-nums;white-space:nowrap;grid-area:1/1;justify-self:start;font-size:11px;font-weight:600}@media (min-width:768px){.cook-progress-count{font-size:12px}}.cook-step-text{font-family:var(--font-serif);letter-spacing:-.01em;color:#f5f1ea;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;min-height:0;margin:0 0 16px;font-size:22px;font-weight:400;line-height:1.35;overflow-y:auto}@media (min-width:768px){.cook-step-text{max-width:680px;margin-bottom:24px;font-size:36px;line-height:1.3}}.voice-hint{color:#a8a29e;align-items:center;gap:5px;font-size:11px;display:flex}.voice-dot{background:var(--color-good);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s infinite pulse-dot}.cook-nav{gap:10px;min-width:0;padding-top:8px;display:flex}@media (min-width:768px){.cook-nav{gap:14px;padding-top:16px}}.cook-btn-prev{border-radius:var(--radius-card);color:#f5f1ea;cursor:pointer;transition:background var(--duration-fast);background:#ffffff1a;border:none;flex:none;align-items:center;gap:8px;padding:16px 20px;font-family:inherit;font-size:14px;font-weight:600;display:flex}@media (min-width:768px){.cook-btn-prev{padding:20px 28px;font-size:15px}}.cook-btn-prev:hover{background:#ffffff29}.cook-btn-next{border-radius:var(--radius-card);background:var(--color-cook-amber);min-width:0;color:var(--color-cook-dark);cursor:pointer;transition:opacity var(--duration-fast);border:none;flex:1 1 0;justify-content:center;align-items:center;gap:10px;padding:16px;font-family:inherit;font-size:14px;font-weight:600;display:flex}@media (min-width:768px){.cook-btn-next{gap:12px;max-width:380px;padding:20px 28px;font-size:15px}}.cook-btn-next:hover{opacity:.92}.cook-kbd{font-size:11px;font-family:var(--font-mono);background:#0003;border-radius:5px;padding:3px 7px;display:none}@media (min-width:768px){.cook-kbd{display:inline}}.cook-aside{padding:14px 20px calc(12px + env(safe-area-inset-bottom));background:#ffffff0a;border-top:1px solid #ffffff14;border-radius:18px 18px 0 0;flex-direction:column;flex-shrink:0;min-height:0;max-height:38dvh;display:flex}@media (min-width:768px){.cook-aside{border-top:0;border-left:1px solid #ffffff14;border-radius:0;max-height:none;margin-top:0;padding:32px 28px;overflow-y:auto}}.cook-aside-head{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}@media (min-width:768px){.cook-aside-head{margin-bottom:20px}}.cook-aside-title{letter-spacing:.12em;text-transform:uppercase;color:#a8a29e;font-size:11px;font-weight:600}.serves-badge{color:#f5f1ea;background:#ffffff1a;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:500}.serves-edit{cursor:pointer;text-underline-offset:3px;border-radius:4px;padding:0 2px;-webkit-text-decoration:underline dotted #fff6;text-decoration:underline dotted #fff6}.serves-edit:hover{background:#ffffff14}.serves-edit:focus-visible{outline:2px solid var(--color-accent,#b85c38);outline-offset:2px}.serves-edit-input{width:3.5ch;color:inherit;font:inherit;text-align:center;background:0 0;border:none;padding:0}.serves-edit-input:focus{outline:none}.serves-edit-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.serves-edit-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.serves-edit-input{-moz-appearance:textfield}.serves-original{color:#f5f1ea8c;margin-left:2px;font-size:.92em;font-weight:400}.serves-original[hidden]{display:none}.cook-ing-list{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;min-height:0;margin:0;padding:0;overflow-y:auto}@media (min-width:768px){.cook-ing-list{flex:0 auto;overflow-y:visible}}.cook-ing-list li{color:#f5f1ea;border-bottom:1px solid #ffffff12;grid-template-columns:1fr auto;align-items:center;column-gap:8px;font-size:14px;display:grid}.cook-ing-label{cursor:pointer;align-items:center;gap:14px;min-width:0;padding:12px 0;display:flex}.cook-ing-text{overflow-wrap:anywhere;flex:1;min-width:0}.cook-ing-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.cook-ing-input:focus-visible+.cook-check,.cook-ing-input:focus-visible+.pane-check{outline:2px solid var(--color-cook-amber);outline-offset:2px}.cook-ing-list li:last-child{border-bottom:none}.cook-ing-list li.done{color:#78716c;text-decoration:line-through}.ing-qty-cook{color:var(--color-cook-amber);font-weight:600}.cook-ing-list li.done .ing-qty-cook{color:#78716c}.cook-check{cursor:pointer;border:1.5px solid #ffffff4d;border-radius:5px;flex-shrink:0;width:18px;height:18px;position:relative}.cook-check.checked{background:var(--color-good);border-color:var(--color-good)}.cook-check.checked:after{content:"";border-bottom:2px solid #fff;border-right:2px solid #fff;width:5px;height:9px;position:absolute;top:2px;left:5px;transform:rotate(45deg)}.cook-ing-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.cook-ing-add,.cook-ing-remove{color:#fff6;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:color .15s cubic-bezier(.22,1,.36,1),border-color .15s cubic-bezier(.22,1,.36,1),background-color .15s cubic-bezier(.22,1,.36,1),transform .15s cubic-bezier(.22,1,.36,1);display:inline-flex}.cook-ing-remove{width:32px;height:32px}.cook-ing-add i{font-size:18px}.cook-ing-remove i{font-size:16px}.cook-ing-add:hover,.cook-ing-remove:hover{color:#ffffffd9;border-color:#ffffff1f}.cook-ing-add:focus-visible,.cook-ing-remove:focus-visible{outline:2px solid var(--color-cook-amber);outline-offset:2px;color:#ffffffd9}.cook-ing-add:active,.cook-ing-remove:active{transform:scale(.92)}.cook-ing-added{height:28px;color:var(--color-cook-amber);letter-spacing:.02em;text-transform:uppercase;background:#e8a8381f;border-radius:999px;align-items:center;gap:6px;padding:0 10px;font-size:11px;font-weight:600;display:inline-flex}.cook-ing-added i{font-size:14px}.cook-ing-list li.done .cook-ing-added{color:#78716c;background:#ffffff0a}.cook-ing-error{color:#f87171;grid-column:1/-1;padding:4px 0 8px;font-size:12px}.cook-ing-actions .hidden,.cook-ing-error.hidden{display:none}.cook-ing-pane{background:#ffffff0f;border-top:1px solid #ffffff1a;border-radius:18px 18px 0 0;margin-top:auto;padding:14px 20px 8px}@media (min-width:768px){.cook-ing-pane{display:none}}.cook-ing-pane-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cook-ing-pane-title{text-transform:uppercase;letter-spacing:.1em;color:#a8a29e;font-size:11px;font-weight:600}.cook-ing-pane ul{margin:0;padding:0;list-style:none}.cook-ing-pane li{color:#f5f1ea;border-bottom:1px solid #ffffff12;font-size:13px}.cook-ing-pane .cook-ing-label{gap:10px;padding:6px 0}.cook-ing-pane li:last-child{border-bottom:none}.cook-ing-pane li.done{color:#57534e;text-decoration:line-through}.pane-check{cursor:pointer;border:1.5px solid #ffffff4d;border-radius:4px;flex-shrink:0;width:16px;height:16px;position:relative}.pane-check.checked{background:var(--color-good);border-color:var(--color-good)}.pane-check.checked:after{content:"";border-bottom:2px solid #fff;border-right:2px solid #fff;width:4px;height:8px;position:absolute;top:2px;left:5px;transform:rotate(45deg)}.cook-step-list{margin:0;padding:0;list-style:none}.cook-step-list li{padding:0}button.cook-step-item{text-align:left;width:100%;font:inherit;background:0 0;border:0;align-items:flex-start}button.cook-step-item:focus-visible{outline:2px solid var(--color-cook-amber);outline-offset:-2px}.cook-step-item .step-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.cook-scale{flex-direction:column;align-items:center;gap:2px;display:inline-flex}.cook-scale-row{align-items:center;gap:8px;display:flex}.cook-scale-btn{color:#f5f1ea;cursor:pointer;width:28px;height:28px;font:inherit;transition:background var(--duration-fast);background:#ffffff1a;border:0;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.cook-scale-btn:before{content:"";min-width:44px;min-height:44px;position:absolute;inset:-8px}.cook-scale-btn:hover{background:#ffffff2e}.cook-scale-btn:focus-visible{outline:2px solid var(--color-cook-amber);outline-offset:2px}.cook-finish{background:#e8a05c14;border:1px solid #e8a05c47;border-radius:18px;margin-bottom:24px;padding:28px 28px 24px}@media (min-width:768px){.cook-finish{max-width:640px;padding:40px 44px 32px}}.cook-finish-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--color-cook-amber);margin-bottom:10px;font-size:11px;font-weight:600}.cook-finish-title{font-family:var(--font-serif);color:#f5f1ea;letter-spacing:-.01em;margin:0 0 14px;font-size:34px;font-weight:400;line-height:1.15}@media (min-width:768px){.cook-finish-title{margin-bottom:18px;font-size:48px}}.cook-finish-body{color:#d6d3d1;margin-bottom:20px;font-size:15px;line-height:1.55}@media (min-width:768px){.cook-finish-body{font-size:16px}}.cook-finish-cook-time{background:#ffffff0a;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:20px;padding:16px 18px;display:flex}.cook-finish-cook-time-copy{color:#d6d3d1;flex:220px;min-width:0;font-size:14px;line-height:1.5}.cook-btn-update-time{flex:none;padding:12px 20px;font-size:14px}.cook-finish-actions{flex-wrap:wrap;gap:10px;display:flex}.cook-ing-empty{color:#a8a29e;padding:8px 0 4px;font-size:13px;line-height:1.5}@media (prefers-reduced-motion:reduce){.cook-elapsed-dot,.voice-dot,.cook-timer-row.is-fired,.cook-timer-summary-pill.is-fired{animation:none}.cook-timer-row.is-fired,.cook-timer-summary-pill.is-fired{box-shadow:0 0 0 1px #e8a05cbf}.cook-mode.is-timer-just-fired:after{opacity:0;animation:none}.cook-progress-fill,.cook-step-item,.cook-btn-prev,.cook-btn-next,.cook-scale-btn,.cook-exit,.cook-timer-pill,.cook-timer-row{transition:none}}.cook-timer-pill{color:var(--color-cook-amber);cursor:pointer;font-variant-numeric:tabular-nums;transition:background var(--duration-fast), border-color var(--duration-fast), transform var(--duration-fast);background:0 0;border:1px solid #e8a05c8c;border-radius:999px;align-items:center;gap:4px;min-height:40px;padding:9px 14px;font-size:13px;font-weight:500;display:inline-flex}.cook-timer-pill:hover{border-color:var(--color-cook-amber);background:#e8a05c1a}.cook-timer-pill:active{transform:translateY(1px)}.cook-timer-pill--ghost{color:#d6d3d1;border-color:#ffffff24}.cook-timer-pill--ghost:hover{color:#f5f1ea;background:#ffffff0f;border-color:#ffffff38}.cook-timer-custom{background:#ffffff0a;border:1px solid #e8a05c59;border-radius:14px;align-items:center;gap:8px;padding:8px;display:flex}.cook-timer-custom-field{cursor:text;flex:0 auto;align-items:baseline;gap:4px;display:inline-flex}.cook-timer-custom-input{width:3ch;color:var(--color-cook-amber);font-family:var(--font-serif);letter-spacing:-.01em;text-align:center;font-variant-numeric:tabular-nums;background:#ffffff0a;border:1px solid #e8a05c8c;border-radius:8px;outline:none;padding:4px 6px;font-size:24px;font-weight:500}.cook-timer-custom-input:focus{border-color:var(--color-cook-amber)}.cook-timer-custom-unit{color:#a8a29e;letter-spacing:.08em;text-transform:uppercase;font-size:12px}.cook-timer-start{background:var(--color-cook-amber);color:var(--color-cook-dark);cursor:pointer;min-height:36px;transition:opacity var(--duration-fast);border:none;border-radius:999px;flex-shrink:0;padding:8px 14px;font-size:13px;font-weight:600}.cook-timer-start:hover{opacity:.9}.cook-timer-cancel{color:#a8a29e;cursor:pointer;width:36px;height:36px;transition:color var(--duration-fast);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.cook-timer-cancel:hover{color:#f5f1ea}.cook-timer-icon{color:#f5f1ea;cursor:pointer;font-variant-numeric:tabular-nums;width:36px;height:36px;transition:background var(--duration-fast);background:#ffffff0f;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:inline-flex}.cook-timer-icon:hover{background:#ffffff1f}.cook-timer-row{transition:background var(--duration-base), border-color var(--duration-base);background:#e8a05c14;border:1px solid #e8a05c40;border-radius:12px;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:10px 14px;display:grid}.cook-timer-row[hidden]{display:none}.cook-timer-row-label{color:#d6d3d1;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:13px;font-weight:500;overflow:hidden}.cook-timer-row-time{font-family:var(--font-serif);color:var(--color-cook-amber);font-variant-numeric:tabular-nums;letter-spacing:-.01em;text-align:right;min-width:76px;font-size:20px;font-weight:500}.cook-timer-row-actions{align-items:center;gap:4px;display:flex}.cook-timer-row .cook-timer-icon{width:36px;height:36px}.cook-timer-row.is-fired{background:#4d7c4f29;border-color:#e8a05c8c;animation:1.6s cubic-bezier(.22,1,.36,1) infinite timer-glow}.cook-timer-row.is-fired .cook-timer-row-time{color:var(--color-good)}.cook-timer-summary{grid-area:1/3;justify-self:end;position:relative}.cook-timer-summary[hidden]{display:none}.cook-timer-summary-pill{height:44px;color:var(--color-cook-amber);cursor:pointer;font-variant-numeric:tabular-nums;transition:background var(--duration-fast), border-color var(--duration-fast);-webkit-tap-highlight-color:transparent;background:#e8a05c1f;border:1px solid #e8a05c52;border-radius:999px;align-items:center;gap:10px;padding:0 14px 0 10px;display:inline-flex}.cook-timer-summary-pill:hover{background:#e8a05c2e;border-color:#e8a05c8c}.cook-timer-summary-pill:focus-visible{outline:2px solid var(--color-cook-amber);outline-offset:3px}.cook-timer-summary-pill.is-idle{color:#d6d3d1;background:#ffffff0a;border-color:#ffffff1f}.cook-timer-summary-pill.is-idle .cook-timer-summary-icon i{color:#d6d3d1}.cook-timer-summary-pill.is-idle .cook-timer-summary-next{color:#d6d3d1;font-family:var(--font-sans);letter-spacing:0;min-width:0;font-size:12px;font-weight:500}.cook-timer-summary-pill.is-idle:hover{color:var(--color-cook-amber);background:#e8a05c1a;border-color:#e8a05c73}.cook-timer-summary-pill.is-idle:hover .cook-timer-summary-icon i,.cook-timer-summary-pill.is-idle:hover .cook-timer-summary-next{color:var(--color-cook-amber)}.cook-timer-summary-icon{justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;position:relative}.cook-timer-summary-icon i{color:var(--color-cook-amber);font-size:22px;line-height:1}.cook-timer-summary-count{background:var(--color-cook-amber);min-width:18px;height:18px;color:var(--color-cook-dark);font-family:var(--font-sans);text-align:center;box-shadow:0 0 0 2px var(--color-cook-dark);border-radius:999px;padding:0 5px;font-size:11px;font-weight:700;line-height:18px;position:absolute;bottom:-4px;right:-6px}.cook-timer-summary-count[hidden]{display:none}.cook-timer-summary-next{font-family:var(--font-mono);color:var(--color-cook-amber);letter-spacing:-.01em;text-align:right;min-width:38px;font-size:13px;font-weight:500}@media (max-width:380px){.cook-timer-summary-next{display:none}.cook-timer-summary-pill{padding-right:10px}}.cook-timer-summary-pill.is-fired{color:var(--color-good);background:#4d7c4f2e;border-color:#e8a05c8c;animation:1.6s cubic-bezier(.22,1,.36,1) infinite timer-glow}.cook-timer-summary-pill.is-fired .cook-timer-summary-icon i,.cook-timer-summary-pill.is-fired .cook-timer-summary-next{color:var(--color-good)}.cook-timer-summary-pill.is-fired .cook-timer-summary-count{background:var(--color-good);color:#f5f1ea}.cook-timer-summary-panel{z-index:40;opacity:0;background:#2a2522;border:1px solid #ffffff1a;border-radius:16px;width:min(360px,100vw - 32px);padding:14px;transition:opacity .14s cubic-bezier(.22,1,.36,1),transform .14s cubic-bezier(.22,1,.36,1);position:absolute;top:calc(100% + 10px);right:0;transform:translateY(-4px);box-shadow:0 24px 60px #00000073,0 4px 12px #0000004d}.cook-timer-summary-panel[hidden]{display:none}.cook-timer-summary-panel.is-open{opacity:1;transform:translateY(0)}@media (max-width:480px){.cook-timer-summary-panel{width:calc(100vw - 24px);right:-8px}}.cook-timer-summary-section+.cook-timer-summary-section{border-top:1px solid #ffffff14;margin-top:14px;padding-top:12px}.cook-timer-summary-section[hidden],.cook-timer-summary-section--running:not(:has(.cook-timer-row)){display:none}.cook-timer-summary-section-title{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.14em;color:#a8a29e;padding:0 2px 8px;font-size:10px;font-weight:600}.cook-timer-summary-list{flex-direction:column;gap:6px;display:flex}.cook-timer-summary-list .cook-timer-row{background:#ffffff08;border-color:#ffffff14;padding:10px 12px}.cook-timer-summary-list .cook-timer-row.is-fired{background:#4d7c4f29;border-color:#4d7c4f73}.cook-timer-summary-suggestions{flex-wrap:wrap;gap:6px;min-width:0;display:flex}.cook-timer-summary-suggestions[hidden]{display:none}.cook-timer-summary-suggestion-set{display:contents}.cook-timer-summary-suggestion-set[hidden]{display:none}.cook-timer-custom.cook-timer-summary-custom{width:100%}@media (max-width:480px){.cook-recipe-name{font-size:14px}}@media (prefers-reduced-motion:reduce){.cook-timer-summary-panel{transition:none}}.plan-head{flex-direction:column;align-items:stretch;gap:20px;margin-bottom:28px;display:flex}.plan-head .toolbar>.btn{margin-left:0}@media (min-width:768px){.plan-head{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:16px}}.plan-greeting{text-transform:uppercase;letter-spacing:.14em;color:var(--color-ink-3);margin-bottom:6px;font-size:12px;font-weight:600}.plan-title{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-size:32px;font-weight:500;line-height:1.1}@media (min-width:768px){.plan-title{font-size:38px}}.plan-sub{color:var(--color-ink-2);margin:6px 0 0;font-size:14px}.plan-section-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:4px 12px;margin:28px 0 12px;display:flex}.plan-section-head:first-child{margin-top:0}.plan-section-title{font-family:var(--font-serif);letter-spacing:-.01em;align-items:baseline;gap:10px;min-width:0;margin:0;font-size:20px;font-weight:500;display:inline-flex}@media (min-width:768px){.plan-section-title{font-size:22px}}.plan-section-pill{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--color-accent);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:700}.plan-section-sub{color:var(--color-ink-3);margin:0;font-size:12px}.plan-today-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);grid-template-columns:1fr;margin-bottom:18px;display:grid}.plan-hero{background:var(--color-bg-2);border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:140px;position:relative;overflow:hidden}.plan-hero .recipe-thumb-monogram{font-size:clamp(48px,9vw,72px)}@media (min-width:768px){.plan-today-card{grid-template-columns:220px 1fr}.plan-hero{border-right:1px solid var(--color-line);border-radius:var(--radius-lg) 0 0 0;grid-area:1/1;height:100%;min-height:220px}.plan-today-card>.plan-body{grid-area:1/2}.plan-today-card>.plan-card-foot{grid-column:1/-1}}.plan-status-chip{letter-spacing:.1em;text-transform:uppercase;color:#fff;background:#1c1917e0;border-radius:6px;padding:4px 9px;font-size:10px;font-weight:700;position:absolute;top:12px;left:12px}.plan-status-chip.waiting{background:#c08a2eeb;align-items:center;gap:6px;display:inline-flex}.plan-status-chip.waiting:before{content:"";background:#fff;border-radius:50%;width:6px;height:6px;animation:2s infinite plan-pulse}@keyframes plan-pulse{0%,to{opacity:1}50%{opacity:.35}}.plan-body{padding:16px}@media (min-width:768px){.plan-body{padding:20px}}.plan-recipe-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:0 0 8px;font-size:22px;font-weight:500;line-height:1.2}@media (min-width:768px){.plan-recipe-title{font-size:26px}}.plan-meta{color:var(--color-ink-2);flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;font-size:12px;display:flex}.plan-meta .sep{color:var(--color-line)}.plan-meta-tag{background:var(--color-tag-bg);color:var(--color-tag-ink);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:500}.plan-time-row{border:1px solid var(--color-line);border-radius:var(--radius-md);align-items:stretch;gap:12px;margin-bottom:12px;padding:12px 14px;display:flex}.plan-time-col{flex-direction:column;flex:1;justify-content:center;min-width:0;display:flex}.plan-time-col .label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);margin-bottom:4px;font-size:10px;font-weight:700}.plan-time-col .label .usual{color:var(--color-accent)}.plan-time-col .t{font-family:var(--font-serif);color:var(--color-ink);letter-spacing:-.02em;font-size:22px;font-weight:500;line-height:1}@media (min-width:768px){.plan-time-col .t{font-size:26px}}.plan-time-col.start .t{color:var(--color-accent)}.plan-time-col .sub{color:var(--color-ink-3);margin-top:3px;font-size:11px}.plan-time-divider{background:var(--color-line);align-self:stretch;width:1px}.plan-alert{background:var(--color-accent-soft);border:1px solid var(--tint-accent-medium);border-radius:var(--radius-md);align-items:center;gap:12px;margin:4px 0 14px;padding:12px 14px;display:flex}.plan-alert-icon{border-radius:var(--radius-sm);background:var(--tint-accent-soft);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.plan-alert-body{flex:1;min-width:0}.plan-alert-label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin-bottom:2px;font-size:10px;font-weight:700}.plan-alert-title{margin:0 0 2px;font-size:13px;font-weight:600;line-height:1.25}.plan-alert-desc{color:var(--color-ink-2);margin:0;font-size:12px;line-height:1.3}.plan-timeline{border-top:1px solid var(--color-line);margin-top:14px;padding-top:12px}.plan-timeline-summary{cursor:pointer;color:var(--color-ink-2);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:baseline;gap:12px;padding:4px 0;font-size:13px;font-weight:600;list-style:none;display:flex}.plan-timeline-summary::-webkit-details-marker{display:none}.plan-timeline-summary:after{content:"›";color:var(--color-ink-3);font-size:18px;line-height:1;transition:transform .18s}.plan-timeline[open]>.plan-timeline-summary:after{transform:rotate(90deg)}.plan-timeline-summary-sub{color:var(--color-ink-3);margin-left:auto;font-size:12px;font-weight:400}.plan-timeline[open]>.plan-pip:first-of-type{margin-top:14px}.plan-pip{grid-template-columns:60px 16px 1fr auto;align-items:center;gap:10px;font-size:14px;display:grid;position:relative}@media (min-width:768px){.plan-pip{grid-template-columns:96px 24px 1fr auto;gap:14px}}.plan-pip-time{font-family:var(--font-mono);color:var(--color-ink-2);font-size:13px;font-weight:600}.plan-pip.passed .plan-pip-time{color:var(--color-ink-3)}.plan-pip.active .plan-pip-time{color:var(--color-accent)}.plan-pip-dot{border:2.5px solid var(--color-line);z-index:1;background:#fff;border-radius:50%;justify-self:center;width:12px;height:12px;position:relative}.plan-pip.passed .plan-pip-dot{background:var(--color-good);border-color:var(--color-good)}.plan-pip.active .plan-pip-dot{background:var(--color-accent);border-color:var(--color-accent);box-shadow:0 0 0 4px var(--tint-accent-soft)}.plan-pip-what{flex-direction:column;gap:3px;min-width:0;line-height:1.35;display:flex}.plan-pip-what strong{color:var(--color-ink);font-weight:600}.plan-pip-what .detail{color:var(--color-ink-3);font-size:11px}.plan-pip.passed .plan-pip-what,.plan-pip.passed .plan-pip-what strong{color:var(--color-ink-3)}.plan-pip-tag{background:var(--color-tag-bg);color:var(--color-tag-ink);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:10px;font-weight:600;display:inline-block}.plan-pip-tag.prep{color:#7a5a2e;background:#f0e2ca}.plan-pip-tag.cook{background:var(--color-accent-soft);color:var(--color-accent)}.plan-pip-tag.rest{color:#6e5e4a;background:#ebe0d0}.plan-pip-tag.eat{background:var(--color-ink);color:#fff}.plan-card-foot{border-top:1px solid var(--color-line);background:var(--color-bg-2);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:14px 16px}@media (min-width:768px){.plan-card-foot{padding:16px 20px}}.plan-card-foot-actions{flex-wrap:wrap;gap:8px;display:flex}.plan-upcoming-list{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden}.plan-up-row{border-bottom:1px solid var(--color-line);color:var(--color-ink);transition:background var(--duration-fast);grid-template-columns:56px 1fr auto 14px;align-items:center;gap:12px;padding:12px 14px;display:grid}.plan-up-row:last-of-type{border-bottom:none}.plan-up-row:hover{background:var(--color-bg-2)}.plan-up-date-link,.plan-up-thumb-link,.plan-up-eat-link,.plan-up-chev-link{color:inherit;text-decoration:none;display:contents}.plan-up-title-link{color:inherit;text-decoration:none}.plan-up-title-link:hover{color:var(--color-accent)}@media (min-width:768px){.plan-up-row{grid-template-columns:110px 72px 1fr auto auto 24px;gap:18px;padding:16px 20px}}.plan-up-date{line-height:1.2;display:none}@media (min-width:768px){.plan-up-date{display:block}}.plan-up-date .dow{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);font-size:10px;font-weight:700}.plan-up-date .mon{font-family:var(--font-serif);margin-top:2px;font-size:17px;font-weight:500}.plan-up-date.tomorrow .dow{color:var(--color-accent)}.plan-up-thumb{border-radius:var(--radius-md);background:var(--color-bg-2);flex-shrink:0;width:56px;height:56px}.plan-up-thumb .recipe-thumb-monogram{font-size:24px}@media (min-width:768px){.plan-up-thumb{width:72px;height:72px}.plan-up-thumb .recipe-thumb-monogram{font-size:30px}}.plan-up-info{min-width:0}.plan-up-date-line{letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-3);align-items:center;gap:6px;margin-bottom:2px;font-size:10px;font-weight:700;display:flex}.plan-up-date-line .tom{color:var(--color-accent)}@media (min-width:768px){.plan-up-date-line{display:none}}.plan-up-title{white-space:nowrap;text-overflow:ellipsis;margin:0 0 4px;font-size:14px;font-weight:600;line-height:1.2;overflow:hidden}@media (min-width:768px){.plan-up-title{font-size:15px}}.plan-up-meta{color:var(--color-ink-3);flex-wrap:wrap;align-items:center;gap:6px;font-size:11px;display:flex}.plan-up-meta .sep{color:var(--color-line)}.plan-up-flag{background:var(--color-accent-soft);color:var(--color-accent);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;padding:2px 7px;font-size:10px;font-weight:700}.plan-up-eat{text-align:right;line-height:1.1}.plan-up-eat .lbl{letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-3);font-size:9px;font-weight:700}.plan-up-eat .t{font-family:var(--font-serif);color:var(--color-ink);letter-spacing:-.01em;margin-top:2px;font-size:16px;font-weight:500}.plan-up-chev{color:var(--color-ink-3);text-align:right;font-size:16px}.plan-upcoming-foot{background:var(--color-bg-2);border-top:1px dashed var(--color-line);color:var(--color-accent);align-items:center;gap:10px;padding:14px;font-size:13px;font-weight:600;display:flex}.plan-upcoming-foot .plus{background:var(--color-card);border:1px dashed var(--color-accent);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;display:flex}.plan-new-wrap{flex-direction:column;gap:20px;max-width:520px;margin:0 auto;display:flex}.plan-new-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:24px}.plan-new-head{margin-bottom:20px}.plan-new-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:0 0 6px;font-size:22px;font-weight:500}.plan-new-sub{color:var(--color-ink-2);margin:0;font-size:13px;line-height:1.45}.plan-new-field{margin-bottom:18px}.plan-new-label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);margin-bottom:8px;font-size:10px;font-weight:700;display:block}.plan-new-slots{gap:10px;margin-bottom:12px;display:flex}.plan-new-slot{border:1px solid var(--color-line);border-radius:var(--radius-md);text-align:center;color:var(--color-ink-2);cursor:pointer;transition:border-color var(--duration-fast), background var(--duration-fast);flex:1;padding:12px 8px;font-size:14px;font-weight:500}.plan-new-slot input[type=radio]{display:none}.plan-new-slot small{color:var(--color-ink-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:700;display:block}.plan-new-slot-time{font-family:var(--font-serif);letter-spacing:-.01em;font-size:16px}.plan-new-slot.sel{background:var(--color-ink);border-color:var(--color-ink);color:#fff}.plan-new-slot.sel small{color:var(--color-accent-soft)}.plan-new-custom{margin-top:6px}.plan-new-servings{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-card);align-items:center;gap:14px;padding:8px 10px;display:inline-flex}.plan-new-servings-btn{border:1px solid var(--color-line);width:32px;height:32px;color:var(--color-ink);cursor:pointer;transition:background var(--duration-fast), border-color var(--duration-fast);background:0 0;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.plan-new-servings-btn:hover{background:var(--color-line)}.plan-new-servings-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.plan-new-servings-count{flex-direction:column;align-items:center;min-width:64px;line-height:1.1;display:flex}.plan-new-servings-count>span:first-child{font-family:var(--font-serif);letter-spacing:-.01em;font-size:22px}.plan-new-servings-unit{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);font-size:10px;font-weight:700}.plan-new-servings-count .serves-original{color:var(--color-ink-3);text-transform:none;letter-spacing:0;margin-top:2px;font-size:11px;font-weight:400}.plan-new-servings-count .serves-original[hidden]{display:none}.plan-new-foot{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.plan-detail{flex-direction:column;gap:20px;max-width:520px;margin:0 auto;display:flex}.btn-danger{color:#9a3b2a;border:1px solid var(--tint-danger-line);background:0 0}.btn-danger:hover{opacity:1;background:#9a3b2a0f}.btn-danger:active{opacity:1;background:#9a3b2a1f}.plan-preview{display:block}.plan-preview-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:20px 20px 16px}.plan-preview-head{align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.plan-preview-head-text{flex:1;min-width:0}.plan-preview-menu{flex-shrink:0;margin:-4px -4px 0 0}.plan-preview-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--color-accent);margin-bottom:4px;font-size:10px;font-weight:700}.plan-preview-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:0;font-size:22px;font-weight:500;line-height:1.2}.plan-preview-no-timing{background:var(--color-bg-2);border:1px dashed var(--color-line);border-radius:var(--radius-md);align-items:flex-start;gap:12px;padding:14px;display:flex}.plan-preview-no-timing-icon{color:var(--color-ink-3);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:22px;line-height:1;display:inline-flex}.plan-preview-no-timing-body{flex-direction:column;gap:6px;min-width:0;display:flex}.plan-preview-no-timing-title{color:var(--color-ink);margin:0;font-size:14px;font-weight:600}.plan-preview-no-timing-desc{color:var(--color-ink-2);margin:0 0 4px;font-size:13px;line-height:1.45}.plan-new-custom-tile{border:1px solid var(--color-line);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--duration-fast), background var(--duration-fast);margin-top:10px;padding:10px 12px;display:block}.plan-new-custom-tile:hover{border-color:var(--color-ink-3)}.plan-new-custom-row{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.plan-new-custom-tile small{color:var(--color-ink-3);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:700;display:block}.plan-new-custom-hint{color:var(--color-ink-3);align-items:center;gap:4px;font-size:11px;font-weight:500;display:inline-flex}.plan-new-custom-hint i{font-size:12px}.plan-new-custom-tile.sel{border-color:var(--color-accent);background:var(--color-accent-soft)}.plan-new-custom-tile.sel small{color:var(--color-accent)}.plan-new-custom-tile.sel .plan-new-custom-hint{display:none}.plan-new-custom-input{font-family:var(--font-serif);letter-spacing:-.01em;width:100%;color:var(--color-ink);cursor:pointer;background:0 0;border:0;outline:none;padding:0;font-size:16px}.plan-new-slot-badge{letter-spacing:.1em;background:var(--color-accent-soft);color:var(--color-accent);border-radius:999px;margin-left:6px;padding:1px 6px;font-size:8px;display:inline-block}.plan-new-slot.sel .plan-new-slot-badge{color:#fff;background:#ffffff2e}.planning-banner{justify-content:space-between;margin-bottom:20px}.planning-banner-body{align-items:center;gap:12px;min-width:0;display:flex}.planning-banner strong{color:var(--color-ink);margin-bottom:2px;font-size:13px;font-weight:600;display:block}.planning-banner p{color:var(--color-ink-2);margin:0;font-size:12px;line-height:1.35}.planning-banner-cancel{flex-shrink:0}.quick-add-backdrop{z-index:50;background:#1c161273;justify-content:center;align-items:flex-start;padding:10vh 16px 16px;display:flex;position:fixed;inset:0}body.native-app .quick-add-backdrop{padding-top:calc(env(safe-area-inset-top,0px) + 64px)}.quick-add-backdrop[hidden]{display:none}.quick-add-panel{background:var(--color-card);border-radius:14px;flex-direction:column;gap:14px;width:100%;max-width:520px;padding:18px;display:flex;box-shadow:0 20px 50px #1c161240}.quick-add-head{justify-content:space-between;align-items:center;display:flex}.quick-add-title{font-family:var(--font-serif);letter-spacing:-.01em;margin:0;font-size:20px;font-weight:500}.quick-add-close{color:var(--color-ink-2);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:4px}.quick-add-close:hover{background:var(--color-bg-2)}.quick-add-search{border:1px solid var(--color-line);color:var(--color-ink-3);border-radius:10px;align-items:center;gap:8px;padding:10px 12px;display:flex}.quick-add-search:focus-within{border-color:var(--color-accent)}.quick-add-search-input{color:var(--color-ink);background:0 0;border:0;outline:none;flex:1;font-size:15px}.quick-add-results{min-height:80px}.quick-add-hint{color:var(--color-ink-3);margin:4px 2px;font-size:14px}.quick-add-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.quick-add-item{color:var(--color-ink);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;display:flex}.quick-add-item:hover{background:var(--color-bg-2)}.quick-add-item-title{font-weight:500}.quick-add-item-meta{color:var(--color-ink-3);font-size:12px}.shopping-page{--shopping-tap:40px;--shopping-row-pad-y:16px;--shopping-tick-size:30px;--shopping-tick-icon:14px;--shopping-line-size:18px;--shopping-qty-size:16px;--shopping-mod-size:14px;flex-direction:column;gap:32px;max-width:760px;margin:0 auto;padding-bottom:80px;display:flex}.shopping-page.is-shopping{--shopping-row-pad-y:20px;--shopping-tick-size:38px;--shopping-tick-icon:18px;--shopping-line-size:22px;--shopping-qty-size:19px;--shopping-mod-size:16px}.shopping-head{flex-direction:column;gap:10px;display:flex}.shopping-head-row{justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.shopping-head-titleblock{flex:auto;min-width:0}.shopping-eyebrow{font-family:var(--font-sans);letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink-3);margin:0 0 6px;font-size:11px;font-weight:700}.shopping-title{font-family:var(--font-serif);letter-spacing:-.015em;color:var(--color-ink);margin:0;font-size:clamp(28px,5vw,38px);font-weight:500;line-height:1.1}.shopping-title-count{font-feature-settings:"lnum";font-variant-numeric:lining-nums tabular-nums;color:var(--color-ink);margin-right:.22em;font-weight:600}.shopping-title-rest{color:var(--color-ink-2);font-weight:400}.shopping-sub{font-family:var(--font-serif);color:var(--color-ink-2);max-width:52ch;margin:0;font-size:15px;font-style:italic}.shopping-head-actions{flex:none;gap:8px;display:flex}.btn-start-shopping,.btn-stop-shopping{white-space:nowrap;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:600;display:inline-flex}.btn-start-shopping .ph,.btn-start-shopping .ph-fill,.btn-stop-shopping .ph,.btn-stop-shopping .ph-fill{font-size:16px}.quick-add-form{flex-direction:column;gap:8px;display:flex}.quick-add-input-wrap{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;grid-template-columns:auto 1fr auto;align-items:stretch;display:grid;overflow:hidden}.quick-add-input-wrap:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 4px var(--tint-accent-soft)}.quick-add-icon{color:var(--color-ink-3);justify-content:center;align-items:center;padding:0 14px;font-size:18px;display:inline-flex}.quick-add-input{font-family:var(--font-sans);color:var(--color-ink);resize:none;white-space:nowrap;background:0 0;border:0;outline:0;min-width:0;height:52px;padding:16px 4px;font-size:16px;line-height:1.4;overflow:auto hidden}.quick-add-input::placeholder{color:var(--color-ink-3)}.quick-add-submit{border-radius:0;align-self:stretch;padding:0 18px}.quick-add-hint{color:var(--color-ink-3);margin:0;padding:0 4px;font-size:12px}.quick-add-hint kbd{font-family:var(--font-sans);background:var(--color-bg-2);border:1px solid var(--color-line);color:var(--color-ink-2);border-radius:4px;padding:1px 5px;font-size:11px}.quick-add-hint--keyboard{display:none}.quick-add-hint--touch{display:block}@media (hover:hover) and (pointer:fine){.quick-add-hint--keyboard{display:block}.quick-add-hint--touch{display:none}}.quick-add-preview{flex-wrap:wrap;align-items:center;gap:6px;padding:0 4px;display:flex}.quick-add-preview-label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-3);font-size:10px;font-weight:700}.quick-add-preview-chip{background:var(--color-accent-soft);color:var(--color-accent);font-family:var(--font-sans);border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-flex}.shopping-body{flex-direction:column;gap:28px;display:flex}.shopping-category{flex-direction:column;gap:2px;display:flex}.shopping-category-head{font-family:var(--font-sans);align-items:center;gap:12px;margin:0;padding:0 4px 8px;display:flex}.cat-name{letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink-2);flex:none;font-size:11px;font-weight:700}.is-shopping .cat-name{font-size:13px}.cat-rule{background:var(--color-line);flex:auto;height:1px}.cat-count{font-family:var(--font-serif);color:var(--color-ink-3);font-variant-numeric:lining-nums tabular-nums;flex:none;font-size:13px;font-style:italic}.shopping-list{margin:0;padding:0;list-style:none}.shopping-item{padding:var(--shopping-row-pad-y) 4px;border-bottom:1px solid var(--color-line);transition:background var(--duration-fast) ease, opacity var(--duration-fast) ease;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;display:grid}.shopping-item:last-child{border-bottom:0}.shopping-item:hover{background:#1c191706}.is-shopping .shopping-item.done{opacity:.32}.shopping-item-tick-form{display:contents}.shopping-item-tick{appearance:none;border:1.5px solid var(--color-line);width:var(--shopping-tick-size);height:var(--shopping-tick-size);min-width:var(--shopping-tap);min-height:var(--shopping-tap);cursor:pointer;color:#0000;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease, transform var(--duration-fast) ease;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex}.shopping-item-tick:hover{border-color:var(--color-good);transform:scale(1.05)}.shopping-item-tick:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.shopping-item-tick .tick-mark{display:inline-flex}.shopping-item-tick .tick-mark .ph,.shopping-item-tick .tick-mark .ph-fill{font-size:var(--shopping-tick-icon)}.shopping-item.done .shopping-item-tick{background:var(--color-good);border-color:var(--color-good);color:#fff}.shopping-item-body{flex-direction:column;gap:4px;min-width:0;display:flex}.shopping-item-line{font-family:var(--font-serif);font-size:var(--shopping-line-size);color:var(--color-ink);word-break:break-word;font-weight:400;line-height:1.35}.shopping-item-qty{font-feature-settings:"lnum";font-variant-numeric:lining-nums tabular-nums;color:var(--color-ink-2);font-style:italic;font-size:var(--shopping-qty-size);margin-right:6px}.shopping-item-name{color:var(--color-ink)}.shopping-item-mod{color:var(--color-ink-3);font-size:var(--shopping-mod-size);font-style:italic}.shopping-item.done .shopping-item-line{color:var(--color-ink-3);text-decoration:line-through;-webkit-text-decoration-color:var(--color-ink-3);-webkit-text-decoration-color:var(--color-ink-3);text-decoration-color:var(--color-ink-3);text-underline-offset:-2px;text-decoration-thickness:1.5px}.shopping-item.done .shopping-item-qty,.shopping-item.done .shopping-item-mod{color:var(--color-ink-3)}.shopping-item-sources{font-family:var(--font-sans);color:var(--color-ink-3);font-size:12px}.shopping-item-sources summary{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;align-items:baseline;gap:4px;padding:1px 0;list-style:none;display:inline-flex}.shopping-item-sources summary::-webkit-details-marker{display:none}.shopping-item-sources summary em{font-style:italic;font-family:var(--font-serif);font-size:13px}.shopping-item-sources .sources-caret{color:var(--color-ink-3);transition:transform var(--duration-fast) ease;align-items:center;margin-right:2px;display:inline-flex;transform:rotate(0)}.shopping-item-sources .sources-caret .ph,.shopping-item-sources .sources-caret .ph-fill{font-size:12px}.shopping-item-sources[open] .sources-caret{transform:rotate(90deg)}.shopping-item-sources summary:hover em,.shopping-item-sources summary:hover .sources-caret{color:var(--color-accent)}.sources-list{background:var(--color-bg-2);border-radius:var(--radius-sm);flex-direction:column;gap:4px;margin:6px 0 4px;padding:8px 12px;list-style:none;display:flex}.sources-list-item{align-items:center;gap:8px;font-size:12px;display:flex}.sources-link{color:var(--color-ink);font-weight:500;text-decoration:none}.sources-link:hover{color:var(--color-accent);text-decoration:underline}.sources-qty{color:var(--color-ink-3);font-feature-settings:"lnum";font-variant-numeric:tabular-nums;margin-left:auto}.sources-unit{color:var(--color-ink-3)}.btn-icon-tiny{appearance:none;color:var(--color-ink-3);cursor:pointer;background:0 0;border:0;border-radius:4px;padding:4px;line-height:0}.btn-icon-tiny:hover{color:var(--color-danger);background:var(--color-danger-bg)}.btn-icon-tiny .ph{font-size:12px}.shopping-item-remove{appearance:none;color:var(--color-ink-3);cursor:pointer;min-width:var(--shopping-tap);min-height:var(--shopping-tap);transition:opacity var(--duration-fast) ease, color var(--duration-fast) ease, background var(--duration-fast) ease;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;padding:10px;line-height:0;display:inline-flex}.shopping-item-remove .ph{font-size:16px}@media (hover:hover) and (pointer:fine){.shopping-item-remove{opacity:0;min-width:0;min-height:0;padding:8px}.shopping-item-remove .ph{font-size:14px}.shopping-item:hover .shopping-item-remove,.shopping-item-remove:focus-visible{opacity:1}}.shopping-item-remove:hover{color:var(--color-danger);background:var(--color-danger-bg)}.shopping-utility-row{justify-content:center;padding-top:8px;display:flex}.shopping-utility-row form{margin:0}.btn-clear-completed{appearance:none;font-family:var(--font-sans);color:var(--color-ink-3);cursor:pointer;transition:color var(--duration-fast) ease, background var(--duration-fast) ease;background:0 0;border:0;border-radius:6px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;display:inline-flex}.btn-clear-completed:hover{color:var(--color-danger);background:var(--color-danger-bg)}.btn-clear-completed .ph{font-size:13px}.shopping-all-done{text-align:center;color:var(--color-ink-2);font-family:var(--font-serif);padding:56px 16px 32px;font-size:18px;font-style:italic}.all-done-mark{color:var(--color-good);margin-bottom:8px}.shopping-all-done .ph,.shopping-all-done .ph-fill{font-size:36px}.empty-state--shopping{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-lg);text-align:center;padding:48px 28px}.empty-state--shopping .empty-desc em{color:var(--color-accent);font-style:italic;font-family:var(--font-serif)}.wake-notice{bottom:calc(var(--tab-bar-height,72px) + 16px);background:var(--color-ink);color:var(--color-cook-amber);font-family:var(--font-sans);letter-spacing:.14em;text-transform:uppercase;box-shadow:var(--shadow-card);z-index:10;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:700;display:inline-flex;position:fixed;right:16px}.wake-notice .ph,.wake-notice .ph-fill{font-size:14px}@media (min-width:900px){.wake-notice{bottom:16px}}.from-recipe-page{flex-direction:column;gap:24px;max-width:720px;margin:0 auto;display:flex}.from-recipe-eyebrow{font-family:var(--font-sans);letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink-3);margin:0 0 6px;font-size:11px;font-weight:700}.from-recipe-title{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--color-ink);margin:0 0 8px;font-size:clamp(28px,4.5vw,40px);font-weight:500;line-height:1.05}.from-recipe-sub{font-family:var(--font-serif);color:var(--color-ink-2);max-width:52ch;margin:0;font-size:16px;font-style:italic}.from-recipe-serves{margin-top:12px}.from-recipe-serves .serves-badge{background:var(--color-surface-2,#0000000f);color:var(--color-ink);border-radius:999px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.from-recipe-toolbar{border-bottom:1px solid var(--color-line);justify-content:space-between;align-items:center;gap:16px;padding:12px 4px;display:flex}.from-recipe-toolbar-left{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.toolbar-sep{color:var(--color-ink-3);font-size:12px}.link-action{appearance:none;font-family:var(--font-sans);color:var(--color-accent);cursor:pointer;min-height:32px;transition:background var(--duration-fast) ease;background:0 0;border:0;border-radius:4px;padding:6px 10px;font-size:13px;font-weight:500}.link-action:hover{background:var(--color-accent-soft)}.selected-count{font-family:var(--font-sans);letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-2);font-variant-numeric:tabular-nums;font-size:11px;font-weight:700}.from-recipe-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.from-recipe-row{border-bottom:1px solid var(--color-line);transition:opacity var(--duration-fast) ease}.from-recipe-label{cursor:pointer;grid-template-columns:auto 1fr;align-items:center;gap:14px;min-height:56px;padding:14px 4px;display:grid}.from-recipe-label input[type=checkbox]{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.from-recipe-tick{border:1.5px solid var(--color-line);color:#0000;background:var(--color-card);width:30px;height:30px;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.from-recipe-tick .ph,.from-recipe-tick .ph-fill{font-size:14px}.from-recipe-label:hover .from-recipe-tick{border-color:var(--color-accent)}.from-recipe-label input:checked+.from-recipe-tick{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.from-recipe-label input:focus-visible+.from-recipe-tick{outline:2px solid var(--color-accent);outline-offset:2px}.from-recipe-body{flex-direction:column;gap:4px;min-width:0;display:flex}.from-recipe-line{font-family:var(--font-serif);color:var(--color-ink);flex-wrap:wrap;align-items:baseline;gap:0 8px;font-size:18px;line-height:1.3;display:flex}.from-recipe-qty{color:var(--color-ink-2);font-feature-settings:"lnum";font-variant-numeric:lining-nums tabular-nums;font-size:16px;font-style:italic}.from-recipe-mod{color:var(--color-ink-3);font-size:14px;font-style:italic}.from-recipe-meta{font-family:var(--font-sans);color:var(--color-ink-3);align-items:center;gap:4px;font-size:12px;display:inline-flex}.from-recipe-meta .ph{font-size:12px}.already-on-list{color:var(--color-accent)}.from-recipe-label input:not(:checked)~.from-recipe-body .from-recipe-line,.from-recipe-label input:not(:checked)~.from-recipe-body .from-recipe-qty,.from-recipe-label input:not(:checked)~.from-recipe-body .from-recipe-mod{color:var(--color-ink-3)}.from-recipe-actions{background:linear-gradient(to bottom, #f5f1ea00 0%, var(--color-bg) 28%);justify-content:flex-end;align-items:center;gap:12px;padding:16px 0 32px;display:flex;position:sticky;bottom:0}.from-recipe-submit{min-width:220px}.from-recipe-submit:disabled{opacity:.5;cursor:not-allowed}@media (prefers-reduced-motion:reduce){.shopping-item,.shopping-item-tick{transition:none}}body.auth-body{background:var(--color-bg);color:var(--color-ink);min-height:100vh;font-family:var(--font-sans)}.auth-screen{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px 20px 48px;display:flex}@media (min-width:768px){.auth-screen{padding:48px 24px 64px}}.auth-screen:before{content:"Cooking";font-family:var(--font-serif);color:var(--color-accent);letter-spacing:.01em;margin-bottom:24px;font-size:18px;font-style:italic;display:block}.auth-card{background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-card);width:100%;max-width:420px;box-shadow:var(--shadow-card);padding:32px 28px}@media (min-width:768px){.auth-card{padding:40px 36px}}.auth-card .page-title{font-family:var(--font-serif);color:var(--color-ink);letter-spacing:-.01em;margin:0 0 8px;font-size:32px;font-weight:500;line-height:1.15}@media (min-width:768px){.auth-card .page-title{font-size:38px}}.auth-card .auth-lede{color:var(--color-ink-2);max-width:34ch;margin:0 0 24px;font-size:14px;line-height:1.55}.auth-card .page-title+form,.auth-card .page-title+.auth-form{margin-top:20px}.auth-form .form-field,.auth-form .form-group{margin-bottom:16px}.auth-form label,.auth-form .form-group>label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-ink-2);margin:0 0 6px;font-size:11px;font-weight:600;display:block}.auth-form input[type=email],.auth-form input[type=password],.auth-form input[type=text],.auth-form input[type=time],.auth-form select{border:1px solid var(--color-line);border-radius:var(--radius-md);width:100%;color:var(--color-ink);background:var(--color-card);transition:border-color var(--duration-fast), box-shadow var(--duration-fast);padding:12px 14px;font-family:inherit;font-size:16px;line-height:1.3}.auth-form input:focus,.auth-form select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--tint-accent-soft);outline:none}.auth-form .hint,.auth-form small,.auth-form .form-text{color:var(--color-ink-3);margin-top:6px;font-size:12px;line-height:1.4;display:block}.auth-form .form-actions .btn{flex:1;min-width:140px}.auth-link{color:var(--color-accent);transition:border-color var(--duration-fast);border-bottom:1px solid #0000;padding-bottom:1px;font-size:13px;font-weight:500;text-decoration:none}.auth-link:hover,.auth-link:focus-visible{border-bottom-color:var(--color-accent)}.auth-alt{color:var(--color-ink-2);text-align:center;margin-top:24px;font-size:13px}.auth-alt a{color:var(--color-accent);border-bottom:1px solid #0000;margin-left:4px;font-weight:500;text-decoration:none}.auth-alt a:hover,.auth-alt a:focus-visible{border-bottom-color:var(--color-accent)}.auth-form .form-group .help-block,.auth-form .hint{margin-top:6px}.sidebar-signout{margin-top:auto;padding-top:1rem}.sidebar-signout button{font:inherit;color:inherit;cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:0}.admin-table{border-collapse:collapse;background:var(--color-card);border:1px solid var(--color-line);border-radius:var(--radius-md);width:100%;font-size:14px;overflow:hidden}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--color-line);padding:12px 16px}.admin-table th{background:var(--color-bg-2);text-transform:uppercase;letter-spacing:.04em;color:var(--color-ink-2);font-size:12px;font-weight:600}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table .admin-table-num{text-align:right;font-variant-numeric:tabular-nums}.admin-table .admin-badge{background:var(--color-accent-soft);color:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.admin-pagination{justify-content:center;gap:8px;margin-top:20px;font-size:13px;display:flex}.admin-pagination .page a,.admin-pagination .page span,.admin-pagination .first a,.admin-pagination .last a,.admin-pagination .prev a,.admin-pagination .next a{border-radius:var(--radius-sm);color:var(--color-ink);border:1px solid var(--color-line);background:var(--color-card);padding:6px 10px;text-decoration:none}.admin-pagination .current{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}}@layer utilities{.\@container{container-type:inline-size}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.top-20{top:calc(var(--spacing) * 20)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mt-1{margin-top:calc(var(--spacing) * 1)}.\!mb-0{margin-bottom:calc(var(--spacing) * 0)!important}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline\!{display:inline!important}.inline-flex{display:inline-flex}.table{display:table}.h-140{height:calc(var(--spacing) * 140)}.w-24{width:calc(var(--spacing) * 24)}.w-full{width:100%}.flex-shrink{flex-shrink:1}.flex-grow,.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-red-200{border-color:var(--color-red-200)}.border-red-500{border-color:var(--color-red-500)}.bg-indigo-600{background-color:var(--color-indigo-600)}.bg-red-50{background-color:var(--color-red-50)}.bg-transparent{background-color:#0000}.p-4{padding:calc(var(--spacing) * 4)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-wrap{text-wrap:wrap}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-accent{--tw-shadow:0 8px 24px var(--tw-shadow-color,#b85c3866);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-btn{--tw-shadow:0 6px 18px var(--tw-shadow-color,#b85c3847);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-card{--tw-shadow:0 10px 40px var(--tw-shadow-color,#1c191714), 0 2px 6px var(--tw-shadow-color,#1c19170a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-card-lg{--tw-shadow:0 20px 60px var(--tw-shadow-color,#1c19171a), 0 4px 12px var(--tw-shadow-color,#1c19170a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm,.shadow\/elevation{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}@media (hover:hover){.hover\:bg-indigo-700:hover{background-color:var(--color-indigo-700)}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-indigo-500:focus{--tw-ring-color:var(--color-indigo-500)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.font-serif{font-family:var(--font-serif)}.font-sans{font-family:var(--font-sans)}.text-ink{color:var(--color-ink)}.text-ink-2{color:var(--color-ink-2)}.text-ink-3{color:var(--color-ink-3)}.text-accent{color:var(--color-accent)}.text-good{color:var(--color-good)}.text-amber{color:var(--color-cook-amber)}.bg-app{background:var(--color-bg)}.bg-app-2{background:var(--color-bg-2)}.bg-card{background:var(--color-card)}.bg-accent{background:var(--color-accent)}.bg-tag{background:var(--color-tag-bg)}.border-line{border-color:var(--color-line)}.shadow-card{box-shadow:var(--shadow-card)}.shadow-card-lg{box-shadow:var(--shadow-card-lg)}.radius-card{border-radius:var(--radius-card)}.radius-card-lg{border-radius:var(--radius-lg)}.recipe-image-fill{object-fit:cover;width:100%;height:100%;display:block}.recipe-thumb-paper{background-color:var(--color-bg-2);background-image:radial-gradient(circle at 18% 12%,#1c191709 0 1px,#0000 1px),radial-gradient(circle at 68% 74%,#1c191708 0 1px,#0000 1px),radial-gradient(circle at 88% 30%,#1c191706 0 1px,#0000 1px);background-size:7px 7px,11px 11px,13px 13px;justify-content:center;align-items:center;display:flex;position:relative}.recipe-thumb-paper>.recipe-image-fill{z-index:1;position:relative}.recipe-thumb-monogram{font-family:var(--font-serif);color:var(--color-accent);opacity:.55;-webkit-user-select:none;user-select:none;letter-spacing:-.01em;font-style:italic;font-weight:500;line-height:1}}@font-face{font-family:Literata;font-style:normal;font-weight:200 900;font-display:swap;src:url("/assets/literata-variable-cf325924.woff2")format("woff2-variations")}@font-face{font-family:Literata;font-style:italic;font-weight:200 900;font-display:swap;src:url("/assets/literata-italic-variable-85b405f3.woff2")format("woff2-variations")}body.native-app .breadcrumb,body.native-app .page-title,body.native-app .page-sub,body.native-app .recipe-show-title,body.native-app .plan-greeting,body.native-app .plan-title,body.native-app .plan-sub,body.native-app .shopping-eyebrow,body.native-app .shopping-title,body.native-app .from-recipe-title,body.native-app .cook-recipe-name{display:none}body.native-app{margin-top:50px}body.native-app .app-main-inner{padding-top:64px;padding-bottom:calc(96px + env(safe-area-inset-bottom))}body.native-app .hidden-on-native{display:none}body.native-app #sentry-feedback{--page-margin:calc(96px + env(safe-area-inset-top)) 16px calc(96px + env(safe-area-inset-bottom)) 16px}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}