:root{--paper-50: oklch(.985 .015 80);--paper-100: oklch(.965 .022 80);--paper-200: oklch(.93 .025 80);--paper-300: oklch(.86 .02 80);--ink-400: oklch(.62 .012 80);--ink-500: oklch(.54 .013 80);--ink-600: oklch(.45 .014 80);--ink-800: oklch(.27 .014 80);--ink-900: oklch(.16 .012 80);--crust-50: oklch(.96 .02 38);--crust-100: oklch(.92 .04 36);--crust-500: oklch(.62 .15 36);--crust-600: oklch(.55 .16 36);--crust-700: oklch(.46 .16 34);--crust-on: oklch(.97 .015 80);--success-600: oklch(.58 .13 145);--warn-600: oklch(.72 .15 75);--danger-600: oklch(.55 .17 25);--info-600: oklch(.55 .1 230);--color-bg-canvas: var(--paper-100);--color-bg-surface: var(--paper-200);--color-bg-muted: var(--paper-300);--color-bg-deep: var(--paper-50);--color-fg-default: var(--ink-800);--color-fg-strong: var(--ink-900);--color-fg-muted: var(--ink-600);--color-fg-subtle: var(--ink-400);--color-fg-icon: var(--ink-500);--color-fg-on-accent: var(--crust-on);--color-border: var(--paper-300);--color-border-strong: var(--ink-800);--color-accent-fg: var(--crust-600);--color-accent-bg: var(--crust-50);--color-accent-deep: var(--crust-700);--color-focus-ring: var(--crust-600);--color-emphasis: var(--ink-900);--pattern-benday: radial-gradient( circle, color-mix(in oklab, var(--ink-900) 35%, transparent) .7px, transparent 1.4px );--pattern-benday-size: 5px 5px;--pattern-benday-soft: radial-gradient( circle, color-mix(in oklab, var(--crust-600) 18%, transparent) .7px, transparent 1.4px );--pattern-hatch: repeating-linear-gradient( -45deg, var(--paper-300) 0, var(--paper-300) .5px, transparent .5px, transparent 4px );--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-display: "Inter", "Helvetica Neue Condensed Bold", "Arial Narrow", sans-serif;--font-editorial: "Fraunces", "Iowan Old Style", Georgia, serif;--type-masthead-size: clamp(1.25rem, 5vw, 2.25rem);--type-masthead-lh: 1;--type-masthead-tracking: -.015em;--type-h1-size: 1.75rem;--type-h1-lh: 1.05;--type-h2-size: 1.25rem;--type-h2-lh: 1.15;--type-h3-size: .875rem;--type-h3-lh: 1.2;--type-body-size: .9375rem;--type-body-lh: 1.45;--type-small-size: .8125rem;--type-small-lh: 1.4;--type-eyebrow-size: .6875rem;--type-eyebrow-lh: 1.2;--type-eyebrow-tracking: .12em;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--space-0: 0;--space-px: 2px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 9999px;--border-hairline: 1px;--border-rule: 2px;--border-frame: 3px;--border-rule-double: 4px;--shadow-overlay: 0 1px 2px rgba(31, 28, 22, .04), 0 8px 24px rgba(31, 28, 22, .1);--shadow-stamp: 2px 2px 0 var(--color-fg-strong);--duration-fast: 80ms;--duration-standard: .16s;--duration-slow: .28s;--easing-standard: cubic-bezier(.2, 0, 0, 1);--easing-overlay: cubic-bezier(.32, .72, 0, 1);--z-tooltip: 1000;--z-popover: 1100;--z-drawer: 1200;--calc-max-width: 880px;color-scheme:light dark}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--paper-50: oklch(.16 .02 245);--paper-100: oklch(.2 .025 245);--paper-200: oklch(.24 .028 245);--paper-300: oklch(.34 .03 245);--ink-400: oklch(.66 .015 80);--ink-500: oklch(.74 .012 80);--ink-600: oklch(.8 .01 80);--ink-800: oklch(.92 .006 80);--ink-900: oklch(.97 .005 80);--crust-500: oklch(.74 .13 38);--crust-600: oklch(.68 .14 36);--crust-700: oklch(.62 .14 34);--crust-50: oklch(.32 .05 36);--crust-100: oklch(.38 .07 36);--crust-on: oklch(.16 .02 245);--success-600: oklch(.7 .13 145);--warn-600: oklch(.8 .15 75);--danger-600: oklch(.7 .17 25);--info-600: oklch(.72 .1 230);--shadow-overlay: 0 1px 2px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .6)}}[data-theme=dark]{--paper-50: oklch(.16 .02 245);--paper-100: oklch(.2 .025 245);--paper-200: oklch(.24 .028 245);--paper-300: oklch(.34 .03 245);--ink-400: oklch(.66 .015 80);--ink-500: oklch(.74 .012 80);--ink-600: oklch(.8 .01 80);--ink-800: oklch(.92 .006 80);--ink-900: oklch(.97 .005 80);--crust-500: oklch(.74 .13 38);--crust-600: oklch(.68 .14 36);--crust-700: oklch(.62 .14 34);--crust-50: oklch(.32 .05 36);--crust-100: oklch(.38 .07 36);--crust-on: oklch(.16 .02 245);--success-600: oklch(.7 .13 145);--warn-600: oklch(.8 .15 75);--danger-600: oklch(.7 .17 25);--info-600: oklch(.72 .1 230);--shadow-overlay: 0 1px 2px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .6)}@media (prefers-contrast: more){:root{--color-border: CanvasText;--color-fg-default: CanvasText;--color-bg-canvas: Canvas}}@media (prefers-reduced-motion: reduce){:root{--duration-fast: 0ms;--duration-standard: 0ms;--duration-slow: 0ms}}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/inter-variable.woff2) format("woff2-variations")}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/fraunces-variable.woff2) format("woff2-variations")}body{font-family:var(--font-sans);font-size:var(--type-body-size);line-height:var(--type-body-lh);color:var(--color-fg-default);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-editorial);color:var(--color-fg-strong);margin:0}h1{font-size:var(--type-h1-size);line-height:var(--type-h1-lh);font-weight:var(--weight-bold)}h2{font-size:var(--type-h2-size);line-height:var(--type-h2-lh);font-weight:var(--weight-semibold)}h3{font-size:var(--type-h3-size);line-height:var(--type-h3-lh);font-weight:var(--weight-semibold)}p{margin:0 0 var(--space-3)}p:last-child{margin-bottom:0}small{font-size:var(--type-small-size)}code,kbd,samp{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875em}input[type=number]{font-variant-numeric:tabular-nums;font-feature-settings:"cv11","ss01"}.type-display-md{font-family:var(--font-editorial);font-size:clamp(1.5rem,5vw,2.25rem);line-height:1.1;font-weight:var(--weight-bold);font-variation-settings:"opsz" 72;letter-spacing:-.015em}.type-heading-lg{font-family:var(--font-sans);font-size:22px;line-height:30px;font-weight:var(--weight-semibold);letter-spacing:-.22px}.type-heading-md{font-family:var(--font-sans);font-size:18px;line-height:26px;font-weight:var(--weight-semibold);letter-spacing:-.09px}.type-body-lg{font-family:var(--font-sans);font-size:17px;line-height:1.55;font-weight:var(--weight-regular)}.type-body-md{font-family:var(--font-sans);font-size:var(--type-body-size);line-height:var(--type-body-lh);font-weight:var(--weight-regular)}.type-body-sm{font-family:var(--font-sans);font-size:13px;line-height:18px;font-weight:var(--weight-medium);letter-spacing:.13px}.type-numeric-display{font-family:var(--font-sans);font-size:32px;line-height:36px;font-weight:var(--weight-medium);font-variant-numeric:tabular-nums;letter-spacing:-.32px}.type-numeric-md{font-family:var(--font-sans);font-size:17px;line-height:24px;font-weight:var(--weight-medium);font-variant-numeric:tabular-nums}.type-numeric-sm{font-family:var(--font-sans);font-size:13px;line-height:18px;font-weight:var(--weight-medium);font-variant-numeric:tabular-nums}.type-caption{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);line-height:var(--type-eyebrow-lh);font-weight:var(--weight-medium);letter-spacing:.24px}#site-header{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4) calc(var(--space-3) + 2px);background:var(--color-bg-canvas);position:sticky;top:0;z-index:100;border-bottom:var(--border-rule) solid var(--color-fg-strong)}#site-header:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:var(--color-accent-fg);pointer-events:none}.header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.header-wordmark{text-decoration:none;color:var(--color-accent-fg);font-family:var(--font-display);font-weight:var(--weight-black);font-size:var(--type-masthead-size);line-height:var(--type-masthead-lh);letter-spacing:var(--type-masthead-tracking);text-transform:uppercase}.header-wordmark:hover{color:var(--color-accent-deep)}.header-nav{display:flex;align-items:center;gap:var(--space-4)}.header-learn{color:var(--color-fg-default);text-decoration:none;font-weight:var(--weight-semibold);font-size:var(--type-small-size);text-transform:uppercase;letter-spacing:var(--type-eyebrow-tracking)}.header-learn:hover{color:var(--color-accent-fg);text-decoration:underline}.header-overflow{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:18px;color:var(--color-fg-default);cursor:pointer;transition:box-shadow var(--duration-fast) var(--easing-standard)}.header-overflow:hover{background:var(--color-bg-muted);box-shadow:var(--shadow-stamp)}.header-overflow:focus-visible{outline:var(--border-rule) solid var(--color-focus-ring);outline-offset:2px}.header-tagline{margin:0;color:var(--color-fg-muted);font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size)}.header-menu{position:absolute;top:calc(100% + var(--space-1));right:var(--space-4);min-width:180px;background-color:var(--color-bg-canvas);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-stamp);padding:var(--space-1);z-index:200;display:flex;flex-direction:column}.header-menu-item{background:transparent;border:none;text-align:left;padding:var(--space-1) var(--space-2);font-family:var(--font-sans);font-size:var(--type-small-size);color:var(--color-fg-default);cursor:pointer;border-radius:var(--radius-sm)}.header-menu-item:hover{background:var(--color-bg-muted);color:var(--color-fg-strong)}.header-menu-item:focus-visible{outline:var(--border-rule) solid var(--color-focus-ring);outline-offset:2px}.skip-link{position:absolute;top:-100px;left:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-accent-fg);color:var(--color-fg-on-accent);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);border-radius:var(--radius-sm);z-index:1000;text-decoration:none}.skip-link:focus{top:var(--space-2)}#tip-strip:empty{display:none}.tip-strip-inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-4) var(--space-2) calc(var(--space-4) + 3px);background-color:var(--color-bg-surface);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);border-bottom:var(--border-hairline) solid var(--color-border);border-left:3px solid var(--color-accent-fg);font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);color:var(--color-fg-default);line-height:1.4}.tip-strip-dismiss{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:var(--border-hairline) solid var(--color-border);border-radius:var(--radius-sm);font-size:16px;color:var(--color-fg-muted);cursor:pointer}.tip-strip-dismiss:hover{background:var(--color-bg-muted);border-color:var(--color-border-strong);box-shadow:var(--shadow-stamp);color:var(--color-fg-strong)}@media (forced-colors: active){.tip-strip-inner{border-left-color:Highlight}}#recipe-headline{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-4) var(--space-3)}.recipe-name{margin:0;font-family:var(--font-editorial);font-size:var(--type-h1-size);font-weight:var(--weight-bold);line-height:var(--type-h1-lh);color:var(--color-fg-strong);letter-spacing:-.01em}.recipe-name [data-role=name]{display:inline-block;min-width:1ch;outline:none;border-radius:var(--radius-sm);padding:0 var(--space-1);margin:0 calc(-1 * var(--space-1))}.recipe-name [data-role=name][data-empty="1"]{color:var(--color-fg-subtle);font-style:italic}.recipe-name [data-role=name]:hover{background:var(--color-bg-muted)}.recipe-name [data-role=name]:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.recipe-notes-row{display:flex;align-items:center;gap:var(--space-2);margin:0;min-height:24px}.recipe-notes{font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);line-height:1.3;color:var(--color-fg-muted);outline:none;border-radius:var(--radius-sm);padding:0 var(--space-1);flex:1}.recipe-notes:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.recipe-notes-clear{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-fg-subtle);font-size:16px;padding:0;cursor:pointer}.recipe-notes-clear:hover{background:var(--color-bg-muted);color:var(--color-fg-default)}.recipe-notes-add{background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius-pill);padding:var(--space-1) var(--space-3);color:var(--color-fg-muted);cursor:pointer}.recipe-notes-add:hover{color:var(--color-accent-fg);border-color:var(--color-accent-fg)}.mode-badge{display:inline-block;align-self:flex-start;padding:2px var(--space-2);background:var(--color-bg-muted);color:var(--color-fg-muted);border-radius:var(--radius-pill)}.metric-strip{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-2)}.metric-tile{display:flex;flex-direction:column;justify-content:space-between;align-items:center;min-width:84px;padding:var(--space-2) var(--space-3);background-color:var(--color-fg-strong);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-fg-strong);text-align:center}.metric-tile-label{font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-semibold);color:var(--color-bg-canvas);opacity:.85}.metric-tile-value{font-size:1.375rem;font-weight:var(--weight-black);font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.015em;margin-top:2px;color:var(--color-bg-canvas)}@media (max-width: 480px){.metric-tile{min-width:64px;padding:var(--space-1) var(--space-2)}.metric-tile-value{font-size:1.125rem}}#template-picker{margin-bottom:var(--space-3)}.template-trigger{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-fg-muted);font:inherit;cursor:pointer;min-height:36px;font-size:var(--type-small-size);font-family:var(--font-sans);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:var(--type-eyebrow-tracking);transition:box-shadow var(--duration-fast) var(--easing-standard)}.template-trigger:hover{background:var(--color-bg-muted);color:var(--color-accent-fg);border-color:var(--color-accent-fg);box-shadow:var(--shadow-stamp)}.template-popover{position:relative;margin-top:var(--space-2);background:var(--color-bg-surface);border:var(--border-frame) solid var(--color-fg-strong);border-radius:var(--radius-sm);box-shadow:4px 4px 0 var(--color-accent-fg);padding:var(--space-2);z-index:var(--z-popover)}.template-search-row{display:grid;grid-template-columns:1fr 44px;gap:var(--space-2);align-items:center;padding-bottom:var(--space-2);border-bottom:var(--border-rule) solid var(--color-accent-fg);margin-bottom:var(--space-2)}.template-close{width:36px;height:36px;background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:18px;color:var(--color-fg-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.template-close:hover{background:var(--color-bg-muted);box-shadow:var(--shadow-stamp);color:var(--color-fg-default)}.template-list{max-height:60vh;overflow-y:auto;padding:0;margin:0}.template-group{list-style:none;margin:0;padding:0}.template-group-label{list-style:none;padding:var(--space-2) var(--space-2) var(--space-1);font-family:var(--font-display);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-black);color:var(--color-fg-subtle)}[role=option]{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;min-height:36px;transition:transform var(--duration-fast) var(--easing-standard),box-shadow var(--duration-fast) var(--easing-standard)}[role=option]:hover{background:var(--color-bg-muted);transform:translate(-1px,-1px);box-shadow:var(--shadow-stamp)}[role=option]:focus-visible{outline:var(--border-rule) solid var(--color-focus-ring);outline-offset:2px}.template-name{font-family:var(--font-display);font-size:var(--type-small-size);font-weight:var(--weight-black);text-transform:uppercase;letter-spacing:.04em;color:var(--color-fg-strong)}.template-meta{font-family:var(--font-editorial);font-style:italic;color:var(--color-fg-muted);font-size:13px;font-variant-numeric:tabular-nums}#template-confirm{border:var(--border-frame) solid var(--color-fg-strong);padding:0;border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-fg-default);box-shadow:4px 4px 0 var(--color-accent-fg);width:min(420px,calc(100vw - 32px));max-width:420px;padding:var(--space-5) var(--space-6)}#template-confirm::backdrop{background:#1f1c1666}#template-confirm h2{margin:0 0 var(--space-3);font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong)}#template-confirm p{margin:0 0 var(--space-4);font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);color:var(--color-fg-muted)}#template-confirm .dialog-actions{display:flex;gap:var(--space-2);justify-content:flex-end}#template-confirm button{padding:var(--space-2) var(--space-4);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-bg-canvas);color:var(--color-fg-default);font:inherit;font-size:var(--type-small-size);cursor:pointer}#template-confirm button:hover{box-shadow:var(--shadow-stamp)}#template-confirm button.primary{background:var(--color-accent-fg);color:var(--color-bg-canvas);border-color:var(--color-accent-fg);font-weight:var(--weight-bold)}@media (forced-colors: active){.template-trigger{border-color:ButtonText}.template-popover{border-color:ButtonText;box-shadow:none}[role=option]:hover{transform:none;box-shadow:none}#template-confirm{border-color:ButtonText;box-shadow:none}}.tooltip-overlay{background-color:var(--color-bg-surface);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);color:var(--color-fg-default);border:var(--border-hairline) solid var(--color-accent-fg);border-radius:var(--radius-sm);box-shadow:var(--shadow-stamp);padding:var(--space-2) var(--space-3);font-size:var(--type-small-size);max-width:min(320px,calc(100vw - 32px));font-family:var(--font-sans)}.tooltip-overlay a{color:var(--color-accent-fg);text-underline-offset:2px}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:var(--space-1);padding:4px;margin-right:-4px;border:var(--border-hairline) solid var(--color-fg-subtle);border-radius:50%;background:transparent;color:var(--color-fg-subtle);font-size:11px;font-family:var(--font-sans);font-weight:var(--weight-bold);cursor:pointer;vertical-align:middle;transition:box-shadow var(--duration-fast) var(--easing-standard)}.help-icon:hover{color:var(--color-accent-fg);border-color:var(--color-accent-fg);box-shadow:var(--shadow-stamp)}@media (forced-colors: active){.tooltip-overlay{border-color:ButtonText}.help-icon{border-color:ButtonText;forced-color-adjust:none}}#settings-drawer{border:var(--border-frame) solid var(--color-fg-strong);padding:0;border-radius:var(--radius-md);background:var(--color-bg-canvas);color:var(--color-fg-default);box-shadow:-8px 0 24px #0000001a,var(--shadow-stamp);width:min(360px,calc(100vw - 32px));margin-left:auto;margin-right:0;max-height:90vh}#settings-drawer::backdrop{background:#1f1c1666}@media (max-width: 767px){#settings-drawer{width:100vw;max-height:60vh;margin:auto auto 0;border-radius:var(--radius-md) var(--radius-md) 0 0}}.drawer-inner{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-5)}.drawer-header{display:flex;align-items:center;justify-content:space-between}.drawer-header h2{margin:0;font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);padding-bottom:var(--space-1);border-bottom:var(--border-rule) solid var(--color-accent-fg)}.drawer-close{width:36px;height:36px;border:var(--border-hairline) solid var(--color-border-strong);background:var(--color-bg-canvas);border-radius:var(--radius-sm);font-size:20px;color:var(--color-fg-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.drawer-close:hover{box-shadow:var(--shadow-stamp);color:var(--color-fg-default)}.drawer-control{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.drawer-control legend{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-muted);padding:0;margin-bottom:var(--space-1)}.segmented{display:inline-flex;border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:2px;background:var(--color-bg-canvas);box-shadow:var(--shadow-stamp)}.segmented button{flex:1 1 auto;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-fg-default);font:inherit;cursor:pointer;font-size:var(--type-small-size)}.segmented button.is-on{background:var(--color-accent-fg);color:var(--color-bg-canvas);font-weight:var(--weight-bold)}.checkbox-row{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--type-small-size);color:var(--color-fg-default)}.checkbox-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-accent-fg)}@media (forced-colors: active){#settings-drawer,.segmented{border-color:ButtonText}}#snapshot-card{display:flex;flex-direction:column;gap:var(--space-4)}.snapshot-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.snapshot-gear{width:36px;height:36px;background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.snapshot-gear:hover{background:var(--color-bg-muted);border-color:var(--color-fg-strong);box-shadow:var(--shadow-stamp);color:var(--color-fg-default)}.snapshot-headline{display:flex;flex-wrap:wrap;gap:var(--space-5) var(--space-8);align-items:flex-start}.snapshot-stat{display:flex;flex-direction:column;gap:var(--space-1);min-width:140px}.snapshot-stat-label{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-semibold);color:var(--color-fg-muted);display:inline-flex;align-items:center}.snapshot-stat-value{color:var(--color-fg-default);font-variant-numeric:tabular-nums}.snapshot-stat-headline{color:var(--color-accent-fg);font-weight:var(--weight-black)}.snapshot-target-link{align-self:flex-start;background:transparent;border:none;padding:var(--space-1) 0;color:var(--color-accent-fg);cursor:pointer;text-decoration:underline;text-underline-offset:2px;font-size:var(--type-small-size)}.snapshot-target-input{width:100px;height:36px;padding:0 var(--space-2);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;box-shadow:var(--shadow-stamp)}.snapshot-target-input:focus{outline:var(--border-rule) solid var(--color-focus-ring);outline-offset:1px}.snapshot-secondary{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-5);padding-top:var(--space-3);border-top:var(--border-rule) solid var(--color-accent-fg)}.snapshot-secondary-stat{display:flex;flex-direction:column;min-width:96px;gap:var(--space-1)}@media (forced-colors: active){.snapshot-gear,.snapshot-target-input{border-color:ButtonText}.snapshot-secondary{border-top-color:ButtonText}}#zone-band{display:flex;flex-direction:column;gap:var(--space-3)}.zone-band-heading{margin:0 0 var(--space-6);display:flex;align-items:center;gap:var(--space-1)}.zone-band{position:relative;width:100%;height:48px;background:var(--color-bg-muted);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);overflow:hidden}@media (max-width: 767px){.zone-band{height:64px}}.zone-segment{position:absolute;top:0;bottom:0;border-right:var(--border-hairline) solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:var(--type-small-size);font-weight:var(--weight-semibold);color:var(--color-fg-muted);background:var(--color-bg-muted);pointer-events:none;z-index:0;text-transform:uppercase;letter-spacing:.04em;text-align:center}.zone-segment:last-of-type{border-right:none}.zone-segment.is-active{background-color:var(--color-accent-fg);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent)}.zone-segment-label{font-size:var(--type-eyebrow-size);letter-spacing:.06em;font-weight:var(--weight-semibold);padding:2px var(--space-2);border-radius:var(--radius-sm);position:relative;z-index:2}.zone-tick{position:absolute;bottom:0;transform:translate(-50%);width:1.5px;height:32%;background:var(--color-fg-default);opacity:.32;border:none;padding:0;cursor:pointer;z-index:1;border-radius:0;transition:opacity var(--duration-fast) var(--easing-standard),height var(--duration-fast) var(--easing-standard),background var(--duration-fast) var(--easing-standard)}.zone-tick:hover{opacity:1;height:80%;background:var(--color-accent-fg)}.zone-tick:focus-visible{opacity:1;height:80%;background:var(--color-accent-fg);outline:2px solid var(--color-focus-ring);outline-offset:2px}.zone-band-track{position:relative;margin-top:var(--space-8)}.zone-marker-line{position:absolute;top:0;bottom:0;transform:translate(-50%);width:4px;background-color:var(--color-accent-fg);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);border-left:1px solid var(--color-fg-strong);border-right:1px solid var(--color-fg-strong);z-index:4;pointer-events:none}.zone-marker-badge{position:absolute;bottom:calc(100% + 8px);transform:translate(-50%);display:flex;flex-direction:column;align-items:center;z-index:5;cursor:default;pointer-events:auto}.zone-marker-badge:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:4px;border-radius:var(--radius-sm)}.zone-marker-eyebrow{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);background:var(--color-bg-canvas);border:1px solid var(--color-fg-strong);border-bottom:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0;padding:1px var(--space-2);white-space:nowrap;line-height:1.3}.zone-marker-value{background-color:var(--color-accent-fg);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent);font-family:var(--font-sans);font-size:var(--type-body-size);font-weight:var(--weight-black);font-variant-numeric:tabular-nums;letter-spacing:-.01em;padding:2px var(--space-3);border:1.5px solid var(--color-fg-strong);border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-stamp);white-space:nowrap;line-height:1.2}.zone-marker-arrow{display:block;font-size:18px;line-height:1;color:var(--color-fg-strong);margin-top:-1px}.zone-note{margin:0;color:var(--color-fg-muted)}@media (forced-colors: active){.zone-segment{border:1px solid CanvasText}}#ingredient-picker{position:relative;display:inline-block;width:100%;background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm)}#ingredient-picker:focus-within{box-shadow:var(--shadow-stamp)}#ingredient-picker label{display:block;font-family:var(--font-sans);font-size:var(--type-eyebrow-size);font-weight:var(--weight-bold);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;color:var(--color-fg-muted);padding:var(--space-1) var(--space-2) 0}#ing-search{display:block;width:100%;background:transparent;border:none;padding:var(--space-1) var(--space-2) var(--space-2);font-family:var(--font-sans);font-size:var(--type-body-size);color:var(--color-fg-default);box-sizing:border-box}#ing-search:focus{outline:none}#ing-search::placeholder{color:var(--color-fg-subtle)}#ing-results{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-canvas);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);border:var(--border-hairline) solid var(--color-border-strong);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-overlay);z-index:var(--z-popover);max-height:240px;overflow-y:auto;margin:0;padding:0;list-style:none}#ing-results li[role=option]{padding:var(--space-1) var(--space-3);cursor:pointer;font-size:var(--type-small-size);font-family:var(--font-sans);color:var(--color-fg-default);border-bottom:var(--border-hairline) solid var(--color-border)}#ing-results li[role=option]:last-child{border-bottom:none}#ing-results li[role=option].is-selected,#ing-results li[role=option][aria-selected=true]{border-left:3px solid var(--color-accent-fg);padding-left:calc(var(--space-3) - 3px);background:var(--color-bg-muted)}#ing-results li[role=option]:hover{background:var(--color-bg-muted)}#ing-results li small{color:var(--color-fg-subtle);font-size:var(--type-eyebrow-size);text-transform:uppercase;letter-spacing:.04em;margin-left:var(--space-1)}.role-pill-host{position:relative;display:inline-block}.role-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);background:var(--color-accent-fg);color:var(--color-fg-on-accent);border:none;border-radius:var(--radius-pill);box-shadow:var(--shadow-stamp);font-family:var(--font-sans);font-size:var(--type-eyebrow-size);font-weight:var(--weight-bold);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;line-height:1.4;cursor:pointer;min-height:26px}.role-pill:hover{filter:brightness(1.08)}.role-pill.is-derived{background:var(--color-bg-muted);color:var(--color-fg-muted);box-shadow:1px 1px 0 var(--color-border-strong);font-style:italic;border:var(--border-hairline) dashed var(--color-border-strong)}.role-pill[data-role=flour],.role-pill[data-role=salt]{background:var(--ink-800);color:var(--paper-50)}.role-pill[data-role=wet]{background:var(--info-600, var(--ink-600));color:var(--paper-50)}.role-pill[data-role=fat]{background:var(--warn-600, var(--crust-500));color:var(--ink-900)}.role-pill[data-role=sweetener]{background:var(--crust-600);color:var(--paper-50)}.role-pill[data-role=yeast]{background:var(--success-600, var(--ink-600));color:var(--paper-50)}.role-pill[data-role=leavener]{background:var(--info-600, var(--ink-600));color:var(--paper-50)}.role-pill[data-role=inclusion]{background:var(--paper-300);color:var(--ink-900);box-shadow:1px 1px 0 var(--ink-900)}.role-pill[data-role=enrichment]{background:var(--crust-100);color:var(--ink-900);box-shadow:1px 1px 0 var(--crust-700)}.role-pill-caret{color:inherit;opacity:.75;font-size:10px}.role-popover{position:absolute;top:calc(100% + 4px);left:0;background:var(--color-bg-surface);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-overlay);padding:var(--space-1);min-width:160px;z-index:var(--z-popover);display:flex;flex-direction:column}.role-option{text-align:left;background:transparent;border:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--color-fg-default);font-family:var(--font-sans);font-size:var(--type-small-size);cursor:pointer;text-transform:uppercase;letter-spacing:.03em}.role-option:hover{background:var(--color-bg-muted)}.role-option[aria-selected=true]{background:var(--color-accent-bg);color:var(--crust-700);font-weight:var(--weight-bold)}.role-option-inferred{color:var(--color-fg-muted);border-top:1px solid var(--color-border);margin-top:var(--space-1);text-transform:none;font-style:italic;letter-spacing:0}#recipe-table{display:flex;flex-direction:column;gap:0;border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);overflow:hidden}[role=row]{display:grid;grid-template-columns:minmax(0,2fr) minmax(80px,1fr) minmax(80px,1fr) 120px 44px;gap:var(--space-2);align-items:center;padding:var(--space-2) var(--space-3)}.row-header{background:var(--color-accent-fg);color:var(--color-fg-on-accent);font-family:var(--font-sans);font-size:var(--type-eyebrow-size);font-weight:var(--weight-bold);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase}.row-header [role=columnheader]:nth-child(2),.row-header [role=columnheader]:nth-child(3){padding-left:var(--space-1)}.row-header [role=columnheader]:nth-child(4){padding-left:var(--space-1)}.row-header .help-icon{background:transparent;border:none;cursor:pointer;color:var(--color-fg-on-accent);opacity:.75;font-size:.625rem;padding:0 2px;vertical-align:middle}.row-header .help-icon:hover{opacity:1}[role=row]:not(.row-header){border-bottom:var(--border-hairline) solid var(--color-border);font-size:var(--type-body-size);color:var(--color-fg-default)}[role=row]:not(.row-header):last-child{border-bottom:none}[role=row]:not(.row-header):nth-child(2n){background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size)}[role=row] .role-pill-host{justify-self:start}.solved-grams{color:var(--color-fg-muted);font-variant-numeric:tabular-nums;padding-left:var(--space-1)}#recipe-table input[type=number],#recipe-table input[type=text]{width:100%;background:var(--color-bg-canvas);color:var(--color-fg-default);border:var(--border-hairline) solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-family:var(--font-sans);font-size:var(--type-body-size);font-variant-numeric:tabular-nums;box-sizing:border-box}#recipe-table input:focus{outline:none;border-color:var(--color-accent-fg);box-shadow:0 0 0 1px var(--color-accent-fg)}input.pct-derived{color:var(--color-fg-subtle);font-style:italic}[role=row] button[data-action=remove]{width:44px;height:44px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-fg-icon);cursor:pointer}[role=row] button[data-action=remove]:hover{background:var(--color-bg-muted);color:var(--color-accent-fg);border-color:var(--color-border)}@media (max-width: 767px){#recipe-table{border:none;border-radius:0;overflow:visible;gap:var(--space-1)}[role=row]:not(.row-header){display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:var(--space-1) var(--space-2);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-canvas);background-image:none;margin-bottom:var(--space-2)}[role=row]:not(.row-header) [role=cell]:nth-child(1){grid-column:1 / 2;grid-row:1;font-weight:600}[role=row]:not(.row-header) [role=cell]:nth-child(2),[role=row]:not(.row-header) [role=cell]:nth-child(3),[role=row]:not(.row-header) [role=cell]:nth-child(4){grid-row:2}[role=row]:not(.row-header) [role=cell]:nth-child(2){grid-column:1}[role=row]:not(.row-header) [role=cell]:nth-child(3){grid-column:2}[role=row]:not(.row-header) [role=cell]:nth-child(4){grid-column:1 / span 2}[role=row]:not(.row-header) [role=cell]:nth-child(5){grid-column:2;grid-row:1;align-self:start;justify-self:end}.row-header{display:none}}#warnings-panel h2,#warnings-panel h3{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);margin:0 0 var(--space-2);padding-bottom:var(--space-1);border-bottom:var(--border-rule) solid var(--color-accent-fg);position:relative}#warnings-panel h2:after,#warnings-panel h3:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:.5px;background:var(--color-fg-strong)}#warnings-panel .warn-list{list-style:none;padding:0;margin:0 0 var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);counter-reset:warning}.warn-row{counter-increment:warning;display:grid;grid-template-columns:24px 1fr;gap:var(--space-2);align-items:start;padding:var(--space-2) var(--space-3);border-left:3px solid;border-radius:var(--radius-sm);cursor:pointer;position:relative}.warn-row.warn-error{border-color:var(--color-accent-deep);background:color-mix(in oklch,var(--color-accent-deep) 8%,var(--color-bg-surface))}.warn-row.warn-warn{border-color:var(--color-accent-fg);background:color-mix(in oklch,var(--color-accent-fg) 10%,var(--color-bg-surface))}.warn-row.warn-info{border-color:var(--color-fg-strong);background:color-mix(in oklch,var(--color-fg-strong) 6%,var(--color-bg-surface))}.warn-row-icon{width:20px;height:20px;border-radius:50%;background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent);font-family:var(--font-sans);font-size:var(--type-eyebrow-size);font-weight:var(--weight-black);line-height:20px;text-align:center;box-shadow:1px 1px 0 var(--color-fg-strong);display:inline-flex;align-items:center;justify-content:center;font-size:13px}.warn-row.warn-info .warn-row-icon{background-color:var(--color-fg-strong)}.warn-row.warn-warn .warn-row-icon{background-color:var(--color-accent-fg)}.warn-row.warn-error .warn-row-icon{background-color:var(--color-accent-deep)}.warnings-empty{display:flex;align-items:center;gap:var(--space-2);margin:0;color:var(--color-fg-muted)}.warnings-empty-icon{width:20px;height:20px;border-radius:50%;background:var(--color-accent-fg);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent);display:inline-flex;align-items:center;justify-content:center;font-weight:var(--weight-black);font-size:13px;box-shadow:1px 1px 0 var(--color-fg-strong)}@media (forced-colors: active){.warn-row{border-left-color:ButtonText}.warn-row-icon{forced-color-adjust:none}}#show-math-section h2{font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);margin:0 0 var(--space-1);padding-bottom:var(--space-1);border-bottom:var(--border-rule) solid var(--color-accent-fg);position:relative}#show-math-section h2:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:.5px;background:var(--color-fg-strong)}.show-math-item{border-top:var(--border-hairline) solid var(--color-border);padding:var(--space-3) 0}.show-math-item:first-of-type{border-top:none}.show-math-item summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-editorial);font-style:italic;font-weight:var(--weight-semibold);color:var(--color-fg-strong)}.show-math-item summary::-webkit-details-marker{display:none}.show-math-item summary:before{content:"";display:inline-block;width:18px;height:18px;border-radius:50%;background-color:var(--color-fg-strong);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);box-shadow:1px 1px 0 var(--color-accent-fg);flex-shrink:0;clip-path:polygon(30% 20%,80% 50%,30% 80%)}.show-math-item[open] summary:before{clip-path:polygon(20% 30%,80% 30%,50% 80%);background-color:var(--color-accent-fg)}.show-math-body{padding:var(--space-2) 0 0 var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.show-math-line{font-family:var(--font-sans);font-size:var(--type-small-size);line-height:1.5;color:var(--color-fg-default);word-break:break-word}.show-math-term{display:inline-flex;align-items:baseline;gap:4px;background:transparent;border:none;padding:0 var(--space-1);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-accent-fg);font:inherit;font-size:var(--type-small-size);transition:box-shadow var(--duration-fast) var(--easing-standard)}.show-math-term:hover,.show-math-term.is-open{background:var(--color-accent-bg);box-shadow:var(--shadow-stamp)}.show-math-term-leaf{display:inline-flex;align-items:baseline;gap:4px;color:var(--color-fg-default);font-size:var(--type-small-size)}.show-math-term-label{color:var(--color-fg-muted);font-family:var(--font-editorial);font-style:italic}.show-math-nested{margin-left:var(--space-3);padding-left:var(--space-3);border-left:3px solid var(--color-accent-fg);display:flex;flex-direction:column;gap:var(--space-2);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size)}.show-math-result{margin-top:var(--space-2);padding-top:var(--space-2);border-top:var(--border-rule) solid var(--color-accent-fg);font-family:var(--font-sans);font-size:var(--type-body-size);font-weight:var(--weight-bold);color:var(--color-accent-fg);font-variant-numeric:tabular-nums}@media (forced-colors: active){.show-math-item summary:before{forced-color-adjust:none}.show-math-nested{border-left-color:Highlight}.show-math-term{border:1px solid transparent}.show-math-term:hover,.show-math-term.is-open{border-color:Highlight;box-shadow:none}}.learn-page{background:var(--color-bg-canvas)}.learn-header{max-width:72ch;margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-4)}.learn-back{display:inline-block;margin-bottom:var(--space-3);color:var(--color-fg-muted);text-decoration:none}.learn-back:hover{color:var(--color-accent-fg);text-decoration:underline}.learn-header h1{margin:0;font-family:var(--font-editorial);font-size:2rem;font-weight:var(--weight-bold);line-height:1.1;color:var(--color-fg-strong)}.learn-main{max-width:72ch;margin:0 auto;padding:0 var(--space-4) var(--space-12);display:grid;gap:var(--space-8)}.learn-toc{background-color:var(--color-bg-surface);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);border:var(--border-rule) solid var(--color-fg-strong);border-left:var(--border-frame) solid var(--color-accent-fg);border-radius:var(--radius-sm);padding:var(--space-4)}.learn-toc ol{margin:0;padding-left:var(--space-5)}.learn-toc a{color:var(--color-accent-fg);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}.learn-toc a:hover{color:var(--color-accent-deep)}.learn-article section{margin-bottom:var(--space-8)}.learn-article h2{font-family:var(--font-display);font-size:var(--type-h2-size);font-weight:var(--weight-black);text-transform:uppercase;letter-spacing:.02em;color:var(--color-fg-strong);margin:0 0 var(--space-3);padding-bottom:var(--space-1);border-bottom:var(--border-rule) solid var(--color-accent-fg);position:relative}.learn-article h2:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:.5px;background:var(--color-fg-strong)}.learn-article h2 a{color:inherit;text-decoration:none}.learn-article h2 a:hover{color:var(--color-accent-fg)}.learn-article p,.learn-article ul{margin:0 0 var(--space-3);color:var(--color-fg-default)}.learn-article p strong{color:var(--color-fg-strong);font-weight:var(--weight-semibold)}.learn-article ul{padding-left:var(--space-5);list-style:disc}.learn-article li{margin-bottom:var(--space-1)}.learn-article a{color:var(--color-accent-fg);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:2px}.learn-article a:hover{color:var(--color-accent-deep)}.learn-article code{background:var(--color-bg-muted);border-radius:var(--radius-sm);padding:1px 4px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875em;color:var(--color-fg-strong)}.learn-article pre{background-color:var(--color-bg-surface);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-3);overflow-x:auto;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875rem;line-height:1.4;color:var(--color-fg-default);margin:0 0 var(--space-3);box-shadow:var(--shadow-stamp)}.learn-article pre code{background:transparent;padding:0;font-size:inherit;color:inherit}.learn-footer{max-width:72ch;margin:0 auto;padding:var(--space-6) var(--space-4);color:var(--color-fg-subtle);text-align:center;border-top:var(--border-hairline) solid var(--color-border)}.learn-footer a{color:var(--color-fg-muted);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.learn-footer a:hover{color:var(--color-accent-fg)}@media print{@page{size:6in 4in;margin:0}body>*:not(#kitchen-card){display:none!important}body{--print-accent: #b94626;--print-accent-deep: #8a3217;--print-text: #1a1612;--print-body: #2e2820;--print-muted: #6a615a;--print-subtle: #8d837a;--print-rule: #d6cec3;--print-wash: #f0e9dc;--print-paper: #faf2dc;--print-on-accent: #fbf3dc;--benday: radial-gradient(circle, rgba(0, 0, 0, .35) .5pt, transparent .9pt);--benday-size: 3pt 3pt;--benday-cream: radial-gradient(circle, rgba(184, 70, 38, .18) .5pt, transparent .9pt);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--print-body);background:var(--print-paper);margin:0;padding:0;width:6in;height:4in;overflow:hidden;font-size:9pt;line-height:1.35;-webkit-print-color-adjust:exact;print-color-adjust:exact}#kitchen-card{display:block!important;width:100%;height:100%;padding:0;margin:0}.kc-card{position:relative;width:100%;height:100%;box-sizing:border-box;padding:.18in .22in;background:var(--print-paper);border:2pt solid var(--print-text);box-shadow:inset 0 0 0 .5pt var(--print-accent),inset 0 0 0 4pt var(--print-paper);display:flex;flex-direction:column;gap:6pt;overflow:hidden;break-inside:avoid;page-break-inside:avoid}.kc-header{display:flex;justify-content:space-between;align-items:stretch;gap:14pt;padding-bottom:5pt;border-bottom:2.5pt solid var(--print-text);flex:0 0 auto;position:relative}.kc-header:after{content:"";position:absolute;left:0;right:0;bottom:-3.5pt;height:.75pt;background:var(--print-accent)}.kc-header-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center}.kc-name{font-family:Inter,Helvetica Neue Condensed Bold,Arial Narrow,sans-serif;font-size:21pt;font-weight:800;line-height:1;margin:0 0 3pt;color:var(--print-text);text-transform:uppercase;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kc-notes{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-style:italic;color:var(--print-muted);margin:0;font-size:9pt;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kc-metric-strip{display:flex;gap:4pt;align-items:stretch;flex:0 0 auto}.kc-metric{display:flex;flex-direction:column;justify-content:space-between;align-items:center;min-width:36pt;padding:2pt 5pt 3pt;background:var(--print-text);background-image:var(--benday);background-size:var(--benday-size);color:var(--print-on-accent);border:.5pt solid var(--print-text);text-align:center}.kc-metric-label{font-size:5.5pt;text-transform:uppercase;letter-spacing:.1em;color:var(--print-on-accent);margin-bottom:1pt;font-weight:600;opacity:.85}.kc-metric-value{font-size:13pt;font-weight:800;font-variant-numeric:tabular-nums;color:var(--print-on-accent);line-height:1;white-space:nowrap;letter-spacing:-.015em}.kc-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);column-gap:14pt;align-items:stretch;flex:1 1 auto;min-height:0;overflow:hidden}.kc-col-left,.kc-col-right{min-width:0;height:100%;overflow:hidden}.kc-col-right{display:flex;flex-direction:column;gap:6pt}.kc-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;break-inside:avoid}.kc-table thead th{text-align:left;font-size:6pt;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--print-on-accent);background:var(--print-accent);padding:3pt 4pt;border:none;overflow:hidden;white-space:nowrap}.kc-table tbody td{padding:3pt 4pt;font-size:9pt;line-height:1.3;color:var(--print-body);vertical-align:baseline;border-bottom:.25pt solid var(--print-rule)}.kc-table tbody tr:nth-child(2n) td{background-color:var(--print-wash);background-image:var(--benday-cream);background-size:var(--benday-size)}.kc-table tbody tr:last-child td{border-bottom:none}.kc-table th:first-child,.kc-table td:first-child{width:auto}.kc-table th:nth-child(2),.kc-table td:nth-child(2){width:13%;text-align:right;font-variant-numeric:tabular-nums;padding-left:3pt;padding-right:4pt}.kc-table th:nth-child(3):last-child,.kc-table td:nth-child(3):last-child{width:18%;text-align:right;font-variant-numeric:tabular-nums;padding-left:3pt;padding-right:5pt}.kc-table th:nth-child(3):not(:last-child),.kc-table td:nth-child(3):not(:last-child){width:20%;font-size:7pt;text-transform:lowercase;color:var(--print-muted);padding-left:4pt;padding-right:4pt;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kc-table th:nth-child(4),.kc-table td:nth-child(4){width:18%;text-align:right;font-variant-numeric:tabular-nums;padding-left:3pt;padding-right:5pt}.kc-td-name{font-weight:600;color:var(--print-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kc-td-num{font-weight:500}.kc-section-heading{font-size:6.5pt;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--print-text);margin:0 0 4pt;padding-bottom:2pt;border-bottom:2pt solid var(--print-accent);position:relative}.kc-section-heading:after{content:"";position:absolute;left:0;right:0;bottom:-3.5pt;height:.5pt;background:var(--print-text)}.kc-course-block{flex:0 0 auto;break-inside:avoid}.kc-course-heading{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-size:14pt;font-weight:600;margin:0 0 1pt;color:var(--print-text);line-height:1.1;display:flex;align-items:center;gap:5pt;flex-wrap:wrap}.kc-course-prefix{font-family:Inter,system-ui,sans-serif;font-size:6.5pt;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--print-accent);flex:0 0 auto}.kc-course-num{display:inline-flex;align-items:center;justify-content:center;width:22pt;height:22pt;border-radius:50%;background:var(--print-accent);background-image:var(--benday);background-size:var(--benday-size);color:var(--print-on-accent);font-family:Inter,system-ui,sans-serif;font-size:13pt;font-weight:800;line-height:1;flex:0 0 auto;box-shadow:1pt 1pt 0 var(--print-text)}.kc-course-dash{display:none}.kc-course-name{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-weight:600;color:var(--print-text);line-height:1.1}.kc-course-subline{font-size:8pt;color:var(--print-muted);margin:3pt 0 0;line-height:1.2;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.kc-notes-block{flex:0 1 auto;min-height:0;overflow:hidden;break-inside:avoid}.kc-notes-block p{font-family:Fraunces,Iowan Old Style,Georgia,serif;font-size:8.5pt;margin:0 0 3pt;line-height:1.35;color:var(--print-body)}.kc-notes-block p:last-child{margin-bottom:0}.kc-hints-block{flex:0 0 auto;break-inside:avoid}.kc-hints-list{list-style:none;margin:0;padding:0;counter-reset:hint;display:flex;flex-direction:column;gap:2pt}.kc-hints-list li{counter-increment:hint;font-size:8.5pt;line-height:1.3;color:var(--print-body);padding-left:17pt;position:relative;font-weight:500}.kc-hints-list li:before{content:counter(hint);position:absolute;left:0;top:0;width:12pt;height:12pt;border-radius:50%;background:var(--print-text);background-image:var(--benday);background-size:var(--benday-size);color:var(--print-on-accent);font-family:Inter,system-ui,sans-serif;font-size:7pt;font-weight:800;line-height:12pt;text-align:center;box-shadow:.75pt .75pt 0 var(--print-accent)}.kc-footer{position:absolute;bottom:.06in;right:.22in;font-size:5.5pt;text-transform:uppercase;letter-spacing:.22em;color:var(--print-text);font-weight:700;line-height:1;padding:1pt 4pt;border:.5pt solid var(--print-text);background:var(--print-paper)}}@media not print{#kitchen-card{display:none}#kitchen-card[data-preview=on]{display:block;width:6in;height:4in;margin:1rem auto;box-shadow:0 4px 16px #0000002e}#kitchen-card[data-preview=on] .kc-card{width:100%;height:100%;box-sizing:border-box;padding:.18in .22in;background:#faf2dc;color:#2e2820;border:2pt solid #1a1612;box-shadow:inset 0 0 0 .5pt #b94626,inset 0 0 0 4pt #faf2dc;display:flex;flex-direction:column;gap:6pt;overflow:hidden;font-family:Inter,system-ui,sans-serif;font-size:9pt;line-height:1.35}}#kitchen-card{display:none}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-sans);color:var(--color-fg-default);background-color:var(--color-bg-canvas);background-image:radial-gradient(circle,color-mix(in oklab,var(--color-accent-fg) 4%,transparent) .6px,transparent 1.2px);background-size:6px 6px;background-attachment:fixed;font-size:var(--type-body-size);line-height:var(--type-body-lh);margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent-fg);text-decoration:underline;text-underline-offset:2px}a:hover{color:var(--crust-700)}button{font-family:inherit;font-size:inherit;cursor:pointer}:focus{outline:none}:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px;border-radius:var(--radius-sm)}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}main{max-width:var(--calc-max-width);margin:0 auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-6)}.card{background:var(--color-bg-surface);border-radius:var(--radius-md);padding:var(--space-6)}input[type=number],input[type=search],input[type=text]{height:44px;width:100%;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-canvas);color:var(--color-fg-default);font-family:inherit;font-size:15px}input[type=number]:focus-visible,input[type=search]:focus-visible,input[type=text]:focus-visible{border-color:var(--color-focus-ring)}#results-pane{display:flex;flex-direction:column;gap:var(--space-6)}#site-footer{max-width:var(--calc-max-width);margin:var(--space-12) auto 0;padding:var(--space-6) var(--space-4);border-top:1px solid var(--color-border);color:var(--color-fg-subtle);text-align:center;font-family:var(--font-sans);font-size:12px;line-height:16px;letter-spacing:.24px}#site-footer a{color:var(--color-fg-muted);margin:0 var(--space-2)}@media (min-width: 1024px){main{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);max-width:1180px;align-items:start}#recipe-pane{grid-column:1}#results-pane{grid-column:2}}.recipe-meta-strip{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:flex-start;padding:var(--space-3) var(--space-4);border-bottom:var(--border-rule) solid var(--color-fg-strong);position:relative}.recipe-meta-section-title{flex-basis:100%;margin:0;font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);padding-bottom:var(--space-1);border-bottom:var(--border-hairline) solid var(--color-accent-fg)}.recipe-meta-section-hint{font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);letter-spacing:0;text-transform:none;color:var(--color-fg-muted);font-weight:var(--weight-regular);margin-left:var(--space-1)}@media (max-width: 480px){.recipe-meta-section-hint{display:none}}.recipe-meta-strip:after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:var(--color-accent-fg)}.recipe-meta-control{display:flex;flex-direction:column;gap:var(--space-1)}.recipe-meta-label{font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-muted)}.recipe-meta-course{background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-family:var(--font-sans);font-size:var(--type-small-size);color:var(--color-fg-default)}.recipe-meta-course:focus{outline:none;box-shadow:var(--shadow-stamp)}.segmented{display:inline-flex;border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);overflow:hidden}.segmented button[role=radio]{background:var(--color-bg-canvas);border:none;border-right:var(--border-hairline) solid var(--color-border-strong);padding:var(--space-1) var(--space-3);font-size:var(--type-small-size);font-weight:var(--weight-semibold);color:var(--color-fg-default);cursor:pointer}.segmented button[role=radio]:last-child{border-right:none}.segmented button[role=radio].is-on,.segmented button[role=radio][aria-checked=true]{background-color:var(--color-accent-fg);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent)}.recipe-meta-clear{background:transparent;border:none;font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;color:var(--color-fg-muted);cursor:pointer;padding:var(--space-1);margin-top:var(--space-1)}.recipe-meta-clear:hover{color:var(--color-accent-fg)}.rm-target-set,.rm-target-current,.rm-target-stop,.rm-target-done{background:transparent;border:none;font-family:var(--font-sans);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-accent-fg);cursor:pointer;padding:var(--space-1) var(--space-1) 0;margin-top:var(--space-1);text-align:left}.rm-target-set:hover,.rm-target-current:hover,.rm-target-stop:hover,.rm-target-done:hover{color:var(--color-accent-deep);text-decoration:underline}.rm-target-current{font-weight:var(--weight-black);text-transform:none;letter-spacing:0;font-size:var(--type-small-size);color:var(--color-fg-strong);font-variant-numeric:tabular-nums}.rm-target-stop{margin-left:var(--space-1);color:var(--color-fg-muted)}.rm-target-stop:hover{color:var(--color-accent-fg)}.rm-target-input{background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-accent-fg);border-radius:var(--radius-sm);padding:2px var(--space-2);font-family:var(--font-sans);font-size:var(--type-small-size);font-variant-numeric:tabular-nums;font-weight:var(--weight-semibold);color:var(--color-fg-strong);width:80px;margin-top:var(--space-1);box-shadow:var(--shadow-stamp)}.rm-target-input:focus{outline:none}.recipe-meta-details{margin-top:var(--space-4);color:var(--color-fg-default)}.recipe-meta-details summary{cursor:pointer;font-weight:500}.recipe-meta-extended{display:flex;flex-direction:column;gap:var(--space-1);margin:var(--space-2) 0}.recipe-meta-extended-notes{width:100%;resize:vertical;min-height:6rem;color:var(--color-fg-default);background:var(--color-bg-canvas);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2)}.bake-hints-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:var(--space-1)}.bake-hints-list li{display:flex;gap:var(--space-2);align-items:center}.bake-hints-list input[type=text]{flex:1;color:var(--color-fg-default);background:var(--color-bg-canvas);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 6px}.bake-hint-add,.bake-hint-remove{font-size:.8125rem;color:var(--color-fg-muted);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 8px;cursor:pointer}.bake-hint-add:hover,.bake-hint-remove:hover{background:var(--color-bg-muted);color:var(--color-fg-default)}.recipe-meta-intent{border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);background:var(--color-bg-surface)}.recipe-meta-intent[data-state=set]{border-color:var(--color-accent-fg);box-shadow:var(--shadow-stamp)}.recipe-meta-intent>summary{cursor:pointer;user-select:none;font-family:var(--font-sans);font-weight:var(--weight-bold);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;padding:var(--space-1) 0;color:var(--color-fg-strong)}.recipe-meta-intent[data-state=unset] .intent-chip{display:none}.recipe-meta-intent[data-state=set] .intent-chip{font-weight:var(--weight-medium);font-size:var(--type-small-size);letter-spacing:0;text-transform:none;color:var(--color-accent-fg);margin-left:var(--space-2);font-family:var(--font-editorial);font-style:italic}.recipe-meta-intent .intent-controls{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) 0 var(--space-1)}.recommendation-strip{padding:var(--space-3) var(--space-4);background:var(--color-bg-surface);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);margin:var(--space-3) var(--space-4)}.recommendation-empty{padding:var(--space-3) var(--space-4);font-style:italic;color:var(--color-fg-muted);font-family:var(--font-editorial)}.rec-top3{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-2)}.rec-top3 .rec-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.rec-top3 .rec-rank{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background-color:var(--color-fg-strong);background-image:var(--pattern-benday);background-size:var(--pattern-benday-size);color:var(--color-fg-on-accent);font-family:var(--font-sans);font-size:var(--type-small-size);font-weight:var(--weight-black);font-variant-numeric:tabular-nums;box-shadow:1px 1px 0 var(--color-accent-fg)}.rec-top3 .rec-row-1 .rec-rank{background-color:var(--color-accent-fg)}.rec-top3 .rec-name{font-family:var(--font-editorial);font-weight:var(--weight-bold);font-size:var(--type-body-size);color:var(--color-fg-strong)}.rec-top3 .rec-row-2 .rec-name,.rec-top3 .rec-row-3 .rec-name{font-weight:var(--weight-semibold);color:var(--color-fg-default)}.rec-top3 .rec-branch{flex:1 1 auto;font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);color:var(--color-fg-muted)}.rec-top3 .rec-use{flex:0 0 auto;background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:2px var(--space-2);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);cursor:pointer}.rec-top3 .rec-use:hover{background:var(--color-accent-fg);color:var(--color-fg-on-accent);box-shadow:var(--shadow-stamp)}.rec-top3 .rec-user-marker{flex:0 0 auto;font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);color:var(--color-accent-fg);font-weight:var(--weight-semibold)}.rec-user-pick{margin:0;font-family:var(--font-editorial);font-style:italic;font-size:var(--type-small-size);color:var(--color-fg-muted);padding:var(--space-1) var(--space-2)}.rec-see-all{background:var(--color-bg-canvas);border:var(--border-hairline) solid var(--color-border-strong);border-radius:var(--radius-sm);padding:2px var(--space-2);font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold);color:var(--color-fg-strong);cursor:pointer}.rec-see-all:hover{background:var(--color-accent-fg);color:var(--color-fg-on-accent);box-shadow:var(--shadow-stamp)}.recommendation-table{width:100%;border-collapse:collapse;margin-top:var(--space-2);border:var(--border-hairline) solid var(--color-border-strong)}.recommendation-table thead th{background:var(--color-accent-fg);color:var(--color-fg-on-accent);padding:var(--space-1) var(--space-2);text-align:left;font-size:var(--type-eyebrow-size);letter-spacing:var(--type-eyebrow-tracking);text-transform:uppercase;font-weight:var(--weight-bold)}.recommendation-table tr.rec-row td{padding:var(--space-1) var(--space-2);font-size:var(--type-small-size);border-bottom:var(--border-hairline) solid var(--color-border)}.recommendation-table tr.rec-row:nth-child(2n) td{background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size)}.recommendation-table tr.rec-row[data-eligible=false] td{opacity:.6;font-style:italic}.recommendation-table .rec-row-expand{background:none;border:none;cursor:pointer;font-size:var(--type-body-size);color:var(--color-accent-fg);padding:0 var(--space-1)}.recommendation-table .rec-row-detail>td{background:var(--color-bg-deep);background-image:var(--pattern-benday-soft);background-size:var(--pattern-benday-size);padding:var(--space-2) var(--space-3);border-bottom:var(--border-hairline) solid var(--color-fg-strong)}.recommendation-table .rec-row-notes{margin:0 0 var(--space-2);font-family:var(--font-editorial);font-size:var(--type-small-size);color:var(--color-fg-default);line-height:1.4}.recommendation-table .rec-row-fingerprint{margin:0;padding-left:var(--space-4);font-size:var(--type-small-size);color:var(--color-fg-muted)}.recommendation-table .rec-row-fingerprint li{line-height:1.45}@media (max-width: 720px){.recipe-meta-intent .intent-controls{gap:var(--space-3)}.rec-top3 .rec-branch{display:block;flex-basis:100%}.recommendation-table th:last-child{display:none}.recommendation-table td:last-child{display:inline-block;padding-left:var(--space-2);border:none;vertical-align:middle}}.section-divider{position:relative;height:0;border-top:var(--border-hairline) solid var(--color-fg-strong);margin:var(--space-6) 0 calc(var(--space-6) + 2px)}.section-divider:after{content:"";position:absolute;left:0;right:0;top:1px;height:.5px;background:var(--color-accent-fg)}
