*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4}body{margin:0;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}hr{height:0;color:inherit;border-top-width:1px}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}select{-webkit-appearance:none;-moz-appearance:none;appearance:none}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:transparent;background-image:none;border:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}:root{--color-primary: #2D8C4E;--color-primary-light: #E8F5EC;--color-primary-lighter: #F0FAF3;--color-primary-dark: #1E6B38;--color-primary-50: #F0FAF3;--color-primary-100: #D1F0DA;--color-primary-500: #2D8C4E;--color-primary-600: #1E6B38;--color-primary-700: #155A2C;--color-secondary: #E8763A;--color-secondary-light: #FEF0E7;--color-secondary-dark: #C55E28;--color-accent: #A3C94A;--color-accent-light: #F3F9E6;--color-accent-dark: #7BA32E;--color-success: #34C759;--color-warning: #FFB340;--color-danger: #E5484D;--color-info: #5B9BD5;--color-gray-50: #FAFAF8;--color-gray-100: #F5F4F1;--color-gray-200: #E8E6E1;--color-gray-300: #D4D1CB;--color-gray-400: #A8A29E;--color-gray-500: #78716C;--color-gray-600: #57534E;--color-gray-700: #44403C;--color-gray-800: #292524;--color-gray-900: #1C1917;--color-bg-primary: #FFFFFF;--color-bg-secondary: #FAFAF8;--color-bg-tertiary: #F5F4F1;--color-bg-sidebar: #1C2B1F;--color-bg-sidebar-hover: #263D2A;--color-bg-sidebar-active: #2D8C4E;--color-text-primary: #1C1917;--color-text-secondary: #78716C;--color-text-tertiary: #A8A29E;--color-text-inverse: #FFFFFF;--color-text-link: #2D8C4E;--color-meal-breakfast: #F5A623;--color-meal-breakfast-bg: #FFF7E6;--color-meal-breakfast-text: #A66A00;--color-meal-lunch: #2D8C4E;--color-meal-lunch-bg: #E8F5EC;--color-meal-lunch-text: #155A2C;--color-meal-dinner: #6366F1;--color-meal-dinner-bg: #EEF0FF;--color-meal-dinner-text: #3730A3;--color-meal-snack: #EC4899;--color-meal-snack-bg: #FDF2F8;--color-meal-snack-text: #9D174D;--width-sidebar: 15rem;--width-sidebar-collapsed: 4.5rem;--shadow-xs: 0 1px 2px rgba(28, 25, 23, .04);--shadow-card: 0 1px 3px rgba(28, 25, 23, .06), 0 1px 2px rgba(28, 25, 23, .04);--shadow-card-hover: 0 4px 12px rgba(28, 25, 23, .08), 0 2px 4px rgba(28, 25, 23, .04);--shadow-modal: 0 20px 60px rgba(28, 25, 23, .15), 0 4px 16px rgba(28, 25, 23, .08);--shadow-dropdown: 0 4px 16px rgba(28, 25, 23, .1);--shadow-toast: 0 8px 24px rgba(28, 25, 23, .12);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--font-sans: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.inline-block{display:inline-block}.block{display:block}.hidden{display:none}.contents{display:contents}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:start}.items-end{align-items:end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:end}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.col-span-2{grid-column:span 2 / span 2}.col-span-3{grid-column:span 3 / span 3}.col-span-full{grid-column:1 / -1}.gap-0{gap:0}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-7{padding:1.75rem}.p-8{padding:2rem}.p-12{padding:3rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.pb-4{padding-bottom:1rem}.pl-10{padding-left:2.5rem}.m-0{margin:0}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-3{margin-top:.75rem;margin-bottom:.75rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-0\.5{margin-left:.125rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-60{margin-left:15rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.-mt-px{margin-top:-1px}.w-0{width:0}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-48{width:12rem}.w-60{width:15rem}.w-64{width:16rem}.w-full{width:100%}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-20{height:5rem}.h-24{height:6rem}.h-36{height:9rem}.h-48{height:12rem}.h-64{height:16rem}.h-screen{height:100vh}.h-full{height:100%}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.min-w-72{min-width:18rem}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-h-\[85vh\]{max-height:85vh}.max-h-96{max-height:24rem}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.top-4{top:1rem}.right-0{right:0}.right-4{right:1rem}.bottom-0{bottom:0}.left-0{left:0}.left-3{left:.75rem}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[100\]{z-index:100}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.text-\[10px\]{font-size:10px}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.uppercase{text-transform:uppercase}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-white{color:#fff}.text-black{color:#000}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-primary{color:var(--color-primary)}.text-primary-dark{color:var(--color-primary-dark)}.text-secondary{color:var(--color-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.text-text-tertiary{color:var(--color-text-tertiary)}.text-text-inverse{color:var(--color-text-inverse)}.text-meal-breakfast-text{color:var(--color-meal-breakfast-text)}.text-meal-lunch-text{color:var(--color-meal-lunch-text)}.text-meal-dinner-text{color:var(--color-meal-dinner-text)}.text-meal-snack-text{color:var(--color-meal-snack-text)}.text-blue-600{color:#2563eb}.text-green-600{color:#16a34a}.text-green-700{color:#15803d}.text-red-600{color:#dc2626}.text-red-700{color:#b91c1c}.text-amber-600{color:#d97706}.text-amber-700{color:#b45309}.text-indigo-600{color:#4f46e5}.text-yellow-700{color:#a16207}.text-yellow-800{color:#854d0e}.text-white\/50{color:#ffffff80}.text-white\/30{color:#ffffff4d}.text-white\/60{color:#fff9}.bg-white{background-color:#fff}.bg-black{background-color:#000}.bg-transparent{background-color:transparent}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-gray-300{background-color:var(--color-gray-300)}.bg-gray-400{background-color:var(--color-gray-400)}.bg-gray-500{background-color:var(--color-gray-500)}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.bg-primary-lighter{background-color:var(--color-primary-lighter)}.bg-primary-dark{background-color:var(--color-primary-dark)}.bg-secondary{background-color:var(--color-secondary)}.bg-secondary-dark{background-color:var(--color-secondary-dark)}.bg-danger{background-color:var(--color-danger)}.bg-success{background-color:var(--color-success)}.bg-warning{background-color:var(--color-warning)}.bg-bg-primary{background-color:var(--color-bg-primary)}.bg-bg-secondary{background-color:var(--color-bg-secondary)}.bg-bg-tertiary{background-color:var(--color-bg-tertiary)}.bg-bg-sidebar{background-color:var(--color-bg-sidebar)}.bg-bg-sidebar-hover{background-color:var(--color-bg-sidebar-hover)}.bg-bg-sidebar-active{background-color:var(--color-bg-sidebar-active)}.bg-meal-breakfast{background-color:var(--color-meal-breakfast)}.bg-meal-breakfast-bg{background-color:var(--color-meal-breakfast-bg)}.bg-meal-lunch{background-color:var(--color-meal-lunch)}.bg-meal-lunch-bg{background-color:var(--color-meal-lunch-bg)}.bg-meal-dinner{background-color:var(--color-meal-dinner)}.bg-meal-dinner-bg{background-color:var(--color-meal-dinner-bg)}.bg-meal-snack{background-color:var(--color-meal-snack)}.bg-meal-snack-bg{background-color:var(--color-meal-snack-bg)}.bg-green-50{background-color:#f0fdf4}.bg-green-100{background-color:#dcfce7}.bg-red-50{background-color:#fef2f2}.bg-red-100{background-color:#fee2e2}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-amber-50{background-color:#fffbeb}.bg-amber-100{background-color:#fef3c7}.bg-yellow-50{background-color:#fefce8}.bg-indigo-50{background-color:#eef2ff}.bg-white\/80{background-color:#fffc}.bg-white\/95{background-color:#fffffff2}.bg-black\/40{background-color:#0006}.bg-gray-50\/50{background-color:#fafaf880}.bg-danger\/90{background-color:#e5484de6}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-from),var(--tw-gradient-to))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-from),var(--tw-gradient-to))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-from),var(--tw-gradient-to))}.from-primary{--tw-gradient-from: var(--color-primary);--tw-gradient-to: var(--color-primary)}.to-primary-dark{--tw-gradient-to: var(--color-primary-dark)}.border{border-width:1px;border-style:solid}.border-0{border-width:0}.border-2{border-width:2px;border-style:solid}.border-4{border-width:4px;border-style:solid}.border-t{border-top-width:1px;border-top-style:solid}.border-b{border-bottom-width:1px;border-bottom-style:solid}.border-l{border-left-width:1px;border-left-style:solid}.border-l-2{border-left-width:2px;border-left-style:solid}.border-l-4{border-left-width:4px;border-left-style:solid}.border-transparent{border-color:transparent}.border-gray-100{border-color:var(--color-gray-100)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-primary{border-color:var(--color-primary)}.border-primary-light{border-color:var(--color-primary-light)}.border-danger{border-color:var(--color-danger)}.border-white\/10{border-color:#ffffff1a}.border-green-300{border-color:#86efac}.border-yellow-200{border-color:#fde68a}.border-dashed{border-style:dashed}.divide-y>*+*{border-top-width:1px;border-top-style:solid}.divide-gray-100>*+*{border-color:var(--color-gray-100)}.rounded{border-radius:.25rem}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.rounded-t-2xl{border-top-left-radius:var(--radius-2xl);border-top-right-radius:var(--radius-2xl)}.rounded-b-2xl{border-bottom-left-radius:var(--radius-2xl);border-bottom-right-radius:var(--radius-2xl)}.shadow-xs{box-shadow:var(--shadow-xs)}.shadow-card{box-shadow:var(--shadow-card)}.shadow-card-hover{box-shadow:var(--shadow-card-hover)}.shadow-modal{box-shadow:var(--shadow-modal)}.shadow-toast{box-shadow:var(--shadow-toast)}.shadow-dropdown{box-shadow:var(--shadow-dropdown)}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.shadow-sm{box-shadow:0 1px 2px #0000000d}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.transform{transform:translate(var(--tw-translate-x, 0),var(--tw-translate-y, 0)) rotate(var(--tw-rotate, 0)) skew(var(--tw-skew-x, 0)) skewY(var(--tw-skew-y, 0)) scaleX(var(--tw-scale-x, 1)) scaleY(var(--tw-scale-y, 1))}.-translate-y-1\/2{transform:translateY(-50%)}.top-1\/2{top:50%}.scale-95{transform:scale(.95)}.scale-100{transform:scale(1)}.rotate-180{transform:rotate(180deg)}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-move{cursor:move}.object-cover{object-fit:cover}.object-contain{object-fit:contain}.backdrop-blur-sm{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes pulse{50%{opacity:.5}}@keyframes slideIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}.animate-\[slideIn_0\.3s_ease-out\]{animation:slideIn .3s ease-out}.animate-\[scaleIn_0\.2s_ease-out\]{animation:scaleIn .2s ease-out}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--tw-ring-color, rgba(45, 140, 78, .3))}.focus\:ring-primary\/20:focus{--tw-ring-color: rgba(45, 140, 78, .2)}.focus\:ring-primary\/30:focus{--tw-ring-color: rgba(45, 140, 78, .3)}.focus\:ring-offset-1:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px var(--tw-ring-color, rgba(45, 140, 78, .3))}.focus\:border-primary:focus{border-color:var(--color-primary)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-gray-200:hover{background-color:var(--color-gray-200)}.hover\:bg-primary-lighter:hover{background-color:var(--color-primary-lighter)}.hover\:bg-bg-sidebar-hover:hover{background-color:var(--color-bg-sidebar-hover)}.hover\:bg-secondary-dark:hover{background-color:var(--color-secondary-dark)}.hover\:bg-danger\/90:hover{background-color:#e5484de6}.hover\:bg-green-50:hover{background-color:#f0fdf4}.hover\:text-white:hover{color:#fff}.hover\:text-primary:hover{color:var(--color-primary)}.hover\:text-primary-dark:hover{color:var(--color-primary-dark)}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-gray-700:hover{color:var(--color-gray-700)}.hover\:text-gray-900:hover{color:var(--color-gray-900)}.hover\:text-danger:hover{color:var(--color-danger)}.hover\:border-gray-300:hover{border-color:var(--color-gray-300)}.hover\:border-gray-200:hover{border-color:var(--color-gray-200)}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.hover\:shadow-card-hover:hover{box-shadow:var(--shadow-card-hover)}.active\:shadow-sm:active{box-shadow:0 1px 2px #0000000d}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{background-color:var(--color-gray-100)}.placeholder\:text-gray-400::placeholder{color:var(--color-gray-400)}.ring-1{box-shadow:0 0 0 1px var(--tw-ring-color, currentColor)}.ring-danger\/20{--tw-ring-color: rgba(229, 72, 77, .2)}.space-y-0\.5>*+*{margin-top:.125rem}.space-y-1>*+*{margin-top:.25rem}.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-5>*+*{margin-top:1.25rem}.space-y-6>*+*{margin-top:1.5rem}.space-x-1>*+*{margin-left:.25rem}.space-x-2>*+*{margin-left:.5rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.group:hover .group-hover\:text-primary{color:var(--color-primary)}.group:hover .group-hover\:visible{visibility:visible}.group:hover .group-hover\:opacity-100{opacity:1}@media(min-width:640px){.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:block{display:block}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.md\:flex-row{flex-direction:row}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:col-span-2{grid-column:span 2 / span 2}}@media(min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.resize-none{resize:none}.appearance-none{appearance:none}.outline-none{outline:2px solid transparent;outline-offset:2px}.select-none{-webkit-user-select:none;user-select:none}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.font-sans{font-family:var(--font-sans)}.nutriplan-page-centered{max-width:56rem;margin-left:auto;margin-right:auto}.nutriplan-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.nutriplan-page-title{font-size:1.25rem;line-height:1.75rem;font-weight:700}.nutriplan-section-title{font-size:1.125rem;line-height:1.75rem;font-weight:700;color:var(--color-gray-900)}.nutriplan-card{background-color:#fff;border-radius:var(--radius-xl);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-card)}.nutriplan-card-hoverable{background-color:#fff;border-radius:var(--radius-xl);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-card);transition:all .2s}.nutriplan-card-hoverable:hover{box-shadow:var(--shadow-card-hover)}.nutriplan-card-lg{background-color:#fff;border-radius:var(--radius-2xl);border:1px solid var(--color-gray-100);box-shadow:var(--shadow-card);padding:1.5rem}.nutriplan-card-simple{background-color:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.nutriplan-empty{text-align:center;color:var(--color-gray-400);font-size:.875rem;padding-top:2rem;padding-bottom:2rem}.nutriplan-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:2rem}.nutriplan-pagination-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);transition:color .15s,background-color .15s}.nutriplan-pagination-btn:hover{background-color:var(--color-gray-50)}.nutriplan-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.nutriplan-grid-cards{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:768px){.nutriplan-grid-cards{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.nutriplan-grid-cards{grid-template-columns:repeat(3,1fr)}}.nutriplan-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.25rem}.nutriplan-input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);font-size:.875rem;outline:none;transition:all .15s}.nutriplan-input:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33}.nutriplan-search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;background-color:var(--color-gray-50);border:none;border-radius:var(--radius-xl);font-size:.875rem;transition:all .15s}.nutriplan-search-input::placeholder{color:var(--color-gray-400)}.nutriplan-search-input:focus{background-color:#fff;box-shadow:0 0 0 2px #2d8c4e33}.nutriplan-select{display:inline-block;min-width:8rem;padding:.625rem 2.5rem .625rem 1rem;background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);font-size:.875rem;line-height:1.25rem;color:var(--color-gray-700);cursor:pointer;outline:none;transition:all .15s;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right .75rem center!important;background-size:1rem!important}.nutriplan-select::-ms-expand{display:none}.nutriplan-select:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.nutriplan-select--flat{background-color:var(--color-gray-50);border-color:transparent}.nutriplan-select--flat:hover{border-color:var(--color-gray-300)}.nutriplan-checkbox{width:1rem;height:1rem;border-radius:.25rem;border:1px solid var(--color-gray-300);cursor:pointer;accent-color:var(--color-primary)}.nutriplan-checkbox:focus{box-shadow:0 0 0 2px #2d8c4e4d}.nutriplan-radio{width:1rem;height:1rem;border:1px solid var(--color-gray-300);cursor:pointer;accent-color:var(--color-primary)}.nutriplan-radio:focus{box-shadow:0 0 0 2px #2d8c4e4d}.nutriplan-textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);font-size:.875rem;color:var(--color-gray-700);resize:none;transition:all .15s}.nutriplan-textarea::placeholder{color:var(--color-gray-400)}.nutriplan-textarea:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.nutriplan-th{font-size:.75rem;font-weight:600;color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.05em}.nutriplan-icon-btn{width:2rem;height:2rem;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-gray-400);transition:color .15s,background-color .15s}.nutriplan-icon-btn:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);font-weight:500;transition:all .2s}.btn:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 1px #fff,0 0 0 3px #2d8c4e4d}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-image:linear-gradient(to bottom,var(--color-primary),var(--color-primary-dark));color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.btn-primary:active:not(:disabled){box-shadow:0 1px 2px #0000000d}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-dark)}.btn-outline{border:1px solid var(--color-gray-200);color:var(--color-text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-ghost{color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-primary-lighter);color:var(--color-primary)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#e5484de6}.btn-sm{padding:.375rem .75rem;font-size:.875rem}.btn-md{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-full{width:100%}.btn-spinner{animation:spin 1s linear infinite;height:1rem;width:1rem}.card{background-color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid var(--color-gray-100)}.card-hoverable{transition:all .2s;cursor:pointer}.card-hoverable:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-gray-200)}.card-title{font-weight:600;font-size:1.125rem;line-height:1.75rem;color:var(--color-gray-900);margin-bottom:1rem}.input-field{width:100%;padding:.625rem .875rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);font-size:.875rem;transition:all .2s}.input-field::placeholder{color:var(--color-gray-400)}.input-field:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.input-field:disabled{background-color:var(--color-gray-100);cursor:not-allowed}.input-field-error{border-color:var(--color-danger);box-shadow:0 0 0 1px #e5484d33}.badge{display:inline-flex;align-items:center;border-radius:var(--radius-full);font-weight:600}.badge-sm{padding:.125rem .5rem;font-size:.75rem}.badge-md{padding:.25rem .625rem;font-size:.875rem}.badge-primary{background-color:var(--color-primary-light);color:var(--color-primary-dark)}.badge-success{background-color:#f0fdf4;color:#15803d}.badge-warning{background-color:#fffbeb;color:#b45309}.badge-danger{background-color:#fef2f2;color:#b91c1c}.badge-gray{background-color:var(--color-gray-100);color:var(--color-gray-600)}.badge-breakfast{background-color:var(--color-meal-breakfast-bg);color:var(--color-meal-breakfast-text)}.badge-lunch{background-color:var(--color-meal-lunch-bg);color:var(--color-meal-lunch-text)}.badge-dinner{background-color:var(--color-meal-dinner-bg);color:var(--color-meal-dinner-text)}.badge-snack{background-color:var(--color-meal-snack-bg);color:var(--color-meal-snack-text)}.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center}.modal-backdrop{position:fixed;inset:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background-color:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-modal);width:100%;margin-left:1rem;margin-right:1rem;max-height:85vh;display:flex;flex-direction:column;animation:scaleIn .2s ease-out}.modal-sm{max-width:24rem}.modal-md{max-width:32rem}.modal-lg{max-width:42rem}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-gray-100)}.modal-header-title{font-size:1.125rem;line-height:1.75rem;font-weight:700;color:var(--color-gray-900)}.modal-close-btn{border-radius:var(--radius-full);width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;color:var(--color-gray-400);transition:background-color .15s,color .15s}.modal-close-btn:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.modal-body{padding:1.25rem 1.5rem;overflow-y:auto}.modal-body--overflow-visible{overflow:visible!important}.modal-footer{padding:1rem 1.5rem;background-color:#fafaf880;border-top:1px solid var(--color-gray-100);border-bottom-left-radius:var(--radius-2xl);border-bottom-right-radius:var(--radius-2xl)}.sidebar{width:15rem;height:100vh;position:fixed;left:0;top:0;background-color:var(--color-bg-sidebar);display:flex;flex-direction:column}.sidebar-logo{padding:1.25rem}.sidebar-logo-link{display:flex;align-items:center;gap:.625rem}.sidebar-logo-icon{width:2.25rem;height:2.25rem;background-color:var(--color-primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center}.sidebar-logo-title{font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.025em}.sidebar-logo-subtitle{display:block;font-size:10px;color:#ffffff80;font-weight:500}.sidebar-nav{flex:1;padding:.75rem 1rem}.sidebar-nav-list{display:flex;flex-direction:column;gap:.25rem}.sidebar-separator{border-top:1px solid rgba(255,255,255,.1);margin-top:.75rem;margin-bottom:.75rem}.sidebar-nav-link{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:var(--radius-xl);font-size:.875rem;transition:background-color .15s,color .15s}.sidebar-nav-link-active{background-color:var(--color-bg-sidebar-active);color:#fff;font-weight:600}.sidebar-nav-link-inactive{color:#fff9;font-weight:500}.sidebar-nav-link-inactive:hover{background-color:var(--color-bg-sidebar-hover);color:#fff}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-version{font-size:.75rem;color:#ffffff4d}.header{background-color:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-bottom:1px solid var(--color-gray-100);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30}.header-title{font-size:1.25rem;line-height:1.75rem;font-weight:700;color:var(--color-gray-900);letter-spacing:-.025em}.header-user{display:flex;align-items:center;gap:1rem}.header-user-info{display:flex;align-items:center;gap:.5rem}.header-avatar{width:2rem;height:2rem;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.header-avatar-img{width:100%;height:100%;object-fit:cover}.header-avatar-placeholder{width:100%;height:100%;background-color:var(--color-primary-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700}.header-username{font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.loading-spinner-container{display:flex;align-items:center;justify-content:center;padding-top:3rem;padding-bottom:3rem}.loading-spinner{height:2rem;width:2rem;animation:spin 1s linear infinite;border-radius:var(--radius-full);border:4px solid var(--color-gray-200);border-top-color:var(--color-primary)}.skeleton{background-color:var(--color-gray-200);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-text{height:1rem;border-radius:var(--radius-md)}.skeleton-rect{border-radius:var(--radius-lg)}.skeleton-circle{border-radius:var(--radius-full)}.toast-container{position:fixed;top:1.5rem;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:column;align-items:center}.toast-item{background-color:#fff;border-radius:var(--radius-xl);box-shadow:0 8px 32px #1c19172e,0 2px 8px #1c191714;padding:1rem 1.25rem;margin-bottom:.5rem;min-width:22rem;max-width:28rem;display:flex;align-items:flex-start;gap:.75rem;animation:slideIn .3s ease-out;border-left:4px solid transparent}.toast-icon{width:1.5rem;height:1.5rem;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.toast-icon-success{background-color:#dcfce7;color:#16a34a}.toast-icon-error{background-color:#fee2e2;color:#dc2626}.toast-icon-info{background-color:#dbeafe;color:#2563eb}.toast-icon-warning{background-color:#fef3c7;color:#d97706}.toast-item-success{border-left-color:#16a34a}.toast-item-error{border-left-color:#dc2626}.toast-item-info{border-left-color:#2563eb}.toast-item-warning{border-left-color:#d97706}.toast-message{font-size:.875rem;font-weight:500;color:var(--color-gray-800);flex:1}.toast-close{color:var(--color-gray-400);font-size:.75rem;flex-shrink:0}.toast-close:hover{color:var(--color-gray-600)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}body{background-color:var(--color-bg-secondary);color:var(--color-text-primary);font-family:var(--font-sans)}.login-container{display:flex;min-height:100vh}.login-branding{display:none;position:relative;overflow:hidden;background:linear-gradient(to bottom right,var(--color-primary),var(--color-primary-dark),#0F4A24)}@media(min-width:1024px){.login-branding{display:flex;width:50%}}.login-branding-circle-1{position:absolute;top:5rem;left:2.5rem;width:16rem;height:16rem;background-color:#ffffff0d;border-radius:9999px;filter:blur(40px)}.login-branding-circle-2{position:absolute;bottom:5rem;right:2.5rem;width:20rem;height:20rem;background-color:rgba(var(--color-accent-rgb, 255, 165, 0),.1);border-radius:9999px;filter:blur(64px)}.login-branding-content{position:relative;z-index:10;display:flex;flex-direction:column;justify-content:center;padding-left:4rem;padding-right:4rem}.login-branding-icon{width:3.5rem;height:3.5rem;background-color:#ffffff26;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.login-branding-icon svg{height:2rem;width:2rem;color:#fff}.login-branding-title{font-size:2.25rem;font-weight:700;color:#fff;margin-bottom:1rem;line-height:1.25}.login-branding-desc{font-size:1.125rem;color:#ffffffb3;line-height:1.75}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding-left:2rem;padding-right:2rem;background-color:var(--color-bg-secondary, #f9fafb)}.login-form-wrapper{max-width:24rem;width:100%}.login-mobile-logo{text-align:center;margin-bottom:2.5rem}@media(min-width:1024px){.login-mobile-logo{display:none}}.login-mobile-logo-icon{width:3rem;height:3rem;background-color:var(--color-primary);border-radius:1rem;display:flex;align-items:center;justify-content:center;margin-left:auto;margin-right:auto;margin-bottom:.75rem}.login-mobile-logo-icon svg{height:1.75rem;width:1.75rem;color:#fff}.login-mobile-logo-title{font-size:1.25rem;font-weight:700;color:#111827}.login-heading{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.25rem}.login-subheading{font-size:.875rem;color:#6b7280;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-submit-btn{border-radius:.75rem;height:3rem}.login-toggle-section{margin-top:2rem;text-align:center;font-size:.875rem}.login-toggle-text{color:var(--color-text-secondary, #6b7280)}.login-toggle-btn{color:var(--color-primary);font-weight:500;background:none;border:none;cursor:pointer;padding:0}.login-toggle-btn:hover{color:var(--color-primary-dark)}.calendar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem .5rem}.calendar-header-nav{display:flex;align-items:center;gap:.75rem}.calendar-header-nav-btn{width:2.25rem;height:2.25rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#6b7280;background:none;border:none;cursor:pointer;transition:background-color .15s ease,color .15s ease}.calendar-header-nav-btn:hover{background-color:#f3f4f6;color:#374151}.calendar-header-nav-btn svg{height:1.25rem;width:1.25rem}.calendar-header-title{font-size:1.25rem;font-weight:700;color:#111827;min-width:140px;text-align:center}.calendar-header-actions{display:flex;align-items:center;gap:.5rem}.calendar-header-today-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-primary);border:1px solid rgba(45,140,78,.3);border-radius:.5rem;background:none;cursor:pointer;transition:background-color .15s ease}.calendar-header-today-btn:hover{background-color:var(--color-primary-lighter, #F0FAF3)}.meal-type-tab-bar{padding:0 .5rem}.meal-type-tab-bar__tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--color-gray-200);overflow-x:auto;-webkit-overflow-scrolling:touch}.meal-type-tab-bar__tab{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .15s ease;margin-bottom:-1px}.meal-type-tab-bar__tab:hover{color:var(--color-text-primary);background-color:var(--color-gray-50)}.meal-type-tab-bar__tab--active{color:var(--color-primary);font-weight:600;border-bottom-color:var(--color-primary)}.meal-type-tab-bar__tab--active:hover{color:var(--color-primary);background-color:var(--color-primary-lighter)}.meal-type-tab-bar__tab-label{line-height:1}.meal-type-tab-bar__tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.125rem;padding:0 .375rem;font-size:.6875rem;font-weight:600;border-radius:var(--radius-full);background-color:var(--color-gray-100);color:var(--color-text-secondary)}.meal-type-tab-bar__tab--active .meal-type-tab-bar__tab-count{background-color:var(--color-primary-light);color:var(--color-primary)}@media(max-width:768px){.meal-type-tab-bar__tabs{scrollbar-width:none;-ms-overflow-style:none}.meal-type-tab-bar__tabs::-webkit-scrollbar{display:none}}.calendar-cell{min-height:100px;padding:.5rem;cursor:pointer;transition:background-color .15s ease;position:relative;background-color:#fff}.calendar-cell:hover{background-color:#f9fafb}.calendar-cell.other-month{background-color:#f9fafb80}.calendar-cell.selected{background-color:var(--color-primary-lighter, #F0FAF3);box-shadow:inset 0 0 0 2px #2d8c4e4d}.calendar-cell-day{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;font-size:.875rem;font-weight:500;border-radius:9999px}.calendar-cell-day.today{background-color:var(--color-primary);color:#fff}.calendar-cell-day.other-month{color:#d1d5db}.calendar-cell-day.current-month{color:#374151}.calendar-cell-meals{margin-top:.25rem;display:flex;flex-direction:column;gap:.125rem}.calendar-cell-meal-tag{font-size:11px;font-weight:500;padding:.125rem .375rem;border-radius:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-cell-meal-tag.breakfast{background-color:var(--color-meal-breakfast-bg, #FEF3C7);color:var(--color-meal-breakfast-text, #92400E)}.calendar-cell-meal-tag.lunch{background-color:var(--color-meal-lunch-bg, #DBEAFE);color:var(--color-meal-lunch-text, #1E40AF)}.calendar-cell-meal-tag.dinner{background-color:var(--color-meal-dinner-bg, #FCE7F3);color:var(--color-meal-dinner-text, #9D174D)}.calendar-cell-meal-tag.snack{background-color:var(--color-meal-snack-bg, #D1FAE5);color:var(--color-meal-snack-text, #065F46)}.calendar-grid-wrapper{border-radius:.75rem;border:1px solid #e5e7eb;overflow:hidden;background-color:#fff}.calendar-day-labels{display:grid;grid-template-columns:repeat(7,1fr);background-color:#f9fafbcc}.calendar-day-label{padding:.75rem 0;text-align:center;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af}.calendar-day-label.sunday{color:#f87171}.calendar-day-label.saturday{color:#60a5fa}.calendar-date-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-date-grid>*{border-right:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6}.calendar-date-grid>*:nth-child(7n){border-right:none}.calendar-grid-wrapper{transition:opacity .2s ease}.calendar-grid-wrapper.calendar-grid-loading{opacity:.4;pointer-events:none}.meal-slot{border-radius:.75rem;border:1px solid var(--color-gray-100, #F5F4F1);overflow:hidden}.meal-slot__header{padding:.5rem 1rem .625rem;display:flex;align-items:center;justify-content:space-between}.meal-slot__header--breakfast{background-color:var(--color-meal-breakfast-bg, #FFF7E6)}.meal-slot__header--lunch{background-color:var(--color-meal-lunch-bg, #E8F5EC)}.meal-slot__header--dinner{background-color:var(--color-meal-dinner-bg, #EEF0FF)}.meal-slot__header--snack{background-color:var(--color-meal-snack-bg, #FDF2F8)}.meal-slot__header-left{display:flex;align-items:center;gap:.5rem}.meal-slot__dot{width:.625rem;height:.625rem;border-radius:9999px}.meal-slot__dot--breakfast{background-color:var(--color-meal-breakfast, #F5A623)}.meal-slot__dot--lunch{background-color:var(--color-meal-lunch, #2D8C4E)}.meal-slot__dot--dinner{background-color:var(--color-meal-dinner, #6366F1)}.meal-slot__dot--snack{background-color:var(--color-meal-snack, #EC4899)}.meal-slot__label{font-size:.875rem;font-weight:600}.meal-slot__add-btn{font-size:.75rem;font-weight:500;color:var(--color-primary, #2D8C4E);background:transparent;border:none;cursor:pointer;transition:color .15s ease;padding:0}.meal-slot__add-btn:hover{color:var(--color-primary-dark, #1E6B38)}.meal-slot__body{padding:.75rem 1rem}.meal-slot__empty{font-size:.875rem;color:var(--color-gray-400, #A8A29E);text-align:center;padding:.75rem 0}.meal-slot__list{display:flex;flex-direction:column;gap:.5rem}.meal-slot__item{display:flex;align-items:center;justify-content:space-between;padding:.375rem 0}.meal-slot__item-name{font-size:.875rem;font-weight:500;color:var(--color-gray-800, #292524)}.meal-slot__item-calories{font-size:.75rem;color:var(--color-gray-400, #A8A29E);margin-left:.5rem}.meal-slot__item-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s ease}.meal-slot__item:hover .meal-slot__item-actions{opacity:1}.meal-slot__action-btn{width:1.75rem;height:1.75rem;border-radius:var(--radius-md, .5rem);display:flex;align-items:center;justify-content:center;color:var(--color-gray-400, #A8A29E);background:transparent;border:none;cursor:pointer;transition:all .15s ease}.meal-slot__action-btn:hover{background-color:var(--color-gray-100, #F5F4F1);color:var(--color-gray-600, #57534E)}.meal-slot__action-btn--delete:hover{color:var(--color-danger, #E5484D)}.meal-slot__action-btn svg{height:.875rem;width:.875rem}.daily-panel{width:24rem;border-left:1px solid #e5e7eb;background-color:#fff;height:100%;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column}.daily-panel-header{padding:1.25rem 1.5rem;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between}.daily-panel-title{font-size:1rem;font-weight:700;color:#111827}.daily-panel-subtitle{font-size:.75rem;color:#9ca3af;margin-top:.125rem}.daily-panel-close{width:2rem;height:2rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#9ca3af;background:transparent;border:none;cursor:pointer;transition:all .15s ease}.daily-panel-close:hover{background-color:#f3f4f6;color:#4b5563}.daily-panel-close svg{height:1.25rem;width:1.25rem}.daily-panel-body{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1rem}.daily-panel-skeleton{border-radius:.75rem;border:1px solid #f3f4f6;padding:1rem}.custom-select{position:relative;display:inline-block;min-width:8rem}.custom-select--full{width:100%}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.625rem 2.25rem .625rem 1rem;background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);font-size:.875rem;line-height:1.25rem;color:var(--color-gray-700);cursor:pointer;outline:none;transition:all .15s;text-align:left}.custom-select-trigger:hover{border-color:var(--color-gray-300)}.custom-select-trigger:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.custom-select-trigger.open{box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.custom-select--flat .custom-select-trigger{background-color:var(--color-gray-50);border-color:transparent}.custom-select--flat .custom-select-trigger:hover{border-color:var(--color-gray-300)}.custom-select-arrow{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--color-gray-400);transition:transform .2s;pointer-events:none}.custom-select-arrow.open{transform:translateY(-50%) rotate(180deg)}.custom-select-placeholder{color:var(--color-gray-400)}.custom-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);box-shadow:var(--shadow-dropdown);max-height:15rem;overflow-y:auto;padding:.25rem;animation:scaleIn .15s ease-out}.custom-select-option{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;font-size:.875rem;color:var(--color-gray-700);border-radius:var(--radius-lg);cursor:pointer;transition:background-color .1s;list-style:none}.custom-select-option:hover{background-color:var(--color-primary-lighter);color:var(--color-primary-dark)}.custom-select-option--selected{background-color:var(--color-primary-light);color:var(--color-primary-dark);font-weight:500}.custom-select-check{width:1rem;height:1rem;color:var(--color-primary)}.meal-edit-form{display:flex;flex-direction:column;gap:1rem}.meal-edit-header-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.meal-edit-group-selector{min-width:10rem}.meal-edit-group-warning{font-size:.75rem;color:#ef4444;font-weight:500}.meal-edit-search-row{display:flex;flex-direction:column;gap:.75rem}@media(min-width:640px){.meal-edit-search-row{flex-direction:row}}.meal-edit-search-wrapper{position:relative;flex:1}.meal-edit-search-wrapper svg{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:#9ca3af}.meal-edit-search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;background-color:#f9fafb;border:none;border-radius:.75rem;font-size:.875rem;transition:all .15s ease}.meal-edit-search-input::placeholder{color:#9ca3af}.meal-edit-search-input:focus{outline:none;background-color:#fff;box-shadow:0 0 0 2px #2d8c4e33}.meal-edit-results-loading{display:flex;flex-direction:column;gap:.5rem}.meal-edit-no-results{text-align:center;padding:2rem 0;font-size:.875rem;color:#9ca3af}.meal-edit-results-list{max-height:20rem;overflow-y:auto;border-radius:.75rem;border:1px solid #f3f4f6}.meal-edit-results-list>*+*{border-top:1px solid #f9fafb}.meal-edit-menu-btn{width:100%;text-align:left;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;background:transparent;border:none;cursor:pointer;transition:background-color .15s ease}.meal-edit-menu-btn:hover{background-color:var(--color-primary-lighter, #F0FAF3)}.meal-edit-menu-btn--selected,.meal-edit-menu-btn--selected:hover{background-color:var(--color-primary-light, #E8F5EC)}.meal-edit-menu-checkbox-area{display:flex;align-items:center;gap:.75rem}.meal-edit-checkbox{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:var(--radius-sm, .375rem);border:2px solid var(--color-gray-300, #D4D1CB);background:transparent;flex-shrink:0;transition:all .15s ease}.meal-edit-checkbox svg{width:.75rem;height:.75rem}.meal-edit-checkbox--checked{background-color:var(--color-primary, #2D8C4E);border-color:var(--color-primary, #2D8C4E);color:#fff}.meal-edit-menu-name{font-size:.875rem;font-weight:500;color:#1f2937}.meal-edit-menu-category{display:block;font-size:.75rem;color:#9ca3af}.meal-edit-menu-calories{font-size:.75rem;color:#9ca3af;transition:color .15s ease;flex-shrink:0}.meal-edit-menu-btn:hover .meal-edit-menu-calories{color:var(--color-primary)}.meal-edit-selection-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:var(--color-primary-lighter, #F0FAF3);border:1px solid var(--color-primary-light, #E8F5EC);border-radius:var(--radius-lg, .75rem);gap:1rem}.meal-edit-selection-info{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.meal-edit-selection-count{font-size:.875rem;font-weight:600;color:var(--color-primary, #2D8C4E)}.meal-edit-selection-calories{font-size:.75rem;color:var(--color-text-secondary, #78716C)}.meal-edit-selection-clear{font-size:.75rem;color:var(--color-text-secondary, #78716C);background:transparent;border:none;cursor:pointer;text-decoration:underline;padding:0}.meal-edit-selection-clear:hover{color:var(--color-text-primary, #1C1917)}.meal-edit-selection-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.meal-edit-btn-cancel{padding:.5rem .875rem;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary, #78716C);background:transparent;border:1px solid var(--color-gray-300, #D4D1CB);border-radius:var(--radius-md, .5rem);cursor:pointer;transition:all .15s ease}.meal-edit-btn-cancel:hover{background-color:var(--color-gray-50, #FAFAF8);border-color:var(--color-gray-400, #A8A29E)}.meal-edit-btn-submit{padding:.5rem 1rem;font-size:.8125rem;font-weight:600;color:#fff;background-color:var(--color-primary, #2D8C4E);border:none;border-radius:var(--radius-md, .5rem);cursor:pointer;transition:all .15s ease;white-space:nowrap}.meal-edit-btn-submit:hover{background-color:var(--color-primary-dark, #1E6B38)}.meal-edit-btn-submit:disabled{opacity:.6;cursor:not-allowed}.calendar-layout{display:flex;height:calc(100vh - 73px);gap:0}.calendar-main{flex:1;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.calendar-group-selector-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem .5rem 0}.calendar-content{flex:1;overflow:auto;padding:.25rem}.calendar-skeleton-wrapper{border-radius:.75rem;border:1px solid #e5e7eb;overflow:hidden}.calendar-skeleton-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}.calendar-skeleton-cell{min-height:100px;padding:.5rem;border:1px solid #f3f4f6}.calendar-side-panel{transition:all .3s ease-in-out;overflow:hidden}.calendar-side-panel.open{width:24rem}.calendar-side-panel.closed{width:0}.menu-search{display:flex;flex-direction:column;gap:.75rem}.menu-search-input-container{position:relative}.menu-search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:#9ca3af}.menu-search-input{width:100%;padding:.625rem 1rem .625rem 2.5rem;background-color:#f9fafb;border:none;border-radius:.75rem;font-size:.875rem;transition:all .15s ease;outline:none}.menu-search-input::placeholder{color:#9ca3af}.menu-search-input:focus{background-color:#fff;box-shadow:0 0 0 2px #2d8c4e33}.menu-search-categories{display:flex;flex-wrap:wrap;gap:.375rem}.menu-search-category-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:.625rem;font-size:.8125rem;font-weight:500;transition:all .2s ease;border:1px solid;white-space:nowrap;cursor:pointer}.menu-search-category-btn.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 1px 2px #0000000d}.menu-search-category-btn.inactive{background-color:#fff;border-color:#e5e7eb;color:#4b5563}.menu-search-category-btn.inactive:hover{background-color:#f9fafb;border-color:#d1d5db}.menu-search-category-emoji{font-size:.875rem;line-height:1}.menu-card{background-color:#fff;border-radius:.75rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));transition:all .2s ease;overflow:hidden;cursor:pointer}.menu-card:hover{box-shadow:var(--shadow-card-hover, 0 4px 12px rgba(0,0,0,.1))}.menu-card-header{padding:1.25rem 1.25rem .75rem;display:flex;align-items:center;justify-content:space-between}.menu-card-category{font-size:.75rem;font-weight:600;color:var(--color-primary);background-color:var(--color-primary-lighter, #F0FAF3);padding:.25rem .625rem;border-radius:9999px}.menu-card-favorite-btn{flex-shrink:0;background:none;border:none;cursor:pointer;padding:0}.menu-card-favorite-icon{width:1.25rem;height:1.25rem;transition:color .15s ease}.menu-card-favorite-icon.active{color:var(--color-secondary, #F59E0B);fill:var(--color-secondary, #F59E0B)}.menu-card-favorite-icon.inactive{color:#d1d5db}.menu-card-favorite-icon.inactive:hover{color:#9ca3af}.menu-card-body{padding:0 1.25rem 1rem}.menu-card-name{font-size:1rem;font-weight:700;color:#111827;margin-bottom:.25rem}.menu-card-description{font-size:.875rem;color:#6b7280;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.75rem}.menu-card-nutrients{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:#6b7280}.menu-card-calories{font-weight:600;color:#111827}.menu-card-calories-unit{font-weight:400;color:#9ca3af;margin-left:.125rem}.menu-card-actions{padding:.75rem 1.25rem;border-top:1px solid #f9fafb;display:flex;justify-content:flex-end;gap:.5rem;opacity:0;transition:opacity .15s ease}.menu-card:hover .menu-card-actions{opacity:1}.menu-card-action-btn{font-size:.75rem;color:#9ca3af;background:none;border:none;cursor:pointer;padding:0;transition:color .15s ease}.menu-card-action-btn.edit:hover{color:var(--color-primary)}.menu-card-action-btn.delete:hover{color:var(--color-danger, #EF4444)}.menu-list-empty{text-align:center;padding:3rem 0;color:var(--color-text-secondary, #6b7280)}.menu-list-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:640px){.menu-list-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.menu-list-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.menu-list-grid{grid-template-columns:repeat(4,1fr)}}.menu-search-card{padding:1.25rem;margin-bottom:1.5rem}.menu-search-row{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;gap:1rem}@media(min-width:640px){.menu-search-row{flex-direction:row;align-items:flex-start}}.menu-search-input-wrapper{flex:1;width:100%}.menu-add-btn{flex-shrink:0;border-radius:.75rem;gap:.5rem}.menu-add-btn svg{height:1rem;width:1rem}.menu-result-count{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;transition:opacity .2s ease}.menu-result-count.is-loading{opacity:.5}.menu-result-count-text{font-size:.875rem;color:#6b7280}.menu-result-count-number{font-weight:600;color:#374151}.menu-result-keyword-badge{display:inline-flex;align-items:center;padding:.125rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary)}.menu-skeleton-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:640px){.menu-skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.menu-skeleton-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.menu-skeleton-grid{grid-template-columns:repeat(4,1fr)}}.menu-skeleton-card{background-color:#fff;border-radius:.75rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));overflow:hidden;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.menu-skeleton-header{padding:1.25rem 1.25rem .75rem;display:flex;align-items:center;justify-content:space-between}.menu-skeleton-badge{height:1.25rem;width:4rem;background-color:#e5e7eb;border-radius:9999px}.menu-skeleton-icon{height:1.25rem;width:1.25rem;background-color:#e5e7eb;border-radius:9999px}.menu-skeleton-body{padding:0 1.25rem 1rem}.menu-skeleton-title{height:1.25rem;width:75%;background-color:#e5e7eb;border-radius:.375rem;margin-bottom:.5rem}.menu-skeleton-desc{height:1rem;width:100%;background-color:#f3f4f6;border-radius:.375rem;margin-bottom:.75rem}.menu-skeleton-nutrients{display:flex;gap:1rem}.menu-skeleton-nutrient{height:.75rem;background-color:#f3f4f6;border-radius:.25rem}.menu-skeleton-nutrient:nth-child(1){width:3rem}.menu-skeleton-nutrient:nth-child(2){width:2.5rem}.menu-skeleton-nutrient:nth-child(3){width:2.5rem}.menu-skeleton-nutrient:nth-child(4){width:2.5rem}.menu-list-container{position:relative}.menu-loading-overlay{position:absolute;inset:0;z-index:10;display:flex;align-items:flex-start;justify-content:center;padding-top:5rem;pointer-events:none}.menu-loading-pill{display:flex;align-items:center;gap:.5rem;background-color:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.625rem 1rem;border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;border:1px solid #f3f4f6}.menu-loading-spinner{animation:spin 1s linear infinite;height:1rem;width:1rem;color:var(--color-primary)}@keyframes spin{to{transform:rotate(360deg)}}.menu-loading-spinner .spinner-track{opacity:.25}.menu-loading-spinner .spinner-head{opacity:.75}.menu-loading-text{font-size:.875rem;color:#6b7280;font-weight:500}.menu-list-content{transition:opacity .2s ease}.menu-list-content.is-loading{opacity:.4;pointer-events:none}.menu-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:2rem}.menu-pagination-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:background-color .15s ease,color .15s ease}.menu-pagination-btn:hover:not(:disabled){background-color:#f9fafb}.menu-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.menu-pagination-info{font-size:.875rem;color:#6b7280}.menu-modal-footer{display:flex;justify-content:flex-end;gap:.75rem}.menu-modal-cancel-btn{border-radius:.75rem;padding-left:1.5rem;padding-right:1.5rem}.menu-modal-save-btn{border-radius:.75rem;padding-left:1.5rem;padding-right:1.5rem;box-shadow:0 1px 2px #0000000d}.menu-modal-save-btn svg{height:1rem;width:1rem;margin-right:.375rem}.menu-modal-title-icon{display:flex;align-items:center;gap:.5rem}.menu-modal-title-icon-circle{width:2rem;height:2rem;border-radius:.75rem;background-color:var(--color-primary-lighter, #F0FAF3);display:flex;align-items:center;justify-content:center}.menu-modal-title-icon-circle svg{height:1.125rem;width:1.125rem;color:var(--color-primary)}.menu-form-sections{display:flex;flex-direction:column;gap:1.5rem}.menu-form-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.menu-form-section-icon{width:1.75rem;height:1.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.menu-form-section-icon.primary{background-color:var(--color-primary-lighter, #F0FAF3)}.menu-form-section-icon.secondary{background-color:var(--color-secondary-light, #FFF3E0)}.menu-form-section-icon svg{height:1rem;width:1rem}.menu-form-section-icon.primary svg{color:var(--color-primary)}.menu-form-section-icon.secondary svg{color:var(--color-secondary, #F59E0B)}.menu-form-section-title{font-size:.875rem;font-weight:600;color:#374151}.menu-form-fields{display:flex;flex-direction:column;gap:1rem;padding-left:.25rem}.menu-category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.menu-category-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .625rem;border-radius:.75rem;font-size:.75rem;font-weight:500;transition:all .2s ease;border:1px solid;cursor:pointer;background:none}.menu-category-btn.active{background-color:var(--color-primary-lighter, #F0FAF3);border-color:#2d8c4e4d;color:var(--color-primary);box-shadow:0 0 0 2px #2d8c4e1a,0 1px 2px #0000000d}.menu-category-btn.inactive{background-color:#f9fafb;border-color:#f3f4f6;color:#6b7280}.menu-category-btn.inactive:hover{background-color:#f3f4f6;border-color:#e5e7eb}.menu-category-emoji{font-size:1rem;line-height:1}.menu-category-label-required{color:var(--color-danger, #EF4444);margin-left:.125rem}.menu-nutrition-bg{background:linear-gradient(to bottom right,#f9fafbcc,#f0faf34d);border-radius:1rem;border:1px solid #f3f4f6;padding:1.25rem}.menu-nutrition-calorie{margin-bottom:1rem}.menu-nutrition-label{display:block;font-size:.75rem;font-weight:500;color:#6b7280;margin-bottom:.375rem}.menu-nutrition-input-wrapper{position:relative}.menu-nutrition-input{width:100%;padding:.75rem 4rem .75rem 1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;font-weight:600;color:#1f2937;transition:all .15s ease;outline:none}.menu-nutrition-input:focus{ring:2px solid rgba(45,140,78,.2);border-color:var(--color-primary);box-shadow:0 0 0 2px #2d8c4e33}.menu-nutrition-unit{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:500;color:#9ca3af}.menu-nutrition-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:640px){.menu-nutrition-grid{grid-template-columns:repeat(3,1fr)}}.menu-nutrition-field-input{width:100%;padding:.625rem 2.5rem .625rem .875rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;color:#374151;transition:all .15s ease;outline:none}.menu-nutrition-field-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #2d8c4e33}.menu-nutrition-field-unit{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:#9ca3af}.weekly-bar-chart-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:1.25rem}.weekly-bar-chart-rows{display:flex;flex-direction:column;gap:.75rem}.weekly-bar-row{display:flex;align-items:center;gap:.75rem}.weekly-bar-day-label{width:2.5rem;font-size:.875rem;font-weight:500;color:#6b7280;text-align:right;flex-shrink:0}.weekly-bar-track{flex:1;background-color:#f9fafb;border-radius:9999px;height:2rem;position:relative;overflow:hidden}.weekly-bar-fill{border-radius:9999px;height:2rem;transition:width .7s ease-out;display:flex;align-items:center;background:linear-gradient(to right,rgba(45,140,78,.7),var(--color-primary))}.weekly-bar-inner-label{font-size:.75rem;font-weight:600;color:#fff;padding-left:.75rem}.weekly-bar-value{width:6rem;font-size:.875rem;text-align:right;flex-shrink:0;font-weight:500;color:#374151}.daily-donut-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:1.25rem}.daily-donut-layout{display:flex;flex-direction:column;align-items:center;gap:2rem}@media(min-width:768px){.daily-donut-layout{flex-direction:row}}.daily-donut-chart-container{position:relative}.daily-donut-svg{width:14rem;height:14rem}.daily-donut-bg{stroke:#f9fafb}.daily-donut-segment-breakfast{stroke:var(--color-meal-breakfast, #F59E0B)}.daily-donut-segment-lunch{stroke:var(--color-meal-lunch, #3B82F6)}.daily-donut-segment-dinner{stroke:var(--color-meal-dinner, #EC4899)}.daily-donut-segment-snack{stroke:var(--color-meal-snack, #10B981)}.daily-donut-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.daily-donut-center-text{text-align:center}.daily-donut-total-value{font-size:1.875rem;font-weight:800;color:#111827}.daily-donut-total-unit{font-size:.75rem;font-weight:500;color:#9ca3af;margin-top:.125rem}.daily-donut-legend{display:flex;flex-direction:column;gap:.75rem}.daily-donut-legend-item{display:flex;align-items:center;gap:.75rem}.daily-donut-legend-dot{width:1rem;height:1rem;border-radius:.375rem}.daily-donut-legend-dot.breakfast{background-color:var(--color-meal-breakfast, #F59E0B)}.daily-donut-legend-dot.lunch{background-color:var(--color-meal-lunch, #3B82F6)}.daily-donut-legend-dot.dinner{background-color:var(--color-meal-dinner, #EC4899)}.daily-donut-legend-dot.snack{background-color:var(--color-meal-snack, #10B981)}.daily-donut-legend-info{flex:1}.daily-donut-legend-header{display:flex;align-items:center;gap:.5rem}.daily-donut-legend-name{font-size:.875rem;font-weight:600;color:#1f2937}.daily-donut-legend-percent{font-size:.75rem;color:#9ca3af}.daily-donut-legend-cal{font-size:.875rem;color:#6b7280}.daily-nutrition-table-title{font-size:1rem;font-weight:700;color:#111827;padding:1.5rem 1.5rem 1rem}.daily-nutrition-table-scroll{overflow-x:auto}.daily-nutrition-table{width:100%;font-size:.875rem;border-collapse:collapse}.daily-nutrition-table thead tr{border-bottom:1px solid #f3f4f6}.daily-nutrition-table th{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.daily-nutrition-table th.col-date{text-align:left;padding-left:1.5rem}.daily-nutrition-table th.col-value{text-align:right}.daily-nutrition-table tbody tr{border-bottom:1px solid #f9fafb;transition:background-color .15s ease}.daily-nutrition-table tbody tr:hover{background-color:#f9fafb80}.daily-nutrition-table td{padding:1rem}.daily-nutrition-table td.cell-date{padding-left:1.5rem;font-weight:500;color:#1f2937}.daily-nutrition-table td.cell-value{text-align:right;color:#4b5563;font-variant-numeric:tabular-nums}.analysis-summary-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:640px){.analysis-summary-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.analysis-summary-grid{grid-template-columns:repeat(4,1fr)}}.analysis-summary-card{background-color:#fff;border-radius:1rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));padding:1.5rem;position:relative;overflow:hidden}.analysis-summary-card-accent{position:absolute;top:0;right:0;width:5rem;height:5rem;border-bottom-left-radius:2.5rem;opacity:.4}.analysis-summary-card-accent.accent-green{background-color:var(--color-primary-lighter, #D1FAE5)}.analysis-summary-card-accent.accent-amber{background-color:#fde68a}.analysis-summary-card-accent.accent-blue{background-color:#bfdbfe}.analysis-summary-card-accent.accent-rose{background-color:#fecdd3}.analysis-summary-card-content{position:relative}.analysis-summary-label{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.5rem}.analysis-summary-value{font-size:1.875rem;font-weight:800;color:#111827;letter-spacing:-.025em}.analysis-summary-unit{font-size:.875rem;font-weight:400;color:#9ca3af;margin-left:.25rem}.analysis-chart-section{margin-top:2rem}.analysis-chart-card{background-color:#fff;border-radius:1rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));padding:1.5rem}.analysis-table-section{margin-top:2rem}.analysis-table-card{background-color:#fff;border-radius:1rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));overflow:hidden}.analysis-empty{padding:3rem}.analysis-empty-content{text-align:center}.analysis-empty-icon{width:4rem;height:4rem;background-color:#f3f4f6;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.analysis-empty-icon svg{width:2rem;height:2rem;color:#9ca3af}.analysis-empty-title{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.analysis-empty-desc{color:#9ca3af;font-size:.75rem}.analysis-skeleton-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:640px){.analysis-skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.analysis-skeleton-grid{grid-template-columns:repeat(4,1fr)}}.analysis-skeleton-chart,.analysis-skeleton-table{margin-top:2rem}.analysis-controls{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:2rem}.analysis-view-toggle{display:inline-flex;background-color:#f3f4f6;border-radius:.75rem;padding:.25rem}.analysis-view-btn{padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:.5rem;transition:all .2s ease;border:none;cursor:pointer;background:none}.analysis-view-btn.active{background-color:#fff;color:#111827;box-shadow:0 1px 2px #0000000d}.analysis-view-btn.inactive{color:#6b7280}.analysis-view-btn.inactive:hover{color:#374151}.analysis-date-wrapper{position:relative}.analysis-date-input{padding:.625rem 1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;color:#374151;transition:all .15s ease;outline:none}.analysis-date-input:focus{box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.analysis-week-range{font-size:.875rem;color:#6b7280;background-color:#f9fafb;padding:.375rem .75rem;border-radius:.5rem}.food-searchbar-wrapper{position:relative;max-width:42rem;margin-left:auto;margin-right:auto}.food-searchbar-container{position:relative}.food-searchbar-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:#9ca3af}.food-searchbar-input{width:100%;padding:1rem 7rem 1rem 3.25rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:1rem;font-size:1rem;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));transition:all .15s ease;outline:none}.food-searchbar-input::placeholder{color:#9ca3af}.food-searchbar-input:focus{box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.food-searchbar-input:focus{box-shadow:var(--shadow-card-hover, 0 4px 12px rgba(0,0,0,.1)),0 0 0 2px #2d8c4e33}.food-searchbar-btn{position:absolute;right:.625rem;top:50%;transform:translateY(-50%);padding:.625rem 1.5rem;background-color:var(--color-primary);color:#fff;border-radius:.75rem;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:background-color .15s ease}.food-searchbar-btn:hover:not(:disabled){background-color:var(--color-primary-dark)}.food-searchbar-btn:disabled{opacity:.5;cursor:not-allowed}.food-result-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.food-result-grid{grid-template-columns:repeat(2,1fr)}}.food-result-empty{text-align:center;color:#9ca3af;padding:2rem 0}.food-result-item{background-color:#fff;border-radius:.75rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));padding:1.25rem;text-align:left;transition:all .2s ease;cursor:pointer;width:100%;display:block}.food-result-item:hover{box-shadow:var(--shadow-card-hover, 0 4px 12px rgba(0,0,0,.1))}.food-result-header{display:flex;align-items:flex-start;justify-content:space-between}.food-result-name{font-size:.875rem;font-weight:700;color:#111827;transition:color .15s ease}.food-result-item:hover .food-result-name{color:var(--color-primary)}.food-result-manufacturer{font-size:.75rem;color:#9ca3af;margin-top:.125rem;display:block}.food-result-calories{font-size:1.125rem;font-weight:800;color:var(--color-primary)}.food-result-calories-unit{font-size:.75rem;font-weight:400;color:#9ca3af;margin-left:.125rem}.food-result-nutrients{display:flex;align-items:center;gap:1rem;margin-top:.75rem;font-size:.75rem;color:#6b7280}.food-result-nutrients b{color:#374151}.food-detail-compact{width:100%;background-color:#fff;border-radius:.75rem;border:1px solid #f3f4f6;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06));padding:1.25rem;text-align:left;transition:all .2s ease;cursor:pointer;display:block}.food-detail-compact:hover{box-shadow:var(--shadow-card-hover, 0 4px 12px rgba(0,0,0,.1))}.food-detail-compact-header{display:flex;align-items:flex-start;justify-content:space-between}.food-detail-compact-name{font-size:.875rem;font-weight:700;color:#111827;transition:color .15s ease}.food-detail-compact:hover .food-detail-compact-name{color:var(--color-primary)}.food-detail-compact-manufacturer{font-size:.75rem;color:#9ca3af;margin-top:.125rem;display:block}.food-detail-compact-calories{font-size:1.125rem;font-weight:800;color:var(--color-primary)}.food-detail-compact-calories-unit{font-size:.75rem;font-weight:400;color:#9ca3af;margin-left:.125rem}.food-detail-compact-nutrients{display:flex;align-items:center;gap:1rem;margin-top:.75rem;font-size:.75rem;color:#6b7280}.food-detail-compact-nutrients b{color:#374151}.food-detail-full{display:flex;flex-direction:column;gap:1.25rem}.food-detail-header{text-align:center;padding-bottom:1.25rem;border-bottom:1px solid #f3f4f6}.food-detail-title{font-size:1.25rem;font-weight:700;color:#111827}.food-detail-manufacturer{font-size:.875rem;color:#9ca3af;margin-top:.25rem}.food-detail-calories-main{font-size:2.25rem;font-weight:800;color:var(--color-primary);margin-top:1rem}.food-detail-calories-main-unit{font-size:1rem;font-weight:400;color:#9ca3af;margin-left:.25rem}.food-detail-serving{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.food-detail-macros{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.food-detail-macro-card{border-radius:.75rem;padding:1rem;text-align:center}.food-detail-macro-card.carbs{background-color:#fffbeb}.food-detail-macro-card.protein{background-color:#eff6ff}.food-detail-macro-card.fat{background-color:#fff1f2}.food-detail-macro-label{font-size:.75rem;font-weight:600;margin-bottom:.25rem}.food-detail-macro-label.carbs{color:#d97706}.food-detail-macro-label.protein{color:#2563eb}.food-detail-macro-label.fat{color:#e11d48}.food-detail-macro-value{font-size:1.25rem;font-weight:800}.food-detail-macro-value.carbs{color:#b45309}.food-detail-macro-value.protein{color:#1d4ed8}.food-detail-macro-value.fat{color:#be123c}.food-detail-macro-value-unit{font-size:.75rem;font-weight:400}.food-detail-other{background-color:#f9fafb;border-radius:.75rem;padding:1rem}.food-detail-other-title{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.food-detail-other-list{display:flex;flex-direction:column;gap:.625rem}.food-detail-other-row{display:flex;align-items:center;justify-content:space-between}.food-detail-other-label{font-size:.875rem;color:#6b7280}.food-detail-other-value{font-size:.875rem;font-weight:600;color:#374151}.food-search-container{max-width:56rem;margin-left:auto;margin-right:auto}.food-search-header{text-align:center;margin-bottom:2rem}.food-search-title{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.5rem}.food-search-subtitle{font-size:.875rem;color:#6b7280}.food-search-results{margin-top:2rem}.food-search-empty{text-align:center;padding:4rem 0}.food-search-empty-icon{width:4rem;height:4rem;background-color:#f3f4f6;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin-left:auto;margin-right:auto;margin-bottom:1rem}.food-search-empty-icon svg{width:2rem;height:2rem;color:#9ca3af}.food-search-empty-text{color:#9ca3af;font-size:.875rem}.food-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:2rem}.food-pagination-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#4b5563;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;cursor:pointer;transition:all .15s ease}.food-pagination-btn:hover:not(:disabled){background-color:#f9fafb}.food-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.food-pagination-info{font-size:.875rem;font-weight:500;color:#6b7280;background-color:#f9fafb;padding:.5rem 1rem;border-radius:.5rem}.food-modal-footer{display:flex;justify-content:flex-end}.dietgroup-page{max-width:56rem;margin-left:auto;margin-right:auto}.dietgroup-header{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:2rem}@media(min-width:640px){.dietgroup-header{flex-direction:row;align-items:center;justify-content:space-between}}.dietgroup-title{font-size:1.5rem;font-weight:700;color:#111827}.dietgroup-subtitle{font-size:.875rem;color:#6b7280;margin-top:.25rem}.dietgroup-add-btn{flex-shrink:0;border-radius:.75rem;gap:.5rem}.dietgroup-add-btn svg{height:1rem;width:1rem}.dietgroup-modal-footer{display:flex;justify-content:flex-end;gap:.5rem}.dietgroup-form{display:flex;flex-direction:column;gap:1rem}.dietgroup-list{display:flex;flex-direction:column;gap:.75rem}.dietgroup-item{padding:1.25rem;display:flex;align-items:flex-start;justify-content:space-between}.dietgroup-item-name{display:flex;align-items:center;gap:.5rem}.dietgroup-item-name span{font-weight:600;color:#111827}.dietgroup-item-desc{font-size:.875rem;color:#6b7280;margin-top:.375rem}.dietgroup-item-actions{display:flex;gap:.5rem;flex-shrink:0;margin-left:1rem}.dietgroup-empty{padding:3rem}.dietgroup-empty-content{text-align:center}.dietgroup-empty-icon{width:4rem;height:4rem;background-color:#f3f4f6;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin-left:auto;margin-right:auto;margin-bottom:1rem}.dietgroup-empty-icon svg{width:2rem;height:2rem;color:#9ca3af}.dietgroup-empty-text{color:#9ca3af;font-size:.875rem}.genopts{display:flex;flex-direction:column;gap:1.25rem}.genopts-card{padding:1.5rem}.genopts-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}.genopts-icon-box{width:1.75rem;height:1.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.genopts-icon-box.primary{background-color:var(--color-primary-light, #E8F5EC)}.genopts-icon-box.secondary{background-color:var(--color-secondary-light, #FEF3C7)}.genopts-icon-box.accent{background-color:var(--color-accent-light, #EDE9FE)}.genopts-icon-box svg{width:1rem;height:1rem}.genopts-icon-box.primary svg{color:var(--color-primary)}.genopts-icon-box.secondary svg{color:var(--color-secondary, #f59e0b)}.genopts-icon-box.accent svg{color:var(--color-accent-dark, #6d28d9)}.genopts-date-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.25rem}@media(min-width:640px){.genopts-date-grid{grid-template-columns:repeat(2,1fr)}}.genopts-date-input{width:100%;padding:.625rem 1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;color:#374151;transition:all .15s ease}.genopts-date-input:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.genopts-day-count{margin-bottom:1.25rem;padding:.5rem .75rem;background-color:var(--color-primary-lighter, #F0FAF3);border-radius:.5rem;font-size:.875rem;color:var(--color-primary-dark, #1E6B38);display:inline-flex;align-items:center;gap:.375rem}.genopts-day-count svg{width:1rem;height:1rem}.genopts-meal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.genopts-meal-btn{position:relative;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:.75rem;border:2px solid transparent;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:pointer}.genopts-meal-btn.unchecked{background-color:#f9fafb;color:#9ca3af;border-color:transparent}.genopts-meal-btn.unchecked:hover{background-color:#f3f4f6}.genopts-meal-btn.checked{border-color:currentColor}.genopts-meal-btn.checked.breakfast{background-color:var(--color-meal-breakfast-bg);color:var(--color-meal-breakfast-text)}.genopts-meal-btn.checked.lunch{background-color:var(--color-meal-lunch-bg);color:var(--color-meal-lunch-text)}.genopts-meal-btn.checked.dinner{background-color:var(--color-meal-dinner-bg);color:var(--color-meal-dinner-text)}.genopts-meal-btn svg{width:1rem;height:1rem}.genopts-source-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media(min-width:640px){.genopts-source-grid{grid-template-columns:repeat(3,1fr)}}.genopts-source-btn{display:flex;flex-direction:column;align-items:flex-start;padding:1rem;border-radius:.75rem;border:2px solid;text-align:left;transition:all .2s ease;cursor:pointer;background:transparent}.genopts-source-btn.active{border-color:var(--color-primary);background-color:var(--color-primary-lighter, #F0FAF3)}.genopts-source-btn.inactive{border-color:#f3f4f6;background-color:#fff}.genopts-source-btn.inactive:hover{border-color:#e5e7eb;background-color:#f9fafb}.genopts-source-label-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.genopts-source-icon{font-size:1rem}.genopts-source-label{font-size:.875rem;font-weight:600}.genopts-source-label.active{color:var(--color-primary-dark, #1E6B38)}.genopts-source-label.inactive{color:#374151}.genopts-source-desc{font-size:.75rem}.genopts-source-desc.active{color:#1e6b38b3}.genopts-source-desc.inactive{color:#9ca3af}.genopts-facility-chips{display:flex;flex-wrap:wrap;gap:.5rem}.genopts-facility-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:.75rem;font-size:.875rem;font-weight:500;transition:all .2s ease;border:none;cursor:pointer}.genopts-facility-btn.active{background-color:var(--color-primary);color:#fff;box-shadow:0 1px 2px #0000000d}.genopts-facility-btn.inactive{background-color:#f9fafb;color:#4b5563}.genopts-facility-btn.inactive:hover{background-color:#f3f4f6}.genopts-facility-btn .icon{font-size:.75rem}.genopts-facility-input{margin-top:.75rem;width:100%;padding:.625rem 1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;color:#374151;transition:all .15s ease}.genopts-facility-input:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.genopts-advanced-toggle{width:100%;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;background:transparent;border:none;cursor:pointer;transition:background-color .15s ease}.genopts-advanced-toggle:hover{background-color:#f9fafb80}.genopts-advanced-left{display:flex;align-items:center;gap:.75rem}.genopts-advanced-text{text-align:left}.genopts-advanced-title{font-size:.875rem;font-weight:600;color:#111827;display:block}.genopts-advanced-subtitle{display:block;font-size:.75rem;color:#9ca3af}.genopts-advanced-right{display:flex;align-items:center;gap:.5rem}.genopts-restriction-badge{padding:.125rem .5rem;font-size:.75rem;font-weight:600;background-color:var(--color-primary-light, #E8F5EC);color:var(--color-primary);border-radius:9999px}.genopts-chevron{width:1.25rem;height:1.25rem;color:#9ca3af;transition:transform .3s ease}.genopts-chevron.open{transform:rotate(180deg)}.genopts-advanced-content{transition:max-height .3s ease-in-out,opacity .3s ease-in-out;overflow:hidden}.genopts-advanced-content.open{max-height:800px;opacity:1}.genopts-advanced-content.closed{max-height:0;opacity:0}.genopts-advanced-body{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;border-top:1px solid #f3f4f6}.genopts-exclude-row{display:flex;gap:.5rem;margin-bottom:.5rem}.genopts-exclude-input{flex:1;padding:.625rem 1rem;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;transition:all .15s ease}.genopts-exclude-input:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.genopts-exclude-add-btn{padding:.625rem 1rem;background-color:#f3f4f6;color:#4b5563;border-radius:.75rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:background-color .15s ease}.genopts-exclude-add-btn:hover{background-color:#e5e7eb}.genopts-exclude-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.genopts-exclude-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background-color:#fef2f2;color:#b91c1c;border-radius:9999px;font-size:.75rem;font-weight:500;border:1px solid #fecaca}.genopts-exclude-tag button{color:#f87171;background:transparent;border:none;cursor:pointer;padding:0;display:flex;transition:color .15s ease}.genopts-exclude-tag button:hover{color:#dc2626}.genopts-exclude-tag button svg{width:.875rem;height:.875rem}.genopts-allergy-chips{display:flex;flex-wrap:wrap;gap:.5rem}.genopts-allergy-btn{padding:.5rem .875rem;border-radius:.75rem;font-size:.75rem;font-weight:500;transition:all .2s ease;cursor:pointer}.genopts-allergy-btn.active{background-color:#fff7ed;color:#9a3412;border:1px solid #fed7aa;box-shadow:0 1px 2px #0000000d}.genopts-allergy-btn.inactive{background-color:#f9fafb;color:#6b7280;border:1px solid transparent}.genopts-allergy-btn.inactive:hover{background-color:#f3f4f6;color:#374151}.genopts-allergy-btn svg{width:.75rem;height:.75rem;display:inline;margin-right:.25rem}.genopts-nutrition-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.genopts-nutrition-grid{grid-template-columns:repeat(2,1fr)}}.genopts-nutrition-label{font-size:.75rem;color:#6b7280;margin-bottom:.375rem;display:block}.genopts-nutrition-input-wrapper{position:relative}.genopts-nutrition-input{width:100%;padding:.625rem 3.5rem .625rem 1rem;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.875rem;transition:all .15s ease}.genopts-nutrition-input:focus{outline:none;box-shadow:0 0 0 2px #2d8c4e33;border-color:var(--color-primary)}.genopts-nutrition-unit{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:#9ca3af;font-weight:500}.genopts-soft-food-label{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.75rem;background-color:#f9fafb;cursor:pointer;transition:background-color .15s ease}.genopts-soft-food-label:hover{background-color:#f3f4f6}.genopts-soft-food-text{font-size:.875rem;font-weight:500;color:#374151}.genopts-soft-food-desc{display:block;font-size:.75rem;color:#9ca3af}.genopts-submit-btn{border-radius:.75rem;padding-top:.875rem;padding-bottom:.875rem;font-size:1rem;box-shadow:0 1px 2px #0000000d}.genopts-submit-btn:hover{box-shadow:0 4px 6px -1px #0000001a}.genopts-submit-content{display:flex;align-items:center;gap:.5rem}.genopts-submit-content svg{width:1.25rem;height:1.25rem}@keyframes genopts-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.genopts-spinner{animation:genopts-spin 1s linear infinite;height:1.25rem;width:1.25rem}.genopts-spinner circle{opacity:.25}.genopts-spinner path{opacity:.75}.genopts-weekend-toggle{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.75rem;background-color:#f9fafb;cursor:pointer;transition:background-color .15s ease;margin-bottom:1.25rem}.genopts-weekend-toggle:hover{background-color:#f3f4f6}.genopts-weekend-text{font-size:.875rem;font-weight:500;color:#374151}.genopts-weekend-desc{display:block;font-size:.75rem;color:#9ca3af}.genopts-holiday-section{margin-bottom:1.25rem}.genopts-holiday-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.75rem;background-color:#fefce8;border:1px solid #fef08a;border-radius:.75rem}.genopts-holiday-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer}.genopts-holiday-date{font-weight:500;color:#374151}.genopts-holiday-name{padding:.125rem .5rem;background-color:#fef08a;color:#854d0e;border-radius:9999px;font-size:.75rem;font-weight:500}.genopts-holiday-hint{margin-top:.5rem;font-size:.75rem;color:#9ca3af}.genopts-manual-section{margin-bottom:1.25rem}.genopts-manual-date-row{display:flex;gap:.5rem;margin-top:.5rem}.genopts-manual-date-row .genopts-date-input{flex:1}.genopts-manual-date-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.genopts-manual-date-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background-color:#eff6ff;color:#1e40af;border-radius:9999px;font-size:.75rem;font-weight:500;border:1px solid #bfdbfe}.genopts-manual-date-tag button{color:#60a5fa;background:transparent;border:none;cursor:pointer;padding:0;display:flex;transition:color .15s ease}.genopts-manual-date-tag button:hover{color:#2563eb}.genopts-manual-date-tag button svg{width:.875rem;height:.875rem}.genopts-excluded-summary{padding:.625rem .75rem;background-color:var(--color-primary-lighter, #F0FAF3);border-radius:.5rem;font-size:.875rem;color:var(--color-primary-dark, #1E6B38);text-align:center}.genopts-label-mb-sm{margin-bottom:.5rem}.genopts-label-mb-md{margin-bottom:.75rem}.genopts-section-mb{margin-bottom:1.5rem}.genopts-card-overflow-hidden{overflow:hidden}.genopts-section-pt{padding-top:1.25rem}.genpreview-empty{padding:3rem;text-align:center}.genpreview-empty-icon{width:4rem;height:4rem;margin-left:auto;margin-right:auto;margin-bottom:1rem;border-radius:1rem;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center}.genpreview-empty-icon svg{width:2rem;height:2rem;color:#d1d5db}.genpreview-empty-text{font-size:.875rem;color:#9ca3af}.genpreview-empty-hint{font-size:.75rem;color:#d1d5db;margin-top:.25rem}.genpreview{display:flex;flex-direction:column;gap:1.25rem}.genpreview-header-card{padding:1.5rem}.genpreview-header-row{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}@media(min-width:640px){.genpreview-header-row{flex-direction:row;align-items:center;justify-content:space-between}}.genpreview-title-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.genpreview-title-icon{width:1.75rem;height:1.75rem;border-radius:.5rem;background-color:var(--color-primary-light, #E8F5EC);display:flex;align-items:center;justify-content:center}.genpreview-title-icon svg{width:1rem;height:1rem;color:var(--color-primary)}.genpreview-subtitle{font-size:.875rem;color:#6b7280;margin-left:2.25rem}.genpreview-header-actions{display:flex;gap:.5rem;width:100%}@media(min-width:640px){.genpreview-header-actions{width:auto}}.genpreview-header-actions .btn-flex{flex:1}@media(min-width:640px){.genpreview-header-actions .btn-flex{flex:none}}.genpreview-header-actions .btn-round{border-radius:.75rem}.genpreview-warning{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:.75rem}.genpreview-warning svg{width:1.25rem;height:1.25rem;color:var(--color-warning, #f59e0b);flex-shrink:0;margin-top:.125rem}.genpreview-warning p{font-size:.875rem;color:#854d0e}.genpreview-dates{display:flex;flex-direction:column;gap:1rem}.genpreview-date-header{padding:.75rem 1.25rem;background-color:#f9fafb;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;gap:.5rem}.genpreview-date-header svg{width:1rem;height:1rem;color:#9ca3af}.genpreview-date-label{font-size:.875rem;font-weight:700;color:#1f2937}.genpreview-date-raw{font-size:.75rem;color:#9ca3af}.genpreview-meal-grid-wrapper{padding:1rem}.genpreview-meal-grid{display:grid;grid-template-columns:1fr;gap:.75rem}@media(min-width:768px){.genpreview-meal-grid{grid-template-columns:repeat(3,1fr)}}.genpreview-meal-card{border-radius:.75rem;border:1px solid;padding:1rem;transition:all .15s ease}.genpreview-meal-card:hover{box-shadow:0 1px 2px #0000000d}.genpreview-meal-card.breakfast{background-color:var(--color-meal-breakfast-bg, #FFF8F0);border-color:rgba(var(--color-meal-breakfast-rgb, 249, 115, 22),.2)}.genpreview-meal-card.lunch{background-color:var(--color-meal-lunch-bg, #F0FFF4);border-color:rgba(var(--color-meal-lunch-rgb, 34, 197, 94),.2)}.genpreview-meal-card.dinner{background-color:var(--color-meal-dinner-bg, #F0F4FF);border-color:rgba(var(--color-meal-dinner-rgb, 59, 130, 246),.2)}.genpreview-meal-card.snack{background-color:var(--color-meal-snack-bg, #F5F3FF);border-color:rgba(var(--color-meal-snack-rgb, 139, 92, 246),.2)}.genpreview-meal-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.genpreview-meal-dot{width:.5rem;height:.5rem;border-radius:9999px}.genpreview-meal-badge{font-size:.75rem;font-weight:700;padding:.125rem .5rem;border-radius:.375rem}.genpreview-meal-count{font-size:.75rem;color:#9ca3af;margin-left:auto}.genpreview-menu-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.genpreview-menu-item{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:#374151}.genpreview-menu-dot{width:.25rem;height:.25rem;border-radius:9999px;background-color:#d1d5db;margin-top:.5rem;flex-shrink:0}.genpreview-footer{padding:1rem;display:flex;align-items:center;justify-content:space-between}.genpreview-footer-text{font-size:.875rem;color:#6b7280}.genpreview-footer-text strong{color:#111827}.genpreview-footer-actions{display:flex;gap:.5rem}.genpreview-footer-actions .btn-round{border-radius:.75rem}.generate-page{max-width:56rem;margin-left:auto;margin-right:auto}.generate-header{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:2rem}@media(min-width:640px){.generate-header{flex-direction:row;align-items:center;justify-content:space-between}}.generate-title{font-size:1.5rem;font-weight:700;color:#111827}.generate-subtitle{font-size:.875rem;color:#6b7280;margin-top:.25rem}.generate-steps-card{padding:1rem;margin-bottom:1.5rem}.generate-steps{display:flex;align-items:center;justify-content:space-between}.generate-step-item{display:flex;align-items:center;flex:1}.generate-step-content{display:flex;align-items:center;gap:.75rem}.generate-step-circle{width:2rem;height:2rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;transition:all .3s ease}.generate-step-circle.completed{background-color:var(--color-primary);color:#fff}.generate-step-circle.current{background-color:var(--color-primary);color:#fff;box-shadow:0 4px 6px -1px #0000001a;outline:4px solid rgba(45,140,78,.2)}.generate-step-circle.upcoming{background-color:#f3f4f6;color:#9ca3af}.generate-step-circle svg{width:1rem;height:1rem}.generate-step-label{font-size:.875rem;font-weight:500;display:none}@media(min-width:640px){.generate-step-label{display:block}}.generate-step-label.current{color:#111827}.generate-step-label.completed{color:var(--color-primary)}.generate-step-label.upcoming{color:#9ca3af}.generate-step-line{flex:1;height:.125rem;margin-left:1rem;margin-right:1rem;border-radius:9999px;transition:all .3s ease}.generate-step-line.active{background-color:var(--color-primary)}.generate-step-line.inactive{background-color:#e5e7eb}.excel-import-page{max-width:56rem;margin-left:auto;margin-right:auto}.excel-import-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.excel-import-title{font-size:1.25rem;font-weight:700}.excel-upload-area{background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;padding:1.5rem}.excel-upload-actions{display:flex;justify-content:flex-end;margin-bottom:.75rem}.excel-template-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.875rem;border:1px solid #86efac;border-radius:.75rem;color:#15803d;background:transparent;cursor:pointer;transition:background-color .15s ease}.excel-template-btn:hover{background-color:#f0fdf4}.excel-template-btn svg{width:1rem;height:1rem}.excel-dropzone{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;transition:border-color .15s ease,background-color .15s ease;cursor:pointer}.excel-dropzone:hover{border-color:#9ca3af}.excel-dropzone.drag-over{border-color:var(--color-primary);background-color:var(--color-primary-lighter, #F0FAF3)}.excel-dropzone-text{color:#6b7280}.excel-dropzone-text p:first-child{font-size:1.125rem;margin-bottom:.25rem}.excel-dropzone-text p:last-child{font-size:.875rem;color:#9ca3af}.excel-hidden-input{display:none}.excel-parsing-msg{margin-top:1rem;text-align:center;font-size:.875rem;color:#6b7280}.excel-stats{background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;padding:1rem;margin-top:1rem}.excel-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}.excel-stat-value{font-size:1.5rem;font-weight:700}.excel-stat-value.blue{color:#2563eb}.excel-stat-value.green{color:#16a34a}.excel-stat-value.gray{color:#6b7280}.excel-stat-value.indigo{color:#4f46e5}.excel-stat-label{font-size:.75rem;color:#6b7280}.excel-stats-period{margin-top:.5rem;text-align:center;font-size:.875rem;color:#6b7280}.excel-warnings{margin-top:.75rem;background-color:#fefce8;border:1px solid #fde68a;border-radius:.375rem;padding:.75rem}.excel-warnings-title{font-size:.875rem;font-weight:500;color:#854d0e;margin-bottom:.25rem}.excel-warnings-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.125rem}.excel-warnings-list li{font-size:.75rem;color:#a16207}.excel-results{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.excel-day-card{background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;padding:1rem}.excel-day-title{font-size:.875rem;font-weight:600;color:#1f2937;margin-bottom:.75rem}.excel-meals-list{display:flex;flex-direction:column;gap:.5rem}.excel-meal-row{display:flex;align-items:flex-start;gap:.75rem}.excel-meal-type{font-size:.75rem;font-weight:500;color:#6b7280;width:2rem;padding-top:.25rem;flex-shrink:0}.excel-meal-menus{display:flex;flex-wrap:wrap;gap:.375rem}.excel-menu-tag{display:inline-block;padding:.125rem .5rem;font-size:.75rem;border-radius:9999px}.excel-menu-tag.cat-rice{background-color:#fef3c7;color:#92400e}.excel-menu-tag.cat-soup{background-color:#fee2e2;color:#991b1b}.excel-menu-tag.cat-main{background-color:#dbeafe;color:#1e40af}.excel-menu-tag.cat-side{background-color:#dcfce7;color:#166534}.excel-menu-tag.cat-dessert{background-color:#f3e8ff;color:#6b21a8}.excel-menu-tag.cat-beverage{background-color:#cffafe;color:#155e75}.excel-menu-tag.cat-snack{background-color:#ffedd5;color:#9a3412}.excel-menu-tag.cat-other{background-color:#f3f4f6;color:#1f2937}.excel-menu-tag.cat-default{background-color:#f3f4f6;color:#374151}.excel-close-btn{width:100%;padding:.5rem;font-size:.875rem;color:#6b7280;background:transparent;border:none;cursor:pointer}.excel-close-btn:hover{color:#374151}.excel-history-section{margin-top:1.5rem;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;padding:1rem 1.5rem}.excel-history-title{font-size:1rem;font-weight:600;color:#1f2937;margin-bottom:.75rem}.excel-history-loading,.excel-history-empty{text-align:center;font-size:.875rem;color:#9ca3af;padding:2rem 0}.excel-history-table{width:100%;border-collapse:collapse;font-size:.875rem}.excel-history-table th{text-align:left;padding:.5rem .75rem;font-weight:500;color:#6b7280;border-bottom:2px solid #e5e7eb;white-space:nowrap}.excel-history-table td{padding:.5rem .75rem;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:middle}.excel-history-table tbody tr:hover{background-color:#f9fafb}.excel-history-filename{max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.excel-status-badge{display:inline-block;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.excel-status-badge.status-success{background-color:#dcfce7;color:#166534}.excel-status-badge.status-partial{background-color:#fef9c3;color:#854d0e}.excel-status-badge.status-failed{background-color:#fee2e2;color:#991b1b}.excel-history-pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f3f4f6}.excel-history-page-btn{padding:.25rem .75rem;font-size:.8125rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;color:#374151;cursor:pointer;transition:background-color .15s ease}.excel-history-page-btn:hover:not(:disabled){background-color:#f3f4f6}.excel-history-page-btn:disabled{opacity:.4;cursor:not-allowed}.excel-history-page-info{font-size:.8125rem;color:#6b7280}.shared-page-header{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}@media(min-width:640px){.shared-page-header{flex-direction:row;align-items:center;justify-content:space-between}}.shared-page-desc{font-size:.875rem;color:var(--color-text-secondary, #6b7280)}.shared-share-btn{border-radius:.75rem;gap:.5rem;flex-shrink:0}.shared-share-btn svg{height:1rem;width:1rem}.shared-filter-bar{padding:1rem;margin-bottom:1.5rem}.shared-filter-content{display:flex;flex-direction:column;gap:1rem}@media(min-width:768px){.shared-filter-content{flex-direction:row}}.shared-search-wrapper{position:relative;flex:1}.shared-search-wrapper svg{height:1rem;width:1rem;position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af}.shared-target-filters{display:flex;gap:.5rem;flex-wrap:wrap}.shared-target-btn{padding:.375rem .75rem;border-radius:.75rem;font-size:.875rem;font-weight:500;transition:all .2s ease;border:none;cursor:pointer}.shared-target-btn.active{background-color:var(--color-primary);color:#fff}.shared-target-btn.inactive{background-color:#f3f4f6;color:#6b7280}.shared-target-btn.inactive:hover{background-color:#e5e7eb}.shared-card-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}@media(min-width:768px){.shared-card-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.shared-card-grid{grid-template-columns:repeat(3,1fr)}}.shared-card{padding:1.25rem;cursor:pointer}.shared-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.shared-card-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:.5rem;font-size:.75rem;font-weight:600;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary)}.shared-card-date{font-size:.75rem;color:#9ca3af}.shared-card-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:.25rem;transition:color .15s ease}.shared-card:hover .shared-card-title{color:var(--color-primary)}.shared-card-author{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.shared-card-author-inner{display:inline-flex;align-items:center;gap:.25rem}.shared-card-author-avatar{width:1.25rem;height:1.25rem;background-color:var(--color-primary-light, #E8F5EC);color:var(--color-primary);border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.shared-card-stats{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:#9ca3af}.shared-card-stat{display:flex;align-items:center;gap:.25rem}.shared-card-stat svg{height:.875rem;width:.875rem}.shared-card-stat svg.heart{color:var(--color-danger, #ef4444)}.shared-modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.shared-modal-backdrop{position:absolute;inset:0;background-color:#0006}.shared-modal{position:relative;background-color:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-width:42rem;width:100%;max-height:85vh;overflow-y:auto}.shared-modal-header{position:sticky;top:0;background-color:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #f3f4f6;padding:1rem 1.5rem;border-top-left-radius:1rem;border-top-right-radius:1rem;display:flex;align-items:center;justify-content:space-between}.shared-modal-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:.5rem;font-size:.75rem;font-weight:600;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary);margin-bottom:.25rem}.shared-modal-title{font-size:1.125rem;font-weight:700;color:#111827}.shared-modal-meta{font-size:.875rem;color:#6b7280;margin-top:.125rem}.shared-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.shared-modal-desc{font-size:.875rem;color:#4b5563;line-height:1.625}.shared-nutrition-title{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.shared-nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.shared-nutrition-item{background-color:#f9fafb;border-radius:.75rem;padding:.75rem;text-align:center}.shared-nutrition-label{font-size:.75rem;color:#9ca3af;margin-bottom:.25rem}.shared-nutrition-value{font-size:1.125rem;font-weight:700}.shared-nutrition-value.text-secondary{color:var(--color-secondary, #f59e0b)}.shared-nutrition-value.text-primary{color:var(--color-primary)}.shared-nutrition-value.text-info{color:var(--color-info, #3b82f6)}.shared-nutrition-value.text-warning{color:var(--color-warning, #f59e0b)}.shared-nutrition-unit{font-size:.75rem;font-weight:400;color:#9ca3af;margin-left:.125rem}.shared-weekly-title{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.75rem}.shared-weekly-list{display:flex;flex-direction:column;gap:.5rem}.shared-weekly-item{display:flex;align-items:flex-start;gap:.75rem;background-color:#f9fafb;border-radius:.75rem;padding:.75rem 1rem}.shared-weekly-day{flex-shrink:0;width:2rem;height:2rem;border-radius:.5rem;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary);font-weight:700;font-size:.875rem;display:flex;align-items:center;justify-content:center}.shared-weekly-menus{font-size:.875rem;color:#4b5563}.shared-modal-actions{display:flex;gap:.75rem;padding-top:.5rem}.shared-modal-actions .action-btn{border-radius:.75rem;gap:.5rem;flex:1}.shared-modal-actions .action-btn svg{height:1rem;width:1rem}.shared-modal-actions .action-btn svg.heart{color:var(--color-danger, #ef4444)}.ranking-page{max-width:48rem;margin-left:auto;margin-right:auto}.ranking-desc{font-size:.875rem;color:var(--color-text-secondary, #6b7280);margin-bottom:1.5rem}.ranking-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.ranking-tab{padding:.5rem 1.25rem;border-radius:.75rem;font-size:.875rem;font-weight:600;transition:all .2s ease;border:none;cursor:pointer}.ranking-tab.active{background-color:var(--color-primary);color:#fff;box-shadow:0 1px 2px #0000000d}.ranking-tab.inactive{background-color:#f3f4f6;color:#6b7280}.ranking-tab.inactive:hover{background-color:#e5e7eb}.ranking-list{display:flex;flex-direction:column;gap:.75rem}.ranking-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:.75rem;border:1px solid;transition:all .2s ease;cursor:pointer}.ranking-item:hover{box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d}.ranking-item.rank-1{background-color:#fefce8;border-color:#fde68a}.ranking-item.rank-2{background-color:#f9fafb;border-color:#e5e7eb}.ranking-item.rank-3{background-color:#fff7ed;border-color:#fed7aa}.ranking-item.rank-default{background-color:#fff;border-color:#f3f4f6}.ranking-rank-col{flex-shrink:0;width:3rem;text-align:center}.ranking-rank-icon{display:flex;flex-direction:column;align-items:center}.ranking-rank-icon svg{height:1.5rem;width:1.5rem}.ranking-rank-icon svg.gold{color:#eab308}.ranking-rank-icon svg.silver{color:#9ca3af}.ranking-rank-icon svg.bronze{color:#fb923c}.ranking-rank-number-top{font-size:1.125rem;font-weight:800}.ranking-rank-number-top.gold{color:#eab308}.ranking-rank-number-top.silver{color:#9ca3af}.ranking-rank-number-top.bronze{color:#fb923c}.ranking-rank-number{font-size:1.25rem;font-weight:700;color:#d1d5db}.ranking-info{flex:1;min-width:0}.ranking-item-title{font-size:.875rem;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-item-meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.ranking-item-author{font-size:.75rem;color:#6b7280}.ranking-item-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.375rem;font-size:10px;font-weight:600;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary)}.ranking-stats{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}.ranking-stat{text-align:center}.ranking-stat-label{font-size:.75rem;color:#9ca3af}.ranking-stat-value{font-size:.875rem;font-weight:700;color:#374151}.mypage{max-width:56rem;margin-left:auto;margin-right:auto}.mypage-hidden-input{display:none}.mypage-profile-card{padding:1.5rem;margin-bottom:1.5rem}.mypage-profile-row{display:flex;align-items:center;gap:1rem}.mypage-profile-info{flex:1}.mypage-profile-name{font-size:1.125rem;font-weight:700;color:#111827}.mypage-profile-email{font-size:.875rem;color:#6b7280}.mypage-profile-meta{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.mypage-plan-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:.5rem;font-size:.75rem;font-weight:600;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary)}.mypage-stats-text{font-size:.75rem;color:#9ca3af}.mypage-edit-btn{border-radius:.75rem}.mypage-avatar{position:relative;border-radius:1rem;overflow:hidden;flex-shrink:0}.mypage-avatar.sm{width:3.5rem;height:3.5rem;font-size:1.25rem}.mypage-avatar.md{width:4rem;height:4rem;font-size:1.5rem}.mypage-avatar.lg{width:5rem;height:5rem;font-size:1.875rem}.mypage-avatar.clickable{cursor:pointer}.mypage-avatar img{width:100%;height:100%;object-fit:cover}.mypage-avatar-placeholder{width:100%;height:100%;background-color:var(--color-primary-light, #E8F5EC);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:700}.mypage-avatar-overlay{position:absolute;inset:0;background-color:#0006;border-radius:1rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease;cursor:pointer}.mypage-avatar:hover .mypage-avatar-overlay{opacity:1}.mypage-avatar-overlay svg{height:1.5rem;width:1.5rem;color:#fff}.mypage-tabs{display:flex;gap:.25rem;background-color:#f3f4f6;border-radius:.75rem;padding:.25rem;margin-bottom:1.5rem}.mypage-tab{flex:1;padding:.625rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;transition:all .2s ease;border:none;cursor:pointer;background:transparent}.mypage-tab.active{background-color:#fff;color:#111827;box-shadow:0 1px 2px #0000000d}.mypage-tab.inactive{color:#6b7280}.mypage-tab.inactive:hover{color:#374151}.mypage-plans-list{display:flex;flex-direction:column;gap:.75rem}.mypage-plan-item{padding:1rem;cursor:pointer}.mypage-plan-row{display:flex;align-items:center;justify-content:space-between}.mypage-plan-content{flex:1;min-width:0}.mypage-plan-title-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.mypage-plan-title{font-size:.875rem;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mypage-plan-target{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:.375rem;font-size:10px;font-weight:600;background-color:var(--color-primary-lighter, #F0FAF3);color:var(--color-primary);flex-shrink:0}.mypage-plan-stats{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:#9ca3af}.mypage-plan-stat{display:flex;align-items:center;gap:.25rem}.mypage-plan-stat svg{height:.875rem;width:.875rem}.mypage-plan-stat svg.heart{color:var(--color-danger, #ef4444)}.mypage-plan-arrow svg{height:1.25rem;width:1.25rem;color:#d1d5db}.mypage-dl-author-avatar{width:1rem;height:1rem;background-color:var(--color-primary-light, #E8F5EC);color:var(--color-primary);border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700}.mypage-current-plan{padding:1rem;margin-bottom:1.5rem}.mypage-current-plan-row{display:flex;align-items:center;gap:.75rem}.mypage-current-plan-icon{width:2.5rem;height:2.5rem;background-color:var(--color-primary);border-radius:.75rem;display:flex;align-items:center;justify-content:center}.mypage-current-plan-icon svg{height:1.25rem;width:1.25rem;color:#fff}.mypage-current-plan-label{font-size:.875rem;font-weight:700;color:var(--color-primary)}.mypage-current-plan-desc{font-size:.75rem;color:#2d8c4eb3}.mypage-plans-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.mypage-plans-grid{grid-template-columns:repeat(3,1fr)}}.mypage-sub-card{border-radius:1rem;border:2px solid;padding:1.25rem;transition:all .2s ease;position:relative}.mypage-sub-card.recommended{border-color:var(--color-primary);background-color:#fff;box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d}.mypage-sub-card.current{border-color:#2d8c4e4d;background-color:var(--color-primary-lighter, #F0FAF3)}.mypage-sub-card.default{border-color:#f3f4f6;background-color:#fff}.mypage-sub-card.default:hover{border-color:#e5e7eb}.mypage-sub-recommend-badge{position:absolute;top:-.75rem;left:50%;transform:translate(-50%);padding:.25rem .75rem;background-color:var(--color-primary);color:#fff;font-size:10px;font-weight:700;border-radius:9999px}.mypage-sub-card-header{text-align:center;margin-bottom:1rem}.mypage-sub-plan-name{font-size:1.125rem;font-weight:700}.mypage-sub-plan-name.recommended{color:var(--color-primary)}.mypage-sub-plan-name.default{color:#111827}.mypage-sub-price{margin-top:.5rem}.mypage-sub-price-value{font-size:1.5rem;font-weight:800;color:#111827}.mypage-sub-price-period{font-size:.875rem;color:#9ca3af}.mypage-sub-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.mypage-sub-feature{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:#4b5563}.mypage-sub-feature svg{height:1rem;width:1rem;flex-shrink:0;margin-top:.125rem}.mypage-sub-feature svg.recommended{color:var(--color-primary)}.mypage-sub-feature svg.default{color:#9ca3af}.mypage-sub-btn{border-radius:.75rem}.mypage-account-sections{display:flex;flex-direction:column;gap:1.5rem}.mypage-account-card{padding:1.5rem}.mypage-account-title{font-size:1rem;font-weight:700;color:#111827;margin-bottom:1rem}.mypage-account-form{display:flex;flex-direction:column;gap:1rem}.mypage-account-avatar-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.mypage-account-avatar-info{flex:1}.mypage-account-avatar-name{font-size:.875rem;font-weight:600;color:#374151}.mypage-account-avatar-hint{font-size:.75rem;color:#9ca3af}.mypage-account-remove-img{font-size:.75rem;color:#9ca3af;font-weight:500;padding:.25rem .5rem;border-radius:.5rem;border:none;background:transparent;cursor:pointer;transition:all .15s ease}.mypage-account-remove-img:hover{color:#ef4444;background-color:#fef2f2}.mypage-readonly-hint{font-size:.75rem;color:#9ca3af;margin-top:.25rem}.mypage-form-actions{display:flex;justify-content:flex-end;padding-top:.5rem}.mypage-form-btn{border-radius:.75rem}.mypage-pw-valid{font-size:.75rem;margin-top:.25rem;color:#16a34a}.mypage-pw-invalid{font-size:.75rem;margin-top:.25rem;color:#ef4444}.mypage-modal-footer{display:flex;justify-content:flex-end;gap:.5rem}.mypage-modal-form{display:flex;flex-direction:column;gap:1rem}.mypage-modal-avatar-section{display:flex;flex-direction:column;align-items:center;gap:.5rem}.mypage-modal-avatar-actions{display:flex;gap:.5rem}.mypage-modal-change-img{font-size:.75rem;color:var(--color-primary);font-weight:500;border:none;background:transparent;cursor:pointer;transition:color .15s ease}.mypage-modal-change-img:hover{color:var(--color-primary-dark, #1E6B38)}.mypage-modal-remove-img{font-size:.75rem;color:#9ca3af;font-weight:500;border:none;background:transparent;cursor:pointer;transition:color .15s ease}.mypage-modal-remove-img:hover{color:#ef4444}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.app-loading-text{color:var(--color-text-secondary, #6b7280)}.app-layout{display:flex;min-height:100vh}.app-main-area{flex:1;margin-left:15rem}.app-content{padding:1.5rem}
