/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}.visible{visibility:visible}.sr-only{-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.isolate{isolation:isolate}.z-20{z-index:20}.z-50{z-index:50}.container{width:100%}.mx-auto{margin-inline:auto}.mt-auto{margin-top:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.aspect-square{aspect-ratio:1}.size-full{width:100%;height:100%}.w-fit{width:-webkit-fit-content;width:fit-content}.w-full{width:100%}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.flex-grow,.grow{flex-grow:1}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y: calc(-50% - 2px) ;translate:var(--tw-translate-x)var(--tw-translate-y)}.rotate-45{rotate:45deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-in{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.rounded-\[2px\]{border-radius:2px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-muted{background-color:var(--muted)}.bg-primary{background-color:var(--primary)}.fill-primary{fill:var(--primary)}.text-center{text-align:center}.text-balance{text-wrap:balance}.text-primary-foreground{color:var(--primary-foreground)}.italic{font-style:italic}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.running{animation-play-state:running}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:opacity-50:disabled{opacity:.5}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:calc(2*var(--spacing)*-1)}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:calc(2*var(--spacing))}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:calc(2*var(--spacing)*-1)}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:calc(2*var(--spacing))}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}html,body{-webkit-overflow-scrolling:touch;width:100vw;height:100%;margin:0;padding:0;overflow-x:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-container{-webkit-overflow-scrolling:touch;width:100%;height:100%;position:relative;overflow:hidden auto}@viewport{width:device-width;zoom:1}button,a{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.scrollbar-hide::-webkit-scrollbar{display:none}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.perspective-1000{perspective:1000px}:root{--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:oklch(20.5% 0 0);--primary-foreground:oklch(98.5% 0 0);--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0)}.dark{--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:oklch(92.2% 0 0);--primary-foreground:oklch(20.5% 0 0);--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}@layer base{*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring)50%,transparent)}}body{background-color:var(--background);color:var(--foreground)}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}@font-face{font-family:Comico-Regular;src:url(/fonts/comico/Comico-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-Thin;src:url(/fonts/zodiak/Zodiak-Thin.woff2) format("woff2");font-weight:100;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-ThinItalic;src:url(/fonts/zodiak/Zodiak-ThinItalic.woff2) format("woff2");font-weight:100;font-style:italic;font-display:swap}@font-face{font-family:Zodiak-Light;src:url(/fonts/zodiak/Zodiak-Light.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-LightItalic;src:url(/fonts/zodiak/Zodiak-LightItalic.woff2) format("woff2");font-weight:300;font-style:italic;font-display:swap}@font-face{font-family:Zodiak-Regular;src:url(/fonts/zodiak/Zodiak-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-Italic;src:url(/fonts/zodiak/Zodiak-Italic.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:Zodiak-Bold;src:url(/fonts/zodiak/Zodiak-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-BoldItalic;src:url(/fonts/zodiak/Zodiak-BoldItalic.woff2) format("woff2");font-weight:700;font-style:italic;font-display:swap}@font-face{font-family:Zodiak-Extrabold;src:url(/fonts/zodiak/Zodiak-Extrabold.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-ExtraboldItalic;src:url(/fonts/zodiak/Zodiak-ExtraboldItalic.woff2) format("woff2");font-weight:800;font-style:italic;font-display:swap}@font-face{font-family:Zodiak-Black;src:url(/fonts/zodiak/Zodiak-Black.woff2) format("woff2");font-weight:900;font-style:normal;font-display:swap}@font-face{font-family:Zodiak-BlackItalic;src:url(/fonts/zodiak/Zodiak-BlackItalic.woff2) format("woff2");font-weight:900;font-style:italic;font-display:swap}:root{font-family:Zodiak-Regular,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0f172a;background-color:#f8fafc;--palette-porcelain: #ffffff;--palette-shell: #ffebda;--palette-peach: #fedbc0;--palette-blush: #f4a994;--palette-coral: #ff6458;--palette-rust: #da4832;--palette-squash: #ec8846;--palette-espresso: #3a2d28;--palette-parchment: #f9f1e4;--palette-lavender: #a8b1f5;--palette-teal: #1d463c;--palette-brick: #da463e;--palette-spring: #aad985;--palette-midnight-teal: #213c3b;--palette-rose: #e94d54;--calendar-surface: var(--palette-espresso);--calendar-panel: var(--palette-shell);--calendar-grid-cell: rgba(255, 235, 218, .22);--calendar-grid-cell-hover: rgba(236, 136, 70, .45);--calendar-grid-cell-active: rgba(218, 72, 50, .9);--calendar-grid-cell-planned: rgba(254, 219, 192, .85);--calendar-grid-cell-planned-hover: rgba(254, 219, 192, 1);--calendar-grid-cell-future: rgba(58, 45, 40, .55);--calendar-outline-today: var(--palette-squash);--calendar-drag-outline: rgba(255, 173, 138, .7);--calendar-scrollbar-track: rgba(255, 235, 218, .2);--calendar-scrollbar-thumb: rgba(255, 173, 138, .55);--calendar-text-muted: rgba(58, 45, 40, .72);--calendar-text-bright: var(--palette-espresso);--calendar-accent: var(--palette-peach)}body{margin:0;font-family:Zodiak-Regular,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.6;color:inherit;background-color:inherit;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden;overflow-y:auto}.settings-modal-open{overflow:hidden}.settings-modal-open .App{pointer-events:none;filter:blur(0px)}.settings-modal-open .chakra-modal__overlay,.settings-modal-open .chakra-modal__content,.settings-modal-open .chakra-modal__content *{pointer-events:auto}body.paywall-modal-open{overflow:hidden}body.paywall-modal-open .App{pointer-events:none}body.paywall-modal-open .chakra-modal__overlay,body.paywall-modal-open .chakra-modal__content,body.paywall-modal-open .chakra-modal__content *{pointer-events:auto}#chakra-modal-portal,[id*=chakra-modal],[id*=chakra-portal],body>div[data-chakra-portal],body>div[id*=portal]{z-index:999999!important;position:relative!important}.chakra-modal__overlay,body.paywall-modal-open .chakra-modal__overlay,.chakra-modal__content-container,body.paywall-modal-open .chakra-modal__content-container,.chakra-modal__content,body.paywall-modal-open .chakra-modal__content{z-index:999999!important}body.paywall-modal-open .calendar-header-controls,body.paywall-modal-open .calendar-header-controls .calendar-settings-trigger,body.paywall-modal-open .add-member-button,body.paywall-modal-open .calendar-weekdays{z-index:1!important;position:relative!important}body.paywall-modal-open .navigation-ui-container h1.z-20,body.paywall-modal-open h1[class*=z-20],body.paywall-modal-open h1{visibility:hidden!important;z-index:1!important}body.paywall-modal-open .devtools-log-db{display:none!important}body.paywall-modal-open .navigation-ui-container,body.paywall-modal-open .calendar-container{z-index:1!important;position:relative!important}body.paywall-modal-open .calendar-container.is-expanded{z-index:1!important}body.paywall-modal-open [id*=chakra-modal] *,body.paywall-modal-open [id*=chakra-portal] *,body.paywall-modal-open .chakra-modal__overlay,body.paywall-modal-open .chakra-modal__content,body.paywall-modal-open .chakra-modal__content *{z-index:999999!important}body.recipe-modal-open .coverflow-container{pointer-events:auto!important;position:relative;z-index:10001!important}body.recipe-modal-open .chakra-modal__overlay{pointer-events:auto!important;z-index:10000!important}body.recipe-modal-open .chakra-modal__content{pointer-events:auto!important;position:relative;z-index:10002!important;transition:top .3s ease-out,left .3s ease-out!important}body.recipe-modal-open .chakra-modal__content *{pointer-events:auto!important}h1,h2,h3,h4,h5,h6{font-family:Comico-Regular,Zodiak-Bold,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;margin:0;line-height:1.1}h1{font-size:clamp(2.5rem,5vw,3.5rem)}h2{font-size:clamp(2.25rem,4vw,3rem)}h3{font-size:clamp(2rem,3vw,2.5rem)}h4{font-size:clamp(1.75rem,2.5vw,2rem)}h5{font-size:clamp(1.5rem,2vw,1.75rem)}h6{font-size:clamp(1.25rem,1.5vw,1.5rem)}p,ul,ol,dl{margin-block:0}p+p{margin-top:1rem}ul,ol{padding-left:1.5rem}.font-heading{font-family:Comico-Regular,Zodiak-Bold,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.font-body{font-family:Zodiak-Regular,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}.App{text-align:center;max-width:100%;overflow-x:hidden;position:relative}.App-logo{height:40vmin;pointer-events:none}@media(prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin infinite 20s linear}}.App-header{background-color:#260f00f9;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:calc(10px + 2vmin);color:#fff}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scroll{0%{transform:translate(100%)}to{transform:translate(-100%)}}body{margin:0;padding:0;overflow-x:hidden;width:100%}.recipe-input,.file-input-text{padding:12px 16px;border:2px solid transparent;border-radius:8px;font-size:16px;background:#fff;height:24px;line-height:24px;color:#6e6e6e}.recipe-input{flex:1;margin-right:10px}.file-input-label{flex:1;position:relative;display:inline-block;margin-right:10px;height:48px;border-radius:8px}.file-input{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}.file-input-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;height:100%}.addon-button{padding:12px 24px;height:48px;background-color:#fff;border:2px solid #3b2314;border-radius:8px;font-weight:600;cursor:pointer;color:#3b2314;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;box-sizing:border-box;min-width:150px}.addon-button:hover{background-color:#f5e5c0}.addon-button:disabled{opacity:.5;cursor:not-allowed}.button-icon{margin-left:5px}.recipe-inputs{display:flex;flex-direction:column;gap:15px;width:100%;max-width:650px;margin:0 auto}.input-group{display:flex;width:100%;align-items:center;justify-content:center;height:48px}.recipe-input::placeholder{color:#6e6e6e;opacity:1}.loading-overlay{display:flex;justify-content:center;align-items:center;position:fixed;top:0;right:0;bottom:0;left:0;background-color:#111827e6;color:#fff;font-size:1.5rem;z-index:100}.ticker-container{overflow:hidden;white-space:nowrap;width:100%;background:transparent}.ticker-content{display:inline-block;white-space:nowrap;animation:ticker 60s linear infinite}.ticker-item{display:inline-block;padding:0 2rem}@keyframes ticker{0%{transform:translateZ(0)}to{transform:translate3d(-50%,0,0)}}.ticker-container:hover .ticker-content{animation-play-state:paused}.custom-scrollbar{overflow-x:scroll!important;overflow-y:hidden;scrollbar-width:auto;scrollbar-color:rgba(126,236,255,.7) rgba(31,41,55,.5)}.custom-scrollbar::-webkit-scrollbar{height:32px!important;width:32px!important;background-color:#1f293766;border-radius:8px}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:#7eecffb3;border-radius:8px;border:8px solid rgba(31,41,55,.6)}.custom-scrollbar::-webkit-scrollbar-track{background-color:#1118274d;border-radius:8px;margin:0 2px}#smooth-scrollbar{margin-top:15px;box-shadow:inset 0 1px 3px #0000004d;z-index:10;position:relative}#smooth-scrollbar>div{background-color:#7eecffcc;box-shadow:0 1px 4px #0006}.carousel-item{transition:transform .2s ease-out,opacity .3s ease-out}#smooth-scrollbar{margin-top:15px;box-shadow:0 2px 10px #0003;z-index:10}.perspective-container{perspective:1500px;transform-style:preserve-3d;overflow:visible!important}.overflow-x-scroll{overflow-x:scroll!important;scrollbar-width:thin!important}.carousel-item:hover{z-index:20}.navigation-ui-container{min-height:100vh;color:#fff;padding:1rem;display:flex;flex-direction:column}.calendar-container.is-expanded{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:50;background-color:#111827fa;padding:1rem;margin-top:0;border-radius:0;overflow-y:auto;display:flex;flex-direction:column}.omnibar-camera-button{width:3.75rem;height:3.75rem;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;background:linear-gradient(145deg,var(--palette-shell),var(--palette-peach));color:var(--palette-espresso);cursor:pointer;border:1px solid rgba(33,60,59,.25);box-shadow:0 10px 18px #213c3b40;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.omnibar-camera-button:hover{transform:translateY(-1px);box-shadow:0 16px 26px #213c3b59}.omnibar-camera-button:active{transform:translateY(1px) scale(.98);filter:brightness(.95)}.omnibar-camera-button:focus-within{outline:3px solid rgba(33,60,59,.3);outline-offset:3px}.calendar-header-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;margin-bottom:8px;position:relative;z-index:3}.calendar-header-left{display:flex;align-items:center;gap:10px}.calendar-header-controls .calendar-settings-trigger{background:none;border:1px solid #ccc;color:#ccc;border-radius:50%;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:background-color .2s,color .2s,border-color .2s;z-index:4}.calendar-header-controls .calendar-settings-trigger:hover{background-color:#ffffff1a;border-color:#fff;color:#fff}.settings-status-bubble{position:absolute;top:-3px;right:-3px;width:10px;height:10px;border-radius:50%;border:2px solid #1f1f1f}.settings-status-bubble--online{background-color:#38a169}.settings-status-bubble--offline{background-color:#e53e3e}.add-member-button{background:none;border:1px solid #ccc;color:#ccc;border-radius:50%;padding:6px;margin-right:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.add-member-button:hover{background-color:#ffffff1a;color:#fff}.add-member-button .spinner{border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top:2px solid #fff;width:16px;height:16px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.invite-link-display{display:flex;align-items:center;margin-left:15px;background-color:#ffffff1a;padding:4px 8px;border-radius:4px}.invite-link-display input[type=text]{background:none;border:none;color:#e0e0e0;font-size:.8em;margin-right:5px;width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-link-display button{background:none;border:none;color:#ccc;cursor:pointer;padding:2px;display:flex;align-items:center}.invite-link-display button:hover{color:#fff}:root{--cover-size: clamp(160px, 26vw, 280px);--perspective: 1500px;--container-height-multiplier: 1.45}.coverflow-container{position:relative;perspective:var(--perspective);width:100%;height:min(100vh,calc(var(--cover-size) * var(--container-height-multiplier)));overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:pan-y;-webkit-user-select:none;user-select:none}.coverflow-container--dragging{cursor:grabbing}.coverflow-list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%;transform-style:preserve-3d}.coverflow-item{position:absolute;top:50%;left:50%;width:var(--cover-size);height:var(--cover-size);margin:0;display:block;transform:translate(-50%,-50%) translateZ(-320px) scale(.48);opacity:0;pointer-events:none;will-change:transform,opacity}.coverflow-item-content{width:100%;height:100%;background-color:#333;border-radius:8px;overflow:hidden;box-shadow:0 10px 20px #00000080,0 6px 10px #0006;display:flex;justify-content:center;align-items:center;position:relative;border:1px solid rgba(255,255,255,.1);transform-style:preserve-3d;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-box-reflect:below 2px linear-gradient(transparent,transparent 75%,rgba(0,0,0,.5))}.coverflow-item-content img{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none}.coverflow-item-edit-button{position:absolute;top:8px;right:8px;z-index:15;background-color:#0009;color:#fff;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s ease-in-out,background-color .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.coverflow-item.is-center .coverflow-item-edit-button{opacity:1}.coverflow-item-edit-button:hover{background-color:#000c}.placeholder-content{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ccc;text-align:center;padding:10px;font-size:.9em;width:100%;height:100%}.placeholder-icon{font-size:2.5em;margin-bottom:10px;opacity:.5;color:#a0a0a0}.placeholder-text{font-weight:700;color:#e0e0e0}.coverflow-item.is-muted{opacity:0}.coverflow-item:focus-visible{outline:3px solid dodgerblue;outline-offset:4px}.scrollbar-track{width:80%;max-width:500px;height:24px;background-color:var(--palette-espresso);border-radius:12px;margin:20px auto 0;position:relative;cursor:pointer;box-shadow:inset 0 1px 3px #3a2d288c;transition:height .4s cubic-bezier(.4,0,.2,1),border-radius .4s cubic-bezier(.4,0,.2,1),background-color .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.scrollbar-thumb{height:100%;background:linear-gradient(145deg,var(--palette-peach),var(--palette-shell))!important;border-radius:12px;position:absolute;top:0;left:0;will-change:transform;transition:width .4s cubic-bezier(.4,0,.2,1),height .4s cubic-bezier(.4,0,.2,1),border-radius .4s cubic-bezier(.4,0,.2,1),background-color .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #0000004d;touch-action:none;border:none!important}.scrollbar-thumb.dragging{transition:none!important}.thumb-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.grabber-icon{width:30px;height:4px;background-color:#fff6;border-radius:2px}.scrollbar-track.search-active{height:48px;border-radius:24px;background-color:var(--palette-espresso)!important;border:none!important}.scrollbar-track.search-active .scrollbar-thumb{background:linear-gradient(145deg,var(--palette-peach),var(--palette-shell))!important;border-radius:24px;border:none!important}.thumb-content .search-icon{color:var(--palette-espresso);margin:0 12px;flex-shrink:0}.thumb-content input{flex-grow:1;height:100%;background:transparent;border:none;outline:none;color:var(--palette-espresso);font-size:1rem;padding-right:10px}.thumb-content input::placeholder{color:#3a2d288c}.thumb-content .close-search-btn{background:none;border:none;color:var(--palette-espresso);cursor:pointer;padding:12px;margin-right:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.thumb-content .close-search-btn:hover{background-color:#a8b1f51f}.scrollbar-thumb:hover{filter:brightness(1.05)}:root{--cell-size: 24px;--cell-gap: 4px;--cell-size-with-gap: calc(var(--cell-size) + var(--cell-gap));--weekday-label-width: 45px;--month-label-height: 25px}.calendar-container{padding:.5rem;background-color:var(--calendar-surface);border-radius:8px;margin-top:1rem;overflow:hidden;position:relative}.calendar-drag-cta{position:-webkit-sticky;position:sticky;top:0;z-index:6;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--palette-porcelain);background:linear-gradient(180deg,#ffebda40,#ffebda00);border-bottom:1px dashed rgba(255,173,138,.45);height:36px;opacity:0;transform:translateY(-6px) scale(.98);transition:opacity .18s ease,transform .18s ease;pointer-events:none}.calendar-container.drag-intent .calendar-drag-cta{opacity:1;transform:translateY(0) scale(1)}.calendar-container.catch-all-mode{border:2px dashed rgba(126,236,255,.6);border-radius:12px;background-color:#7eecff14;box-shadow:0 0 20px #7eecff4d;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.calendar-container.catch-all-mode.drag-intent{border-color:#7eecffe6;background-color:#7eecff26;box-shadow:0 0 30px #7eecff80}.calendar-container.catch-all-mode .calendar-drag-cta{opacity:1;transform:translateY(0) scale(1)}.calendar-months-container{padding-left:var(--weekday-label-width);margin-bottom:5px;height:var(--month-label-height);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;background-color:#3a2d28d9}.calendar-months-container::-webkit-scrollbar{display:none}.calendar-months{display:grid;grid-auto-flow:column;gap:var(--cell-gap);width:-webkit-fit-content;width:fit-content;height:100%;align-items:center}.calendar-month-label{font-size:.75rem;color:var(--palette-parchment);text-align:left;white-space:nowrap;overflow:hidden;grid-row:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.calendar-body-wrapper{position:relative;overflow:hidden}.calendar-grid-scroll-container{overflow-x:auto;padding-left:var(--weekday-label-width);scrollbar-width:thin;scrollbar-color:var(--calendar-scrollbar-thumb) var(--calendar-scrollbar-track)}.calendar-grid-scroll-container::-webkit-scrollbar{height:8px}.calendar-grid-scroll-container::-webkit-scrollbar-track{background:var(--calendar-scrollbar-track);border-radius:4px}.calendar-grid-scroll-container::-webkit-scrollbar-thumb{background-color:var(--calendar-scrollbar-thumb);border-radius:4px}.calendar-weekdays{position:absolute;left:0;top:0;height:100%;display:grid;grid-template-rows:repeat(7,var(--cell-size));gap:var(--cell-gap);font-size:.7rem;color:var(--palette-parchment);width:var(--weekday-label-width);text-align:right;padding-right:10px;box-sizing:border-box;background-color:#3a2d28d9;z-index:2}.calendar-weekdays>div{display:flex;align-items:center;justify-content:flex-end;height:var(--cell-size)}.calendar-weekdays>div:nth-child(1),.calendar-weekdays>div:nth-child(3),.calendar-weekdays>div:nth-child(5),.calendar-weekdays>div:nth-child(7){visibility:hidden}.calendar-grid{display:grid;grid-template-rows:repeat(7,var(--cell-size));grid-auto-flow:column;gap:var(--cell-gap);width:-webkit-fit-content;width:fit-content;padding-bottom:8px}.calendar-container.drag-intent .calendar-grid{filter:brightness(1.05);transition:filter .12s ease}.calendar-container.drag-intent .calendar-cell:not(.planned){outline:2px dashed var(--calendar-drag-outline);outline-offset:-2px}.calendar-cell[data-drop-active=true]{background-color:var(--palette-squash)!important;transform:scale(.95);transition:transform .12s ease,background-color .12s ease}.calendar-cell{width:var(--cell-size);height:var(--cell-size);background-color:var(--calendar-grid-cell);border-radius:4px;cursor:pointer;transition:background-color .2s ease,transform .1s ease}.calendar-cell:hover{background-color:var(--calendar-grid-cell-hover);transform:scale(1.05)}.calendar-cell:active{transform:scale(.95);background-color:var(--calendar-grid-cell-active)}.calendar-cell.today{outline:1px solid var(--calendar-outline-today);outline-offset:1px}.calendar-cell.planned{background-color:var(--calendar-grid-cell-planned)}.calendar-cell.planned:hover{background-color:var(--calendar-grid-cell-planned-hover)}.calendar-cell.grocery-list-selected{opacity:.75;background:linear-gradient(135deg,#4caf5066,#81c78499);position:relative;box-shadow:inset 0 0 8px #4caf504d}.calendar-cell.grocery-list-selected.planned{background:linear-gradient(135deg,var(--calendar-grid-cell-planned) 0%,rgba(129,199,132,.5) 50%,rgba(76,175,80,.4) 100%);box-shadow:inset 0 0 8px #4caf5066}.calendar-cell.grocery-list-selected:hover{opacity:.85;background:linear-gradient(135deg,#4caf5080,#81c784b3);box-shadow:inset 0 0 10px #4caf5066}.calendar-cell.grocery-list-selected.planned:hover{background:linear-gradient(135deg,var(--calendar-grid-cell-planned-hover) 0%,rgba(129,199,132,.6) 50%,rgba(76,175,80,.5) 100%);box-shadow:inset 0 0 10px #4caf5080}.calendar-cell[data-future=true]{background-color:var(--calendar-grid-cell);opacity:1;cursor:pointer}.calendar-cell[data-future=true]:hover{background-color:var(--calendar-grid-cell-hover);transform:scale(1.05)}.calendar-cell[data-future=true]:active{transform:scale(.95);background-color:var(--calendar-grid-cell-active)}.calendar-cell.planned[data-future=true]{background-color:var(--calendar-grid-cell-planned);opacity:1;cursor:pointer}.calendar-cell.planned[data-future=true]:hover{background-color:var(--calendar-grid-cell-planned-hover);transform:scale(1.05)}.calendar-cell.planned[data-future=true]:active{background-color:var(--calendar-grid-cell-planned);transform:scale(.95)}.calendar-container.is-expanded .calendar-cell[aria-disabled=true]{opacity:.4;cursor:not-allowed}.calendar-container.is-expanded .calendar-cell[aria-disabled=true]:hover{background-color:var(--calendar-grid-cell);transform:none}.calendar-container.is-expanded .calendar-cell[aria-disabled=true].planned{opacity:.5}.calendar-vertical-wrapper{display:none}.calendar-container.is-expanded{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:50;background-color:#3a2d28f2;padding:0;padding-top:clamp(.25rem,1vw,.5rem);margin-top:0;border-radius:0;overflow:hidden;display:flex;flex-direction:column;--cell-size: clamp(56px, 12vw, 100px);--cell-gap: clamp(6px, 2vw, 16px);--cell-size-with-gap: calc(var(--cell-size) + var(--cell-gap));--vertical-left-gutter: 0px;--vertical-right-gutter: clamp(24px, 3.4vw, 36px)}.calendar-container.is-expanded .calendar-months-container,.calendar-container.is-expanded .calendar-body-wrapper{display:none}.calendar-container.is-expanded .calendar-vertical-wrapper{display:flex;flex-direction:column;flex:1;gap:clamp(var(--cell-gap),3vw,var(--cell-gap) * 1.5);min-height:0}.calendar-vertical-toolbar{display:flex;align-items:center;justify-content:flex-end;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-bottom:clamp(.125rem,.5vw,.25rem);padding-top:0}.calendar-vertical-weekdays{display:grid;grid-template-columns:minmax(18px,-webkit-max-content) repeat(7,1fr);grid-template-columns:minmax(18px,max-content) repeat(7,1fr);gap:clamp(var(--cell-gap) * .28,.75vw,var(--cell-gap) * .5);font-size:clamp(.7rem,2.2vw,1rem);color:var(--palette-parchment);text-transform:uppercase;letter-spacing:.05em;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);height:clamp(42px,7vw,70px);align-items:center;justify-items:center;background-color:#3a2d28eb;border-bottom:1px solid rgba(255,235,218,.12);position:-webkit-sticky;position:sticky;top:0;z-index:4}.calendar-vertical-weekdays>button{grid-column:1}.calendar-vertical-weekday-spacer{justify-self:stretch;height:100%}.calendar-vertical-scroll{flex:1;overflow-y:auto;min-height:0;box-sizing:border-box;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-top:clamp(var(--cell-gap) * .55,2vw,var(--cell-gap) * .85);padding-bottom:clamp(var(--cell-gap) * 1.1,3.5vw,var(--cell-gap) * 2);scrollbar-width:thin;scrollbar-color:var(--calendar-scrollbar-thumb) var(--calendar-scrollbar-track)}.calendar-vertical-scroll::-webkit-scrollbar{width:8px}.calendar-vertical-scroll::-webkit-scrollbar-track{background:var(--calendar-scrollbar-track);border-radius:4px}.calendar-vertical-scroll::-webkit-scrollbar-thumb{background-color:var(--calendar-scrollbar-thumb);border-radius:4px}.calendar-vertical-layout{display:grid;grid-template-columns:minmax(18px,-webkit-max-content) repeat(7,1fr);grid-template-columns:minmax(18px,max-content) repeat(7,1fr);gap:clamp(var(--cell-gap) * .32,.8vw,var(--cell-gap) * .62);align-items:start;min-width:0;width:100%}.calendar-vertical-months{display:grid;grid-auto-rows:var(--cell-size);gap:clamp(var(--cell-gap) * .22,.7vw,var(--cell-gap) * .5);padding-top:clamp(var(--cell-gap) * .2,.85vw,var(--cell-gap) * .45);grid-column:1 / 2;justify-items:end}.calendar-vertical-month-label{font-size:clamp(.75rem,2.2vw,1.1rem);color:var(--palette-parchment);text-align:right;padding-right:clamp(2px,1vw,8px);white-space:nowrap}.calendar-vertical-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:var(--cell-size);gap:clamp(var(--cell-gap) * .33,.75vw,var(--cell-gap) * .7);width:100%;grid-column:2 / -1}.calendar-vertical-grid .calendar-cell{border-radius:clamp(10px,3vw,18px);width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center}.calendar-container.is-expanded .calendar-close-expanded{display:inline-flex;align-items:center;justify-content:center;width:clamp(40px,10vw,48px);height:clamp(40px,10vw,48px);background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:999px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:clamp(1.2rem,4vw,1.6rem)}.calendar-container.is-expanded .calendar-exit-edit-mode{display:inline-flex;align-items:center;justify-content:center;padding:0 clamp(16px,4vw,24px);height:clamp(40px,10vw,48px);background:#aad98533;border:1px solid rgba(170,217,133,.5);color:var(--palette-porcelain);border-radius:999px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;font-size:clamp(.9rem,2.5vw,1.1rem);font-weight:500;margin-right:clamp(8px,2vw,12px)}.calendar-container.is-expanded .calendar-exit-edit-mode:hover{background-color:#aad9854d;border-color:#aad985b3;transform:scale(1.05)}.calendar-container.is-expanded .calendar-exit-edit-mode:active{transform:scale(.95)}.calendar-container.is-expanded .calendar-close-expanded:hover{background-color:#ffebda38;border-color:#ffebda99}@media(min-width:768px){.calendar-container{padding:1rem;border-radius:12px}.calendar-container.is-expanded{padding:clamp(1rem,6vw,2rem);--cell-size: clamp(60px, 7vw, 90px);--cell-gap: clamp(10px, 1.5vw, 20px)}}.calendar-history-toggle{position:absolute;top:.5rem;left:.5rem;z-index:10;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:8px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0}.calendar-history-toggle:hover{background-color:#ffebda38;border-color:#ffebda99;transform:scale(1.05)}.calendar-history-toggle:active{transform:scale(.95)}.calendar-container.is-expanded .calendar-history-toggle{display:none}.calendar-history-toggle-inline{display:inline-flex;align-items:center;justify-content:center;width:clamp(32px,8vw,42px);height:clamp(32px,8vw,42px);background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:8px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0}.calendar-history-toggle-inline:hover{background-color:#ffebda38;border-color:#ffebda99;transform:scale(1.05)}.calendar-history-toggle-inline:active{transform:scale(.95)}.meal-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,235,218,.2);flex-shrink:0}.meal-history-header h2{color:var(--palette-porcelain);font-size:clamp(1.25rem,4vw,1.75rem);margin:0}.meal-history-controls{display:flex;align-items:center;gap:1rem}.meal-history-range-select{background-color:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:6px;padding:.5rem .75rem;font-size:.9rem;cursor:pointer}.meal-history-range-select:focus{outline:none;border-color:#ffebda99}.meal-history-close{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:8px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;padding:0}.meal-history-close:hover{background-color:#ffebda38;border-color:#ffebda99}.history-cell{width:var(--cell-size);height:var(--cell-size);background-color:var(--calendar-grid-cell);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,transform .1s ease;position:relative}.history-cell[data-drop-active=true],.meal-history-calendar.is-expanded .history-cell[data-drop-active=true]{background-color:var(--palette-squash)!important;transform:scale(.95);transition:transform .12s ease,background-color .12s ease}.history-cell.cooked:hover,.history-cell.not-cooked:hover{transform:scale(1.05)}.history-cell.storage-leftovers{background-color:#aad9854d;border:1px solid rgba(170,217,133,.5)}.history-cell.storage-leftovers:hover{background-color:#aad98566;transform:scale(1.05)}.history-cell.storage-spoilage{background-color:#ff64584d;border:1px solid rgba(255,100,88,.5)}.history-cell.storage-spoilage:hover{background-color:#ff645866;transform:scale(1.05)}.history-cell.storage-freezer{background-color:#a8b1f54d;border:1px solid rgba(168,177,245,.5)}.history-cell.storage-freezer:hover{background-color:#a8b1f566;transform:scale(1.05)}.history-cell.storage-pickled{background-color:#aad98566;border:1px solid rgba(170,217,133,.6)}.history-cell.storage-pickled:hover{background-color:#aad98580;transform:scale(1.05)}.history-cell.today{outline:1px solid var(--calendar-outline-today);outline-offset:1px}.history-cell.toggling{opacity:.6;transform:scale(.95)}.history-icon{pointer-events:none}.history-icon.cooked-icon{color:#aad985e6}.history-icon.not-cooked-icon{color:#ff6458e6}.history-badge{pointer-events:none;position:absolute;top:1px;right:1px;opacity:.4;transition:opacity .2s ease}.history-badge.manually-adjusted-badge{color:#ec8846e6;background-color:transparent}.history-cell.manually-adjusted:hover .history-badge{opacity:1;color:#ec8846}.history-cell.manually-adjusted{border:1px dotted rgba(236,136,70,.5)}.meal-history-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#3a2d28f2;z-index:100;display:flex;flex-direction:column;padding:clamp(1rem,4vw,2rem);overflow:hidden}.meal-history-modal .meal-history-calendar{flex:1 1 auto;max-height:calc(100vh - 400px);min-height:0;overflow:hidden;display:flex;flex-direction:column;background-color:var(--calendar-surface);border-radius:8px;padding:.5rem}.meal-history-calendar.is-expanded{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;max-height:100%;z-index:10;background-color:#3a2d28f2;padding:clamp(.75rem,4vw,1.5rem);margin:0;border-radius:0;--cell-size: clamp(56px, 12vw, 100px);--cell-gap: clamp(6px, 2vw, 16px);--cell-size-with-gap: calc(var(--cell-size) + var(--cell-gap));--vertical-left-gutter: 0px;--vertical-right-gutter: clamp(24px, 3.4vw, 36px)}.meal-history-calendar.is-expanded .calendar-months-container,.meal-history-calendar.is-expanded .calendar-body-wrapper{display:none}.meal-history-calendar.is-expanded .meal-history-vertical-wrapper{display:flex;flex-direction:column;flex:1;gap:clamp(var(--cell-gap),3vw,var(--cell-gap) * 1.5);min-height:0;overflow:hidden}.meal-history-vertical-wrapper{display:none}.meal-history-vertical-wrapper .meal-history-header{padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-top:clamp(.5rem,2vw,1rem);padding-bottom:clamp(.75rem,2vw,1rem);margin-bottom:clamp(var(--cell-gap) * .5,1.5vw,var(--cell-gap));flex-shrink:0}.meal-history-vertical-toolbar{display:flex;align-items:center;justify-content:flex-end;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-bottom:clamp(.2rem,2vw,.6rem);flex-shrink:0}.meal-history-close-expanded{display:inline-flex;align-items:center;justify-content:center;width:clamp(40px,10vw,48px);height:clamp(40px,10vw,48px);background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:999px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0}.meal-history-close-expanded:hover{background-color:#ffebda38;border-color:#ffebda99;transform:scale(1.05)}.meal-history-close-expanded:active{transform:scale(.95)}.meal-history-vertical-weekdays{display:grid;grid-template-columns:minmax(18px,-webkit-max-content) repeat(7,1fr);grid-template-columns:minmax(18px,max-content) repeat(7,1fr);gap:clamp(var(--cell-gap) * .28,.75vw,var(--cell-gap) * .5);font-size:clamp(.7rem,2.2vw,1rem);color:var(--palette-parchment);text-transform:uppercase;letter-spacing:.05em;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);height:clamp(42px,7vw,70px);align-items:center;justify-items:center;background-color:#3a2d28eb;border-bottom:1px solid rgba(255,235,218,.12);position:-webkit-sticky;position:sticky;top:0;z-index:4;flex-shrink:0}.meal-history-vertical-weekday-spacer{justify-self:stretch;height:100%}.meal-history-vertical-scroll{flex:1 1 auto;overflow-y:auto;min-height:40vh;max-height:100%;box-sizing:border-box;padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-top:clamp(var(--cell-gap) * .55,2vw,var(--cell-gap) * .85);padding-bottom:clamp(var(--cell-gap) * 1.1,3.5vw,var(--cell-gap) * 2);scrollbar-width:thin;scrollbar-color:var(--calendar-scrollbar-thumb) var(--calendar-scrollbar-track)}.meal-history-vertical-scroll::-webkit-scrollbar{width:8px}.meal-history-vertical-scroll::-webkit-scrollbar-track{background:var(--calendar-scrollbar-track);border-radius:4px}.meal-history-vertical-scroll::-webkit-scrollbar-thumb{background-color:var(--calendar-scrollbar-thumb);border-radius:4px}.meal-history-vertical-layout{display:grid;grid-template-columns:minmax(18px,-webkit-max-content) repeat(7,1fr);grid-template-columns:minmax(18px,max-content) repeat(7,1fr);gap:clamp(var(--cell-gap) * .32,.8vw,var(--cell-gap) * .62);align-items:start;min-width:0;width:100%}.meal-history-vertical-months{display:grid;grid-auto-rows:var(--cell-size);gap:clamp(var(--cell-gap) * .22,.7vw,var(--cell-gap) * .5);padding-top:clamp(var(--cell-gap) * .2,.85vw,var(--cell-gap) * .45);grid-column:1 / 2;justify-items:end}.meal-history-vertical-month-label{font-size:clamp(.75rem,2.2vw,1.1rem);color:var(--palette-parchment);text-align:right;padding-right:clamp(2px,1vw,8px);white-space:nowrap}.meal-history-vertical-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:var(--cell-size);gap:clamp(var(--cell-gap) * .33,.75vw,var(--cell-gap) * .7);width:100%;grid-column:2 / -1}.meal-history-vertical-grid .history-cell{border-radius:clamp(10px,3vw,18px);width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center}.meal-history-calendar .calendar-body-wrapper{flex:1;min-height:0;max-height:100%;overflow:hidden;display:flex;flex-direction:column}.meal-history-calendar .calendar-grid-scroll-container{flex:1;min-height:0;overflow-x:auto;overflow-y:auto}.meal-history-legend{display:flex;align-items:center;gap:1.5rem;margin-top:.75rem;padding-top:.75rem;padding-bottom:.5rem;border-top:1px solid rgba(255,235,218,.2);flex-wrap:wrap;flex-shrink:0;max-height:200px;overflow-y:auto}.meal-history-vertical-scroll .meal-history-legend{padding-left:var(--vertical-left-gutter);padding-right:var(--vertical-right-gutter);padding-top:clamp(1rem,3vw,1.5rem);padding-bottom:clamp(.75rem,2vw,1rem);margin-top:clamp(var(--cell-gap) * 1.5,3vw,var(--cell-gap) * 2);margin-bottom:clamp(.5rem,1.5vw,1rem);max-height:none;overflow-y:visible}.legend-item{display:flex;align-items:center;gap:.5rem;color:var(--palette-porcelain);font-size:.9rem}.legend-item .history-cell{width:20px;height:20px}.legend-hint{margin-left:auto;color:var(--palette-parchment);font-size:.85rem;font-style:italic}@media(max-width:767px){.meal-history-legend{flex-direction:column;align-items:flex-start;gap:.75rem}.legend-hint{margin-left:0}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}.calendar-cell.edit-mode{animation:wiggle .3s ease-in-out infinite;cursor:grab;z-index:10}.calendar-cell.edit-mode:active{cursor:grabbing;animation-play-state:paused}.calendar-cell.dragging{opacity:.6;animation-play-state:paused;z-index:100}.calendar-container.is-expanded.is-edit-mode{user-select:none;-webkit-user-select:none}.calendar-container.is-expanded.is-edit-mode .calendar-cell.edit-mode{touch-action:none}.history-cell.edit-mode{animation:wiggle .3s ease-in-out infinite;cursor:grab;z-index:10}.history-cell.edit-mode:active{cursor:grabbing;animation-play-state:paused}.history-cell.dragging{opacity:.6;animation-play-state:paused;z-index:100}.meal-history-vertical-grid.is-edit-mode{user-select:none;-webkit-user-select:none}.meal-history-vertical-grid.is-edit-mode .history-cell.edit-mode{touch-action:none}.recipe-detail-overlay{position:-webkit-sticky;position:sticky;top:0;z-index:5;background-color:#3a2d28fa;padding:clamp(.375rem,1.5vw,.625rem);padding-right:clamp(.375rem,1.5vw,.625rem);margin-bottom:clamp(.375rem,1.5vw,.625rem);border-bottom:1px solid rgba(255,235,218,.2)}.recipe-detail-content{display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:clamp(.5rem,2vw,.75rem);row-gap:clamp(.375rem,1.25vw,.5rem);max-width:100%;position:relative;min-height:-webkit-fit-content;min-height:fit-content}.recipe-detail-image-wrapper{display:flex;align-items:flex-start;gap:clamp(.75rem,3vw,1.25rem);flex:1;min-height:0}.recipe-detail-image{width:clamp(160px,40vw,260px);height:calc(100% + clamp(.5rem,1.5vw,.75rem) + clamp(36px,9vw,44px));min-height:clamp(160px,40vw,260px);object-fit:cover;border-radius:clamp(12px,3vw,16px);flex-shrink:0;align-self:flex-start}.recipe-detail-placeholder{width:clamp(160px,40vw,260px);height:calc(100% + clamp(.5rem,1.5vw,.75rem) + clamp(36px,9vw,44px));min-height:clamp(160px,40vw,260px);display:flex;align-items:center;justify-content:center;background-color:#ffebda1a;border-radius:clamp(12px,3vw,16px);flex-shrink:0;align-self:flex-start}.recipe-detail-placeholder-icon{font-size:clamp(3rem,10vw,5rem);opacity:.6}.recipe-detail-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:clamp(.5rem,2vw,.75rem)}.recipe-detail-title{margin:0;font-size:clamp(1.125rem,3.5vw,1.75rem);font-weight:600;color:var(--palette-porcelain);line-height:1.3;word-wrap:break-word}.recipe-detail-content{display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:clamp(.75rem,3vw,1.25rem);row-gap:clamp(.5rem,1.5vw,.75rem);max-width:100%;position:relative;min-height:-webkit-fit-content;min-height:fit-content}.recipe-detail-image-wrapper{display:contents}.recipe-detail-image{width:clamp(165px,38vw,240px);height:clamp(165px,38vw,240px);grid-row:1 / -1;object-fit:cover;border-radius:clamp(12px,3vw,16px);align-self:flex-start}.recipe-detail-placeholder{width:clamp(165px,38vw,240px);height:clamp(165px,38vw,240px);grid-row:1 / -1;display:flex;align-items:center;justify-content:center;background-color:#ffebda1a;border-radius:clamp(12px,3vw,16px);align-self:flex-start}.recipe-detail-info{grid-column:2;flex:1;min-width:0;display:flex;flex-direction:column;gap:clamp(.25rem,1.5vw,.375rem)}.recipe-detail-actions{grid-column:2;display:flex;align-items:center;justify-content:flex-end;gap:clamp(.5rem,1.5vw,.625rem);flex-shrink:0}.recipe-detail-overlay-empty{position:-webkit-sticky;position:sticky;top:0;z-index:5;background-color:transparent;padding:clamp(.5rem,2vw,.75rem);padding-right:clamp(.5rem,2vw,.75rem);margin-bottom:clamp(.5rem,2vw,1rem);display:flex;justify-content:flex-end}.recipe-detail-actions-empty{display:flex;align-items:center;justify-content:flex-end;gap:clamp(.75rem,2vw,1rem);flex-shrink:0}.recipe-detail-add-grocery{width:auto;padding:clamp(.625rem,2.5vw,.875rem) clamp(.875rem,2.5vw,1.25rem);background-color:#aad98533;border:1px solid rgba(170,217,133,.5);color:var(--palette-porcelain);border-radius:clamp(8px,2vw,10px);cursor:pointer;font-size:clamp(.875rem,2.5vw,1rem);font-weight:500;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;text-align:center}.recipe-detail-add-grocery:hover{background-color:#aad9854d;border-color:#aad985b3;transform:scale(1.05)}.recipe-detail-add-grocery:active{transform:scale(.95)}.recipe-detail-add-grocery-removed{background-color:#ff645833;border-color:#ff645880}.recipe-detail-add-grocery-removed:hover{background-color:#ff64584d;border-color:#ff6458b3}.recipe-detail-close{display:inline-flex;align-items:center;justify-content:center;width:clamp(36px,9vw,44px);height:clamp(36px,9vw,44px);background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:50%;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0;flex-shrink:0}.recipe-detail-close:hover{background-color:#ffebda38;border-color:#ffebda99;transform:scale(1.05)}.recipe-detail-close:active{transform:scale(.95)}.calendar-review-grocery-list{position:fixed;bottom:clamp(1rem,4vw,2rem);left:50%;transform:translate(-50%);z-index:10;padding:clamp(.75rem,3vw,1rem) clamp(1.5rem,4vw,2rem);background-color:#aad985e6;border:1px solid rgba(170,217,133,.8);color:var(--palette-porcelain);border-radius:clamp(12px,3vw,16px);cursor:pointer;font-size:clamp(.875rem,2.5vw,1rem);font-weight:600;transition:background-color .2s ease,border-color .2s ease,transform .1s ease,box-shadow .2s ease;display:block;width:-webkit-fit-content;width:fit-content;min-width:clamp(200px,60vw,300px);box-shadow:0 4px 12px #0000004d}.calendar-review-grocery-list:hover{background-color:#aad985;border-color:#aad985;transform:translate(-50%) scale(1.05);box-shadow:0 6px 16px #0006}.calendar-review-grocery-list:active{transform:translate(-50%) scale(.95)}.grocery-list-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#3a2d28f2;z-index:100;display:flex;flex-direction:column;padding:clamp(1rem,4vw,2rem);overflow:hidden}.grocery-list-content{flex:1;display:flex;flex-direction:column;background-color:var(--calendar-surface);border-radius:12px;padding:clamp(1rem,3vw,1.5rem);overflow-y:auto;max-width:800px;width:100%;margin:0 auto}.grocery-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(1rem,3vw,1.5rem);padding-bottom:clamp(.75rem,2vw,1rem);border-bottom:1px solid rgba(255,235,218,.2)}.grocery-list-header h2{margin:0;font-size:clamp(1.25rem,4vw,1.75rem);color:var(--palette-porcelain)}.grocery-list-close{display:inline-flex;align-items:center;justify-content:center;width:clamp(36px,9vw,44px);height:clamp(36px,9vw,44px);background:#ffebda1f;border:1px solid rgba(255,235,218,.4);color:var(--palette-porcelain);border-radius:50%;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0}.grocery-list-close:hover{background-color:#ffebda38;border-color:#ffebda99;transform:scale(1.05)}.grocery-list-close:active{transform:scale(.95)}.grocery-list-selected-meals{margin-bottom:clamp(1rem,3vw,1.5rem)}.grocery-list-selected-meals h3{margin:0 0 clamp(.75rem,2vw,1rem) 0;font-size:clamp(1rem,3vw,1.25rem);color:var(--palette-porcelain)}.grocery-list-empty{color:var(--palette-parchment);font-style:italic;margin:0}.grocery-list-meals{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:clamp(.5rem,2vw,.75rem)}.grocery-list-meal-item{display:flex;justify-content:space-between;align-items:center;padding:clamp(.75rem,2vw,1rem);background-color:#ffebda14;border:1px solid rgba(255,235,218,.2);border-radius:clamp(6px,1.5vw,8px)}.grocery-list-meal-info{display:flex;flex-direction:column;gap:clamp(.25rem,1vw,.5rem);flex:1;min-width:0}.grocery-list-meal-date{font-size:clamp(.75rem,2vw,.875rem);color:var(--palette-parchment);text-transform:uppercase;letter-spacing:.05em}.grocery-list-meal-title{font-size:clamp(.875rem,2.5vw,1rem);color:var(--palette-porcelain);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grocery-list-remove-meal{display:inline-flex;align-items:center;justify-content:center;width:clamp(32px,8vw,36px);height:clamp(32px,8vw,36px);background:#ff645826;border:1px solid rgba(255,100,88,.4);color:var(--palette-coral);border-radius:6px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .1s ease;padding:0;flex-shrink:0}.grocery-list-remove-meal:hover{background-color:#ff645840;border-color:#ff645899;transform:scale(1.05)}.grocery-list-remove-meal:active{transform:scale(.95)}.grocery-list-actions{margin-bottom:clamp(1rem,3vw,1.5rem)}.grocery-list-generate{width:100%;padding:clamp(.75rem,3vw,1rem) clamp(1.5rem,4vw,2rem);background-color:#aad98540;border:1px solid rgba(170,217,133,.6);color:var(--palette-porcelain);border-radius:clamp(8px,2vw,12px);cursor:pointer;font-size:clamp(.875rem,2.5vw,1rem);font-weight:600;transition:background-color .2s ease,border-color .2s ease,transform .1s ease}.grocery-list-generate:hover:not(:disabled){background-color:#aad98559;border-color:#aad985cc;transform:scale(1.02)}.grocery-list-generate:active:not(:disabled){transform:scale(.98)}.grocery-list-generate:disabled{opacity:.5;cursor:not-allowed}.grocery-list-generated{margin-top:clamp(1rem,3vw,1.5rem);padding-top:clamp(1rem,3vw,1.5rem);border-top:1px solid rgba(255,235,218,.2)}.grocery-list-generated h3{margin:0 0 clamp(.75rem,2vw,1rem) 0;font-size:clamp(1rem,3vw,1.25rem);color:var(--palette-porcelain)}.grocery-list-ingredients{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:clamp(.5rem,2vw,.75rem)}.grocery-list-ingredient-item{padding:clamp(.75rem,2vw,1rem);background-color:#ffebda0d;border-left:3px solid rgba(170,217,133,.6);border-radius:clamp(4px,1vw,6px);display:flex;flex-direction:column;gap:clamp(.25rem,1vw,.5rem)}.grocery-list-ingredient-text{font-size:clamp(.875rem,2.5vw,1rem);color:var(--palette-porcelain);font-weight:500}.grocery-list-ingredient-sources{font-size:clamp(.75rem,2vw,.875rem);color:var(--palette-parchment);font-style:italic}.avatar-stack-container{display:flex;align-items:center}.avatar-stack-item{border:2px solid var(--calendar-surface);border-radius:50%;margin-left:-10px;transition:transform .2s ease-in-out;box-shadow:0 2px 4px #0003}.avatar-stack-item:first-child{margin-left:0}.avatar-stack-item:hover{transform:translateY(-2px)}.avatar-stack-more{background-color:var(--palette-rust);color:var(--palette-porcelain);display:flex;align-items:center;justify-content:center;font-weight:500}.tutorial-container{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:auto;padding:10px 20px;position:relative}.tutorial-welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px;max-width:600px;width:100%;overflow:visible}.tutorial-chef-container{width:140px;height:140px;margin:0 auto;position:relative}.tutorial-speech-bubble{background:var(--palette-peach);border-radius:16px;padding:14px 18px;max-width:300px;width:100%;margin:0 auto 16px;position:relative;box-shadow:0 4px 12px #00000026;animation:fadeInUp .4s ease-out;color:var(--palette-espresso);font-size:clamp(.85rem,2.2vw,1rem);line-height:1.5;text-align:center;transition:opacity .3s ease-in-out;min-height:120px;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.tutorial-speech-bubble.visible{opacity:1}.tutorial-speech-bubble.hidden{opacity:0}.tutorial-speech-bubble:before{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid var(--palette-peach);pointer-events:none;z-index:1}.tutorial-step-content{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:800px;overflow:visible}.tutorial-media-container{width:100%;max-width:600px;margin:8px 0;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0003}.tutorial-media-container img{width:100%;height:auto;display:block;object-fit:contain}.tutorial-media-container iframe{width:100%;aspect-ratio:16 / 9;border:none}.tutorial-progress-wrapper{width:100%;max-width:600px;display:flex;align-items:center;gap:12px;margin:12px auto 0;padding:0 8px;position:relative;z-index:10002}.tutorial-progress-track{flex:1;height:24px;background-color:var(--palette-espresso);border-radius:12px;position:relative;box-shadow:inset 0 1px 3px #3a2d288c;overflow:hidden}.tutorial-progress-thumb{height:100%;background:linear-gradient(145deg,var(--palette-peach),var(--palette-shell))!important;border-radius:12px;position:absolute;top:0;left:0;transition:width .4s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px #0000004d;display:flex;align-items:center;justify-content:center}.tutorial-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--palette-espresso);font-size:.75rem;font-weight:600;white-space:nowrap;pointer-events:none}.tutorial-navigation{display:flex;gap:12px;align-items:center;justify-content:space-between;width:100%}.tutorial-button{padding:8px 16px;border-radius:999px;font-weight:600;font-family:Zodiak-Bold,sans-serif;font-size:clamp(.85rem,2vw,.95rem);cursor:pointer;border:none;transition:all .2s ease;min-width:90px;height:40px;display:flex;align-items:center;justify-content:center;gap:4px;position:relative;z-index:10003}.tutorial-button-primary{background:linear-gradient(145deg,var(--palette-peach),var(--palette-shell));color:var(--palette-espresso);box-shadow:0 2px 8px #0003}.tutorial-button-primary:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.tutorial-button-primary:active{transform:translateY(0)}.tutorial-button-secondary{background:#3a2d28cc;color:var(--palette-porcelain)}.tutorial-button-secondary:hover{background:#3a2d28}.tutorial-button:disabled{opacity:.5;cursor:not-allowed}.tutorial-skip-button{background:transparent;color:var(--palette-espresso);border:2px solid var(--palette-espresso);padding:8px 16px;border-radius:999px;font-weight:600;font-family:Zodiak-Bold,sans-serif;font-size:clamp(.8rem,1.8vw,.9rem);cursor:pointer;transition:all .2s ease;margin-top:8px;position:relative;z-index:10003}.tutorial-skip-button:hover{background:var(--palette-espresso);color:var(--palette-porcelain)}.tutorial-highlight-overlay{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:9998}.tutorial-highlight-element{position:relative;z-index:9999!important;transition:all .3s ease}.tutorial-highlight-element:before{content:"";position:absolute;top:-4px;left:-4px;right:-4px;bottom:-4px;border-radius:8px;box-shadow:0 0 0 3px var(--palette-peach),0 0 20px #fedbc0cc,0 0 40px #fedbc066!important;pointer-events:none;animation:pulseGlow 2s ease-in-out infinite;z-index:10000!important}.calendar-container.tutorial-highlight-element{overflow:visible!important;z-index:9999!important}.calendar-container.tutorial-highlight-element:before{margin:-4px;border-radius:12px}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 3px var(--palette-peach),0 0 20px #fedbc0cc,0 0 40px #fedbc066}50%{box-shadow:0 0 0 3px var(--palette-peach),0 0 30px #fedbc0,0 0 60px #fedbc099}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutorial-countdown{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;animation:fadeInUp .3s ease-out;z-index:10001;position:fixed;top:20px;left:50%;transform:translate(-50%);background:#3a2d28f2;padding:16px 20px;border-radius:16px;box-shadow:0 4px 16px #0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tutorial-countdown-ring{position:relative;width:64px;height:64px;background:#3a2d280d;border-radius:50%;display:flex;align-items:center;justify-content:center}.tutorial-countdown-svg{width:100%;height:100%;position:absolute;top:0;left:0}.tutorial-countdown-circle{transition:stroke-dashoffset 1s linear;transform-origin:18px 18px}.tutorial-countdown-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;font-family:Zodiak-Bold,sans-serif;color:var(--palette-peach);text-shadow:0 2px 4px rgba(0,0,0,.3);z-index:1}.tutorial-countdown-text{font-size:.85rem;color:var(--palette-porcelain);opacity:.9;font-weight:600;font-family:Zodiak-Regular,sans-serif;text-align:center}.tutorial-welcome-buttons{display:flex;gap:12px;align-items:center;justify-content:space-between;width:100%;max-width:400px;margin-top:8px}@media(max-width:640px){.tutorial-container{padding:8px 12px}.tutorial-welcome-screen{gap:12px;padding:16px}.tutorial-chef-container{width:120px;height:120px}.tutorial-speech-bubble{padding:12px 16px;font-size:.85rem;margin:6px auto 16px;min-height:100px}.tutorial-progress-wrapper{gap:8px;padding:0 4px}.tutorial-button{min-width:70px;padding:6px 12px;font-size:.8rem;height:36px}.tutorial-skip-button{padding:6px 12px;font-size:.75rem;margin-top:6px}.tutorial-welcome-buttons{gap:8px;max-width:100%}.tutorial-welcome-buttons .tutorial-button{flex:1;min-width:auto}.tutorial-welcome-buttons .tutorial-skip-button{flex:1;margin-top:0}}.recipe-drag-preview{width:120px;height:120px;background-color:#4a4a4a;border-radius:12px;box-shadow:0 10px 25px #00000059,0 6px 10px #00000040;overflow:hidden;display:flex;justify-content:center;align-items:center;cursor:grabbing;opacity:.95;transition:opacity .16s ease,transform .16s ease}.recipe-drag-preview img{display:block;width:100%;height:100%;object-fit:cover;pointer-events:none}.placeholder-content-preview{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ccc;text-align:center;padding:6px;font-size:.8em;width:100%;height:100%;pointer-events:none}.placeholder-icon-preview{font-size:1.8em;margin-bottom:5px;opacity:.6;color:#a0a0a0}.placeholder-text-preview{font-weight:600;color:#e0e0e0;font-size:.9em;line-height:1.2}.preview-title{position:absolute;bottom:0;left:0;right:0;background-color:#0009;color:#fff;font-size:.7em;padding:3px 5px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
