@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Space+Grotesk:wght@500;600;700;800&family=DM+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg-deep: #060A14;--color-bg: #080F1C;--color-surface: #0A1220;--color-surface-2: #101a2e;--color-surface-3: #16223a;--color-text: #F0F1F4;--color-text-muted: rgba(240, 241, 244, .62);--color-text-faint: rgba(240, 241, 244, .42);--color-gold: #F4C95D;--color-gold-bright: #FCD34D;--color-gold-deep: #B45309;--color-lime: #5EFC8D;--color-lime-bright: #86FFAB;--color-lime-deep: #15803D;--color-fire: #F97316;--color-fire-bright: #FB923C;--color-danger: #DC2626;--color-danger-bright: #EF4444;--color-water: #38BDF8;--color-water-bright: #7DD3FC;--color-water-deep: #0369A1;--color-protein: #F472B6;--color-protein-bright: #FB7185;--color-border: rgba(240, 241, 244, .1);--color-border-strong: rgba(240, 241, 244, .18);--chip-good-fg: #4ade80;--chip-good-bg: rgba(74, 222, 128, .12);--chip-good-bd: rgba(74, 222, 128, .25);--chip-warn-fg: #fbbf24;--chip-warn-bg: rgba(251, 191, 36, .12);--chip-warn-bd: rgba(251, 191, 36, .25);--chip-bad-fg: #f87171;--chip-bad-bg: rgba(255, 71, 87, .12);--chip-bad-bd: rgba(255, 71, 87, .25);--chip-neutral-fg: rgba(240, 241, 244, .62);--chip-neutral-bg: rgba(255, 255, 255, .06);--chip-neutral-bd: rgba(240, 241, 244, .18);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--nav-h: 64px}html,body,#root{min-height:100%;height:100%}body{background:radial-gradient(ellipse at 80% -10%,rgba(244,201,93,.1),transparent 55%),radial-gradient(ellipse at -10% 110%,rgba(94,252,141,.05),transparent 55%),var(--color-bg);background-attachment:fixed;color:var(--color-text);font-family:Syne,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none}input,textarea,select{background:#fafafa0a;border:1px solid var(--color-border);border-radius:10px;padding:12px 14px;color:var(--color-text);font-family:Syne,sans-serif;font-size:15px;outline:none;width:100%;transition:border-color .2s;-webkit-appearance:none}input:focus,textarea:focus,select:focus{border-color:var(--color-gold)}input::placeholder{color:var(--color-text-muted)}button{font-family:Syne,sans-serif;cursor:pointer;border:none;background:transparent;color:inherit;-webkit-tap-highlight-color:transparent}button:disabled{opacity:.35;cursor:not-allowed}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}a{color:var(--color-gold-bright);text-decoration:none}a:hover{text-decoration:underline}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.15);opacity:1}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulseRing{0%{box-shadow:0 0 #f4c95d73}to{box-shadow:0 0 0 16px #f4c95d00}}@keyframes xpFly{0%{transform:translateY(0) scale(.8);opacity:0}20%{transform:translateY(-8px) scale(1.1);opacity:1}80%{transform:translateY(-44px) scale(1);opacity:1}to{transform:translateY(-72px) scale(.9);opacity:0}}@keyframes confetti{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(var(--cx, 0),var(--cy, 80px)) rotate(540deg);opacity:0}}@keyframes flicker{0%,to{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-1px) scale(1.05);opacity:.92}}@keyframes ripple{0%{transform:scale(.4);opacity:.5}to{transform:scale(2.4);opacity:0}}.app-shell{min-height:100dvh;display:flex;flex-direction:column;padding-top:var(--safe-top);padding-bottom:calc(var(--nav-h) + var(--safe-bottom));max-width:720px;margin:0 auto}.app-header{display:flex;align-items:center;gap:.8rem;padding:.9rem 1.1rem .6rem}.app-header-brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1rem;letter-spacing:-.01em}.app-header-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(180deg,#f4c95d38,#b453091a);border:1px solid rgba(244,201,93,.3);display:flex;align-items:center;justify-content:center;color:var(--color-gold-bright);font-weight:800;font-size:15px}.app-header-sub{color:var(--color-text-faint);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}.app-header-spacer{flex:1}.app-header-signout{background:#ffffff0a;border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:8px;padding:6px 11px;font-size:.74rem;font-weight:600}.app-main{flex:1;padding:.4rem 1.1rem 1.5rem;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#0a1220eb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;align-items:stretch;z-index:50}.bottom-nav-inner{width:100%;max-width:720px;margin:0 auto;display:flex;justify-content:space-around;align-items:stretch}.nav-link{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--color-text-faint);text-decoration:none;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;transition:color .15s;padding:4px 0 6px;position:relative}.nav-link.active{color:var(--color-gold-bright)}.nav-link.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--color-gold);border-radius:0 0 2px 2px}.nav-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}.nav-icon svg{width:100%;height:100%;stroke-width:2}.gate-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.gate-card{width:100%;max-width:380px;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:16px;padding:2rem 1.8rem;text-align:center;animation:fadeUp .3s ease-out}.gate-mark{width:60px;height:60px;border-radius:16px;background:linear-gradient(180deg,#f4c95d38,#b453091a);border:1px solid rgba(244,201,93,.3);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;color:var(--color-gold-bright);font-weight:800;font-size:24px}.gate-title{font-size:1.35rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.5rem}.gate-sub{color:var(--color-text-muted);font-size:.88rem;margin-bottom:1.5rem;line-height:1.4}.gate-form{display:flex;flex-direction:column;gap:.7rem}.gate-primary{background:linear-gradient(180deg,var(--color-gold),var(--color-gold-deep));border:1px solid rgba(244,201,93,.45);color:#1a0e00;border-radius:10px;padding:12px 16px;font-weight:700;font-size:.92rem;transition:transform .1s,box-shadow .15s;box-shadow:0 4px 14px #f4c95d33}.gate-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #f4c95d4d}.gate-err{color:var(--chip-bad-fg);font-size:.78rem;margin-top:.5rem}.gate-ok{color:var(--chip-good-fg);font-size:.85rem;line-height:1.45}.section{margin-bottom:1.6rem}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;margin-bottom:.7rem;padding:0 2px}.section-title{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted)}.section-action{font-size:.74rem;color:var(--color-gold-bright);font-weight:600}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:1.05rem 1.15rem}.card-padded{padding:1.3rem 1.25rem}.card-tight{padding:.85rem 1rem}.card-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.85rem}.card-title{font-size:.84rem;font-weight:700;letter-spacing:.01em}.card-eyebrow{font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-faint)}.hero-card{background:radial-gradient(ellipse at 100% 0%,rgba(244,201,93,.18),transparent 60%),linear-gradient(180deg,var(--color-surface-2),var(--color-surface));border:1px solid var(--color-border-strong);border-radius:18px;padding:1.3rem 1.3rem 1.2rem;position:relative;overflow:hidden;margin-bottom:1.4rem}.hero-row{display:flex;align-items:center;gap:.95rem;margin-bottom:.95rem}.level-badge{width:60px;height:60px;flex-shrink:0;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fcd34dd9,#b45309d9),linear-gradient(180deg,#fcd34d,#b45309);border:2px solid rgba(252,211,77,.55);box-shadow:0 6px 20px #f4c95d52,inset 0 -4px 8px #0003;display:flex;align-items:center;justify-content:center;position:relative}.level-badge-num{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:1.55rem;color:#1a0e00;line-height:1}.level-badge-tag{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);background:var(--color-bg);border:1px solid var(--color-gold);color:var(--color-gold-bright);font-size:.55rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:1px 7px;border-radius:4px;white-space:nowrap}.hero-text{flex:1;min-width:0}.hero-greeting{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-faint);font-weight:700;margin-bottom:.15rem}.hero-title{font-size:1.15rem;font-weight:800;letter-spacing:-.01em;color:var(--color-text)}.hero-title b{color:var(--color-gold-bright)}.hero-sub{font-size:.78rem;color:var(--color-text-muted);margin-top:.15rem}.xp-bar-wrap{display:flex;flex-direction:column;gap:6px}.xp-bar{position:relative;height:12px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:999px;overflow:hidden}.xp-bar-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,var(--color-gold),var(--color-gold-bright));box-shadow:0 0 12px #f4c95d73;border-radius:999px;transition:width .7s cubic-bezier(.16,1,.3,1)}.xp-bar-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2.4s linear infinite;border-radius:999px;pointer-events:none}.xp-bar-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--color-text-muted);font-family:Space Grotesk,sans-serif;font-weight:600}.xp-bar-labels b{color:var(--color-gold-bright)}.xp-float{position:fixed;left:50%;bottom:calc(var(--nav-h) + var(--safe-bottom) + 24px);transform:translate(-50%);background:linear-gradient(180deg,var(--color-gold),var(--color-gold-deep));color:#1a0e00;font-family:Space Grotesk,sans-serif;font-weight:800;font-size:.95rem;letter-spacing:.02em;padding:9px 16px;border-radius:12px;border:1px solid rgba(252,211,77,.55);box-shadow:0 8px 24px #f4c95d73;animation:xpFly 1.6s ease-out forwards;pointer-events:none;z-index:100}.streak-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem}.streak-chip{background:#ffffff08;border:1px solid var(--color-border);border-radius:12px;padding:.65rem .7rem;display:flex;align-items:center;gap:.55rem;min-width:0}.streak-chip.fire{background:linear-gradient(180deg,#f9731626,#f973160d);border-color:#f9731659}.streak-flame{width:26px;height:26px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;animation:flicker 1.4s ease-in-out infinite}.streak-flame.dim{opacity:.35;animation:none}.streak-meta{min-width:0}.streak-count{font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:800;line-height:1;color:var(--color-text)}.streak-count.fire-on{color:var(--color-fire-bright)}.streak-label{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--color-text-muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}.today-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:.95rem 1rem;display:flex;align-items:center;gap:.9rem;text-decoration:none;color:inherit;transition:border-color .15s,transform .1s}.today-tile:hover{border-color:var(--color-border-strong)}.today-tile:active{transform:scale(.99)}.today-tile.done{border-color:#5efc8d4d;background:linear-gradient(180deg,#5efc8d0f,#5efc8d05)}.ring{width:54px;height:54px;flex-shrink:0;position:relative}.ring svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#ffffff12;stroke-width:7}.ring-fg{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.16,1,.3,1)}.ring-fg.gold{stroke:var(--color-gold-bright)}.ring-fg.lime{stroke:var(--color-lime)}.ring-fg.protein{stroke:var(--color-protein-bright)}.ring-fg.water{stroke:var(--color-water-bright)}.ring-fg.fire{stroke:var(--color-fire-bright)}.ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;letter-spacing:.06em;color:var(--color-text)}.today-meta{min-width:0}.today-meta-label{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--color-text-muted)}.today-meta-value{font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:800;line-height:1.1;margin-top:1px;color:var(--color-text)}.today-meta-value b{font-weight:800}.today-meta-sub{font-size:.72rem;color:var(--color-text-muted);margin-top:1px}.today-meta-sub b{color:var(--color-text);font-weight:600}.macro-list{display:flex;flex-direction:column;gap:.65rem}.macro-row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:.7rem}.macro-label{font-size:.74rem;font-weight:700;letter-spacing:.04em;color:var(--color-text)}.macro-label.protein{color:var(--color-protein-bright)}.macro-label.carbs{color:var(--color-gold-bright)}.macro-label.fat{color:var(--color-lime)}.macro-track{position:relative;height:10px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:999px;overflow:hidden}.macro-fill{height:100%;border-radius:999px;transition:width .6s cubic-bezier(.16,1,.3,1)}.macro-fill.protein{background:linear-gradient(90deg,var(--color-protein),var(--color-protein-bright))}.macro-fill.carbs{background:linear-gradient(90deg,var(--color-gold-deep),var(--color-gold-bright))}.macro-fill.fat{background:linear-gradient(90deg,var(--color-lime-deep),var(--color-lime))}.macro-num{font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:700;color:var(--color-text-muted);white-space:nowrap}.macro-num b{color:var(--color-text);font-weight:700}.quest-card{background:radial-gradient(ellipse at 0% 0%,rgba(94,252,141,.16),transparent 60%),linear-gradient(180deg,var(--color-surface-2),var(--color-surface));border:1px solid rgba(94,252,141,.25);border-radius:14px;padding:1rem 1.15rem;position:relative;overflow:hidden}.quest-eyebrow{font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--color-lime);margin-bottom:.35rem;display:flex;align-items:center;gap:.4rem}.quest-title{font-size:1.05rem;font-weight:800;letter-spacing:-.005em;color:var(--color-text);margin-bottom:.3rem}.quest-meta{font-size:.78rem;color:var(--color-text-muted)}.quest-meta b{color:var(--color-lime-bright)}.quest-reward{position:absolute;top:.85rem;right:.9rem;font-family:Space Grotesk,sans-serif;font-weight:800;font-size:.78rem;letter-spacing:.04em;color:var(--color-gold-bright);background:#f4c95d1a;border:1px solid rgba(244,201,93,.3);padding:3px 8px;border-radius:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:Syne,sans-serif;font-weight:700;font-size:.88rem;letter-spacing:.01em;border-radius:10px;padding:11px 16px;border:1px solid var(--color-border);background:#ffffff0a;color:var(--color-text);transition:transform .1s,border-color .12s,background .12s,box-shadow .15s;text-decoration:none;-webkit-tap-highlight-color:transparent}.btn:hover:not(:disabled){border-color:var(--color-border-strong)}.btn:active:not(:disabled){transform:scale(.98)}.btn-primary{background:linear-gradient(180deg,var(--color-gold),var(--color-gold-deep));color:#1a0e00;border-color:#f4c95d73;box-shadow:0 4px 14px #f4c95d2e}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #f4c95d47}.btn-lime{background:linear-gradient(180deg,var(--color-lime),var(--color-lime-deep));color:#062612;border-color:#5efc8d73;box-shadow:0 4px 14px #5efc8d2e}.btn-lime:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #5efc8d47}.btn-water{background:linear-gradient(180deg,var(--color-water),var(--color-water-deep));color:#03161f;border-color:#38bdf880;box-shadow:0 4px 14px #38bdf833}.btn-ghost{background:#ffffff08;color:var(--color-text)}.btn-danger{background:#dc26261a;border-color:#dc262659;color:var(--color-danger-bright)}.btn-full{width:100%}.btn-lg{padding:14px 18px;font-size:.95rem;border-radius:12px}.btn-sm{padding:7px 11px;font-size:.76rem;border-radius:8px}.fav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem}.fav-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:.7rem .85rem;text-align:left;color:var(--color-text);display:flex;flex-direction:column;gap:.25rem;transition:border-color .12s,transform .1s,background .12s;cursor:pointer;font-family:inherit}.fav-tile:hover{border-color:var(--color-border-strong)}.fav-tile:active{transform:scale(.98);background:#f4c95d0f}.fav-tile-name{font-weight:700;font-size:.85rem;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-tile-meta{font-family:Space Grotesk,sans-serif;font-size:.72rem;color:var(--color-text-muted);font-weight:600}.fav-tile-meta b{color:var(--color-gold-bright);font-weight:700}.entry-list{display:flex;flex-direction:column;gap:.45rem}.entry-row{background:#ffffff06;border:1px solid var(--color-border);border-radius:10px;padding:.65rem .85rem;display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.7rem}.entry-row-name{font-weight:600;font-size:.86rem;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-row-cal{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:.84rem;color:var(--color-gold-bright)}.entry-row-cal-unit{color:var(--color-text-faint);font-size:.68rem;font-weight:600;margin-left:2px}.entry-row-x{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--color-text-faint);background:transparent;font-size:1rem;line-height:1;transition:color .12s,background .12s}.entry-row-x:hover{color:var(--color-danger-bright);background:#dc26261a}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.form-grid .full{grid-column:1 / -1}.form-label{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--color-text-muted);margin-bottom:4px;display:block}.workout-hero{background:radial-gradient(ellipse at 100% 100%,rgba(244,201,93,.14),transparent 60%),linear-gradient(180deg,var(--color-surface-2),var(--color-surface));border:1px solid var(--color-border-strong);border-radius:18px;padding:1.3rem 1.3rem 1.2rem;margin-bottom:1.1rem}.workout-hero-eyebrow{font-size:.62rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--color-gold-bright);margin-bottom:.45rem}.workout-hero-title{font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin-bottom:.5rem}.workout-hero-meta{font-size:.82rem;color:var(--color-text-muted);margin-bottom:1rem}.workout-hero-meta b{color:var(--color-text);font-weight:700}.exercise-list{display:flex;flex-direction:column;gap:.5rem}.exercise-row{background:#ffffff06;border:1px solid var(--color-border);border-radius:11px;padding:.75rem .95rem;display:flex;align-items:center;gap:.85rem}.exercise-pip{width:28px;height:28px;border-radius:50%;background:#f4c95d1a;border:1px solid rgba(244,201,93,.3);color:var(--color-gold-bright);font-family:Space Grotesk,sans-serif;font-weight:800;font-size:.78rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exercise-name{flex:1;font-weight:700;font-size:.92rem}.exercise-reps{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:.85rem;color:var(--color-gold-bright)}.history-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem .85rem;border-bottom:1px solid var(--color-border)}.history-row:last-child{border-bottom:none}.history-row-date{font-family:Space Grotesk,sans-serif;font-size:.76rem;font-weight:600;color:var(--color-text-muted)}.history-row-type{font-size:.78rem;font-weight:700;background:#f4c95d1a;border:1px solid rgba(244,201,93,.25);color:var(--color-gold-bright);padding:2px 8px;border-radius:6px}.water-stage{display:flex;flex-direction:column;align-items:center;padding:1rem 0 .5rem}.bottle{width:180px;height:280px;position:relative;margin-bottom:1.3rem}.bottle-svg{width:100%;height:100%}.bottle-fill-rect{transition:y .7s cubic-bezier(.16,1,.3,1),height .7s cubic-bezier(.16,1,.3,1)}.bottle-label{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.bottle-label-value{font-family:Space Grotesk,sans-serif;font-size:2.4rem;font-weight:800;color:var(--color-text);line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.4)}.bottle-label-unit{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-top:5px}.tap-cluster{position:relative;display:flex;justify-content:center;width:100%;margin-bottom:1rem}.tap-btn{width:88px;height:88px;border-radius:50%;background:linear-gradient(180deg,var(--color-water-bright),var(--color-water-deep));border:2px solid rgba(125,211,252,.5);color:#03161f;font-weight:800;font-family:Space Grotesk,sans-serif;font-size:1.15rem;letter-spacing:-.01em;box-shadow:0 8px 30px #38bdf84d;transition:transform .1s,box-shadow .15s;position:relative}.tap-btn:active{transform:scale(.95)}.tap-ripple{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid var(--color-water-bright);animation:ripple .7s ease-out forwards;pointer-events:none}.water-controls{display:flex;gap:.5rem;justify-content:center;margin-top:.5rem}.weigh-input-wrap{display:flex;align-items:center;gap:.5rem;background:#ffffff08;border:1px solid var(--color-border);border-radius:12px;padding:.55rem .5rem .55rem 1rem}.weigh-input{flex:1;background:transparent!important;border:none!important;font-family:Space Grotesk,sans-serif;font-size:1.5rem!important;font-weight:800!important;color:var(--color-text)!important;padding:0!important}.weigh-input:focus{border:none!important}.weigh-unit{font-size:.78rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.04em}.progress-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem;margin-bottom:1rem}.progress-stat{background:#ffffff06;border:1px solid var(--color-border);border-radius:11px;padding:.7rem .8rem}.progress-stat-label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--color-text-muted);margin-bottom:4px}.progress-stat-value{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:1.25rem;line-height:1.05;color:var(--color-text)}.progress-stat-value.gold{color:var(--color-gold-bright)}.progress-stat-value.lime{color:var(--color-lime)}.progress-stat-value.fire{color:var(--color-fire-bright)}.progress-stat-sub{font-size:.7rem;color:var(--color-text-faint);margin-top:2px}.weight-goal-bar{background:#ffffff06;border:1px solid var(--color-border);border-radius:12px;padding:.85rem 1rem}.weight-goal-meta{display:flex;justify-content:space-between;font-size:.72rem;color:var(--color-text-muted);font-family:Space Grotesk,sans-serif;font-weight:600;margin-bottom:7px}.weight-goal-meta b{color:var(--color-text);font-weight:700}.weight-goal-track{height:10px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:999px;overflow:hidden}.weight-goal-fill{height:100%;background:linear-gradient(90deg,var(--color-lime-deep),var(--color-lime));box-shadow:0 0 10px #5efc8d4d;border-radius:999px;transition:width .7s cubic-bezier(.16,1,.3,1)}.chart-wrap{width:100%;position:relative}.chart-wrap svg{width:100%;height:auto;display:block}.chart-axis-y,.chart-axis-x{font-family:Space Grotesk,sans-serif;font-size:9px;fill:var(--color-text-faint);font-weight:600}.chart-grid-line{stroke:#ffffff0d;stroke-width:1}.chart-line{fill:none;stroke:var(--color-gold-bright);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 1px 4px rgba(244,201,93,.3))}.chart-line.lime{stroke:var(--color-lime);filter:drop-shadow(0 1px 4px rgba(94,252,141,.3))}.chart-line.water{stroke:var(--color-water-bright);filter:drop-shadow(0 1px 4px rgba(56,189,248,.3))}.chart-area{fill:url(#chart-area-grad);opacity:.7}.chart-dot{fill:var(--color-gold-bright)}.chart-dot.lime{fill:var(--color-lime)}.chart-dot.water{fill:var(--color-water-bright)}.chart-target-line{stroke:var(--color-lime);stroke-width:1;stroke-dasharray:4 4;opacity:.6}.chart-target-label{font-family:Space Grotesk,sans-serif;font-size:9px;font-weight:700;fill:var(--color-lime)}.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem}@media (max-width: 360px){.ach-grid{grid-template-columns:repeat(2,1fr)}}.ach-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:.85rem .7rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;position:relative}.ach-tile.unlocked{background:linear-gradient(180deg,#f4c95d1a,#f4c95d05);border-color:#f4c95d59}.ach-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid var(--color-border);font-size:1.2rem;color:var(--color-text-faint)}.ach-tile.unlocked .ach-icon{background:linear-gradient(180deg,#fcd34d8c,#b453098c);border-color:#fcd34d8c;color:#1a0e00;box-shadow:0 4px 14px #f4c95d4d}.ach-name{font-size:.72rem;font-weight:700;color:var(--color-text);line-height:1.15}.ach-tile:not(.unlocked) .ach-name{color:var(--color-text-muted)}.ach-sub{font-size:.62rem;color:var(--color-text-faint);line-height:1.25}.plan-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.7rem;padding:.75rem .95rem;border-bottom:1px solid var(--color-border)}.plan-row:last-child{border-bottom:none}.plan-row-label{font-size:.78rem;font-weight:600;color:var(--color-text)}.plan-row-label-sub{font-size:.66rem;color:var(--color-text-faint);margin-top:2px}.plan-row-value{display:flex;align-items:center;gap:.4rem}.plan-value-num{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:1rem;color:var(--color-gold-bright)}.plan-value-unit{font-size:.7rem;font-weight:600;color:var(--color-text-muted)}.plan-row-input{width:80px;text-align:right;font-family:Space Grotesk,sans-serif!important;font-weight:700!important;font-size:.95rem!important;padding:8px 10px!important}.empty-state{padding:1.5rem 1rem;text-align:center;color:var(--color-text-faint);font-size:.84rem;background:#ffffff04;border:1px dashed var(--color-border);border-radius:10px}.toast-stack{position:fixed;top:calc(var(--safe-top) + 12px);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:.4rem;z-index:200;pointer-events:none}.toast{background:var(--color-surface-2);border:1px solid var(--color-border-strong);border-radius:10px;padding:.6rem .9rem;font-size:.82rem;font-weight:600;color:var(--color-text);box-shadow:0 8px 24px #0006;animation:fadeUp .25s ease-out}.toast.lime{border-color:#5efc8d59;color:var(--color-lime-bright)}.toast.gold{border-color:#f4c95d59;color:var(--color-gold-bright)}.level-up-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#060a14b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:250;display:flex;align-items:center;justify-content:center;animation:fadeUp .25s ease-out}.level-up-card{width:min(380px,92vw);background:radial-gradient(ellipse at 50% 0%,rgba(244,201,93,.3),transparent 60%),linear-gradient(180deg,var(--color-surface-2),var(--color-surface));border:1px solid rgba(244,201,93,.4);border-radius:20px;padding:2rem 1.5rem;text-align:center;position:relative;animation:pop .5s ease-out}.level-up-eyebrow{font-size:.74rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--color-gold-bright);margin-bottom:.5rem}.level-up-num{font-family:Space Grotesk,sans-serif;font-size:3.2rem;font-weight:800;line-height:1;color:var(--color-gold-bright);text-shadow:0 4px 18px rgba(244,201,93,.5);margin-bottom:.7rem}.level-up-text{font-size:.94rem;color:var(--color-text);line-height:1.4;margin-bottom:1.4rem}.confetti-piece{position:absolute;top:50%;left:50%;width:8px;height:12px;border-radius:1px;animation:confetti 1.4s ease-out forwards;pointer-events:none}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--color-gold-bright);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.reveal{animation:fadeUp .3s ease-out}
