:root{--bg-app:#f4f5f7;--bg-surface:#fff;--bg-subtle:#f6f7f9;--bg-soft-pink:#ece7ff;--bg-nav:#101319;--accent:#7c5cff;--accent-press:#6845ff;--accent-glow:#7c5cff73;--text-primary:#0f1115;--text-secondary:#8b92a0;--text-on-dark:#fff;--text-on-dark-muted:#6e7682;--border:#eceef2;--border-strong:#dfe3ea;--success:#2ecc71;--info:#2d8cff;--warning:#ff8a3d;--shadow-card:0 4px 16px #0f172a0a;--shadow-card-strong:0 6px 22px #0f172a0f;--shadow-nav:0 12px 28px #00000038;--shadow-fab:0 10px 24px #7c5cff80;--r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:24px;--r-pill:999px;--gap-xs:6px;--gap-s:10px;--gap-m:12px;--gap-l:16px;--gap-xl:20px;--gap-xxl:24px;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-spring:cubic-bezier(.32, .72, 0, 1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0;padding:0}body{color:var(--text-primary);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;overscroll-behavior-y:none;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:22px}button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:0;height:0}.t-display{letter-spacing:-.01em;font-size:26px;font-weight:800;line-height:32px}.t-h2{letter-spacing:-.01em;font-size:20px;font-weight:700;line-height:26px}.t-metric-xl{letter-spacing:-.02em;font-size:32px;font-weight:800;line-height:36px}.t-metric-l{letter-spacing:-.01em;font-size:22px;font-weight:700;line-height:28px}.t-body{font-size:15px;font-weight:500;line-height:22px}.t-body-strong{font-size:15px;font-weight:700;line-height:22px}.t-caption{color:var(--text-secondary);font-size:12px;font-weight:500;line-height:16px}.t-caption-up{letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-size:11px;font-weight:700;line-height:14px}.emoji{vertical-align:-2px;font-family:Apple Color Emoji,Segoe UI Emoji,Noto Color Emoji,Twemoji Mozilla,EmojiOne Color,sans-serif;font-style:normal;font-weight:400;line-height:1;display:inline-block}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important}}.shell{background:var(--bg-app);justify-content:center;min-height:100dvh;display:flex}.shell__viewport{background:var(--bg-app);flex-direction:column;width:100%;max-width:480px;min-height:100dvh;display:flex;position:relative}.shell__surface{background:var(--bg-surface);border-top-left-radius:var(--r-lg);border-top-right-radius:var(--r-lg);padding:20px 16px calc(112px + env(safe-area-inset-bottom,0px));flex:1;min-height:calc(100dvh - 8px);margin-top:8px;position:relative;overflow:hidden}@media (width>=390px){.shell__surface{padding-left:20px;padding-right:20px}}.tabbar{left:50%;bottom:calc(12px + env(safe-area-inset-bottom,0px));z-index:50;pointer-events:none;width:calc(100% - 32px);max-width:448px;position:fixed;transform:translate(-50%)}.tabbar__pill{pointer-events:auto;background:var(--bg-nav);border-radius:var(--r-pill);height:64px;box-shadow:var(--shadow-nav);grid-template-columns:2fr 1fr 1fr 1fr;align-items:center;padding:0 4px;display:grid;position:relative}.tabbar__item{height:64px;color:var(--text-on-dark-muted);transition:color .18s var(--ease-out), transform .12s var(--ease-out);-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;display:flex;position:relative}.tabbar__item:active{transform:scale(.94)}.tabbar__item.is-active{color:var(--accent)}.tabbar__label{letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:700;line-height:12px}.tabbar__dot{background:var(--accent);opacity:0;width:4px;height:4px;transition:opacity .18s var(--ease-out), transform .18s var(--ease-out);border-radius:999px;position:absolute;bottom:8px;transform:translateY(2px)}.tabbar__item.is-active .tabbar__dot{opacity:1;transform:translateY(0)}.tabbar__fab-slot{justify-content:center;align-items:center;height:64px;display:flex;position:relative}.tabbar__fab{background:var(--accent);color:#fff;width:60px;height:60px;box-shadow:var(--shadow-fab);transition:transform .14s var(--ease-out), background .14s;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.tabbar__fab:active{background:var(--accent-press);transform:translate(-50%)scale(.94)}.toast{left:50%;top:calc(20px + env(safe-area-inset-top,0px));color:#fff;z-index:200;opacity:0;max-width:calc(100% - 32px);transition:opacity .22s var(--ease-out), transform .22s var(--ease-out);pointer-events:none;background:#0f1117f2;border-radius:14px;align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:600;display:flex;position:fixed;transform:translate(-50%,-16px);box-shadow:0 12px 32px #00000040}.toast.is-visible{opacity:1;transform:translate(-50%)}.toast__dot{background:var(--accent);border-radius:999px;flex-shrink:0;width:8px;height:8px}.toast--success .toast__dot{background:var(--success)}.toast--error .toast__dot{background:var(--accent)}.toast__msg{line-height:18px}.avatar{flex-shrink:0;position:relative}.avatar__img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.avatar__placeholder{color:#fff;letter-spacing:.02em;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;font-weight:800;display:flex;box-shadow:inset 0 -2px 6px #00000014}.avatar__online{background:var(--success);border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;bottom:1px;right:1px}.sheet-root{z-index:100;pointer-events:none;position:fixed;inset:0}.sheet-root.is-open{pointer-events:auto}.sheet-backdrop{opacity:0;transition:opacity .2s var(--ease-out);background:#0f111773;position:absolute;inset:0}.sheet-root.is-open .sheet-backdrop{opacity:1}.sheet{background:var(--bg-surface);border-top-left-radius:var(--r-xl);border-top-right-radius:var(--r-xl);width:100%;max-width:480px;max-height:92dvh;transition:transform .32s var(--ease-spring);padding-bottom:env(safe-area-inset-bottom,0px);flex-direction:column;margin:0 auto;display:flex;position:absolute;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%)}.sheet-root.is-open .sheet{transform:translateY(0)}.sheet__grabber{background:#d5d8de;border-radius:999px;flex-shrink:0;width:36px;height:4px;margin:8px auto 0}.sheet__head{flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.sheet__title{margin:0}.sheet__close{background:var(--bg-subtle);width:36px;height:36px;color:var(--text-primary);transition:transform .12s var(--ease-out), background .12s;border-radius:50%;justify-content:center;align-items:center;display:flex}.sheet__close:active{background:#eceef2;transform:scale(.94)}.sheet__body{flex:1;padding:8px 20px 24px;overflow-y:auto}.home{flex-direction:column;gap:14px;display:flex}.home__hello{justify-content:space-between;align-items:center;margin:4px 0 6px;display:flex}.home__hello-title{margin:0}.accent{color:var(--accent)}.success{color:var(--success)}.card{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-card);padding:18px}.hero{padding:20px}.hero__head{justify-content:space-between;align-items:flex-start;display:flex}.hero__title{margin:8px 0 0}.hero__trophy{color:#e0a53d;filter:drop-shadow(0 2px 4px #e0a53d2e);background:linear-gradient(135deg,#ece7ff 0%,#dcd0ff 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.hero__trophy svg{stroke-width:2px}.hero__progress{align-items:center;gap:20px;margin-top:18px;display:flex}.hero__counts{flex-direction:column;gap:4px;display:flex}.hero__counts-num{align-items:baseline;gap:6px;display:flex}.hero__counts-of{color:var(--text-secondary);font-size:18px;font-weight:600}.stats{grid-template-columns:1fr 1fr;gap:12px;display:grid}.stat{flex-direction:column;gap:6px;min-height:116px;padding:16px;display:flex}.stat--btn{text-align:left;width:100%;transition:transform .14s var(--ease-out), box-shadow .14s}.stat--btn:active{box-shadow:var(--shadow-card-strong);transform:scale(.98)translateY(1px)}.row--btn{text-align:left;width:100%;transition:transform .14s var(--ease-out)}.row--btn:active{transform:scale(.99)}.stat__head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.stat__icon--green{color:var(--success)}.stat__icon--accent{color:var(--accent)}.stat__delta{align-items:center;gap:4px;display:flex}.stat__delta--green{color:var(--success);font-weight:600}.topweek{flex-direction:column;gap:10px;margin-top:4px;display:flex}.topweek__head{justify-content:space-between;align-items:center;margin-top:6px;padding:0 4px;display:flex}.topweek__link{color:var(--accent);letter-spacing:.08em;align-items:center;gap:6px;font-size:11px;font-weight:700;transition:opacity .12s;display:inline-flex}.topweek__link:active{opacity:.7}.topweek__list{flex-direction:column;gap:12px;display:flex}.row{align-items:center;gap:12px;min-height:72px;padding:12px 16px 12px 12px;display:flex}.row__main{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.row__sub{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.row__dot{background:var(--text-secondary);border-radius:999px;width:3px;height:3px}.row__count{text-align:right;flex-shrink:0}.row__count .t-metric-l{margin-bottom:4px;line-height:1}.band{flex-direction:column;gap:14px;display:flex}.band__title{margin:4px 0 6px}.band__filters{grid-template-columns:1fr 1fr;gap:12px;padding:14px;display:grid}.band__filter{flex-direction:column;gap:8px;display:flex}.band__select{background:var(--bg-subtle);border-radius:var(--r-md);height:48px;position:relative}.band__select select{appearance:none;width:100%;height:100%;color:var(--text-primary);cursor:pointer;background:0 0;padding:0 36px 0 16px;font-weight:700}.band__caret{color:var(--text-secondary);pointer-events:none;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.band__list{flex-direction:column;gap:12px;margin-top:4px;display:flex}.band__row{text-align:left;width:100%;min-height:72px;transition:transform .12s var(--ease-out), box-shadow .14s;align-items:center;gap:12px;padding:12px 16px 12px 12px;display:flex}.band__row:active{box-shadow:var(--shadow-card-strong);transform:scale(.99)}.band__row-main{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.band__row-sub{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.band__row-dot{background:var(--text-secondary);border-radius:999px;width:3px;height:3px}.band__row-count{text-align:right;flex-shrink:0}.band__row-count .t-metric-l{margin-bottom:4px;line-height:1}.band__empty{text-align:center;flex-direction:column;align-items:center;padding:40px 16px;display:flex}.profile{flex-direction:column;gap:18px;display:flex}.profile__hello{justify-content:space-between;align-items:center;margin:4px 0 0;display:flex}.profile__hello-title{margin:0}.profile__section{flex-direction:column;gap:10px;display:flex}.profile__section-head{justify-content:space-between;display:flex}.profile__list{flex-direction:column;gap:12px;display:flex}.workout-row{text-align:left;width:100%;transition:transform .12s var(--ease-out);align-items:center;gap:12px;padding:14px 12px;display:flex}.workout-row:active{transform:scale(.99)}.workout-row__emoji{background:var(--bg-soft-pink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.workout-row__main{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.workout-row__chev{color:var(--accent);flex-shrink:0}.profile__about{padding:18px}.profile__about-text{margin:0}.profile__divider{background:var(--border);height:1px;margin:16px 0}.profile__about-meta{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile__about-vline{background:var(--border);align-self:stretch;width:1px}.profile__empty{text-align:center;flex-direction:column;align-items:center;padding:32px 16px;display:flex}.profile__edit{border-radius:var(--r-pill);background:var(--bg-subtle);height:52px;color:var(--text-primary);letter-spacing:.06em;text-transform:uppercase;transition:transform .12s var(--ease-out), background .12s;margin-top:6px;font-size:14px;font-weight:700}.profile__edit:active{background:#eceef2;transform:scale(.98)}.title-bolt{color:var(--warning);vertical-align:-4px}.form{flex-direction:column;gap:18px;padding-bottom:8px;display:flex}.field{flex-direction:column;gap:8px;display:flex}.field__err{color:var(--accent);font-size:12px}.input{background:var(--bg-subtle);height:52px;color:var(--text-primary);border-radius:26px;width:100%;padding:0 18px;font-size:15px;font-weight:700;transition:box-shadow .14s,background .14s}.input::placeholder{color:var(--text-secondary);font-weight:500}.input:focus{box-shadow:0 0 0 1.5px var(--accent) inset;background:#fff}.textarea{resize:vertical;border-radius:22px;height:auto;min-height:110px;padding:14px 18px;font-weight:500;line-height:22px}.chips{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.chip{background:var(--bg-subtle);height:64px;transition:transform .12s var(--ease-out), box-shadow .14s, background .14s;border-radius:22px;flex-direction:column;justify-content:center;align-items:center;gap:4px;display:flex}.chip__dot{border-radius:999px;width:8px;height:8px}.chip__label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary);font-size:12px;font-weight:700}.chip:active{transform:scale(.96)}.chip.is-active{box-shadow:0 0 0 1.5px var(--accent) inset, var(--shadow-card-strong);background:#fff}.dropzone{border-radius:var(--r-lg);background:var(--bg-surface);width:100%;transition:transform .12s var(--ease-out), border-color .14s;border:1.5px dashed #e2e5eb;flex-direction:column;align-items:center;gap:6px;padding:22px 16px;display:flex}.dropzone:active{border-color:var(--accent);transform:scale(.99)}.dropzone__icon{background:var(--bg-soft-pink);width:48px;height:48px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.dropzone--filled{border-style:solid;border-color:var(--border);padding:0;position:relative;overflow:hidden}.dropzone--filled img{object-fit:cover;width:100%;height:200px;display:block}.dropzone__remove{color:#fff;background:#0f1117a6;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:absolute;top:8px;right:8px}.btn-primary{border-radius:var(--r-pill);background:var(--accent);color:#fff;letter-spacing:.06em;text-transform:uppercase;height:56px;transition:transform .12s var(--ease-out), background .14s, box-shadow .14s;margin-top:4px;font-size:14px;font-weight:700;box-shadow:0 8px 20px #7c5cff59}.btn-primary:active{background:var(--accent-press);transform:scale(.98)}.btn-primary:disabled{color:#9aa0ac;box-shadow:none;cursor:not-allowed;background:#e5e7eb}.btn-secondary-danger{border-radius:var(--r-pill);background:var(--bg-subtle);color:#ef4444;letter-spacing:.04em;height:52px;transition:transform .12s var(--ease-out), background .14s;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.btn-secondary-danger:active{background:#fee4e2;transform:scale(.98)}.title-spark{color:#f4c540;vertical-align:-3px}.settings{flex-direction:column;gap:18px;padding-bottom:8px;display:flex}.select-wrap{position:relative}.select-wrap select{appearance:none;cursor:pointer;padding-right:40px;font-weight:700}.select-caret{color:var(--text-secondary);pointer-events:none;position:absolute;top:50%;right:16px;transform:translateY(-50%)}
