.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid #e5e7eb;box-shadow:0 -2px 20px #00000012;height:var(--bottom-nav-h);padding-bottom:env(safe-area-inset-bottom,0px);padding-bottom:max(env(safe-area-inset-bottom,0px),0px);justify-content:space-around;align-items:center}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex:1;height:100%;padding:4px 2px;color:#9ca3af;font-size:10px;font-weight:600;letter-spacing:.2px;transition:color .15s;text-decoration:none;border-radius:0;-webkit-tap-highlight-color:transparent;position:relative}.bottom-nav-item svg{display:block;width:24px;height:24px;flex-shrink:0}.bottom-nav-item:hover,.bottom-nav-item.active{color:#22c55e}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;background:#22c55e;border-radius:0 0 4px 4px}.bottom-nav-item.active svg{stroke-width:2.5}@media (max-width: 900px){.bottom-nav{display:flex}}.nb-wrap{position:relative}.nb-bell{position:relative;width:34px;height:34px;border-radius:10px;background:var(--bg-alt);color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:var(--transition);border:1px solid var(--gray-light)}.nb-bell:hover{color:var(--primary);border-color:var(--primary)}.nb-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:9px;font-weight:800;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);line-height:1}.nb-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:420px;background:var(--white);border:1px solid var(--gray-light);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;z-index:999;animation:nbSlide .15s ease}@keyframes nbSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.nb-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--gray-light)}.nb-title{font-family:Poppins,sans-serif;font-size:14px;font-weight:700;color:var(--text)}.nb-mark-all{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--primary);cursor:pointer}.nb-mark-all:hover{color:var(--primary-dark)}.nb-list{overflow-y:auto;flex:1}.nb-empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:14px}.nb-item{display:flex;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--gray-light);transition:background .15s;position:relative}.nb-item:last-child{border-bottom:none}.nb-item:hover{background:var(--bg-alt)}.nb-item.unread{background:color-mix(in srgb,var(--primary-bg) 80%,transparent)}.nb-item.unread:hover{background:var(--primary-bg)}.nb-item-icon{font-size:20px;flex-shrink:0;margin-top:1px}.nb-item-body{flex:1;min-width:0}.nb-item-title{font-weight:700;font-size:13px;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nb-item-text{font-size:12px;color:var(--text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.nb-item-time{font-size:10px;color:var(--text-muted);margin-top:4px}.nb-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:4px}@media (max-width: 900px){.nb-dropdown{right:-80px;width:290px}}.landing{min-height:100vh;background:var(--white)}.landing-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-light)}.landing-logo{font-family:Poppins,sans-serif;font-size:20px;font-weight:800;color:var(--primary-dark)}.landing-nav-links{display:flex;gap:10px}.hero{text-align:center;padding:72px 24px 56px;background:linear-gradient(180deg,#f0fdf4 0%,var(--white) 100%)}.hero-badge{display:inline-block;padding:6px 16px;border-radius:30px;background:var(--primary-bg);color:var(--primary-dark);font-size:13px;font-weight:600;margin-bottom:20px;border:1px solid rgba(34,197,94,.3)}.hero-title{font-size:clamp(36px,6vw,64px);font-weight:800;color:var(--dark);line-height:1.1;margin-bottom:20px}.hero-sub{max-width:520px;margin:0 auto 32px;font-size:17px;color:var(--gray);line-height:1.7}.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}.hero-preview{max-width:420px;margin:0 auto}.chat-preview{background:var(--bg);border-radius:20px;padding:20px;border:1px solid var(--gray-light);box-shadow:var(--shadow-lg);text-align:left}.preview-msg{padding:10px 14px;border-radius:16px;font-size:14px;margin-bottom:8px;max-width:88%;line-height:1.5}.preview-msg.bot{background:var(--white);border:1px solid var(--gray-light)}.preview-msg.user{background:var(--primary);color:#fff;margin-left:auto}.preview-chips{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 10px}.preview-chips span{padding:6px 12px;border:1.5px solid var(--primary);border-radius:16px;font-size:12px;color:var(--primary-dark);font-weight:600}.features{padding:64px 24px;max-width:960px;margin:0 auto}.section-title{font-size:clamp(22px,4vw,32px);text-align:center;margin-bottom:40px;color:var(--dark)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.feature-card{padding:24px;transition:var(--transition)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-icon{width:48px;height:48px;border-radius:12px;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.feature-card h3{font-size:16px;font-weight:700;margin-bottom:8px;color:var(--dark)}.feature-card p{font-size:14px;color:var(--gray);line-height:1.6}.landing-cta{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;text-align:center;padding:64px 24px;margin:0}.landing-cta h2{font-size:32px;margin-bottom:12px}.landing-cta p{font-size:16px;opacity:.9;margin-bottom:28px}.landing-cta .btn-primary{background:#fff;color:var(--primary-dark);border-color:#fff}.landing-cta .btn-primary:hover{background:var(--primary-bg)}.landing-footer{padding:24px;text-align:center;color:var(--gray);font-size:13px;border-top:1px solid var(--gray-light)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7,#f9fafb)}.auth-card{background:var(--white);border-radius:20px;box-shadow:var(--shadow-lg);padding:40px 36px;width:100%;max-width:420px}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 12px;box-shadow:0 6px 20px #22c55e59}.auth-logo h1{font-size:24px;color:var(--dark);margin-bottom:4px}.auth-logo p{font-size:14px;color:var(--gray)}.auth-title{font-size:20px;font-weight:700;color:var(--dark);margin-bottom:4px}.auth-subtitle{font-size:14px;color:var(--gray);margin-bottom:28px}.auth-footer{text-align:center;margin-top:20px;font-size:14px;color:var(--gray)}.auth-footer a{color:var(--primary);font-weight:600}.otp-grid{display:flex;gap:10px;justify-content:center;margin:20px 0}.otp-input{width:50px;height:58px;text-align:center;font-size:24px;font-weight:700;border:2px solid var(--gray-light);border-radius:10px;transition:var(--transition)}.otp-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #22c55e1f}.auth-error-banner{display:flex;align-items:center;gap:10px;background:#fef2f2;border:1.5px solid #fca5a5;border-radius:10px;padding:11px 14px;font-size:13px;font-weight:500;color:#b91c1c;margin-top:12px;animation:fadeInDown .2s ease}.auth-error-icon{font-size:16px;flex-shrink:0}.input-error{border-color:#f87171!important;background:#fff8f8!important}.input-error:focus{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef44441f!important}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(6px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}90%{transform:translate(2px)}}.auth-shake{animation:shake .55s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.auth-card{padding:28px 20px}.otp-input{width:42px;height:50px;font-size:20px}}.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7 50%,#f9fafb)}.setup-card{width:100%;max-width:480px;padding:0 0 28px;border-radius:20px;overflow:hidden}.setup-progress-bar{height:5px;background:var(--gray-light)}.setup-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));transition:width .4s ease}.setup-step-label{font-size:12px;color:var(--text-muted);padding:10px 28px 0;font-weight:600}.setup-step{padding:12px 28px 0}.setup-emoji{font-size:40px;margin-bottom:10px}.setup-step h2{font-size:22px;font-weight:700;color:var(--dark);margin-bottom:6px}.setup-sub{font-size:14px;color:var(--gray);line-height:1.5;margin-bottom:20px}.gender-toggle{display:flex;gap:10px}.gender-btn{flex:1;padding:12px;border-radius:10px;border:2px solid var(--gray-light);font-size:14px;font-weight:600;color:var(--gray);transition:var(--transition);cursor:pointer;background:var(--white)}.gender-btn.active{border-color:var(--primary);color:var(--primary-dark);background:var(--primary-bg)}.option-card{padding:14px 16px;border-radius:10px;border:2px solid var(--gray-light);margin-bottom:10px;cursor:pointer;transition:var(--transition);background:var(--white)}.option-card:hover{border-color:var(--primary-light)}.option-card.active{border-color:var(--primary);background:var(--primary-bg)}.option-label{font-weight:700;font-size:15px;color:var(--dark);margin-bottom:2px}.option-desc{font-size:13px;color:var(--gray)}.coach-tip{display:flex;gap:10px;align-items:flex-start;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 14px;font-size:13px;color:#92400e;margin-top:8px}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.summary-box{background:var(--bg-alt);border-radius:10px;padding:16px;text-align:center}.summary-num{font-size:28px;font-weight:800;font-family:Poppins,sans-serif}.summary-lbl{font-size:12px;color:var(--gray);margin-top:2px}.summary-bmi{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--dark)}.setup-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 28px 0;margin-top:16px}.setup-nav .btn:only-child{margin-left:auto}.role-cards{display:flex;gap:12px;margin-bottom:8px}.role-card{flex:1;padding:18px 14px;border-radius:12px;border:2px solid var(--gray-light);background:#fff;cursor:pointer;text-align:center;transition:var(--transition)}.role-card:hover{border-color:var(--primary-light)}.role-card.active{border-color:var(--primary);background:var(--primary-bg)}.role-icon{font-size:32px;display:block;margin-bottom:8px}.role-label{font-weight:700;font-size:15px;color:var(--dark);margin-bottom:4px}.role-desc{font-size:12px;color:var(--gray);line-height:1.4}.coach-summary-list{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:20px;margin:16px 0;display:flex;flex-direction:column;gap:10px}.coach-sum-item{font-size:14px;color:#15803d;font-weight:500}@media (max-width: 380px){.role-cards{flex-direction:column}}.chat-bubble-wrap{display:flex;align-items:flex-end;gap:8px;margin-bottom:12px;animation:bubble-in .2s ease}.chat-bubble-wrap.bot{justify-content:flex-start}.chat-bubble-wrap.user{justify-content:flex-end}@keyframes bubble-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bot-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 8px #22c55e4d}.bubble{max-width:75%;padding:11px 15px;border-radius:18px;font-size:14.5px;line-height:1.6;word-break:break-word}.bubble-bot{background:var(--white);border:1px solid var(--gray-light);border-bottom-left-radius:4px;color:var(--dark);box-shadow:var(--shadow)}.bubble-user{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-bottom-right-radius:4px}@media (max-width: 600px){.bubble{max-width:85%;font-size:14px}}.quick-replies{display:flex;flex-wrap:wrap;gap:8px;padding:8px 16px 12px}.qr-chip{padding:8px 16px;background:var(--white);border:1.5px solid var(--primary);border-radius:20px;color:var(--primary-dark);font-size:13.5px;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}.qr-chip:hover:not(:disabled){background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.qr-chip:disabled{opacity:.5;cursor:not-allowed}.chat-page{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg)}.chat-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--white);border-bottom:1px solid var(--gray-light);box-shadow:var(--shadow)}.chat-header-info{display:flex;align-items:center;gap:12px}.chat-bot-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 2px 8px #22c55e4d}.chat-bot-name{font-weight:700;font-size:15px;color:var(--dark)}.chat-bot-status{font-size:12px;color:var(--gray)}.chat-header-actions{display:flex;gap:6px}.icon-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--gray);transition:var(--transition);cursor:pointer}.icon-btn:hover{background:var(--bg-alt);color:var(--dark)}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;scroll-behavior:smooth}.typing-indicator{display:flex;align-items:center;gap:4px;padding:12px 16px!important}.typing-indicator span{width:7px;height:7px;border-radius:50%;background:var(--primary);opacity:.6;animation:typing-bounce 1.2s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.chat-input-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--white);border-top:1px solid var(--gray-light)}@media (max-width: 768px){.chat-input-bar{padding-bottom:calc(10px + var(--bottom-nav-h))}}.chat-input{flex:1;padding:11px 16px;border:1.5px solid var(--gray-light);border-radius:24px;font-size:15px;background:var(--bg);transition:var(--transition)}.chat-input:focus{outline:none;border-color:var(--primary)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn{width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0;cursor:pointer}.chat-send-btn:hover:not(:disabled){background:var(--primary-dark);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.water-card{padding:18px 20px;margin-bottom:16px}.water-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.water-title{font-size:15px;font-weight:700;color:var(--text-primary)}.water-count{font-size:13px;font-weight:600;color:#0ea5e9}.water-glasses{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.water-glass{width:36px;height:36px;border-radius:8px;border:2px solid #e0f2fe;background:#f0f9ff;font-size:18px;cursor:pointer;transition:transform .15s,background .2s;display:flex;align-items:center;justify-content:center;padding:0;filter:grayscale(1) opacity(.35)}.water-glass.filled{background:#e0f2fe;border-color:#0ea5e9;filter:none;transform:scale(1.05)}.water-glass:hover{filter:none;transform:scale(1.1)}.water-bar-wrap{display:flex;align-items:center;gap:10px;margin-bottom:12px}.water-bar{flex:1;height:8px;background:#e0f2fe;border-radius:99px;overflow:hidden}.water-bar-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#0ea5e9);border-radius:99px;transition:width .4s ease}.water-pct{font-size:12px;font-weight:600;color:#0ea5e9;min-width:32px;text-align:right}.water-actions{display:flex;gap:8px}.water-add-btn{background:linear-gradient(135deg,#38bdf8,#0ea5e9)!important;border-color:transparent!important}.streak-badge{display:inline-flex;align-items:center;gap:8px;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:12px;padding:8px 14px;transition:transform .2s}.streak-badge.streak-hot{background:linear-gradient(135deg,#fff7ed,#fef3c7);border-color:#f97316;animation:pulse-streak 2s ease-in-out infinite}@keyframes pulse-streak{0%,to{box-shadow:0 0 #f9731633}50%{box-shadow:0 0 0 6px #f9731600}}.streak-emoji{font-size:24px;line-height:1}.streak-info{display:flex;flex-direction:column;line-height:1.2}.streak-days{font-size:15px;font-weight:800;color:#c2410c}.streak-label{font-size:11px;color:#9a3412;text-transform:uppercase;letter-spacing:.5px}.ms-wrap{background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-light);box-shadow:var(--shadow);padding:16px 20px 18px;margin-bottom:16px}.ms-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.ms-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ms-title{font-family:Poppins,sans-serif;font-size:15px;font-weight:700;color:var(--text)}.ms-label{font-size:12px;font-weight:600;color:var(--primary);background:var(--primary-bg);padding:2px 10px;border-radius:20px}.ms-refresh{width:30px;height:30px;border-radius:50%;background:var(--bg-alt);border:1px solid var(--gray-light);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);flex-shrink:0}.ms-refresh:hover{color:var(--primary);border-color:var(--primary)}.ms-refresh.spinning svg{animation:msSpin .7s linear infinite}@keyframes msSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ms-message{font-size:13px;color:var(--text-muted);margin-bottom:14px;line-height:1.4}.ms-done{background:var(--primary-bg);border:1px solid rgba(34,197,94,.25);border-radius:12px;padding:14px 16px;font-size:14px;font-weight:600;color:var(--primary-dark);text-align:center}.ms-grid{display:flex;flex-direction:column;gap:10px}.ms-card{background:var(--bg);border:1.5px solid var(--gray-light);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;transition:var(--transition)}.ms-card:hover{border-color:var(--primary);box-shadow:0 2px 12px #22c55e1a}.ms-card.ms-card-logged{border-color:var(--primary);background:var(--primary-bg);opacity:.85}.ms-card-top{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.ms-emoji{font-size:26px;flex-shrink:0;line-height:1;margin-top:1px}.ms-card-body{flex:1;min-width:0}.ms-food-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ms-macros{display:flex;gap:8px;flex-wrap:wrap;font-size:11.5px;font-weight:600;margin-bottom:6px}.ms-kcal{color:#f97316}.ms-p{color:#3b82f6}.ms-c{color:#f59e0b}.ms-f{color:#8b5cf6}.ms-reasons{display:flex;gap:5px;flex-wrap:wrap}.ms-reason-tag{font-size:10px;font-weight:600;background:var(--white);border:1px solid var(--gray-light);border-radius:20px;padding:2px 7px;color:var(--text-muted);white-space:nowrap}[data-theme=dark] .ms-reason-tag{background:var(--bg-alt)}.ms-log-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:10px;font-size:12px;font-weight:700;background:var(--primary);color:#fff;border:none;cursor:pointer;flex-shrink:0;transition:var(--transition);white-space:nowrap}.ms-log-btn:hover{background:var(--primary-dark);transform:scale(1.03)}.ms-log-btn.logged{background:var(--bg-alt);color:var(--primary);border:1.5px solid var(--primary);cursor:default;transform:none}.ms-all-logged{margin-top:12px;padding:10px 14px;background:var(--primary-bg);border-radius:10px;font-size:13px;font-weight:600;color:var(--primary-dark);text-align:center}.ms-more-btn{background:none;border:none;color:var(--primary);font-weight:700;font-size:13px;cursor:pointer;text-decoration:underline;padding:0}[data-theme=dark] .ms-card{background:var(--bg-alt)}[data-theme=dark] .ms-card.ms-card-logged{background:#22c55e14}[data-theme=dark] .ms-log-btn.logged{background:transparent}@media (max-width: 480px){.ms-wrap{padding:14px 14px 16px}.ms-food-name{font-size:13px}.ms-emoji{font-size:22px}.ms-log-btn{padding:6px 10px;font-size:11px}.ms-macros{gap:6px;font-size:11px}}.dashboard-greeting{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}.dashboard-greeting h1{font-size:22px;margin-bottom:4px}.greeting-sub{font-size:14px;color:var(--gray)}.dashboard-top{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.dash-ring-card{padding:20px}.dash-side{display:flex;flex-direction:column;gap:12px}.dash-section-title{font-size:14px;font-weight:700;color:var(--dark);margin-bottom:12px}.calorie-row{display:flex;justify-content:center;gap:20px;margin-top:12px}.calorie-chip{text-align:center;font-size:20px;font-weight:800;font-family:Poppins,sans-serif}.calorie-chip span{display:block;font-size:11px;font-weight:500;color:var(--gray);font-family:Inter,sans-serif}.calorie-chip.consumed{color:var(--primary-dark)}.calorie-chip.remaining{color:var(--gray)}.dash-macros{padding:20px;margin-bottom:16px}.macro-row{margin-bottom:14px}.macro-row:last-child{margin-bottom:0}.macro-info{display:flex;justify-content:space-between;margin-bottom:5px}.macro-name{font-size:13px;font-weight:600;color:var(--dark)}.macro-vals{font-size:13px;color:var(--gray)}.dash-trend{padding:20px;margin-bottom:16px}.quick-action-card{padding:20px;display:flex;align-items:center;gap:14px;font-size:15px;font-weight:700;color:var(--dark);transition:var(--transition);text-decoration:none}.quick-action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.qa-icon{font-size:28px}@media (max-width: 600px){.dashboard-top{grid-template-columns:1fr}.dash-side{flex-direction:row}.dash-side .stat-card{flex:1}}.barcode-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:2000;display:flex;align-items:flex-end;justify-content:center}.barcode-modal{background:var(--surface, #fff);border-radius:20px 20px 0 0;width:100%;max-width:480px;padding-bottom:env(safe-area-inset-bottom,16px);animation:slideUp .25s ease}.barcode-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border, #e5e7eb)}.barcode-header h3{margin:0;font-size:17px;font-weight:700}.barcode-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:4px 8px}.barcode-viewfinder{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:#000}.barcode-video{width:100%;height:100%;object-fit:cover}.barcode-frame{position:absolute;top:20%;right:20%;bottom:20%;left:20%;pointer-events:none}.barcode-corner{position:absolute;width:24px;height:24px;border-color:#22c55e;border-style:solid}.barcode-corner.tl{top:0;left:0;border-width:3px 0 0 3px}.barcode-corner.tr{top:0;right:0;border-width:3px 3px 0 0}.barcode-corner.bl{bottom:0;left:0;border-width:0 0 3px 3px}.barcode-corner.br{bottom:0;right:0;border-width:0 3px 3px 0}.barcode-scan-line{position:absolute;top:50%;left:0;right:0;height:2px;background:#22c55e;animation:scan 1.8s ease-in-out infinite;box-shadow:0 0 8px #22c55e}@keyframes scan{0%,to{top:10%}50%{top:90%}}.barcode-hint{text-align:center;font-size:13px;color:var(--text-muted);padding:14px 20px;margin:0}.barcode-error,.barcode-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.foodlog-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.foodlog-header h1{font-size:22px}.calorie-summary{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;margin-bottom:12px;text-align:center}.cal-item{flex:1}.cal-val{font-size:26px;font-weight:800;font-family:Poppins,sans-serif;color:var(--dark)}.cal-lbl{font-size:12px;color:var(--gray);margin-top:2px}.cal-divider{font-size:20px;color:var(--gray-light);font-weight:300}.macro-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.macro-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600}.macro-chip.protein{background:#3b82f61a;color:var(--accent)}.macro-chip.carbs{background:#f59e0b1a;color:#92400e}.macro-chip.fat{background:#ef44441a;color:var(--danger)}.meal-section{margin-bottom:20px}.meal-title{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:700;color:var(--dark);margin-bottom:8px;padding:0 2px}.meal-cal{font-size:13px;color:var(--gray);font-weight:500}.meal-empty{font-size:13px;color:var(--text-muted);padding:10px 14px;background:var(--bg-alt);border-radius:8px}.food-entry{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;margin-bottom:8px}.food-entry-info{flex:1;min-width:0}.food-entry-name{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.food-entry-meta{font-size:12px;color:var(--gray)}.food-entry-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.food-kcal{font-size:14px;font-weight:700;color:var(--primary-dark)}.rt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rt-card{background:var(--white);border-radius:24px;padding:24px;width:100%;max-width:320px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;gap:20px}.rt-header{display:flex;align-items:center;justify-content:space-between}.rt-title{font-family:Poppins,sans-serif;font-size:16px;font-weight:700;color:var(--text)}.rt-close{width:32px;height:32px;border-radius:50%;background:var(--bg-alt);color:var(--gray);display:flex;align-items:center;justify-content:center;transition:var(--transition)}.rt-close:hover{background:var(--gray-light);color:var(--text)}.rt-presets{display:flex;gap:8px}.rt-preset{flex:1;padding:8px 4px;border:2px solid var(--gray-light);border-radius:10px;background:var(--bg);font-size:13px;font-weight:600;color:var(--text-muted);transition:var(--transition)}.rt-preset:hover{border-color:#6366f1;color:#6366f1}.rt-preset.active{border-color:#6366f1;background:#eef2ff;color:#4338ca}[data-theme=dark] .rt-preset{background:var(--bg-alt)}[data-theme=dark] .rt-preset.active{background:#1e1b4b;color:#a5b4fc}.rt-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;margin:0 auto}.rt-ring-wrap svg{display:block}.rt-time{position:absolute;font-family:Poppins,sans-serif;font-size:28px;font-weight:800;color:var(--text);letter-spacing:-1px}.rt-done-msg{text-align:center;font-size:14px;font-weight:600;color:#22c55e;background:#f0fdf4;border-radius:10px;padding:10px}[data-theme=dark] .rt-done-msg{background:#052e16}.rt-controls{display:flex;gap:12px;align-items:center;justify-content:center}.rt-btn{display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition);font-weight:600}.rt-btn.secondary{width:44px;height:44px;background:var(--bg-alt);color:var(--gray);border:2px solid var(--gray-light)}.rt-btn.secondary:hover{background:var(--gray-light);color:var(--text)}.rt-btn.primary{width:60px;height:60px;background:#6366f1;color:#fff;box-shadow:0 4px 14px #6366f159;font-size:20px}.rt-btn.primary:hover{background:#4f46e5;transform:scale(1.05)}.rt-btn.primary.disabled{background:var(--gray-light);color:var(--gray);box-shadow:none}[data-theme=dark] .rt-btn.secondary{background:var(--bg-alt);border-color:#334155}.wl-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.wl-header h1{font-size:22px}.wl-tabs{display:flex;gap:0;background:var(--bg-alt);border-radius:10px;padding:4px;margin-bottom:16px}.wl-tab{flex:1;padding:9px;border-radius:7px;font-size:14px;font-weight:600;color:var(--gray);transition:var(--transition);cursor:pointer}.wl-tab.active{background:var(--white);color:var(--primary-dark);box-shadow:var(--shadow)}.session-card{padding:16px;margin-bottom:14px}.session-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.session-name{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:3px}.session-time{font-size:12px;color:var(--gray)}.exercise-list{display:flex;flex-direction:column;gap:8px}.exercise-row{display:flex;align-items:flex-start;gap:10px;background:var(--bg-alt);border-radius:8px;padding:10px 12px}.ex-emoji{font-size:18px;flex-shrink:0}.ex-info{display:flex;flex-direction:column;gap:2px}.ex-name{font-size:13px;font-weight:700;color:var(--dark)}.ex-detail{font-size:12px;color:var(--gray)}.date-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;margin-bottom:14px}.date-nav-btn{width:36px;height:36px;border-radius:8px;font-size:20px;font-weight:700;color:var(--gray);transition:var(--transition);cursor:pointer;display:flex;align-items:center;justify-content:center}.date-nav-btn:hover:not(:disabled){background:var(--bg-alt);color:var(--dark)}.date-nav-btn:disabled{opacity:.3;cursor:not-allowed}.date-nav-label{text-align:center}.date-main{font-size:16px;font-weight:700;color:var(--dark)}.date-sub{font-size:12px;color:var(--gray)}.del-btn{color:var(--gray);padding:4px;border-radius:6px;transition:var(--transition);cursor:pointer}.del-btn:hover{color:var(--danger);background:#ef444414}.achievements-wrap{margin-top:16px}.achievements-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}.achievements-title{font-size:14px;font-weight:700;margin:0 0 2px;color:var(--text, #111827)}.achievements-sub{font-size:12px;color:var(--text-muted, #6b7280);margin:0}.achievements-progress-pill{position:relative;flex-shrink:0;width:80px;height:20px;background:var(--border, #e5e7eb);border-radius:99px;overflow:hidden}.achievements-progress-fill{position:absolute;top:0;right:0;bottom:0;left:0;height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:99px;transition:width .6s ease}.achievements-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;mix-blend-mode:difference}.achievements-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (min-width: 480px){.achievements-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 768px){.achievements-grid{grid-template-columns:repeat(6,1fr)}}.achievement-card{border-radius:14px;padding:12px 8px;text-align:center;border:1.5px solid var(--border, #e5e7eb);background:var(--surface, #fff);position:relative;transition:transform .15s,box-shadow .15s;cursor:default}.achievement-card.earned{border-color:#22c55e;background:#22c55e0f;box-shadow:0 2px 10px #22c55e1f}.achievement-card.earned:hover{transform:translateY(-2px);box-shadow:0 6px 18px #22c55e33}.achievement-card.locked{opacity:.5;filter:grayscale(.4)}.achievement-emoji{font-size:28px;margin-bottom:6px;line-height:1}.achievement-title{font-size:11px;font-weight:700;color:var(--text, #111827);margin-bottom:3px;line-height:1.2}.achievement-desc{font-size:9px;color:var(--text-muted, #6b7280);line-height:1.3}.achievement-earned-tag{position:absolute;top:6px;right:6px;background:#22c55e;color:#fff;font-size:8px;font-weight:700;border-radius:99px;padding:2px 5px;letter-spacing:.3px;text-transform:uppercase}.profile-section{padding:20px;margin-bottom:16px}.profile-section-title{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--gray-light)}.profile-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile-tool-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1.5px solid var(--gray-light);border-radius:12px;background:var(--bg);text-decoration:none;transition:var(--transition);cursor:pointer}.profile-tool-card:hover{border-color:var(--primary);background:var(--primary-bg)}.profile-tool-emoji{font-size:22px;flex-shrink:0}.profile-tool-title{font-size:13px;font-weight:700;color:var(--text);line-height:1.2}.profile-tool-desc{font-size:11px;color:var(--text-muted);margin-top:2px}@media (max-width: 480px){.profile-tools-grid{grid-template-columns:1fr}}.bmi-display{font-size:14px;color:var(--gray);margin-top:8px;display:flex;align-items:center}.calorie-preview{background:var(--primary-bg);border:1px solid rgba(34,197,94,.2);border-radius:10px;padding:14px 16px;margin-top:16px}.preview-row{display:flex;gap:16px;flex-wrap:wrap;font-size:14px;margin-bottom:6px}.preview-row:last-child{margin-bottom:0}.preview-row.muted{color:var(--gray);font-size:13px}.delete-confirm{padding:16px;margin-top:16px;border:2px solid var(--danger);background:#fef2f2;font-size:14px;color:var(--dark)}.delete-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.delete-modal{width:100%;max-width:420px;padding:32px 28px;border-radius:20px;text-align:center;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.delete-modal-icon{font-size:44px;margin-bottom:12px}.delete-modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.delete-modal-sub{font-size:14px;color:var(--text-muted);line-height:1.6;margin:0 0 12px}.delete-modal-actions{display:flex;gap:10px;justify-content:center;margin-top:20px}.delete-modal-actions .btn{flex:1}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.edm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:edm-fade-in .2s ease}@keyframes edm-fade-in{0%{opacity:0}to{opacity:1}}.edm-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;animation:edm-slide-up .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes edm-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.edm-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.edm-header-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.edm-cat-icon{font-size:28px;flex-shrink:0;line-height:1;margin-top:2px}.edm-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.2}.edm-badges{display:flex;gap:6px;flex-wrap:wrap}.edm-diff{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:capitalize}.edm-diff.green{background:#dcfce7;color:#15803d}.edm-diff.orange{background:#ffedd5;color:#c2410c}.edm-diff.red{background:#fee2e2;color:#b91c1c}.edm-tag{font-size:11px;padding:3px 8px;border-radius:6px;background:#f3f4f6;color:var(--text-secondary);text-transform:capitalize}.edm-close{background:#f3f4f6;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);flex-shrink:0;transition:background .2s}.edm-close:hover{background:#e5e7eb;color:var(--text-primary)}.edm-body{overflow-y:auto;padding:20px;flex:1}.edm-stats-row{display:flex;gap:12px;margin-bottom:20px}.edm-stat{flex:1;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:12px;text-align:center}.edm-stat-label{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.edm-stat-value{display:block;font-size:18px;font-weight:700;color:var(--primary-dark)}.edm-section{margin-bottom:24px}.edm-section-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 14px;text-transform:uppercase;letter-spacing:.5px}.edm-section-title svg{color:var(--primary)}.edm-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.edm-step{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#f9fafb;border-radius:10px;border-left:3px solid var(--primary)}.edm-step-num{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.edm-step-text{font-size:14px;color:var(--text-secondary);line-height:1.5}.edm-tips{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.edm-tip{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:#fffbeb;border-radius:8px;border-left:3px solid #f59e0b;font-size:14px;color:var(--text-secondary);line-height:1.5}.edm-tip-dot{width:6px;height:6px;border-radius:50%;background:#f59e0b;flex-shrink:0;margin-top:5px}@media (min-width: 680px){.edm-overlay{align-items:center}.edm-sheet{border-radius:20px;max-height:85vh;margin:20px;animation:edm-pop-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes edm-pop-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}}.el-page{min-height:100vh;background:var(--bg);padding-top:var(--nav-height);padding-bottom:calc(var(--bottom-nav-h) + 20px)}.el-hero{background:linear-gradient(135deg,#0f172a,#1e293b 60%,#0f3460);padding:28px 20px 32px;position:relative;overflow:hidden}.el-hero:before{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(99,102,241,.25) 0%,transparent 70%);border-radius:50%}.el-hero:after{content:"";position:absolute;bottom:-30px;left:10%;width:160px;height:160px;background:radial-gradient(circle,rgba(34,197,94,.2) 0%,transparent 70%);border-radius:50%}.el-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}.el-hero-text h1{font-size:26px;font-weight:800;color:#fff;margin:0 0 4px}.el-hero-text p{font-size:13px;color:#ffffff8c;margin:0 0 20px}.el-hero-search{display:flex;align-items:center;gap:10px;background:#ffffff1a;border:1.5px solid rgba(255,255,255,.15);border-radius:14px;padding:0 16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .2s}.el-hero-search:focus-within{border-color:#6366f1b3;background:#ffffff21}.el-hero-search-icon{color:#ffffff80;flex-shrink:0}.el-hero-search-input{flex:1;background:none;border:none;outline:none;font-size:15px;color:#fff;padding:14px 0;font-family:inherit}.el-hero-search-input::placeholder{color:#fff6}.el-hero-clear{background:none;border:none;color:#ffffff80;cursor:pointer;display:flex;align-items:center;padding:2px;border-radius:50%;transition:color .15s}.el-hero-clear:hover{color:#fff}.el-body{max-width:900px;margin:0 auto;padding:20px 16px 0}.el-tabs-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:14px}.el-tabs-scroll::-webkit-scrollbar{display:none}.el-tabs{display:flex;gap:8px;width:max-content}.el-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 16px;border:1.5px solid var(--gray-light);border-radius:12px;background:#fff;font-size:12px;font-weight:600;color:var(--gray);cursor:pointer;white-space:nowrap;transition:all .18s}.el-tab-emoji{font-size:20px;line-height:1}.el-tab:hover{border-color:#6366f1;color:#6366f1;background:#f0f0ff}.el-tab.active{background:#1e1b4b;border-color:#1e1b4b;color:#fff;box-shadow:0 4px 12px #6366f14d}.el-diff-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}.el-diff-pill{padding:5px 14px;border-radius:20px;border:1.5px solid var(--gray-light);background:#fff;font-size:12px;font-weight:600;color:var(--gray);cursor:pointer;transition:all .15s;text-transform:capitalize}.el-diff-pill:hover{border-color:#9ca3af}.el-diff-pill.active-green{background:#dcfce7;border-color:#22c55e;color:#15803d}.el-diff-pill.active-orange{background:#ffedd5;border-color:#f97316;color:#c2410c}.el-diff-pill.active-red{background:#fee2e2;border-color:#ef4444;color:#b91c1c}.el-diff-pill.clear{background:#f3f4f6;color:var(--gray);display:flex;align-items:center;gap:4px}.el-diff-pill.clear:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.el-count-pill{margin-left:auto;font-size:12px;font-weight:700;color:var(--text-muted);background:#fff;border:1.5px solid var(--gray-light);padding:4px 12px;border-radius:20px}.el-loading{display:flex;justify-content:center;padding:60px 0}.el-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.el-empty h3{color:var(--text);margin:12px 0 6px}.el-empty p{margin-bottom:20px}.el-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px;margin-bottom:24px}.el-card{background:#fff;border:1.5px solid var(--gray-light);border-radius:16px;padding:0;text-align:left;cursor:pointer;transition:all .2s;width:100%;overflow:hidden;position:relative;display:flex;flex-direction:column}.el-card:hover{border-color:var(--accent);box-shadow:0 6px 24px #6366f11f;transform:translateY(-3px)}.el-card-custom{border-color:#c4b5fd}.el-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent, #6366f1);border-radius:16px 0 0 16px}.el-card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 8px 20px}.el-card-cat-icon{font-size:22px}.el-card-name{font-size:15px;font-weight:700;color:var(--text);margin:0 0 8px;padding:0 16px 0 20px;line-height:1.3}.el-card-tags{display:flex;gap:6px;flex-wrap:wrap;padding:0 16px 10px 20px}.el-tag{font-size:11px;padding:3px 8px;border-radius:6px;background:#f3f4f6;color:#6b7280;text-transform:capitalize;font-weight:500}.el-card-footer{display:flex;align-items:center;gap:8px;padding:10px 16px 14px 20px;margin-top:auto;border-top:1px solid #f3f4f6}.el-card-sets{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--primary);font-weight:700}.el-card-steps{font-size:11px;color:var(--text-muted)}.el-card-arrow{color:var(--text-muted);margin-left:auto;flex-shrink:0}.el-diff-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:capitalize}.el-diff-badge.green{background:#dcfce7;color:#15803d}.el-diff-badge.orange{background:#ffedd5;color:#c2410c}.el-diff-badge.red{background:#fee2e2;color:#b91c1c}.el-custom-badge{font-size:9px;font-weight:700;background:#ede9fe;color:#7c3aed;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.el-delete-btn{background:none;border:none;cursor:pointer;color:#ef4444;padding:3px;border-radius:4px;display:flex;align-items:center;opacity:.7;transition:all .15s}.el-delete-btn:hover{opacity:1;background:#fee2e2}.el-add-cta{margin-top:8px;margin-bottom:24px}.el-add-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(135deg,#1e1b4b,#312e81);border-radius:16px;padding:20px 24px;box-shadow:0 4px 20px #6366f140}.el-add-cta-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:4px}.el-add-cta-sub{font-size:13px;color:#fff9}.el-add-cta-btn{display:flex;align-items:center;gap:8px;padding:12px 22px;background:#22c55e;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,transform .15s;font-family:inherit}.el-add-cta-btn:hover{background:#16a34a;transform:scale(1.04)}.el-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.el-modal{background:#fff;border-radius:20px;width:100%;max-width:620px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0003;animation:slideUp .22s ease}.el-modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 14px;position:sticky;top:0;background:#fff;z-index:1;border-bottom:1px solid var(--gray-light)}.el-modal-head h2{font-size:18px;font-weight:700;margin:0}.el-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:8px;display:flex;transition:background .15s}.el-modal-close:hover{background:var(--bg)}.el-modal-body{padding:20px 24px 24px}.el-form-section{margin-bottom:24px}.el-form-section h3{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--gray-light)}.el-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.el-step-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.el-step-num{font-size:12px;font-weight:700;color:var(--primary);min-width:22px;text-align:center}.el-step-rm{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;flex-shrink:0;transition:all .15s}.el-step-rm:hover{color:#ef4444;background:#fee2e2}.el-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--gray-light)}@media (max-width: 600px){.el-hero{padding:20px 16px 28px}.el-hero-text h1{font-size:22px}.el-body{padding:16px 12px 0}.el-grid{grid-template-columns:1fr 1fr;gap:10px}.el-card-name{font-size:13px}.el-card-head{padding:12px 12px 6px 18px}.el-card-name{padding:0 12px 0 18px}.el-card-tags{padding:0 12px 8px 18px}.el-card-footer{padding:8px 12px 12px 18px}.el-add-cta-inner{flex-direction:column;align-items:flex-start;gap:14px}.el-add-cta-btn{width:100%;justify-content:center}.el-form-grid{grid-template-columns:1fr}.el-modal{max-height:95vh;border-radius:20px 20px 0 0;align-self:flex-end}.el-modal-footer{flex-direction:column-reverse}.el-modal-footer .btn{width:100%}}@media (max-width: 380px){.el-grid{grid-template-columns:1fr}}.myplan-page{max-width:720px;margin:0 auto;padding:24px 16px 100px}.myplan-loading{text-align:center;padding:60px;color:var(--text-muted)}.myplan-header{margin-bottom:20px}.myplan-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.myplan-desc{font-size:14px;color:var(--text-muted);margin:0 0 6px}.myplan-coach{font-size:13px;color:var(--text-muted);margin:0}.myplan-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.myplan-empty p{font-size:15px;margin-bottom:8px}.myplan-day{margin-bottom:14px;border-radius:14px;padding:18px;border:1.5px solid var(--border)}.myplan-day-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.myplan-rest{font-size:14px;color:var(--text-muted);margin:0}.myplan-exercises{display:flex;flex-direction:column;gap:10px}.myplan-ex{display:flex;align-items:flex-start;gap:12px}.myplan-ex-num{width:26px;height:26px;border-radius:50%;background:var(--primary);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.myplan-ex-info{flex:1}.myplan-ex-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.myplan-ex-meta{display:flex;gap:6px;flex-wrap:wrap}.myplan-tag{font-size:11px;padding:2px 8px;border-radius:6px}.myplan-tag.green{background:#dcfce7;color:#15803d}.myplan-tag.blue{background:#dbeafe;color:#1d4ed8}.myplan-tag.gray{background:#f3f4f6;color:var(--text-muted)}.mydiet-page{max-width:720px;margin:0 auto;padding:24px 16px 100px}.mydiet-loading{text-align:center;padding:60px;color:var(--text-muted)}.mydiet-header{margin-bottom:20px}.mydiet-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.mydiet-desc{font-size:14px;color:var(--text-muted);margin:0 0 6px}.mydiet-coach{font-size:13px;color:var(--text-muted);margin:0}.mydiet-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.mydiet-empty p{font-size:15px;margin-bottom:8px}.mydiet-macros{padding:18px;margin-bottom:16px;border-radius:14px;display:flex;align-items:center;gap:20px}.mydiet-macro-total{text-align:center;flex-shrink:0}.mydiet-macro-cal{display:block;font-size:28px;font-weight:800;color:var(--primary-dark);font-family:Poppins,sans-serif}.mydiet-macro-unit{font-size:11px;color:var(--text-muted)}.mydiet-macro-bars{flex:1;display:flex;flex-direction:column;gap:8px}.mydiet-macro-bar-row{display:flex;align-items:center;gap:8px}.mydiet-macro-label{font-size:11px;font-weight:700;width:50px;flex-shrink:0;text-transform:capitalize}.mydiet-macro-label.protein{color:#ef4444}.mydiet-macro-label.carbs{color:#f59e0b}.mydiet-macro-label.fat{color:#6366f1}.mydiet-bar-track{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.mydiet-bar-fill{height:100%;border-radius:4px;transition:width .6s ease}.mydiet-bar-fill.protein{background:#ef4444}.mydiet-bar-fill.carbs{background:#f59e0b}.mydiet-bar-fill.fat{background:#6366f1}.mydiet-macro-val{font-size:11px;color:var(--text-muted);width:80px;text-align:right;flex-shrink:0}.mydiet-meals{display:flex;flex-direction:column;gap:12px}.mydiet-meal{border-radius:12px;padding:16px;border:1.5px solid var(--border)}.mydiet-meal-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.mydiet-meal-icon{font-size:20px}.mydiet-meal-type{font-size:14px;font-weight:700;color:var(--text-primary);flex:1;text-transform:capitalize}.mydiet-meal-cal{font-size:13px;font-weight:600;color:var(--primary-dark);background:#f0fdf4;padding:2px 8px;border-radius:6px}.mydiet-meal-foods{font-size:14px;color:var(--text-secondary);margin:0 0 6px;line-height:1.5}.mydiet-meal-notes{font-size:12px;color:var(--text-muted);font-style:italic;margin:0}@media (max-width: 500px){.mydiet-macros{flex-direction:column;align-items:flex-start;gap:12px}.mydiet-macro-total{display:flex;align-items:baseline;gap:8px}.mydiet-macro-val{width:70px;font-size:10px}}.cd-page{min-height:100vh;background:var(--bg);padding-top:var(--nav-height);padding-bottom:calc(var(--bottom-nav-h) + 20px)}.cd-hero{background:linear-gradient(135deg,#0f172a,#1e293b 55%,#0c2340);padding:28px 20px 36px;position:relative;overflow:hidden}.cd-hero:before{content:"";position:absolute;top:-50px;right:-30px;width:220px;height:220px;background:radial-gradient(circle,rgba(34,197,94,.18) 0%,transparent 70%);border-radius:50%;pointer-events:none}.cd-hero:after{content:"";position:absolute;bottom:-40px;left:5%;width:180px;height:180px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}.cd-hero-inner{max-width:720px;margin:0 auto;position:relative;z-index:1}.cd-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:24px}.cd-hero-greeting{font-size:13px;color:#ffffff80;margin:0 0 4px}.cd-hero-name{font-size:28px;font-weight:800;color:#fff;margin:0}.cd-add-btn{display:flex;align-items:center;gap:8px;padding:11px 20px;background:#22c55e;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0;white-space:nowrap;transition:background .15s,transform .15s;font-family:inherit;box-shadow:0 4px 14px #22c55e59}.cd-add-btn:hover{background:#16a34a;transform:scale(1.04)}.cd-hero-stats{display:flex;gap:10px;flex-wrap:wrap}.cd-stat-pill{display:flex;align-items:center;gap:6px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 14px;color:#ffffffd9;font-size:13px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cd-stat-val{font-weight:800;font-size:16px;color:#fff}.cd-stat-lbl{color:#ffffff8c;font-size:12px}.cd-body{max-width:720px;margin:0 auto;padding:20px 16px 0}.cd-tabs{display:flex;gap:6px;background:#fff;border:1.5px solid var(--gray-light);border-radius:12px;padding:4px;margin-bottom:20px;width:fit-content}.cd-tab{display:flex;align-items:center;gap:6px;padding:8px 20px;border-radius:9px;border:none;background:none;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .18s;font-family:inherit}.cd-tab.active{background:#0f172a;color:#fff;box-shadow:0 2px 8px #0f172a40}.cd-loading{display:flex;justify-content:center;padding:60px 0}.cd-empty{text-align:center;padding:56px 20px;color:var(--text-muted)}.cd-empty h3{color:var(--text);margin:12px 0 6px;font-size:17px}.cd-empty p{font-size:14px}.cd-client-list{display:flex;flex-direction:column;gap:12px}.cd-client-card{background:#fff;border:1.5px solid var(--gray-light);border-radius:16px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.cd-client-card:hover{border-color:#22c55e;box-shadow:0 4px 16px #22c55e1a}.cd-client-main{display:flex;align-items:center;gap:14px;padding:16px;cursor:pointer}.cd-client-avatar{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 10px #22c55e4d}.cd-client-info{flex:1;min-width:0}.cd-client-name{font-weight:700;font-size:15px;color:var(--text);margin-bottom:2px}.cd-client-email{font-size:12px;color:var(--text-muted);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cd-client-badges{display:flex;gap:5px;flex-wrap:wrap}.cd-badge{font-size:11px;padding:3px 8px;border-radius:20px;font-weight:600;text-transform:capitalize}.cd-badge.goal{background:#dcfce7;color:#15803d}.cd-badge.weight{background:#eff6ff;color:#1d4ed8}.cd-badge.pending{background:#f3f4f6;color:#6b7280}.cd-badge.plan{background:#ede9fe;color:#7c3aed}.cd-badge.diet{background:#ffedd5;color:#c2410c}.cd-client-arrow{color:var(--text-muted);flex-shrink:0}.cd-client-actions{display:flex;border-top:1px solid var(--gray-light)}.cd-act-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:none;background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.cd-act-btn+.cd-act-btn{border-left:1px solid var(--gray-light)}.cd-act-btn.chat{color:#22c55e}.cd-act-btn.chat:hover{background:#f0fdf4}.cd-act-btn.plans{color:#6366f1}.cd-act-btn.plans:hover{background:#f0f0ff}.cd-act-btn.remove{color:#ef4444;flex:none;padding:10px 18px}.cd-act-btn.remove:hover{background:#fef2f2}.cd-section-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.cd-analytics-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}.cd-analytics-stat{background:#fff;border:1.5px solid var(--gray-light);border-radius:14px;padding:16px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}.cd-as-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}.cd-as-icon.blue{background:#eff6ff;color:#3b82f6}.cd-as-icon.green{background:#dcfce7;color:#22c55e}.cd-as-icon.red{background:#fee2e2;color:#ef4444}.cd-as-icon.purple{background:#ede9fe;color:#7c3aed}.cd-as-val{font-size:22px;font-weight:800;color:var(--text);line-height:1}.cd-as-lbl{font-size:11px;color:var(--text-muted);font-weight:500}.cd-analytics-list{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.cd-ana-row{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--gray-light);border-radius:12px;padding:12px 14px;transition:border-color .2s}.cd-ana-row.inactive{border-color:#fca5a5;background:#fff8f8}.cd-ana-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cd-ana-info{flex:1;min-width:0}.cd-ana-name{font-weight:700;font-size:14px;color:var(--text);margin-bottom:4px}.cd-ana-stats{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.cd-inactive-tag{background:#fef2f2;color:#dc2626;font-size:10px;font-weight:700;border-radius:6px;padding:3px 8px;border:1px solid #fca5a5;flex-shrink:0}.cd-broadcast{background:#fff;border:1.5px solid var(--gray-light);border-radius:14px;padding:16px;margin-bottom:4px}.cd-broadcast-sub{font-size:13px;color:var(--text-muted);margin:0 0 12px}.cd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0}.cd-modal{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 -8px 40px #00000026;animation:slideUp .25s ease}.cd-modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 14px;position:sticky;top:0;background:#fff;z-index:1;border-bottom:1px solid var(--gray-light)}.cd-modal-head h2{font-size:18px;font-weight:700;margin:0}.cd-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:8px;display:flex;transition:background .15s}.cd-modal-close:hover{background:var(--bg);color:var(--text)}.cd-modal-body{padding:20px 24px 32px}.cd-modal-sub{font-size:13px;color:var(--text-muted);margin:0 0 16px}.cd-search-box{display:flex;align-items:center;gap:10px;border:1.5px solid var(--gray-light);border-radius:12px;padding:0 14px;background:var(--bg);transition:border-color .2s;margin-bottom:12px}.cd-search-box:focus-within{border-color:var(--primary);background:#fff}.cd-search-icon{color:var(--text-muted);flex-shrink:0}.cd-search-input{flex:1;border:none;outline:none;font-size:15px;padding:13px 0;background:transparent;font-family:inherit;color:var(--text)}.cd-search-spinner{width:16px;height:16px;border:2px solid var(--gray-light);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.cd-search-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:50%;display:flex;align-items:center;transition:color .15s}.cd-search-clear:hover{color:var(--text)}.cd-search-results{border:1.5px solid var(--gray-light);border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 4px 16px #0000000f}.cd-search-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--gray-light);cursor:pointer;transition:background .15s}.cd-search-item:last-child{border-bottom:none}.cd-search-item:hover{background:var(--bg)}.cd-search-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cd-search-info{flex:1;min-width:0}.cd-search-name{font-weight:600;font-size:14px;color:var(--text)}.cd-search-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cd-search-empty{padding:20px;text-align:center;color:var(--text-muted);font-size:13px;background:var(--bg);border-radius:10px;border:1.5px dashed var(--gray-light)}@media (max-width: 600px){.cd-hero{padding:20px 16px 28px}.cd-hero-name{font-size:24px}.cd-add-btn{padding:10px 16px;font-size:13px}.cd-hero-stats{gap:8px}.cd-stat-pill{padding:7px 12px;font-size:12px}.cd-body{padding:16px 12px 0}.cd-analytics-stats{grid-template-columns:repeat(3,1fr);gap:8px}.cd-as-val{font-size:18px}}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.ccp-form{padding:20px;margin-bottom:16px;border:1.5px solid var(--primary);border-radius:14px;background:#f0fdf4}.ccp-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.ccp-form-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.ccp-close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;transition:background .2s}.ccp-close:hover{background:#e5e7eb;color:var(--text-primary)}.ccp-day{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px}.ccp-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.ccp-day-select{border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;font-weight:600;color:var(--text-primary);background:#fff;cursor:pointer;outline:none}.ccp-remove-day{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;border-radius:6px;padding:5px 8px;cursor:pointer;display:flex;align-items:center}.ccp-exercise{background:#f9fafb;border-radius:8px;padding:10px;margin-bottom:8px}.ccp-ex-row{display:flex;gap:8px;margin-bottom:6px;align-items:center}.ccp-ex-row:last-child{margin-bottom:0}.ccp-ex-name{flex:1}.ccp-ex-short{width:80px;flex-shrink:0}.ccp-remove-ex{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;padding:4px;border-radius:4px;flex-shrink:0}.ccp-remove-ex:hover{color:#ef4444}.ccp-add-ex-btn{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--primary);background:none;border:1px dashed var(--primary);border-radius:6px;padding:6px 12px;cursor:pointer;margin-top:4px;transition:background .2s;width:100%;justify-content:center}.ccp-add-ex-btn:hover{background:#f0fdf4}.ccp-add-day-btn{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#6366f1;background:none;border:1px dashed #a5b4fc;border-radius:8px;padding:10px;cursor:pointer;width:100%;justify-content:center;margin-bottom:16px;transition:background .2s}.ccp-add-day-btn:hover{background:#f0f0ff}.ccp-form-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width: 500px){.ccp-ex-row{flex-wrap:wrap}.ccp-ex-short{width:70px}}.ccd-form{padding:20px;margin-bottom:16px;border:1.5px solid #f59e0b;border-radius:14px;background:#fffbeb}.ccd-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.ccd-form-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0}.ccd-close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;transition:background .2s}.ccd-close:hover{background:#e5e7eb;color:var(--text-primary)}.ccd-macros-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:8px}.ccd-derived-note{font-size:12px;color:var(--text-muted);margin:0 0 12px}.ccd-meals-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.ccd-meal-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.ccd-meal-type{border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px;color:var(--text-primary);background:#fff;cursor:pointer;outline:none;flex-shrink:0;text-transform:capitalize}.ccd-meal-foods{flex:1}.ccd-meal-cal{width:80px;flex-shrink:0}.ccd-remove-meal{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;padding:4px;border-radius:4px;flex-shrink:0}.ccd-remove-meal:hover{color:#ef4444}.ccd-add-meal-btn{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#d97706;background:none;border:1px dashed #f59e0b;border-radius:6px;padding:6px 12px;cursor:pointer;margin-bottom:16px;width:100%;justify-content:center;transition:background .2s}.ccd-add-meal-btn:hover{background:#fef3c7}.ccd-form-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width: 500px){.ccd-macros-row{grid-template-columns:1fr 1fr}.ccd-meal-row{flex-wrap:wrap}.ccd-meal-type,.ccd-meal-foods{width:100%}}.ccd-page{max-width:720px;margin:0 auto;padding:16px 16px 100px}.ccd-loading{text-align:center;padding:60px;color:var(--text-muted)}.ccd-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ccd-back{background:#f3f4f6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--text-secondary);transition:background .2s}.ccd-back:hover{background:#e5e7eb}.ccd-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ccd-title-info{flex:1;min-width:0}.ccd-name{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 2px}.ccd-email{font-size:12px;color:var(--text-muted);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ccd-chat-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .2s}.ccd-chat-btn:hover{background:var(--primary-dark)}.ccd-stats{display:flex;gap:10px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.ccd-stat{background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;text-align:center;flex-shrink:0}.ccd-stat span{display:block;font-size:16px;font-weight:700;color:var(--primary-dark)}.ccd-stat label{font-size:11px;color:var(--text-muted);display:block;margin-top:2px}.ccd-tabs{display:flex;gap:0;background:#f3f4f6;border-radius:10px;padding:4px;margin-bottom:16px}.ccd-tab{flex:1;padding:8px;border:none;border-radius:7px;background:transparent;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s}.ccd-tab.active{background:#fff;color:var(--text-primary);font-weight:600;box-shadow:0 1px 3px #0000001a}.ccd-section-h{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 10px}.ccd-tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.ccd-tab-header .ccd-section-h{margin:0}.btn-sm{padding:6px 12px;font-size:12px;display:inline-flex;align-items:center;gap:4px}.ccd-empty-txt{color:var(--text-muted);font-size:14px;padding:20px 0;text-align:center}.ccd-log-list{display:flex;flex-direction:column;gap:6px}.ccd-log-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:13px}.ccd-log-val{font-weight:600;color:var(--text-primary)}.ccd-log-date{color:var(--text-muted);font-size:12px}.ccd-plan-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px}.ccd-plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:8px}.ccd-plan-name{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.ccd-plan-desc{font-size:13px;color:var(--text-muted);margin-bottom:6px}.ccd-plan-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:#f3f4f6;color:var(--text-muted)}.ccd-plan-badge.active{background:#dcfce7;color:#15803d}.ccd-delete-btn{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;border-radius:8px;padding:6px 10px;cursor:pointer;flex-shrink:0;transition:background .2s}.ccd-delete-btn:hover{background:#fee2e2}.ccd-day{background:#f9fafb;border-radius:8px;padding:10px 12px;margin-bottom:8px}.ccd-day-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.ccd-ex-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px}.ccd-ex-name{font-weight:500;color:var(--text-secondary)}.ccd-ex-detail{font-size:12px;color:var(--primary-dark);font-weight:600;background:#dcfce7;padding:2px 6px;border-radius:4px}.ccd-ex-note{font-size:12px;color:var(--text-muted);font-style:italic}.ccd-diet-macros{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-muted);margin-bottom:6px}.ccd-checkin-wrap{background:#f5f3ff;border:1.5px solid #e0d9ff;border-radius:12px;padding:14px;margin-bottom:4px}.ccd-checkin-sub{font-size:12px;color:var(--text-muted);margin:0 0 10px}.ccd-checkin-days{display:flex;gap:6px;flex-wrap:wrap}.ccd-day-btn{padding:6px 10px;border-radius:8px;border:1.5px solid #c4b5fd;background:#fff;color:#6366f1;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.ccd-day-btn:hover{background:#ede9fe}.ccd-day-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.ccd-day-btn:disabled{opacity:.6;cursor:not-allowed}.ccd-checkin-set{font-size:12px;color:#4f46e5;font-weight:600;margin:8px 0 0}.cc-page{display:flex;flex-direction:column;height:100vh;max-width:720px;margin:0 auto}.cc-loading{text-align:center;padding:60px;color:var(--text-muted)}.cc-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:0;z-index:10}.cc-back{background:#f3f4f6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);flex-shrink:0;transition:background .2s}.cc-back:hover{background:#e5e7eb}.cc-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cc-header-name{font-weight:700;font-size:15px;color:var(--text-primary)}.cc-header-sub{font-size:12px;color:var(--text-muted)}.cc-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px;background:#f9fafb}.cc-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:40px}.cc-msg{display:flex;flex-direction:column;max-width:75%;gap:2px}.cc-msg.mine{align-self:flex-end;align-items:flex-end}.cc-msg.theirs{align-self:flex-start;align-items:flex-start}.cc-bubble{padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.5;word-break:break-word}.cc-msg.mine .cc-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.cc-msg.theirs .cc-bubble{background:#fff;color:var(--text-primary);border:1px solid var(--border);border-bottom-left-radius:4px}.cc-img{max-width:220px;max-height:200px;border-radius:12px;object-fit:cover;cursor:pointer}.cc-time{font-size:10px;color:var(--text-muted);padding:0 4px}.cc-typing{display:flex;align-items:center;gap:4px;padding:12px 16px;min-width:50px}.cc-typing span{width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:cc-bounce 1.2s infinite}.cc-typing span:nth-child(2){animation-delay:.2s}.cc-typing span:nth-child(3){animation-delay:.4s}@keyframes cc-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.cc-img-preview{padding:8px 16px;background:#fff;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0}.cc-img-preview img{width:60px;height:60px;object-fit:cover;border-radius:8px}.cc-img-clear{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.cc-input-row{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid var(--border);flex-shrink:0}.cc-attach{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);flex-shrink:0;transition:all .2s}.cc-attach:hover{border-color:var(--primary);color:var(--primary)}.cc-textarea{flex:1;border:1.5px solid var(--border);border-radius:20px;padding:10px 16px;font-size:14px;resize:none;outline:none;background:#f9fafb;line-height:1.4;max-height:120px;overflow-y:auto;transition:border-color .2s;font-family:inherit}.cc-textarea:focus{border-color:var(--primary);background:#fff}.cc-send{width:40px;height:40px;border-radius:50%;background:var(--primary);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}.cc-send:hover:not(:disabled){background:var(--primary-dark)}.cc-send:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.cg-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:16px}.cg-modal{background:#fff;border-radius:20px 20px 16px 16px;width:100%;max-width:500px;padding:24px;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}.cg-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cg-modal-header h2{font-size:18px;font-weight:700;margin:0}.cg-modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px}.cg-client-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;border:1.5px solid var(--gray-light);border-radius:10px;padding:8px}.cg-client-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s;border:1.5px solid transparent}.cg-client-item:hover{background:var(--bg)}.cg-client-item.selected{background:#f0fdf4;border-color:var(--primary)}.cg-client-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cg-check{margin-left:auto;color:var(--primary);font-weight:700;font-size:16px}.cg-group-card{border-radius:14px;border:1.5px solid var(--border, #e5e7eb);overflow:hidden;transition:border-color .2s}.cg-group-card:hover{border-color:#6366f1}.cg-group-main{display:flex;align-items:center;gap:14px;padding:16px;cursor:pointer}.cg-group-avatar{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cg-group-info{flex:1;min-width:0}.cg-group-name{font-weight:700;font-size:15px;color:var(--text-primary, #111827);margin-bottom:2px}.cg-group-desc{font-size:13px;color:var(--text-muted);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cg-group-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-muted)}.cg-last-msg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.cg-group-actions{display:flex;border-top:1px solid var(--gray-light)}.cg-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:none;background:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.cg-action-btn+.cg-action-btn{border-left:1px solid var(--gray-light)}.cg-action-btn.chat{color:#6366f1}.cg-action-btn.chat:hover{background:#f0f0ff}.cg-action-btn.remove{color:#ef4444;flex:none;padding:10px 16px}.cg-action-btn.remove:hover{background:#fef2f2}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.cp-client-table{display:flex;flex-direction:column;gap:8px}.cp-client-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:var(--bg, #f9fafb);border:1.5px solid transparent;transition:border-color .2s}.cp-client-row:hover{border-color:var(--primary)}.cp-client-row.inactive{opacity:.6}.cp-client-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cp-client-info{flex:1;min-width:0}.cp-client-name{font-weight:600;font-size:14px;color:var(--text-primary, #111827);margin-bottom:2px}.cp-client-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-muted)}.cp-inactive-tag{background:#fee2e2;color:#dc2626;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;flex-shrink:0}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-card{display:flex;flex-direction:column;align-items:center;padding:16px 12px;text-align:center;gap:6px}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.stat-value{font-size:22px;font-weight:800;color:var(--text-primary, #111827);line-height:1}.stat-label{font-size:11px;color:var(--text-muted);font-weight:500}@media (max-width: 480px){.grid-3{grid-template-columns:repeat(3,1fr);gap:8px}.stat-value{font-size:18px}.stat-label{font-size:10px}.stat-icon{width:34px;height:34px}}.gc-page{display:flex;flex-direction:column;height:100vh;height:100dvh;padding-top:var(--nav-height);background:var(--bg)}.gc-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border-bottom:1px solid var(--gray-light);flex-shrink:0}.gc-back{background:none;border:none;cursor:pointer;color:var(--text);padding:4px;display:flex;align-items:center;flex-shrink:0}.gc-group-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.gc-group-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gc-group-name{font-weight:700;font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gc-group-sub{font-size:12px;color:var(--text-muted)}.gc-icon-btn{background:#f3f4f6;border:none;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:background .15s}.gc-icon-btn:hover{background:#e5e7eb}.gc-icon-btn.danger{color:#ef4444}.gc-icon-btn.danger:hover{background:#fef2f2}.gc-members-panel{background:#fff;border-bottom:1px solid var(--gray-light);padding:12px 16px;max-height:240px;overflow-y:auto;flex-shrink:0}.gc-members-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.gc-member-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #f3f4f6}.gc-member-row:last-child{border-bottom:none}.gc-member-avatar{width:30px;height:30px;border-radius:50%;background:#dcfce7;color:#15803d;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gc-member-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}.gc-remove-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.gc-remove-btn:hover{background:#fef2f2}.gc-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.gc-empty{text-align:center;color:var(--text-muted);font-size:14px;margin-top:60px}.gc-msg-row{display:flex;align-items:flex-end;gap:8px}.gc-msg-row.me{flex-direction:row-reverse}.gc-msg-avatar{width:28px;height:28px;border-radius:50%;background:#e5e7eb;color:#374151;font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gc-bubble{max-width:70%;background:#fff;border:1px solid var(--gray-light);border-radius:16px 16px 16px 4px;padding:10px 14px}.gc-bubble.me{background:var(--primary);border-color:var(--primary);border-radius:16px 16px 4px;color:#fff}.gc-bubble.coach:not(.me){background:#ede9fe;border-color:#c4b5fd}.gc-bubble-sender{font-size:11px;font-weight:700;color:#6b7280;margin-bottom:4px;display:flex;align-items:center;gap:4px}.gc-coach-tag{background:#6366f1;color:#fff;font-size:9px;padding:1px 5px;border-radius:4px;font-weight:700}.gc-bubble-text{font-size:14px;line-height:1.5;word-break:break-word}.gc-bubble.me .gc-bubble-text{color:#fff}.gc-bubble-time{font-size:10px;color:#00000059;margin-top:4px;text-align:right}.gc-bubble.me .gc-bubble-time{color:#ffffffa6}.gc-input-row{display:flex;gap:8px;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid var(--gray-light);flex-shrink:0}.gc-input{flex:1;padding:11px 16px;border:1.5px solid var(--gray-light);border-radius:24px;font-size:15px;font-family:inherit;background:var(--bg);outline:none;transition:border-color .2s}.gc-input:focus{border-color:#6366f1}.gc-send-btn{width:44px;height:44px;border-radius:50%;background:#6366f1;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}.gc-send-btn:hover:not(:disabled){background:#4f46e5}.gc-send-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.gc-page{padding-top:var(--nav-height)}.gc-messages{padding-bottom:8px}}.tdee-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.tdee-activity-list{display:flex;flex-direction:column;gap:6px}.tdee-activity-btn{display:flex;flex-direction:column;align-items:flex-start;padding:10px 14px;border:1.5px solid var(--gray-light);border-radius:10px;background:var(--bg);cursor:pointer;transition:all .15s;text-align:left;font-family:inherit}.tdee-activity-btn:hover{border-color:var(--primary)}.tdee-activity-btn.active{border-color:var(--primary);background:var(--primary-bg)}.tdee-act-label{font-size:13px;font-weight:700;color:var(--text)}.tdee-act-sub{font-size:11px;color:var(--text-muted);margin-top:1px}.tdee-goal-row{display:flex;gap:8px}.tdee-goal-btn{flex:1;padding:10px 8px;border:1.5px solid var(--gray-light);border-radius:10px;background:var(--bg);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;text-align:center}.tdee-goal-btn:hover{border-color:var(--primary)}.tdee-goal-btn.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary-dark)}.tdee-result{background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:20px;overflow:hidden;box-shadow:0 8px 32px #0003}.tdee-result-hero{text-align:center;padding:28px 20px 20px}.tdee-main-cal{font-size:56px;font-weight:900;color:#4ade80;line-height:1;font-family:Poppins,sans-serif}.tdee-main-label{font-size:14px;color:#fff9;margin-top:4px;margin-bottom:12px}.tdee-sub-stats{display:flex;gap:20px;justify-content:center;font-size:13px;color:#ffffff80}.tdee-sub-stats strong{color:#ffffffd9}.tdee-macros{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(255,255,255,.08)}.tdee-macro{padding:18px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.06)}.tdee-macro:last-child{border-right:none}.tdee-macro-val{font-size:22px;font-weight:800;color:#fff;font-family:Poppins,sans-serif}.tdee-macro-lbl{font-size:11px;color:#ffffff80;margin:2px 0 8px;text-transform:uppercase;letter-spacing:.5px}.tdee-macro-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.tdee-macro-bar div{height:100%;border-radius:2px;transition:width .5s ease}.tdee-macro.protein .tdee-macro-bar div{background:#60a5fa}.tdee-macro.carbs .tdee-macro-bar div{background:#fbbf24}.tdee-macro.fat .tdee-macro-bar div{background:#f87171}@media (max-width: 480px){.tdee-grid{grid-template-columns:1fr}.tdee-goal-row{flex-direction:column}.tdee-main-cal{font-size:44px}}.bm-page{max-width:600px}.bm-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}.bm-form-card{padding:20px;margin-bottom:16px}.bm-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.bm-snapshot{background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:20px;padding:20px;margin-bottom:20px}.bm-snapshot-title{color:#ffffffb3;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.bm-snap-grid{display:flex;gap:12px;flex-wrap:wrap}.bm-snap-item{flex:1;min-width:80px;background:#ffffff0f;border-radius:14px;padding:14px 10px;text-align:center;border:1px solid rgba(255,255,255,.08)}.bm-snap-icon{font-size:18px;margin-bottom:4px}.bm-snap-val{font-family:Poppins,sans-serif;font-size:20px;font-weight:800;color:#4ade80;line-height:1}.bm-snap-val span{font-size:11px;color:#ffffff80;margin-left:2px}.bm-snap-label{font-size:11px;color:#ffffff80;margin-top:3px;text-transform:uppercase;letter-spacing:.5px}.bm-trend{display:inline-flex;align-items:center;gap:2px;font-size:10px;font-weight:700;margin-top:6px;border-radius:6px;padding:2px 6px}.bm-trend.down{background:#22c55e26;color:#4ade80}.bm-trend.up{background:#ef444426;color:#f87171}.bm-section-title{font-family:Poppins,sans-serif;font-size:16px;font-weight:700;color:var(--text);margin-bottom:12px}.bm-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.bm-history{display:flex;flex-direction:column;gap:10px}.bm-log-card{padding:16px;border:1.5px solid var(--gray-light);transition:var(--transition)}.bm-log-card.latest{border-color:var(--primary)}.bm-log-date{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);font-weight:600;margin-bottom:10px}.bm-badge{background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.bm-log-values{display:flex;flex-wrap:wrap;gap:8px}.bm-log-val{display:flex;flex-direction:column;background:var(--bg-alt);border-radius:8px;padding:6px 10px;min-width:72px}.bm-log-lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.bm-log-num{font-family:Poppins,sans-serif;font-size:14px;font-weight:700;color:var(--text)}.bm-log-note{margin-top:8px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--gray-light);padding-top:8px}@media (max-width: 480px){.bm-grid{grid-template-columns:1fr}.bm-snap-grid{gap:8px}}.pp-page{max-width:640px}.pp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.pp-upload-card{padding:16px;margin-bottom:20px}.pp-upload-zone{border:2px dashed var(--gray-light);border-radius:14px;padding:32px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:var(--transition);color:var(--text-muted);font-size:14px;font-weight:500;min-height:140px;overflow:hidden}.pp-upload-zone:hover{border-color:var(--primary);color:var(--primary)}.pp-upload-hint{font-size:11px;color:var(--text-muted)}.pp-preview-img{width:100%;max-height:240px;object-fit:cover;border-radius:10px;margin:-8px 0}.pp-upload-meta{margin-top:12px;display:flex;flex-direction:column;gap:10px}.pp-upload-actions{display:flex;gap:8px;justify-content:flex-end}.pp-section-title{font-family:Poppins,sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}.pp-empty{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:14px}.pp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pp-card{border-radius:14px;overflow:hidden;background:var(--white);border:1px solid var(--gray-light);box-shadow:var(--shadow)}.pp-img-wrap{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer}.pp-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.pp-img-wrap:hover .pp-img{transform:scale(1.05)}.pp-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;color:#fff;font-weight:700;font-size:13px}.pp-img-wrap:hover .pp-img-overlay{opacity:1}.pp-info{padding:8px 10px;position:relative}.pp-date{font-size:10px;color:var(--text-muted);font-weight:600}.pp-caption{font-size:11px;color:var(--text);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-delete{position:absolute;top:8px;right:8px;color:#ef4444;opacity:.6;transition:opacity .15s}.pp-delete:hover{opacity:1}.pp-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pp-lightbox-inner{position:relative;max-width:500px;width:100%;border-radius:20px;overflow:hidden;background:#1e293b}.pp-lightbox-inner img{width:100%;max-height:70vh;object-fit:contain}.pp-lb-caption{color:#fff;font-weight:600;font-size:14px;padding:12px 16px 4px}.pp-lb-date{color:#ffffff80;font-size:12px;padding:0 16px 16px}.pp-lb-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:#0009;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center}.pp-lb-close:hover{background:#000000e6}@media (max-width: 480px){.pp-grid{grid-template-columns:repeat(2,1fr)}}.top-nav{position:fixed;top:0;left:0;right:0;z-index:200;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-light);box-shadow:var(--shadow);height:var(--nav-height)}.top-nav-inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;gap:16px;padding:0 20px}.top-nav-logo{font-family:Poppins,sans-serif;font-size:16px;font-weight:800;color:var(--primary-dark);text-decoration:none;flex-shrink:0;margin-right:8px}.top-nav-links{display:flex;gap:4px;flex:1}.top-nav-right{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.top-nav-link{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:7px;font-size:12px;font-weight:600;color:var(--gray);transition:var(--transition);text-decoration:none;cursor:pointer;background:none;border:none;font-family:inherit}.top-nav-link:hover,.top-nav-link.active{background:var(--primary-bg);color:var(--primary-dark)}@media (max-width: 900px){.top-nav-links,.top-nav-right{display:none}.top-nav-logo{font-size:15px}.top-nav-inner{padding:0 16px}}:root{--primary: #22c55e;--primary-dark: #16a34a;--primary-light: #4ade80;--primary-bg: #f0fdf4;--accent: #3b82f6;--accent-bg: #eff6ff;--gold: #f59e0b;--bg: #f9fafb;--bg-alt: #f3f4f6;--white: #ffffff;--dark: #111827;--gray: #6b7280;--gray-light: #e5e7eb;--text: #111827;--text-muted: #9ca3af;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0,0,0,.07);--shadow-lg: 0 8px 40px rgba(0,0,0,.12);--transition: all .22s cubic-bezier(.4,0,.2,1);--nav-height: 54px;--bottom-nav-h: 64px}[data-theme=dark]{--bg: #0f172a;--bg-alt: #1e293b;--white: #1e293b;--dark: #f1f5f9;--gray: #94a3b8;--gray-light: #334155;--text: #f1f5f9;--text-muted: #64748b;--primary-bg: #052e16;--accent-bg: #172554;--shadow: 0 4px 24px rgba(0,0,0,.3);--shadow-lg: 0 8px 40px rgba(0,0,0,.4)}[data-theme=dark] body{background:#0f172a;color:#f1f5f9}[data-theme=dark] .card,[data-theme=dark] .form-input,[data-theme=dark] .top-nav,[data-theme=dark] .bottom-nav{background:#1e293b;border-color:#334155}[data-theme=dark] .bottom-nav{background:#1e293bf7}[data-theme=dark] .form-input{color:#f1f5f9}[data-theme=dark] .form-input::placeholder{color:#64748b}[data-theme=dark] .top-nav-logo{color:#4ade80}[data-theme=dark] .auth-page{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}[data-theme=dark] .auth-card{background:#1e293b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}h1,h2,h3,h4,h5,.heading{font-family:Poppins,sans-serif}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit;border:none;background:none}input,textarea,select{font-family:inherit}.container{max-width:1100px;margin:0 auto;padding:0 20px}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--gray-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:var(--transition);border:2px solid transparent}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-outline{border-color:var(--primary);color:var(--primary);background:transparent}.btn-outline:hover{background:var(--primary-bg)}.btn-ghost{color:var(--gray)}.btn-ghost:hover{background:var(--bg-alt);color:var(--dark)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-sm{padding:7px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px;border-radius:var(--radius)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:13px;font-weight:600;color:var(--dark)}.form-hint{font-size:12px;color:var(--gray)}.form-input{width:100%;padding:11px 14px;border:1.5px solid var(--gray-light);border-radius:var(--radius-sm);font-size:15px;background:var(--white);color:var(--dark);transition:var(--transition)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #22c55e1f}.form-input::placeholder{color:var(--text-muted)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.spinner{width:36px;height:36px;border:3px solid var(--gray-light);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{width:18px;height:18px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;height:40vh}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:30px;font-size:12px;font-weight:600}.badge-green{background:var(--primary-bg);color:var(--primary-dark)}.badge-blue{background:var(--accent-bg);color:var(--accent)}.badge-gold{background:#fffbeb;color:#92400e}.badge-red{background:#fef2f2;color:var(--danger)}.badge-gray{background:var(--bg-alt);color:var(--gray)}.empty-state{text-align:center;padding:48px 24px;color:var(--gray)}.empty-state svg{margin:0 auto 16px;opacity:.4}.empty-state h3{font-size:17px;color:var(--dark);margin-bottom:8px}.empty-state p{font-size:14px;line-height:1.6}.macro-bar{height:8px;border-radius:4px;background:var(--gray-light);overflow:hidden;margin-top:4px}.macro-bar-fill{height:100%;border-radius:4px;transition:width .5s ease;max-width:100%}.macro-bar-fill.protein{background:var(--accent)}.macro-bar-fill.carbs{background:var(--gold)}.macro-bar-fill.fat{background:var(--danger)}.page-wrapper{padding-top:var(--nav-height);min-height:100vh}.page-content{padding:24px 20px;max-width:900px;margin:0 auto}@media (max-width: 768px){.page-content{padding-bottom:calc(var(--bottom-nav-h) + 24px)}}.stat-card{padding:20px}.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-value{font-size:26px;font-weight:800;color:var(--dark);font-family:Poppins,sans-serif}.stat-label{font-size:13px;color:var(--gray);margin-top:2px}.stat-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 768px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.bottom-nav{padding-bottom:env(safe-area-inset-bottom,0px);height:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}.top-nav{padding-top:env(safe-area-inset-top,0px);height:calc(var(--nav-height) + env(safe-area-inset-top,0px))}.page-wrapper{padding-top:calc(var(--nav-height) + env(safe-area-inset-top,0px))}@media (max-width: 900px){.page-wrapper{padding-top:calc(var(--nav-height) + env(safe-area-inset-top,0px))}.page-content{padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0px) + 24px)}.top-nav-links,.top-nav-right{display:none!important}.cd-page,.el-page{padding-top:calc(var(--nav-height) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0px) + 16px)}.gc-page{padding-top:calc(var(--nav-height) + env(safe-area-inset-top,0px))}}@media (max-width: 768px){.btn{min-height:44px}.btn-sm{min-height:38px}.form-input{min-height:46px;font-size:16px}select.form-input{font-size:16px}a,button{-webkit-tap-highlight-color:transparent}.stat-icon{width:40px;height:40px}.stat-value{font-size:22px}.card{border-radius:14px}.grid-2{gap:12px}.grid-3{gap:10px}}@media (max-width: 380px){.grid-2{grid-template-columns:1fr}}html{scroll-behavior:smooth}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.bubble{max-width:78%;padding:12px 16px;border-radius:18px;font-size:15px;line-height:1.55;word-break:break-word}.bubble-bot{background:var(--white);border:1px solid var(--gray-light);align-self:flex-start;border-bottom-left-radius:4px}.bubble-user{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
