*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #16a34a;--green-strong: #0f7a37;--green-deep: #0b4f2a;--green-light: #dcfce7;--green-dark: #14532d;--mint: #eaf8ef;--cream: #fffdf4;--peach: #ffe2bf;--red: #dc2626;--red-light: #fee2e2;--yellow: #ca8a04;--yellow-light: #fef9c3;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--bg: radial-gradient(circle at top, #f6fff8 0%, #edf8f0 38%, #e8f4ea 100%);--card: #ffffff;--radius: 16px;--radius-sm: 10px;--shadow: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-xl: 0 30px 60px rgba(15, 84, 45, .12)}body{font-family:Nunito,sans-serif;background:var(--bg);color:var(--gray-800);min-height:100vh;font-size:15px;line-height:1.6}h1,h2,h3{font-family:Fraunces,serif}button{font-family:Nunito,sans-serif;cursor:pointer;border:none;outline:none;transition:all .15s ease}button:active{transform:scale(.97)}input,textarea,select{font-family:Nunito,sans-serif;font-size:15px;outline:none}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.btn-primary{background:var(--green);color:#fff;padding:.65rem 1.4rem;border-radius:100px;font-size:14px;font-weight:700;box-shadow:0 2px 8px #16a34a4d}.btn-primary:hover{background:#15803d;box-shadow:0 4px 12px #16a34a66}.btn-danger{background:var(--red);color:#fff;padding:.65rem 1.4rem;border-radius:100px;font-size:14px;font-weight:700}.btn-danger:hover{background:#b91c1c}.btn-outline{background:transparent;color:var(--green);padding:.6rem 1.4rem;border-radius:100px;font-size:14px;font-weight:700;border:2px solid var(--green)}.btn-outline:hover{background:var(--green-light)}.btn-ghost{background:var(--gray-100);color:var(--gray-700);padding:.6rem 1.2rem;border-radius:100px;font-size:14px;font-weight:600}.btn-ghost:hover{background:var(--gray-200)}.input{width:100%;padding:.7rem 1rem;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:15px;color:var(--gray-800);background:#fff;transition:border-color .15s}.input:focus{border-color:var(--green)}.badge-green{background:var(--green-light);color:var(--green-dark);padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}.badge-red{background:var(--red-light);color:var(--red);padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}.badge-yellow{background:var(--yellow-light);color:var(--yellow);padding:3px 10px;border-radius:100px;font-size:12px;font-weight:700}.page{max-width:480px;margin:0 auto;padding:1rem;min-height:100vh}.score-big{font-family:Fraunces,serif;font-size:3.5rem;font-weight:900;line-height:1}.leaderboard-podium{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-bottom:1rem}.podium-card{position:relative;border-radius:20px;padding:1rem .75rem .9rem;color:#1f2937;text-align:center;box-shadow:var(--shadow-md);overflow:hidden;border:1px solid rgba(255,255,255,.72)}.podium-card.is-first{transform:translateY(-6px);box-shadow:0 14px 28px #ca8a0429}.podium-card.is-me{outline:3px solid rgba(20,83,45,.2)}.podium-badge{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.25rem .55rem;border-radius:999px;font-size:11px;font-weight:800;color:#14532d;background:#ffffffc2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:inset 0 0 0 1px #14532d14}.podium-avatar{width:54px;height:54px;border-radius:50%;margin:.8rem auto .55rem;display:flex;align-items:center;justify-content:center;color:#14532d;background:#ffffffd1;border:2px solid rgba(255,255,255,.95);font-size:1rem;font-weight:900;box-shadow:0 10px 20px #ffffff47}.podium-name{font-size:13px;font-weight:800;line-height:1.2;min-height:32px;color:#111827;text-shadow:0 1px 0 rgba(255,255,255,.3)}.podium-score{font-family:Fraunces,serif;font-size:2.3rem;font-weight:900;line-height:1;margin-top:.35rem;color:#14532d;text-shadow:0 1px 0 rgba(255,255,255,.35)}.podium-points{font-size:11px;color:#4b5563;font-weight:700}.leaderboard-row{display:flex;align-items:center;gap:.75rem;padding:.85rem .95rem;border-radius:16px;background:#f9fafb;border:1px solid #e5e7eb}.leaderboard-row.is-me{background:#f0fdf4;border-color:#86efac}.leaderboard-rank{min-width:38px;font-size:1rem;font-weight:900;color:#14532d;text-align:center}.tab-bar{display:flex;background:#fff;border-radius:100px;padding:4px;box-shadow:var(--shadow);gap:2px}.tab-btn{flex:1;padding:.5rem;border-radius:100px;font-size:13px;font-weight:700;background:transparent;color:var(--gray-500);text-align:center}.tab-btn.active{background:var(--green);color:#fff}.auth-shell{position:relative;min-height:100vh;overflow:hidden;padding:1rem}.auth-bg{position:absolute;border-radius:999px;filter:blur(14px);pointer-events:none}.auth-bg-top{width:340px;height:340px;top:-110px;right:-90px;background:radial-gradient(circle,#fbbf2438,#fbbf2400 72%)}.auth-bg-bottom{width:420px;height:420px;left:-160px;bottom:-180px;background:radial-gradient(circle,#16a34a29,#16a34a00 72%)}.auth-layout{position:relative;z-index:1;max-width:520px;margin:0 auto;min-height:calc(100vh - 2rem);display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:start}.auth-hero{padding:.5rem 0 0;text-align:center}.auth-badge{width:88px;height:88px;display:flex;align-items:center;justify-content:center;border-radius:28px;font-size:2.7rem;background:linear-gradient(135deg,#ffffffe0,#e8f8eaeb);box-shadow:0 20px 45px #14532d1f;margin:0 auto 1.2rem}.auth-kicker{font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--green-strong);margin-bottom:.85rem}.auth-title{max-width:none;font-size:2.45rem;line-height:.98;color:var(--green-deep);margin-bottom:1rem}.auth-subtitle{max-width:none;font-size:.98rem;line-height:1.65;color:var(--gray-600);margin-bottom:1.4rem}.auth-highlights{display:grid;grid-template-columns:1fr;gap:.75rem;max-width:none;text-align:left}.auth-highlight-card{padding:1rem;border-radius:22px;background:#ffffffad;border:1px solid rgba(255,255,255,.78);box-shadow:0 16px 30px #14532d0f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-highlight-card span{display:inline-flex;margin-bottom:.7rem;font-size:1.2rem}.auth-highlight-card strong{display:block;color:var(--green-deep);font-size:14px;margin-bottom:.35rem}.auth-highlight-card p{color:var(--gray-600);font-size:13px;line-height:1.55}.auth-card{width:100%;padding:1.1rem;border-radius:24px;border:1px solid rgba(255,255,255,.78);background:linear-gradient(180deg,#fffffff0,#ffffffe0),linear-gradient(135deg,#eaf8efa6,#fffaf080);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-card-header{margin-bottom:1.25rem}.auth-card-eyebrow{color:var(--green-strong);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem}.auth-card-title{font-size:1.35rem;line-height:1.15;color:var(--green-deep)}.auth-invite{margin-bottom:1rem;background:linear-gradient(135deg,#eff6ff,#f5f3ff);color:#1d4ed8;border:1px solid #bfdbfe;border-radius:16px;padding:.85rem 1rem;font-size:13px;line-height:1.5}.auth-tab-bar{margin-bottom:1.1rem;padding:5px;background:#f0fdf4eb;box-shadow:inset 0 0 0 1px #14532d0f}.auth-form{display:flex;flex-direction:column;gap:.8rem}.auth-input{min-height:54px;border-radius:16px;border-color:#d7e5db;background:#ffffffeb;box-shadow:inset 0 1px #ffffffb3}.auth-input:focus{border-color:var(--green);box-shadow:0 0 0 4px #16a34a1f}.auth-feedback{font-size:13px;padding:.7rem .85rem;border-radius:14px;line-height:1.45}.auth-feedback-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.auth-feedback-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.auth-submit{margin-top:.3rem;min-height:56px;font-size:15px;font-weight:900;background:linear-gradient(135deg,var(--green) 0%,var(--green-strong) 100%);box-shadow:0 16px 30px #16a34a3d}.auth-submit:hover{background:linear-gradient(135deg,#1aae4f,#0f7a37)}.auth-link-button{margin-top:.8rem;background:transparent;color:var(--green-strong);font-size:13px;font-weight:800;text-align:center}.auth-link-button:hover{color:var(--green-deep)}.auth-footer-note{margin-top:1rem;font-size:12px;color:var(--gray-500);line-height:1.6;text-align:center}.main-shell{max-width:560px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top,#ffffffe6,#fff0 42%),linear-gradient(180deg,#eef8f0,#f8fcf8 24%,#f4f8f5)}.main-topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem 1rem;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(209,229,216,.9)}.main-topbar-title{display:flex;align-items:center;gap:.75rem;min-width:0}.main-brand-mark{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:1.35rem;background:linear-gradient(135deg,#f7fff8,#dff4e4);box-shadow:inset 0 0 0 1px #14532d14}.main-challenge-name{font-weight:900;font-size:14px;color:#14532d;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-challenge-meta{font-size:11px;color:#7b8794;margin-top:.15rem}.main-topbar-actions{display:flex;align-items:center;gap:.55rem;flex-shrink:0}.main-icon-button{position:relative;background:linear-gradient(180deg,#fff,#f5fbf6);color:#14532d;width:40px;height:40px;border-radius:999px;font-size:18px;border:1px solid #dcfce7;box-shadow:0 10px 24px #14532d14}.main-pill-button{background:#f0fdf4;color:#166534;font-size:12px;font-weight:800;padding:.55rem .8rem;border-radius:999px;box-shadow:inset 0 0 0 1px #16a34a14}.main-text-button{background:none;color:#94a3b8;font-size:12px;font-weight:700}.main-content{flex:1;padding:1rem}.main-bottom-nav{position:sticky;bottom:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;padding:.75rem 1rem calc(.75rem + env(safe-area-inset-bottom));background:#ffffffe6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(209,229,216,.85)}.main-nav-item{padding:.6rem .35rem;border-radius:16px;background:transparent;color:#94a3b8;display:flex;flex-direction:column;align-items:center;gap:.18rem;font-size:1.15rem;transition:all .18s ease}.main-nav-item.is-active{background:linear-gradient(180deg,#ebfbef,#dcfce7);color:#14532d;box-shadow:inset 0 0 0 1px #16a34a14;transform:translateY(-1px)}.main-nav-label{font-size:10px;font-weight:800}.today-screen{padding:0 0 5rem}.today-screen .card{margin-bottom:1rem;border:1px solid rgba(221,232,224,.95);box-shadow:0 18px 35px #0f542d0f}.today-hero-card{color:#fff;background:radial-gradient(circle at top right,#ffffff2e,#fff0 32%),linear-gradient(135deg,#0f4f2b,#1c8c47 58%,#25b45c)}.today-hero-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.today-hero-card p:first-child{font-size:11px;opacity:.8;font-weight:800;letter-spacing:.08em}.today-hero-card h2{font-size:1.6rem;margin:.2rem 0 0}.today-hero-card button{box-shadow:inset 0 0 0 1px #ffffff2e}.today-water-card{background:linear-gradient(180deg,#f5faff,#fff)}.today-water-header{gap:.75rem}.today-water-header h3,.today-meals-header h3{color:#0f4f2b}.today-water-header p{font-size:12px;color:#64748b;margin-top:.15rem}.today-water-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:.55rem!important}.today-water-action{min-height:46px;font-weight:800;box-shadow:inset 0 0 0 1px #2563eb0d}.today-water-card>p:last-child{margin-top:.65rem!important;color:#64748b!important}.today-meals-card{background:linear-gradient(180deg,#fff,#fbfdfb)}.today-calorie-banner{box-shadow:inset 0 0 0 1px #fb923c14}.today-meals-list{gap:.75rem!important}.today-meals-list .meal-slot{padding:.95rem;border-radius:16px;background:#ffffffeb;box-shadow:0 10px 22px #0f542d0a}.today-meals-list .meal-slot:hover{transform:translateY(-1px)}.today-meals-card>p:last-child{border-radius:12px!important;padding:.7rem .8rem!important}.meal-slot{border:2px dashed var(--gray-200);border-radius:var(--radius-sm);padding:1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .15s}.meal-slot:hover{border-color:var(--green);background:var(--green-light)}.meal-slot.filled{border-style:solid;border-color:var(--green);background:var(--green-light)}.meal-slot.unhealthy{border-color:var(--red);background:var(--red-light)}.water-btn{background:#dbeafe;color:#1e40af;border-radius:var(--radius-sm);padding:.5rem;font-size:1.5rem;text-align:center;cursor:pointer;transition:all .15s;border:2px solid transparent}.water-btn:hover{border-color:#3b82f6}.water-btn.filled{background:#3b82f6;border-color:#2563eb}.msg-bubble{padding:.6rem .9rem;border-radius:18px;max-width:80%;word-break:break-word;font-size:14px;line-height:1.5}.msg-mine{background:var(--green);color:#fff;border-bottom-right-radius:4px;margin-left:auto}.msg-other{background:#fff;color:var(--gray-800);border-bottom-left-radius:4px;box-shadow:var(--shadow)}.progress-bar{background:var(--gray-200);border-radius:100px;height:8px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:100px;transition:width .5s ease}.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0}.day-chip{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;cursor:default;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:1rem}.modal{background:#fff;border-radius:24px 24px 16px 16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:1.5rem}.modal-handle{width:40px;height:4px;background:var(--gray-200);border-radius:100px;margin:0 auto 1.25rem}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.trophy-bounce{animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@media (max-width: 420px){.leaderboard-podium{grid-template-columns:1fr}.podium-card.is-first{transform:none}}@media (min-width: 640px){.main-shell{max-width:900px}.main-content{padding:1.25rem}.main-bottom-nav{width:min(560px,calc(100% - 2rem));margin:0 auto 1rem;border:1px solid rgba(209,229,216,.9);border-radius:24px;box-shadow:0 20px 40px #0f542d14}.auth-shell{padding:1.5rem}.auth-layout{max-width:640px;min-height:calc(100vh - 3rem);gap:1.5rem}.auth-card{padding:1.35rem;border-radius:28px}.auth-card-title{font-size:1.5rem}.auth-highlights{grid-template-columns:repeat(2,minmax(0,1fr))}.today-water-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}}@media (min-width: 920px){.auth-layout{max-width:1120px;min-height:calc(100vh - 4rem);grid-template-columns:minmax(0,1.1fr) minmax(360px,420px);gap:2rem;align-items:center}.auth-hero{padding:1rem 1rem 1rem 0;text-align:left}.auth-badge{margin:0 0 1.4rem}.auth-highlights{grid-template-columns:repeat(3,minmax(0,1fr));max-width:700px}.auth-title{max-width:12ch;font-size:clamp(2.8rem,5vw,4.8rem);line-height:.95}.auth-subtitle{max-width:520px;font-size:1.05rem;line-height:1.7;margin-bottom:1.8rem}.auth-card{padding:1.4rem;border-radius:30px}.auth-card-title{font-size:1.55rem}}
