.app-layout{display:flex;min-height:100vh;min-height:100dvh;max-width:100vw;overflow-x:hidden}.sidebar{display:none;width:260px;background:#fff;border-right:1px solid #e8e8e8;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e8e8e8}.sidebar-logo{font-size:1.5rem;font-weight:700;color:#4caf50}.sidebar-tagline{font-size:.75rem;color:#999}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#555;text-decoration:none;font-size:.95rem;transition:all .15s ease}.sidebar-nav-item:hover{background:#f5f5f5;color:#333}.sidebar-nav-item.active{background:#e8f5e9;color:#2e7d32;font-weight:600;border-right:3px solid #4CAF50}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid #e8e8e8}.sidebar-user{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:#4caf50;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{font-size:.85rem;font-weight:600;color:#333}.sidebar-user-email{font-size:.75rem;color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{width:100%;padding:.5rem;background:none;border:1px solid #ddd;border-radius:6px;color:#666;font-size:.85rem;cursor:pointer;transition:all .15s ease}.sidebar-logout:hover{background:#fee;border-color:#fcc;color:#c33}.app-main{flex:1;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;min-width:0;max-width:100%;overflow-x:hidden}.chat-mode .app-main{height:100vh;height:100dvh}.app-content{flex:1;padding:1rem;padding-bottom:calc(70px + 1rem);overflow-y:auto;overflow-x:hidden;max-width:600px;margin:0 auto;width:100%;box-sizing:border-box}.app-content-chat{padding:0;max-width:100%;display:flex;flex-direction:column}@media(min-width:768px){.app-content-chat{padding:1.5rem;max-width:700px}}.mobile-header{display:flex;align-items:center;justify-content:center;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e8e8e8;position:sticky;top:0;z-index:50}.mobile-logo{font-size:1.25rem;font-weight:700;color:#4caf50}.bottom-nav{display:flex;justify-content:space-around;align-items:center;background:#fff;border-top:1px solid #e8e8e8;padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px));position:fixed;bottom:0;left:0;right:0;z-index:100}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:.15rem;text-decoration:none;color:#999;font-size:.7rem;padding:.25rem .75rem;transition:color .15s ease}.bottom-nav-item .nav-icon{font-size:1.3rem}.bottom-nav-item.active{color:#4caf50}.bottom-nav-item.active .nav-label{font-weight:600}.dashboard-greeting{margin-bottom:1.5rem}.dashboard-greeting h2{font-size:1.4rem;font-weight:700;color:#333}.dashboard-greeting p{color:#999;font-size:.85rem;margin-top:.25rem}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1rem}.widget{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.widget-title{font-size:.85rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.03em}.widget-icon{font-size:1.2rem}.widget-value{font-size:2rem;font-weight:700;color:#333}.widget-unit{font-size:.9rem;font-weight:400;color:#999;margin-left:.25rem}.widget-sub{font-size:.8rem;color:#999;margin-top:.25rem}.widget-progress{height:6px;background:#f0f0f0;border-radius:3px;margin-top:.75rem;overflow:hidden}.widget-progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.widget-progress-bar.green{background:#4caf50}.widget-progress-bar.orange{background:#ff9800}.widget-progress-bar.red{background:#f44336}.widget-progress-bar.blue{background:#2196f3}.macro-bars{display:flex;flex-direction:column;gap:.75rem}.macro-row{display:flex;align-items:center;gap:.75rem}.macro-label{font-size:.8rem;color:#666;width:60px;flex-shrink:0}.macro-bar-track{flex:1;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.macro-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.macro-value{font-size:.75rem;color:#999;width:65px;text-align:right;flex-shrink:0}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f8f9fa;border:1px solid #e8e8e8;border-radius:10px;cursor:pointer;transition:all .15s ease;font-size:.85rem;color:#555}.quick-action-btn:hover{background:#e8f5e9;border-color:#c8e6c9;color:#2e7d32}.quick-action-btn .nav-icon{font-size:1.5rem}.page-header{margin-bottom:1.5rem}.page-header h2{font-size:1.3rem;font-weight:700;color:#333}.page-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#999;text-align:center}.page-placeholder .nav-icon{font-size:3rem;margin-bottom:1rem}@media(min-width:768px){.sidebar{display:flex}.app-main{margin-left:260px}.mobile-header,.bottom-nav{display:none}.app-content{padding:2rem;max-width:700px}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.dashboard-greeting h2{font-size:1.6rem}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.skel{background:linear-gradient(90deg,#eee 25%,#f5f5f5,#eee 75%);background-size:400px 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}.skel-circle{border-radius:50%}.skel-circle-sm{width:20px;height:20px;border-radius:50%}.skel-text{height:12px;border-radius:4px}.day-circles.skeleton{border:1px solid #f0f0f0}.meal-card.skeleton{padding:0;overflow:hidden}.meal-card.skeleton .meal-card-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem .75rem;border-bottom:1px solid #f0f0f0}.skel-row{display:flex;align-items:center;gap:8px}.skel-items{padding:.5rem .75rem}.skel-item{display:flex;align-items:center;justify-content:space-between;padding:.45rem 0}.skel-item+.skel-item{border-top:1px solid #f6f6f6}.skel-item-left{flex:1}.skel-add{padding:.5rem .75rem;border-top:1px solid #f0f0f0;display:flex;justify-content:center}.skel-ring-container{display:flex;justify-content:center;padding:1.5rem 0 1rem}.skel-circle-big{width:160px;height:160px;border-radius:50%}.skel-tiles{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:0 .5rem}.skel-tile{height:72px;border-radius:12px}.calorie-card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0;margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:center;overflow:hidden}.calorie-ring-container{position:relative;width:140px;height:140px;margin-bottom:1rem}.calorie-ring{width:100%;height:100%}.calorie-ring-progress{transition:stroke-dasharray .6s ease}.calorie-ring-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column}.calorie-ring-value{font-size:1.8rem;font-weight:700;color:#333;line-height:1}.calorie-ring-value.over{color:#f44336}.calorie-ring-unit{font-size:.7rem;color:#999;margin-top:.2rem}.calorie-breakdown{display:flex;align-items:center;justify-content:center;gap:0;width:100%}.calorie-breakdown-item{display:flex;flex-direction:column;align-items:center;flex:1}.calorie-breakdown-value{font-size:1.1rem;font-weight:700;color:#333}.calorie-breakdown-label{font-size:.7rem;color:#999;margin-top:.1rem}.calorie-breakdown-divider{width:1px;height:30px;background:#e8e8e8}.section-title{font-size:.8rem;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.tile-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.5rem;margin-bottom:1.5rem}.tile{background:#fff;border-radius:10px;padding:.65rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0;display:flex;flex-direction:column;gap:.25rem;overflow:hidden;min-width:0}.tile-top{display:flex;justify-content:space-between;align-items:center}.tile-label{font-size:.6rem;font-weight:600;color:#777;text-transform:uppercase;letter-spacing:.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-pct{font-size:.6rem;font-weight:700;flex-shrink:0}.tile-value{font-size:.85rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tile-goal{font-size:.7rem;color:#bbb;font-weight:400}.tile-bar-track{height:5px;background:#f0f0f0;border-radius:3px;overflow:hidden;margin-top:.15rem}.tile-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.tile-hint{font-size:.7rem;color:#ccc}.quick-actions-row{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}.quick-actions-row::-webkit-scrollbar{display:none}.quick-btn{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.75rem 1rem;min-width:72px;background:#fff;border:1px solid #e8e8e8;border-radius:12px;cursor:pointer;font-size:.72rem;color:#555;transition:all .15s ease;flex-shrink:0}.quick-btn span{font-size:1.4rem}.quick-btn:hover{background:#e8f5e9;border-color:#c8e6c9;color:#2e7d32}.quick-btn:active{transform:scale(.96)}@media(min-width:768px){.calorie-card{flex-direction:row;gap:2rem;padding:2rem}.calorie-ring-container{margin-bottom:0;width:180px;height:180px;flex-shrink:0}.calorie-breakdown{flex-direction:column;gap:.75rem;align-items:flex-start}.calorie-breakdown-item{align-items:flex-start}.calorie-breakdown-divider{width:100%;height:1px}.calorie-breakdown-value{font-size:1.3rem}.tile-grid{grid-template-columns:repeat(2,1fr)}.tile{padding:1rem}.quick-actions-row{flex-wrap:wrap}}@media(min-width:1200px){.calorie-ring-container{width:200px;height:200px}.calorie-ring-value{font-size:2.2rem}}.datepicker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.datepicker{background:#fff;border-radius:16px;width:100%;max-width:340px;box-shadow:0 8px 30px #00000026;overflow:hidden}.datepicker-header{display:flex;align-items:center;justify-content:space-between;padding:1rem}.datepicker-month{font-size:1rem;font-weight:700;color:#333;text-transform:capitalize}.datepicker-nav{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:10px;font-size:1.2rem;color:#555;cursor:pointer;transition:all .15s ease}.datepicker-nav:hover{background:#e8f5e9;color:#4caf50}.datepicker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);padding:0 .75rem;margin-bottom:.25rem}.datepicker-weekday{text-align:center;font-size:.7rem;font-weight:600;color:#bbb;padding:.25rem 0}.datepicker-days{display:grid;grid-template-columns:repeat(7,1fr);padding:0 .75rem;gap:.2rem}.datepicker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:none;background:none;border-radius:50%;font-size:.85rem;color:#333;cursor:pointer;transition:all .1s ease}.datepicker-day:hover:not(.empty){background:#f0f0f0}.datepicker-day.empty{cursor:default}.datepicker-day.today{font-weight:700;color:#4caf50}.datepicker-day.selected{background:#4caf50;color:#fff;font-weight:700}.datepicker-day.selected.today{color:#fff}.datepicker-footer{display:flex;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid #f0f0f0}.datepicker-today-btn,.datepicker-close-btn{background:none;border:none;font-size:.85rem;font-weight:600;cursor:pointer;padding:.4rem .75rem;border-radius:8px;transition:all .15s ease}.datepicker-today-btn{color:#4caf50}.datepicker-today-btn:hover{background:#e8f5e9}.datepicker-close-btn{color:#999}.datepicker-close-btn:hover{background:#f5f5f5}.date-nav{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:12px;padding:.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0}.date-nav-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:10px;font-size:1.3rem;color:#555;cursor:pointer;flex-shrink:0}.date-nav-btn:hover{background:#e8f5e9;color:#4caf50}.date-nav-center{display:flex;flex-direction:column;align-items:center;background:none;border:none;cursor:pointer;padding:.25rem 1rem}.date-nav-label{font-size:1rem;font-weight:700;color:#333}.date-nav-full{font-size:.7rem;color:#999}.day-circles{display:flex;align-items:flex-start;justify-content:space-around;background:#fff;border-radius:12px;padding:.75rem .25rem .5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0}.circle-progress{display:flex;flex-direction:column;align-items:center;position:relative}.circle-progress svg{display:block}.circle-value{position:absolute;top:0;left:0;right:0;bottom:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.circle-num{font-size:.78rem;font-weight:700;color:#333;line-height:1}.circle-unit{font-size:.48rem;color:#999;line-height:1;margin-top:1px}.circle-label{font-size:.58rem;color:#888;margin-top:.2rem;text-align:center}.meals-list{display:flex;flex-direction:column;gap:.75rem}.meal-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0;overflow:hidden}.meal-card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem .875rem;border-bottom:1px solid #f5f5f5}.meal-card-header.clickable{cursor:pointer}.meal-card-header.clickable:active{background:#fafafa}.meal-card-title{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#333}.meal-card-icon{font-size:1.1rem}.meal-card-right{display:flex;align-items:center;gap:.3rem}.meal-card-kcal{font-size:.8rem;font-weight:600;color:#4caf50}.meal-card-chevron{font-size:1.1rem;color:#ccc}.swipe-container{position:relative;overflow:hidden;border-bottom:1px solid #f8f8f8}.swipe-container:last-child{border-bottom:none}.swipe-bg{position:absolute;top:0;left:0;right:0;bottom:0;background:#f44336;display:flex;align-items:center;padding-left:1rem;color:#fff;font-size:.75rem;font-weight:600}.meal-items{padding:0}.meal-item{padding:.5rem .875rem;background:#fff;position:relative;z-index:1}.meal-item-top{display:flex;justify-content:space-between;align-items:center}.meal-item-info{display:flex;flex-direction:column;min-width:0;flex:1}.meal-item-name{font-size:.85rem;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-item-amount{font-size:.65rem;color:#bbb}.meal-item-cal{font-size:.75rem;font-weight:600;color:#555;flex-shrink:0}.nutri-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.3rem}.nutri-tag{display:inline-flex;align-items:center;padding:.12rem .4rem;border-radius:6px;font-size:.58rem;font-weight:600;line-height:1.3}.meal-empty{padding:.75rem .875rem;font-size:.8rem;color:#ccc;text-align:center}.meal-add-btn{width:100%;padding:.6rem;background:none;border:none;border-top:1px solid #f0f0f0;color:#4caf50;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s ease}.meal-add-btn:hover{background:#f8fdf8}.meals-loading{text-align:center;padding:3rem;color:#999}.undo-snackbar{position:fixed;bottom:calc(56px + .75rem);left:50%;transform:translate(-50%);background:#333;color:#fff;padding:.6rem .8rem;border-radius:10px;display:flex;align-items:center;gap:.75rem;font-size:.8rem;box-shadow:0 4px 12px #00000040;z-index:100;animation:snackIn .25s ease;max-width:calc(100% - 2rem)}.undo-snackbar span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.undo-snackbar button{background:none;border:none;color:#81c784;font-weight:700;font-size:.8rem;cursor:pointer;flex-shrink:0;padding:.2rem .4rem}@keyframes snackIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ctx-menu{position:fixed;z-index:200;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;border:1px solid #e0e0e0;overflow:hidden;min-width:140px}.ctx-menu-item{display:flex;align-items:center;gap:.4rem;width:100%;padding:.55rem .75rem;background:none;border:none;font-size:.8rem;cursor:pointer;text-align:left;color:#333}.ctx-menu-item:hover{background:#f5f5f5}.ctx-menu-item.danger{color:#d32f2f}.ctx-menu-item.danger:hover{background:#ffebee}.fab-today{position:fixed;bottom:calc(70px + 1rem);right:1rem;background:#4caf50;color:#fff;border:none;border-radius:20px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #4caf504d;z-index:50}@media(min-width:768px){.fab-today{bottom:2rem;right:2rem}.undo-snackbar{bottom:2rem}}.barcode-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;z-index:1000;display:flex;flex-direction:column}.barcode-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;padding-top:calc(.5rem + env(safe-area-inset-top,0px));background:#0009;position:relative;z-index:2}.barcode-close,.barcode-flash{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;cursor:pointer;border-radius:50%}.barcode-close:active,.barcode-flash:active{background:#ffffff26}.barcode-flash.on{color:#ffd600}.barcode-title{font-size:.9rem;font-weight:600;color:#fff}.barcode-camera{flex:1;position:relative;overflow:hidden}.barcode-camera video{width:100%;height:100%;object-fit:cover}.barcode-guide{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.guide-frame{width:260px;height:160px;position:relative}.guide-corner{position:absolute;width:24px;height:24px;border-color:#4caf50;border-style:solid;border-width:0}.guide-corner.tl{top:0;left:0;border-top-width:3px;border-left-width:3px;border-top-left-radius:8px}.guide-corner.tr{top:0;right:0;border-top-width:3px;border-right-width:3px;border-top-right-radius:8px}.guide-corner.bl{bottom:0;left:0;border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:8px}.guide-corner.br{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:8px}.guide-line{position:absolute;top:50%;left:10px;right:10px;height:2px;background:#f44336;opacity:.7;animation:scanLine 2s ease-in-out infinite}@keyframes scanLine{0%,to{top:30%}50%{top:70%}}.guide-text{margin-top:1.5rem;color:#fffc;font-size:.82rem;text-align:center}.barcode-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff;text-align:center}.barcode-error p{margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.barcode-error button{padding:.6rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer}.chat-page{display:flex;flex-direction:column;height:calc(100vh - 56px);height:calc(100dvh - 56px);background:#ece5dd}.chat-page-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.chat-back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:1.4rem;color:#555;cursor:pointer}.chat-page-title{display:flex;flex-direction:column;align-items:center}.chat-page-title>span:first-child{font-size:.9rem;font-weight:600;color:#333}.chat-page-date{font-size:.65rem;color:#999}.chat-page-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.4rem}.chat-row{display:flex;align-items:flex-end;gap:.35rem;max-width:85%}.chat-row.user{align-self:flex-end}.chat-row.assistant{align-self:flex-start}.chat-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.7rem;font-weight:700}.chat-av.ai{background:#fff;font-size:.95rem;box-shadow:0 1px 2px #0000001a}.chat-av.usr{background:#4caf50;color:#fff}.chat-content{min-width:0}.chat-bbl{padding:.45rem .65rem;border-radius:10px;font-size:.82rem;line-height:1.4;white-space:pre-line;word-wrap:break-word}.chat-row.user .chat-bbl{background:#dcf8c6;color:#333;border-bottom-right-radius:3px}.chat-row.assistant .chat-bbl{background:#fff;color:#333;border-bottom-left-radius:3px}.dots span{animation:blink 1.4s infinite both;font-size:1.1rem}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.2}40%{opacity:1}}.chat-items-card{background:#fff;border-radius:10px;overflow:hidden}.chat-items-hdr{display:flex;justify-content:space-between;padding:.45rem .6rem;border-bottom:1px solid #f0f0f0;font-size:.7rem;font-weight:600;color:#777}.chat-items-kcal{color:#4caf50;font-weight:700}.chat-food{border-bottom:1px solid #f5f5f5}.chat-food:last-of-type{border-bottom:none}.chat-food-top{display:flex;justify-content:space-between;align-items:center;padding:.35rem .6rem;cursor:pointer}.chat-food-info{display:flex;flex-direction:column;min-width:0;flex:1}.chat-food-name{font-size:.8rem;font-weight:500;color:#333}.chat-food-amt{font-size:.62rem;color:#bbb}.chat-food-right{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.chat-food-cal{font-size:.72rem;font-weight:600;color:#555}.chat-food-cal:after{content:" kcal";font-weight:400;color:#999;font-size:.6rem}.chat-food-x{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#ccc;font-size:.65rem;cursor:pointer;border-radius:50%}.chat-food-x:hover{background:#fee;color:#f44336}.chat-food-macros{display:flex;gap:.5rem;padding:0 .6rem .3rem;font-size:.6rem;font-weight:600}.chat-food-detail{padding:.3rem .6rem .4rem;background:#fafafa;display:flex;flex-direction:column;gap:.2rem}.detail-r{display:flex;justify-content:space-between;font-size:.68rem;color:#777}.chat-items-foot{display:flex;justify-content:space-around;padding:.35rem .6rem;border-top:1px solid #f0f0f0;font-size:.62rem;font-weight:700;background:#fafafa}.chat-page-bottom{flex-shrink:0;background:#f7f4ef;border-top:1px solid #e0dbd3;padding:.5rem .65rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:.4rem}.chat-confirm-btn{width:100%;padding:.6rem;background:#4caf50;color:#fff;border:none;border-radius:10px;font-size:.84rem;font-weight:600;cursor:pointer}.chat-confirm-btn:disabled{background:#ccc;cursor:not-allowed}.chat-input-card{background:#fff;border-radius:14px;border:1px solid #e8e4dc;overflow:hidden}.chat-input-top{padding:.65rem .75rem}.chat-inp{width:100%;padding:0;border:none;font-size:.9rem;outline:none;background:transparent;color:#333}.chat-inp::placeholder{color:#b0a898}.chat-input-actions{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;border-top:1px solid #f0ece5}.chat-input-left{display:flex;align-items:center;gap:.15rem}.chat-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.15rem;color:#8a8078;transition:background .15s ease}.chat-action-btn:hover{background:#f0ece5}.chat-action-btn:active{background:#e8e4dc}.chat-send-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#d5d0c8;color:#fff;border:none;border-radius:50%;font-size:.9rem;cursor:pointer;flex-shrink:0;transition:background .15s ease}.chat-send-btn.active{background:#4caf50}.chat-send-btn:disabled{background:#d5d0c8;cursor:default}@media(min-width:768px){.chat-page{height:auto;min-height:0;flex:1;background:transparent;max-width:600px;margin:0 auto}.chat-page-header{border-radius:12px 12px 0 0;border:1px solid #e0e0e0;border-bottom:1px solid #e0e0e0}.chat-page-messages{background:#ece5dd;border-left:1px solid #e0e0e0;border-right:1px solid #e0e0e0}.chat-page-bottom{border-radius:0 0 12px 12px;border:1px solid #d4cfc7;border-top:1px solid #d4cfc7;padding-bottom:.5rem}.chat-row{max-width:70%}}.meal-detail{padding-bottom:2rem}.meal-detail-loading,.meal-detail-empty{text-align:center;padding:3rem 1rem;color:#999}.meal-detail-empty button{margin-top:1rem;padding:.5rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer}.meal-detail-header{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:12px;padding:.6rem .75rem;margin-bottom:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0}.meal-detail-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:10px;font-size:1.3rem;color:#555;cursor:pointer}.meal-detail-title{display:flex;flex-direction:column;align-items:center}.meal-detail-title>span:first-child{font-size:.95rem;font-weight:600;color:#333}.meal-detail-date{font-size:.65rem;color:#999}.meal-detail-cal{font-size:.9rem;font-weight:700;color:#4caf50}.meal-detail-items{background:#fff;border-radius:12px;margin-bottom:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0;overflow:hidden}.md-item{display:flex;justify-content:space-between;align-items:center;padding:.55rem .875rem;border-bottom:1px solid #f5f5f5}.md-item:last-child{border-bottom:none}.md-item-name{font-size:.84rem;font-weight:500;color:#333}.md-item-meta{font-size:.7rem;color:#999;flex-shrink:0;margin-left:.5rem}.meal-detail-nutrients{background:#fff;border-radius:12px;padding:.75rem;box-shadow:0 1px 3px #0000000f;border:1px solid #f0f0f0}.md-section-title{font-size:.75rem;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.3px;margin-bottom:.6rem}.md-nutrient{margin-bottom:.6rem}.md-nutrient.indent{padding-left:.75rem}.md-nutrient.indent .md-nutrient-label{color:#999;font-weight:400}.md-nutrient-top{display:flex;justify-content:space-between;margin-bottom:.2rem}.md-nutrient-label{font-size:.78rem;font-weight:500;color:#555}.md-nutrient-value{font-size:.78rem;font-weight:600;color:#333}.md-nutrient-bar-bg{height:5px;background:#f0f0f0;border-radius:3px;overflow:hidden}.md-nutrient-bar{height:100%;border-radius:3px;transition:width .4s ease;min-width:1px}.md-nutrient-goal{font-size:.6rem;color:#bbb;margin-top:.1rem;display:block}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5;color:#333;overflow-x:hidden;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}#root{overflow-x:hidden}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-page h1{font-size:2.5rem;margin-bottom:.5rem}.auth-page p{color:#666;margin-bottom:2rem}.auth-page form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:400px}.auth-page input{padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.auth-page button{padding:.75rem 1rem;background-color:#4caf50;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer}.auth-page button:hover{background-color:#45a049}.auth-error{background-color:#fee;color:#c33;padding:.75rem 1rem;border-radius:8px;border:1px solid #fcc;font-size:.9rem}.auth-info{background-color:#e8f5e9;color:#2e7d32;padding:.75rem 1rem;border-radius:8px;border:1px solid #c8e6c9;font-size:.9rem;margin-bottom:1rem;max-width:400px;text-align:center}.auth-links{margin-top:1rem}.auth-links a{color:#4caf50;text-decoration:none}.auth-links a:hover{text-decoration:underline}.link-button{background:none;border:none;color:#4caf50;cursor:pointer;font-size:.9rem;padding:0}.link-button:hover{text-decoration:underline}.auth-page button:disabled{background-color:#ccc;cursor:not-allowed}.dashboard-page header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;box-shadow:0 1px 3px #0000001a}.dashboard-page main{padding:2rem}
