*{box-sizing:border-box;margin:0;padding:0}:root{--ink:#111;--ink-soft:#2c2c2e;--surface:#fff;--surface-muted:#f3f2f4;--canvas:#e5e3e6;--chip:#d9d7da;--primary-green:#111;--primary-green-dark:#000;--primary-green-light:#3a3a3c;--primary-green-lighter:#9a989b;--primary-green-bg:#11111112;--bg-primary:#fff;--bg-secondary:#e5e3e6;--bg-sidebar:#111;--text-primary:#111;--text-secondary:#5f5d61;--text-tertiary:#98969a;--border-color:#dbd9dc;--border-color-strong:#c6c4c8;--shadow:0 2px 10px #0000000d;--shadow-md:0 6px 18px #00000014;--shadow-lg:0 14px 34px #0000001f;--bottom-bar-height:76px;--top-bar-height:56px;--sidebar-width:240px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--radius-pill:999px}html,body{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary);overscroll-behavior-y:none;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}#root{flex-direction:column;min-height:100svh;display:flex}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.app-shell{background-color:var(--bg-secondary);min-height:100svh;display:flex}.app-shell--desktop{flex-direction:row}.app-shell--desktop .app-shell__main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100svh;display:flex}.app-shell--desktop .app-shell__content{width:100%;max-width:1280px;margin:0 auto;padding:2rem 2.5rem 2.5rem}.app-sidebar{width:var(--sidebar-width);background:var(--ink);color:#ffffffeb;z-index:50;border-right:1px solid #ffffff0f;flex-direction:column;height:100svh;padding:1.25rem .875rem;display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 20px #00000026}.app-sidebar__brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:.5rem .5rem 1.25rem;display:flex}.app-sidebar__logo{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));letter-spacing:.5px;color:#fff;place-items:center;width:40px;height:40px;font-weight:700;display:grid;box-shadow:0 4px 12px #22c55e4d}.app-sidebar__brand-text{flex-direction:column;display:flex}.app-sidebar__brand-title{color:#fff;font-size:.95rem;font-weight:700}.app-sidebar__brand-subtitle{color:#ffffff8c;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem}.app-sidebar__nav{flex-direction:column;flex:1;gap:.25rem;margin-top:1rem;display:flex}.app-sidebar__link{--nav-hole:var(--ink);border-radius:var(--radius-md);color:#ffffffbf;align-items:center;gap:.75rem;padding:.75rem .875rem;font-size:.92rem;font-weight:500;transition:background-color .2s,color .2s,transform .2s;display:flex}.app-sidebar__link:hover{color:#fff;background:#ffffff0d;transform:translate(2px)}.app-sidebar__link.is-active{color:#fff;box-shadow:inset 3px 0 0 var(--primary-green);background:linear-gradient(135deg,#22c55e2e,#22c55e14)}.app-sidebar__link svg{opacity:.85;flex-shrink:0}.app-sidebar__link.is-active svg{color:var(--primary-green-light);opacity:1}.app-sidebar__footer{border-top:1px solid #ffffff14;flex-direction:column;gap:.625rem;padding-top:.875rem;display:flex}.app-sidebar__user{border-radius:var(--radius-md);background:#ffffff0a;align-items:center;gap:.625rem;padding:.5rem;display:flex}.app-sidebar__avatar{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:grid}.app-sidebar__user-info{flex-direction:column;min-width:0;display:flex}.app-sidebar__user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.app-sidebar__user-email{color:#ffffff8c;white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.app-sidebar__logout{border-radius:var(--radius-md);color:#ffffffd9;cursor:pointer;background:0 0;border:1px solid #ffffff14;justify-content:center;align-items:center;gap:.5rem;padding:.6rem .75rem;font-size:.85rem;font-weight:600;transition:background-color .2s,color .2s,border-color .2s;display:flex}.app-sidebar__logout:hover{color:#fecaca;background:#ef44441f;border-color:#ef44444d}.app-shell--mobile{flex-direction:column;min-height:100svh}.app-shell--mobile .app-shell__content{padding:calc(var(--safe-top) + 1rem) 1rem calc(var(--bottom-bar-height) + var(--safe-bottom) + 1.25rem);flex:1;width:100%}.app-top-bar{height:calc(var(--top-bar-height) + var(--safe-top));padding-top:var(--safe-top);-webkit-backdrop-filter:saturate(180%)blur(16px);border-bottom:1px solid var(--border-color);z-index:40;background:#e5e3e6eb;grid-template-columns:44px 1fr 44px;align-items:center;padding-inline:.75rem;display:grid;position:sticky;top:0;left:0;right:0}.app-top-bar__left,.app-top-bar__right{justify-content:center;align-items:center;display:flex}.app-top-bar__title{color:var(--text-primary);text-align:center;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1rem;font-weight:600;overflow:hidden}.app-top-bar__icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;place-items:center;transition:background-color .2s;display:grid}.app-top-bar__icon-btn:hover,.app-top-bar__icon-btn:focus-visible{background:var(--bg-secondary);outline:none}.app-top-bar__logo{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;place-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:grid;box-shadow:0 4px 12px #22c55e4d}.app-bottom-bar{left:50%;bottom:calc(.875rem + var(--safe-bottom));background:var(--ink);border-radius:var(--radius-pill);z-index:40;width:min(380px,100% - 2rem);position:fixed;transform:translate(-50%);box-shadow:0 12px 30px #0000004d}.app-bottom-bar__list{grid-template-columns:repeat(4,1fr);justify-items:center;margin:0;padding:.5rem;list-style:none;display:grid}.app-bottom-bar__item{display:flex}.app-bottom-bar__link{-webkit-tap-highlight-color:transparent;text-decoration:none;display:block}.app-bottom-bar__inner{place-items:center;display:grid}.app-bottom-bar__icon{background:var(--ink-soft);color:#ffffffc7;--nav-hole:var(--ink-soft);border-radius:50%;place-items:center;width:52px;height:52px;transition:background-color .25s,color .25s,transform .25s;display:grid}.app-bottom-bar__icon.is-active{color:var(--ink);--nav-hole:#fff;background:#fff;transform:translateY(-1px)}.app-bottom-bar__label{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.page{flex-direction:column;gap:1.25rem;display:flex}.page-header{flex-direction:column;gap:.5rem;display:flex}.page-title{letter-spacing:-.02em;color:var(--text-primary);margin:0;font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin:0;font-size:.95rem}.section-title{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.25rem}.card-stack{flex-direction:column;gap:.875rem;display:flex}.btn-primary{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 4px 12px #22c55e40}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #22c55e59}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;transition:background-color .2s,border-color .2s;display:inline-flex}.btn-ghost:hover{background:var(--bg-secondary);border-color:var(--primary-green);color:var(--primary-green-dark)}.empty-state{text-align:center;color:var(--text-secondary);background:var(--bg-primary);border:1px dashed var(--border-color-strong);border-radius:var(--radius-lg);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2rem 1rem;display:flex}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-inline-loading{color:var(--text-secondary);align-items:center;gap:.55rem;margin-top:.35rem;font-size:.9rem;display:flex}.page-inline-error{flex-wrap:wrap;align-items:center;gap:.65rem;margin-top:.35rem;display:flex}.page-inline-error p{color:#b45309;flex:1;min-width:140px;margin:0;font-size:.9rem}.greet{align-items:center;gap:.75rem;display:flex}.greet__avatar{background:var(--ink);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:48px;height:48px;font-size:.95rem;font-weight:700;display:grid}.greet__text{flex:1;min-width:0}.greet__hello{letter-spacing:-.02em;color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:800;line-height:1.25}.greet__date{color:var(--text-secondary);margin:0;font-size:.8rem}.greet__actions{gap:.5rem;display:flex}.greet__icon-btn{background:var(--surface);width:42px;height:42px;color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow);border:none;border-radius:50%;place-items:center;transition:transform .2s,box-shadow .2s;display:grid}.greet__icon-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.day-chips{grid-template-columns:repeat(7,1fr);gap:.4rem;display:grid}.day-chip{border-radius:var(--radius-pill);background:var(--surface);box-shadow:var(--shadow);border:1px solid #0000;flex-direction:column;align-items:center;gap:.2rem;min-width:0;padding:.55rem .15rem .5rem;display:flex}.day-chip__label{color:var(--text-secondary);letter-spacing:.02em;font-size:.68rem;font-weight:700}.day-chip__icon{background:var(--surface-muted);width:26px;height:26px;color:var(--text-secondary);border-radius:50%;place-items:center;display:grid}.day-chip--rest .day-chip__icon{color:var(--text-tertiary)}.day-chip--today{background:var(--ink);box-shadow:0 6px 16px #00000040}.day-chip--today .day-chip__label{color:#ffffffd9}.day-chip--today .day-chip__icon{color:#fff;background:#ffffff29}.home-hero-card{background:var(--ink);color:#fff;border-radius:var(--radius-xl);padding:1.5rem 1.5rem 1.4rem;position:relative;overflow:hidden;box-shadow:0 14px 30px #00000038}.home-hero-card__eyebrow{letter-spacing:.04em;color:#ffffffa6;margin:0 0 .3rem;font-size:.78rem;font-weight:600}.home-hero-card__title{letter-spacing:-.02em;text-transform:uppercase;margin:0;font-size:1.75rem;font-weight:800;line-height:1.15}.home-hero-card__sub{color:#ffffffb3;max-width:75%;margin:.35rem 0 1.1rem;font-size:.85rem}.home-hero-card__cta{color:var(--ink);border-radius:var(--radius-pill);background:#fff;align-items:center;gap:.45rem;padding:.6rem 1.1rem;font-size:.85rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:inline-flex}.home-hero-card__cta:hover{transform:translateY(-1px);box-shadow:0 6px 16px #00000059}.home-hero-card__deco{color:#ffffff14;pointer-events:none;position:absolute;bottom:-1.25rem;right:-.75rem;transform:rotate(-18deg)}.home-section-title{letter-spacing:-.01em;margin:.25rem 0 -.5rem;font-size:1.05rem;font-weight:800}.home-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);align-items:center;gap:.9rem;padding:1rem 1.1rem;transition:transform .2s,box-shadow .2s;display:flex}.home-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.home-card__icon{border-radius:var(--radius-md);background:var(--surface-muted);width:44px;height:44px;color:var(--ink);flex-shrink:0;place-items:center;display:grid}.home-card__body{flex:1;min-width:0}.home-card__eyebrow{letter-spacing:.03em;color:var(--text-secondary);text-transform:uppercase;font-size:.72rem;font-weight:600;display:block}.home-card__title{letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:.1rem 0 0;font-size:1rem;font-weight:700;overflow:hidden}.home-card__meta{color:var(--text-secondary);flex-wrap:wrap;gap:.65rem;margin-top:.2rem;font-size:.78rem;display:flex}.home-card__meta span{align-items:center;gap:.3rem;display:inline-flex}.home-card__chevron{color:var(--text-tertiary);flex-shrink:0}.home-card__progress{margin-top:.5rem}.home-card__progress-track{background:var(--surface-muted);border-radius:999px;height:8px;overflow:hidden}.home-card__progress-fill{background:var(--ink);border-radius:999px;height:100%}.home-card__progress-text{color:var(--text-secondary);margin-top:.3rem;font-size:.74rem;display:block}.h-date-strip{-webkit-overflow-scrolling:touch;scrollbar-width:thin;width:100%;padding-bottom:2px;overflow:auto hidden}.h-date-strip::-webkit-scrollbar{height:5px}.h-date-strip::-webkit-scrollbar-thumb{background:var(--border-color-strong,var(--border-color));border-radius:999px}.h-date-strip__track{flex-flow:row;gap:.45rem;min-width:min-content;padding:.15rem .05rem .35rem;display:flex}.h-date-strip__day{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:48px;color:var(--text-secondary);cursor:pointer;flex-direction:column;flex:none;align-items:center;gap:.2rem;padding:.55rem .35rem .72rem;font-weight:600;transition:border-color .2s,color .2s,background-color .2s,transform .2s;display:flex;position:relative}.h-date-strip__day:hover{border-color:var(--primary-green-light);transform:translateY(-1px)}.h-date-strip__label{text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.h-date-strip__num{color:var(--text-primary);font-size:1rem;font-weight:700}.h-date-strip__day.is-today .h-date-strip__num{color:var(--primary-green-dark)}.h-date-strip__day.is-active{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;border-color:#0000;box-shadow:0 6px 14px #22c55e59}.h-date-strip__day.is-active .h-date-strip__num,.h-date-strip__day.is-active .h-date-strip__label{color:#fff}.h-date-strip__dot{background:var(--primary-green);border-radius:50%;width:5px;height:5px;position:absolute;bottom:6px}.h-date-strip__day.is-active .h-date-strip__dot{background:#fff}.exercise-image-lightbox{z-index:10050;box-sizing:border-box;background:#0f172aeb;flex-direction:column;justify-content:center;align-items:center;padding:3rem 1rem 1.5rem;display:flex;position:fixed;inset:0}.exercise-image-lightbox__close{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:999px;place-items:center;width:2.5rem;height:2.5rem;transition:background-color .15s;display:grid;position:absolute;top:.65rem;right:.65rem}.exercise-image-lightbox__close:hover{background:#ffffff38}.exercise-image-lightbox__main{flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;max-width:520px;min-height:0;display:flex}.exercise-image-lightbox__img{object-fit:contain;border-radius:var(--radius-md);width:auto;max-width:100%;height:auto;max-height:min(70vh,520px)}.exercise-image-lightbox__cap{color:#f8fafce0;text-align:center;margin:.6rem 0 0;padding:0 .25rem;font-size:.82rem;line-height:1.4}.exercise-image-lightbox__dots{flex-wrap:wrap;justify-content:center;gap:.35rem;padding-top:.75rem;display:flex}.exercise-image-lightbox__dot{cursor:pointer;background:#ffffff59;border:none;border-radius:50%;width:7px;height:7px;padding:0}.exercise-image-lightbox__dot.is-on{background:#fff;transform:scale(1.15)}.exercise-media-compact{flex-wrap:wrap;align-items:center;gap:.35rem;margin:.28rem 0 .4rem;display:flex}.exercise-media-compact__link,.exercise-media-compact__btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--primary-green-dark);cursor:pointer;border-radius:999px;align-items:center;gap:.3rem;padding:.28rem .55rem;font-family:inherit;font-size:.72rem;font-weight:600;text-decoration:none;display:inline-flex}.exercise-media-compact__link:hover,.exercise-media-compact__btn:hover{background:var(--primary-green-bg);border-color:var(--primary-green-light)}.exercise-media-compact__thumbs{gap:.25rem;display:inline-flex}.exercise-media-compact__thumb{border-radius:var(--radius-sm);border:1px solid var(--border-color);flex-shrink:0;width:36px;height:36px;overflow:hidden}.exercise-media-compact__thumb img{object-fit:cover;width:100%;height:100%;display:block}.workout-page .page-header{margin-bottom:.35rem}.workout-program-picker{flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;display:flex}.workout-program-picker__chip{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.28rem .55rem;font-size:.72rem;font-weight:600;transition:background-color .15s,border-color .15s,color .15s}.workout-program-picker__chip.is-active{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.workout-panel{flex-direction:column;gap:.65rem;display:flex}.workout-panel__hint{color:var(--text-secondary);margin:0;font-size:.84rem;line-height:1.45}.workout-panel__hint strong{color:var(--text-primary)}.workout-panel__sessions{flex-direction:column;gap:0;display:flex}.workout-session{padding:.75rem 0 0}.workout-session:first-child{padding-top:0}.workout-session+.workout-session{margin-top:.85rem}.workout-session__head{margin-bottom:.6rem}.workout-session__title{background:var(--ink);color:#fff;border-radius:var(--radius-sm);letter-spacing:.02em;text-transform:uppercase;margin:0;padding:.3rem .8rem;font-size:.82rem;font-weight:800;line-height:1.4;display:inline-block}.workout-session__meta{color:var(--text-secondary);margin:.18rem 0 0;font-size:.72rem;line-height:1.35}.workout-session__empty{color:var(--text-secondary);margin:0;font-size:.8rem}.workout-session__list{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.workout-session__ex{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.workout-ex__head{text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;grid-template-columns:1.5rem minmax(0,1fr) auto;align-items:center;gap:.55rem;width:100%;padding:.8rem .95rem;display:grid}.workout-ex__headtext{flex-direction:column;gap:.1rem;min-width:0;display:flex}.workout-ex__summary{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;line-height:1.4;overflow:hidden}.workout-ex__done{color:var(--ink);vertical-align:-2px;margin-left:.3rem}.workout-ex__chev{color:var(--text-tertiary);transition:transform .2s}.workout-session__ex.is-open .workout-ex__chev{transform:rotate(180deg)}.workout-ex__detail{flex-direction:column;gap:.4rem;padding:0 .95rem .85rem 3rem;display:flex}.workout-session__idx{color:var(--text-tertiary);font-size:.72rem;font-weight:800;line-height:1.45}.workout-session__body{flex-direction:column;gap:.28rem;min-width:0;display:flex}.workout-session__name{color:var(--text-primary);font-size:.86rem;font-weight:600;line-height:1.38}.workout-session__note{color:var(--text-tertiary);margin:0;font-size:.74rem;line-height:1.45}.workout-session .exercise-media-compact{margin:0}.workout-metrics{flex-wrap:wrap;gap:.35rem;margin-top:.12rem;display:flex}.workout-metrics__pill{border-radius:var(--radius-pill);background:var(--surface-muted);border:1px solid #0000;align-items:center;gap:.28rem;padding:.28rem .5rem;display:inline-flex}.workout-metrics__pill--wide{flex-wrap:wrap}.workout-metrics__unit{text-transform:uppercase;letter-spacing:.05em;color:var(--primary-green-dark);opacity:.88;font-size:.62rem;font-weight:700}.workout-metrics__val{color:var(--primary-green-dark);letter-spacing:-.02em;font-size:.84rem;font-weight:800;line-height:1}.workout-metrics__val--mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.78rem}@media (width<=380px){.workout-metrics__pill{padding:.24rem .42rem}.workout-metrics__val{font-size:.8rem}}.workout-logs-hint{color:var(--text-secondary);align-items:center;gap:.4rem;margin:0;font-size:.78rem;display:flex}.workout-panel__datestrong{color:var(--text-secondary);margin:0 0 .35rem;font-size:.82rem;font-weight:600}.workout-panel__datestrong span{font-variant-numeric:tabular-nums}.workout-session__row-actions{flex-wrap:wrap;align-items:center;gap:.35rem;margin-top:.35rem;display:flex}.workout-log-badge{color:#1d4ed8;background:#3b82f61f;border:1px solid #3b82f638;border-radius:999px;align-items:center;gap:.22rem;padding:.14rem .45rem;font-size:.65rem;font-weight:700;display:inline-flex}.workout-log-badge--done{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.workout-log-btn{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;align-items:center;gap:.3rem;padding:.32rem .55rem;font-size:.72rem;font-weight:600;transition:border-color .15s,background-color .15s;display:inline-flex}.workout-log-btn:hover{border-color:var(--primary-green-light);background:var(--primary-green-bg);color:var(--primary-green-dark)}.workout-sheet-backdrop{z-index:80;background:#0f172a6b;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.workout-sheet{-webkit-overflow-scrolling:touch;background:var(--bg-primary);width:100%;max-width:520px;max-height:min(92vh,640px);padding:.35rem 1rem calc(1rem + var(--safe-bottom,0px));border:1px solid var(--border-color);border-bottom:none;border-radius:1.1rem 1.1rem 0 0;overflow:auto;box-shadow:0 -10px 40px #0f172a2e}.workout-sheet__handle{background:var(--border-color);border-radius:999px;width:36px;height:4px;margin:.25rem auto .65rem}.workout-sheet__title{color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem;font-weight:700;line-height:1.35}.workout-sheet__form{flex-direction:column;gap:.65rem;display:flex}.workout-sheet__field span{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.7rem;font-weight:600;display:block}.workout-sheet__field input,.workout-sheet__field textarea{box-sizing:border-box;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);padding:.58rem .7rem;font-size:.94rem}.workout-sheet__field textarea{resize:vertical;min-height:4rem}.workout-sheet__check{flex-direction:row;align-items:center;gap:.5rem;display:flex}.workout-sheet__check span{text-transform:none;color:var(--text-primary);margin:0;font-size:.88rem}.workout-sheet__check input[type=checkbox]{width:1.05rem;height:1.05rem;accent-color:var(--primary-green-dark)}.workout-sheet__error{color:#b91c1c;margin:0;font-size:.82rem}.workout-sheet__actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;padding-bottom:.15rem;display:flex}.workout-sheet__actions .btn-primary{min-width:6rem}@media (width>=480px){.workout-sheet-backdrop{align-items:center;padding:1.5rem}.workout-sheet{border-radius:var(--radius-lg);border:1px solid var(--border-color);max-height:min(86vh,560px);padding:.5rem 1.25rem 1.25rem}.workout-sheet__handle{display:none}}.meal-page .page-header{margin-bottom:.35rem}.meal-plan-picker{flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;display:flex}.meal-plan-picker__chip{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.28rem .55rem;font-size:.72rem;font-weight:600;transition:background-color .15s,border-color .15s,color .15s}.meal-plan-picker__chip.is-active{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.meal-tabs{grid-template-columns:repeat(3,1fr);gap:.3rem;margin-bottom:.45rem;display:grid}.meal-tab{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;gap:.32rem;padding:.38rem .4rem;font-family:inherit;font-size:.76rem;font-weight:600;transition:background-color .15s,border-color .15s,color .15s;display:inline-flex}.meal-tab:hover{border-color:var(--primary-green-light);color:var(--primary-green-dark)}.meal-tab.is-active{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.meal-strip{flex-wrap:wrap;gap:.35rem;margin-bottom:.55rem;display:flex}.meal-strip__pill{background:var(--primary-green-bg);border:1px solid var(--primary-green-light);color:var(--primary-green-dark);border-radius:999px;align-items:center;gap:.3rem;padding:.26rem .5rem;display:inline-flex}.meal-strip__pill--neutral{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.meal-strip__lbl{text-transform:uppercase;letter-spacing:.05em;opacity:.85;font-size:.62rem;font-weight:700}.meal-strip__val{letter-spacing:-.02em;font-size:.84rem;font-weight:800}.meal-panel{padding-top:.15rem}.empty-state--compact{padding:1.25rem 1rem}.empty-state--compact svg{opacity:.55}.empty-state--compact p{color:var(--text-secondary);margin:.35rem 0 0;font-size:.88rem}.meal-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.meal-item{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.meal-item+.meal-item{margin-top:.6rem}.meal-item__head{text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:.55rem;width:100%;padding:.75rem .9rem;display:flex}.meal-item__headtext{flex-direction:column;flex:1;gap:.08rem;min-width:0;display:flex}.meal-item__name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.86rem;font-weight:600;line-height:1.38;overflow:hidden}.meal-item__serving{color:var(--text-secondary);font-size:.72rem;line-height:1.35}.meal-item__chev{color:var(--text-tertiary);flex-shrink:0;transition:transform .2s}.meal-item.is-open .meal-item__chev{transform:rotate(180deg)}.meal-item__detail{flex-direction:column;gap:.4rem;padding:0 .9rem .8rem;display:flex}.meal-item__note{color:var(--text-tertiary);margin:0;font-size:.74rem;line-height:1.45}.meal-metrics{flex-wrap:wrap;gap:.35rem;display:flex}.meal-metrics__pill{border-radius:var(--radius-sm);background:var(--primary-green-bg);border:1px solid var(--primary-green-light);align-items:center;gap:.28rem;padding:.26rem .48rem;display:inline-flex;box-shadow:0 1px 2px #22c55e12}.meal-metrics__pill--muted{opacity:.85;border-style:dashed}.meal-metrics__unit{text-transform:uppercase;letter-spacing:.05em;color:var(--primary-green-dark);opacity:.88;font-size:.62rem;font-weight:700}.meal-metrics__val{color:var(--primary-green-dark);letter-spacing:-.02em;font-size:.84rem;font-weight:800;line-height:1}.meal-metrics__suffix{color:var(--primary-green-dark);opacity:.75;font-size:.68rem;font-weight:700}.meal-summary{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow);flex-direction:column;gap:.9rem;padding:1.25rem 1.25rem 1.1rem;display:flex}.meal-summary__kcal{color:var(--text-primary);justify-content:center;align-items:baseline;gap:.45rem;display:flex}.meal-summary__kcal svg{color:var(--ink);align-self:center}.meal-summary__kcal strong{letter-spacing:-.03em;font-size:2.2rem;font-weight:800;line-height:1}.meal-summary__kcal span{color:var(--text-secondary);font-size:.85rem;font-weight:600}.meal-summary__macros{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.meal-summary__macro{flex-direction:column;align-items:center;gap:.3rem;min-width:0;display:flex}.meal-summary__macro-val{letter-spacing:-.01em;color:var(--text-primary);font-size:.92rem;font-weight:800}.meal-summary__macro-bar{background:var(--surface-muted);border-radius:999px;width:100%;height:7px;overflow:hidden}.meal-summary__macro-fill{background:var(--ink);border-radius:999px;height:100%;transition:width .4s;display:block}.meal-summary__macro-label{color:var(--text-secondary);font-size:.74rem;font-weight:700}.meal-item__time{background:var(--ink);color:#fff;font-variant-numeric:tabular-nums;vertical-align:1px;border-radius:999px;flex-shrink:0;padding:.08rem .45rem;font-size:.68rem;font-weight:700;display:inline-block}.account-hero{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem;display:flex}.account-hero__avatar{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:56px;height:56px;font-size:1.1rem;font-weight:700;display:grid;box-shadow:0 6px 14px #22c55e4d}.account-hero__name{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.account-hero__email{color:var(--text-secondary);margin:.15rem 0 0;font-size:.85rem}.account-tabs{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);grid-template-columns:repeat(3,1fr);gap:.4rem;padding:.3rem;display:grid}.account-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.6rem .75rem;font-size:.85rem;font-weight:600;transition:background-color .2s,color .2s}.account-tab.is-active{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;box-shadow:0 4px 12px #22c55e40}.account-info-card .section-title{margin-bottom:.85rem}.account-profile-form{flex-direction:column;gap:.75rem;display:flex}.account-static-field{border-bottom:1px dashed var(--border-color);margin:0;padding-bottom:.65rem}.account-static-field .account-info-label{margin-bottom:.2rem;display:block}.account-field-hint{color:var(--text-tertiary);margin-top:.25rem;font-size:.72rem;display:block}.account-form-field{flex-direction:column;gap:.28rem;display:flex}.account-form-field>span:first-child{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.account-form-field input,.account-form-field select{box-sizing:border-box;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);padding:.58rem .72rem;font-size:.94rem}.account-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.account-form-grid--full{grid-column:1/-1}.account-form-error{color:#b91c1c;margin:0;font-size:.82rem}.account-form-ok{color:var(--primary-green-dark);margin:0;font-size:.82rem;font-weight:600}.account-profile-form .btn-primary{align-self:flex-start;margin-top:.15rem}.account-info-list{flex-direction:column;gap:.65rem;margin:0;padding:0;list-style:none;display:flex}.account-info-list li{border-bottom:1px dashed var(--border-color);align-items:center;gap:.85rem;padding:.6rem .5rem;display:flex}.account-info-list li:last-child{border-bottom:none}.account-info-list svg{color:var(--primary-green-dark);flex-shrink:0}.account-info-list>li>div{flex-direction:column;display:flex}.account-info-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:600}.account-info-value{color:var(--text-primary);font-size:.9rem;font-weight:600}.contract-row{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:inherit;box-shadow:var(--shadow);grid-template-columns:44px 1fr 18px;align-items:center;gap:.85rem;padding:.95rem 1rem;text-decoration:none;transition:transform .2s,border-color .2s,box-shadow .2s;display:grid}.contract-row:hover{border-color:var(--primary-green-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.contract-row__icon{border-radius:var(--radius-md);background:var(--primary-green-bg);width:44px;height:44px;color:var(--primary-green-dark);place-items:center;display:grid}.contract-row__title{color:var(--text-primary);font-size:.95rem;font-weight:700}.contract-row__meta{color:var(--text-secondary);margin-top:.15rem;font-size:.78rem}.contract-row__status{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.78rem;display:flex}.contract-row__paid{color:var(--text-primary);margin-left:auto;font-weight:600}.contract-row__chev{color:var(--text-tertiary)}.badge{border-radius:999px;align-items:center;gap:.3rem;padding:.18rem .5rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge--active{background:var(--primary-green-bg);color:var(--primary-green-dark)}.badge--expired{color:#b91c1c;background:#ef44441a}.account-security__row{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.account-security__icon{border-radius:var(--radius-md);color:#2563eb;background:#3b82f61f;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.account-security__text{flex:1;min-width:180px}.account-security__text p{color:var(--text-secondary);margin:.2rem 0 0;font-size:.85rem}.account-logout{background:var(--bg-primary);border-radius:var(--radius-md);color:#b91c1c;cursor:pointer;border:1px solid #ef444440;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.85rem 1rem;font-weight:600;transition:background-color .2s,border-color .2s;display:inline-flex}.account-logout:hover{background:#ef444414;border-color:#ef444473}@media (width>=1024px){.account-logout{align-self:flex-start;max-width:240px}}.profile-hero{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow);align-items:center;gap:.9rem;padding:1.1rem 1.15rem;display:flex}.profile-hero__avatar{background:var(--ink);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:64px;height:64px;font-size:1.2rem;font-weight:800;display:grid}.profile-hero__text{flex:1;min-width:0}.profile-hero__name{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.15rem;font-weight:800;overflow:hidden}.profile-hero__stats{color:var(--text-secondary);flex-wrap:wrap;gap:.7rem;margin-top:.15rem;font-size:.76rem;display:flex}.profile-hero__stats strong{color:var(--text-primary);font-weight:800}.profile-section-title{letter-spacing:-.01em;margin:.25rem 0 -.6rem;font-size:1.02rem;font-weight:800}.profile-stat-grid{grid-template-columns:1fr 1fr;gap:.7rem;display:grid}.profile-stat-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:column;gap:.2rem;padding:.9rem 1rem;display:flex}.profile-stat-card__label{color:var(--text-secondary);font-size:.74rem;font-weight:600}.profile-stat-card__value{letter-spacing:-.02em;font-size:1.35rem;font-weight:800}.profile-card{border-radius:var(--radius-lg);box-shadow:var(--shadow);border:none}.profile-card__head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.7rem;display:flex}.profile-card__head .section-title{align-items:center;gap:.4rem;font-weight:800;display:inline-flex}.profile-link-soft{color:var(--text-secondary);font-size:.78rem;font-weight:700}.profile-link-btn{background:var(--surface-muted);border-radius:var(--radius-pill);cursor:pointer;border:none;align-items:center;gap:.25rem;padding:.35rem .7rem;display:inline-flex}.profile-muted{color:var(--text-secondary);margin:0;font-size:.84rem}.profile-muted-sm{color:var(--text-tertiary);font-size:.72rem}.profile-banner-error{color:#b45309;margin:0;font-size:.85rem}.profile-chart{width:100%;height:120px;color:var(--ink)}.profile-log-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.profile-log-row{align-items:center;gap:.6rem;padding:.5rem 0;font-size:.82rem;display:flex}.profile-log-row+.profile-log-row{border-top:1px solid var(--border-color)}.profile-log-row__date{color:var(--text-tertiary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.74rem}.profile-log-row__name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:600;overflow:hidden}.profile-pill{background:var(--surface-muted);color:var(--text-secondary);border-radius:999px;flex-shrink:0;align-items:center;gap:.2rem;padding:.12rem .5rem;font-size:.66rem;font-weight:700;display:inline-flex}.profile-pill--ok{background:var(--ink);color:#fff}.profile-photo-strip{-webkit-overflow-scrolling:touch;gap:.55rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.profile-photo{border-radius:var(--radius-md);background:var(--surface-muted);flex-shrink:0;width:96px;height:128px;margin:0;overflow:hidden}.profile-photo img{object-fit:cover;width:100%;height:100%}.profile-checkin-form{border-top:1px solid var(--border-color);flex-direction:column;gap:.65rem;margin-top:.8rem;padding-top:.8rem;display:flex}.profile-field span{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem;font-size:.7rem;font-weight:700;display:block}.profile-field input,.profile-field textarea{box-sizing:border-box;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-muted);width:100%;color:var(--text-primary);padding:.58rem .7rem;font-size:.94rem}.profile-form-error{color:#b91c1c;margin:0;font-size:.82rem}.profile-card--menu{padding:.4rem .5rem}.profile-menu-row{width:100%;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-md);text-align:left;background:0 0;border:none;align-items:center;gap:.7rem;padding:.8rem .7rem;font-size:.88rem;font-weight:600;display:flex}.profile-menu-row:hover{background:var(--surface-muted)}.profile-menu-row span{flex:1}.profile-menu-row__chev{color:var(--text-tertiary)}.profile-menu-row--danger{color:#b91c1c}.profile-menu-row+.profile-menu-row{border-top:1px solid var(--border-color);border-radius:0 0 var(--radius-md) var(--radius-md)}.contract-detail__back{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;align-self:flex-start;align-items:center;gap:.4rem;padding:.5rem .85rem;font-weight:600;transition:background-color .2s,color .2s,border-color .2s;display:inline-flex}.contract-detail__back:hover{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.contract-detail__hero{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem;display:flex}.contract-detail__icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;flex-shrink:0;place-items:center;width:56px;height:56px;display:grid;box-shadow:0 6px 14px #22c55e4d}.contract-detail__eyebrow{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:.72rem;font-weight:600}.contract-detail__title{color:var(--text-primary);margin:.15rem 0 .4rem;font-size:1.2rem;font-weight:700}.contract-detail__status-row{align-items:center;gap:.5rem;display:flex}.contract-detail__list{flex-direction:column;gap:.55rem;margin:.85rem 0 0;padding:0;list-style:none;display:flex}.contract-detail__list li{border-bottom:1px dashed var(--border-color);align-items:center;gap:.85rem;padding:.55rem .4rem;display:flex}.contract-detail__list li:last-child{border-bottom:none}.contract-detail__list svg{color:var(--primary-green-dark);flex-shrink:0}.contract-detail__list>li>div{flex-direction:column;display:flex}.contract-detail__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-size:.72rem;font-weight:600}.contract-detail__value{color:var(--text-primary);font-size:.92rem;font-weight:600}.contract-detail__note{background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);margin:.85rem 0 0;padding:.65rem .85rem;font-size:.85rem}.payment-list{flex-direction:column;gap:.45rem;margin:.85rem 0 0;padding:0;list-style:none;display:flex}.payment-list li{background:var(--bg-secondary);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .85rem;display:flex}.payment-list__date{color:var(--text-secondary);font-size:.78rem;display:block}.payment-list__amount{color:var(--text-primary);margin-top:.15rem;font-size:.95rem;font-weight:700;display:block}.contract-detail__sessions-hint{color:var(--text-secondary);margin:.35rem 0 .75rem;font-size:.82rem;line-height:1.45}.contract-detail__session-filters{flex-wrap:wrap;gap:.45rem;margin-bottom:.85rem;display:flex}.contract-detail__filter-chip{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.35rem .75rem;font-size:.78rem;font-weight:600;transition:background-color .2s,border-color .2s,color .2s}.contract-detail__filter-chip.is-active{background:var(--primary-green-bg);border-color:var(--primary-green-light);color:var(--primary-green-dark)}.contract-detail__sessions-loading,.contract-detail__sessions-error{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:.65rem;padding:.5rem 0;font-size:.88rem;display:flex}.contract-detail__sessions-error p{color:#b45309;flex:1;min-width:160px;margin:0}.contract-detail__sessions-empty{color:var(--text-secondary);margin:.5rem 0 0;font-size:.88rem}.contract-session-list{flex-direction:column;gap:.5rem;margin:.35rem 0 0;padding:0;list-style:none;display:flex}.contract-session-list__item{background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:.65rem .85rem}.contract-session-list__main{flex-direction:column;gap:.35rem;display:flex}.contract-session-list__row{color:var(--text-primary);align-items:center;gap:.45rem;font-size:.88rem;font-weight:600;display:flex}.contract-session-list__row.contract-session-list__meta{color:var(--text-secondary);font-size:.82rem;font-weight:500}.contract-session-list__date{font-weight:700}.contract-session-list__status{text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-sm);align-self:flex-start;padding:.2rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.contract-session-list__status--completed{color:var(--primary-green-dark);background:#22c55e26}.contract-session-list__status--cancelled{color:var(--text-secondary);background:#94a3b840}.contract-session-list__status--no_show{color:#b45309;background:#fbbf2433}.contract-session-list__note{color:var(--text-secondary);margin:.15rem 0 0;font-size:.8rem;line-height:1.45}.login-page{color:#fff;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);justify-content:center;align-items:center;min-height:100svh;padding:2rem;display:flex;position:relative;overflow:hidden}.login-background{z-index:0;position:absolute;inset:0;overflow:hidden}.bg-circle{filter:blur(60px);background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.circle-1{width:400px;height:400px;animation-delay:0s;top:-100px;left:-100px}.circle-2{width:500px;height:500px;animation-delay:5s;bottom:-150px;right:-150px}.circle-3{width:350px;height:350px;animation-delay:10s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{opacity:.4}50%{opacity:.6}}.fireflies{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.firefly{background:var(--primary-green);width:4px;height:4px;box-shadow:0 0 10px var(--primary-green), 0 0 20px var(--primary-green);opacity:0;border-radius:50%;animation:15s ease-in-out infinite firefly-float;position:absolute}.firefly:first-child{animation-duration:12s;animation-delay:0s;left:10%}.firefly:nth-child(2){animation-duration:14s;animation-delay:1s;left:20%}.firefly:nth-child(3){animation-duration:13s;animation-delay:2s;left:30%}.firefly:nth-child(4){animation-duration:15s;animation-delay:3s;left:40%}.firefly:nth-child(5){animation-duration:16s;animation-delay:1.5s;left:50%}.firefly:nth-child(6){animation-duration:11s;animation-delay:2.5s;left:60%}.firefly:nth-child(7){animation-duration:13s;animation-delay:.5s;left:70%}.firefly:nth-child(8){animation-duration:14s;animation-delay:3.5s;left:80%}.firefly:nth-child(9){animation-duration:12s;animation-delay:1.2s;left:90%}.firefly:nth-child(10){animation-duration:15s;animation-delay:4s;left:15%}.firefly:nth-child(11){animation-duration:13s;animation-delay:2.8s;left:25%}.firefly:nth-child(12){animation-duration:14s;animation-delay:.8s;left:45%}.firefly:nth-child(13){animation-duration:12s;animation-delay:3.2s;left:65%}.firefly:nth-child(14){animation-duration:16s;animation-delay:1.8s;left:75%}.firefly:nth-child(15){animation-duration:11s;animation-delay:2.2s;left:85%}@keyframes firefly-float{0%{opacity:0;top:100%;transform:translate(0)scale(1)}10%{opacity:.8}20%{transform:translate(30px)scale(1.2)}40%{transform:translate(-30px)scale(.8)}60%{transform:translate(20px)scale(1.1)}80%{opacity:.8;transform:translate(-20px)scale(.9)}90%{opacity:0}to{opacity:0;top:-10%;transform:translate(0)scale(1)}}.login-container{z-index:1;width:100%;max-width:450px;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;padding:3rem;box-shadow:0 8px 32px #0000004d}.login-logo{text-align:center;margin-bottom:2.5rem}.logo-section{text-align:center;margin-bottom:1.5rem}.logo-image{width:300px;max-width:80%;height:auto;margin:0 auto;display:block}.logo-fallback-mark{color:#fff;letter-spacing:.06em;background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));border-radius:24px;place-items:center;width:120px;height:120px;margin:0 auto;font-size:2rem;font-weight:800;display:grid;box-shadow:0 8px 28px #22c55e59}.login-title{color:#fff;background:linear-gradient(135deg,#fff,#fffc);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2rem;font-weight:700}.login-subtitle{color:#fff9;font-size:.875rem}.error-message{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:12px;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:1rem;font-size:.875rem;display:flex;position:relative}.error-message svg:first-child{color:#ef4444;flex-shrink:0;margin-top:.125rem}.error-content{flex-direction:column;flex:1;gap:.5rem;display:flex}.error-main{color:#fca5a5;font-weight:600}.error-details{flex-direction:column;gap:.25rem;margin:0;padding-left:1.25rem;list-style:outside;display:flex}.error-details li{color:#fca5a5e6;font-size:.8125rem;line-height:1.4}.error-close{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:.25rem;transition:all .2s;display:flex}.error-close:hover{color:#fff;background:#ffffff1a}.login-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.75rem;display:flex}.login-page .form-group label,.login-card .form-group label{align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;display:flex;color:#22c55e!important}.form-group label svg{color:var(--primary-green)}.form-group input{color:#fff;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;width:100%;padding:.875rem 1rem;font-size:.875rem;transition:all .3s}.form-group input::placeholder{color:#fff6}.form-group input:focus{border-color:var(--primary-green);background:#ffffff14;outline:none;box-shadow:0 0 0 3px #22c55e33}.form-group input:disabled{opacity:.65;cursor:not-allowed}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:3rem}.password-toggle{color:#fff9;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;transition:color .3s;display:flex;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.password-toggle:hover{color:var(--primary-green)}.form-options{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.remember-me{color:#ffffffb3;cursor:pointer;align-items:center;gap:.5rem;display:flex}.remember-me input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--primary-green)}.remember-me input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.forgot-password{color:var(--primary-green);font-weight:600;text-decoration:none;transition:all .3s}.forgot-password:hover{color:var(--primary-green-dark);text-decoration:underline}.forgot-password--static{cursor:default;text-align:right;color:#ffffffa6;font-size:.8125rem;font-weight:600}.forgot-password--static:hover{color:#ffffffd9;text-decoration:none}.login-button{background:linear-gradient(135deg, var(--primary-green), var(--primary-green-dark));color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.75rem;width:100%;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 16px #22c55e66}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #22c55e80}.login-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px}.login-footer{text-align:center;color:#fff9;margin-top:2rem;font-size:.875rem}.login-footer--client{line-height:1.55}.signup-link{color:var(--primary-green);font-weight:600;text-decoration:none;transition:all .3s}.signup-link:hover{color:var(--primary-green-light);text-decoration:underline}@media (width<=768px){.login-page{padding:1rem}.login-card{padding:2rem 1.5rem}.login-title{font-size:1.75rem}.logo-image{width:250px}.circle-1,.circle-2,.circle-3{width:300px;height:300px}}@media (width<=480px){.login-card{padding:1.5rem 1rem}.login-title{font-size:1.5rem}.form-options{flex-direction:column;align-items:flex-start}.forgot-password--static{text-align:left}}
