*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a2e;--bg-card-hover:#1f1f35;--border:#2a2a3e;--text-primary:#e8e8f0;--text-secondary:#8888a0;--text-muted:#555570;--accent-green:#0f8;--accent-green-dim:#00cc6a;--accent-blue:#0af;--accent-blue-dim:#08c;--accent-purple:#a6f;--accent-orange:#f84;--accent-pink:#f4a;--accent-yellow:#fc0;--accent-red:#f46;--gradient-macro:linear-gradient(135deg,#0f8,#0af);--gradient-hydration:linear-gradient(135deg,#0af,#a6f);--gradient-fire:linear-gradient(135deg,#f84,#f46);--nav-height:0px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app{max-width:1200px;margin:0 auto;padding:16px 20px;padding-bottom:calc(var(--nav-height) + 16px)}.header{text-align:center;padding:24px 0 16px;border-bottom:1px solid var(--border);margin-bottom:20px}.header h1{font-size:2.2rem;font-weight:900;letter-spacing:-1px;background:var(--gradient-macro);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header .tagline{color:var(--text-secondary);font-size:.85rem;margin-top:4px;font-weight:500}.nav{display:flex;gap:6px;justify-content:center;margin-bottom:24px;flex-wrap:wrap}.nav button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:10px 18px;border-radius:12px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.nav button:hover{background:var(--bg-card-hover);color:var(--text-primary)}.nav button.active{background:var(--bg-card-hover);border-color:var(--accent-green);color:var(--accent-green);box-shadow:0 0 20px rgba(0,255,136,.1)}.bottom-nav{display:none}@media (max-width:768px){:root{--nav-height:64px}.nav{display:none}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border);z-index:1000;justify-content:space-around;padding:6px 0 max(6px,env(safe-area-inset-bottom));backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);height:auto}.bottom-nav button{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text-muted);font-size:.65rem;font-weight:600;font-family:inherit;cursor:pointer;padding:6px 12px;border-radius:10px;transition:all .2s;text-transform:uppercase;letter-spacing:.5px}.bottom-nav button .nav-icon{font-size:1.3rem;line-height:1}.bottom-nav button.active{color:var(--accent-green)}.bottom-nav button.active .nav-icon{filter:drop-shadow(0 0 6px rgba(0,255,136,.4))}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:16px;transition:border-color .2s}.card:hover{border-color:var(--text-muted)}.card h2{font-size:1.1rem;font-weight:800;margin-bottom:14px;letter-spacing:-.5px}.macro-title{background:var(--gradient-macro);-webkit-background-clip:text;background-clip:text}.hydration-title,.macro-title{-webkit-text-fill-color:transparent}.hydration-title{background:var(--gradient-hydration);-webkit-background-clip:text;background-clip:text}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.grid-3{grid-template-columns:1fr 1fr 1fr;grid-gap:14px}.grid-3,.grid-4{display:grid;gap:14px}.grid-4{grid-template-columns:repeat(4,1fr);grid-gap:14px}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr 1fr}.grid-4{gap:10px}.header h1{font-size:1.6rem}.header{padding:16px 0 10px;margin-bottom:12px}.header .tagline{font-size:.75rem}.app{padding:12px 14px;padding-bottom:calc(var(--nav-height) + 12px)}.card{padding:16px;margin-bottom:12px;border-radius:14px}}@media (max-width:480px){.grid-4{grid-template-columns:1fr 1fr}}.stat-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}.stat-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:4px}.stat-value{font-size:1.6rem;font-weight:900;letter-spacing:-1px}.stat-unit{font-size:.7rem;color:var(--text-secondary);font-weight:500}.stat-range{font-size:.65rem;color:var(--text-muted);margin-top:2px}.stat-remaining{font-size:.7rem;font-weight:600;margin-top:4px;line-height:1.3}.stat-pct{font-size:.65rem;color:var(--text-muted);margin-top:2px}.green{color:var(--accent-green)}.blue{color:var(--accent-blue)}.purple{color:var(--accent-purple)}.orange{color:var(--accent-orange)}.pink{color:var(--accent-pink)}.yellow{color:var(--accent-yellow)}.red{color:var(--accent-red)}@media (max-width:768px){.stat-box{padding:12px 8px;border-radius:10px}.stat-value{font-size:1.3rem}.stat-label{letter-spacing:.5px}.stat-label,.stat-range,.stat-remaining,.stat-unit{font-size:.6rem}}.progress-bar-wrap{width:100%;height:6px;background:var(--bg-primary);border-radius:3px;margin-top:8px;overflow:hidden;position:relative}.progress-bar-wrap .goal-marker{position:absolute;top:-1px;width:2px;height:8px;background:var(--text-muted);border-radius:1px;z-index:2}.progress-bar{height:100%;border-radius:3px;transition:width .5s ease}.progress-bar.bar-green{background:var(--gradient-macro)}.progress-bar.bar-blue{background:var(--gradient-hydration)}.progress-bar.bar-orange{background:var(--gradient-fire)}.progress-bar.bar-over{opacity:.7}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:5px}.form-group input,.form-group textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:11px 13px;border-radius:10px;font-size:.95rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-green);box-shadow:0 0 10px rgba(0,255,136,.1)}@media (max-width:768px){.form-group input,.form-group textarea{padding:12px 14px;font-size:16px;border-radius:12px}}.btn{padding:11px 22px;border-radius:12px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s;border:none;font-family:inherit}.btn-primary{background:var(--gradient-macro);color:#000}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,255,136,.3)}.btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.btn-small{padding:6px 14px;font-size:.75rem;border-radius:8px}@media (max-width:768px){.btn{padding:13px 22px;font-size:.9rem;min-height:44px}.btn-small{padding:8px 14px;font-size:.75rem;min-height:36px}}.quick-log-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:10px}.quick-log-btn{display:flex;align-items:center;gap:4px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--accent-blue);padding:8px 14px;border-radius:20px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}.quick-log-btn:hover{border-color:var(--accent-blue);background:rgba(0,170,255,.1);transform:translateY(-1px)}.quick-log-btn:active{transform:scale(.95)}.quick-log-btn.logged-flash{border-color:var(--accent-green);color:var(--accent-green);background:rgba(0,255,136,.1)}.score-card{text-align:center;padding:20px}.score-ring{position:relative;width:100px;height:100px;margin:0 auto 12px}.score-ring svg{transform:rotate(-90deg);width:100px;height:100px}.score-ring .ring-bg{fill:none;stroke:var(--bg-primary);stroke-width:8}.score-ring .ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .8s ease}.score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:900}.score-label{font-size:.8rem;color:var(--text-secondary);font-weight:600}.score-breakdown{display:flex;gap:16px;justify-content:center;margin-top:14px;flex-wrap:wrap}.score-item{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600}@media (max-width:768px){.score-ring,.score-ring svg{width:80px;height:80px}.score-value{font-size:1.2rem}}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 240px);min-height:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.chat-messages{flex:1 1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;-webkit-overflow-scrolling:touch}.chat-bubble{max-width:85%;padding:12px 16px;border-radius:16px;font-size:.9rem;line-height:1.5;word-wrap:break-word}.chat-bubble.user{align-self:flex-end;background:linear-gradient(135deg,#1a3a2e,#1a2a3e);border:1px solid rgba(0,255,136,.2);color:var(--text-primary)}.chat-bubble.assistant{align-self:flex-start;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary)}.chat-bubble .food-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px;margin-top:10px}.chat-bubble .food-card .food-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px;gap:6px;margin-top:8px}.chat-bubble .food-card .food-item{display:flex;justify-content:space-between;font-size:.8rem;padding:4px 8px;background:rgba(0,0,0,.2);border-radius:6px}.chat-bubble .food-card .food-item .label{color:var(--text-muted)}.chat-bubble .food-card .food-item .value{font-weight:700}.chat-bubble .confirm-btn{margin-top:10px;width:100%;padding:10px;background:var(--gradient-macro);border:none;border-radius:10px;font-weight:700;font-size:.85rem;color:#000;cursor:pointer;font-family:inherit;transition:all .2s}.chat-bubble .confirm-btn:hover{opacity:.9;transform:translateY(-1px)}.chat-bubble .confirm-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-bubble .confirm-btn.logged{background:var(--bg-card);border:1px solid var(--accent-green);color:var(--accent-green)}.chat-input-area{padding:16px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:flex-end}.chat-input-area textarea{flex:1 1;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);padding:12px 14px;border-radius:12px;font-size:16px;font-family:inherit;resize:none;min-height:44px;max-height:120px;transition:border-color .2s}.chat-input-area textarea:focus{outline:none;border-color:var(--accent-green)}.chat-input-area .send-btn{width:44px;height:44px;border-radius:12px;background:var(--gradient-macro);border:none;color:#000;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.chat-input-area .send-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(0,255,136,.3)}.chat-input-area .send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.chat-input-area .upload-btn{width:44px;height:44px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.chat-input-area .upload-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.chat-typing{display:flex;gap:4px;padding:4px 0}.chat-typing span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:typingDot 1.4s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.image-preview{max-width:200px;max-height:150px;border-radius:10px;margin-bottom:8px;border:1px solid var(--border)}@media (max-width:768px){.chat-container{height:calc(100vh - 180px);height:calc(100dvh - 180px);border-radius:14px;min-height:300px}.chat-messages{padding:14px;gap:10px}.chat-bubble{max-width:92%;padding:10px 14px;font-size:.88rem;border-radius:14px}.chat-bubble .food-card .food-grid{grid-template-columns:1fr}.chat-input-area{padding:10px;gap:8px}.chat-input-area textarea{min-height:42px;padding:10px 12px}.image-preview{max-width:140px;max-height:100px}}.user-pill{display:inline-flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);padding:7px 14px;border-radius:20px;cursor:pointer;transition:all .2s;font-family:inherit;color:var(--text-primary);font-weight:600;font-size:.8rem}.user-pill.active,.user-pill:hover{border-color:var(--accent-blue);background:var(--bg-card-hover)}.user-pill.active{box-shadow:0 0 15px rgba(0,170,255,.15)}.streak-badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--accent-orange);color:var(--accent-orange);padding:7px 14px;border-radius:20px;font-weight:700;font-size:.8rem;box-shadow:0 0 15px rgba(255,136,68,.1)}@media (max-width:768px){.streak-badge{font-size:.7rem;padding:6px 10px}}.status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px}.status-dot.hit{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.status-dot.close{background:var(--accent-yellow);box-shadow:0 0 6px var(--accent-yellow)}.status-dot.miss{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.history-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -22px;padding:0 22px}.history-table{width:100%;border-collapse:collapse;min-width:600px}.history-table th{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:8px 6px;text-align:right;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;background:var(--bg-card)}.history-table th:first-child{text-align:left}.history-table td{padding:10px 6px;text-align:right;font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(42,42,62,.5)}.history-table td:first-child{text-align:left;font-weight:600;color:var(--text-secondary)}@media (max-width:768px){.history-table-wrap{margin:0 -16px;padding:0 16px}.history-table{min-width:520px}.history-table th{font-size:.6rem;padding:6px 4px}.history-table td{padding:8px 4px;font-size:.8rem}}.onboarding{max-width:480px;margin:40px auto;text-align:center}.onboarding h2{font-size:1.8rem;font-weight:900;margin-bottom:6px;background:var(--gradient-macro);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.onboarding p{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.onboarding .card{text-align:left}@media (max-width:768px){.onboarding{margin:20px auto;padding:0 4px}.onboarding h2{font-size:1.5rem}.onboarding p{font-size:.85rem;margin-bottom:16px}}.chart-container{margin-top:14px;background:var(--bg-secondary);border-radius:12px;padding:14px}@media (max-width:768px){.chart-container{padding:8px 4px;margin-top:10px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}@keyframes pulseGreen{0%{box-shadow:0 0 0 0 rgba(0,255,136,.4)}70%{box-shadow:0 0 0 8px rgba(0,255,136,0)}to{box-shadow:0 0 0 0 rgba(0,255,136,0)}}.date-nav{gap:10px;margin-bottom:20px}.date-nav,.date-nav button{display:flex;align-items:center;justify-content:center}.date-nav button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);width:34px;height:34px;border-radius:10px;cursor:pointer;font-size:1rem;transition:all .2s}.date-nav button:hover{background:var(--bg-card-hover);border-color:var(--text-muted)}.date-display{font-weight:700;font-size:1rem;min-width:160px;text-align:center}.date-today{font-size:.7rem;color:var(--accent-green);font-weight:600;text-align:center}.user-selector{display:flex;gap:6px;justify-content:center;margin-bottom:12px;flex-wrap:wrap}@media (max-width:768px){.user-selector{gap:4px;margin-bottom:8px;overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;padding:0 4px;-webkit-overflow-scrolling:touch}.user-pill{flex-shrink:0;font-size:.75rem;padding:6px 12px}}