:root{color:#101828;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--blue:#0b73ff;--blue-dark:#045fe0;--text:#111827;--muted:#667085;--line:#e6eaf0;--surface:#fff;--soft-blue:#eef5ff;--soft-teal:#e9fbf8;--soft-purple:#f3edff;--soft-orange:#fff4e7;--shadow:0 12px 34px #0f172a14;--shadow-soft:0 8px 22px #0f172a0f;background:#f4f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.35}*{box-sizing:border-box}html{overscroll-behavior:none;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;height:100%;overflow:hidden}body{overscroll-behavior:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at top,#fff 0,#f4f7fb 360px),#f4f7fb;min-width:320px;height:100%;margin:0;overflow:hidden}#root{height:100%}button,input,select{appearance:none;font:inherit;-webkit-user-select:text;user-select:text}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.64}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}h1,h2,h3,p,span,strong,small,button,input,select{overflow-wrap:anywhere}h1{color:var(--text);font-size:28px;line-height:1.05}h2{color:var(--text);font-size:24px;line-height:1.12}h3{color:var(--text);font-size:17px}.app-shell{background:#fbfcff;flex-direction:column;max-width:430px;height:100svh;min-height:100svh;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 1px #0f172a0d}.app-header{z-index:10;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;grid-template-columns:48px minmax(0,1fr) 48px;align-items:center;gap:8px;min-height:78px;padding:14px 16px 12px;display:grid;position:sticky;top:0}.app-title{text-align:center;min-width:0}.app-title p{color:var(--muted);margin-top:2px;font-size:16px}.header-actions{justify-content:flex-end;display:flex;position:relative}.header-icon-button{width:48px;height:48px;color:var(--blue);background:0 0;border:0;border-radius:16px;justify-content:center;align-items:center;display:inline-flex}.header-icon-button.danger{color:#e5484d}.app-main{overscroll-behavior:contain;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:22px 16px 116px;overflow-y:auto}.app-main::-webkit-scrollbar{display:none}.bottom-nav{z-index:20;padding:12px 12px calc(12px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff0;border-top:1px solid #e6eaf0e6;border-radius:26px 26px 0 0;grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;display:grid;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -14px 34px #0f172a14}.bottom-nav-link{color:#737b89;border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:58px;font-size:12px;font-weight:700;display:flex}.bottom-nav-link.active{color:var(--blue)}.home-page,.page-stack{gap:22px;display:grid}.hero-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.eyebrow{color:var(--blue);text-transform:uppercase;margin-bottom:4px;font-size:13px;font-weight:800}.muted{color:var(--muted);font-size:15px}.avatar{width:64px;height:64px;color:var(--blue);background:linear-gradient(145deg,#e8f2ff,#f5f0ff);border-radius:50%;flex:none;place-items:center;font-size:26px;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #0b73ff14}.stat-grid{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:24px;grid-template-columns:repeat(2,minmax(0,1fr));display:grid;overflow:hidden}.stat-card{text-align:center;align-content:start;justify-items:center;gap:4px;min-height:118px;padding:18px 8px 14px;display:grid}.stat-card+.stat-card{border-left:1px solid var(--line)}.stat-card:nth-child(odd){border-left:0}.stat-card:nth-child(n+3){border-top:1px solid var(--line)}.stat-card strong{color:var(--text);margin-top:8px;font-size:21px;line-height:1}.stat-card span:not(.soft-icon){color:var(--text);font-size:12px;font-weight:800}.stat-card small{color:var(--muted);font-size:11px}.soft-icon,.template-icon,.simple-page-icon{flex:none;justify-content:center;align-items:center;display:inline-flex}.soft-icon{border-radius:14px;width:38px;height:38px}.soft-icon-blue{background:var(--soft-blue);color:var(--blue)}.soft-icon-teal{background:var(--soft-teal);color:#13aaa4}.soft-icon-purple{background:var(--soft-purple);color:#8b5cf6}.soft-icon-orange{background:var(--soft-orange);color:#f59e0b}.home-actions{gap:12px;display:grid}.action-button,.button{text-align:center;background-clip:padding-box;border:1px solid #0000;border-radius:14px;flex-wrap:nowrap;justify-content:center;align-items:center;gap:10px;min-height:54px;padding:0 18px;font-weight:850;line-height:1.15;display:inline-flex}.action-button-primary,.button{background:var(--blue);color:#fff;box-shadow:none}.action-button-secondary,.button-secondary{background:var(--soft-blue);color:var(--blue);box-shadow:none;border-color:#0b73ff3d}.button-icon{width:54px;padding:0}.dashboard-section{gap:14px;display:grid}.section-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.section-header>div{min-width:0}.section-link{min-height:44px;color:var(--blue);align-items:center;gap:2px;font-size:15px;font-weight:750;display:inline-flex}.template-preview-list,.list,.exercise-grid{gap:12px;display:grid}.template-card,.list-item,.last-workout-card,.form-panel{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:22px}.template-card{grid-template-columns:72px minmax(0,1fr) 28px;align-items:center;gap:14px;min-height:104px;padding:14px 16px;display:grid}.template-icon{border-radius:18px;width:60px;height:60px}.template-card-body{gap:5px;min-width:0;display:grid}.template-card-body strong,.last-workout-card strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:18px;line-height:1.15;overflow:hidden}.template-card-body small,.last-workout-card small{color:var(--muted);font-size:14px}.last-workout-card{grid-template-columns:52px minmax(0,1fr) auto;align-items:center;gap:12px;min-height:88px;padding:16px;display:grid}.last-workout-card>div{gap:5px;min-width:0;display:grid}.inline-action{background:var(--soft-blue);min-height:42px;color:var(--blue);border:0;border-radius:12px;padding:0 12px;font-weight:800}.floating-create-button{display:none}.form-row{grid-template-columns:minmax(0,1fr);gap:10px;display:grid}.text-field{width:100%;min-height:52px;color:var(--text);background:#fff;border:1px solid #d7dde6;border-radius:16px;padding:0 14px}.text-field:focus{border-color:var(--blue);outline:4px solid #0b73ff1f}select.text-field{appearance:none;background-image:linear-gradient(45deg,#0000 50%,#667085 50%),linear-gradient(135deg,#667085 50%,#0000 50%);background-position:calc(100% - 20px) 22px,calc(100% - 14px) 22px;background-repeat:no-repeat;background-size:6px 6px,6px 6px;padding-right:38px}.list-item{gap:12px;padding:16px;display:grid}.template-list-item{padding:0;overflow:hidden}.template-list-link{gap:12px;padding:16px 16px 0;display:grid}.template-list-item>.list-item-row{padding:0 16px 16px}.list-item-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.pill-row{flex-wrap:wrap;gap:7px;display:flex}.pill{background:var(--soft-blue);color:#1d4ed8;border-radius:999px;align-items:center;padding:5px 9px;font-size:12px;font-weight:800;display:inline-flex}.empty-state,.error-state,.loading-state{color:var(--muted);background:#ffffffb3;border:1px dashed #d7dde6;border-radius:20px;padding:18px}.error-state{color:#b42318;background:#fff7f7;border-color:#fecaca}.dev-auth{border:1px solid var(--line);width:160px;box-shadow:var(--shadow-soft);background:#fff;border-radius:16px;gap:6px;padding:10px;display:grid;position:absolute;top:50px;right:0}.dev-auth label{color:var(--muted);font-size:11px;font-weight:800}.dev-auth input{border-radius:12px;min-height:38px}.detail-header{gap:14px;display:grid}.template-titlebar{grid-template-columns:48px minmax(0,1fr) 96px;align-items:center;gap:8px;display:grid}.template-title-actions{justify-content:flex-end;display:flex}.template-title-center{text-align:center;gap:3px;min-width:0;display:grid}.template-title-center h2{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.template-title-form{min-width:0}.template-title-form input{width:100%;min-height:46px;color:var(--text);text-align:center;background:#fff;border:1px solid #d7dde6;border-radius:14px;padding:0 12px;font-size:18px;font-weight:850}.template-title-form input:focus{border-color:var(--blue);outline:4px solid #0b73ff1f}.template-delete-confirm-panel{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px;display:grid}.form-panel{gap:14px;padding:16px;display:grid}.template-exercise-form{gap:12px;display:grid}.field-label{color:var(--muted);gap:7px;font-size:13px;font-weight:800;display:grid}.checkbox-row,.switch-row{width:fit-content;color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:800;display:inline-flex}.checkbox-row input{width:20px;height:20px;accent-color:var(--blue)}.switch-row{gap:10px;min-height:44px}.switch-row input{opacity:0;pointer-events:none;position:absolute}.switch-row span{background:#e7ecf3;border-radius:999px;width:50px;height:30px;transition:background .16s,box-shadow .16s;position:relative;box-shadow:inset 0 0 0 1px #0f172a0f}.switch-row span:after{content:"";background:#fff;border-radius:50%;width:24px;height:24px;transition:transform .16s;position:absolute;top:3px;left:3px;box-shadow:0 3px 8px #0f172a29}.switch-row input:checked+span{background:var(--blue);box-shadow:inset 0 0 0 1px #0b73ff2e}.switch-row input:checked+span:after{transform:translate(20px)}.number-grid{grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:10px;display:grid}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.metric{background:#f5f8ff;border-radius:16px;padding:10px}.metric span{color:var(--muted);font-size:12px;display:block}.metric strong{color:var(--text);font-size:17px}.template-edit-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:22px;gap:14px;padding:16px;display:grid}.template-edit-card-head{grid-template-columns:minmax(0,1fr) 38px 38px;align-items:center;gap:12px;display:grid}.template-exercise-collapse-button{min-width:0;color:inherit;text-align:left;background:0 0;border:0;gap:4px;padding:0;display:grid}.template-exercise-collapse-button h3{text-overflow:ellipsis;white-space:nowrap;font-size:19px;line-height:1.18;overflow:hidden}.template-plan-form{gap:12px;display:grid}.sticky-bottom-action{gap:10px;padding-bottom:8px;display:grid}.simple-page{text-align:center;align-content:center;justify-items:center;gap:12px;min-height:56svh;display:grid}.simple-page-icon{background:var(--soft-blue);width:76px;height:76px;color:var(--blue);border-radius:24px}.simple-page p{max-width:280px;color:var(--muted)}.workout-page{gap:20px;display:grid}.workout-topbar{text-align:center;grid-template-columns:48px minmax(0,1fr) 48px;align-items:center;gap:8px;display:grid}.workout-progress-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:24px;grid-template-columns:58px minmax(0,1fr);align-items:center;gap:14px;padding:18px;display:grid}.workout-progress-card>div{gap:8px;min-width:0;display:grid}.workout-progress-card>strong{grid-column:2;justify-self:end}.workout-progress-card strong{color:var(--text);font-size:17px}.workout-progress-card small{color:var(--muted);font-size:14px}.progress-track{background:#e9edf4;border-radius:999px;height:8px;overflow:hidden}.progress-track span{border-radius:inherit;background:linear-gradient(90deg, #16b8aa 0%, var(--blue) 100%);height:100%;display:block}.workout-exercise-list{gap:16px;display:grid}.workout-exercise-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:24px;gap:16px;padding:16px;display:grid}.workout-exercise-head{grid-template-columns:54px minmax(0,1fr) 28px;align-items:center;gap:14px;display:grid}.workout-exercise-head>div{gap:4px;min-width:0;display:grid}.workout-exercise-head h3{font-size:20px;line-height:1.15}.sets-table{background:#fbfcff;border-radius:18px;display:grid;overflow:hidden}.sets-table-head,.sets-table-row{grid-template-columns:minmax(48px,.8fr) minmax(62px,1fr) minmax(48px,.8fr) 68px;align-items:center;gap:8px;display:grid}.sets-table-bodyweight .sets-table-head,.sets-table-bodyweight .sets-table-row{grid-template-columns:minmax(48px,.9fr) minmax(48px,.9fr) 68px}.sets-table-head{min-height:48px;color:var(--muted);background:#f5f7fb;padding:0 10px;font-size:13px}.sets-table-row{border-top:1px solid var(--line);min-height:58px;color:var(--text);padding:0 10px;font-size:16px}.sets-table-row strong{font-size:18px}.sets-empty{border-top:1px solid var(--line);color:var(--muted);padding:16px 12px}.set-actions{justify-content:flex-end;gap:2px;display:flex}.small-icon-button{color:#687385;background:0 0;border:0;border-radius:12px;justify-content:center;align-items:center;width:32px;height:34px;display:inline-flex}.small-icon-button.danger{color:#e5484d}.set-field{width:100%;min-height:38px;color:var(--text);background:#fff;border:1px solid #d7dde6;border-radius:12px;padding:0 8px}.add-set-form{grid-template-columns:repeat(auto-fit,minmax(112px,1fr));align-items:end;gap:10px;display:grid}.compact-field{color:var(--muted);gap:6px;font-size:13px;font-weight:800;display:grid}.compact-field input{width:100%;min-height:48px;color:var(--text);background:#fff;border:1px solid #d7dde6;border-radius:16px;padding:0 12px}.add-set-button{grid-column:1/-1;min-height:48px}.workout-bottom-actions{gap:12px;margin-top:2px;padding:4px 0 18px;display:grid}.workout-add-exercise-panel{box-shadow:none}.workout-add-exercise-panel>.button{width:100%;min-height:50px}.draft-button{min-height:44px;color:var(--blue);background:0 0;border:0;font-weight:800}.danger-text-button{color:#e5484d}.danger-action-button{color:#c62828;background:#fff7f7;border:1px solid #fecaca;border-radius:14px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 16px;font-weight:850;display:inline-flex}.template-delete-button{color:#c62828;background:#fff7f7;border:0;border-radius:14px;justify-content:center;align-items:center;gap:8px;min-height:46px;padding:0 14px;font-weight:850;display:inline-flex}.template-delete-confirm-button,.template-delete-cancel-button{flex:1}.template-delete-cancel-button{background:var(--soft-blue);border-radius:14px}.history-page{gap:20px;display:grid}.history-summary-grid{grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:10px;display:grid}.history-summary-card{border:1px solid var(--line);background:var(--surface);min-height:116px;box-shadow:var(--shadow-soft);border-radius:22px;align-content:start;gap:12px;padding:14px;display:grid}.history-summary-card strong{color:var(--text);font-size:22px;line-height:1;display:block}.history-summary-card small{color:var(--muted);font-size:13px}.history-group-list{gap:20px;display:grid}.history-group{gap:10px;display:grid}.history-date{min-height:36px;color:var(--muted);text-transform:capitalize;align-items:center;gap:8px;font-size:14px;font-weight:800;display:flex}.history-session-list{gap:12px;display:grid}.history-session-card{border:1px solid var(--line);background:var(--surface);min-height:104px;box-shadow:var(--shadow-soft);border-radius:22px;grid-template-columns:58px minmax(0,1fr) 24px;align-items:center;gap:14px;padding:14px;display:grid}.history-session-body{gap:5px;min-width:0;display:grid}.history-session-body strong{color:var(--text);flex-wrap:wrap;align-items:center;gap:8px;font-size:18px;line-height:1.15;display:flex}.status-badge{background:var(--soft-orange);color:#d97706;border-radius:999px;align-items:center;min-height:22px;padding:0 8px;font-size:11px;font-style:normal;font-weight:850;display:inline-flex}.history-session-body small{color:var(--muted);font-size:14px}.calendar-page{gap:20px;display:grid}.calendar-picker-card,.create-session-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:24px;gap:16px;padding:16px;display:grid}.month-switcher{grid-template-columns:46px minmax(0,1fr) 46px;align-items:center;gap:10px;display:grid}.month-switcher strong{color:var(--text);text-align:center;text-transform:capitalize;font-size:22px;font-weight:850}.month-switcher button{width:46px;height:46px;color:var(--blue);background:#fff;border:1px solid #d7dde6;border-radius:15px;justify-content:center;align-items:center;display:inline-flex}.month-strip{--date-strip-gap:8px;--date-strip-day-width:58px;gap:var(--date-strip-gap);overscroll-behavior-x:contain;scroll-snap-type:x proximity;scrollbar-width:none;touch-action:pan-x;-webkit-overflow-scrolling:touch;padding:2px 0 8px;display:flex;overflow:auto hidden}.month-strip::-webkit-scrollbar{display:none}.week-day{width:var(--date-strip-day-width);flex:0 0 var(--date-strip-day-width);border:1px solid var(--line);min-width:0;min-height:84px;color:var(--muted);scroll-snap-align:center;touch-action:pan-x;background:#fff;border-radius:22px;align-content:center;justify-items:center;gap:5px;padding:8px 4px;display:grid;position:relative}.week-day span{text-transform:capitalize;font-size:11px;font-weight:800}.week-day strong{color:var(--text);font-size:19px;line-height:1}.week-day small{background:var(--soft-blue);min-width:18px;height:18px;color:var(--blue);border-radius:999px;justify-content:center;align-items:center;font-size:11px;font-weight:900;display:inline-flex}.week-day.active{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:none}.week-day.active strong,.week-day.active span{color:#fff}.week-day.active small{color:#fff;background:#fff3}.calendar-session-list{gap:12px;display:grid}.create-session-head{grid-template-columns:46px minmax(0,1fr);align-items:center;gap:12px;display:grid}.create-session-head>div{gap:4px;display:grid}.progress-page{gap:20px;display:grid}.progress-control-card,.progress-chart-card,.current-progress-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:24px}.progress-control-card{gap:16px;padding:16px;display:grid}.segmented-control{border:1px solid var(--line);background:#fff;border-radius:18px;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;padding:3px;display:grid;overflow:hidden}.segmented-control button{min-height:48px;color:var(--muted);background:0 0;border:0;border-radius:15px;font-weight:800}.segmented-control button.active{background:var(--blue);color:#fff;box-shadow:none}.progress-chart-card{gap:16px;padding:18px;display:grid}.progress-chart-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.progress-chart-head>div{gap:5px;min-width:0;display:grid}.progress-chart-head h3{font-size:20px;line-height:1.15}.progress-chart-head strong{color:#13aaa4;font-size:21px}.progress-chart{width:100%;height:auto}.progress-chart line{stroke:#e6eaf0;stroke-width:1px}.progress-chart polygon{fill:#0b73ff1a}.progress-chart polyline{fill:none;stroke:var(--blue);stroke-linecap:round;stroke-linejoin:round;stroke-width:4px}.progress-chart circle{fill:#fff;stroke:var(--blue);stroke-width:4px}.progress-chart-footer{color:var(--muted);justify-content:space-between;font-size:14px;display:flex}.progress-summary-section{gap:12px;display:grid}.progress-summary-grid{grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:10px;display:grid}.progress-summary-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);border-radius:22px;gap:10px;padding:14px;display:grid}.progress-summary-card strong{color:var(--text);font-size:24px;line-height:1}.progress-summary-card small{color:var(--muted);font-size:13px}.current-progress-card{grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;padding:16px;display:grid}.current-progress-card>div{gap:4px;display:grid}.current-progress-card strong{color:var(--text);font-size:16px}.current-progress-card small{color:var(--muted)}@media (width<=380px){.app-main{padding-left:12px;padding-right:12px}.stat-card{padding-left:5px;padding-right:5px}.stat-card strong{font-size:18px}.template-card{grid-template-columns:62px minmax(0,1fr) 24px;padding:12px}.form-row,.number-grid{grid-template-columns:minmax(0,1fr)}.history-summary-card{padding:12px 10px}.history-summary-card strong{font-size:18px}.history-session-card{grid-template-columns:58px minmax(0,1fr) 24px;padding:12px}.week-day{border-radius:15px;min-width:54px;min-height:68px}.week-day strong{font-size:17px}.progress-summary-card{padding:12px 10px}.progress-summary-card strong{font-size:19px}}
