:root{--color-primary:#22c55e;--color-primary-light:#4ade80;--color-primary-dark:#16a34a;--color-success:#16a34a;--color-warning:#f59e0b;--color-danger:#ef4444;--color-bg:#f7f8fa;--color-surface:#fff;--color-text:#111827;--color-text-secondary:#6b7280;--color-border:#e5e7eb;--color-border-hover:var(--color-border-hover);--color-success-bg:var(--color-success-bg);--color-success-text:var(--color-success-text);--color-success-border:var(--color-success-border);--color-danger-bg:var(--color-danger-bg);--color-danger-text:var(--color-danger-text);--color-danger-border:var(--color-danger-border);--color-warning-bg:var(--color-warning-bg);--color-warning-bg-hover:var(--color-warning-bg-hover);--color-info-bg:var(--color-info-bg);--color-primary-bg:var(--color-primary-bg);--color-primary-bg-alt:var(--color-primary-bg-alt);--color-primary-border-light:var(--color-primary-border-light);--color-accent-blue:var(--color-accent-blue);--color-accent-blue-dark:var(--color-accent-blue-dark);--color-like:#ef4444;--color-like-bg:var(--color-danger-bg);--overlay-dark:#00000080;--overlay-light:#ffffffeb;--overlay-gradient:#00000073;--space-2xs:2px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 10px 30px #00000014;--shadow-glow:0 4px 20px #22c55e59;--shadow-glow-lg:0 8px 30px #22c55e73;--font-sans:-apple-system, "SF Pro Display", "Inter", system-ui, sans-serif;--font-size-2xs:10px;--font-size-xs:clamp(.7rem, .65rem + .25vw, .75rem);--font-size-sm:clamp(.8rem, .75rem + .25vw, .875rem);--font-size-base:clamp(.875rem, .8rem + .4vw, 1rem);--font-size-lg:clamp(1rem, .9rem + .5vw, 1.25rem);--font-size-xl:clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--font-size-2xl:clamp(1.5rem, 1.25rem + 1.25vw, 2rem);--font-size-input:16px;--z-sticky:10;--z-nav:100;--z-modal:200;--z-banner:300;--opacity-disabled:.5;--opacity-hover:.7}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);-webkit-text-size-adjust:100%;touch-action:manipulation;-webkit-font-smoothing:antialiased;line-height:1.6}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.container{width:100%;max-width:1200px;padding:0 var(--space-md);margin:0 auto}.card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:var(--shadow-md);border:none}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-base);cursor:pointer;border:none;min-width:44px;min-height:44px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover{background:var(--color-border-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger)}.btn-block{width:100%}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-group label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600}.form-group input,.form-group select{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-input);background:var(--color-surface);min-height:44px;color:var(--color-text);outline:none;transition:border-color .2s}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #22c55e1a}.error-text{color:var(--color-danger);font-size:var(--font-size-sm);opacity:0;grid-template-rows:0fr;margin:0;transition:grid-template-rows .3s,opacity .3s,margin .3s;display:grid;overflow:hidden}.error-text.visible{opacity:1;grid-template-rows:1fr}.error-text>span{overflow:hidden}.success-text{color:var(--color-success);font-size:var(--font-size-sm);opacity:0;grid-template-rows:0fr;margin:0;transition:grid-template-rows .3s,opacity .3s,margin .3s;display:grid;overflow:hidden}.success-text.visible{opacity:1;grid-template-rows:1fr}.success-text>span{overflow:hidden}.page{min-height:100vh;padding:0}.page-title{font-size:var(--font-size-2xl);margin-bottom:var(--space-lg);font-weight:700}.grid-2{gap:var(--space-md);grid-template-columns:1fr;display:grid}@media (width>=768px){.grid-2{grid-template-columns:1fr 1fr}}.grid-3{gap:var(--space-md);grid-template-columns:1fr;display:grid}@media (width>=768px){.grid-3{grid-template-columns:1fr 1fr 1fr}}.bottom-nav{background:var(--color-surface);padding:var(--space-sm) 0 calc(var(--space-sm) + env(safe-area-inset-bottom,0px));z-index:var(--z-nav);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffeb;border-top:1px solid #0000000f;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav a{font-size:var(--font-size-2xs);color:var(--color-text-secondary);padding:var(--space-xs);letter-spacing:.2px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:44px;min-height:44px;text-decoration:none;display:flex}.bottom-nav a.active{color:var(--color-primary)}.bottom-nav a.active svg{stroke-width:2.5px}.bottom-nav a.scan-nav-btn{color:#fff}.bottom-nav a.scan-nav-btn .nav-icon{background:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;margin-top:-12px;display:flex;box-shadow:0 4px 12px #22c55e59}.bottom-nav a.scan-nav-btn svg{stroke:#fff}.nav-icon{justify-content:center;align-items:center;display:inline-flex;position:relative}@media (width>=768px){.bottom-nav{display:none}}.sidebar{display:none}@media (width>=768px){.app-layout{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{gap:var(--space-sm);background:var(--color-surface);border-right:1px solid var(--color-border);padding:var(--space-lg);flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.sidebar .logo{font-size:var(--font-size-xl);color:var(--color-primary);margin-bottom:var(--space-lg);font-weight:700}.sidebar a{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:500;text-decoration:none;display:flex}.sidebar a:hover{background:var(--color-bg);color:var(--color-text)}.sidebar a.active{color:var(--color-primary);background:#22c55e14;font-weight:700}.sidebar a.active svg{stroke-width:2.5px;stroke:var(--color-primary)}.sidebar .public-profile-link{margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px dashed var(--color-primary-light);border-radius:var(--radius-md);color:var(--color-primary);font-weight:600;font-size:var(--font-size-sm);align-items:center;gap:var(--space-sm);text-decoration:none;display:flex}.sidebar .public-profile-link:hover{background:#22c55e14}.sidebar .logout-btn{margin-top:auto}.main-content{padding:var(--space-xl);padding-bottom:var(--space-2xl)}.top-bar{display:none}}@media (width<=767px){.main-content{padding:0 var(--space-md) 80px;background:var(--color-surface);height:100vh;overflow-y:auto}}.calorie-ring{width:180px;height:180px;margin:0 auto;position:relative}.calorie-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.calorie-ring svg circle{transition:stroke-dashoffset .6s,stroke .3s}.calorie-ring-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.calorie-ring-center .amount{font-size:var(--font-size-2xl);font-weight:700}.calorie-ring-center .label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.meal-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);display:flex}.meal-item:last-child{border-bottom:none}.meal-item .meal-info{flex:1}.meal-item .meal-name{font-weight:600}.meal-item .meal-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.meal-item .meal-cals{color:var(--color-primary);font-weight:700}.meal-item .meal-delete{color:var(--color-text-secondary);cursor:pointer;padding:var(--space-xs);background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:18px;display:flex}.meal-item .meal-delete:hover{color:var(--color-danger)}.modal-overlay{z-index:var(--z-modal);padding:var(--space-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-md);width:100%;max-width:480px;box-shadow:var(--shadow-lg);position:relative}.modal h2{margin-bottom:var(--space-md)}.modal-close{top:var(--space-sm);right:var(--space-sm);color:#fff;cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;line-height:1;transition:background .2s;display:flex;position:absolute}.modal-close:hover{background:#000000b3}.ai-analyze-btn{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-md);border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary-dark), var(--color-primary), var(--color-primary-light), var(--color-primary));color:#fff;font-size:var(--font-size-base);letter-spacing:.3px;cursor:pointer;background-size:200% 200%;border:none;min-height:52px;font-weight:700;transition:transform .2s,box-shadow .2s;animation:4s infinite gradientShift;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #22c55e59,0 0 40px #16a34a26}.ai-analyze-btn:before{content:"";background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);width:200%;height:200%;animation:3s ease-in-out infinite shimmer;position:absolute;top:-50%;left:-50%}.ai-analyze-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #22c55e73,0 0 60px #16a34a33}.ai-analyze-btn:active{transform:translateY(0)}.ai-analyze-btn:disabled{opacity:var(--opacity-hover);cursor:not-allowed;animation:none;transform:none}.ai-analyze-btn:disabled:before{animation:none}.ai-analyze-icon{font-size:20px;animation:2s ease-in-out infinite sparkle}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)rotate(0)}50%{opacity:.8;transform:scale(1.3)rotate(15deg)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes shimmer{0%{transform:translate(-100%)rotate(25deg)}to{transform:translate(100%)rotate(25deg)}}.ai-analysis-content{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.7}.ai-analysis-content p{margin-bottom:var(--space-md)}.ai-analysis-content p:last-child{margin-bottom:0}.context-help-icon{background:var(--color-primary-light);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;transition:background .2s;display:inline-flex}.context-help-icon:hover{background:var(--color-primary)}.context-help-tip{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);line-height:1.5;animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.suggestion-card{background:linear-gradient(135deg, var(--color-primary-bg), var(--color-primary-bg-alt));border:1px solid var(--color-primary-border-light);border-radius:var(--radius-lg);padding:var(--space-lg)}.suggestion-card .suggestion-text{font-size:var(--font-size-lg);color:var(--color-primary-dark);font-weight:500}.macro-bar{gap:var(--space-md);flex-wrap:wrap;display:flex}.macro-item{align-items:center;gap:var(--space-xs);flex-direction:column;flex:1;min-width:70px;display:flex}.macro-item .macro-value{font-size:var(--font-size-lg);font-weight:700}.macro-item .macro-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.motivation-banner{z-index:var(--z-banner);align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;animation:.4s ease-out motivationSlideIn;display:flex;position:fixed;top:0;left:0;right:0}.motivation-text{font-size:var(--font-size-sm);flex:1;font-weight:500;line-height:1.4}.motivation-close{color:#fff;border-radius:var(--radius-full);cursor:pointer;background:#fff3;border:none;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:18px;transition:background .2s;display:flex}.motivation-close:hover{background:#ffffff59}@keyframes motivationSlideIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.macro-cards{gap:var(--space-sm);margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.macro-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);align-items:center;gap:var(--space-sm);text-align:center;flex-direction:column;display:flex}.macro-card-ring{width:64px;height:64px;position:relative}.macro-card-ring svg{width:100%;height:100%}.macro-card-ring svg circle{transition:stroke-dashoffset .6s}.macro-card-pct{font-size:var(--font-size-xs);color:var(--color-text);justify-content:center;align-items:center;font-weight:700;transition:opacity .3s;display:flex;position:absolute;inset:0}.macro-card-info{flex-direction:column;gap:2px;display:flex}.macro-card-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);font-weight:700}.macro-card-value{font-size:var(--font-size-sm);color:var(--color-text);font-weight:600}.macro-card-sep{color:var(--color-text-secondary);font-weight:400}.macro-card-remaining{font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media (width<=480px){.macro-cards{gap:var(--space-xs);grid-template-columns:repeat(3,1fr)}.macro-card{padding:var(--space-sm)}.macro-card-ring{width:52px;height:52px}}.dashboard-page{max-width:560px;margin:0 auto}.dash-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.dash-weighin-prompt{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-warning-bg);border-radius:var(--radius-lg);margin-bottom:var(--space-md);cursor:pointer;transition:background .15s;display:flex}.dash-weighin-prompt:hover{background:var(--color-warning-bg-hover)}.dash-today-card{margin-bottom:var(--space-md)}.dash-today-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.dash-edit-goal{color:var(--color-primary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;padding:0;font-weight:600}.dash-today-content{align-items:center;gap:var(--space-lg);display:flex}.dash-ring-wrap{flex-shrink:0}.dash-macros{gap:var(--space-md);flex-direction:column;flex:1;min-width:0;display:flex}.dash-macro-row{flex-direction:column;gap:4px;display:flex}.dash-macro-top{justify-content:space-between;align-items:center;display:flex}.dash-macro-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.dash-macro-value{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.dash-macro-value strong{color:var(--color-text)}.dash-macro-bar-bg{background:var(--color-bg);border-radius:var(--radius-full);height:8px;overflow:hidden}.dash-macro-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .6s}.dash-quick-stats{gap:var(--space-md);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border);justify-content:center;display:flex}.dash-stat{align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.dash-stat strong{color:var(--color-text);font-size:var(--font-size-base)}.dash-chart{gap:var(--space-sm);height:200px;margin-top:var(--space-sm);display:flex}.dash-chart-y{color:var(--color-text-secondary);text-align:right;flex-direction:column;flex-shrink:0;justify-content:space-between;width:24px;padding-bottom:22px;font-size:11px;display:flex}.dash-chart-bars{flex:1;align-items:flex-end;gap:0;display:flex;position:relative}.dash-chart-target{border-top:2px dashed var(--color-border);z-index:1;position:absolute;left:0;right:0}.dash-chart-col{align-items:center;gap:var(--space-xs);flex-direction:column;flex:1;height:100%;display:flex}.dash-chart-bar-wrap{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex;position:relative}.dash-chart-bar-label{font-size:var(--font-size-2xs);color:var(--color-text);white-space:nowrap;margin-bottom:2px;font-weight:600;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.dash-chart-bar{background:var(--color-primary-bg-alt);border-radius:var(--radius-sm) var(--radius-sm) 2px 2px;width:70%;min-width:16px;max-width:36px;min-height:4px;transition:height .6s}.dash-chart-bar.today{background:var(--color-primary)}.dash-chart-label{color:var(--color-text-secondary);font-size:11px}.dash-chart-label.today{color:var(--color-text);font-weight:700}.dash-tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);display:flex}.dash-tab{font-size:var(--font-size-base);color:var(--color-text-secondary);cursor:pointer;padding:var(--space-sm) var(--space-md);text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;font-weight:600;transition:all .2s}.dash-tab.active{color:var(--color-text);border-bottom-color:var(--color-text)}.dash-actions{gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.dash-meal-swipe-wrapper{border-bottom:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:2px;position:relative;overflow:hidden}.dash-meal-swipe-wrapper:last-child{border-bottom:none;margin-bottom:0}.dash-meal-delete-action{color:#fff;width:90px;font-weight:600;font-size:var(--font-size-xs);cursor:pointer;-webkit-user-select:none;user-select:none;opacity:0;background:linear-gradient(135deg,#ef4444,#dc2626);flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:opacity .25s,transform .25s;display:flex;position:absolute;top:0;bottom:0;right:0;transform:scale(.8)}.dash-meal-swipe-wrapper.reveal-delete .dash-meal-delete-action{opacity:1;transform:scale(1)}.dash-meal-delete-action:active{background:linear-gradient(135deg,#dc2626,#b91c1c)}.dash-meal-delete-action svg{width:20px;height:20px}.dash-meal-content{background:var(--color-surface);z-index:1;transition:transform .3s cubic-bezier(.25,.46,.45,.94);position:relative}.dash-meal-content.swiped{transform:translate(-90px)}.dash-meal-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;cursor:pointer;transition:background .15s;display:flex}.dash-meal-item:hover{background:var(--color-bg);margin:0 calc(-1 * var(--space-lg));padding-left:var(--space-lg);padding-right:var(--space-lg)}.dash-meal-img{border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;width:48px;height:48px}.dash-meal-img-placeholder{border-radius:var(--radius-md);background:var(--color-bg);width:48px;height:48px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-meal-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.dash-meal-name{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dash-meal-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.dash-meal-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.dash-meal-cals{font-weight:600;font-size:var(--font-size-sm)}.dash-meal-time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.scan-mode-toggle{gap:var(--space-xs);margin-bottom:var(--space-md);background:var(--color-surface);border-radius:var(--radius-lg);padding:4px;display:flex}.scan-mode-btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;flex:1;font-weight:500;transition:all .2s}.scan-mode-btn.active{background:var(--color-primary);color:#fff}.voice-record-btn{border:4px solid var(--color-primary-light);background:var(--color-primary);color:#fff;cursor:pointer;justify-content:center;align-items:center;gap:var(--space-xs);border-radius:50%;flex-direction:column;width:120px;height:120px;font-size:40px;transition:all .2s;display:flex}.voice-record-btn span:last-child{font-size:var(--font-size-xs)}.voice-record-btn.recording{background:var(--color-danger,#e53e3e);border-color:var(--color-danger,#e53e3e);animation:1.5s ease-in-out infinite voice-pulse}@keyframes voice-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.voice-record-btn:disabled{opacity:.5;cursor:not-allowed}.voice-transcript{width:100%;margin-top:var(--space-md)}.voice-transcript label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs);display:block}.barcode-scanner-container{border-radius:var(--radius-lg);width:100%;max-width:400px;position:relative;overflow:hidden}.barcode-scanner-container video{border-radius:var(--radius-lg);width:100%;display:block}.barcode-scanner-container canvas.drawingBuffer{display:none}.barcode-servings{text-align:center}.scan-area{align-items:center;gap:var(--space-lg);padding:var(--space-xl);flex-direction:column;display:flex}.photo-preview{border-radius:var(--radius-lg);width:100%;max-width:400px;overflow:hidden}.photo-preview img{width:100%;height:auto;display:block}.camera-btn{background:var(--color-primary);color:#fff;border:4px solid var(--color-primary-light);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:32px;transition:transform .2s;display:flex}.camera-btn:hover{transform:scale(1.05)}.steps{gap:var(--space-sm);margin-bottom:var(--space-xl);justify-content:center;display:flex}.step{background:var(--color-border);border-radius:50%;width:10px;height:10px}.step.active{background:var(--color-primary)}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);width:32px;height:32px;margin:var(--space-lg) auto;border-radius:50%;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.scan-overlay{z-index:1000;background:#000000d9;justify-content:center;align-items:center;animation:.3s ease-out scanOverlayIn;display:flex;position:fixed;inset:0}@keyframes scanOverlayIn{0%{opacity:0}to{opacity:1}}.scan-overlay-content{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.scan-image-wrapper{border-radius:var(--radius-lg);width:280px;max-width:80vw;position:relative;overflow:hidden}.scan-image-wrapper img{border-radius:var(--radius-lg);width:100%;height:auto;display:block}.scan-line-h{pointer-events:none;background:linear-gradient(90deg,#0000,#00e5ff,#00e5ff,#0000);width:100%;height:2px;animation:2s ease-in-out infinite scanH;position:absolute;left:0;box-shadow:0 0 15px 3px #00e5ff80}@keyframes scanH{0%{top:0}50%{top:100%}to{top:0}}.scan-line-v{pointer-events:none;background:linear-gradient(#0000,#00e5ff,#00e5ff,#0000);width:2px;height:100%;animation:2.6s ease-in-out infinite scanV;position:absolute;top:0;box-shadow:0 0 15px 3px #00e5ff80}@keyframes scanV{0%{left:0}50%{left:100%}to{left:0}}.scan-corners{pointer-events:none;position:absolute;inset:0}.scan-corner{border:0 solid #00e5ff;width:24px;height:24px;position:absolute}.scan-corner.tl{border-top-left-radius:var(--radius-lg);border-top-width:3px;border-left-width:3px;top:0;left:0}.scan-corner.tr{border-top-right-radius:var(--radius-lg);border-top-width:3px;border-right-width:3px;top:0;right:0}.scan-corner.bl{border-bottom-left-radius:var(--radius-lg);border-bottom-width:3px;border-left-width:3px;bottom:0;left:0}.scan-corner.br{border-bottom-right-radius:var(--radius-lg);border-bottom-width:3px;border-right-width:3px;bottom:0;right:0}.scan-glow{border-radius:var(--radius-lg);pointer-events:none;border:1px solid #00e5ff4d;animation:1.5s ease-in-out infinite alternate scanGlow;position:absolute;inset:0;box-shadow:inset 0 0 30px #00e5ff1a,0 0 20px #00e5ff26}@keyframes scanGlow{0%{box-shadow:inset 0 0 30px #00e5ff0d,0 0 15px #00e5ff1a}to{box-shadow:inset 0 0 40px #00e5ff26,0 0 30px #00e5ff40}}.scan-label{color:#00e5ff;font-size:var(--font-size-lg);letter-spacing:2px;text-transform:uppercase;font-weight:600;animation:1.2s ease-in-out infinite alternate scanPulse}@keyframes scanPulse{0%{opacity:.6}to{opacity:1}}.legal-page{width:100%;max-width:680px}.legal-page section{margin-bottom:var(--space-lg)}.legal-page h2{font-size:var(--font-size-lg);margin-bottom:var(--space-sm);color:var(--color-text);font-weight:600}.legal-page p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm);line-height:1.7}.legal-page ul{padding-left:var(--space-lg);margin-bottom:var(--space-sm)}.legal-page li{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs);line-height:1.7}.legal-updated{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.auth-page{min-height:100vh;padding:var(--space-lg) var(--space-md);background:var(--color-surface);justify-content:center;align-items:center;display:flex}.auth-card{width:100%;max-width:400px}.auth-logo{justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);display:flex}.auth-logo-text{font-size:var(--font-size-xl);color:var(--color-text);font-weight:700}.auth-title{font-size:var(--font-size-2xl);text-align:center;margin-bottom:var(--space-xs);font-weight:700}.auth-subtitle{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-lg)}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-switch{text-align:center;margin-top:var(--space-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.legal-links{text-align:center;margin-top:var(--space-md);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.legal-links a{color:var(--color-text-secondary);text-underline-offset:2px;text-decoration:underline}.legal-links a:hover{color:var(--color-primary)}.legal-links-sep{margin:0 var(--space-sm)}.profile-toast{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-md);font-weight:500;animation:.3s ease-out toastSlideIn;display:flex}.profile-toast button{cursor:pointer;opacity:var(--opacity-hover);padding:0 var(--space-xs);color:inherit;background:0 0;border:none;font-size:18px}.profile-toast button:hover{opacity:1}.profile-toast-success{background:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.profile-toast-error{background:var(--color-danger-bg);color:var(--color-danger-text);border:1px solid var(--color-danger-border)}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.avatar-upload-area{cursor:pointer;border-radius:50%;margin:0 auto;position:relative;overflow:hidden}.avatar-upload-overlay{opacity:0;background:#0006;border-radius:50%;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.avatar-upload-area:hover .avatar-upload-overlay{opacity:1}.public-profile-header{text-align:center;padding:var(--space-xl) 0}.public-avatar{border-radius:var(--radius-full);object-fit:cover;width:96px;height:96px;margin:0 auto var(--space-md);display:block}.public-avatar-placeholder{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:96px;height:96px;font-size:var(--font-size-2xl);margin:0 auto var(--space-md);justify-content:center;align-items:center;font-weight:700;display:flex}.public-bio{color:var(--color-text-secondary);font-size:var(--font-size-sm);max-width:400px;margin:var(--space-sm) auto;line-height:1.5}.public-filter-bar{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.meal-grid{gap:var(--space-xs);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=480px){.meal-grid{gap:var(--space-xs);grid-template-columns:repeat(2,1fr)}}.meal-tile{aspect-ratio:1;cursor:pointer;background:var(--color-border);border-radius:var(--radius-md);position:relative;overflow:hidden}.meal-tile img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.meal-tile:hover img{transform:scale(1.05)}.meal-tile-overlay{padding:var(--space-md) var(--space-sm) var(--space-sm);color:#fff;font-size:var(--font-size-xs);border-radius:0 0 var(--radius-md) var(--radius-md);background:linear-gradient(#0000,#000000a6);position:absolute;bottom:0;left:0;right:0}.meal-tile-placeholder{justify-content:center;align-items:center;gap:var(--space-xs);width:100%;height:100%;padding:var(--space-sm);text-align:center;background:linear-gradient(135deg, var(--color-bg), var(--color-surface));flex-direction:column;display:flex}.meal-tile-name{font-weight:600;font-size:var(--font-size-sm)}.meal-tile-cals,.meal-tile-stats{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.meal-tile-engagement{top:var(--space-xs);right:var(--space-xs);gap:var(--space-xs);color:#fff;text-shadow:0 1px 3px #00000080;font-size:11px;display:flex;position:absolute}.day-group{margin-bottom:var(--space-lg)}.day-group-header{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:3px;font-weight:600;display:flex}.like-btn{cursor:pointer;padding:var(--space-xs);background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:24px;transition:transform .2s;display:flex}.like-btn:hover{transform:scale(1.2)}.like-btn:disabled{opacity:.5;cursor:default;transform:none}.comment-list{max-height:300px;margin:var(--space-sm) 0;overflow-y:auto}.comment-item{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);line-height:1.5}.comment-item:last-child{border-bottom:none}.comment-author{margin-right:var(--space-xs);font-weight:600}.comment-body{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.comment-like-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;padding:2px;transition:color .15s}.comment-like-btn:hover,.comment-like-btn.liked{color:var(--color-like)}.comment-like-btn:disabled{opacity:.4;cursor:default}.comment-meta{gap:var(--space-sm);align-items:center;display:flex}.comment-time{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.comment-likes{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:600}.mention-link{color:var(--color-primary);font-weight:600;text-decoration:none}.mention-link:hover{text-decoration:underline}.comment-input-row{margin-top:var(--space-sm);background:var(--color-bg);border-radius:var(--radius-full);border:1px solid var(--color-border);padding:4px 4px 4px var(--space-md);align-items:center;gap:0;transition:border-color .2s,box-shadow .2s;display:flex}.comment-input-row:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #22c55e1a}.comment-input-row input{padding:var(--space-sm) 0;font-size:var(--font-size-input);background:0 0;border:none;outline:none;flex:1;min-height:36px}.comment-input-row button{min-height:36px;border-radius:var(--radius-full)!important;padding:0 var(--space-md)!important;font-size:var(--font-size-sm)!important}.toggle-switch{flex-shrink:0;width:48px;height:28px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";width:22px;height:22px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.form-group textarea{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-input);font-family:var(--font-sans);-webkit-appearance:none;outline:none;min-height:80px;transition:border-color .2s}.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #22c55e1a}.explore-results{flex-direction:column;display:flex}.explore-result-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text);text-decoration:none;transition:background .15s;display:flex}.explore-result-item:hover{background:var(--color-bg);text-decoration:none}.explore-result-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:48px;height:48px}.explore-result-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:48px;height:48px;font-weight:700;font-size:var(--font-size-lg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.explore-result-info{flex-direction:column;gap:2px;min-width:0;display:flex}.explore-result-name{font-weight:600;font-size:var(--font-size-base)}.explore-result-username{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.explore-result-bio{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.explore-users-grid{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=480px){.explore-users-grid{grid-template-columns:repeat(2,1fr)}}.explore-user-card{align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);text-align:center;flex-direction:column;text-decoration:none;transition:box-shadow .2s;display:flex}.explore-user-card:hover{box-shadow:var(--shadow-md);text-decoration:none}.explore-user-avatar{object-fit:cover;border-radius:50%;width:56px;height:56px}.explore-user-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:56px;height:56px;font-weight:700;font-size:var(--font-size-lg);border-radius:50%;justify-content:center;align-items:center;display:flex}.explore-user-name{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.explore-user-handle,.explore-user-stats{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.discover-search{margin-bottom:var(--space-md);position:relative}.discover-search-icon{left:var(--space-md);color:var(--color-text-secondary);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.discover-search input{width:100%;padding:var(--space-sm) var(--space-md) var(--space-sm) 44px;border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-input);background:var(--color-bg);outline:none;min-height:44px;transition:border-color .2s,box-shadow .2s}.discover-search input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #22c55e1a}.discover-chips{gap:var(--space-sm);padding-bottom:var(--space-md);scrollbar-width:none;-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.discover-chips::-webkit-scrollbar{display:none}.discover-chip{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);border:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;background:#fff;flex-shrink:0;min-height:36px;font-weight:500;transition:all .2s}.discover-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.discover-chip:hover:not(.active){border-color:var(--color-text-secondary)}.discover-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr);display:grid}@media (width>=600px){.discover-grid{grid-template-columns:repeat(3,1fr)}}.discover-card{cursor:pointer;border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);overflow:hidden}.discover-card-img-wrap{aspect-ratio:3/4;position:relative;overflow:hidden}.discover-card-img-wrap img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.discover-card:hover img{transform:scale(1.03)}.discover-card-overlay{padding:var(--space-lg) var(--space-sm) var(--space-sm);color:#fff;background:linear-gradient(#0000,#0009);justify-content:space-between;align-items:flex-end;display:flex;position:absolute;bottom:0;left:0;right:0}.discover-card-name{font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:600;overflow:hidden}.discover-card-kcal{font-size:var(--font-size-xs);border-radius:var(--radius-full);margin-left:var(--space-xs);background:#00000073;flex-shrink:0;padding:2px 8px;font-weight:600}.discover-card-more{top:var(--space-sm);right:var(--space-sm);color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000004d;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute}.discover-card-placeholder{aspect-ratio:3/4;justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:linear-gradient(135deg, var(--color-primary-bg), var(--color-primary-bg-alt));text-align:center;flex-direction:column;display:flex}.discover-card-placeholder .discover-card-name{color:var(--color-text);font-size:var(--font-size-base)}.discover-card-placeholder .discover-card-kcal{background:var(--color-primary);color:#fff}.explore-auth-banner{background:linear-gradient(135deg, var(--color-primary-bg), var(--color-primary-bg-alt));border:1px solid var(--color-primary-border-light);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;margin-bottom:var(--space-lg)}.explore-auth-banner p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.explore-auth-banner .action-btn{text-decoration:none}.scroll-sentinel{height:1px}.profile-tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg);display:flex}.profile-tab{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;font-weight:500;transition:all .2s;display:flex}.profile-tab.active{color:var(--color-text);border-bottom-color:var(--color-text)}.profile-tab:hover{color:var(--color-text)}.profile-stats{justify-content:center;gap:var(--space-lg);margin:var(--space-md) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex}.profile-stats strong{color:var(--color-text)}.profile-stat-btn{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);background:0 0;border:none;padding:0}.profile-stat-btn:hover,.profile-stat-btn strong{color:var(--color-text)}.follow-list-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);color:var(--color-text);text-decoration:none;display:flex}.follow-list-item:last-child{border-bottom:none}.follow-list-item:hover{text-decoration:none}.follow-list-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:44px;height:44px}.follow-list-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-weight:700;display:flex}.follow-list-info{flex-direction:column;gap:2px;display:flex}.follow-list-name{font-weight:600;font-size:var(--font-size-sm)}.follow-list-handle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.profile-actions-row{margin-top:var(--space-md);justify-content:center;gap:8px;display:flex}.action-icon-btn{border:1.5px solid var(--color-border);width:44px;height:32px;color:var(--color-text);cursor:pointer;background:0 0;border-radius:16px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:inline-flex}.action-icon-btn:hover{background:var(--color-bg)}.action-icon-btn svg{width:18px;height:18px}.action-icon-follow{border-color:var(--color-primary);color:var(--color-primary)}.action-icon-follow:hover{background:#22c55e0f}.action-icon-follow.following{background:#22c55e14}.action-icon-message{border-color:var(--color-border);color:var(--color-text)}.action-icon-message:hover{border-color:var(--color-text-secondary)}.action-icon-share{border-color:var(--color-border);color:var(--color-text)}.action-icon-share:hover{border-color:var(--color-text-secondary)}.action-icon-block{border-color:var(--color-danger);color:var(--color-danger)}.action-icon-block:hover{background:#ef44440f}.action-btn{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);cursor:pointer;min-height:38px;color:var(--color-text);border:none;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.action-btn-follow{background:var(--color-primary);color:#fff}.action-btn-follow:hover{background:var(--color-primary-dark)}.action-btn-follow.following{color:var(--color-primary);border:2px solid var(--color-primary);background:0 0}.action-btn-follow.following:hover{background:#22c55e0f}.action-btn-message{background:var(--color-border);color:var(--color-text)}.action-btn-message:hover{background:var(--color-border-hover)}.action-btn-share{color:var(--color-text);border:2px solid var(--color-border);background:0 0}.action-btn-share:hover{border-color:var(--color-text-secondary);background:var(--color-bg)}.action-btn-block{color:var(--color-danger);border:2px solid var(--color-danger);background:0 0}.action-btn-block:hover{background:#ef44440f}.action-btn-link{color:var(--color-success);border:2px solid var(--color-success);background:0 0}.action-btn-link:hover{background:#10b9810f}.follow-btn{background:var(--color-primary);color:#fff;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-weight:600}.follow-btn:hover{background:var(--color-primary-dark)}.follow-btn.following{color:var(--color-primary);border:2px solid var(--color-primary);background:0 0}.follow-btn.following:hover{background:#22c55e0f}.feed-page{max-width:560px;margin:0 auto}.top-bar{padding:var(--space-sm) 0;padding-top:var(--space-md);margin:0 calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md);z-index:var(--z-nav);background:var(--color-surface);justify-content:flex-end;align-items:center;display:flex;position:sticky;top:0}.top-bar:has(.top-bar-title){justify-content:space-between}.top-bar-title{font-size:var(--font-size-2xl);margin:0;font-weight:700}.top-bar-actions{align-items:center;gap:var(--space-xs);display:flex}.feed-top-bar{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.feed-logo{align-items:center;display:flex}.feed-tabs-row{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);gap:0;display:flex}.feed-tab{font-size:var(--font-size-base);color:var(--color-text-secondary);cursor:pointer;padding:var(--space-sm) var(--space-md);text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;font-weight:600;transition:all .2s}.feed-tab.active{color:var(--color-text);border-bottom-color:var(--color-text)}.feed-tab:hover,.feed-top-btn.active{color:var(--color-text)}.stories-row{gap:var(--space-md);padding:var(--space-sm) 0 var(--space-md);-webkit-overflow-scrolling:touch;scrollbar-width:none;display:flex;overflow-x:auto}.stories-row::-webkit-scrollbar{display:none}.story-item{align-items:center;gap:var(--space-xs);flex-direction:column;flex-shrink:0;text-decoration:none;display:flex}.story-avatar-ring{cursor:pointer;border-radius:50%;width:60px;height:60px;padding:3px;position:relative}.story-avatar-ring.unviewed{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark))}.story-avatar-ring.viewed{background:var(--color-border)}.story-avatar-ring.add{background:var(--color-bg)}.story-add-badge{background:var(--color-primary);color:#fff;border:2px solid var(--color-surface);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:14px;font-weight:700;display:flex;position:absolute;bottom:0;right:0}.story-ring{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:50%;width:60px;height:60px;padding:2px}.story-viewer-overlay{z-index:var(--z-modal);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.story-viewer{flex-direction:column;width:100%;max-width:420px;height:100%;max-height:100vh;display:flex;position:relative}.story-progress-row{padding:var(--space-sm) var(--space-sm) 0;z-index:2;gap:3px;display:flex;position:absolute;top:0;left:0;right:0}.story-progress-bar{background:#ffffff4d;border-radius:2px;flex:1;height:3px;overflow:hidden}.story-progress-fill{background:#fff;border-radius:2px;height:100%;transition:width .1s linear}.story-header{top:var(--space-lg);left:var(--space-sm);right:var(--space-sm);align-items:center;gap:var(--space-sm);z-index:2;display:flex;position:absolute}.story-header-avatar{object-fit:cover;border:2px solid #fff;border-radius:50%;width:32px;height:32px}.story-header-avatar-placeholder{background:var(--color-primary);color:#fff;width:32px;height:32px;font-size:var(--font-size-xs);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.story-header-name{color:#fff;font-weight:600;font-size:var(--font-size-sm);flex:1}.story-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:28px;line-height:1}.story-video{object-fit:contain;background:#000;width:100%;height:100%}.story-tap-left,.story-tap-right{z-index:1;cursor:pointer;width:40%;position:absolute;top:80px;bottom:0}.story-tap-left{left:0}.story-tap-right{right:0}.story-avatar{object-fit:cover;border:2px solid #fff;border-radius:50%;width:100%;height:100%}.story-avatar-placeholder{background:var(--color-bg);width:100%;height:100%;color:var(--color-text-secondary);font-weight:700;font-size:var(--font-size-sm);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;display:flex}.story-name{font-size:var(--font-size-2xs);color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;text-align:center;max-width:64px;overflow:hidden}.feed-top-actions{gap:var(--space-sm);display:flex}.feed-my-profile{align-items:center;text-decoration:none;display:flex}.feed-my-avatar{object-fit:cover;border:2px solid var(--color-primary);border-radius:50%;width:28px;height:28px}.feed-my-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border:2px solid var(--color-primary);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.feed-top-btn{color:var(--color-text);padding:var(--space-xs);justify-content:center;align-items:center;min-width:44px;min-height:44px;text-decoration:none;display:flex}.feed-section-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.feed-card{background:var(--color-surface);border-bottom:1px solid var(--color-border);border-radius:0;margin-bottom:0}@media (width>=480px){.feed-card{border-radius:var(--radius-xl);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm);border-bottom:none;overflow:hidden}}.feed-header{padding:var(--space-sm) 0;justify-content:space-between;align-items:center;display:flex}.feed-header-user{align-items:center;gap:var(--space-sm);color:var(--color-text);text-decoration:none;display:flex}.feed-avatar{object-fit:cover;border-radius:50%;width:36px;height:36px}.feed-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:36px;height:36px;font-weight:700;font-size:var(--font-size-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.feed-username{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text);display:block}.feed-date{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:block}.feed-time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.feed-photo-wrap{cursor:pointer;border-radius:var(--radius-lg);position:relative;overflow:hidden}.feed-photo{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.feed-calorie-badge{bottom:var(--space-md);right:var(--space-md);color:#fff;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000008c;font-weight:600;position:absolute}.feed-no-photo{background:linear-gradient(135deg, var(--color-primary-bg), var(--color-success-bg));padding:var(--space-2xl) var(--space-lg);text-align:center;cursor:pointer}.feed-no-photo-name{font-size:var(--font-size-lg);color:var(--color-text);margin-bottom:var(--space-sm);font-weight:600;display:block}.feed-calorie-badge-inline{background:var(--color-primary);color:#fff;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-weight:600}.feed-body{padding:var(--space-sm) 0 var(--space-md)}.feed-actions{margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.feed-actions-left{gap:var(--space-xs);display:flex}.feed-action-btn{cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-full);min-width:44px;min-height:44px;color:var(--color-text-secondary);background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.feed-action-btn:hover{background:var(--color-bg)}.feed-action-like{color:var(--color-text-secondary)}.feed-action-like:hover{color:var(--color-like);background:var(--color-danger-bg)}.feed-action-like.liked{color:var(--color-like)}.feed-action-comment{color:var(--color-text-secondary)}.feed-action-comment:hover{color:var(--color-accent-blue);background:var(--color-info-bg)}.feed-action-share{color:var(--color-text-secondary)}.feed-action-share:hover{color:var(--color-success);background:var(--color-success-bg)}.feed-likes{font-size:var(--font-size-sm);margin-bottom:var(--space-xs);font-weight:600}.feed-meal-name{font-size:var(--font-size-sm);margin-bottom:2px}.feed-macros{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.feed-caption-user{color:var(--color-text);font-weight:600;text-decoration:none}.feed-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs);line-height:1.5}.feed-tags{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.feed-tag{border-radius:var(--radius-full);background:var(--color-primary-bg);color:var(--color-primary-dark);border:1px solid var(--color-primary-border-light);padding:3px 10px;font-size:11px;font-weight:500}.feed-action-save{color:var(--color-text-secondary)}.feed-action-save:hover,.feed-action-save.saved{color:var(--color-text)}.feed-view-comments{color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;padding:0}.feed-view-comments:hover{color:var(--color-text)}.feed-suggestions-section{margin-bottom:var(--space-md)}.feed-suggestions{gap:var(--space-sm);padding-bottom:var(--space-sm);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.feed-suggestions::-webkit-scrollbar{display:none}.suggestion-card-mini{scroll-snap-align:start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-sm);text-align:center;align-items:center;gap:var(--space-xs);flex-direction:column;flex:0 0 140px;display:flex}.suggestion-card-mini a{color:var(--color-text);align-items:center;gap:var(--space-xs);flex-direction:column;text-decoration:none;display:flex}.suggestion-avatar{object-fit:cover;border-radius:50%;width:56px;height:56px}.suggestion-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:56px;height:56px;font-weight:700;font-size:var(--font-size-lg);border-radius:50%;justify-content:center;align-items:center;display:flex}.suggestion-name{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.suggestion-handle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.notif-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text);text-decoration:none;transition:background .15s;display:flex}.notif-item:hover{background:var(--color-bg);text-decoration:none}.notif-item.unread{background:var(--color-primary-bg)}.notif-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:44px;height:44px}.notif-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-weight:700;display:flex}.notif-content{flex:1;min-width:0}.notif-text{font-size:var(--font-size-sm);margin:0;line-height:1.4}.notif-time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.unread-badge{background:var(--color-danger);color:#fff;font-size:var(--font-size-2xs);border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-6px}.messages-page{flex-direction:column;max-width:560px;min-height:calc(100vh - 100px);margin:0 auto;display:flex}.inbox-list{flex-direction:column;display:flex}.inbox-item{align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text);text-decoration:none;transition:background .15s;display:flex}.inbox-item:hover{background:var(--color-bg);text-decoration:none}.inbox-unread{background:var(--color-primary-bg)}.inbox-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:48px;height:48px}.inbox-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:48px;height:48px;font-weight:700;font-size:var(--font-size-lg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.inbox-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.inbox-name{font-weight:600;font-size:var(--font-size-base)}.inbox-preview{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.inbox-meta{align-items:flex-end;gap:var(--space-xs);flex-direction:column;flex-shrink:0;display:flex}.inbox-time{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.chat-header{align-items:center;gap:var(--space-sm);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);display:flex}.chat-header-user{align-items:center;gap:var(--space-sm);color:var(--color-text);text-decoration:none;display:flex}.chat-header-avatar{object-fit:cover;border-radius:50%;width:36px;height:36px}.chat-header-avatar-placeholder{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;width:36px;height:36px;font-weight:700;font-size:var(--font-size-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.chat-header-name{font-weight:600}.chat-messages{justify-content:flex-end;gap:var(--space-sm);padding:var(--space-sm) 0;margin-bottom:var(--space-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-bubble{max-width:75%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);font-size:var(--font-size-sm);background:var(--color-bg);align-self:flex-start;line-height:1.4}.chat-bubble p{word-break:break-word;margin:0}.chat-bubble-mine{background:var(--color-primary);color:#fff;align-self:flex-end}.chat-bubble-time{font-size:var(--font-size-2xs);opacity:.6;margin-top:2px;display:block}.chat-input-bar{gap:var(--space-sm);background:var(--color-surface);padding:var(--space-sm) 0;margin-top:auto;display:flex}.chat-input-bar input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-input);outline:none;flex:1;min-height:44px}.chat-input-bar input:focus{border-color:var(--color-primary)}.public-profile-page{padding:var(--space-md)}
