.base-button[data-v-8482b29f]{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 22px;border:0;border-radius:var(--radius-button);font-family:DM Sans,system-ui;font-size:.95rem;font-weight:800;letter-spacing:0;cursor:pointer;transition:background .18s ease,box-shadow .18s ease,color .18s ease,transform .18s var(--ease-out)}.base-button[data-v-8482b29f]:disabled{cursor:not-allowed;opacity:.62}.base-button--solid[data-v-8482b29f]{color:var(--color-panel);background:linear-gradient(180deg,#3a8a64,var(--color-accent) 78%),var(--color-accent);box-shadow:inset 0 1px #ffffff2e,0 18px 40px -12px #26745180}.base-button--soft[data-v-8482b29f]{color:var(--color-ink);background:var(--color-panel);box-shadow:inset 0 0 0 1px #0f24181a,0 10px 24px -16px #0f24182e}.base-button--danger[data-v-8482b29f]{color:var(--color-danger);background:var(--color-panel);box-shadow:inset 0 0 0 1px #a33d3d2e,0 10px 24px -16px #0f24182e}.base-button[data-v-8482b29f]:active{transform:scale(.97)}@media(hover:hover)and (pointer:fine){.base-button[data-v-8482b29f]:not(:disabled):hover{transform:translateY(-1px)}.base-button--solid[data-v-8482b29f]:not(:disabled):hover{box-shadow:inset 0 1px #fff3,0 22px 50px -12px #2674518c}.base-button--soft[data-v-8482b29f]:not(:disabled):hover{background:var(--color-soft-2)}.base-button--danger[data-v-8482b29f]:not(:disabled):hover{background:#a33d3d14}}.base-input[data-v-9e33ef51]{display:grid;gap:8px;color:var(--color-ink);font-family:DM Sans,system-ui;font-size:.88rem;font-weight:700;letter-spacing:0}.base-input input[data-v-9e33ef51]{width:100%;min-height:50px;border:1px solid rgb(15 36 24 / .1);border-radius:16px;padding:0 16px;color:var(--color-ink);background:var(--color-soft);font-family:DM Sans,system-ui;font-size:.96rem;outline:none;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.base-input input[data-v-9e33ef51]:focus{border-color:var(--color-accent);background:var(--color-panel);box-shadow:0 0 0 4px #26745129}.base-input input[data-v-9e33ef51]::placeholder{color:var(--color-muted);font-weight:500}.page{width:min(1240px,calc(100% - 32px));margin:0 auto;padding:32px 0 64px}.page>*{opacity:1;visibility:visible}.page--welcome{height:calc(100dvh - 76px);width:100%;padding:0;overflow:hidden}body.is-welcome-page{height:100dvh;overflow:hidden}body.is-welcome-page #app,body.is-welcome-page .app-shell{height:100dvh;min-height:100dvh;overflow:hidden}@media(max-width:820px){.page{width:min(100% - 24px,720px);padding-top:16px}.page--welcome{height:calc(100dvh - 66px);width:100%;padding:0}}.auth-backdrop{position:fixed;inset:0;z-index:999;background:radial-gradient(circle at var(--blendy-backdrop-x, 50%) var(--blendy-backdrop-y, 50%),rgb(38 116 81 / .2),transparent 34%),#0f24185c;-webkit-backdrop-filter:blur(16px) saturate(120%);backdrop-filter:blur(16px) saturate(120%);animation:auth-fade-in .28s var(--ease-out) forwards}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}.auth-blendy-target{position:fixed;right:auto;bottom:auto;height:fit-content;z-index:1000;transform-origin:var(--blendy-origin-x, 50%) var(--blendy-origin-y, 50%);will-change:transform}.auth-modal-card{position:relative;display:grid;gap:10px;width:100%;max-height:inherit;overflow:auto;padding:40px 36px 36px;border:1px solid rgb(15 36 24 / .08);border-radius:30px;background:linear-gradient(150deg,#fefdf8fa,#ecf0e2f5),var(--color-panel);box-shadow:0 0 0 1px #ffffff14,0 48px 120px -20px #0f241859,0 20px 50px -15px #2674512e;transform-origin:var(--blendy-origin-x, 50%) var(--blendy-origin-y, 50%);will-change:transform,opacity}.auth-modal-card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(ellipse at 20% -10%,rgb(255 255 255 / .7),transparent 55%);mix-blend-mode:lighten}.auth-modal-close{position:absolute;top:16px;right:16px;display:grid;place-items:center;width:44px;height:44px;border:1px solid rgb(15 36 24 / .08);border-radius:50%;color:var(--color-muted);background:#fefdf8b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:transform .18s var(--ease-out),color .18s ease,background .18s ease;z-index:2}.auth-modal-close:hover{color:var(--color-accent-strong);background:var(--color-accent-soft);transform:scale(1.05)}.auth-modal-close:active{transform:scale(.9)}.auth-modal-eyebrow{margin:0;color:var(--color-accent);font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}.auth-modal-title{margin:0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(2rem,4.5vw,2.8rem);font-weight:700;line-height:.95;letter-spacing:-.03em;color:var(--color-ink)}.auth-modal-hint{margin:4px 0 8px;color:var(--color-muted);font-size:.95rem;line-height:1.5;max-width:38ch}@media(max-width:600px){.auth-modal-card{padding:32px 24px 28px;border-radius:24px}}:root{color-scheme:light;font-family:DM Sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-ink);background:var(--color-soft);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01" on,"cv11" on;--color-ink: #0f2418;--color-ink-soft: #1b3a2a;--color-muted: #56665b;--color-soft: #f4f1e8;--color-soft-2: #ebe7d8;--color-panel: #fefdf8;--color-line: #d8d4c2;--color-accent: #267451;--color-accent-strong: #155c3c;--color-accent-soft: rgb(38 116 81 / .12);--color-amber: #c2873a;--color-amber-soft: rgb(194 135 58 / .16);--color-danger: #a33d3d;--shadow-soft: 0 30px 80px -20px rgb(15 36 24 / .18);--shadow-card: 0 18px 40px -16px rgb(15 36 24 / .14);--shadow-pop: 0 38px 100px -10px rgb(15 36 24 / .32);--radius-card: 28px;--radius-button: 999px;--radius-pill: 14px;--ease-out: cubic-bezier(.23, 1, .32, 1);--ease-in-out: cubic-bezier(.77, 0, .175, 1);--ease-elastic: cubic-bezier(.38, .49, 0, 1)}*{box-sizing:border-box}html{min-width:320px;background:var(--color-soft);overflow-x:hidden}body{min-width:320px;min-height:100dvh;margin:0;font-family:inherit;overflow-x:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0;background:transparent;color:inherit;-webkit-tap-highlight-color:transparent}button:disabled,input:disabled,textarea:disabled{cursor:not-allowed;opacity:.65}a{color:inherit;text-decoration:none}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid rgb(38 116 81 / .34);outline-offset:3px}input,textarea{font-family:inherit}#app{min-height:100dvh}::selection{color:var(--color-panel);background:var(--color-accent)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.pill-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 22px;border:0;border-radius:var(--radius-button);color:var(--color-panel);background:linear-gradient(180deg,#3a8a64,var(--color-accent) 78%),var(--color-accent);font-family:DM Sans,system-ui;font-weight:700;font-size:.95rem;letter-spacing:-.01em;box-shadow:inset 0 1px #ffffff2e,0 18px 40px -12px #26745180;cursor:pointer;transition:transform .18s var(--ease-out),box-shadow .18s ease,background .18s ease}.pill-button:active{transform:scale(.96);transition-duration:.12s}.pill-button--light{color:var(--color-ink);background:var(--color-panel);box-shadow:inset 0 0 0 1px #0f24181a,0 10px 24px -16px #0f24182e}@media(hover:hover)and (pointer:fine){.pill-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:inset 0 1px #fff3,0 22px 50px -12px #2674518c}.pill-button--light:hover{transform:translateY(-3px) scale(1.02);background:var(--color-soft-2);box-shadow:inset 0 0 0 1px #2674511f,0 14px 34px -16px #0f241838}}.workspace__label{color:var(--color-accent-strong);font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin:0 0 8px}.app-shell{min-height:100dvh;background:radial-gradient(circle at 12% 0%,rgb(194 135 58 / .18),transparent 38%),radial-gradient(circle at 92% 14%,rgb(38 116 81 / .16),transparent 42%),radial-gradient(circle at 50% 100%,rgb(15 36 24 / .06),transparent 60%),linear-gradient(180deg,#faf6e8 0%,var(--color-soft) 48%,#ecf0e2 100%);background-attachment:fixed}.app-header{position:sticky;top:0;z-index:20;width:min(1240px,calc(100% - 32px));min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 auto;padding:12px 0}.brand,.nav__item,.header-action{border:0;border-radius:var(--radius-button);transition:transform .28s cubic-bezier(.34,1.56,.64,1),color .22s ease,background .22s ease,box-shadow .22s ease;will-change:transform}.brand,.nav__item,.header-action{min-width:0}.brand{display:inline-flex;gap:12px;align-items:center;justify-self:start;min-width:0;padding:6px 18px 6px 6px;color:var(--color-ink);background:#fefdf8b8;text-align:left;font-family:Bricolage Grotesque,system-ui;font-weight:600;letter-spacing:-.02em;box-shadow:inset 0 0 0 1px #0f24180f,0 14px 40px -20px #0f24182e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand__mark{width:40px;height:40px;display:grid;flex:0 0 auto;place-items:center;border-radius:14px;color:var(--color-panel);background:radial-gradient(circle at 30% 30%,#3a8a64,var(--color-accent) 70%),var(--color-accent);font-family:Bricolage Grotesque,system-ui;font-weight:800;font-size:1.1rem;box-shadow:inset 0 1px #fff3,0 8px 20px -8px #26745180}.brand strong,.brand small{display:block;line-height:1.05;letter-spacing:-.02em}.brand strong{font-size:1.05rem;font-weight:700}.brand small{margin-top:2px;color:var(--color-muted);font-family:DM Sans,system-ui;font-size:.74rem;font-weight:500;letter-spacing:0}.nav{display:inline-flex;gap:4px;justify-self:center;padding:5px;border:1px solid rgb(15 36 24 / .06);border-radius:var(--radius-button);background:#fefdf8b3;box-shadow:0 14px 40px -20px #0f24182e;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav__item{min-height:40px;padding:0 18px;color:var(--color-muted);background:transparent;font-family:DM Sans,system-ui;font-weight:600;font-size:.92rem;letter-spacing:-.005em}.nav__item--active{color:var(--color-panel);background:var(--color-ink);box-shadow:inset 0 1px #ffffff1a,0 8px 18px -8px #0f241880}.header-actions{display:inline-flex;justify-self:end;align-items:center;gap:8px}.header-action{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;min-height:44px;padding:0 22px;color:var(--color-panel);background:linear-gradient(180deg,#3a8a64,var(--color-accent) 78%),var(--color-accent);font-family:DM Sans,system-ui;font-weight:700;font-size:.9rem;letter-spacing:-.01em;box-shadow:inset 0 1px #ffffff2e,0 14px 30px -10px #2674518c}.header-action--ghost{color:var(--color-ink);background:var(--color-panel);box-shadow:inset 0 0 0 1px #0f24181a,0 10px 24px -16px #0f24182e}.brand:active,.nav__item:active,.header-action:active{transform:scale(.97)}@media(hover:hover)and (pointer:fine){.brand:hover{transform:translateY(-2px) scale(1.02);box-shadow:inset 0 0 0 1px #0f241814,0 18px 44px -20px #0f241840}.nav__item:not(.nav__item--active):hover{color:var(--color-ink);background:#0f24180f;transform:translateY(-1px)}.header-action:hover{transform:translateY(-2px) scale(1.02);box-shadow:inset 0 1px #fff3,0 20px 48px -12px #26745199}.header-action--ghost:hover{transform:translateY(-2px) scale(1.02);box-shadow:inset 0 0 0 1px #26745126,0 14px 34px -16px #0f241838}}@media(max-width:820px){.app-header{position:static;width:min(100% - 24px,720px);grid-template-columns:1fr;justify-items:stretch;padding-top:12px}.brand,.nav,.header-actions{justify-self:stretch}.header-actions,.header-action,.nav{width:100%}.nav__item{flex:1;min-width:0;padding-inline:12px}}@media(max-width:820px){body.is-welcome-page .app-header{min-height:66px;grid-template-columns:1fr auto;gap:10px;padding-block:8px}body.is-welcome-page .brand{justify-self:start;padding-right:12px}body.is-welcome-page .brand small,body.is-welcome-page .nav{display:none}body.is-welcome-page .header-actions{justify-self:end;width:auto}body.is-welcome-page .header-action{width:auto;min-height:40px;padding-inline:16px}}@media(max-width:520px){body.is-welcome-page .header-action{display:none}}@media(max-width:420px){.brand{padding-right:12px}.brand__mark{width:36px;height:36px;border-radius:12px}.brand strong{font-size:.98rem}.nav{gap:3px;padding:4px}.nav__item{min-height:38px;padding-inline:8px;font-size:.84rem}}.auth-panel{display:grid;gap:20px;margin-top:12px}.auth-panel__copy{display:none}.auth-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:5px;border:1px solid rgb(15 36 24 / .08);border-radius:var(--radius-button);background:var(--color-soft)}.auth-tabs__button{min-height:44px;border:0;border-radius:var(--radius-button);color:var(--color-muted);background:transparent;font-family:DM Sans,system-ui;font-weight:600;font-size:.9rem;letter-spacing:-.005em;transition:transform .16s var(--ease-out),color .18s ease,background .18s ease}.auth-tabs__button--active{color:var(--color-panel);background:var(--color-ink);box-shadow:inset 0 1px #ffffff1a,0 8px 18px -8px #0f241866}.auth-tabs__button:active{transform:scale(.97)}.auth-form{display:grid;gap:14px}.auth-form label{display:grid;gap:8px;color:var(--color-ink);font-family:DM Sans,system-ui;font-weight:600;font-size:.88rem;letter-spacing:-.005em}.auth-form span{font-size:.88rem}.auth-form input{width:100%;min-height:50px;border:1px solid rgb(15 36 24 / .1);border-radius:16px;padding:0 16px;color:var(--color-ink);background:var(--color-soft);font-family:DM Sans,system-ui;font-size:.96rem;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.auth-form input:focus{border-color:var(--color-accent);background:var(--color-panel);box-shadow:0 0 0 4px #26745129}.auth-form input::placeholder{color:var(--color-muted);font-weight:500}.form-message{margin:0;border-radius:14px;padding:12px 14px;font-family:DM Sans,system-ui;font-weight:600;font-size:.9rem;line-height:1.4}.form-message--error{color:var(--color-danger);background:#a33d3d1a}.form-message--success{color:var(--color-accent-strong);background:var(--color-accent-soft)}.auth-form__submit{width:100%;min-height:52px;margin-top:6px;border:0;border-radius:var(--radius-button);color:var(--color-panel);background:linear-gradient(180deg,#3a8a64,var(--color-accent) 78%),var(--color-accent);font-family:DM Sans,system-ui;font-weight:700;font-size:.98rem;letter-spacing:-.01em;box-shadow:inset 0 1px #ffffff2e,0 18px 40px -12px #2674518c;transition:transform .18s var(--ease-out),box-shadow .18s ease}.auth-form__submit:active{transform:scale(.97)}@media(hover:hover)and (pointer:fine){.auth-tabs__button:not(.auth-tabs__button--active):hover{color:var(--color-ink);background:#0f24180f}.auth-form__submit:hover{transform:translateY(-1px);box-shadow:inset 0 1px #fff3,0 24px 50px -12px #26745199}}.inventory-panel{display:grid;gap:28px}.inventory-panel__header{display:flex;gap:16px;align-items:end;justify-content:space-between}.inventory-panel__header h2{margin:0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(2.4rem,5vw,4.4rem);font-weight:700;line-height:.95;letter-spacing:-.03em}.inventory-panel__header p{margin:0 0 8px;color:var(--color-accent);font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}.inventory-count{flex:0 0 auto;border:1px solid rgb(15 36 24 / .08);border-radius:var(--radius-button);padding:10px 16px;color:var(--color-accent-strong);background:var(--color-panel);font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:600;letter-spacing:.04em;box-shadow:0 10px 24px -16px #0f24182e}.ingredient-form{display:grid;grid-template-columns:minmax(180px,1.6fr) minmax(120px,.7fr) minmax(120px,.7fr) auto auto;gap:12px;align-items:end;border:1px solid rgb(15 36 24 / .08);border-radius:28px;padding:22px;background:linear-gradient(160deg,#fefdf8f5,#f4f1e8eb),var(--color-panel);box-shadow:var(--shadow-card)}.ingredient-form label{display:grid;gap:8px;color:var(--color-ink);font-family:DM Sans,system-ui;font-weight:600;font-size:.88rem;letter-spacing:-.005em}.ingredient-form input{min-height:50px;width:100%;border:1px solid rgb(15 36 24 / .1);border-radius:16px;padding:0 16px;color:var(--color-ink);background:var(--color-soft);font-family:DM Sans,system-ui;font-size:.96rem;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.ingredient-form input:focus{border-color:var(--color-accent);background:var(--color-panel);box-shadow:0 0 0 4px #26745129}.ingredient-form input::placeholder{color:var(--color-muted);font-weight:500}.ingredient-form__button{min-width:max-content}.inventory-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.ingredient-card{min-height:160px;display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:14px;border:1px solid rgb(15 36 24 / .08);border-radius:24px;padding:20px;background:var(--color-panel);box-shadow:var(--shadow-card);transition:transform .2s var(--ease-out),box-shadow .2s ease;will-change:transform,box-shadow}.ingredient-card strong{font-family:Bricolage Grotesque,system-ui;font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:700;line-height:1;letter-spacing:-.025em;color:var(--color-ink)}.ingredient-card__actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px}.ingredient-card__actions button{min-height:38px;border:1px solid rgb(15 36 24 / .1);border-radius:var(--radius-button);padding:0 14px;color:var(--color-ink);background:var(--color-panel);font-family:DM Sans,system-ui;font-weight:600;font-size:.84rem;transition:transform .16s var(--ease-out),border-color .18s ease,color .18s ease,background .18s ease}.ingredient-card__actions button:last-child{color:var(--color-danger)}.ingredient-card__actions button:active{transform:scale(.96)}.ingredient-card--skeleton span,.ingredient-card--skeleton strong,.ingredient-card--skeleton div{min-height:18px;border-radius:var(--radius-button);background:linear-gradient(90deg,#ebe7d8,#f4f1e8,#ebe7d8);background-size:200% 100%;animation:skeleton-shift 1.2s linear infinite}.ingredient-card--skeleton strong{min-height:42px}.inventory-empty{position:relative;display:grid;justify-items:center;gap:14px;overflow:hidden;border:1px dashed rgb(38 116 81 / .32);border-radius:24px;padding:36px;background:radial-gradient(circle at 50% 0%,rgb(38 116 81 / .13),transparent 42%),#fefdf8c7;text-align:center}.inventory-empty__mark{position:relative;width:112px;height:72px;margin-bottom:4px}.inventory-empty__mark span{position:absolute;inset:auto auto 0 50%;width:42px;height:58px;border:1px solid rgb(15 36 24 / .1);border-radius:16px 16px 22px 22px;background:linear-gradient(180deg,#fefdf8f5,#ecf0e2e6),var(--color-panel);box-shadow:0 18px 40px -22px #0f241852;transform-origin:50% 100%}.inventory-empty__mark span:nth-child(1){transform:translate(-62px) rotate(-11deg)}.inventory-empty__mark span:nth-child(2){height:68px;transform:translate(-21px)}.inventory-empty__mark span:nth-child(3){transform:translate(20px) rotate(10deg)}.inventory-empty h3{margin:0 0 8px;font-family:Bricolage Grotesque,system-ui;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;line-height:1;letter-spacing:-.025em}.inventory-empty>p:not(.workspace__label){max-width:50ch;margin:0 auto;color:var(--color-muted);line-height:1.6}.inventory-empty .base-button{margin-top:4px}@media(hover:hover)and (pointer:fine){.ingredient-card:hover{transform:translateY(-2px);box-shadow:0 24px 50px -16px #0f24182e}.ingredient-card__actions button:hover{border-color:#2674514d;color:var(--color-accent-strong);background:var(--color-accent-soft)}.ingredient-card__actions button:last-child:hover{border-color:#a33d3d4d;color:var(--color-danger)}}@media(max-width:980px){.ingredient-form{grid-template-columns:1fr 1fr}.ingredient-form label:first-child{grid-column:1 / -1}}@media(max-width:820px){.inventory-panel__header{align-items:start;flex-direction:column}.inventory-grid{grid-template-columns:1fr}}@media(max-width:560px){.ingredient-form{grid-template-columns:1fr;padding:16px}.ingredient-form__button{width:100%}}.base-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f241880;opacity:1;transition:opacity .3s ease;will-change:opacity}.base-modal.is-closing{opacity:0}.base-modal__card{position:relative;width:min(560px,100%);max-width:560px;overflow:hidden;border:1px solid rgb(15 36 24 / .08);border-radius:32px;background:linear-gradient(160deg,#fefdf8fa,#f4f1e8f0),var(--color-panel);box-shadow:var(--shadow-pop);transform:scale(.96) translateY(8px);opacity:0;transition:transform .35s cubic-bezier(.23,1,.32,1),opacity .3s ease;will-change:transform,opacity}.base-modal:not(.is-closing) .base-modal__card{transform:scale(1) translateY(0);opacity:1}.base-modal.is-closing .base-modal__card{transform:scale(.96) translateY(8px);opacity:0;transition:transform .28s ease-in,opacity .25s ease}.base-modal__close{width:44px;height:44px;display:grid;flex:0 0 auto;place-items:center;border:1px solid rgb(15 36 24 / .1);border-radius:50%;color:var(--color-ink);background:var(--color-panel);font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:700;line-height:1;transition:transform .2s ease,color .18s ease,border-color .18s ease,background .18s ease;will-change:transform}.base-modal__close:active{transform:scale(.92);transition-duration:.1s}@media(prefers-reduced-motion:reduce){.base-modal,.base-modal__card{transition:none!important;transform:none!important;opacity:1!important}}.base-modal[open]{opacity:1;visibility:visible;transition:opacity .32s cubic-bezier(.23,1,.32,1),visibility 0ms 0ms}.base-modal::backdrop{background:#0f24188c;opacity:0;transition:opacity .32s cubic-bezier(.23,1,.32,1)}.base-modal[open]::backdrop{opacity:1}.base-modal__card{position:relative;overflow:hidden;border:1px solid rgb(15 36 24 / .08);border-radius:32px;background:linear-gradient(160deg,#fefdf8fa,#f4f1e8f0),var(--color-panel);box-shadow:var(--shadow-pop);transform-origin:center;transform:scale(.94) translateY(12px);opacity:0;transition:transform .42s cubic-bezier(.34,1.56,.64,1),opacity .32s cubic-bezier(.23,1,.32,1);will-change:transform,opacity}.base-modal[open] .base-modal__card{transform:scale(1) translateY(0);opacity:1}.base-modal__card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(circle at 20% 0%,rgb(255 255 255 / .7),transparent 50%);mix-blend-mode:lighten}.base-modal__surface{position:relative;border-radius:inherit}.base-modal__header{display:flex;gap:18px;align-items:start;justify-content:space-between;padding:28px 28px 0}.base-modal__header h2{margin:0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(2rem,4vw,2.6rem);font-weight:700;line-height:.95;letter-spacing:-.025em;color:var(--color-ink)}.base-modal__close{width:44px;height:44px;display:grid;flex:0 0 auto;place-items:center;border:1px solid rgb(15 36 24 / .1);border-radius:50%;color:var(--color-ink);background:var(--color-panel);font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:700;line-height:1;transition:transform .28s cubic-bezier(.34,1.56,.64,1),color .18s ease,border-color .18s ease,background .18s ease;will-change:transform}.base-modal__close:active{transform:scale(.92);transition-duration:.12s}.base-modal__body{padding:18px 28px 28px;color:var(--color-ink-soft);font-family:DM Sans,system-ui;line-height:1.6}.modal-flow{display:grid;gap:10px;margin:0;padding:0;list-style:none}.modal-flow li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;padding:14px 16px;color:var(--color-ink);background:var(--color-soft);border:1px solid rgb(15 36 24 / .06);border-radius:18px;font-weight:600;font-size:.95rem;letter-spacing:-.005em}.modal-flow span{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;color:var(--color-panel);background:linear-gradient(180deg,#3a8a64,var(--color-accent) 80%),var(--color-accent);font-family:Bricolage Grotesque,system-ui;font-size:.95rem;font-weight:700;box-shadow:inset 0 1px #fff3,0 8px 18px -8px #26745180}@media(hover:hover)and (pointer:fine){.base-modal__close:hover{color:var(--color-accent-strong);border-color:#2674514d;background:var(--color-accent-soft);transform:scale(1.05)}}@media(prefers-reduced-motion:reduce){.base-modal,.base-modal::backdrop,.base-modal__card{transition:none!important;transform:none!important;opacity:1!important;visibility:visible!important}}.inventory-stack{display:grid;gap:32px}.recipe-generator{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:end;border:1px solid rgb(15 36 24 / .08);border-radius:32px;padding:28px;background:linear-gradient(140deg,#2674511a,#fefdf8f2 60%),var(--color-panel);box-shadow:var(--shadow-card)}.recipe-generator__copy h2{max-width:14ch;margin:0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:.95;letter-spacing:-.03em}.recipe-generator__copy p{margin:0 0 8px;color:var(--color-accent-strong);font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}.recipe-generator__copy p:last-child{max-width:54ch;margin-top:12px;color:var(--color-ink-soft);font-family:DM Sans,system-ui;font-size:.98rem;line-height:1.55;text-transform:none;letter-spacing:-.005em}.recipe-generator__action{display:grid;gap:10px;justify-items:end}.recipe-generator__action small{color:var(--color-muted);font-family:DM Sans,system-ui;font-weight:500;font-size:.82rem}.recipe-generator>.form-message{grid-column:1 / -1}.recipe-card{grid-column:1 / -1;display:grid;gap:22px;border:1px solid rgb(15 36 24 / .08);border-radius:24px;padding:24px;background:var(--color-panel);box-shadow:var(--shadow-card)}.recipe-card__header{display:flex;gap:16px;align-items:start;justify-content:space-between}.recipe-card__header span,.recipe-card__header strong{width:fit-content;border-radius:var(--radius-button);padding:7px 12px;color:var(--color-accent-strong);background:var(--color-accent-soft);font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.recipe-card__header h3{margin:12px 0 0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;line-height:.98;letter-spacing:-.03em;color:var(--color-ink)}.recipe-card__grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:20px}.recipe-card h4{margin:0 0 10px;font-family:Bricolage Grotesque,system-ui;font-size:1.05rem;font-weight:700;letter-spacing:-.02em;color:var(--color-ink)}.recipe-card ul,.recipe-card ol{display:grid;gap:8px;margin:0;padding:0;list-style:none;color:var(--color-ink-soft);font-family:DM Sans,system-ui;font-size:.92rem;line-height:1.5}.recipe-card--loading span,.recipe-card--loading strong,.recipe-card--loading p{min-height:18px;margin:0;border-radius:var(--radius-button);background:linear-gradient(90deg,#ebe7d8,#f4f1e8,#ebe7d8);background-size:200% 100%;animation:skeleton-shift 1.2s linear infinite}.recipe-card--loading strong{min-height:44px}.recipe-card__loading-steps{display:grid;gap:8px;margin:0;padding:0;list-style:none}.recipe-card__loading-steps li{width:fit-content;border-radius:var(--radius-button);padding:7px 12px;color:var(--color-muted);background:#0f24180f;font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:700;letter-spacing:.04em}.recipe-card--generated{border-color:#26745129;background:linear-gradient(145deg,#fefdf8fa,#ecf0e2e6),var(--color-panel)}.history-panel{display:grid;gap:28px}.history-panel__header{display:flex;gap:16px;align-items:end;justify-content:space-between}.history-panel__header h2{margin:0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(2.4rem,5vw,4.4rem);font-weight:700;line-height:.95;letter-spacing:-.03em}.history-panel__header p{margin:0 0 8px;color:var(--color-accent);font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}.history-filters{display:grid;grid-template-columns:minmax(220px,.9fr) minmax(0,1.1fr);gap:14px;align-items:end;border:1px solid rgb(15 36 24 / .08);border-radius:24px;padding:16px;background:#fefdf8b8;box-shadow:0 16px 42px -28px #0f24183d}.history-filter-group{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.history-filter{min-height:42px;border:1px solid rgb(15 36 24 / .1);border-radius:var(--radius-button);padding:0 16px;color:var(--color-muted);background:var(--color-panel);font-family:DM Sans,system-ui;font-size:.86rem;font-weight:800;letter-spacing:0;transition:background .18s ease,border-color .18s ease,color .18s ease,transform .16s var(--ease-out)}.history-filter--active{border-color:var(--color-ink);color:var(--color-panel);background:var(--color-ink);box-shadow:inset 0 1px #ffffff1a,0 10px 22px -12px #0f241870}.history-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.history-card{display:grid;gap:18px;border:1px solid rgb(15 36 24 / .08);border-radius:28px;padding:24px;background:var(--color-panel);box-shadow:var(--shadow-card);transform-origin:top center;transition:transform .24s var(--ease-out),box-shadow .24s ease,border-color .24s ease}.history-card--openable{cursor:pointer}.history-card--openable:active{transform:scale(.985)}.history-card header,.history-card footer{display:flex;gap:14px;align-items:start;justify-content:space-between}.history-card header span,.history-card header strong{width:fit-content;border-radius:var(--radius-button);padding:6px 12px;color:var(--color-accent-strong);background:var(--color-accent-soft);font-family:JetBrains Mono,monospace;font-size:.74rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.history-card h3{margin:12px 0 0;font-family:Bricolage Grotesque,system-ui;font-size:clamp(1.5rem,3vw,2rem);font-weight:700;line-height:.98;letter-spacing:-.03em;color:var(--color-ink)}.history-card__section h4{margin:0 0 8px;font-family:Bricolage Grotesque,system-ui;font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--color-ink)}.history-card__section ul,.history-card__section ol{display:grid;gap:6px;margin:0;padding-left:22px;color:var(--color-muted);font-size:.9rem;line-height:1.5}.rating-row{display:flex;gap:6px}.rating-row button,.history-card__delete{min-height:38px;border:1px solid rgb(15 36 24 / .1);border-radius:var(--radius-button);color:var(--color-ink);background:var(--color-panel);font-family:DM Sans,system-ui;font-weight:600;font-size:.85rem;transition:transform .16s var(--ease-out),border-color .18s ease,color .18s ease,background .18s ease}.rating-row button{width:38px}.history-card__delete{padding:0 16px;color:var(--color-danger)}.rating-row button:active,.history-card__delete:active{transform:scale(.95)}.history-card--loading span,.history-card--loading strong,.history-card--loading p{min-height:18px;margin:0;border-radius:var(--radius-button);background:linear-gradient(90deg,#ebe7d8,#f4f1e8,#ebe7d8);background-size:200% 100%;animation:skeleton-shift 1.2s linear infinite}.history-card--loading strong{min-height:52px}.history-empty-filtered{display:grid;justify-items:center;gap:12px;border:1px dashed rgb(15 36 24 / .18);border-radius:24px;padding:32px;background:#fefdf8b8;text-align:center}.history-empty-filtered h3{margin:0;color:var(--color-ink);font-family:Bricolage Grotesque,system-ui;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:760;letter-spacing:-.02em}.history-empty-filtered p{max-width:44ch;margin:0;color:var(--color-muted);line-height:1.55}@keyframes skeleton-shift{to{background-position:-200% 0}}@media(hover:hover)and (pointer:fine){.history-card--openable:hover{transform:translateY(-2px);box-shadow:0 28px 60px -16px #0f24182e;border-color:#2674513d}.rating-row button:hover,.history-filter:not(.history-filter--active):hover,.history-card__delete:hover{border-color:#2674514d;color:var(--color-accent-strong);background:var(--color-accent-soft)}.history-card__delete:hover{border-color:#a33d3d4d;color:var(--color-danger)}}@media(max-width:820px){.recipe-generator,.recipe-card__grid,.history-filters,.history-grid{grid-template-columns:1fr}.recipe-generator__action,.history-filter-group,.history-panel__header{justify-items:stretch;justify-content:stretch}.recipe-card__header,.history-card header,.history-card footer,.history-panel__header{flex-direction:column}.history-filter{flex:1}}
