.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-h);background:#fffffff5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--gray-light);box-shadow:0 -4px 16px #0000000f;z-index:100;justify-content:space-around;align-items:flex-start;padding:8px 4px 0}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-height:44px;padding:4px;color:var(--gray);font-size:11px;font-weight:600;transition:color .15s;text-decoration:none;border-radius:10px;-webkit-tap-highlight-color:transparent}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active svg{stroke-width:2.5}@media (max-width: 768px){.bottom-nav{display:flex}}.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}@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}.meal-sug-card{padding:0;margin-bottom:16px;overflow:hidden}.meal-sug-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:none;border:none;cursor:pointer;font-size:15px;font-weight:700;color:var(--text-primary);text-align:left}.meal-sug-chevron{font-size:11px;color:var(--text-muted)}.meal-sug-body{padding:0 20px 16px;border-top:1px solid var(--border, #e5e7eb)}.meal-sug-message{font-size:13px;color:var(--text-muted);margin:12px 0;line-height:1.5}.meal-sug-list{display:flex;flex-direction:column;gap:8px}.meal-sug-item{background:var(--bg, #f9fafb);border-radius:10px;padding:12px 14px;border:1px solid var(--border, #e5e7eb)}.msi-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.msi-macros{display:flex;gap:10px;flex-wrap:wrap;font-size:12px}.msi-cal{color:#f97316;font-weight:600}.msi-p{color:#3b82f6}.msi-c{color:#f59e0b}.msi-f{color:#8b5cf6}.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)}.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)}.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}}}.ex-lib{max-width:900px;margin:0 auto;padding:24px 16px 100px}.ex-lib-header{margin-bottom:24px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.ex-custom-badge{font-size:10px;font-weight:700;background:#ede9fe;color:#7c3aed;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.ex-card-custom{border:1.5px solid #ede9fe!important}.ex-delete-btn{background:none;border:none;cursor:pointer;color:#ef4444;padding:2px 4px;border-radius:4px;display:flex;align-items:center;opacity:.7;transition:opacity .15s}.ex-delete-btn:hover{opacity:1;background:#fee2e2}.ex-create-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:16px}.ex-create-modal{background:var(--surface, #fff);border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003;animation:slideUp .2s ease}.ex-create-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 12px;position:sticky;top:0;background:var(--surface, #fff);z-index:1;border-bottom:1px solid var(--border, #e5e7eb)}.ex-create-header h2{font-size:18px;font-weight:700;margin:0;color:var(--text-primary)}.ex-close-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:8px;display:flex;align-items:center;transition:background .15s}.ex-close-btn:hover{background:var(--bg)}.ex-create-form{padding:20px 24px 24px}.ex-create-section{margin-bottom:24px}.ex-create-section h3{font-size:14px;font-weight:700;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border, #e5e7eb)}.ex-create-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ex-step-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ex-step-num{font-size:12px;font-weight:700;color:var(--primary);min-width:20px;text-align:center}.ex-step-remove{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;flex-shrink:0}.ex-step-remove:hover{color:#ef4444;background:#fee2e2}.ex-create-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border, #e5e7eb)}@media (max-width: 480px){.ex-create-grid{grid-template-columns:1fr}.ex-create-modal{max-height:95vh;border-radius:16px 16px 0 0;align-self:flex-end}.ex-create-footer{flex-direction:column-reverse}.ex-create-footer .btn{width:100%}}.ex-lib-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.ex-lib-sub{font-size:14px;color:var(--text-muted);margin:0}.ex-search-row{display:flex;gap:10px;margin-bottom:14px}.ex-search-box{flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:0 12px;transition:border-color .2s}.ex-search-box:focus-within{border-color:var(--primary)}.ex-search-icon{color:var(--text-muted);flex-shrink:0}.ex-search-input{flex:1;border:none;outline:none;font-size:14px;padding:11px 0;background:transparent;color:var(--text-primary)}.ex-search-input::placeholder{color:var(--text-muted)}.ex-clear-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:2px;border-radius:50%;transition:color .2s}.ex-clear-btn:hover{color:var(--text-primary)}.ex-filter-toggle{display:flex;align-items:center;gap:6px;padding:0 16px;border:1.5px solid var(--border);border-radius:10px;background:#fff;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap}.ex-filter-toggle:hover,.ex-filter-toggle.active{border-color:var(--primary);color:var(--primary);background:#f0fdf4}.ex-filters{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:16px;margin-bottom:14px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.ex-filter-group{display:flex;flex-direction:column;gap:4px;min-width:140px}.ex-filter-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.ex-filter-group select{border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:13px;color:var(--text-primary);background:#fff;cursor:pointer;outline:none;transition:border-color .2s}.ex-filter-group select:focus{border-color:var(--primary)}.ex-clear-filters{display:flex;align-items:center;gap:4px;padding:8px 14px;background:#fef2f2;color:#ef4444;border:1.5px solid #fecaca;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s;align-self:flex-end}.ex-clear-filters:hover{background:#fee2e2}.ex-muscle-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.ex-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1.5px solid var(--border);border-radius:20px;background:#fff;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;text-transform:capitalize;transition:all .2s}.ex-chip:hover{border-color:var(--primary);color:var(--primary)}.ex-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.ex-results-info{font-size:13px;color:var(--text-muted);margin-bottom:14px}.ex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.ex-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:18px;text-align:left;cursor:pointer;transition:all .2s;width:100%}.ex-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #22c55e1a;transform:translateY(-2px)}.ex-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.ex-cat-icon{font-size:22px}.ex-diff-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:capitalize}.ex-diff-badge.green{background:#dcfce7;color:#15803d}.ex-diff-badge.orange{background:#ffedd5;color:#c2410c}.ex-diff-badge.red{background:#fee2e2;color:#b91c1c}.ex-card-name{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.3}.ex-card-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}.ex-tag{font-size:11px;padding:3px 8px;border-radius:6px;background:#f3f4f6;color:var(--text-secondary);text-transform:capitalize}.ex-card-sets{font-size:12px;color:var(--primary);font-weight:600;margin:0 0 4px}.ex-card-steps{font-size:11px;color:var(--text-muted);margin:0}.ex-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.ex-empty p{margin-bottom:16px;font-size:15px}@media (max-width: 600px){.ex-lib{padding:16px 12px 90px}.ex-grid{grid-template-columns:1fr 1fr;gap:10px}.ex-card{padding:14px}.ex-card-name{font-size:13px}.ex-filter-toggle{padding:0 12px;font-size:13px}.ex-muscle-chips{gap:6px}.ex-chip{font-size:11px;padding:5px 10px}}@media (max-width: 400px){.ex-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}}.coach-dash{max-width:720px;margin:0 auto;padding:24px 16px 100px}.coach-dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px}.coach-dash-title{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.coach-dash-sub{font-size:14px;color:var(--text-muted);margin:0}.coach-add-btn{white-space:nowrap;display:flex;align-items:center;gap:6px;flex-shrink:0}.coach-add-form{padding:20px;margin-bottom:20px;border-radius:14px;border:1.5px solid var(--primary);background:#f0fdf4}.coach-add-title{font-size:15px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.coach-add-sub{font-size:13px;color:var(--text-muted);margin:0 0 14px}.coach-add-row{display:flex;gap:10px}.coach-add-row .form-input{flex:1}.coach-search-wrap{position:relative}.coach-search-input-row{display:flex;align-items:center;gap:8px;position:relative}.coach-search-icon{color:var(--text-muted);flex-shrink:0}.coach-search-input{flex:1;padding-left:8px!important}.coach-search-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.coach-search-results{margin-top:8px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:0 4px 16px #00000014}.coach-search-result-item{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border)}.coach-search-result-item:last-child{border-bottom:none}.coach-search-result-item:hover{background:var(--bg)}.csr-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light, #dcfce7);color:var(--primary);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.csr-info{flex:1;min-width:0}.csr-name{font-weight:600;font-size:14px;color:var(--text-primary)}.csr-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.csr-add-btn{flex-shrink:0;font-size:12px;padding:6px 12px}.coach-search-empty{margin-top:8px;padding:14px;text-align:center;color:var(--text-muted);font-size:13px;background:var(--bg);border-radius:10px;border:1px dashed var(--border)}.coach-stats-row{display:flex;gap:12px;margin-bottom:24px}.coach-stat-card{flex:1;background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:16px;display:flex;align-items:center;gap:10px}.coach-stat-icon{color:var(--primary);flex-shrink:0}.coach-stat-num{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1}.coach-stat-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}.coach-section-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.coach-client-list{display:flex;flex-direction:column;gap:12px}.coach-client-card{padding:0;border-radius:14px;border:1.5px solid var(--border);overflow:hidden;transition:border-color .2s}.coach-client-card:hover{border-color:var(--primary)}.ccc-main{display:flex;align-items:center;gap:14px;padding:16px;cursor:pointer}.ccc-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}.ccc-info{flex:1;min-width:0}.ccc-name{font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:2px}.ccc-email{font-size:12px;color:var(--text-muted);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ccc-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px}.ccc-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:#f0fdf4;color:#15803d;text-transform:capitalize}.ccc-badge.weight{background:#eff6ff;color:#1d4ed8}.ccc-badge.gray{background:#f3f4f6;color:#6b7280}.ccc-plans{display:flex;gap:6px;flex-wrap:wrap}.ccc-plan-tag{font-size:11px;padding:2px 8px;border-radius:6px}.ccc-plan-tag.green{background:#dcfce7;color:#15803d}.ccc-plan-tag.orange{background:#ffedd5;color:#c2410c}.ccc-arrow{color:var(--text-muted);flex-shrink:0}.ccc-actions{display:flex;gap:0;border-top:1px solid var(--border)}.ccc-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}.ccc-action-btn+.ccc-action-btn{border-left:1px solid var(--border)}.ccc-action-btn.chat{color:var(--primary)}.ccc-action-btn.chat:hover{background:#f0fdf4}.ccc-action-btn.plan{color:#6366f1}.ccc-action-btn.plan:hover{background:#f0f0ff}.ccc-action-btn.remove{color:#ef4444;flex:none;padding:10px 16px}.ccc-action-btn.remove:hover{background:#fef2f2}.coach-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.coach-empty p{margin-bottom:6px;font-size:14px}.coach-empty .btn{margin-top:16px;display:inline-flex;align-items:center;gap:6px}.coach-loading{text-align:center;padding:40px;color:var(--text-muted)}.coach-tab-row{display:flex;gap:8px;margin-bottom:20px}.coach-tab-btn{display:flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:1.5px solid var(--border);background:#fff;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.coach-tab-btn.active{border-color:var(--primary);background:#f0fdf4;color:var(--primary)}.coach-analytics-table{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.coach-analytics-row{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;transition:border-color .2s}.coach-analytics-row.inactive{border-color:#fca5a5;background:#fff5f5}.car-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark, #16a34a));color:#fff;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.car-info{flex:1;min-width:0}.car-name{font-weight:700;font-size:14px;color:var(--text-primary);margin-bottom:4px}.car-stats{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.car-inactive-badge{background:#fef2f2;color:#dc2626;font-size:10px;font-weight:700;border-radius:6px;padding:3px 7px;border:1px solid #fca5a5;flex-shrink:0}.coach-broadcast{padding:16px;margin-bottom:4px}.coach-broadcast-sub{font-size:13px;color:var(--text-muted);margin:0 0 10px}.coach-broadcast-textarea{width:100%;resize:vertical;font-size:14px;line-height:1.5}@media (max-width: 600px){.coach-stats-row{gap:8px}.coach-stat-card{padding:12px 10px}.coach-stat-num{font-size:18px}.coach-add-row{flex-direction:column}}.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}.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:18px;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:7px 12px;border-radius:8px;font-size:13px;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: 768px){.top-nav-links,.top-nav-right{display:none}.top-nav-logo{font-size: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: 64px;--bottom-nav-h: 68px}*,*: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}}@supports (padding: env(safe-area-inset-bottom)){.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)}.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))}}@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}
