@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-family: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--color-primary: hsl(12, 100%, 65%);--color-primary-hover: hsl(12, 100%, 58%);--color-primary-light: hsl(12, 100%, 96%);--color-accent: hsl(159, 27%, 42%);--color-accent-light: hsl(159, 27%, 94%);--color-bg: hsl(210, 20%, 98%);--color-card: hsl(0, 0%, 100%);--color-border: hsl(210, 14%, 93%);--color-border-strong: hsl(210, 14%, 85%);--color-border-dark: rgba(255, 255, 255, .08);--color-border-strong-dark: rgba(255, 255, 255, .14);--color-text-main: hsl(210, 11%, 11%);--color-text-sub: hsl(210, 7%, 46%);--color-text-muted: hsl(210, 6%, 70%);--bg-success: hsl(145, 63%, 95%);--text-success-label: hsl(145, 63%, 30%);--bg-warning: hsl(38, 92%, 95%);--text-warning-label: hsl(38, 92%, 35%);--bg-danger: hsl(4, 90%, 96%);--text-danger-label: hsl(4, 90%, 40%);--bg-info: hsl(217, 89%, 95%);--text-info-label: hsl(217, 89%, 40%);--shadow-color: rgba(0, 0, 0, .06);--shadow-sm: 0 2px 8px var(--shadow-color);--shadow-md: 0 8px 24px var(--shadow-color);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .08);--glass-bg: rgba(255, 255, 255, .85);--glass-blur: blur(12px);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: all .5s cubic-bezier(.175, .885, .32, 1.275);--color-carb: #ffb74d;--color-protein: #81c784;--color-fat: #4fc3f7;--bg-base: var(--color-bg);--bg-surface: var(--color-card);--bg-subtle: hsl(210, 14%, 96%);--bg-hover: rgba(0, 0, 0, .04);--text-primary: var(--color-text-main);--text-secondary: var(--color-text-sub);--text-muted: var(--color-text-muted);--text-disabled: var(--color-text-muted);--text-inverse: hsl(0, 0%, 100%);--text-warning: hsl(38, 92%, 35%);--color-border-focus: var(--color-primary);--bg-progress-track: rgba(0, 0, 0, .06);--bg-lock-overlay: rgba(0, 0, 0, .04)}[data-theme=dark]{--color-primary: hsl(12, 100%, 65%);--color-primary-hover: hsl(12, 100%, 70%);--color-primary-light: hsl(12, 30%, 18%);--color-accent: hsl(159, 27%, 52%);--color-accent-light: hsl(159, 15%, 20%);--color-bg: hsl(222, 14%, 10%);--color-card: hsl(222, 14%, 15%);--color-border: var(--color-border-dark);--color-border-strong: var(--color-border-strong-dark);--color-text-main: hsl(210, 20%, 98%);--color-text-sub: hsl(210, 10%, 75%);--color-text-muted: hsl(210, 8%, 50%);--bg-success: hsla(145, 55%, 52%, .15);--text-success-label: hsl(145, 55%, 65%);--bg-warning: hsla(38, 85%, 60%, .15);--text-warning-label: hsl(38, 85%, 70%);--bg-danger: hsla(4, 85%, 65%, .15);--text-danger-label: hsl(4, 85%, 75%);--bg-info: hsla(217, 85%, 68%, .15);--text-info-label: hsl(217, 85%, 75%);--shadow-color: rgba(0, 0, 0, .35);--shadow-sm: none;--shadow-md: 0 8px 24px var(--shadow-color);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .45);--glass-bg: rgba(26, 32, 44, .85);--color-carb: #ffa726;--color-protein: #66bb6a;--color-fat: #29b6f6;--bg-base: var(--color-bg);--bg-surface: var(--color-card);--bg-subtle: hsl(222, 14%, 18%);--bg-hover: rgba(255, 255, 255, .05);--text-primary: var(--color-text-main);--text-secondary: var(--color-text-sub);--text-muted: var(--color-text-muted);--text-disabled: var(--color-text-muted);--text-inverse: hsl(222, 14%, 10%);--text-warning: hsl(38, 85%, 70%);--bg-progress-track: rgba(255, 255, 255, .12);--bg-lock-overlay: rgba(0, 0, 0, .35)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-main);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.card,.form-input,.selector-card,.theme-btn,.settings-wrapper,.calendar-container,.day-cell,.meal-card,.progress-container,.app-header{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}button{font-family:var(--font-family);border:none;background:none;cursor:pointer;outline:none}input,select,textarea{font-family:var(--font-family);outline:none}a{color:inherit;text-decoration:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:.9;transform:scale(1.1)}80%{transform:scale(.89)}to{opacity:1;transform:scale(1)}}.animate-spin{animation:spin 1s linear infinite}.app-container{max-width:480px;margin:0 auto;min-height:100vh;background-color:var(--color-bg);box-shadow:0 0 40px #00000008;position:relative;display:flex;flex-direction:column}.app-header{padding:1.5rem 1.25rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border)}.logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background-color:var(--color-border);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:var(--text-secondary)}.user-badge.premium{background:linear-gradient(135deg,hsl(38,92%,50%),var(--color-primary));color:#fff;box-shadow:var(--shadow-sm)}.user-badge.trial{background:linear-gradient(135deg,#8b47eb,#a219e6);color:#fff;box-shadow:var(--shadow-sm)}.app-header .calendar-nav-btn{color:var(--color-text-sub);display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:var(--radius-full);transition:var(--transition-smooth)}.app-header .calendar-nav-btn:hover{background-color:var(--bg-hover);color:var(--color-primary)}.app-header .calendar-nav-btn:active{transform:scale(.92)}.text-sub{color:var(--color-text-sub)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-sub);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.form-input{width:100%;padding:.85rem 1rem;border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background-color:var(--color-bg);font-size:1rem;transition:var(--transition-smooth)}.form-input:focus{border-color:var(--color-primary);background-color:var(--color-card);box-shadow:0 0 0 4px var(--color-primary-light)}.primary-button{width:100%;padding:1rem;background-color:var(--color-primary);color:#fff;font-size:1rem;font-weight:600;border-radius:var(--radius-md);box-shadow:0 4px 14px #ff6b4a4d;transition:var(--transition-bounce);display:flex;align-items:center;justify-content:center;gap:.5rem}.primary-button:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #ff6b4a66}.primary-button:active:not(:disabled){transform:translateY(1px)}.primary-button:disabled{background-color:var(--bg-subtle);color:var(--text-disabled);border:1px solid var(--color-border);cursor:not-allowed;box-shadow:none;transform:none;opacity:.65}[data-theme=dark] .primary-button:disabled{background-color:#2c303a;border-color:#424857;color:var(--color-text-muted);opacity:.8}.sync-toast-notification{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);width:calc(100% - 2.5rem);max-width:400px;background-color:var(--text-success-label);color:#fff;padding:.85rem 1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:9999;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:500;text-align:center;animation:syncToastSlideUp .4s cubic-bezier(.16,1,.3,1);pointer-events:none}@keyframes syncToastSlideUp{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#191c1f;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;overflow:hidden;transition:opacity .5s cubic-bezier(.4,0,.2,1),visibility .5s}.splash-screen.fade-out{opacity:0;visibility:hidden}.splash-background-glow{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.glow-circle{position:absolute;border-radius:var(--radius-full);filter:blur(100px);opacity:.15}.glow-1{width:300px;height:300px;background-color:var(--color-primary);top:20%;left:-50px;animation:floatGlow1 8s ease-in-out infinite alternate}.glow-2{width:400px;height:400px;background-color:var(--color-accent);bottom:10%;right:-100px;animation:floatGlow2 10s ease-in-out infinite alternate}.splash-content{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}.splash-logo-container{position:relative;margin-bottom:.75rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.splash-logo-img{height:4.5rem;width:auto;display:block;animation:splashPopIn 1.2s cubic-bezier(.175,.885,.32,1.275) forwards}.splash-logo-text{font-size:3rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),hsl(159,27%,55%));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-2px;margin:0;animation:splashPopIn 1.2s cubic-bezier(.175,.885,.32,1.275) forwards}.splash-logo-shimmer{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#fff3,#fff0);transform:translate(-100%);animation:shimming 1.5s ease-in-out infinite alternate;animation-delay:.6s;pointer-events:none}.splash-subtitle{font-size:1rem;font-weight:500;color:var(--color-text-muted);opacity:0;transform:translateY(10px);animation:splashFadeInUp 1s ease-out forwards;animation-delay:.5s;letter-spacing:.5px}.splash-loading-bar-container{margin-top:2rem;width:120px;height:4px;background-color:#ffffff0d;border-radius:var(--radius-full);overflow:hidden;opacity:0;animation:splashFadeIn .8s ease-out forwards;animation-delay:.8s}.splash-loading-bar{width:100%;height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transform:translate(-100%);animation:loadingProgress 1.6s cubic-bezier(.4,0,.2,1) forwards;animation-delay:.9s}.splash-footer{position:absolute;bottom:2rem;left:0;width:100%;text-align:center;z-index:2;opacity:0;animation:splashFadeIn .8s ease-out forwards;animation-delay:1.2s}.splash-footer-text{font-size:.75rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:#fff3}@keyframes floatGlow1{0%{transform:translate(0) scale(1)}to{transform:translate(30px,-20px) scale(1.1)}}@keyframes floatGlow2{0%{transform:translate(0) scale(1)}to{transform:translate(-40px,30px) scale(1.05)}}@keyframes splashPopIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes splashFadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes splashFadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimming{0%{transform:translate(-80%)}to{transform:translate(80%)}}@keyframes loadingProgress{0%{transform:translate(-100%)}to{transform:translate(0)}}.coming-soon-wrapper{padding:2.5rem 1.5rem;display:flex;flex-direction:column;justify-content:center;align-items:center;flex:1;min-height:100vh;background-color:var(--bg-base);animation:fadeInUp .5s ease-out}.coming-soon-card{background-color:var(--bg-surface);padding:3rem 2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);text-align:center;max-width:400px;width:100%}.coming-soon-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:.8rem;font-weight:600;margin-bottom:1.5rem}.coming-soon-card h1{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem;letter-spacing:-1px}.coming-soon-card h2{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.coming-soon-card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:2rem}.coming-soon-footer{font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--color-border);padding-top:1.25rem}.landing-page-container{min-height:100vh;background-color:var(--bg-base);color:var(--text-primary);display:flex;flex-direction:column;align-items:center;width:100%;padding-bottom:2rem;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}.landing-hero{padding:4rem 1.5rem 3rem;text-align:center;display:flex;flex-direction:column;align-items:center;max-width:600px;width:100%;animation:fadeInUp .6s ease-out}.hero-logo-container{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.hero-logo-img{height:3rem;width:auto;display:block}.hero-brand-name{font-size:2.8rem;font-weight:800;margin:0;background:linear-gradient(135deg,var(--color-primary) 30%,#ff8c00 90%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.03em}.hero-headline{font-size:2.1rem;font-weight:800;line-height:1.35;color:var(--text-primary);margin-bottom:1.25rem;letter-spacing:-.02em;word-break:keep-all;overflow-wrap:break-word}.hero-headline span{color:var(--color-primary)}@media(max-width:400px){.hero-headline{font-size:1.7rem}}.hero-subtext{font-size:1.05rem;line-height:1.6;color:var(--text-secondary);margin-bottom:2.5rem;word-break:keep-all}.hero-cta-wrapper{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:320px}.landing-google-btn,.landing-google-btn-accent{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;height:3.5rem;background-color:var(--bg-surface);border:1px solid var(--color-border);color:var(--text-primary);font-size:1.05rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-1);transition:transform .1s ease,border-color .3s ease,background-color .3s ease,box-shadow .3s ease}.landing-google-btn:hover{border-color:var(--color-primary);background-color:var(--bg-hover);box-shadow:var(--shadow-2)}.landing-google-btn:active,.landing-google-btn-accent:active{transform:scale(.98)}.cta-caption{font-size:.8rem;color:var(--text-muted);font-weight:500}.landing-features{padding:3rem 1.5rem;max-width:800px;width:100%;display:flex;flex-direction:column;align-items:center}.section-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center;letter-spacing:-.01em}.features-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;width:100%}@media(min-width:600px){.features-grid{grid-template-columns:1fr 1fr}}.feature-card{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:.8rem;box-shadow:var(--shadow-1);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--shadow-2)}.feature-icon-wrapper{width:2.75rem;height:2.75rem;border-radius:var(--radius-md);background-color:var(--color-primary-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.feature-icon{width:1.5rem;height:1.5rem}.feature-card h4{font-size:1.15rem;font-weight:700;margin:0;color:var(--text-primary)}.feature-card p{font-size:.9rem;line-height:1.55;color:var(--text-secondary);margin:0;word-break:keep-all}.landing-bottom-cta{padding:2rem 1.5rem 4rem;max-width:800px;width:100%}.cta-card{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-hover) 100%);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem;box-shadow:var(--shadow-2)}.cta-card h3{font-size:1.45rem;font-weight:800;margin:0;color:var(--text-primary);line-height:1.4;word-break:keep-all}.cta-card p{font-size:.95rem;color:var(--text-secondary);margin:0;max-width:480px;line-height:1.5;word-break:keep-all}.landing-google-btn-accent{max-width:280px;background-color:var(--color-primary);color:#fff;border:none}.landing-google-btn-accent:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-2)}.landing-footer{width:100%;max-width:800px;padding:4rem 1.5rem 2rem;border-top:1px solid var(--color-border);margin-top:auto;display:flex;flex-direction:column;gap:2.5rem}.footer-info-container{display:flex;flex-direction:column;gap:1rem}.footer-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0;display:flex;align-items:center;gap:.35rem;letter-spacing:-.01em}.footer-info-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;background-color:var(--bg-surface);border:1px solid var(--color-border);padding:1.25rem 1.75rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-1)}@media(min-width:600px){.footer-info-grid{grid-template-columns:1fr 1.25fr 1.45fr;gap:1.5rem 2rem}}.footer-info-grid div{display:flex;flex-direction:column;gap:.35rem}.footer-info-grid div span{font-size:.72rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.footer-info-grid div strong{font-size:.95rem;color:var(--text-primary);font-weight:600;letter-spacing:-.01em;white-space:nowrap}.footer-links{display:flex;justify-content:center;align-items:center;flex-wrap:nowrap;gap:0;margin-bottom:.25rem;width:100%}.footer-links button{background:none;border:none;color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:color .2s ease,transform .1s ease;padding:.25rem .4rem;position:relative;display:flex;align-items:center;white-space:nowrap}.footer-links button:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:9px;background-color:var(--color-border-strong);opacity:.6}@media(min-width:600px){.footer-links button{font-size:.82rem;padding:.25rem 1rem}.footer-links button:not(:last-child):after{height:10px;opacity:1}}.footer-links button:hover{color:var(--color-primary)}.footer-links button:active{transform:scale(.96)}.footer-copyright{text-align:center;font-size:.78rem;color:var(--text-muted);letter-spacing:.02em}.terms-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1500;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .25s ease-out}.terms-modal-container{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-3);animation:scaleUp .25s ease-out}.terms-modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.terms-modal-header h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--text-primary)}.terms-modal-close{background:none;border:none;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;color:var(--text-secondary);transition:background-color .2s ease,color .2s ease}.terms-modal-close:hover{background-color:var(--bg-subtle);color:var(--text-primary)}.terms-modal-body{padding:1.5rem;overflow-y:auto;font-size:.9rem;line-height:1.6;color:var(--text-secondary);overscroll-behavior:contain}.terms-modal-body::-webkit-scrollbar{width:6px}.terms-modal-body::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}.terms-content-inner h4{font-size:1rem;color:var(--text-primary);margin-top:1.5rem;margin-bottom:.5rem}.terms-content-inner h4:first-of-type{margin-top:0}.terms-content-inner p{margin:0 0 1rem;word-break:keep-all}.terms-content-inner ul{margin:0 0 1rem;padding-left:1.25rem}.terms-content-inner li{margin-bottom:.4rem}.terms-table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.8rem}.terms-table th,.terms-table td{border:1px solid var(--color-border);padding:.6rem;text-align:center}.terms-table th{background-color:var(--bg-subtle);color:var(--text-primary);font-weight:700}.terms-table td:first-child{text-align:left;font-weight:600;background-color:var(--bg-subtle);color:var(--text-primary)}.terms-desc-sub{display:block;font-size:.72rem;color:var(--text-muted);font-weight:400;margin-top:.2rem}.terms-note{font-size:.75rem;color:var(--text-muted);margin-top:.5rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.onboarding-wrapper{padding:2rem 1.5rem;animation:fadeInUp .5s ease-out}.onboarding-title{font-size:1.6rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.onboarding-desc{color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem}.onboarding-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.selector-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.gender-selector-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.gender-btn{background-color:var(--bg-surface);border:1.5px solid var(--color-border);padding:.85rem;border-radius:var(--radius-md);transition:var(--transition-bounce);text-align:center;font-weight:600;font-size:.95rem;color:var(--text-primary);cursor:pointer}.selector-card{background-color:var(--bg-surface);border:1.5px solid var(--color-border);padding:1rem;border-radius:var(--radius-md);transition:var(--transition-bounce);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.selector-card.active{border-color:var(--color-accent);background-color:var(--color-accent-light);transform:scale(1.02)}.selector-card.active .selector-card-title{color:var(--color-accent)}.selector-card-title{font-weight:600;font-size:.9rem;color:var(--text-primary)}.selector-card-desc{font-size:.75rem;color:var(--text-secondary)}.onboarding-progress-bar{width:100%;height:6px;background-color:var(--bg-progress-track);border-radius:var(--radius-full);margin-bottom:.75rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light, var(--color-primary)));border-radius:var(--radius-full);transition:width .3s cubic-bezier(.4,0,.2,1)}.onboarding-step-indicator{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.5rem}.onboarding-step-content{animation:fadeIn .4s ease-out}.onboarding-btn-group{display:grid;grid-template-columns:1fr 2fr;gap:1rem;margin-top:2rem}.section-subtitle{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;display:block}.chip-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.chip-button{background-color:var(--bg-surface);border:1px solid var(--color-border);padding:.5rem .85rem;border-radius:var(--radius-full, 50px);font-size:.85rem;font-weight:500;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.chip-button:hover{background-color:var(--bg-hover, var(--color-border));color:var(--text-primary)}.chip-button.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 4px 10px #ff6b4a33}[data-theme=dark] .chip-button.active{box-shadow:none;border-color:var(--color-primary)}.custom-input-form{display:flex;gap:.5rem;margin-bottom:.75rem}.custom-add-button{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;background-color:var(--bg-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.custom-chip-badge{display:inline-flex;align-items:center;gap:.25rem;background-color:var(--bg-surface);border:1.5px solid var(--color-border);padding:.35rem .6rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.selector-card:active,.chip-button:active,.secondary-button:active,.custom-add-button:active{transform:scale(.98);transition:transform .1s ease}.secondary-button{width:100%;padding:1rem;background-color:var(--bg-surface);border:1.5px solid var(--color-border);color:var(--text-secondary);font-size:1rem;font-weight:600;border-radius:var(--radius-md);transition:var(--transition-bounce);display:flex;align-items:center;justify-content:center;gap:.5rem}.secondary-button:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--color-border-strong)}.secondary-button:disabled{opacity:.5;cursor:not-allowed}.onboarding-wrapper .primary-button{background-color:var(--color-accent);color:#fff;box-shadow:0 4px 14px #2d6c5626;transition:var(--transition-bounce)}.onboarding-wrapper .primary-button:hover:not(:disabled){filter:brightness(.92);box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.onboarding-wrapper .primary-button:active:not(:disabled){transform:scale(.98)}.onboarding-wrapper .primary-button:disabled{background-color:var(--bg-subtle);color:var(--text-disabled);border:1px solid var(--color-border);box-shadow:none;cursor:not-allowed;opacity:.6}[data-theme=dark] .onboarding-wrapper .primary-button:disabled{background-color:#2c303a;border-color:#424857;color:var(--color-text-muted);opacity:.8}.onboarding-wrapper .form-group label{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-align:left;letter-spacing:-.01em}.onboarding-wrapper .onboarding-goal-group{margin-bottom:2.5rem}.onboarding-wrapper .form-input{background-color:var(--bg-surface);color:var(--text-primary);border:1.5px solid var(--color-border)}.onboarding-wrapper .form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 4px var(--color-accent-light)}.onboarding-wrapper .form-input.input-error{border-color:var(--color-border-error, #DC2626)}.onboarding-wrapper .form-input.input-error:focus{box-shadow:0 0 0 4px #dc262626}.form-error-message{display:block;color:var(--text-danger, #DC2626);font-size:.75rem;font-weight:500;margin-top:.35rem;text-align:left}.tooltip-button-wrapper{position:relative;width:100%}.onboarding-tooltip{position:absolute;top:-44px;left:50%;transform:translate(-50%);background-color:var(--color-primary);color:#fff;padding:.4rem .8rem;border-radius:var(--radius-sm, 10px);font-size:.75rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-sm);animation:tooltipBounce 2s infinite;z-index:5}.onboarding-tooltip:after{content:"";position:absolute;bottom:-5px;left:50%;transform:translate(-50%);border-width:5px 5px 0;border-style:solid;border-color:var(--color-primary) transparent transparent}@keyframes tooltipBounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,-6px)}}.onboarding-loading-overlay{position:fixed;inset:0;background-color:var(--bg-lock-overlay, rgba(0, 0, 0, .45));backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1.5rem}.onboarding-loading-card{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:2.5rem 2rem;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-3, 0 10px 25px rgba(0, 0, 0, .1));display:flex;flex-direction:column;align-items:center;gap:1.25rem;animation:onboardingCardFadeIn .3s cubic-bezier(.34,1.56,.64,1)}.onboarding-loading-card .loading-icon{color:var(--color-accent)}.onboarding-loading-card h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.onboarding-loading-card p{font-size:.9rem;line-height:1.6;color:var(--text-secondary);margin:0;word-break:keep-all}@keyframes onboardingCardFadeIn{0%{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .selector-card.active{background-color:#64a68f1f;border-color:var(--color-accent)}[data-theme=dark] .selector-card.active .selector-card-title{color:#97d8c1}[data-theme=dark] .selector-card.active .selector-card-desc{color:#c8dad4}[data-theme=dark] .onboarding-loading-card{box-shadow:0 12px 30px #00000080;border-color:var(--color-border-strong)}[data-theme=dark] .form-input{border-color:var(--color-border-strong)}.onboarding-rate-limit-banner{display:flex;gap:.75rem;align-items:flex-start;text-align:left;margin-bottom:1.25rem;padding:1rem 1.25rem;background-color:#fff5f0;border:1.5px solid hsl(20,90%,85%);border-radius:var(--radius-md);transition:all .3s ease;animation:onboardingCardFadeIn .25s ease-out}.onboarding-rate-limit-banner .warning-icon{font-size:1.25rem;line-height:1}.onboarding-rate-limit-banner .banner-content{display:flex;flex-direction:column;gap:.25rem}.onboarding-rate-limit-banner .banner-title{font-weight:700;font-size:.9rem;color:#c2470a;margin:0}.onboarding-rate-limit-banner .banner-desc{font-size:.82rem;line-height:1.45;color:#7a3d1f;margin:0;word-break:keep-all}[data-theme=dark] .onboarding-rate-limit-banner{background-color:#b84b141f;border-color:#e65e194d}[data-theme=dark] .onboarding-rate-limit-banner .banner-title{color:#f9ac86}[data-theme=dark] .onboarding-rate-limit-banner .banner-desc{color:#e0d6d1}.confetti-wrapper{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:999;overflow:hidden}.confetti-particle{position:absolute;top:-20px;opacity:0;animation:fallAndSpin linear forwards}.confetti-particle.circle{border-radius:var(--radius-full)}.confetti-particle.square{border-radius:2px}@keyframes fallAndSpin{0%{top:-20px;opacity:0;transform:translateY(0) rotate(0)}10%{opacity:1}90%{opacity:1}to{top:105vh;opacity:0;transform:translateY(0) rotate(720deg) translate(50px)}}.daily-progress-widget{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}.widget-header{display:flex;justify-content:space-between;align-items:center}.header-title{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;color:var(--text-primary)}.widget-check-action-btn{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;font-weight:600;padding:.3rem .65rem;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;transition:all .2s ease}.widget-check-action-btn:hover{background-color:var(--bg-base);border-color:var(--color-text-muted);color:var(--text-primary)}.widget-check-action-btn.checked{background-color:var(--color-accent-light);border-color:#4caf5033;color:var(--color-accent)}.cal-progress-section{display:flex;flex-direction:column;gap:.45rem}.cal-info{display:flex;justify-content:space-between;align-items:flex-end}.cal-label{display:flex;align-items:center;gap:.35rem}.cal-count{font-size:1.25rem;font-weight:800;color:var(--text-primary)}.cal-total{font-size:.8rem;color:var(--text-muted);margin-bottom:2px}.cal-percentage{font-size:.95rem;font-weight:800;color:var(--color-primary)}.cal-progress-track{width:100%;height:8px;background-color:var(--bg-progress-track);border-radius:var(--radius-full);overflow:hidden}.cal-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));border-radius:var(--radius-full);transition:width .6s cubic-bezier(.1,.8,.3,1);width:0}.macros-progress-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.25rem;border-top:1px dashed var(--color-border);padding-top:.85rem}.macro-progress-item{display:flex;flex-direction:column;gap:.35rem}.macro-info{display:flex;flex-direction:column;gap:.1rem}.macro-name{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.macro-gram{font-size:.75rem;font-weight:600;color:var(--text-primary)}.macro-bar-track{width:100%;height:4px;background-color:var(--bg-progress-track);border-radius:var(--radius-full);overflow:hidden}.macro-bar{height:100%;border-radius:var(--radius-full);transition:width .8s cubic-bezier(.1,.8,.3,1);width:0}.macro-bar.carb{background-color:var(--color-carb)}.macro-bar.protein{background-color:var(--color-protein)}.macro-bar.fat{background-color:var(--color-fat)}.achievement-overlay{position:fixed;inset:0;background-color:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .25s ease-out;padding:1.5rem}.achievement-modal{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);max-width:380px;width:100%;padding:2rem 1.5rem;text-align:center;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;align-items:center;gap:1.25rem;animation:scaleUp .3s cubic-bezier(.175,.885,.32,1.275);overscroll-behavior:contain}.trophy-container{width:72px;height:72px;background-color:var(--color-primary-light);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-primary);margin-bottom:.25rem;animation:bounceSlow 2s infinite ease-in-out}.achievement-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);line-height:1.4}.achievement-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.5;white-space:pre-line}.achievement-stats{background-color:var(--bg-base);border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;width:100%;display:flex;justify-content:space-around;margin:.25rem 0}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-val{font-size:1.05rem;font-weight:800;color:var(--color-primary)}.stat-lbl{font-size:.7rem;color:var(--text-muted);font-weight:700}.achievement-close-btn{width:100%;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:.85rem;font-size:.9rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .2s ease}.achievement-close-btn:hover{transform:translateY(-2px);background-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}@keyframes scaleUp{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@keyframes bounceSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.replace-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;padding:1rem;z-index:9999;isolation:isolate;animation:fadeIn .25s ease-out;box-sizing:border-box;touch-action:none}.replace-modal-content{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;width:100%;max-width:400px;max-height:calc(100svh - 2rem);padding:1.5rem;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;position:relative;overflow:hidden;z-index:10000;animation:mealReplaceSlideUp .35s cubic-bezier(.175,.885,.32,1.15) both;overscroll-behavior:contain}[data-theme=dark] .replace-modal-content{box-shadow:0 20px 40px #0006}.replace-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.replace-modal-title{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.15rem;color:var(--text-primary)}.replace-modal-title .replace-wand-icon{color:var(--color-primary);animation:shimmer 1.5s infinite alternate}.replace-modal-header .close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.replace-modal-header .close-btn:hover{background-color:var(--color-border);color:var(--text-primary)}.current-meal-brief{background-color:var(--bg-base);border-radius:12px;padding:.75rem 1rem;margin-bottom:1.25rem;display:flex;align-items:flex-start;gap:.75rem}.brief-tag{font-size:.75rem;font-weight:700;padding:.25rem .6rem;border-radius:6px;flex-shrink:0;margin-top:2px}.brief-tag.breakfast{background-color:#ffb74d26;color:#f57c00}.brief-tag.lunch{background-color:#81c78426;color:#388e3c}.brief-tag.dinner{background-color:#4fc3f726;color:#0288d1}.brief-menu-name{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0;white-space:normal;word-break:keep-all;line-height:1.4;flex:1}.fridge-toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-info);border:1px solid var(--text-info-label, #0288d1);border-radius:12px;padding:.6rem .9rem;margin-bottom:1rem;border-color:#4fc3f740}.fridge-toggle-info{display:flex;flex-direction:column;gap:2px}.fridge-toggle-label{font-size:.8rem;font-weight:700;color:var(--text-primary)}.fridge-toggle-count{font-size:.7rem;color:var(--text-muted)}.fridge-toggle-btn{padding:.3rem .85rem;border-radius:20px;font-size:.8rem;font-weight:700;border:1.5px solid var(--color-border);background:var(--bg-base);color:var(--text-muted);cursor:pointer;letter-spacing:.03em;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.fridge-toggle-btn.active{background:var(--color-fat);border-color:transparent;color:var(--text-inverse);box-shadow:0 0 10px #4fc3f740}.fridge-toggle-btn:hover:not(:disabled):not(.active){background:var(--bg-hover);border-color:var(--text-info-label);color:var(--text-info-label)}.fridge-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.tinder-card-container{width:100%;height:325px;position:relative;margin-bottom:1.75rem;box-sizing:border-box}.tinder-card{position:absolute;inset:0;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-base) 100%);border:1px solid var(--color-border);border-radius:20px;padding:1rem 1.15rem;box-shadow:0 10px 25px #00000014;display:flex;flex-direction:column;justify-content:space-between;cursor:grab;-webkit-user-select:none;user-select:none;z-index:10;overflow:hidden;box-sizing:border-box;will-change:transform;touch-action:none}[data-theme=dark] .tinder-card{box-shadow:0 10px 25px #0000004d}.tinder-card:active{cursor:grabbing}.card-top-glow{position:absolute;top:0;left:0;width:100%;height:6px;background:linear-gradient(90deg,#ffb74d,#81c784,#4fc3f7)}.tinder-card-underlay{position:absolute;inset:6px 4% -8px;background:var(--bg-base);border:1px solid var(--color-border);border-radius:20px;z-index:5;box-shadow:0 6px 15px #0000000d;transition:transform .3s ease}.card-meta{display:flex;justify-content:space-between;align-items:center}.card-rec-tag{font-size:.7rem;font-weight:700;color:var(--color-primary, #4caf50);background-color:#4caf501a;padding:.2rem .5rem;border-radius:4px}.card-calories{font-size:.95rem;font-weight:800;color:var(--text-primary)}.card-meal-title{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:.4rem 0;line-height:1.35;text-align:center;word-break:keep-all}.card-nutrients-section{width:100%}.nutrient-bar-compact{height:6px;background-color:var(--color-border);border-radius:3px;overflow:hidden;display:flex;margin-bottom:.4rem}.compact-segment{height:100%}.compact-segment.carb{background-color:var(--color-carb)}.compact-segment.protein{background-color:var(--color-protein)}.compact-segment.fat{background-color:var(--color-fat)}.nutrient-labels-compact{display:flex;justify-content:space-between;font-size:.75rem;font-weight:600;color:var(--text-muted)}.card-ai-comment{background-color:#ffffff05;border-left:3px solid var(--color-carb);padding:.4rem .6rem;border-radius:0 8px 8px 0;font-size:.72rem;color:var(--text-secondary);line-height:1.35;display:flex;align-items:flex-start;gap:.35rem}.card-ai-comment .comment-icon{color:var(--color-carb);margin-top:1px;flex-shrink:0}.card-drag-hint{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:.5rem;letter-spacing:-.5px;line-height:1.4}.swipe-badge{position:absolute;top:20px;padding:.4rem .9rem;border-radius:8px;font-size:1.1rem;font-weight:900;text-transform:uppercase;letter-spacing:.5px;z-index:20;border:3px solid currentColor;background-color:var(--bg-surface);box-shadow:0 4px 12px #0003;animation:popBadge .15s ease-out}.swipe-badge.like-badge{left:20px;right:auto;color:#4caf50;transform:rotate(-12deg)}.swipe-badge.nope-badge{right:20px;left:auto;color:#ef5350;transform:rotate(12deg)}.replace-modal-controls,.tinder-controls{display:flex;justify-content:center;align-items:center;gap:1.25rem}.control-btn{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0000000f;transition:transform .2s cubic-bezier(.175,.885,.32,1.275),background-color .2s,color .2s}[data-theme=dark] .control-btn{box-shadow:0 4px 12px #0003}.control-btn:hover{transform:scale(1.1)}.control-btn:active{transform:scale(.95)}.undo-btn{width:42px;height:42px;color:var(--text-secondary)}.undo-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.nope-btn{width:52px;height:52px;color:#ef5350;border-color:#ef535033}.nope-btn:hover{background-color:#fef2f2}[data-theme=dark] .nope-btn:hover{background-color:#ef53501a}.like-btn{width:52px;height:52px;color:#4caf50;border-color:#4caf5033}.like-btn:hover{background-color:#f0fdf4}[data-theme=dark] .like-btn:hover{background-color:#4caf501a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popBadge{0%{transform:scale(.6) rotate(0);opacity:0}to{transform:scale(1) rotate(inherit);opacity:1}}@keyframes shimmer{0%{opacity:.6;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}@keyframes mealReplaceSlideUp{0%{opacity:0;translate:0 20px}to{opacity:1;translate:0 0}}.modal-loading-container,.modal-error-container,.modal-empty-container,.replace-loading-container,.replace-error-container{width:100%;height:280px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:1.5rem;background-color:#ffffff05;border:1px dashed var(--color-border);border-radius:20px;margin-bottom:1.75rem;box-sizing:border-box}.loading-spinner,.spinner-icon{color:var(--color-primary, #4caf50);animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-title,.error-title,.loading-text,.error-text{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.loading-desc,.error-desc,.error-sub,.empty-text{font-size:.75rem;color:var(--text-muted);line-height:1.4;margin:0 0 1rem;max-width:280px}.retry-btn{background-color:var(--color-primary, #4caf50);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.75rem;font-weight:700;cursor:pointer;transition:opacity .2s}.retry-btn:hover{opacity:.9}@media(max-height:600px){.tinder-card-container,.modal-loading-container,.modal-error-container,.modal-empty-container,.replace-loading-container,.replace-error-container{height:220px;margin-bottom:1.25rem}.replace-modal-content{padding:1rem}}@media(max-width:440px){.tinder-card-container{height:345px;margin-bottom:1.25rem}.card-meal-title{font-size:1.02rem;margin:.3rem 0}.card-ai-comment{padding:.35rem .5rem;font-size:.68rem}.replace-modal-content{padding:1.25rem 1rem}.current-meal-brief{padding:.6rem .85rem;margin-bottom:1rem}}.card-main-info{display:flex;flex-direction:column;gap:.6rem;width:100%}.card-bottom-info{display:flex;flex-direction:column;gap:.5rem;width:100%;margin-top:auto}.card-recipe-accordion{margin-top:.5rem;width:100%}.recipe-toggle-btn{width:100%;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:10px;padding:.4rem .75rem;font-size:.75rem;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.recipe-toggle-btn:hover{background-color:var(--color-bg-hover, rgba(0, 0, 0, .03))}.recipe-toggle-btn.active{background-color:#4caf500d;border-color:#4caf504d;color:var(--color-primary, #4caf50)}.recipe-content-panel{text-align:left;border-top:1px dashed var(--color-border, rgba(0, 0, 0, .08));margin-top:0;padding-top:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .3s ease-out,padding .3s ease-out,margin .3s ease-out}[data-theme=dark] .recipe-content-panel{border-color:#ffffff14}.recipe-content-panel.expanded{margin-top:.5rem;padding-top:.5rem;max-height:88px;opacity:1;overflow-y:auto}.recipe-content-panel::-webkit-scrollbar{width:5px}.recipe-content-panel::-webkit-scrollbar-track{background:transparent}.recipe-content-panel::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}[data-theme=dark] .recipe-content-panel::-webkit-scrollbar-thumb{background:#ffffff26}.recipe-content-panel::-webkit-scrollbar-thumb:hover{background:#0000004d}[data-theme=dark] .recipe-content-panel::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.recipe-toggle-arrow{transition:transform .3s cubic-bezier(.4,0,.2,1);color:var(--text-muted)}.recipe-toggle-arrow.rotated{transform:rotate(180deg);color:var(--color-primary, #4caf50)}.fridge-lock-mask{position:absolute;inset:0;background-color:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10010;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-primary);font-size:.9rem;font-weight:700;border-radius:24px}[data-theme=dark] .fridge-lock-mask{background-color:#1a1d27cc}.recipe-section-block{margin-bottom:.75rem}.recipe-section-block h5{font-size:.75rem;font-weight:800;color:var(--text-primary);margin:0 0 .4rem}.ingredients-tags{display:flex;flex-wrap:wrap;gap:.35rem}.ingredient-tag{font-size:.65rem;font-weight:600;color:var(--color-primary, #4caf50);background-color:#4caf5014;padding:.2rem .45rem;border-radius:6px}.steps-list-compact{margin:0;padding-left:1rem;font-size:.7rem;color:var(--text-secondary);line-height:1.4}.steps-list-compact li{margin-bottom:.25rem}.custom-confirm-overlay{position:absolute;inset:0;background:#00000073;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:10020;animation:fadeIn .2s ease-out}[data-theme=dark] .custom-confirm-overlay{background:#0009}.custom-confirm-content{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;width:82%;max-width:300px;padding:1.25rem;box-shadow:0 10px 30px #0003;text-align:center;animation:confirmPop .25s cubic-bezier(.175,.885,.32,1.15) both}[data-theme=dark] .custom-confirm-content{box-shadow:0 10px 30px #00000073}.confirm-icon-wrapper{margin-bottom:.6rem;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#ff98001f;color:#ff9800}.custom-confirm-content h4{margin:0 0 .4rem;font-size:.95rem;font-weight:800;color:var(--text-primary)}.custom-confirm-content p{margin:0 0 1.1rem;font-size:.75rem;color:var(--text-secondary);line-height:1.45}.confirm-actions{display:flex;gap:.6rem}.confirm-btn{flex:1;padding:.55rem;border-radius:10px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;border:none}.confirm-btn.cancel{background:var(--bg-base);color:var(--text-secondary);border:1px solid var(--color-border)}.confirm-btn.cancel:hover{background:var(--bg-hover)}.confirm-btn.proceed{background:var(--color-primary, #4caf50);color:#fff}.confirm-btn.proceed:hover{opacity:.9;transform:translateY(-1px)}@keyframes confirmPop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.card-drag-hint-outer{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:-.75rem;margin-bottom:1.25rem;font-weight:500;letter-spacing:-.5px}@keyframes pulseHint{0%{opacity:.8}to{opacity:1}}.recipe-open-btn{width:100%;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:10px;padding:.55rem .75rem;font-size:.75rem;font-weight:700;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s}.recipe-open-btn:hover{background-color:var(--color-bg-hover, rgba(0, 0, 0, .03));color:var(--color-primary, #4caf50);border-color:#4caf504d}.recipe-open-btn:active{transform:scale(.98)}.recipe-bottom-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--color-border);border-radius:20px 20px 0 0;max-height:0;opacity:0;overflow:hidden;z-index:10050;display:flex;flex-direction:column;box-shadow:0 -10px 30px #00000026;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s ease-out}[data-theme=dark] .recipe-bottom-sheet{box-shadow:0 -10px 30px #0006}.recipe-bottom-sheet.expanded{max-height:240px;opacity:1}.bottom-sheet-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem .6rem;border-bottom:1px solid var(--color-border)}.bottom-sheet-title-group{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem}.bottom-sheet-title{display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.85rem;color:var(--color-primary, #4caf50)}.bottom-sheet-warn{font-size:.68rem;color:#ff9800;font-weight:600;letter-spacing:-.3px;animation:pulseHint 2s infinite alternate}.bottom-sheet-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.bottom-sheet-close-btn:hover{background-color:var(--color-border);color:var(--text-primary)}.bottom-sheet-body{padding:1rem 1.25rem;overflow-y:auto;flex:1;text-align:left;overscroll-behavior:contain}.bottom-sheet-body::-webkit-scrollbar{width:5px}.bottom-sheet-body::-webkit-scrollbar-track{background:transparent}.bottom-sheet-body::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}[data-theme=dark] .bottom-sheet-body::-webkit-scrollbar-thumb{background:#ffffff26}.bottom-sheet-body::-webkit-scrollbar-thumb:hover{background:#0000004d}[data-theme=dark] .bottom-sheet-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.shopping-container{display:flex;flex-direction:column;gap:1.25rem;width:100%;animation:fadeIn .4s ease-out}.shopping-tabs-container{position:relative;width:100%;display:flex;align-items:center}.shopping-tabs-container:before,.shopping-tabs-container:after{display:none!important}.shopping-tabs-scroll{width:100%;overflow-x:visible!important;padding:0}.shopping-tabs{display:flex;flex-wrap:wrap;gap:.5rem;width:100%;padding:.35rem;background-color:var(--bg-subtle);border-radius:18px;border:1px solid var(--color-border);box-shadow:inset 0 2px 4px #0000000a}.shopping-tab-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1 1 calc(33.333% - .35rem);min-width:90px;padding:.7rem .5rem;border-radius:12px;border:none;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.shopping-tab-btn:hover{color:var(--text-primary);background-color:#00000005}.shopping-tab-btn:active{transform:scale(.96);transition:transform .1s ease}.shopping-tab-btn.active{background-color:var(--bg-surface);color:var(--color-primary);opacity:1;font-weight:700;box-shadow:0 4px 12px #0000000d,0 1px 3px #00000008}.shopping-tab-btn.locked{background-color:#00000004;color:var(--text-muted);opacity:.45;cursor:not-allowed}.shopping-tab-btn.locked:hover{background-color:transparent;color:var(--text-muted)}.shopping-tab-btn .lock-icon{margin-left:2px;opacity:.5}@media(max-width:360px){.shopping-tab-btn{font-size:.78rem;padding:.65rem .3rem}}.shopping-control-header{display:flex;flex-direction:column;align-items:stretch;gap:.65rem;padding:.25rem .25rem .5rem}.shopping-control-header .info-text{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.shopping-control-header .info-icon{color:var(--color-primary)}.control-buttons{display:grid;grid-template-columns:repeat(6,1fr);gap:.45rem;width:100%}.control-buttons button:nth-child(1),.control-buttons button:nth-child(2){grid-column:span 3}.control-buttons button:nth-child(3),.control-buttons button:nth-child(4),.control-buttons button:nth-child(5){grid-column:span 2}.icon-btn-text{display:flex;align-items:center;justify-content:center;gap:4px;background:var(--bg-subtle);border:1px solid var(--color-border);color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;padding:.45rem .25rem;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;min-width:0;box-shadow:var(--shadow-1)}.icon-btn-text:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--color-border-strong)}.icon-btn-text:active{transform:scale(.95);transition:transform .1s ease}.icon-btn-text.text-danger{color:var(--text-danger);border-color:#ef444426}.icon-btn-text.text-danger:hover{background-color:#ef444414;color:var(--text-danger);border-color:var(--text-danger)}.empty-shopping-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;background-color:var(--bg-surface);border-radius:20px;border:1px dashed var(--color-border);text-align:center;gap:.75rem}.empty-cart-icon{color:var(--text-muted);opacity:.6;margin-bottom:.5rem}.empty-shopping-state h4{font-size:1.05rem;font-weight:700;margin:0}.empty-shopping-state p{font-size:.85rem;color:var(--text-secondary);margin:0;max-width:280px;line-height:1.4}.empty-cta-btn{margin-top:1.25rem;padding:.7rem 1.6rem;background:linear-gradient(135deg,var(--color-primary),#43a047);color:var(--text-inverse);border:none;border-radius:12px;font-weight:700;font-size:.82rem;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #4caf5040;display:inline-flex;align-items:center;justify-content:center;gap:6px;outline:none}.empty-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4caf5059}.shopping-categories-list{display:flex;flex-direction:column;gap:1.25rem}.shopping-category-card{background-color:var(--bg-surface);border-radius:20px;padding:1.25rem;border:1px solid var(--color-border);box-shadow:var(--shadow-1);transition:transform .2s,box-shadow .2s,padding-bottom .3s ease}.shopping-category-card:hover{box-shadow:var(--shadow-2)}.category-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding-bottom:.75rem;margin-bottom:1rem;border-bottom:1.5px solid var(--color-border);-webkit-user-select:none;user-select:none;transition:opacity .2s ease,border-bottom-color .25s ease,margin-bottom .25s ease,padding-bottom .25s ease}.category-header:hover{opacity:.85}.category-title-wrapper{display:flex;align-items:center;gap:8px}.category-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0;padding:0}.category-progress-badge{font-size:.72rem;font-weight:700;color:var(--text-muted);background-color:var(--bg-subtle);padding:2px 8px;border-radius:20px;border:1px solid var(--color-border);transition:all .25s ease}.category-progress-badge.all-completed{color:var(--text-inverse);background-color:var(--color-primary);border-color:var(--color-primary)}.collapse-chevron{color:var(--text-muted);transition:transform .3s cubic-bezier(.4,0,.2,1),color .2s ease}.category-header:hover .collapse-chevron{color:var(--color-primary)}.shopping-category-card.collapsed{padding-bottom:.75rem}.shopping-category-card.collapsed .category-header{border-bottom-color:transparent;margin-bottom:0;padding-bottom:0}.shopping-category-card.collapsed .collapse-chevron{transform:rotate(-90deg)}.shopping-category-card .ingredient-items-grid{display:grid;grid-template-columns:1fr;gap:.65rem;max-height:1200px;opacity:1;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .3s ease}.shopping-category-card.collapsed .ingredient-items-grid{max-height:0;opacity:0;pointer-events:none}@media(min-width:400px){.shopping-category-card .ingredient-items-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}.ingredient-check-item{display:flex;align-items:flex-start;gap:10px;padding:.75rem .85rem;border-radius:12px;background-color:var(--bg-subtle);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:48px;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.ingredient-check-item:hover{background-color:var(--bg-hover);border-color:var(--color-border);transform:translateY(-1px)}.ingredient-check-item:active{transform:scale(.98);transition:transform .1s ease}.checkbox-indicator{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:2px solid var(--text-muted);background-color:transparent;color:var(--text-inverse);transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-top:2px}.ingredient-name{flex:1;min-width:0;font-size:.82rem;font-weight:500;color:var(--text-secondary);line-height:1.35;transition:all .2s;word-break:keep-all;overflow-wrap:break-word}.ingredient-check-item.checked{background-color:var(--bg-surface);border-color:var(--color-border)}.ingredient-check-item.checked .checkbox-indicator{background-color:var(--color-primary);border-color:var(--color-primary)}.ingredient-check-item.checked .ingredient-name{text-decoration:line-through;color:var(--text-muted);opacity:.55}.toast-notification{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background-color:var(--text-primary);color:var(--bg-surface);padding:.8rem 1.5rem;border-radius:50px;font-size:.85rem;font-weight:600;box-shadow:var(--shadow-2);z-index:1100;display:flex;align-items:center;animation:toastSlideUp .3s cubic-bezier(.18,.89,.32,1.28)}.premium-lock-overlay-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;background-color:var(--bg-surface);border-radius:20px;border:1px solid var(--color-border);text-align:center;gap:.85rem;animation:fadeIn .3s ease-out}.lock-illustration{color:var(--color-primary);opacity:.85;margin-bottom:.25rem}.premium-lock-overlay-content h3{font-size:1.15rem;font-weight:700;margin:0}.premium-lock-overlay-content p{font-size:.88rem;color:var(--text-secondary);margin:0;max-width:300px;line-height:1.5}.inline-premium-btn{margin-top:.5rem;width:auto!important;padding:.75rem 1.75rem!important;font-weight:600}@keyframes toastSlideUp{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}.buy-shortcut-btn{background:transparent;border:none;border-radius:8px;padding:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-left:2px;align-self:flex-start;margin-top:1px}.buy-shortcut-btn:hover{background-color:var(--bg-hover);color:var(--color-primary)}.buy-shortcut-btn:active{transform:scale(.9);transition:transform .1s ease}.ingredient-check-item.checked .buy-shortcut-btn{opacity:.4}.usage-modal-overlay{position:fixed;inset:0;background-color:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s cubic-bezier(.4,0,.2,1);padding:1.5rem}.usage-modal-overlay.active{opacity:1;pointer-events:auto}.usage-modal-card{width:100%;max-width:360px;background-color:var(--bg-surface);border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-3);border:1px solid var(--color-border);transform:scale(.95);transition:transform .25s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;gap:1.25rem;max-height:80vh}.usage-modal-overlay.active .usage-modal-card{transform:scale(1)}.usage-modal-drag-handle{width:36px;height:4px;background-color:var(--color-border);border-radius:2px;align-self:center;opacity:.6}.usage-modal-header{text-align:center;display:flex;flex-direction:column;gap:4px}.usage-modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;display:flex;align-items:center;justify-content:center;gap:6px}.usage-modal-subtitle{font-size:.8rem;color:var(--text-muted);margin:0;line-height:1.4;word-break:keep-all}.usage-modal-body{overflow-y:auto;max-height:40vh;padding-right:4px;overscroll-behavior:contain}.usage-modal-body::-webkit-scrollbar{width:6px}.usage-modal-body::-webkit-scrollbar-track{background:transparent}.usage-modal-body::-webkit-scrollbar-thumb{background-color:var(--color-border-strong);border-radius:3px}.popover-usage-list{display:flex;flex-direction:column;gap:8px}.usage-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:.5rem 0;border-bottom:1px solid var(--color-border)}.usage-item:last-child{border-bottom:none}.usage-date{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;font-weight:500}.usage-menu{font-size:.8rem;color:var(--text-primary);font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.usage-menu.locked{color:var(--color-primary);cursor:pointer;font-weight:700;filter:blur(1.5px);opacity:.8;transition:filter .25s ease,opacity .25s ease,transform .2s ease;-webkit-user-select:none;user-select:none;display:inline-block}.usage-menu.locked:hover{filter:blur(0px);opacity:1;transform:scale(1.02)}.usage-menu.locked:active{transform:scale(.96)}.usage-empty{font-size:.85rem;color:var(--text-muted);text-align:center;padding:1.5rem 0}.usage-modal-close-btn{width:100%;padding:.75rem;background-color:var(--bg-subtle);border:1px solid var(--color-border);color:var(--text-secondary);font-size:.85rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center}.usage-modal-close-btn:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--color-border-strong)}.usage-modal-close-btn:active{transform:scale(.97)}.ingredient-info-btn{background:transparent;border:none;border-radius:8px;padding:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-left:auto;align-self:flex-start;margin-top:1px}.ingredient-info-btn:hover,.ingredient-info-btn.active{background-color:var(--bg-hover);color:var(--color-primary)}.ingredient-info-btn:active{transform:scale(.88);transition:transform .1s ease}.ingredient-check-item.checked .ingredient-info-btn{opacity:.4}.buy-bottom-sheet-overlay{position:fixed;inset:0;background-color:#0006;z-index:10000;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s cubic-bezier(.4,0,.2,1)}.buy-bottom-sheet-overlay.active{opacity:1;pointer-events:auto}.buy-bottom-sheet{width:100%;max-width:480px;background-color:var(--bg-surface);border-radius:24px 24px 0 0;padding:1.5rem 1.5rem calc(1.5rem + env(safe-area-inset-bottom,12px));box-shadow:var(--shadow-3);transform:translateY(100%);transition:transform .35s cubic-bezier(.1,.76,.55,.94);display:flex;flex-direction:column;gap:1.25rem;border-top:1px solid var(--color-border);overscroll-behavior:contain}.buy-bottom-sheet.active{transform:translateY(0)}.sheet-drag-handle{width:36px;height:4px;background-color:var(--color-border);border-radius:2px;align-self:center;margin-bottom:.25rem;opacity:.6}.buy-sheet-header{text-align:center;display:flex;flex-direction:column;gap:4px}.buy-sheet-header h3{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0}.buy-sheet-header .sheet-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.buy-sheet-buttons{display:flex;flex-direction:column;gap:.75rem;width:100%}.buy-sheet-btn{display:flex;align-items:center;gap:14px;padding:.9rem 1.1rem;border-radius:16px;border:1px solid var(--color-border);background-color:var(--bg-base);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.buy-sheet-btn:hover{background-color:var(--bg-hover);border-color:var(--color-primary-200)}.buy-sheet-btn:active{transform:scale(.98);transition:transform .1s ease}.store-badge{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:900;color:var(--text-inverse);flex-shrink:0}.store-badge.coupang{background:linear-gradient(135deg,#f96400,#ff8500);box-shadow:0 4px 10px #f9640033}.store-badge.kurly{background:linear-gradient(135deg,#5f0080,#7a1599);box-shadow:0 4px 10px #5f008033}.store-info{display:flex;flex-direction:column;gap:2px}.store-name{font-size:.92rem;font-weight:700;color:var(--text-primary)}.store-desc{font-size:.76rem;color:var(--text-muted)}.buy-sheet-cancel-btn{padding:.85rem;border-radius:16px;border:none;background-color:var(--bg-base);color:var(--text-secondary);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center}.buy-sheet-cancel-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.buy-sheet-cancel-btn:active{transform:scale(.98);transition:transform .1s ease}@media(max-width:440px){.shopping-control-header{gap:.5rem;padding:.25rem 0}.shopping-control-header .info-text{justify-content:center;font-size:.78rem}.control-buttons{gap:.35rem}.icon-btn-text{padding:.5rem .2rem;font-size:.72rem;border-radius:8px}}@media print{body,.app-container,.shopping-container{background:#fff!important;color:#111!important;max-width:100%!important;width:100%!important;box-shadow:none!important;padding:0!important;margin:0!important}.app-header,.shopping-tabs-container,.shopping-control-header,.buy-shortcut-btn,.ingredient-info-btn,.offline-banner-container,.timer-floating-widget,.sync-toast-notification,.toast-notification,.buy-bottom-sheet-overlay,nav{display:none!important}.shopping-container:before{content:"🥗 오끼니 스마트 장보기 리스트";display:block;font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:2rem;border-bottom:2px solid #111111;padding-bottom:.5rem}.shopping-categories-list{display:block!important;padding:0!important}.shopping-category-card{page-break-inside:avoid;break-inside:avoid;border:1px solid #e2e8f0!important;margin-bottom:1.25rem!important;box-shadow:none!important;border-radius:12px!important;background:#fff!important}.category-header{border-bottom:1px solid #e2e8f0!important;padding-bottom:.5rem!important;margin-bottom:1rem!important;display:flex!important;justify-content:space-between!important;align-items:center!important;cursor:default!important}.category-title{border-bottom:none!important;padding-bottom:0!important;color:#111!important;font-size:1rem!important}.shopping-category-card.collapsed .category-header{border-bottom:1px solid #e2e8f0!important;margin-bottom:1rem!important;padding-bottom:.5rem!important}.shopping-category-card.collapsed .ingredient-items-grid{max-height:none!important;opacity:1!important;pointer-events:auto!important;display:grid!important}.collapse-chevron,.shopping-category-card.collapsed .collapse-chevron{display:none!important}.category-progress-badge{color:#475569!important;border:1px solid #cbd5e1!important;background:#f1f5f9!important;font-size:.75rem!important}.ingredient-items-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:.5rem!important}.ingredient-check-item{border:1px solid #f1f5f9!important;background:#f8fafc!important;padding:.5rem!important;color:#111!important;min-height:auto!important;box-shadow:none!important;border-radius:8px!important}.checkbox-indicator{border:2px solid #475569!important;width:16px!important;height:16px!important}.ingredient-check-item.checked{background:#f8fafc!important;border-color:#f1f5f9!important}.ingredient-check-item.checked .checkbox-indicator{background-color:#475569!important;border-color:#475569!important}.ingredient-check-item.checked .ingredient-name{text-decoration:line-through!important;color:#94a3b8!important;opacity:.7!important}.ingredient-name{font-size:.8rem!important;color:#334155!important}}.analytics-container{display:flex;flex-direction:column;gap:1.25rem;padding:.5rem .25rem;animation:analyticsFadeIn .4s ease-out}.sub-tab-switcher{display:flex;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:14px;padding:.25rem;gap:.25rem}.sub-tab-btn{flex:1;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;padding:.65rem 0;border-radius:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);outline:none}.sub-tab-btn.active{background:var(--bg-base);color:var(--color-primary);box-shadow:0 4px 12px var(--shadow-color)}.sub-tab-btn:active{transform:scale(.98)}.analytics-content-view{display:flex;flex-direction:column;gap:1.25rem;animation:analyticsSlideUp .3s ease-out}.stat-main-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(33,150,243,.05) 100%);border:1px solid var(--color-border);border-radius:20px;padding:1.5rem;width:100%;box-shadow:0 8px 24px var(--shadow-color);text-align:center}.card-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.overall-rate-circle{position:relative;display:flex;align-items:baseline;justify-content:center;width:100px;height:100px;border-radius:50%;background:var(--bg-base);border:4px solid var(--color-primary);box-shadow:inset 0 4px 10px var(--shadow-color);line-height:92px}.rate-num{font-size:2.25rem;font-weight:900;color:var(--text-primary);font-family:Outfit,sans-serif}.rate-pct{font-size:1rem;font-weight:700;color:var(--color-primary);margin-left:2px}.card-desc{font-size:.85rem;color:var(--text-muted);font-weight:500;margin-top:.75rem}.weekly-stats-list{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 4px 16px var(--shadow-color)}.weekly-stats-list h4{font-size:.95rem;font-weight:800;color:var(--text-primary);margin:0}.weekly-stat-item{display:flex;flex-direction:column;gap:.35rem}.week-info{display:flex;justify-content:space-between;font-size:.8rem;font-weight:600;color:var(--text-secondary)}.week-rate{font-weight:700;color:var(--text-primary)}.progress-bar-bg{height:8px;background:var(--bg-base);border-radius:99px;overflow:hidden;position:relative;box-shadow:inset 0 1px 3px #0000001a}.progress-bar-fill{height:100%;border-radius:99px;transition:width .8s cubic-bezier(.1,.8,.25,1)}.weekly-stat-item.locked{position:relative;cursor:pointer!important}.weekly-stat-item.locked .progress-bar-bg,.weekly-stat-item.locked .week-rate{filter:blur(3.5px);pointer-events:none;opacity:.65}.weekly-stat-lock-badge{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:var(--bg-base);border:1px solid var(--color-border);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);box-shadow:0 2px 6px var(--shadow-color)}.week-rate-badge.future{font-size:.725rem;font-weight:700;color:var(--text-muted);background-color:var(--bg-base);border:1px dashed var(--color-border);padding:.15rem .45rem;border-radius:8px;display:inline-flex;align-items:center}.progress-bar-fill.future-fill,.progress-bar-fill.locked-fill{background-color:transparent!important}.analytics-badge-box{background:linear-gradient(135deg,#ffb74d14,#ff980008);border:1px solid rgba(255,183,77,.2);border-radius:16px;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.badge-header{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;color:#ff9800}.analytics-badge-box p{margin:0;font-size:.8rem;line-height:1.45;color:var(--text-secondary);font-weight:500}.weight-entry-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 4px 16px var(--shadow-color)}.weight-entry-card h4{font-size:.95rem;font-weight:800;color:var(--text-primary);margin:0}.weight-form{display:flex;flex-direction:column;gap:1rem}.slider-container{padding:.5rem 0}.weight-slider{width:100%;-webkit-appearance:none;background:var(--bg-base);height:6px;border-radius:99px;outline:none}.weight-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);border:3px solid var(--bg-surface);box-shadow:0 2px 8px #0003;cursor:pointer;transition:transform .1s}.weight-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.weight-input-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.weight-adjust-container{display:flex;align-items:center;gap:.5rem;flex:1.5}.weight-adjust-btn{background:var(--bg-base);border:1px solid var(--color-border);color:var(--text-primary);font-size:1.25rem;font-weight:700;width:38px;height:38px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none}.weight-adjust-btn:hover:not(:disabled){background:var(--color-border);transform:scale(1.05)}.weight-adjust-btn:active:not(:disabled){transform:scale(.95)}.weight-adjust-btn:disabled{opacity:.5;cursor:not-allowed}.number-input-box{display:flex;align-items:center;background:var(--bg-base);border:1px solid var(--color-border);border-radius:12px;padding:.5rem .75rem;flex:1}.weight-num-input{border:none;background:transparent;font-size:1.15rem;font-weight:800;color:var(--text-primary);width:100%;outline:none;text-align:center;font-family:Outfit,sans-serif}.unit-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);margin-left:.25rem}.submit-weight-btn{flex:1;padding:.75rem 0;border-radius:12px}.weight-chart-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 4px 16px var(--shadow-color)}.card-header-with-action{display:flex;justify-content:space-between;align-items:center}.weight-chart-card h4{font-size:.95rem;font-weight:800;color:var(--text-primary);margin:0}.premium-only-tag{background:#ffb74d1f;border:1px solid rgba(255,183,77,.3);color:#ff9800;font-size:.7rem;font-weight:800;padding:.15rem .4rem;border-radius:8px;display:inline-flex;align-items:center;gap:3px}.chart-wrapper{position:relative;width:100%;border-radius:12px;overflow:hidden;background:var(--bg-base);padding:.5rem 0}.chart-wrapper.locked-blur .svg-line-chart{filter:blur(5px);pointer-events:none;opacity:.6}.svg-line-chart text{font-family:Outfit,Pretendard,sans-serif}.lock-banner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0f1117bf;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:#fff;text-align:center;cursor:pointer;z-index:10;animation:fadeIn .3s ease}[data-theme=light] .lock-banner-overlay{background:#ffffffbf;color:var(--text-primary)}.lock-banner-overlay p{margin:0;font-size:.775rem;font-weight:700;line-height:1.4}.lock-banner-overlay svg{color:#ff9800}.lock-banner-overlay .inline-btn{font-size:.75rem;padding:.4rem 1rem;border-radius:8px;margin-top:2px;box-shadow:0 4px 10px #00000026}.empty-chart-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.empty-chart-overlay p{margin:0;font-size:.775rem;color:var(--text-secondary);font-weight:600;line-height:1.4}.empty-chart-overlay svg{color:var(--text-muted)}.analysis-indicator-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;align-items:flex-start;gap:.85rem;box-shadow:0 4px 16px var(--shadow-color)}.indicator-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;flex-shrink:0}.indicator-icon.down{background:#2196f31f;color:#2196f3}.indicator-icon.up{background:#e91e631f;color:#e91e63}.indicator-icon.maintenance{background:#4caf501f;color:#4caf50}.indicator-text{display:flex;flex-direction:column;gap:.25rem}.indicator-text h4{margin:0;font-size:.9rem;font-weight:800;color:var(--text-primary)}.indicator-text p{margin:0;font-size:.8rem;line-height:1.45;color:var(--text-secondary);font-weight:500}@keyframes analyticsFadeIn{0%{opacity:0}to{opacity:1}}@keyframes analyticsSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.tab-with-lock{display:flex;align-items:center;justify-content:center;gap:.35rem}.lock-icon-tab{color:var(--text-muted)}.sub-tab-btn.active .lock-icon-tab{color:var(--color-primary)}.ai-report-locked-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;padding:2.25rem 1.5rem;box-shadow:0 8px 30px var(--shadow-color);animation:analyticsSlideUp .35s ease-out}.lock-illustration{position:relative;width:90px;height:90px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf501a,#2196f31a);border-radius:50%;margin-bottom:1.25rem}.report-locked-icon{color:var(--color-primary)}.lock-badge-icon{position:absolute;bottom:4px;right:4px;background-color:var(--bg-surface);color:var(--color-accent);padding:4px;border-radius:50%;box-shadow:0 2px 8px #00000026;border:1.5px solid var(--color-border)}.ai-report-locked-card h3{font-size:1.15rem;font-weight:800;color:var(--text-primary);margin:0 0 .75rem}.locked-desc{font-size:.85rem;line-height:1.5;color:var(--text-secondary);margin:0 0 1.5rem;max-width:320px}.locked-features-list{display:flex;flex-direction:column;gap:.95rem;width:100%;max-width:320px;margin-bottom:2rem;text-align:left}.locked-feature-item{display:flex;gap:.75rem;align-items:flex-start}.locked-feature-item .bullet{font-size:.85rem}.locked-feature-item div{display:flex;flex-direction:column;gap:.15rem}.locked-feature-item strong{font-size:.88rem;font-weight:700;color:var(--text-primary)}.locked-feature-item span{font-size:.75rem;color:var(--text-muted)}.upgrade-button{width:100%;max-width:320px;box-shadow:0 4px 15px #4caf5040}.ai-report-loading-box{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;padding:3rem 1.5rem;box-shadow:0 8px 30px var(--shadow-color)}.spinner-glow{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background-color:#4caf5014;border-radius:50%;margin-bottom:1.5rem;position:relative}.spinner-glow:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid transparent;border-top-color:var(--color-primary);animation:spinnerRotate 1.2s linear infinite}.pulse-report-icon{color:var(--color-primary);animation:reportPulse 1.5s ease-in-out infinite alternate}.ai-report-loading-box h3{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem}.ai-report-loading-box p{font-size:.825rem;color:var(--text-secondary);line-height:1.45;max-width:280px;margin:0 0 1.75rem}.loading-bar-tracker{width:100%;max-width:240px;height:6px;background-color:var(--bg-base);border-radius:10px;overflow:hidden}.loading-bar-progress{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:10px;animation:fillProgress 6s cubic-bezier(.1,.8,.2,1) forwards}.ai-report-results-view{display:flex;flex-direction:column;gap:1.25rem}.report-score-card{display:flex;align-items:center;gap:1.5rem;background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(76,175,80,.04) 100%);border:1px solid var(--color-border);border-radius:20px;padding:1.5rem;box-shadow:0 6px 20px var(--shadow-color)}.score-ring-container{position:relative;width:100px;height:100px;flex-shrink:0}.score-circle-svg{transform:rotate(-90deg)}.score-circle-bg{fill:none;stroke:var(--bg-base);stroke-width:8}.score-circle-fill{fill:none;stroke:var(--color-primary);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.34,1.56,.64,1)}.score-text-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:baseline;justify-content:center;line-height:100px}.score-number{font-size:2rem;font-weight:900;color:var(--text-primary);font-family:Outfit,sans-serif}.score-unit{font-size:.85rem;font-weight:700;color:var(--text-secondary);margin-left:2px}.score-evaluation{display:flex;flex-direction:column;gap:.35rem}.score-evaluation h3{margin:0;font-size:.95rem;font-weight:800;color:var(--text-primary)}.score-evaluation p{margin:0;font-size:.8rem;color:var(--text-secondary);line-height:1.4;font-weight:500}.report-feedback-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;box-shadow:0 4px 16px var(--shadow-color)}.report-feedback-card .card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.85rem}.icon-ai{color:var(--color-primary)}.report-feedback-card h4{margin:0;font-size:.9rem;font-weight:800;color:var(--text-primary)}.feedback-content{background-color:var(--bg-base);border-radius:16px;padding:1rem;border:1px solid var(--color-border);position:relative}.feedback-content p{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-primary);font-weight:600}.report-tip-card{background:linear-gradient(135deg,#2196f314,#2196f308);border:1px solid rgba(33,150,243,.2);border-radius:16px;padding:1.25rem;display:flex;flex-direction:column;gap:.65rem}.tip-header-row{display:flex}.tip-badge{background-color:#2196f326;color:#1976d2;font-size:.725rem;font-weight:800;padding:.25rem .65rem;border-radius:8px;display:inline-block;align-self:flex-start;letter-spacing:.02em}[data-theme=dark] .tip-badge{background-color:#2196f340;color:#64b5f6}.tip-text{margin:0;font-size:.85rem;line-height:1.55;color:var(--text-primary);font-weight:700}.regenerate-report-btn{display:flex;align-items:center;justify-content:center;gap:6px;background-color:var(--bg-surface);border:1px solid var(--color-border);color:var(--text-secondary);font-size:.825rem;font-weight:700;padding:.85rem;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);margin-top:.75rem;box-shadow:0 2px 6px #00000005}.regenerate-report-btn:hover{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--color-border-strong)}.regenerate-report-btn:active{transform:scale(.98)}.ai-report-empty-box{display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;padding:3rem 1.5rem;box-shadow:0 8px 30px var(--shadow-color)}.empty-report-icon{color:var(--text-muted);margin-bottom:1.25rem}.ai-report-empty-box h3{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem}.ai-report-empty-box p{font-size:.825rem;color:var(--text-secondary);line-height:1.45;max-width:260px;margin:0 0 1.75rem}.ai-report-error-box{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem 1.5rem;background:var(--bg-surface);border:1px dashed var(--color-border);border-radius:20px;gap:1rem}.ai-report-error-box p{font-size:.875rem;color:var(--text-danger-label, #f44336);font-weight:600;margin:0}@keyframes spinnerRotate{to{transform:rotate(360deg)}}@keyframes reportPulse{0%{transform:scale(1);opacity:.9}to{transform:scale(1.08);opacity:1}}@keyframes fillProgress{0%{width:0%}to{width:92%}}.report-data-summary{display:flex;align-items:center;justify-content:center;background:var(--bg-base);border:1px solid var(--color-border);border-radius:16px;padding:1rem 1.5rem;gap:1.5rem;margin-bottom:1.25rem;width:100%;max-width:320px}.summary-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1}.summary-label{font-size:.725rem;color:var(--text-muted);font-weight:600}.summary-value{font-size:1.1rem;font-weight:800;color:var(--color-primary);font-family:Outfit,sans-serif}.summary-item-divider{width:1px;height:24px;background-color:var(--color-border)}.loading-time-notice{font-size:.75rem;color:var(--text-muted);font-weight:600;margin:0 0 1.25rem;display:flex;align-items:center;gap:4px}.report-comparison-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;box-shadow:0 4px 16px var(--shadow-color);display:flex;flex-direction:column;gap:1rem}.report-comparison-card h4{font-size:.925rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.02em}.comparison-row{display:flex;flex-direction:column;gap:.4rem}.comparison-label{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;font-weight:700}.comparison-label .name{color:var(--text-secondary)}.comparison-label .value{color:var(--text-primary);font-family:Outfit,sans-serif}.comparison-bar-wrapper{width:100%}.comparison-bar-wrapper .bar-bg{height:18px;background:var(--bg-base);border-radius:99px;overflow:hidden;position:relative;box-shadow:inset 0 1px 3px #00000014}.comparison-bar-wrapper .bar-fill{height:100%;border-radius:99px;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;transition:width 1.2s cubic-bezier(.1,.8,.25,1);min-width:24px}.comparison-bar-wrapper .bar-fill.calorie{background:linear-gradient(90deg,#ff9800,#ffb74d)}.comparison-bar-wrapper .bar-fill.carb{background:linear-gradient(90deg,#2196f3,#64b5f6)}.comparison-bar-wrapper .bar-fill.protein{background:linear-gradient(90deg,#4caf50,#81c784)}.comparison-bar-wrapper .bar-fill.fat{background:linear-gradient(90deg,#e91e63,#f48fb1)}.percent-label{font-size:.7rem;font-weight:800;color:#fff;font-family:Outfit,sans-serif;text-shadow:0 1px 2px rgba(0,0,0,.2)}.report-summary-block{background:linear-gradient(135deg,#4caf500f,#2196f30a);border-left:4px solid var(--color-primary);border-radius:4px 16px 16px 4px;padding:1.15rem 1.25rem;position:relative;box-shadow:0 4px 12px var(--shadow-color)}.summary-quote{font-family:Outfit,serif;font-size:2.5rem;color:var(--color-primary);opacity:.3;position:absolute;top:-5px;left:10px;line-height:1;pointer-events:none}.report-summary-block p{margin:0;font-size:.88rem;line-height:1.55;color:var(--text-primary);font-weight:700;padding-left:.75rem;position:relative;z-index:1}.report-details-container{display:flex;flex-direction:column;gap:1rem}.report-detail-section-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;box-shadow:0 4px 16px var(--shadow-color);display:flex;flex-direction:column;gap:.75rem;transition:transform .25s,box-shadow .25s}.report-detail-section-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-color)}.section-title-row{display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.section-title-row h4{font-size:.925rem;font-weight:800;color:var(--text-primary);margin:0}.section-title-row svg{color:var(--color-primary)}.section-title-row .icon-target{color:#ff9800}.section-title-row .icon-droplet{color:#2196f3}.section-title-row .icon-scale{color:#e91e63}.detail-card-content p{margin:0;font-size:.85rem;line-height:1.6;color:var(--text-secondary);font-weight:500}.report-action-plan-card{background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(255,183,77,.05) 100%);border:1px solid rgba(255,183,77,.25);border-radius:20px;padding:1.25rem;box-shadow:0 4px 16px var(--shadow-color);display:flex;flex-direction:column;gap:1rem}.report-action-plan-card h4{font-size:.925rem;font-weight:800;color:var(--text-primary);margin:0}.action-plan-list{display:flex;flex-direction:column;gap:.75rem}.action-plan-item{display:flex;align-items:center;gap:.75rem;background:var(--bg-base);border:1px solid var(--color-border);border-radius:12px;padding:.65rem .85rem;transition:transform .2s}.action-plan-item:hover{transform:translate(4px);border-color:#ffb74d66}.action-number{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background-color:var(--color-primary);color:#fff;font-size:.75rem;font-weight:900;border-radius:50%;flex-shrink:0;font-family:Outfit,sans-serif}.action-text{margin:0;font-size:.825rem;color:var(--text-primary);font-weight:600;line-height:1.4}.loading-step-text{font-size:.825rem;color:var(--text-secondary);line-height:1.45;max-width:280px;margin:0 0 1.75rem;font-weight:600;min-height:2.5rem;display:flex;align-items:center;justify-content:center}:root{--saju-purple-tint: rgba(138, 75, 243, .04);--saju-purple-border: rgba(138, 75, 243, .15);--saju-purple-text: #8a4bf3;--saju-orange-tint: rgba(255, 152, 0, .04);--saju-orange-border: rgba(255, 152, 0, .15);--saju-orange-text: #ff9800}[data-theme=dark]{--saju-purple-tint: rgba(187, 134, 252, .08);--saju-purple-border: rgba(187, 134, 252, .25);--saju-purple-text: #bb86fc;--saju-orange-tint: rgba(255, 183, 77, .08);--saju-orange-border: rgba(255, 183, 77, .25);--saju-orange-text: #ffb74d}.report-score-card{flex-direction:column;align-items:stretch!important;gap:1.25rem!important;background:linear-gradient(135deg,var(--bg-surface) 0%,var(--saju-purple-tint) 100%)!important;border:1px solid var(--saju-purple-border)!important}.score-main-info{display:flex;align-items:center;gap:1.5rem;width:100%}.score-description-box{background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:12px;padding:.85rem 1rem;margin-top:.25rem}.score-description-box p{margin:0;font-size:.8rem;line-height:1.45;color:var(--text-secondary);font-weight:600;word-break:keep-all}.report-comparison-subtext{margin:0;font-size:.725rem;color:var(--text-muted);font-weight:500;line-height:1.4;padding-left:.25rem}.saju-feedback-card{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--saju-purple-tint) 100%)!important;border:1px solid var(--saju-purple-border)!important}.saju-feedback-card .icon-ai{color:var(--saju-purple-text)!important}.saju-tip-card{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--saju-orange-tint) 100%)!important;border:1px solid var(--saju-orange-border)!important}.saju-tip-card .tip-badge{background-color:var(--saju-orange-tint)!important;color:var(--saju-orange-text)!important}.saju-danja-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.5rem;box-shadow:0 4px 16px var(--shadow-color);display:flex;flex-direction:column;gap:1rem}.saju-danja-header{display:flex;align-items:center;justify-content:center;gap:.5rem}.saju-danja-header h4{font-size:.95rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.02em}.saju-danja-decor{font-size:1rem;opacity:.8}.saju-danja-intro{margin:0;font-size:.8rem;color:var(--text-secondary);text-align:center;font-weight:500}.saju-element-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.saju-element-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:12px;border:1px solid var(--color-border);background:var(--bg-base);transition:transform .2s ease,border-color .2s ease}.saju-element-item:hover{transform:translateY(-2px)}.element-emoji{font-size:1.25rem;flex-shrink:0}.element-info{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.element-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.element-desc{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.element-pct{font-size:.85rem;font-weight:800;color:var(--text-primary);font-family:Outfit,sans-serif;flex-shrink:0}.saju-element-item.good{background:#4caf500d;border-color:#4caf5026}.saju-element-item.good .element-label{color:var(--text-success, #4caf50)}.saju-element-item.strong{background:#f443360d;border-color:#f4433626}.saju-element-item.strong .element-label{color:var(--text-danger, #f44336)}.saju-element-item.weak{background:#ff98000d;border-color:#ff980026}.saju-element-item.weak .element-label{color:var(--text-warning, #ff9800)}.saju-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;padding:3.5rem 1.5rem;box-shadow:0 8px 30px var(--shadow-color);animation:analyticsSlideUp .35s ease-out}.saju-spinner-glow{width:90px;height:90px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffb74d1a,#f443361a);border-radius:50%;margin-bottom:1.5rem;position:relative;box-shadow:0 0 20px #ff980026}.yinyang-spinner{width:55px;height:55px;border-radius:50%;background:linear-gradient(to right,#000 50%,#fff 50%);animation:spinnerRotate 2s linear infinite;box-shadow:0 0 10px #00000080}@keyframes spinnerRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.saju-loading-text-sub{font-size:.85rem;color:var(--color-primary);font-weight:700;margin-top:.5rem;min-height:1.5rem;animation:pulse 1s infinite alternate}@keyframes pulse{0%{opacity:.6}to{opacity:1}}.saju-input-container{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;padding:2rem 1.5rem;box-shadow:0 8px 30px var(--shadow-color);animation:analyticsSlideUp .35s ease-out}.saju-intro-header{text-align:center;margin-bottom:2rem}.saju-intro-icon{margin-bottom:.75rem;animation:floatBall 3s ease-in-out infinite}@keyframes floatBall{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.saju-intro-header h3{font-size:1.25rem;font-weight:900;color:var(--text-primary);margin:0 0 .5rem}.saju-intro-header p{font-size:.825rem;color:var(--text-secondary);line-height:1.5;margin:0}.saju-form{display:flex;flex-direction:column;gap:1.25rem}.saju-form-row{display:flex;gap:1rem}.saju-form-group{flex:1;display:flex;flex-direction:column;gap:.4rem}.saju-label{font-size:.8rem;font-weight:700;color:var(--text-secondary)}.saju-input-field{background:var(--bg-base);border:1px solid var(--color-border);color:var(--text-primary);border-radius:12px;padding:.75rem;font-size:.875rem;outline:none;font-weight:600;transition:border-color .2s,background-color .2s,color .2s;font-family:inherit;width:100%;box-sizing:border-box}select.saju-input-field{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23374151' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.25rem;cursor:pointer}[data-theme=dark] select.saju-input-field{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23d1d5db' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'%3E%3C/path%3E%3C/svg%3E")}[data-theme=dark] .saju-input-field::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}@media(max-width:480px){.saju-form-row{flex-direction:column;gap:.75rem}}.saju-input-field:focus{border-color:var(--color-primary)}.saju-submit-btn{margin-top:.5rem;padding:.9rem 0;border-radius:14px;font-weight:800;box-shadow:0 4px 15px #ff980033}.saju-disclaimer{font-size:.725rem;color:var(--text-muted);font-weight:500;text-align:center;margin-top:.25rem;line-height:1.4;word-break:keep-all}.saju-usage-badge{display:inline-block;background-color:var(--saju-purple-tint);border:1px solid var(--saju-purple-border);color:var(--saju-purple-text);font-size:.775rem;font-weight:700;padding:.35rem .75rem;border-radius:99px;margin-top:.75rem}.saju-result-container{display:flex;flex-direction:column;gap:1.25rem;animation:analyticsSlideUp .4s cubic-bezier(.1,.8,.2,1)}.saju-main-card{border-radius:24px;padding:2rem 1.5rem;text-align:center;color:#fff;position:relative;box-shadow:0 8px 30px #0000004d;overflow:hidden;background:linear-gradient(135deg,#1a0f0f,#3d0c0c);border:1px solid rgba(255,255,255,.08)}.saju-main-card.from-amber-950{background:linear-gradient(135deg,#1d0f08,#3a0d0d)}.saju-main-card.from-blue-950{background:linear-gradient(135deg,#090e21,#15103a)}.saju-main-card.from-emerald-950{background:linear-gradient(135deg,#061f14,#082d2c)}.saju-main-card.from-purple-950{background:linear-gradient(135deg,#180829,#30053a)}.saju-main-card.from-rose-950{background:linear-gradient(135deg,#250912,#440d12)}.saju-main-card.from-slate-950{background:linear-gradient(135deg,#0f172a,#1e293b)}.saju-badge{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);font-size:.725rem;font-weight:700;padding:.2rem .6rem;border-radius:8px;display:inline-block;margin-bottom:.75rem;letter-spacing:.05em;text-transform:uppercase}.saju-type-title{font-size:1.4rem;font-weight:900;margin:0 0 .5rem;letter-spacing:-.02em;font-family:Outfit,sans-serif;color:#ffca28}.saju-sub-title{font-size:1.05rem;font-weight:700;margin:0 0 1rem;opacity:.95;color:#fff}.saju-desc{font-size:.8rem;line-height:1.5;margin:0;opacity:.85;word-break:keep-all}.saju-table-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 4px 16px var(--shadow-color)}.saju-table-card h4{font-size:.9rem;font-weight:800;color:var(--text-primary);margin:0}.saju-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;background:var(--bg-base);border-radius:14px;padding:.5rem;border:1px solid var(--color-border)}.saju-grid-col{display:flex;flex-direction:column;gap:.35rem;text-align:center}.col-header{font-size:.7rem;font-weight:700;color:var(--text-muted);padding:.25rem 0}.grid-cell{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:8px;padding:.65rem 0;font-size:.825rem;font-weight:800;color:var(--text-secondary)}.grid-cell.stem{color:#ff9800}.grid-cell.branch{color:#2196f3}.grid-cell.highlight{border-color:#ffca28;background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(255,202,40,.05) 100%);color:#ffca28!important;box-shadow:0 0 8px #ffca281a}.saju-table-caption{margin:0;font-size:.675rem;color:var(--text-muted);text-align:center;font-weight:500}.saju-fortune-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 4px 16px var(--shadow-color)}.card-title-row{display:flex;align-items:center;gap:.5rem}.card-title-row h4{font-size:.9rem;font-weight:800;color:var(--text-primary);margin:0}.saju-fortune-icon{color:#ffca28}.fortune-text{margin:0;font-size:.825rem;line-height:1.5;color:var(--text-secondary);font-weight:500;word-break:keep-all}.saju-warning-box{background:#f443360f;border:1px dashed rgba(244,67,54,.25);border-radius:12px;padding:.75rem;display:flex;flex-direction:column;gap:.2rem}.warning-title{font-size:.725rem;font-weight:800;color:#f44336}.warning-text{margin:0;font-size:.8rem;font-weight:700;color:var(--text-primary)}.saju-solution-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:.6rem;box-shadow:0 4px 16px var(--shadow-color)}.saju-solution-card h4{font-size:.9rem;font-weight:800;color:var(--text-primary);margin:0}.solution-text{margin:0;font-size:.825rem;line-height:1.45;color:var(--text-secondary);font-weight:500}.highlight-text{color:var(--color-primary);font-weight:700}.solution-action-row{display:flex;flex-direction:column;gap:.5rem;background:var(--bg-base);border-radius:12px;padding:.75rem;margin-top:.25rem}.solution-tip{font-size:.725rem;color:var(--text-muted);font-weight:600}.saju-solution-btn{background:var(--color-primary);border:none;color:#fff;font-size:.775rem;font-weight:800;padding:.5rem 0;border-radius:8px;cursor:pointer;transition:transform .2s}.saju-solution-btn:hover{transform:scale(1.02)}.saju-solution-btn:active{transform:scale(.98)}.saju-talisman-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 4px 16px var(--shadow-color);align-items:center}.talisman-header{text-align:center;width:100%}.talisman-header h4{font-size:.9rem;font-weight:800;color:var(--text-primary);margin:0 0 .25rem}.talisman-desc{margin:0;font-size:.725rem;color:var(--text-muted);font-weight:500}.talisman-outer{width:160px;height:280px;perspective:600px;margin:.5rem 0}.talisman-paper{width:100%;height:100%;background-color:#fbc02d;border:3px double #c62828;border-radius:8px;padding:.75rem;display:flex;flex-direction:column;align-items:center;justify-content:space-between;box-shadow:0 8px 20px #00000040;position:relative;box-sizing:border-box}.talisman-stamp{font-family:Outfit,sans-serif;font-size:10px;font-weight:900;color:#c62828;text-transform:uppercase;letter-spacing:.1em;opacity:.8}.talisman-text-glow{font-family:궁서,Gungsuh,"serif",sans-serif;font-size:32px;font-weight:900;color:#b71c1c;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:4px;line-height:1.1;text-shadow:0 0 4px rgba(183,28,28,.15)}.talisman-vertical-title{font-size:10px;font-weight:700;color:#b71c1c;opacity:.9}.talisman-footer-stamp{border:1px solid #b71c1c;font-family:궁서,Gungsuh,"serif",sans-serif;font-size:8px;font-weight:700;color:#b71c1c;padding:1px 3px;border-radius:2px}.talisman-actions{display:flex;gap:.5rem;width:100%}.talisman-btn{flex:1;border:none;font-size:.775rem;font-weight:800;padding:.65rem 0;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.25rem;transition:all .2s}.talisman-btn:active{transform:scale(.98)}.talisman-btn.download{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #4caf5026}.talisman-btn.download:hover{transform:translateY(-1px)}.talisman-btn.share{background:var(--bg-base);color:var(--text-primary);border:1px solid var(--color-border)}.talisman-btn.share:hover{background:var(--color-border)}.saju-retry-btn{background:transparent;border:none;color:var(--text-muted);font-size:.725rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.25rem;margin:.5rem auto 1.5rem;padding:.5rem 1rem;border-radius:8px;transition:all .2s}.saju-retry-btn:hover{color:var(--text-secondary);background:var(--bg-base)}.saju-retry-btn:active{transform:scale(.98)}.fridge-container{display:flex;flex-direction:column;gap:1.25rem;width:100%;animation:fadeIn .4s cubic-bezier(.16,1,.3,1)}.fridge-info-card{position:relative;background:linear-gradient(135deg,#4caf5026,#2196f31a);border:1px solid rgba(76,175,80,.25);border-radius:24px;padding:1.5rem;overflow:hidden;box-shadow:0 8px 32px #00000005}[data-theme=dark] .fridge-info-card{background:linear-gradient(135deg,#4caf501a,#2196f30d);border-color:#4caf5026}.fridge-info-content{position:relative;z-index:2}.fridge-badge{display:inline-flex;align-items:center;gap:6px;padding:.35rem .75rem;background-color:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;border-radius:50px;margin-bottom:.85rem;box-shadow:0 4px 12px #4caf5033}.badge-icon{animation:pulse 2s infinite}.fridge-info-card h4{font-size:1.15rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem}.fridge-info-card p{font-size:.88rem;line-height:1.5;color:var(--text-secondary);margin:0;word-break:keep-all}.fridge-input-card{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;box-shadow:0 4px 20px #00000005}.input-row{display:flex;gap:.75rem;position:relative}.fridge-input{flex:1;background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:14px;padding:.85rem 1rem;font-size:.95rem;font-weight:600;color:var(--text-primary);transition:all .25s ease;outline:none;min-height:48px}.fridge-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-light)}[data-theme=dark] .fridge-input:focus{box-shadow:0 0 0 4px var(--color-accent-light)}.fridge-add-btn{display:flex;align-items:center;justify-content:center;background-color:var(--color-primary);color:#fff;border:none;border-radius:14px;width:48px;height:48px;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #4caf5040;flex-shrink:0}.fridge-add-btn:hover{background-color:var(--color-primary);box-shadow:0 4px 16px #4caf5059;opacity:.92}.fridge-add-btn:active{opacity:.8;transform:scale(.97)}.fridge-add-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.fridge-tier-limit{margin-top:.75rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.78rem;color:var(--text-muted);font-weight:500}.upgrade-link{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--text-warning);font-weight:700;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:background-color .2s}.upgrade-link:hover{background-color:var(--bg-warning)}.fridge-section-card{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;box-shadow:0 4px 20px #00000005}.section-title{display:flex;align-items:center;gap:6px;font-size:.95rem;font-weight:800;color:var(--text-primary);margin:0 0 1rem;letter-spacing:-.3px}.fridge-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1.5rem;text-align:center;border:1px dashed var(--color-border);border-radius:16px;background-color:var(--bg-base)}[data-theme=dark] .fridge-empty{background-color:#ffffff05}.empty-title{font-size:.9rem;font-weight:700;color:var(--text-secondary);margin:0 0 .25rem}.empty-desc{font-size:.8rem;color:var(--text-muted);margin:0;max-width:260px;line-height:1.4;word-break:keep-all}.fridge-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem 1rem;color:var(--text-muted);font-size:.85rem}.ingredients-chip-grid{display:flex;flex-wrap:wrap;gap:.5rem}.ingredient-chip-item{display:inline-flex;align-items:center;gap:6px;padding:.45rem .8rem;background-color:var(--bg-success);border:1px solid rgba(76,175,80,.15);border-radius:50px;transition:all .2s cubic-bezier(.4,0,.2,1);animation:scaleIn .25s cubic-bezier(.34,1.56,.64,1)}.ingredient-chip-item:hover{background-color:var(--bg-success);border-color:var(--text-success-label)}.chip-label{font-size:.85rem;font-weight:700;color:var(--text-success-label)}.chip-remove-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-success-label);cursor:pointer;padding:2px;border-radius:50%;transition:background-color .2s;opacity:.8}.chip-remove-btn:hover{background-color:var(--bg-success);opacity:1}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.preset-item-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:.85rem .5rem;background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:16px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;outline:none;min-height:72px}[data-theme=dark] .preset-item-btn{background-color:#ffffff05}.preset-item-btn:hover{border-color:var(--color-primary);background-color:#4caf500f}.preset-item-btn.added{border-color:var(--color-primary);background-color:#4caf5014;cursor:default;transform:none}.preset-icon{font-size:1.25rem}.preset-name{font-size:.8rem;font-weight:700;color:var(--text-secondary)}.preset-item-btn.added .preset-name{color:var(--color-primary)}.preset-check{position:absolute;top:4px;right:6px;font-size:.75rem;color:var(--color-primary);font-weight:900}.preset-item-btn.protein:hover{box-shadow:0 4px 12px #ff52520f}.preset-item-btn.vegetable:hover{box-shadow:0 4px 12px #4caf500f}.preset-item-btn.carb:hover{box-shadow:0 4px 12px #ff98000f}.preset-item-btn.fruit:hover{box-shadow:0 4px 12px #e91e630f}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.9}to{transform:scale(1);opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.fridge-tab-switcher{display:flex;background-color:var(--bg-base);border:1px solid var(--color-border);padding:4px;border-radius:12px;gap:4px;margin-bottom:1.25rem}.fridge-tab-btn{flex:1;border:none;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:700;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease}.fridge-tab-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.fridge-tab-btn.active{background-color:var(--bg-surface);color:var(--color-primary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.fridge-ocr-section{width:100%}.fridge-dropzone{border:2px dashed var(--color-border);border-radius:14px;padding:2.5rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;background-color:var(--bg-base);text-align:center}.fridge-dropzone:hover{border-color:var(--color-primary);background-color:#4caf500a}.dropzone-icon{color:var(--text-muted);margin-bottom:.75rem;transition:transform .2s ease}.fridge-dropzone:hover .dropzone-icon{transform:translateY(-2px);color:var(--color-primary)}.dropzone-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.dropzone-desc{font-size:.78rem;color:var(--text-muted)}.fridge-ocr-preview-container{display:flex;flex-direction:column;gap:1.25rem;width:100%;align-items:center}.preview-image-wrapper{position:relative;width:100%;max-height:280px;border-radius:14px;overflow:hidden;border:1px solid var(--color-border);background-color:var(--bg-base)}.ocr-preview-img{width:100%;height:240px;object-fit:cover;display:block}.preview-remove-btn{position:absolute;top:10px;right:10px;background-color:#0009;color:#fff;border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s ease;padding:0}.preview-remove-btn:hover{background-color:#000000d9;transform:scale(1.05)}.ocr-analyzing-overlay{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;color:var(--text-secondary);font-size:.88rem;font-weight:700}.ocr-loader{color:var(--color-primary)}.ocr-action-buttons{display:flex;gap:.75rem;width:100%}.ocr-btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background-color:var(--color-primary);color:var(--text-inverse);border:none;border-radius:12px;padding:.85rem;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #4caf5026}.ocr-btn-primary:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.ocr-btn-primary:disabled{background-color:var(--color-border);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.ocr-btn-secondary{display:flex;align-items:center;justify-content:center;background-color:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--color-border);border-radius:12px;padding:.85rem 1.5rem;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s ease}.ocr-btn-secondary:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.ocr-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.ocr-detected-section{width:100%;border-top:1px solid var(--color-border);padding-top:1.25rem;display:flex;flex-direction:column;gap:1rem}.ocr-detected-section h6{font-size:.88rem;font-weight:800;color:var(--text-primary);margin:0}.ocr-detected-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:.25rem 0}.ocr-detected-item{display:inline-flex;align-items:center;gap:8px;padding:.5rem .9rem;border:1px solid var(--color-border);background-color:var(--bg-surface);border-radius:50px;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:700;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.ocr-detected-item:hover{border-color:var(--color-primary);background-color:#4caf500a}.ocr-detected-item.checked{border-color:var(--color-primary);background-color:#4caf500f;color:var(--color-primary)}.checkbox-custom{width:16px;height:16px;border:2px solid var(--color-border);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;background-color:var(--bg-surface);color:transparent;flex-shrink:0}.ocr-detected-item.checked .checkbox-custom{border-color:var(--color-primary);background-color:var(--color-primary);color:var(--text-inverse)}.ocr-empty-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.ocr-no-ingredients{font-size:.85rem;color:var(--text-muted);text-align:center;padding:1.5rem}.fridge-warning-banner{background:linear-gradient(135deg,#ff980026,#f443361f);border:1px solid rgba(255,152,0,.35);border-radius:16px;padding:.95rem 1.25rem;display:flex;align-items:center;gap:10px;box-shadow:0 4px 15px #ff98000d;animation:borderWarningPulse 2s infinite alternate}[data-theme=dark] .fridge-warning-banner{background:linear-gradient(135deg,#ff98001a,#f4433614);border-color:#ff980033}.warning-banner-icon{font-size:1.1rem;line-height:1;animation:bounceTimer .6s infinite alternate;flex-shrink:0}.warning-banner-text-container{display:flex;flex:1;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.warning-banner-text{font-size:.82rem;line-height:1.5;color:var(--text-primary);word-break:keep-all}.warning-item-name{font-weight:800;color:#ff9800}.fridge-warning-action-btn{display:inline-flex;align-items:center;gap:4px;background-color:var(--color-primary, #4caf50);color:#fff;border:none;border-radius:10px;padding:.45rem .85rem;font-size:.75rem;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #4caf5033;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none;white-space:nowrap}.fridge-warning-action-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px #4caf504d}.fridge-warning-action-btn:active{transform:translateY(0) scale(.97)}.input-block{display:flex;flex-direction:column;gap:.75rem}.expiry-picker-row{display:flex;align-items:center;gap:6px;background-color:var(--bg-base);border:1px dashed var(--color-border);border-radius:12px;padding:.5rem .85rem}.picker-icon{color:var(--text-muted)}.picker-label{font-size:.78rem;font-weight:700;color:var(--text-secondary)}.fridge-expiry-input{background:transparent;border:none;font-family:inherit;font-size:.8rem;font-weight:700;color:var(--text-primary);outline:none;cursor:pointer}.ingredients-grid-new{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:.75rem}.ingredient-card-item{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:16px;padding:.85rem;display:flex;flex-direction:column;justify-content:space-between;gap:.6rem;box-shadow:0 4px 12px #00000003;transition:all .25s cubic-bezier(.4,0,.2,1);animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.ingredient-card-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000008}.ingredient-card-item.safe{border-left:4px solid #4caf50}.ingredient-card-item.warning{border-left:4px solid #ff9800;background:linear-gradient(to right,rgba(255,152,0,.03),var(--bg-surface))}.ingredient-card-item.expired{border-left:4px solid #f44336;background:linear-gradient(to right,rgba(244,67,54,.04),var(--bg-surface))}.ingredient-card-main{display:flex;flex-direction:column;gap:4px}.ingredient-card-main .chip-label{font-size:.9rem;font-weight:800;color:var(--text-primary)}.expiry-badge{display:inline-block;align-self:flex-start;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:6px}.expiry-badge.safe{background-color:#4caf501f;color:#2e7d32}.expiry-badge.warning{background-color:#ff980026;color:#ef6c00}.expiry-badge.expired{background-color:#f443361f;color:#c62828}.expiry-badge-empty{font-size:.7rem;color:var(--text-muted);font-weight:500}.ingredient-card-actions{display:flex;justify-content:space-between;align-items:center;gap:4px;margin-top:2px;border-top:1px solid var(--color-border);padding-top:6px}.date-picker-wrapper{position:relative;display:flex;align-items:center;gap:4px;color:var(--text-muted);cursor:pointer;max-width:90px}.date-picker-wrapper:hover{color:var(--text-secondary)}.picker-inside-icon{flex-shrink:0}.expiry-inline-picker{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.chip-remove-btn-new{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:50%;transition:all .2s}.chip-remove-btn-new:hover{background-color:#f4433614;color:#f44336}@keyframes borderWarningPulse{0%{border-color:#ff98004d;box-shadow:0 4px 15px #ff980008}to{border-color:#ff980099;box-shadow:0 4px 20px #ff980014}}.expiry-picker-row-container{display:flex;flex-direction:column;gap:.65rem;margin-top:.75rem}.storage-select-container{display:flex;align-items:center}.storage-option-chips{display:flex;gap:.35rem;flex:1}.storage-chip-btn{flex:1;background-color:var(--bg-base);border:1px solid var(--color-border);color:var(--text-secondary);border-radius:10px;font-size:.75rem;font-weight:700;padding:.4rem .5rem;cursor:pointer;transition:all .2s ease}.storage-chip-btn:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.storage-chip-btn.active{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.fridge-shelves-container{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem}.fridge-shelf-box{background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:18px;padding:1.25rem 1rem;position:relative;box-shadow:inset 0 2px 8px #00000005}[data-theme=dark] .fridge-shelf-box{background-color:#ffffff03}.fridge-shelf-box:after{content:"";position:absolute;bottom:4px;left:5%;width:90%;height:3px;background:linear-gradient(90deg,transparent,var(--color-border),transparent);border-radius:var(--radius-full);opacity:.4}.shelf-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:1px dashed var(--color-border)}.shelf-title{font-size:.88rem;font-weight:800;color:var(--text-primary)}.shelf-count{font-size:.75rem;font-weight:700;color:var(--text-muted)}.shelf-empty-placeholder{display:flex;align-items:center;justify-content:center;padding:1.5rem;font-size:.78rem;color:var(--text-muted);font-weight:500;background-color:var(--bg-surface);border:1px dashed var(--color-border);border-radius:12px}.storage-select-inline{background-color:var(--bg-base);border:1px solid var(--color-border);color:var(--text-secondary);border-radius:6px;font-size:.7rem;font-weight:700;padding:2px 4px;outline:none;cursor:pointer;max-width:68px;transition:all .2s ease;font-family:inherit}[data-theme=dark] .storage-select-inline{background-color:#0003}.storage-select-inline:hover{border-color:var(--text-secondary);color:var(--text-primary)}.date-picker-wrapper.select-wrapper{max-width:72px}.preset-item-btn:disabled,.preset-item-btn.limit-reached{opacity:.45;cursor:not-allowed;background-color:var(--bg-hover)!important;border-color:var(--color-border)!important;box-shadow:none!important;transform:none!important}.preset-item-btn.limit-reached:hover{background-color:var(--bg-hover)!important;border-color:var(--color-border)!important}.fridge-select-modal-content{max-width:380px!important;padding:1.5rem 1.75rem!important;text-align:center}.meal-select-btn-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;width:100%}.meal-select-btn{padding:.85rem;font-size:.95rem;font-weight:700;border:1px solid var(--color-border);border-radius:12px;background-color:var(--bg-surface);color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);outline:none}.meal-select-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.meal-select-btn.breakfast:hover{border-color:#ff9800;background-color:#ff98000d;color:#ff9800}.meal-select-btn.lunch:hover{border-color:#4caf50;background-color:#4caf500d;color:#4caf50}.meal-select-btn.dinner:hover{border-color:#2196f3;background-color:#2196f30d;color:#2196f3}.meal-select-btn:active{transform:translateY(0)}.ocr-limit-badge-wrapper{display:flex;justify-content:flex-end;margin-bottom:.75rem;width:100%}.ocr-limit-badge{font-size:.78rem;font-weight:700;color:#ff9800;background-color:#ff980014;border:1px solid rgba(255,152,0,.2);padding:.3rem .65rem;border-radius:50px;display:inline-flex;align-items:center;gap:4px}[data-theme=dark] .ocr-limit-badge{background-color:#ff98000d;border-color:#ff980026}.community-wrapper{display:flex;flex-direction:column;gap:1.25rem;padding:.5rem .25rem;animation:fadeIn .4s cubic-bezier(.16,1,.3,1);--primary-glow: rgba(0, 230, 118, .15)}.community-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.community-tabs{display:flex;background-color:var(--bg-hover, rgba(0, 0, 0, .03));padding:.25rem;border-radius:12px;border:1px solid var(--color-border)}.comm-tab-btn{padding:.55rem 1rem;border-radius:10px;border:none;background:transparent;font-size:.85rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.comm-tab-btn.active{background-color:var(--bg-surface);color:var(--color-accent);box-shadow:var(--shadow-sm)}.write-post-btn{display:flex;align-items:center;gap:.35rem;padding:.6rem .95rem;border-radius:12px;border:none;background-color:var(--color-accent);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 4px 10px var(--primary-glow);transition:all .2s}.write-post-btn:active{transform:scale(.97);box-shadow:0 2px 4px var(--primary-glow)}.feed-list-container{display:flex;flex-direction:column;gap:1.25rem}.feed-card{display:flex;flex-direction:column;gap:1rem;padding:1.25rem;border-radius:18px;background:var(--bg-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s}.feed-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.feed-author-row{display:flex;align-items:center;gap:.75rem}.author-avatar{width:2.5rem;height:2.5rem;border-radius:10px;background:linear-gradient(135deg,var(--color-accent) 0%,#00b0ff 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;box-shadow:0 2px 6px #00e67633}.author-meta{display:flex;flex-direction:column;gap:.2rem;flex:1}.author-name-container{display:flex;align-items:center;gap:.35rem}.author-name{font-size:.925rem;font-weight:700;color:var(--text-primary)}.pro-badge-icon{color:#facc15;animation:pulse 1.5s infinite alternate}.author-subtitle{display:flex;align-items:center;gap:.5rem}.goal-badge{font-size:.7rem;font-weight:800;padding:.1rem .4rem;border-radius:5px}.goal-diet{background-color:#ff70431a;color:#ff7043}.goal-bulk{background-color:#29b6f61a;color:#29b6f6}.goal-normal{background-color:#00e6761a;color:var(--color-accent)}.time-ago{font-size:.725rem;color:var(--text-muted)}.feed-content-text{font-size:.9rem;line-height:1.55;color:var(--text-primary);word-break:break-all;white-space:pre-wrap}.shared-meal-preview{display:flex;flex-direction:column;gap:.85rem;padding:1.1rem;border-radius:14px;background-color:var(--bg-hover, rgba(0, 0, 0, .02));border:1px solid var(--color-border)}.preview-header{display:flex;flex-direction:column;gap:.25rem}.meal-preview-badge{font-size:.675rem;font-weight:700;color:var(--color-accent);text-transform:uppercase;letter-spacing:.05em}.shared-meal-preview h4{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.preview-macros{display:flex;flex-wrap:wrap;gap:.4rem}.macro-chip{font-size:.75rem;font-weight:600;padding:.25rem .55rem;border-radius:8px;background-color:var(--bg-surface);border:1px solid var(--color-border);color:var(--text-secondary)}.macro-chip.cal{border-color:var(--color-accent);color:var(--color-accent);background-color:#00e6760d}.macro-val{font-weight:800}.preview-menu-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem;padding-top:.75rem;border-top:1px dashed var(--color-border)}.menu-preview-item{display:flex;align-items:center;gap:.5rem}.meal-time-tag{font-size:.7rem;font-weight:700;padding:.15rem .4rem;border-radius:5px;min-width:2.2rem;text-align:center}.meal-time-tag.breakfast{background-color:#ffb74d1f;color:#ff9800}.meal-time-tag.lunch{background-color:#81c7841f;color:#4caf50}.meal-time-tag.dinner{background-color:#90caf91f;color:#2196f3}.menu-name{font-size:.825rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.feed-actions-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.feed-action-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem .85rem;border-radius:10px;border:1px solid transparent;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;background-color:var(--bg-hover, rgba(0, 0, 0, .02));color:var(--text-secondary)}.feed-action-btn:active{transform:scale(.96)}.like-btn.liked{color:#ff1744;background-color:#ff17440d;border-color:#ff174426;animation:popScale .3s cubic-bezier(.175,.885,.32,1.275)}.import-btn{flex:1;color:var(--color-accent);background-color:#00e6760f;border-color:#00e67626}.import-btn:active{background-color:#00e6761f}.empty-feed-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.5rem;background-color:var(--bg-surface);border:1.5px dashed var(--color-border);border-radius:18px;gap:.5rem}.empty-feed-icon{color:var(--text-muted);margin-bottom:.5rem}.empty-feed-state h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.empty-feed-state p{font-size:.8rem;color:var(--text-secondary);line-height:1.4;max-width:250px;margin:0}.comm-modal-overlay{position:fixed;inset:0;background-color:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1100;animation:modalFadeIn .3s cubic-bezier(.16,1,.3,1)}.comm-modal-content{width:90%;max-width:460px;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:1.25rem;animation:modalSlideUp .35s cubic-bezier(.16,1,.3,1)}.comm-modal-header{display:flex;align-items:center;justify-content:space-between}.comm-modal-header h3{font-size:1.1rem;font-weight:800;color:var(--text-primary);margin:0}.comm-modal-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:1px solid var(--color-border);background-color:var(--bg-hover, rgba(0, 0, 0, .02));color:var(--text-primary);cursor:pointer}.share-form{display:flex;flex-direction:column;gap:1rem}.select-date{cursor:pointer}.textarea-content{min-height:100px;resize:vertical;line-height:1.45}.submit-share-btn{margin-top:.5rem}.comm-toast{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);background-color:#1e293b;color:#fff;font-size:.85rem;font-weight:700;padding:.65rem 1.25rem;border-radius:20px;box-shadow:0 4px 15px #0003;z-index:1500;animation:toastFade 2.5s forwards}@keyframes popScale{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastFade{0%{opacity:0;transform:translate(-50%,10px)}10%{opacity:1;transform:translate(-50%)}85%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}.write-post-btn.locked-btn{background-color:var(--bg-hover, rgba(255, 255, 255, .05));border:1px solid var(--color-border);color:var(--text-muted);box-shadow:none;cursor:pointer}.write-post-btn.locked-btn:hover{background-color:var(--bg-hover, rgba(255, 255, 255, .08))}.import-btn.locked-btn{color:var(--text-muted);background-color:var(--bg-hover, rgba(255, 255, 255, .03));border-color:var(--color-border)}.import-btn.locked-btn:hover{background-color:var(--bg-hover, rgba(255, 255, 255, .05))}.water-widget-card{background:var(--bg-surface);border:1px solid var(--color-border);border-radius:20px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 8px 32px #1f26870a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.water-widget-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268714}.water-widget-card.completed{border-color:#29b6f666;box-shadow:0 8px 32px #29b6f614}.water-widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.water-widget-header .title-area{display:flex;align-items:center;gap:.75rem}.water-widget-header .icon-wrapper{width:38px;height:38px;border-radius:12px;background:#29b6f61f;display:flex;align-items:center;justify-content:center;color:#29b6f6;transition:all .3s}.water-widget-card.completed .icon-wrapper{background:#29b6f6;color:#fff;box-shadow:0 0 12px #29b6f666}.water-widget-header h4{font-size:.95rem;font-weight:700;margin:0;color:var(--text-primary)}.water-widget-header .subtitle{font-size:.75rem;color:var(--text-muted);margin:2px 0 0}.water-widget-header .percent-badge{font-size:1.1rem;font-weight:800;color:#29b6f6}.water-widget-card.completed .percent-badge{color:#0288d1}.water-cup-container{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin:.5rem 0;padding:.25rem}.water-cup-visual{position:relative;width:76px;height:105px;border:3.5px solid #29b6f6;border-top:none;border-radius:0 0 18px 18px;background:#29b6f608;overflow:hidden;box-shadow:inset 0 0 12px #29b6f626;flex-shrink:0}.water-cup-visual:before{content:"";position:absolute;top:0;left:0;width:100%;height:8px;border:3.5px solid #29b6f6;border-radius:50%;background:var(--bg-surface);transform:translateY(-4px);z-index:5;box-sizing:border-box}.water-cup-wave-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(180deg,#29b6f6,#0286c2);transition:height .6s cubic-bezier(.1,.8,.3,1)}.water-cup-wave-fill:before,.water-cup-wave-fill:after{content:"";position:absolute;width:260px;height:250px;top:-12px;left:50%;border-radius:38%}.water-cup-wave-fill:before{background-color:#29b6f6d9;animation:rotate-wave 7s infinite linear;transform:translate(-50%)}.water-cup-wave-fill:after{background-color:#0288d166;animation:rotate-wave 10s infinite linear;transform:translate(-50%) rotate(30deg)}@keyframes rotate-wave{0%{transform:translate(-50%) rotate(0)}to{transform:translate(-50%) rotate(360deg)}}.water-info-actions{display:flex;flex-direction:column;flex:1;gap:.45rem}.intake-display-row{display:flex;align-items:baseline;color:var(--text-primary)}.intake-display-row .current-ml{font-size:1.6rem;font-weight:800;color:#29b6f6;line-height:1}.intake-display-row .unit-ml{font-size:.85rem;font-weight:700;color:var(--text-muted);margin-left:2px}.intake-display-row .divider-slash{margin:0 .4rem;color:var(--color-border);font-size:1rem}.intake-display-row .target-ml{font-size:.95rem;font-weight:700;color:var(--text-secondary)}.progress-sub-text{font-size:.72rem;color:var(--text-muted);margin:0;font-weight:500}.water-quick-buttons{display:flex;gap:.35rem;margin-top:.25rem}.quick-add-btn{flex:1;padding:.45rem .25rem;border-radius:8px;border:1px solid rgba(41,182,246,.2);background:#29b6f60f;color:#0288d1;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap}.quick-add-btn:hover{background:#29b6f6;color:#fff;border-color:#29b6f6;box-shadow:0 4px 10px #29b6f640}.quick-add-btn:active{transform:scale(.96)}.water-utility-buttons{display:flex;gap:.35rem}.utility-btn{padding:.35rem .6rem;border-radius:8px;border:1px solid var(--color-border);background:var(--bg-base);color:var(--text-secondary);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:4px}.utility-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.utility-btn:active:not(:disabled){transform:scale(.96)}.utility-btn:disabled{opacity:.35;cursor:not-allowed}.utility-btn.reset{background:transparent;border:1px dashed var(--color-border);color:var(--text-muted)}.utility-btn.reset:hover:not(:disabled){border-color:var(--color-danger);color:var(--color-danger-text);background:#ef53500d}.water-completion-banner{margin-top:.75rem;background:#29b6f61a;border:1px solid rgba(41,182,246,.2);border-radius:12px;padding:.6rem;text-align:center;font-size:.8rem;font-weight:700;color:#0288d1;animation:pulse 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.droplet-icon.bounce{animation:bounce .5s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}[data-theme=dark] .water-widget-card{background:var(--bg-surface);box-shadow:0 8px 32px #0000004d}[data-theme=dark] .water-cup-visual{background:#0f172a99;box-shadow:inset 0 0 12px #0009,0 0 0 1px #ffffff0d}[data-theme=dark] .water-cup-visual:before{background:var(--bg-surface)}[data-theme=dark] .quick-add-btn{background:#29b6f61a;color:#4fc3f7;border-color:#29b6f64d}[data-theme=dark] .quick-add-btn:hover{background:#29b6f6;color:#fff}[data-theme=dark] .water-completion-banner{background:#29b6f626;color:#4fc3f7}.weekly-nutrition-widget{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.85rem;animation:fadeInUp .4s ease-out}.weekly-nutrition-widget .widget-header{display:flex;justify-content:space-between;align-items:center}.weekly-nutrition-widget .widget-achievement-badge{background-color:var(--color-accent-light);color:var(--color-accent);border:1px solid rgba(76,175,80,.15);border-radius:var(--radius-full);padding:.25rem .65rem;font-size:.72rem;font-weight:700}.weekly-nutrition-widget .widget-summary-bar{display:flex;justify-content:space-between;background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.65rem .85rem}.weekly-nutrition-widget .summary-item{display:flex;flex-direction:column;gap:.15rem;flex:1}.weekly-nutrition-widget .summary-label{font-size:.72rem;color:var(--text-muted);font-weight:600}.weekly-nutrition-widget .summary-val{font-size:.95rem;font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:4px}.weekly-nutrition-widget .summary-val .val-unit{font-size:.72rem;font-weight:500;color:var(--text-muted)}.weekly-nutrition-widget .inline-icon{flex-shrink:0}.weekly-chart-container{display:flex;justify-content:space-between;align-items:flex-end;height:140px;padding:.75rem .25rem 0;border-top:1px dashed var(--color-border)}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%;cursor:pointer;position:relative;transition:all .2s ease;border-radius:var(--radius-sm)}.chart-col:hover{background-color:var(--bg-base)}.col-bar-wrapper{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center;padding-bottom:.25rem}.col-bar-track{width:12px;height:100%;background-color:var(--bg-progress-track);border-radius:var(--radius-full);display:flex;align-items:flex-end;overflow:visible;position:relative}.col-bar-fill{width:100%;height:0%;background:linear-gradient(180deg,var(--color-primary-light),var(--color-primary));border-radius:var(--radius-full);transition:height .6s cubic-bezier(.1,.8,.3,1);position:relative;min-height:4px}.chart-col.completed .col-bar-fill{background:linear-gradient(180deg,var(--color-protein),var(--color-accent))}.chart-col.empty .col-bar-fill{background:var(--color-border);min-height:0px;height:0%!important}.chart-col.active{background-color:#ff6b4a14;box-shadow:0 0 0 1px var(--color-primary-light)}.chart-col.active.completed{background-color:#4caf5014;box-shadow:0 0 0 1px #4caf504d}.col-bar-popover{position:absolute;top:-24px;left:50%;transform:translate(-50%) scale(.85);background-color:var(--text-primary);color:var(--bg-surface);font-size:.65rem;font-weight:700;padding:2px 4px;border-radius:4px;opacity:0;pointer-events:none;transition:all .15s ease;white-space:nowrap;z-index:10}.col-bar-popover:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);border-width:4px 4px 0;border-style:solid;border-color:var(--text-primary) transparent transparent}.chart-col:hover .col-bar-popover{opacity:1;transform:translate(-50%) scale(1)}.col-labels{display:flex;flex-direction:column;align-items:center;gap:1px}.col-day-num{font-size:.75rem;font-weight:700;color:var(--text-primary)}.col-day-name{font-size:.62rem;color:var(--text-muted);font-weight:600}.chart-col.active .col-day-num{color:var(--color-primary)}.chart-col.active.completed .col-day-num{color:var(--color-accent)}.weekly-nutrition-widget .widget-notice{font-size:.68rem;color:var(--text-muted);text-align:center;margin-top:.4rem;opacity:.8;font-weight:500;letter-spacing:-.01em;line-height:1.4}[data-theme=dark] .weekly-nutrition-widget .widget-achievement-badge{background-color:#41c87926;color:#75d79e;border-color:#41c87940}[data-theme=dark] .weekly-chart-container{border-top-color:var(--color-border)}[data-theme=dark] .weekly-chart-container .chart-col:hover{background-color:var(--bg-base)}[data-theme=dark] .col-bar-fill{background:linear-gradient(0deg,var(--color-primary-light),var(--color-primary))}[data-theme=dark] .chart-col.active{background-color:#ff6b4a26;box-shadow:0 0 0 1px var(--color-primary)}[data-theme=dark] .chart-col.active.completed{background-color:#4caf5026;box-shadow:0 0 0 1px var(--color-accent)}.install-guide-banner{display:flex;justify-content:space-between;align-items:center;margin:1rem 1rem .5rem;padding:.85rem 1rem;background:var(--glass-bg, rgba(255, 255, 255, .7));backdrop-filter:blur(var(--glass-blur, 10px));-webkit-backdrop-filter:blur(var(--glass-blur, 10px));border:1px solid var(--color-border);border-radius:16px;cursor:pointer;transition:background .25s ease,border-color .25s ease,transform .15s ease;box-shadow:0 4px 12px #00000008}.install-guide-banner:hover{background:var(--bg-hover, rgba(255, 255, 255, .95));border-color:var(--color-primary-light)}.install-guide-banner:active{transform:scale(.98)}.banner-left{display:flex;align-items:center;gap:.75rem}.banner-icon-wrap{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--bg-subtle, rgba(76, 175, 80, .1));color:var(--color-primary);border-radius:12px}.banner-smartphone-icon{width:20px;height:20px}.banner-text-wrap{display:flex;flex-direction:column;gap:.15rem}.banner-title{font-size:.875rem;font-weight:700;color:var(--text-primary)}.banner-subtitle{font-size:.75rem;color:var(--text-muted)}.banner-right{display:flex;align-items:center;gap:.25rem;color:var(--color-primary)}.banner-action-text{font-size:.8rem;font-weight:600}.install-guide-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:flex-end;z-index:10000;isolation:isolate;animation:installGuideFadeIn .25s ease-out}.install-guide-modal{position:relative;width:100%;max-width:480px;background:var(--bg-surface, #ffffff);border-top-left-radius:24px;border-top-right-radius:24px;padding:1.75rem 1.5rem 1.5rem;box-shadow:0 -8px 30px #00000026;animation:installGuideSlideUp .3s cubic-bezier(.16,1,.3,1);box-sizing:border-box;overscroll-behavior:contain}@media(min-width:480px){.install-guide-overlay{align-items:center;padding:1rem}.install-guide-modal{border-radius:24px;box-shadow:0 12px 40px #0003}}.install-guide-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:var(--bg-subtle, rgba(0, 0, 0, .05));border:none;border-radius:50%;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s,background .2s}.install-guide-close-btn:hover{background:var(--bg-hover, rgba(0, 0, 0, .08));color:var(--text-primary)}.install-guide-close-btn:active{transform:scale(.95)}.guide-content{display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:.5rem}.guide-header-icon-wrap{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:18px;margin-bottom:1rem;background:var(--bg-subtle, rgba(76, 175, 80, .08))}.guide-main-icon{width:28px;height:28px;color:var(--color-primary)}.guide-main-icon.safari{color:#007aff}.guide-main-icon.chrome{color:#ea4335}.guide-main-icon.warning{color:var(--text-warning, #ff9800)}.guide-title{font-size:1.15rem;font-weight:800;color:var(--text-primary);margin:0 0 .5rem}.guide-desc{font-size:.875rem;line-height:1.45;color:var(--text-secondary);margin:0 0 1.5rem}.guide-desc strong{color:var(--text-primary);font-weight:700}.guide-steps{display:flex;flex-direction:column;gap:.85rem;width:100%;text-align:left;margin-bottom:1.5rem}.guide-step{display:flex;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;background:var(--bg-subtle, rgba(0, 0, 0, .02));border-radius:12px;border:1px solid var(--color-border)}.guide-step.warning-step{border-color:var(--color-border-warning, rgba(255, 152, 0, .3));background:var(--bg-warning, rgba(255, 152, 0, .08))}.warning-text{color:var(--text-warning, #ff9800)}.step-num{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px;font-size:.75rem;font-weight:700;border-radius:50%;background:var(--color-primary);color:var(--text-inverse, #ffffff)}.step-num.bg-warning{background:var(--text-warning, #ff9800)}.step-text{font-size:.85rem;line-height:1.45;color:var(--text-primary)}.step-text strong{font-weight:700;text-decoration:underline;text-underline-offset:2px}.inline-icon{display:inline-block;vertical-align:middle;margin:0 2px;color:var(--color-primary)}.install-guide-footer{display:flex;flex-direction:column;gap:.75rem;width:100%}.dont-show-again-label{display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.dont-show-checkbox{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.dont-show-text{font-size:.75rem;color:var(--text-muted)}.guide-confirm-btn{width:100%;padding:.85rem;background:var(--color-primary);color:var(--text-inverse, #ffffff);border:none;border-radius:12px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s}.guide-confirm-btn:hover{opacity:.9}.guide-confirm-btn:active{transform:scale(.98)}body.dark-mode .install-guide-banner{background:#1e1e1ea6;box-shadow:0 4px 15px #00000026}body.dark-mode .guide-step{background:#ffffff05}body.dark-mode .dont-show-checkbox{accent-color:var(--color-primary-light, #81c784)}@keyframes installGuideFadeIn{0%{opacity:0}to{opacity:1}}@keyframes installGuideSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(min-width:480px){@keyframes installGuideSlideUp{0%{transform:scale(.92) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}}.dashboard-wrapper{padding:1.25rem;flex:1;display:flex;flex-direction:column;animation:fadeInUp .4s ease-out}.diet-summary-card{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-base) 100%);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center}.diet-summary-info h3{font-size:1.1rem;font-weight:700;margin-bottom:.25rem}.diet-summary-info p{font-size:.85rem;color:var(--text-secondary)}.calories-badge{background-color:var(--color-primary-light);color:var(--color-primary);padding:.5rem 1rem;border-radius:var(--radius-md);font-weight:700;font-size:1.1rem;border:1px solid rgba(255,107,74,.2)}.empty-state-card{background-color:var(--bg-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:3rem 1.5rem;text-align:center;margin:auto 0;display:flex;flex-direction:column;align-items:center;gap:1.25rem;animation:scaleIn .4s ease-out}.empty-icon{width:64px;height:64px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.empty-state-card h3{font-size:1.25rem;font-weight:700}.empty-state-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar-title{font-size:1.2rem;font-weight:700}.calendar-nav-btn{padding:.5rem;border-radius:var(--radius-full);transition:var(--transition-smooth)}.calendar-nav-btn:hover{background-color:var(--color-border)}.calendar-nav-btn:disabled{opacity:.3;cursor:not-allowed;background-color:transparent}.weekdays-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:.5rem}.weekday-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1.5rem}.day-cell{aspect-ratio:1;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.35rem;display:flex;flex-direction:column;justify-content:space-between;transition:var(--transition-bounce);position:relative;overflow:hidden}.day-cell:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--color-primary)}.day-num{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.day-cell.today{border:1.5px solid var(--color-primary);background-color:var(--color-primary-light)}.day-cell.today .day-num{color:var(--color-primary);font-weight:800}.day-cell.today.completed{border:1.5px solid var(--color-primary);background-color:var(--color-accent-light)}.day-cell.today.completed .day-num{color:var(--color-primary);font-weight:800}.meal-indicators{display:flex;gap:2px;margin-top:auto}.indicator-dot{flex:1;height:4px;background-color:var(--color-border);border-radius:var(--radius-full)}.indicator-dot.active{background-color:var(--color-accent)}.day-cell.completed{background-color:var(--color-accent-light);border-color:var(--color-accent)}.day-cell.completed .day-num{color:var(--color-accent)}.day-cell.locked{background-color:var(--bg-base);opacity:.65;cursor:not-allowed}.day-cell.locked:hover{transform:none;box-shadow:none;border-color:var(--color-border)}.lock-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--bg-lock-overlay);-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0006;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:100;display:flex;align-items:flex-end;justify-content:center}.modal-content{width:100%;max-width:480px;background-color:var(--bg-surface);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);padding:1.75rem 1.5rem;box-shadow:var(--shadow-lg);animation:fadeInUp .35s cubic-bezier(.175,.885,.32,1.1) forwards;max-height:85vh;overflow-y:auto;overscroll-behavior:contain}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.modal-header h3{font-size:1.3rem;font-weight:700}.close-btn{padding:.5rem;border-radius:var(--radius-full);background-color:var(--bg-base);display:flex;align-items:center;justify-content:center}.meal-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.meal-item{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;background-color:var(--bg-surface);transition:var(--transition-smooth)}.meal-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.meal-tag{font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:var(--radius-sm);background-color:var(--bg-base);color:var(--text-secondary)}.meal-tag.breakfast{background-color:var(--bg-warning);color:var(--text-warning-label)}.meal-tag.lunch{background-color:var(--bg-success);color:var(--text-success-label)}.meal-tag.dinner{background-color:var(--bg-info);color:var(--text-info-label)}.meal-calories{font-size:.9rem;font-weight:600;color:var(--text-primary)}.meal-name{font-size:1rem;font-weight:600;margin-bottom:.75rem}.nutrients-bar{display:flex;height:6px;border-radius:var(--radius-full);overflow:hidden;background-color:var(--bg-base);margin-bottom:.5rem}.nutrient-segment{height:100%}.nutrient-segment.carb{background-color:var(--color-carb)}.nutrient-segment.protein{background-color:var(--color-protein)}.nutrient-segment.fat{background-color:var(--color-fat)}.nutrients-labels{display:flex;justify-content:flex-start;gap:1.25rem;font-size:.75rem;color:var(--text-secondary)}.carb-label{color:var(--color-carb);font-weight:700}.protein-label{color:var(--color-protein);font-weight:700}.fat-label{color:var(--color-fat);font-weight:700}.modal-actions{display:flex;gap:.75rem}.action-checkbox-btn{flex:1;padding:.95rem;border-radius:var(--radius-md);font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:var(--transition-bounce);border:1.5px solid var(--color-border)}.action-checkbox-btn.completed{background-color:var(--color-accent);color:#fff;border-color:var(--color-accent)}.action-checkbox-btn.pending{background-color:var(--bg-surface);color:var(--text-primary)}.premium-promo-banner{background:linear-gradient(135deg,hsl(38,92%,50%),var(--color-primary));border-radius:var(--radius-lg);padding:1.25rem;color:#fff;margin-top:auto;box-shadow:0 8px 24px #ff6b4a33;display:flex;flex-direction:column;gap:.75rem;animation:fadeInUp .5s ease-out}.promo-header{display:flex;justify-content:space-between;align-items:flex-start}.promo-tag{background-color:#fff3;font-size:.7rem;font-weight:700;padding:.25rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase}.premium-promo-banner h4{font-size:1.1rem;font-weight:700}.premium-promo-banner p{font-size:.85rem;opacity:.9}.promo-btn{background-color:var(--text-inverse);color:var(--color-primary);font-weight:700;padding:.75rem;border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-sm);transition:var(--transition-bounce)}.promo-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.purchase-modal-content{text-align:center}.purchase-illustration{width:80px;height:80px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.price-tag{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin:1rem 0}.price-sub{font-size:.9rem;color:var(--text-secondary);margin-bottom:2rem}.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem 1rem;text-align:left;background-color:var(--color-bg);padding:1.25rem;border-radius:var(--radius-md);margin-bottom:2rem;border:1px solid var(--color-border)}.feature-grid-item{display:flex;flex-direction:column;gap:.25rem}.feature-grid-header{font-size:.85rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.35rem}.feature-grid-header svg{color:var(--color-primary);flex-shrink:0}.feature-grid-desc{font-size:.72rem;color:var(--text-secondary);padding-left:1.25rem;line-height:1.3}@media(max-width:480px){.features-grid{grid-template-columns:1fr;gap:.85rem}}.view-mode-tabs-wrapper{position:relative;margin-bottom:1.5rem}.view-mode-tabs{display:grid;grid-template-columns:repeat(3,1fr);background-color:var(--bg-subtle);padding:.25rem;border-radius:var(--radius-md);width:100%;gap:.25rem}.tab-btn{padding:.65rem .5rem;border:none;background:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:var(--text-secondary);text-align:center;cursor:pointer;transition:var(--transition-smooth)}.tab-btn.active{background-color:var(--bg-surface);color:var(--color-primary);box-shadow:var(--shadow-1)}.today-meals-container{display:flex;flex-direction:column;gap:1.25rem;animation:fadeInUp .4s ease-out}.today-calories-summary{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.today-meals-guide-caption{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-muted);background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.65rem .85rem;margin-bottom:-.5rem;box-shadow:var(--shadow-sm);line-height:1.4}.today-meals-guide-caption svg{color:var(--color-primary);flex-shrink:0}.today-meals-list-wrapper{display:flex;flex-direction:column;gap:1.25rem}.today-meal-card{background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.75rem;position:relative;transition:var(--transition-bounce)}.today-meal-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.today-meal-card.completed{border-color:var(--color-accent);background-color:var(--color-accent-light)}.today-card-meta{display:flex;justify-content:space-between;align-items:center}.today-card-meta .meal-tag{font-size:.8rem;font-weight:700;padding:.25rem .5rem;border-radius:var(--radius-sm)}.today-card-meta .meal-tag.breakfast{background-color:var(--bg-warning);color:var(--text-warning-label)}.today-card-meta .meal-tag.lunch{background-color:var(--bg-success);color:var(--text-success-label)}.today-card-meta .meal-tag.dinner{background-color:var(--bg-info);color:var(--text-info-label)}.meta-right-group{display:flex;align-items:center;gap:.75rem}.today-card-meta .meal-calories{display:flex;align-items:baseline;line-height:1}.today-card-meta .meal-calories .cal-val{font-size:1.15rem;font-weight:800;color:var(--text-primary)}.today-card-meta .meal-calories .cal-unit{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-left:2px}.today-meal-title{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.today-meal-check-btn{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:transparent;background-color:var(--bg-surface);transition:var(--transition-smooth);flex-shrink:0}.today-meal-card.completed .today-meal-check-btn{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.today-meal-card.locked{opacity:.8;background-color:var(--bg-base)}.today-meal-card.locked .today-meal-check-btn{color:var(--color-text-muted);border-color:var(--color-border);background-color:var(--color-border)}.donut-chart-outer{display:flex;align-items:center;gap:1.25rem;background-color:var(--bg-base);padding:.75rem 1rem;border-radius:var(--radius-md);margin:.75rem 0 1rem}.donut-chart-container{position:relative;width:76px;height:76px;display:flex;align-items:center;justify-content:center}.donut-chart{transform:rotate(-90deg)}.donut-center-text{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-center-text .cal-num{font-size:.95rem;font-weight:800;color:var(--text-primary);line-height:1}.donut-center-text .cal-unit{font-size:.65rem;color:var(--text-muted);margin-top:1px}.donut-chart-legend{display:flex;flex-direction:column;gap:.35rem}.legend-item{font-size:.75rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.legend-item .dot{width:8px;height:8px;border-radius:var(--radius-full)}.legend-item .dot.carb{background-color:var(--color-carb)}.legend-item .dot.protein{background-color:var(--color-protein)}.legend-item .dot.fat{background-color:var(--color-fat)}.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.65rem .85rem;background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth)}.accordion-trigger:hover,.accordion-trigger.active{color:var(--color-primary);border-color:var(--color-primary);background-color:var(--color-primary-light)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1),padding .3s ease;padding:0 .5rem}.accordion-content.open{max-height:500px;padding:1rem .5rem .5rem}.recipe-section h5{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.ingredients-list{list-style:none;padding-left:0;display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem}.ingredients-list li{font-size:.78rem;color:var(--text-secondary);position:relative;padding-left:.75rem}.ingredients-list li:before{content:"•";color:var(--color-primary);position:absolute;left:0}.steps-list{padding-left:1rem;display:flex;flex-direction:column;gap:.4rem}.steps-list li{font-size:.78rem;color:var(--text-secondary);line-height:1.4}.guide-tour-overlay{z-index:11000}.guide-tour-content{text-align:center;max-width:420px;border-radius:var(--radius-lg);margin-bottom:auto;margin-top:auto;padding:2rem 1.5rem}.tour-badge-icon{width:64px;height:64px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;animation:bounceIn .8s ease-out}.tour-steps{text-align:left;display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem}.tour-step-item{display:flex;gap:1rem;align-items:flex-start}.tour-step-item .step-num{width:24px;height:24px;background-color:var(--color-primary);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;margin-top:2px}.tour-step-item h4{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:.2rem}.tour-step-item p{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.date-navigator-bar{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:.5rem;-webkit-user-select:none;user-select:none}.nav-arrow-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--text-primary);background-color:var(--bg-base);cursor:pointer;transition:var(--transition-smooth)}.nav-arrow-btn:hover:not(:disabled){background-color:var(--color-primary-light);color:var(--color-primary);border-color:#ff6b4a4d}.nav-arrow-btn:disabled{opacity:.4;cursor:not-allowed}.active-date-label{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.05rem;color:var(--text-primary)}.active-date-label .today-badge{background-color:var(--color-accent-light);color:var(--color-accent);font-size:.7rem;font-weight:800;padding:.15rem .45rem;border-radius:var(--radius-sm);border:1px solid rgba(56,142,60,.2)}.active-date-label .today-go-back-badge{background-color:var(--bg-hover);color:var(--text-muted);font-size:.7rem;font-weight:800;padding:.15rem .45rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;transition:var(--transition-smooth)}.active-date-label .today-go-back-badge:hover{background-color:var(--color-primary-light);color:var(--color-primary);border-color:#ff6b4a4d}.active-date-label .today-go-back-badge:active{transform:scale(.92)}.deducted-notification-banner{background:linear-gradient(135deg,#4caf5026,#2196f31a);border:1px solid rgba(76,175,80,.3);border-radius:var(--radius-lg);padding:.85rem 1.25rem;margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 16px #4caf5014;animation:fadeInUp .3s ease-out}[data-theme=dark] .deducted-notification-banner{background:linear-gradient(135deg,#4caf5014,#2196f30d);border-color:#4caf5026}.deducted-banner-text{font-size:.88rem;font-weight:700;color:var(--text-primary);line-height:1.4}.deducted-banner-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth)}.deducted-banner-close:hover{color:var(--text-primary)}.calendar-info-caption{font-size:.78rem;color:var(--text-muted);text-align:center;margin-top:-.5rem;margin-bottom:1.25rem;font-weight:500}.today-meals-list-wrapper{position:relative;transition:all .3s ease}.today-meals-list-wrapper.locked-blur{pointer-events:none}.today-meals-list-wrapper.locked-blur .today-meal-card{filter:blur(4px);opacity:.5;transition:filter .3s ease,opacity .3s ease}.today-meals-lock-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#ffffffa6;backdrop-filter:blur(1.5px);-webkit-backdrop-filter:blur(1.5px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg);cursor:pointer;pointer-events:auto;animation:fadeIn .3s ease-out}[data-theme=dark] .today-meals-lock-overlay{background-color:#0f1117b3}.lock-overlay-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem 1.5rem;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:340px;width:90%;animation:scaleIn .35s cubic-bezier(.175,.885,.32,1.1) forwards}.lock-icon-badge{width:48px;height:48px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border:1px solid rgba(255,107,74,.2)}.lock-overlay-content h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.lock-overlay-content p{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1.25rem}.upgrade-teaser-btn{background-color:var(--color-primary);color:#fff;font-weight:600;font-size:.9rem;padding:.65rem 1.25rem;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition-bounce);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:.5rem}.upgrade-teaser-btn:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.upgrade-teaser-btn:active{transform:scale(.97)}.today-meals-list-wrapper.dragging-active{user-select:none;-webkit-user-select:none}.today-meals-list-wrapper.dragging-active .today-meal-card{pointer-events:none}.today-meals-list-wrapper.dragging-active .today-meal-card:not(.dragging):hover{transform:none!important}.today-meal-card{user-select:none;-webkit-user-select:none}.today-meal-card.dragging{cursor:grabbing;touch-action:none;will-change:transform;transition:none!important;z-index:100!important;box-shadow:var(--shadow-lg)!important}body.body-dragging-active{overflow:hidden!important;touch-action:none!important}body.body-dragging-active *{pointer-events:none!important;user-select:none!important;-webkit-user-select:none!important}.purchase-modal-overlay{z-index:12000!important}.support-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:10000;padding:1rem;animation:supportFadeIn .25s ease-out forwards}.support-modal-container{width:100%;max-width:480px;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;position:relative;display:flex;flex-direction:column;max-height:85vh;animation:supportSlideUp .3s cubic-bezier(.34,1.56,.64,1) forwards}.support-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);background-color:var(--bg-surface)}.header-title-container{display:flex;align-items:center;gap:.5rem}.icon-support{color:var(--color-primary)}.support-modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s}.close-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.close-btn:active{transform:scale(.9)}.support-modal-tabs{display:flex;border-bottom:1px solid var(--color-border);background-color:var(--bg-subtle, var(--bg-base));padding:4px;gap:4px}.support-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:.75rem;background:none;border:none;font-size:.9rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:12px;transition:all .25s ease}.support-tab-btn.active{background-color:var(--bg-surface);color:var(--color-primary);box-shadow:0 2px 8px #0000000d}.support-tab-btn:not(.active):hover{color:var(--text-primary);background-color:#00000005}.support-tab-btn:active{transform:scale(.97)}.support-modal-content{padding:1.5rem;overflow-y:auto;flex:1;min-height:250px;overscroll-behavior:contain}.faq-list{display:flex;flex-direction:column;gap:.75rem}.faq-item-card{border:1px solid var(--color-border);border-radius:16px;overflow:hidden;background-color:var(--bg-surface);transition:border-color .2s,box-shadow .2s}.faq-item-card.expanded{border-color:var(--color-primary-light, var(--color-primary));box-shadow:0 4px 12px #00000005}.faq-question-btn{width:100%;display:flex;align-items:center;padding:1rem 1.25rem;background:none;border:none;text-align:left;cursor:pointer;gap:.75rem;color:var(--text-primary);font-size:.95rem;font-weight:600;transition:background-color .2s}.faq-question-btn:hover{background-color:var(--bg-hover)}.faq-q-badge{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-primary-light, rgba(76, 175, 80, .1));color:var(--color-primary);border-radius:6px;font-size:.75rem;font-weight:800}.faq-question-text{flex:1}.faq-answer-container{display:flex;padding:0 1.25rem 1.25rem;gap:.75rem;border-top:1px dashed var(--color-border);background-color:var(--bg-subtle, var(--bg-base));animation:faqFadeIn .2s ease-out}.faq-a-badge{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-accent-light, rgba(255, 152, 0, .1));color:var(--color-accent);border-radius:6px;font-size:.75rem;font-weight:800;margin-top:1rem}.faq-answer-text{flex:1;font-size:.88rem;line-height:1.5;color:var(--text-secondary);margin:0;padding-top:1rem}.inquiry-form-container{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:flex;flex-direction:column;gap:.5rem}.form-row label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.inquiry-input,.inquiry-select,.inquiry-textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:12px;background-color:var(--bg-surface);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s}.inquiry-textarea{resize:none;height:140px;line-height:1.5}.inquiry-input:focus,.inquiry-select:focus,.inquiry-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light, rgba(76, 175, 80, .15))}.select-wrapper{position:relative;width:100%}.char-counter{font-size:.75rem;color:var(--text-muted);text-align:right;margin-top:2px}.inquiry-submit-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:.9rem;background:var(--color-gradient-primary, linear-gradient(135deg, #4caf50, #2e7d32));color:var(--text-inverse, #ffffff);border:none;border-radius:14px;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s;box-shadow:0 4px 12px #4caf5033}.inquiry-submit-btn:hover:not(:disabled){opacity:.95}.inquiry-submit-btn:active:not(:disabled){transform:scale(.98)}.inquiry-submit-btn:disabled{background:var(--color-border);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.support-toast{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background-color:var(--text-primary);color:var(--bg-surface);padding:.75rem 1.25rem;border-radius:12px;font-size:.85rem;font-weight:600;box-shadow:var(--shadow-md);z-index:10100;white-space:nowrap;animation:toastPopUp .3s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes supportFadeIn{0%{opacity:0}to{opacity:1}}@keyframes supportSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes faqFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastPopUp{0%{opacity:0;transform:translate(-50%,15px)}to{opacity:1;transform:translate(-50%)}}[data-theme=dark] .support-tab-btn.active{background-color:var(--bg-surface);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .faq-answer-container{background-color:#ffffff05}[data-theme=dark] .support-toast{background-color:var(--bg-base);color:var(--text-primary);border:1px solid var(--color-border)}.inquiry-history-container{display:flex;flex-direction:column;height:100%}.history-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;color:var(--text-secondary);gap:1rem}.history-loading-container .spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:supportSpinner 1s linear infinite}@keyframes supportSpinner{to{transform:rotate(360deg)}}.history-empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1.5rem;color:var(--text-muted);gap:1rem}.history-empty-container .empty-icon{color:var(--color-border-strong, var(--text-muted));opacity:.6}.history-empty-container .empty-text{font-size:.95rem;font-weight:500;margin:0}.empty-cta-btn{padding:.6rem 1.2rem;background:var(--color-gradient-primary, linear-gradient(135deg, #4caf50, #2e7d32));color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;box-shadow:0 4px 10px #4caf5026;transition:opacity .2s,transform .1s}.empty-cta-btn:hover{opacity:.95}.empty-cta-btn:active{transform:scale(.97)}.history-item-card{border:1px solid var(--color-border);border-radius:16px;overflow:hidden;background-color:var(--bg-surface);transition:border-color .2s,box-shadow .2s;margin-bottom:.75rem}.history-item-card.expanded{border-color:var(--color-primary-light, var(--color-primary));box-shadow:0 4px 12px #00000005}.history-header-btn{width:100%;display:flex;flex-direction:column;padding:1rem 1.25rem;background:none;border:none;text-align:left;cursor:pointer;color:var(--text-primary);gap:.5rem;transition:background-color .2s}.history-header-btn:hover{background-color:var(--bg-hover)}.history-meta-top{display:flex;justify-content:space-between;align-items:center;width:100%}.inq-date{font-size:.78rem;color:var(--text-muted)}.inq-cat-tag{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:6px;background-color:var(--bg-subtle, var(--bg-base));color:var(--text-secondary);border:1px solid var(--color-border)}.history-title-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.inq-content-preview{flex:1;font-size:.92rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:8px;font-size:.75rem;font-weight:700;white-space:nowrap}.status-badge.pending{background-color:#ff98001a;color:var(--color-accent, #ff9800);border:1px solid rgba(255,152,0,.15)}.status-badge.replied{background-color:#4caf501a;color:var(--color-primary, #4caf50);border:1px solid rgba(76,175,80,.15)}.expand-indicator-row{display:flex;justify-content:center;width:100%;color:var(--text-muted);margin-top:2px}.history-detail-container{padding:1.25rem;border-top:1px dashed var(--color-border);background-color:var(--bg-subtle, var(--bg-base));display:flex;flex-direction:column;gap:1rem;animation:faqFadeIn .2s ease-out}.detail-label{font-size:.78rem;font-weight:700;color:var(--text-muted);margin:0 0 .25rem;text-transform:uppercase}.detail-text{font-size:.88rem;line-height:1.5;color:var(--text-secondary);margin:0;white-space:pre-wrap}.admin-reply-box{padding:1rem;background-color:var(--bg-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-primary);border-radius:12px;box-shadow:0 2px 6px #00000003}.reply-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.reply-badge{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background-color:var(--color-primary);color:#fff;border-radius:50%;font-size:.7rem;font-weight:800}.reply-title{font-size:.82rem;font-weight:700;color:var(--text-primary)}.reply-date{font-size:.75rem;color:var(--text-muted);margin-left:auto}.reply-text{font-size:.88rem;line-height:1.55;color:var(--text-secondary);margin:0;white-space:pre-wrap}.admin-pending-box{display:flex;align-items:center;gap:8px;padding:.75rem 1rem;background-color:#ff98000d;border:1px solid rgba(255,152,0,.1);border-radius:12px;font-size:.82rem;color:var(--color-accent, #ff9800)}[data-theme=dark] .history-item-card.expanded{border-color:var(--color-primary)}[data-theme=dark] .history-detail-container{background-color:#ffffff03}[data-theme=dark] .admin-reply-box{background-color:#ffffff05;border-color:var(--color-border)}[data-theme=dark] .inq-cat-tag{background-color:#ffffff0a}[data-theme=dark] .admin-pending-box{background-color:#ff980008}.settings-wrapper{display:flex;flex-direction:column;gap:1.75rem;padding:1.25rem;min-height:100%;animation:fadeIn .4s cubic-bezier(.16,1,.3,1);overflow-y:auto;--card-bg: var(--bg-surface);--border-color: var(--color-border)}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:.25rem 0}.settings-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.back-btn{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:50%;border:1px solid var(--border-color);background-color:var(--card-bg);color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.back-btn:active{transform:scale(.95);background-color:var(--border-color)}.settings-section{display:flex;flex-direction:column;gap:.85rem}.settings-section-title{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding-left:.25rem}.profile-info-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:16px;background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.profile-avatar{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:12px;background-color:var(--bg-success);color:var(--text-success-label)}.profile-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.profile-email{font-size:.95rem;font-weight:600;color:var(--text-primary);word-break:break-all}.profile-plan-badge{display:inline-flex;align-self:flex-start;font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:6px;background-color:var(--bg-success);color:var(--text-success-label)}.logout-button{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:10px;border:1px solid transparent;background-color:var(--bg-danger);color:var(--text-danger-label);cursor:pointer;transition:all .2s}.logout-button:active{transform:scale(.95);filter:brightness(.9)}.premium-status-card{padding:1.5rem;border-radius:20px;color:var(--pro-text-color, #ffffff);position:relative;overflow:hidden;box-shadow:var(--shadow-md);--pro-text-color: #ffffff;--pro-sparkle-color: #facc15;--pro-btn-bg: #ffffff;--pro-btn-text: #1d4ed8;--pro-btn-manage-bg: rgba(255, 255, 255, .1);--pro-btn-manage-border: rgba(255, 255, 255, .15);--pro-gradient-activated: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);--pro-gradient-free: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%)}.premium-status-card.activated{background:var(--pro-gradient-activated);border:1px solid rgba(255,255,255,.08)}.premium-status-card.free{background:var(--pro-gradient-free);border:1px solid rgba(255,255,255,.08)}.card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.premium-label{font-size:.75rem;font-weight:800;letter-spacing:.1em;padding:.25rem .6rem;border-radius:20px;background-color:#ffffff2e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.premium-crown-icon{color:var(--pro-sparkle-color);animation:pulse 1.5s infinite alternate}.premium-status-card h4{font-size:1.05rem;font-weight:700;margin:0 0 .5rem;line-height:1.4}.premium-status-card p{font-size:.825rem;line-height:1.5;opacity:.85;margin:0 0 1.25rem}.manage-sub-btn,.upgrade-sub-btn{width:100%;padding:.85rem;border-radius:12px;border:none;font-size:.9rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.manage-sub-btn{background-color:var(--pro-btn-manage-bg);color:var(--pro-text-color);border:1px solid var(--pro-btn-manage-border)}.manage-sub-btn:active{transform:scale(.98);background-color:#ffffff2e}.upgrade-sub-btn{background-color:var(--pro-btn-bg);color:var(--pro-btn-text);box-shadow:0 4px 12px #1d4ed840}.upgrade-sub-btn:active{transform:scale(.98);box-shadow:0 2px 6px #1d4ed826}.gender-selector-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.gender-btn{background-color:var(--bg-surface);border:1px solid var(--border-color);padding:.85rem;border-radius:12px;transition:var(--transition-bounce);text-align:center;font-weight:600;font-size:.95rem;color:var(--text-primary);cursor:pointer}.gender-btn:hover{background-color:var(--bg-hover)}.gender-btn:active{transform:scale(.98)}.gender-btn.active{border-color:var(--color-accent);background-color:var(--color-accent-light);color:var(--color-accent);transform:scale(1.02)}[data-theme=dark] .gender-btn.active{background-color:#64a68f1f;border-color:var(--color-accent);color:#97d8c1}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-group label{font-size:.85rem;font-weight:600;color:var(--text-primary);padding-left:.15rem}.form-input{height:48px;padding:.75rem 1rem;border-radius:12px;border:1px solid var(--border-color);background-color:var(--card-bg);font-size:16px;color:var(--text-primary);font-family:inherit;transition:all .2s;-webkit-appearance:none}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.selector-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.selector-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:.95rem;border-radius:14px;border:1px solid var(--border-color);background-color:var(--card-bg);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);gap:.25rem}.selector-card-title{font-size:.9rem;font-weight:700;color:var(--text-primary)}.selector-card-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.3}.selector-card:active{transform:scale(.97)}.selector-card.active{border-color:var(--color-accent);background:linear-gradient(var(--bg-success),var(--bg-success)),var(--card-bg)}.selector-card.active .selector-card-title{color:var(--text-success-label)}.selector-card.active .selector-card-desc{color:var(--text-success-label);opacity:.85}.settings-wrapper .primary-button{display:flex;align-items:center;justify-content:center;gap:.6rem;height:52px;width:100%;border-radius:14px;border:none;background-color:var(--color-accent);color:#fff;font-size:.975rem;font-weight:700;cursor:pointer;box-shadow:0 4px 14px -2px #388e3c40;transition:all .2s cubic-bezier(.4,0,.2,1)}.settings-wrapper .primary-button:active:not(:disabled){transform:scale(.98);box-shadow:0 2px 6px #388e3c26}.settings-wrapper .primary-button:disabled{background-color:var(--border-color);color:var(--text-disabled);border:1px solid var(--color-border);cursor:not-allowed;box-shadow:none}[data-theme=dark] .settings-wrapper .primary-button:disabled{background-color:#2c303a;border-color:#424857;color:var(--color-text-muted);opacity:.8}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:scale(1);opacity:.9}to{transform:scale(1.1);opacity:1}}.theme-toggle-container{display:flex;gap:.75rem}.theme-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem;border-radius:14px;border:1px solid var(--border-color);background-color:var(--card-bg);color:var(--text-primary);font-weight:600;font-size:.9rem;transition:all .25s cubic-bezier(.4,0,.2,1)}.theme-btn:active{transform:scale(.97)}.theme-btn.active{border-color:var(--color-primary);background-color:var(--color-primary-light);color:var(--color-primary)}.debug-card{border-style:dashed;border-color:var(--color-warning, #f59e0b)!important}.debug-avatar{background-color:#f59e0b1a!important;color:var(--color-warning, #f59e0b)!important}.debug-badge{background-color:#f59e0b1a!important;color:var(--color-warning, #d97706)!important}.debug-switch-btn{padding:.55rem .9rem;border-radius:10px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.debug-switch-btn.mock{background-color:var(--color-accent);color:#fff}.debug-switch-btn.mock:active{transform:scale(.95)}.debug-switch-btn.real{background-color:var(--color-warning, #f59e0b);color:#fff}.debug-switch-btn.real:active{transform:scale(.95)}.notification-settings-card{display:flex;flex-direction:column;gap:1.25rem;padding:1.25rem;border-radius:16px;background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.notification-setting-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1.25rem;border-bottom:1px dashed var(--border-color)}.notification-setting-row:last-of-type{padding-bottom:0;border-bottom:none}.notification-info{display:flex;flex-direction:column;gap:.3rem;flex:1}.notification-title-container{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;color:var(--text-primary)}.notification-title-container .icon-enabled{color:var(--color-accent)}.notification-title-container .icon-disabled{color:var(--text-muted)}.notification-desc{font-size:.775rem;color:var(--text-secondary);line-height:1.35}.notification-controls{display:flex;align-items:center;gap:.75rem}.time-picker-wrapper{display:flex;align-items:center;gap:.35rem;background-color:var(--bg-hover, rgba(0, 0, 0, .04));padding:.4rem .65rem;border-radius:8px;border:1px solid var(--border-color)}.time-picker-wrapper .clock-icon{color:var(--text-secondary)}.time-input{border:none;background:transparent;color:var(--text-primary);font-size:.85rem;font-weight:700;font-family:inherit;width:58px;outline:none;cursor:pointer}.switch-btn{position:relative;width:46px;height:26px;border-radius:20px;background-color:var(--color-border);border:none;cursor:pointer;transition:background-color .25s cubic-bezier(.4,0,.2,1);padding:0}.switch-handle{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background-color:#fff;box-shadow:0 1px 3px #0003;transition:transform .25s cubic-bezier(.4,0,.2,1)}.switch-btn.active{background-color:var(--color-accent)}.switch-btn.active .switch-handle{transform:translate(20px)}.notification-test-row{margin-top:.25rem}.test-notify-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.8rem;border-radius:12px;background-color:var(--bg-subtle, rgba(0, 0, 0, .02));border:1px solid var(--border-color);color:var(--text-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.test-notify-btn:active{transform:scale(.98);background-color:var(--bg-hover, rgba(0, 0, 0, .06))}.chip-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;margin-top:.25rem}.chip-button{background-color:var(--bg-surface);border:1px solid var(--border-color);padding:.5rem .85rem;border-radius:var(--radius-full, 50px);font-size:.85rem;font-weight:500;color:var(--text-secondary);transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.chip-button:hover{background-color:var(--bg-hover, var(--border-color));color:var(--text-primary)}.chip-button.active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--text-inverse, #ffffff);box-shadow:0 4px 10px rgba(var(--color-primary-rgb, 9, 132, 227),.15)}.custom-input-form{display:flex;gap:.5rem;margin-bottom:.75rem;margin-top:.25rem}.custom-input{flex:1}.custom-add-button{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;background-color:var(--bg-surface);border:1.5px solid var(--border-color);border-radius:12px;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.custom-add-button:hover{background-color:var(--bg-hover);border-color:var(--text-secondary)}.custom-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.custom-chip-badge{display:inline-flex;align-items:center;gap:.25rem;background-color:var(--bg-surface);border:1.5px solid var(--border-color);padding:.35rem .6rem;border-radius:6px;font-size:.8rem;font-weight:500;color:var(--text-primary)}.custom-chip-remove{background:none;border:none;padding:0;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:color .2s ease}.custom-chip-remove:hover{color:var(--text-primary)}.section-subtitle{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;display:block}.support-trigger-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:16px;background:var(--card-bg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);outline:none}.support-trigger-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.support-trigger-card:active{transform:translateY(0) scale(.98)}.support-trigger-icon{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:12px;background-color:var(--color-primary-light, rgba(76, 175, 80, .1));color:var(--color-primary);transition:transform .2s ease}.support-trigger-card:hover .support-trigger-icon{transform:scale(1.05) rotate(5deg)}.support-trigger-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.support-trigger-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.support-trigger-desc{font-size:.775rem;color:var(--text-secondary);line-height:1.35}.settings-tabs-container{display:flex;gap:.35rem;background-color:var(--bg-hover, rgba(0, 0, 0, .04));padding:.3rem;border-radius:14px;border:none;margin-bottom:.25rem}[data-theme=dark] .settings-tabs-container{background-color:#ffffff08}.settings-tab-btn{flex:1;padding:.8rem;border:none;background:transparent;border-radius:11px;font-weight:700;font-size:.9rem;color:var(--text-secondary);cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1)}.settings-tab-btn:active{transform:scale(.97)}.settings-tab-btn.active{background-color:var(--card-bg);color:var(--text-primary);box-shadow:0 3px 8px #0000000f,0 1px 3px #0000000a}[data-theme=dark] .settings-tab-btn.active{background-color:var(--color-card);box-shadow:0 4px 12px #00000059,inset 0 1px #ffffff0f}.settings-tab-content{display:flex;flex-direction:column;gap:1.75rem;animation:tabFadeIn .35s cubic-bezier(.16,1,.3,1)}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.delete-account-section{margin-top:1rem;border-top:1px solid var(--border-color);padding-top:1.75rem;display:flex;justify-content:center}.delete-account-btn{background:none;border:none;color:var(--text-danger-label, #ef4444);font-size:.825rem;font-weight:600;text-decoration:underline;cursor:pointer;padding:.6rem 1.2rem;transition:all .2s ease;opacity:.7}.delete-account-btn:hover{opacity:1;color:var(--text-danger, #dc2626)}.delete-account-btn:active{transform:scale(.96)}.delete-modal-overlay{position:fixed;inset:0;background-color:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:modalOverlayFadeIn .3s ease}.delete-modal-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:24px;padding:2rem;max-width:420px;width:100%;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;animation:modalScaleIn .3s cubic-bezier(.16,1,.3,1);color:var(--text-primary);overscroll-behavior:contain}.delete-modal-card h3{font-size:1.2rem;font-weight:800;margin:0;line-height:1.4;color:var(--text-primary)}.delete-modal-card p{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:0}.delete-modal-actions{display:flex;gap:.75rem;margin-top:.5rem}.cancel-delete-btn,.confirm-delete-btn{flex:1;padding:.9rem;border-radius:14px;font-size:.925rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.cancel-delete-btn{background-color:var(--bg-subtle, rgba(0, 0, 0, .02));border-color:var(--border-color);color:var(--text-primary)}.cancel-delete-btn:hover{background-color:var(--bg-hover)}.cancel-delete-btn:active{transform:scale(.97)}.confirm-delete-btn{background-color:var(--bg-danger, #ef4444);color:var(--text-danger-label, #ffffff)}.confirm-delete-btn:hover{filter:brightness(.95)}.confirm-delete-btn:active{transform:scale(.97)}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{transform:scale(.95) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.nickname-settings-card{background:var(--bg-surface-subtle, rgba(255, 255, 255, .03));border:1px solid var(--border-color);border-radius:16px;padding:1.25rem;margin-top:1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 4px 6px -1px #0000000d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nickname-label{font-size:.875rem;font-weight:700;color:var(--text-primary);opacity:.9}.nickname-input-group{display:flex;gap:.75rem}.nickname-input{flex:1;background-color:var(--bg-subtle, rgba(0, 0, 0, .02));border:1px solid var(--border-color);border-radius:12px;padding:.75rem 1rem;font-size:.9rem;color:var(--text-primary);outline:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.nickname-input:focus{border-color:var(--color-accent);background-color:var(--bg-surface);box-shadow:0 0 0 3px #4caf5026}.nickname-save-btn{background-color:var(--color-accent);color:#fff;border:none;border-radius:12px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.nickname-save-btn:hover{filter:brightness(.95)}.nickname-save-btn:active{transform:scale(.97)}.nickname-save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.nickname-lock-notice{font-size:.775rem;color:var(--text-warning, #f59e0b);margin:0;margin-top:.25rem;font-weight:500;line-height:1.35}[data-theme=dark] .nickname-lock-notice{color:#fbbf24}.settings-filter-tip-box{background-color:var(--bg-hover, rgba(0, 0, 0, .03));border:1px solid var(--border-color);border-radius:14px;padding:.95rem 1.15rem;margin-bottom:1.25rem}[data-theme=dark] .settings-filter-tip-box{background-color:#ffffff05}.settings-filter-tip-box .tip-text{font-size:.8rem;color:var(--text-secondary);line-height:1.45;font-weight:500;display:block}.settings-rate-limit-notice{display:flex;align-items:center;gap:.5rem;padding:.85rem 1rem;border-radius:12px;background-color:var(--bg-hover, rgba(0, 0, 0, .03));border:1px solid var(--border-color);margin-bottom:.85rem}[data-theme=dark] .settings-rate-limit-notice{background-color:#ffffff05}.settings-rate-limit-notice .notice-icon{color:var(--text-secondary);flex-shrink:0}.settings-rate-limit-notice .notice-text{font-size:.775rem;color:var(--text-secondary);line-height:1.4;font-weight:500}.payment-success-wrapper{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:1.5rem;background-color:var(--bg-base);animation:fadeInUp .4s ease-out}.success-card{width:100%;max-width:440px;background-color:var(--bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.25rem 1.75rem;box-shadow:var(--shadow-lg);text-align:center;display:flex;flex-direction:column;align-items:center}.success-icon-badge{width:68px;height:68px;border-radius:var(--radius-full);background-color:var(--color-accent-light);color:var(--color-accent);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);animation:bounceIn .8s ease-out}.success-header .welcome-tag{display:inline-flex;align-items:center;gap:.25rem;background-color:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:700;padding:.3rem .65rem;border-radius:var(--radius-sm);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.success-header h2{font-size:1.4rem;font-weight:800;color:var(--text-primary);margin-bottom:.75rem;line-height:1.3}.success-header p{font-size:.88rem;color:var(--text-secondary);line-height:1.5;margin-bottom:2rem}.receipt-container{width:100%;background-color:var(--bg-base);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:2rem;text-align:left;display:flex;flex-direction:column;gap:.85rem}.receipt-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.receipt-row.header{font-weight:700;color:var(--text-primary)}.status-label{background-color:var(--color-accent-light);color:var(--color-accent);font-size:.7rem;font-weight:700;padding:.15rem .45rem;border-radius:2px}.receipt-row .label{color:var(--text-muted)}.receipt-row .value{color:var(--text-primary)}.receipt-row .value .original-price{text-decoration:line-through;color:var(--text-muted);margin-right:6px;font-size:.8rem}.receipt-divider{height:1px;background-color:var(--color-border);border-style:dashed;margin:.25rem 0}.secure-badge{display:flex;align-items:center;justify-content:center;gap:.35rem;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.success-back-btn{width:100%;gap:.5rem}.offline-banner{width:100%;background:var(--bg-warning);color:var(--text-warning-label);padding:.5rem 1rem;font-size:.78rem;font-weight:700;display:flex;justify-content:center;align-items:center;gap:.5rem;box-shadow:var(--shadow-sm);z-index:1000;position:relative;animation:slideDown .3s ease-out;transition:background-color .3s ease,color .3s ease}.offline-icon{display:inline-flex;align-items:center;justify-content:center;animation:blink 1.5s infinite}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.floating-recipe-timer{position:fixed;bottom:84px;left:50%;transform:translate(-50%);width:90%;max-width:440px;background:var(--bg-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:0 10px 30px #0000001f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;overflow:hidden;transition:all .3s cubic-bezier(.175,.885,.32,1.1);padding:0;display:flex;flex-direction:column;animation:slideUpTimer .4s cubic-bezier(.175,.885,.32,1.2)}.floating-recipe-timer.time-over{border-color:#ef444480;box-shadow:0 10px 30px #ef444426;animation:borderPulse 1.5s infinite}.timer-progress-track{width:100%;height:4px;background:var(--color-bg);position:relative}.timer-progress-fill{height:100%;background:linear-gradient(90deg,#ff9800,#ffb74d);transition:width 1s linear}.floating-recipe-timer.time-over .timer-progress-fill{background:#ef4444}.timer-content-row{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;gap:.75rem}.timer-label-section{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.timer-clock-icon{color:#ff9800;flex-shrink:0}.timer-clock-icon.rotate{animation:clockRotate 2s linear infinite}.floating-recipe-timer.time-over .timer-clock-icon{color:#ef4444;animation:bounceTimer .5s ease infinite alternate}.label-text-box{display:flex;flex-direction:column;min-width:0}.timer-menu-label{font-size:.8rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timer-status-desc{font-size:.7rem;color:var(--text-muted)}.floating-recipe-timer.time-over .timer-status-desc{color:#ef4444;font-weight:700}.timer-display-controls{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.timer-time-text{font-family:monospace;font-size:1.25rem;font-weight:800;color:var(--text-primary)}.floating-recipe-timer.time-over .timer-time-text{color:#ef4444;animation:scalePulse .5s ease infinite alternate}.timer-action-buttons{display:flex;align-items:center;gap:.4rem}.timer-control-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--color-border);background:var(--bg-surface);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;outline:none}.timer-control-btn:hover{background:var(--bg-hover);border-color:var(--text-secondary)}.timer-control-btn.play-pause{background:#ff9800;color:#fff;border:none}.timer-control-btn.play-pause:hover{background:#f57c00}.timer-control-btn.close{color:var(--text-muted)}.timer-control-btn.close:hover{background:#ef44441a;color:#ef4444;border-color:#ef444433}.time-over-banner{background:#ef444414;border-top:1px solid rgba(239,68,68,.12);padding:.4rem;text-align:center;font-size:.75rem;font-weight:700;color:#ef4444;display:flex;align-items:center;justify-content:center;gap:4px}@keyframes slideUpTimer{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@keyframes clockRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounceTimer{0%{transform:translateY(0)}to{transform:translateY(-3px)}}@keyframes scalePulse{0%{transform:scale(1)}to{transform:scale(1.05)}}@keyframes borderPulse{0%,to{border-color:#ef444466}50%{border-color:#ef4444cc}}[data-theme=dark] .floating-recipe-timer{background:#1e293bd9;box-shadow:0 12px 40px #0006}[data-theme=dark] .timer-control-btn{background:#0f172a99}[data-theme=dark] .timer-control-btn:hover{background:var(--bg-hover)}
