:root{--bg: #f8f9fa;--card: #ffffff;--surface-soft: #f5f7fa;--surface-muted: #f8fafc;--primary: #2563eb;--primary-soft: #eaf2ff;--danger: #ff4757;--danger-soft: #fff3f4;--success: #2ed573;--success-light: #bcf2d1;--text: #1f2937;--text-light: #6b7280;--gray-light: #e5e7eb;--field-bg: #f9fbfc;--field-border: #d9e2ec;--field-focus: rgba(37, 99, 235, .14);--radius: 12px;--radius-lg: 28px;--title-area-height: 56px;--btn-bg: #ffffff;--btn-bg-soft: #f3f4f6;--btn-border: #dbe1ea;--btn-shadow: 0 1px 2px rgba(31, 41, 55, .06);--card-shadow-soft: 0 10px 24px rgba(15, 23, 42, .04);--app-max-width: 744px;--app-edge-color: #d8dde6;--bottom-side-space: 18px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,sans-serif;background:var(--bg);color:var(--text);padding-top:var(--title-area-height);padding-bottom:calc(40px + var(--title-area-height) + env(safe-area-inset-bottom));overflow:hidden}#app{width:100%}#app>:not(script){width:100%;max-width:var(--app-max-width);margin-left:auto;margin-right:auto}@media(min-width:745px){body:before{content:"";position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:min(100vw,var(--app-max-width));border-left:1px solid var(--app-edge-color);border-right:1px solid var(--app-edge-color);pointer-events:none;z-index:150}}.page-title{position:fixed;top:0;left:50%;transform:translate(-50%);width:min(100vw,var(--app-max-width));font-size:22px;font-weight:800;text-align:center;line-height:1.35;letter-spacing:.5px;height:var(--title-area-height);display:flex;align-items:center;justify-content:center;padding:0 44px 0 15px;background:#fff;color:var(--text);border-bottom:1px solid var(--gray-light);cursor:default;z-index:95}.sync-indicator{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:14px;height:14px;background:#94a3b8;opacity:.88;transform-origin:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19.36 10.46A7.49 7.49 0 0 0 5.5 8A5.5 5.5 0 0 0 5 19h13a4 4 0 0 0 1.36-7.54Z'/%3E%3C/svg%3E");-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain;mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19.36 10.46A7.49 7.49 0 0 0 5.5 8A5.5 5.5 0 0 0 5 19h13a4 4 0 0 0 1.36-7.54Z'/%3E%3C/svg%3E");mask-repeat:no-repeat;mask-position:center;mask-size:contain}@keyframes cloud-breathe-soft{0%,to{transform:translateY(-50%) scale(1);opacity:.9;filter:saturate(1.2)}50%{transform:translateY(-50%) scale(1.2);opacity:.7;filter:saturate(.8)}}.sync-indicator.mode-idle{background:#94a3b8;opacity:.72;animation:none}.sync-indicator.mode-connected{background:#22c55e;animation:cloud-breathe-soft 3.1s cubic-bezier(.42,0,.2,1) infinite}.sync-indicator.mode-syncing{background:#3b82f6;animation:cloud-breathe-soft 2.4s cubic-bezier(.42,0,.2,1) infinite}.sync-indicator.mode-offline{background:#f59e0b;animation:cloud-breathe-soft 3.6s cubic-bezier(.42,0,.2,1) infinite}.sync-indicator.mode-error{background:#ef4444;animation:cloud-breathe-soft 2.8s cubic-bezier(.42,0,.2,1) infinite}.pull-refresh-indicator{position:fixed;top:calc(var(--title-area-height) + 6px);left:50%;width:min(100vw,var(--app-max-width));transform:translate(-50%,-14px);opacity:0;pointer-events:none;z-index:96;display:flex;justify-content:center;transition:transform .16s ease,opacity .16s ease}.pull-refresh-indicator.show{opacity:1}.pull-refresh-pill{min-height:26px;padding:0 12px;border-radius:999px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-light);font-size:12px;font-weight:700;box-shadow:var(--btn-shadow);display:inline-flex;align-items:center;justify-content:center}.pull-refresh-indicator.ready .pull-refresh-pill{color:var(--primary)}.pull-refresh-indicator.refreshing .pull-refresh-pill{color:var(--success)}.app-back-toast{position:fixed;left:50%;bottom:calc(96px + env(safe-area-inset-bottom));transform:translate(-50%,10px);min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(15,23,42,.08);background:#0f172ad1;color:#fff;font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 24px #0f172a2e;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:160}.app-back-toast.show{opacity:1;transform:translate(-50%)}.modal-panel{display:none;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:min(100vw,var(--app-max-width));background:#fff;z-index:100;padding:calc(var(--title-area-height) + 20px) 15px calc(84px + env(safe-area-inset-bottom)) 15px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.modal-panel::-webkit-scrollbar{width:0;height:0;display:none}.modal-panel .page-title{margin:0;cursor:default;z-index:102}button,.tab-item,.btn-link{transition:transform .12s ease,filter .12s ease,box-shadow .12s ease}button:active,.tab-item:active,.btn-link:active{transform:translateY(1px);filter:brightness(.98)}button:focus-visible,.tab-item:focus-visible,.btn-link:focus-visible{outline:2px solid rgba(37,99,235,.35);outline-offset:1px}.app-dialog{position:fixed;inset:0;z-index:220;display:none;align-items:center;justify-content:center;padding:20px 16px;background:#0f172a52;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.app-dialog.show{display:flex}.app-dialog-card{width:min(100%,360px);max-height:min(680px,calc(100dvh - 40px));background:var(--card);border:1px solid var(--field-border);border-radius:20px;box-shadow:0 14px 32px #0f172a14;padding:18px;display:flex;flex-direction:column;min-height:0}.app-dialog-title{font-size:15px;font-weight:800;color:var(--text);line-height:1.35;margin-bottom:8px;text-align:center}.app-dialog-message{font-size:13px;color:var(--text-light);line-height:1.45;white-space:pre-wrap;margin-bottom:14px;text-align:center}.app-dialog-card.entry-dialog,.app-dialog-card.picker-dialog{width:min(100%,420px);border-radius:20px;padding:20px}.app-dialog-card.entry-dialog .app-dialog-title,.app-dialog-card.picker-dialog .app-dialog-title{text-align:left;font-size:16px;margin-bottom:6px}.app-dialog-card.entry-dialog .app-dialog-message,.app-dialog-card.picker-dialog .app-dialog-message{text-align:left}.app-dialog-field,.app-dialog-body{margin-bottom:14px}.app-dialog-body{min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.app-dialog-body::-webkit-scrollbar{width:0;height:0;display:none}.app-dialog-field{display:grid;grid-template-columns:56px minmax(0,1fr);gap:8px;align-items:center}.app-dialog-field-header{display:inline-flex;align-items:center;min-height:48px;font-size:12px;font-weight:700;color:var(--text-light);line-height:1.2;white-space:nowrap}.app-dialog-input-shell{position:relative;display:flex;align-items:center;min-height:48px;padding:0 14px;border:1px solid var(--field-border);border-radius:14px;background:#fff;box-shadow:none;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.app-dialog-input-shell:focus-within{background:#fff;box-shadow:none}.app-dialog-input,.app-dialog-form-input{width:100%;min-width:0;min-height:48px;margin:0;border:0;border-radius:0;padding:0;font-size:14px;font-weight:600;color:var(--text);background:transparent;box-shadow:none;text-align:left}.app-dialog-input:focus,.app-dialog-form-input:focus{outline:none;box-shadow:none}.app-dialog-input::placeholder,.app-dialog-form-input::placeholder{color:#94a3b8;opacity:1}.app-dialog-form{display:grid;gap:10px}.app-dialog-form-row{display:grid;grid-template-columns:minmax(0,1fr) 112px;gap:8px;align-items:center}.app-dialog-form-label,.app-dialog-compact-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.35}.app-dialog-form-hint{font-size:12px;color:var(--text-light);line-height:1.45}.dialog-metric-field{display:grid;grid-template-columns:56px minmax(0,1fr);gap:8px;align-items:center}.dialog-metric-field .app-dialog-input,.dialog-metric-field .app-dialog-form-input{text-align:left;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}.app-dialog-input-label{display:none}.app-dialog-input-suffix{flex:0 0 auto;margin-left:10px;font-size:12px;font-weight:700;color:var(--text-light);line-height:1;white-space:nowrap}.app-dialog-entry-section{display:grid;gap:10px;padding:12px;border:1px solid #e7edf3;border-radius:16px;background:#fbfcfe}.app-dialog-entry-list{display:grid;gap:10px}.app-dialog-entry-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.app-dialog-entry-summary{min-height:40px;border-radius:12px;border:1px solid var(--field-border);background:#fff;color:var(--text);font-size:13px;font-weight:700;text-align:left;padding:0 12px}.app-dialog-entry-field{min-width:0}.app-dialog-entry-add,.app-dialog-entry-remove{min-height:38px;border-radius:12px;border:1px solid var(--field-border);background:#fff;color:var(--text-light);font-size:13px;font-weight:700;box-shadow:none;padding:0 12px}.app-dialog-entry-add{width:100%;justify-self:stretch;background:#fff;color:var(--primary)}.app-dialog-entry-remove{min-width:56px;background:#fff;border-color:#e4e9f0;color:var(--text-light)}.app-dialog-legacy-hint{font-size:12px;color:var(--text-light)}.app-dialog-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:auto}.app-dialog-card.entry-dialog .app-dialog-actions,.app-dialog-card.form-dialog .app-dialog-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.app-dialog-card.triple-action-dialog .app-dialog-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.app-dialog-btn{min-width:112px;height:42px;border-radius:12px;border:1px solid var(--field-border);background:var(--btn-bg);color:var(--text);font-size:13px;font-weight:700;box-shadow:none;padding:0 16px;width:auto;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center}.app-dialog-card.entry-dialog .app-dialog-btn,.app-dialog-card.form-dialog .app-dialog-btn{width:100%;min-width:0;height:44px;border-radius:14px;padding:0 14px}.app-dialog-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:none}.app-dialog-btn.danger{border-color:#fecaca;background:#fff5f5;color:#dc2626}.app-dialog-compact-form{display:grid;gap:12px}.app-dialog-compact-field{min-width:0}.app-dialog-card.compact-input-dialog{width:min(100%,360px)}.app-dialog-card.compact-input-dialog .app-dialog-title{text-align:center;margin-bottom:0}.app-dialog-card.compact-input-dialog .app-dialog-message{display:none!important}.app-dialog-card.compact-input-dialog .app-dialog-body{margin-bottom:16px}.app-dialog-card.compact-input-dialog .app-dialog-compact-form{gap:0}.app-dialog-compact-input-wrap{display:block}.app-dialog-compact-input{text-align:left}.app-dialog-number-stepper{display:grid;grid-template-columns:48px minmax(0,1fr) 48px;align-items:stretch;min-height:48px;border:1px solid var(--field-border);border-radius:14px;background:#fff;overflow:hidden}.app-dialog-number-stepper.has-unit{grid-template-columns:48px minmax(0,1fr) 48px 92px}.app-dialog-number-stepper:focus-within{box-shadow:none}.app-dialog-number-stepper-btn{border:0;background:transparent;color:var(--text);font-size:18px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.app-dialog-number-stepper-btn:first-child{border-right:1px solid var(--field-border)}.app-dialog-number-stepper-btn[data-stepper-action=increment]{border-left:1px solid var(--field-border)}.app-dialog-number-stepper.has-unit .app-dialog-number-stepper-btn:last-of-type{border-right:1px solid var(--field-border)}.app-dialog-number-stepper-input-wrap{display:block;min-width:0}.app-dialog-number-stepper-input-wrap.is-pressing .app-dialog-input-shell,.app-dialog-record-unit-wrap.is-pressing .app-dialog-input-shell{background:#f8fbff}.app-dialog-number-stepper-input-wrap.is-editing .app-dialog-input-shell,.app-dialog-record-unit-wrap.is-editing .app-dialog-input-shell{box-shadow:none}.app-dialog-number-stepper-input-wrap .app-dialog-input-shell{border:0;border-radius:0;box-shadow:none;min-height:48px;padding:0 12px}.app-dialog-number-stepper-input-wrap .app-dialog-input-shell:focus-within{border:0;box-shadow:none}.app-dialog-number-stepper-input{text-align:center;font-variant-numeric:tabular-nums;appearance:textfield;-moz-appearance:textfield}.app-dialog-number-stepper-input::-webkit-outer-spin-button,.app-dialog-number-stepper-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.app-dialog-record-unit-wrap{min-width:0}.app-dialog-record-unit-wrap .app-dialog-input-shell{min-height:48px;border:0;border-radius:0;box-shadow:none;padding:0 10px}.app-dialog-record-unit-input{text-align:center;font-size:13px;font-weight:700}.app-dialog-long-press-hint{font-size:12px;color:var(--text-light);text-align:center;margin-top:8px}.app-dialog-card.picker-dialog .app-dialog-body{margin-bottom:0}.app-dialog-card.picker-dialog .manage-group-picker{gap:10px}.app-dialog-card.picker-dialog .manage-group-picker-btn{min-height:46px;border-radius:12px;border-color:var(--field-border);font-size:13px;box-shadow:none}.app-dialog-card.picker-dialog .manage-group-picker-btn.is-active{background:var(--primary-soft);border-color:#c9dafe}.app-dialog-card.picker-dialog .manage-group-picker-btn.is-create{background:#f8fbff}#app-dialog-ok{order:1}#app-dialog-alt{order:2}#app-dialog-cancel{order:3}@media(max-width:640px){.app-dialog[data-layout=sheet]{align-items:flex-end;padding-top:12px;padding-left:12px;padding-right:12px;padding-bottom:calc(max(12px,env(safe-area-inset-bottom)) + var(--dialog-keyboard-inset, 0px))}.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog{width:min(100%,520px);max-height:calc(var(--dialog-viewport-height, 100dvh) - var(--dialog-viewport-offset-top, 0px) - 12px);border-radius:24px 24px 18px 18px;padding:18px 16px 16px;box-shadow:0 18px 42px #0f172a2e;display:grid;grid-template-columns:minmax(0,1fr);grid-auto-flow:row;grid-auto-rows:max-content;align-content:start;gap:12px}.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-title,.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-message,.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-field,.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-body,.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-actions{margin:0}.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-field,.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .dialog-metric-field{min-width:0}.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-body{min-height:0;max-height:min(320px,calc(var(--dialog-viewport-height, 100dvh) * .42));overflow-y:auto;overscroll-behavior:contain;padding-right:2px}.app-dialog[data-layout=sheet] .app-dialog-card.keyboard-dialog .app-dialog-actions{margin-top:0;position:static;padding-top:2px;background:none}.app-dialog-field,.dialog-metric-field{grid-template-columns:44px minmax(0,1fr)}.app-dialog-entry-row{gap:6px}.app-dialog-entry-remove{min-width:52px;padding:0 10px}}.btn-link{font-size:14px;color:var(--primary);font-weight:600;cursor:pointer}.btn-action{font-size:12px;font-weight:700;padding:6px 12px;border-radius:12px;border:1px solid var(--field-border);background:var(--btn-bg);color:var(--text);cursor:pointer;box-shadow:none}.btn-del{background:var(--danger-soft);border-color:#f5c8cf;color:var(--danger)}.btn-add-row{background:var(--primary-soft);border-color:#cadeff;color:var(--primary)}.btn-icon{width:30px;height:30px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.btn-add-full{width:100%;height:30px;border-radius:10px;padding:0}.btn-action:disabled{opacity:.45;cursor:not-allowed}.sync-key-input{width:100%;height:44px;border:1px solid var(--field-border);border-radius:14px;padding:0 14px;font-size:14px;color:var(--text);background:var(--field-bg);box-shadow:none}.floating-field{position:relative;display:block;--floating-label-width: 56px}.floating-input{width:100%;padding-left:calc(var(--floating-label-width) + 22px)!important}.floating-label{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:var(--floating-label-width);max-width:var(--floating-label-width);padding:0;background:transparent;color:var(--text-light);font-size:11px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;pointer-events:none;transition:color .16s ease}.floating-field:focus-within .floating-label,.floating-field .floating-input:not(:placeholder-shown)+.floating-label{font-size:11px;color:var(--primary)}.page-home .home-fab-wrap{position:fixed;left:50%;transform:translate(-50%);width:min(100vw,var(--app-max-width));bottom:0;height:calc(68px + env(safe-area-inset-bottom));padding-top:8px;padding-bottom:calc(10px + env(safe-area-inset-bottom));padding-left:calc(var(--bottom-side-space) + env(safe-area-inset-left));padding-right:calc(var(--bottom-side-space) + env(safe-area-inset-right));display:grid;grid-template-columns:repeat(3,1fr);align-items:center;gap:10px;background:#fff;border-top:1px solid var(--gray-light);z-index:90}.page-home .home-fab-btn{width:100%;height:48px;min-height:48px;letter-spacing:.2px}.page-home .home-fab-btn,.tab-item{border:1px solid var(--btn-border);border-radius:12px;background:var(--btn-bg);color:var(--text);font-size:13px;font-weight:700;box-shadow:var(--btn-shadow);min-height:48px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;white-space:nowrap}.page-home .home-fab-btn:focus-visible{outline:none}.page-home .home-fab-btn:active{transform:none;filter:none}.page-home .fab-weight{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.page-home .fab-habit{background:#ecfdf3;border-color:#b7ebce;color:#15803d}.page-home .fab-settings{background:#eef4ff;border-color:#c7d7ff;color:#1d4ed8}.page-home .home-main{position:fixed;top:var(--title-area-height);bottom:calc(72px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);width:min(100vw,var(--app-max-width));display:flex;flex-direction:column;min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;z-index:1}.page-home .home-main::-webkit-scrollbar{width:0;height:0;display:none}.page-home .top-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:15px;background:linear-gradient(180deg,#fff,#f8fafc);margin-bottom:10px}.page-home .stat-box{text-align:center;min-width:0;padding:10px 8px;background:var(--bg);border-radius:var(--radius)}.page-home .stat-label{font-size:11px;color:var(--text-light);margin-bottom:4px}.page-home .stat-val{font-size:14px;font-weight:700;color:var(--primary)}.page-home .container{padding:0 15px 18px;flex:0 0 auto;min-height:auto;display:block}.page-home .section-header{display:flex;justify-content:space-between;align-items:center;margin:20px 0 12px 5px}.page-home .section-header h3{font-size:15px;color:var(--text-light);margin:0}.page-home .section-header-actions{margin-left:auto;display:inline-flex;align-items:center;justify-content:flex-end}.page-home .section-header-btn{min-height:32px;border-radius:10px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--primary);font-size:12px;font-weight:700;box-shadow:var(--btn-shadow);padding:0 12px;white-space:nowrap}.page-home .section-header-btn.is-active{background:#eef4ff;border-color:#c7d7ff;color:#1d4ed8}.page-home .exercise-reorder-hint{margin:-4px 0 10px 5px;font-size:12px;color:var(--text-light)}.page-home .habit-list{display:flex;flex-direction:column;gap:10px}.page-home .wide-switch{display:block;width:100%;position:relative;cursor:pointer}.page-home .wide-switch input{display:none}.page-home .track{width:100%;height:52px;border-radius:var(--radius-lg);background:var(--danger);position:relative;overflow:hidden;transition:background .3s ease}.page-home .wide-switch input:checked+.track{background:var(--success)}.page-home .track-text{position:absolute;width:50%;line-height:52px;font-size:13px;font-weight:600;color:#fff;text-align:center}.page-home .left-text{left:0;opacity:0;transform:translate(-20px);transition:.3s}.page-home .right-text{right:0;opacity:1;transform:translate(0);transition:.3s}.page-home input:checked+.track .left-text{opacity:1;transform:translate(0)}.page-home input:checked+.track .right-text{opacity:0;transform:translate(20px)}.page-home .thumb{position:absolute;left:4px;top:4px;height:44px;width:calc(50% - 4px);background:#fff;border-radius:22px;display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text);transition:.3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 6px #0000001a}.page-home input:checked+.track .thumb{left:50%}.page-home .ex-row,.exercise-reorder-fallback{background:#fff;border-radius:16px;padding:0;margin-bottom:8px;display:grid;gap:0;position:relative;touch-action:pan-y;-webkit-user-select:none;user-select:none;overflow:hidden;transition:box-shadow .14s ease,opacity .14s ease,background-color .14s ease}.page-home .ex-row-body,.exercise-reorder-fallback .ex-row-body{display:grid;gap:10px;padding:12px 16px 10px}.page-home .ex-row-top,.exercise-reorder-fallback .ex-row-top{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.page-home .ex-name,.exercise-reorder-fallback .ex-name{flex:1 1 auto;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-home .ex-row-main,.exercise-reorder-fallback .ex-row-main{min-width:0;flex:1 1 auto}.page-home .ex-inline-meta,.exercise-reorder-fallback .ex-inline-meta{display:flex;align-items:center;min-width:0}.page-home .ex-progress-line,.exercise-reorder-fallback .ex-progress-line{display:block;flex:0 0 auto;width:100%;height:5px;border-radius:0;background:#e8eef8;overflow:hidden}.page-home .ex-progress-fill,.exercise-reorder-fallback .ex-progress-fill{height:100%;min-width:0;border-radius:inherit;background:linear-gradient(90deg,#93c5fd,#2563eb)}.page-home .counter-group,.exercise-reorder-fallback .counter-group{display:flex;align-items:center;gap:8px;justify-content:flex-end;flex:0 0 auto}.page-home .counter-group.is-reorder,.exercise-reorder-fallback .counter-group.is-reorder{min-width:88px}.page-home .btn-step{min-width:88px;height:36px;border-radius:10px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--primary);font-size:12px;font-weight:700;box-shadow:var(--btn-shadow);padding:0 14px}.page-home .btn-step.is-link{min-width:88px}.page-home .btn-step.is-add{min-width:88px;background:#eef4ff;border-color:#c7d7ff;color:#1d4ed8}.page-home #exercise-container{overflow:visible;padding-bottom:12px}.page-home .exercise-reorder-handle,.exercise-reorder-fallback .exercise-reorder-handle{width:40px;height:40px;min-width:40px;border-radius:12px;border:1px solid var(--btn-border);background:#fff;box-shadow:var(--btn-shadow);display:inline-flex;align-items:center;justify-content:center;padding:0;touch-action:none}.page-home .exercise-reorder-handle:before,.exercise-reorder-fallback .exercise-reorder-handle:before{content:"";width:16px;height:16px;opacity:.72;background:radial-gradient(circle,#64748b 1.2px,transparent 1.3px) 0 0 / 8px 8px,radial-gradient(circle,#64748b 1.2px,transparent 1.3px) 4px 4px / 8px 8px}.page-home .exercise-reorder-handle:active,.page-home .exercise-reorder-handle.is-active,.exercise-reorder-fallback .exercise-reorder-handle:active,.exercise-reorder-fallback .exercise-reorder-handle.is-active{background:#eef4ff;border-color:#c7d7ff}.page-home .ex-row.is-sortable-chosen{box-shadow:0 12px 28px #0f172a1f}.page-home .ex-row.is-sortable-ghost{opacity:.38;background:#eef4ff;border:1px dashed #c7d7ff;box-shadow:inset 0 0 0 1px #c7d7ff47}.page-home .ex-row.is-sortable-ghost .ex-row-body,.page-home .ex-row.is-sortable-ghost .ex-progress-line{opacity:0}.page-home .ex-row.is-sortable-drag,.exercise-reorder-fallback{box-shadow:0 18px 36px #0f172a2e}.exercise-reorder-fallback{pointer-events:none;opacity:.98;border-radius:16px;background:#fff;box-sizing:border-box;margin:0}.page-home .home-main.is-reordering{overflow:hidden;touch-action:none}@media(max-width:640px){.page-home .top-stats{gap:8px;padding:12px}.page-home .container{padding:0 12px 18px}.page-home .track{height:56px}.page-home .track-text{line-height:56px;font-size:12px}.page-home .thumb{height:48px;border-radius:24px}.page-home .ex-row-body{gap:8px;padding:10px 12px}.page-home .section-header-btn{min-height:30px;padding:0 10px}.page-home .counter-group{gap:4px}.page-home .exercise-reorder-handle{width:38px;height:38px;min-width:38px}.page-home .ex-name{font-size:13px}.page-home .btn-step{min-width:82px;height:34px;padding:0 12px}.page-home .stat-label{font-size:10px}.page-home .stat-val{font-size:13px}}.page-history{display:flex;flex-direction:column;overflow:hidden;padding-bottom:0}.page-history .history-fixed-header{position:relative;z-index:3;flex:0 0 auto;padding:2px 0 12px;background:linear-gradient(180deg,#fff,#fffffffa)}.page-history .history-scroll-body{flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:12px;scrollbar-width:none;-ms-overflow-style:none}.page-history .history-scroll-body::-webkit-scrollbar{width:0;height:0;display:none}.page-history .history-heatmap-body{padding-top:2px}.page-history #heatmap{flex:0 0 auto;min-height:auto;overflow:visible;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.page-history .heatmap{display:grid;grid-template-columns:repeat(auto-fill,minmax(3rem,1fr));gap:8px}.page-history .heat-day{aspect-ratio:1;border-radius:4px;background:var(--gray-light);font-size:10px;display:flex;align-items:center;justify-content:center;color:#9ca3af;cursor:pointer}.page-history .heat-done{background:var(--success)!important;color:#fff!important}.page-history .heat-partial{background:var(--success-light)!important;color:var(--success)!important}.page-history .habit-merged-list{display:flex;flex-direction:column;gap:8px}.page-history .history-entry-list{display:grid;gap:10px}.page-history .history-empty{padding:24px 16px;border:1px solid #e7edf3;border-radius:16px;background:#fff;box-shadow:var(--card-shadow-soft);text-align:center;color:var(--text-light);font-size:13px}.page-history .history-entry-row{width:100%;border:1px solid #e7edf3;border-radius:16px;background:#fff;box-shadow:var(--card-shadow-soft);padding:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left;color:var(--text)}.page-history .history-entry-summary{display:block;flex:1 1 auto;min-width:0;font-size:14px;font-weight:600;color:var(--text);line-height:1.4;word-break:break-word}.page-history .history-entry-edit{flex:0 0 auto;min-width:68px;min-height:36px;padding:0 14px;border:1px solid #c7d7ff;border-radius:12px;background:#eef4ff;color:var(--primary);font-size:13px;font-weight:700}.page-history .habit-merged-row{display:grid;grid-template-columns:minmax(88px,1.05fr) repeat(3,minmax(0,1fr));gap:8px}.page-history .habit-merged-cell{min-height:42px;border-radius:14px;border:1px solid var(--btn-border);background:var(--btn-bg);box-shadow:var(--btn-shadow);font-size:12px;font-weight:700;color:var(--text);display:flex;align-items:center;justify-content:center;text-align:center;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,filter .14s ease}.page-history .habit-merged-cell.is-date{justify-content:center}.page-history .habit-merged-head-cell{background:#eef4ff;border-color:#c7d7ff;color:var(--primary)}.page-history .habit-merged-header-row{position:relative;padding-bottom:2px}.page-history .habit-merged-header-row:after{content:"";position:absolute;left:6px;right:6px;bottom:-8px;height:12px;background:linear-gradient(180deg,#0f172a14,#0f172a00);opacity:.18;pointer-events:none;filter:blur(8px)}.page-history .habit-merged-cell.done{background:#ecfdf3;border-color:#b7ebce;color:#15803d}.page-history .habit-merged-cell.pending{background:#fff7ed;border-color:#fed7aa;color:#c2410c}.page-history .habit-merged-cell[data-long-press].is-pressing{transform:scale(.98);filter:brightness(.98)}.page-history .habit-merged-cell[data-long-press].is-long-pressed{box-shadow:0 0 0 2px #2563eb2e}.page-history .habit-merged-cell[data-long-press]{user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:pan-y}.page-manage{display:flex;flex-direction:column;overflow:hidden;padding-bottom:0}.page-manage .manage-scroll-body{flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:calc(148px + env(safe-area-inset-bottom));scrollbar-width:none;-ms-overflow-style:none;position:relative}.page-manage .manage-scroll-body::-webkit-scrollbar{width:0;height:0;display:none}.page-manage .manage-layout{display:grid;gap:12px;padding-top:4px}.page-manage .manage-section-card{background:#fff;border:1px solid #e5ebf1;border-radius:18px;box-shadow:var(--card-shadow-soft);overflow:hidden}.page-manage .manage-card-header{display:flex;justify-content:flex-start;align-items:center;gap:10px;padding:14px 16px}.page-manage .manage-card-title{font-size:15px;font-weight:800;color:var(--text);text-align:left}.page-manage .manage-item-list{display:grid;border-top:1px solid #eef2f7}.page-manage .manage-item-row{display:grid;gap:12px;padding:16px;border-top:1px solid #eef2f7}.page-manage .manage-item-row:first-child{border-top:0}.page-manage .manage-item-top,.page-manage .manage-item-bottom{display:grid;gap:8px;align-items:center}.page-manage .manage-item-top,.page-manage .manage-item-bottom{grid-template-columns:minmax(0,1fr) 88px}.page-manage .manage-field{display:block;min-width:0}.page-manage .manage-inline-field{display:grid;grid-template-columns:56px minmax(0,1fr);align-items:center;gap:8px}.page-manage .manage-field-label{display:inline-flex;align-items:center;justify-content:flex-start;min-height:48px;font-size:11px;font-weight:700;color:var(--text-light);padding-left:2px;white-space:nowrap}.page-manage .manage-row-input{width:100%;height:48px;border:1px solid var(--field-border);border-radius:14px;padding:0 14px;font-size:14px;color:var(--text);background:#fff;box-shadow:none;text-align:left}.page-manage .manage-row-input:focus{outline:none;border-color:#93b4ef;background:#fff;box-shadow:0 0 0 4px var(--field-focus)}.page-manage .manage-group-switch,.page-manage .manage-delete-btn,.page-manage .manage-add-btn,.page-manage .manage-inline-action{width:100%;height:48px;min-height:48px;min-width:0;padding:0 12px}.page-manage .manage-create-card{display:grid;gap:12px;padding:16px;border-top:1px solid #eef2f7}.page-manage .manage-field-name .manage-row-input,.page-manage .manage-field-name{max-width:100%}.manage-group-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.manage-group-picker-btn{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:44px;min-width:0;padding:0 12px;border:1px solid var(--field-border);border-radius:12px;background:var(--btn-bg);color:var(--text);font-size:12px;font-weight:700;box-shadow:none;text-align:center;white-space:nowrap}.manage-group-picker-btn.is-active{background:var(--primary-soft);border-color:#cadeff;color:var(--primary)}.manage-group-picker-btn.is-create{background:#f8fafc}.page-manage .manage-empty{padding:18px 16px;color:var(--text-light);font-size:13px;text-align:center}.page-manage .manage-row-input.is-readonly{color:var(--text-light);background:var(--surface-soft)}.page-manage .manage-group-switch.is-grouped{background:var(--primary-soft);border-color:#cadeff;color:var(--primary)}.page-manage .manage-group-header{justify-content:space-between}.page-manage .manage-group-toolbar{display:flex;align-items:center;justify-content:flex-end;min-width:0;flex:0 0 auto}.page-manage .manage-mode-tabs{display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;min-width:120px;padding:2px;border:1px solid var(--field-border);border-radius:14px;background:var(--surface-soft)}.page-manage .manage-mode-tab{min-width:0;min-height:38px;padding:0 12px;border:0;border-radius:10px;background:transparent;color:var(--text-light);font-size:12px;font-weight:700}.page-manage .manage-mode-tab.is-active{background:#fff;color:var(--text);box-shadow:var(--btn-shadow)}.page-manage .manage-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:2px}.page-manage .manage-table th{text-align:left;padding:10px 5px;color:var(--text-light);border-bottom:1px solid var(--gray-light)}.page-manage .manage-table td{padding:10px 5px;border-bottom:1px solid var(--gray-light)}.page-manage .manage-sync-dock{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:min(100vw,var(--app-max-width));display:grid;gap:10px;padding:10px calc(var(--bottom-side-space) + env(safe-area-inset-right)) calc(12px + env(safe-area-inset-bottom)) calc(var(--bottom-side-space) + env(safe-area-inset-left));background:#fffffffa;border-top:1px solid #e6edf3;box-shadow:0 -8px 24px #0f172a0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:104}.page-manage .manage-sync-actions{display:grid;grid-template-columns:minmax(180px,1.4fr) minmax(108px,.8fr);gap:8px;align-items:stretch}.page-manage .manage-sync-actions .btn-action,.page-manage .manage-sync-actions .sync-key-input{min-height:48px;height:48px}.page-manage .sync-key-input{text-align:left}.page-manage .manage-target-stepper{display:grid;min-width:0}.page-manage .manage-target-stepper-label{min-height:48px}.page-manage .manage-target-stepper-control{display:grid;grid-template-columns:48px minmax(0,1fr) 48px;align-items:center;min-height:48px;border:1px solid var(--field-border);border-radius:14px;background:#fff;overflow:hidden}.page-manage .manage-target-stepper.is-readonly .manage-target-stepper-control{background:var(--surface-soft)}.page-manage .manage-target-stepper-btn{width:100%;height:100%;border:0;border-right:1px solid var(--field-border);background:transparent;color:var(--text);font-size:18px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.page-manage .manage-target-stepper-btn:last-child{border-right:0;border-left:1px solid var(--field-border)}.page-manage .manage-target-stepper-btn:disabled{color:#b0bac7;background:transparent;cursor:not-allowed}.page-manage .manage-target-stepper-value{display:inline-flex;align-items:center;justify-content:center;min-width:0;font-size:16px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}@media(max-width:640px){.page-manage .manage-scroll-body{padding-bottom:calc(148px + env(safe-area-inset-bottom))}.page-manage .manage-layout{gap:10px}.page-manage .manage-section-card{border-radius:16px}.page-manage .manage-item-row,.page-manage .manage-create-card{grid-template-columns:1fr}.page-manage .manage-card-header{align-items:center;padding:14px}.page-manage .manage-row-input{font-size:14px}.page-manage .manage-item-row,.page-manage .manage-create-card{padding:14px}.page-manage .manage-item-top{grid-template-columns:minmax(0,1fr) 78px}.page-manage .manage-item-bottom{grid-template-columns:minmax(0,1fr) 78px;gap:8px}.page-manage .manage-inline-field{grid-template-columns:44px minmax(0,1fr);gap:8px}.page-manage .manage-group-switch,.page-manage .manage-delete-btn,.page-manage .manage-add-btn,.page-manage .manage-inline-action{min-height:48px;height:48px;padding:0 8px}.page-manage .manage-card-header{padding:14px}.page-manage .manage-group-header{gap:8px}.page-manage .manage-group-toolbar{flex:0 0 auto}.page-manage .manage-mode-tabs{min-width:108px}.page-manage .manage-mode-tab{min-height:36px;padding:0 10px;font-size:11px}}.tab-item:hover{background:#f8fbff;border-color:#c7d7ff}.tab-item:focus-visible{outline:2px solid rgba(37,99,235,.35);outline-offset:1px}.tab-bar{display:flex;gap:10px;background:transparent;padding:0;margin:0;width:100%}.tab-item{flex:1 1 0;cursor:pointer;color:var(--text-light);transition:all .15s ease}.tab-item.active{background:#eaf2ff;border-color:#b7cbff;color:var(--primary);box-shadow:var(--btn-shadow)}.page-progress{overflow:hidden;flex-direction:column;padding-bottom:calc(18px + env(safe-area-inset-bottom))}.page-progress .progress-chart-card{background:#fff;border-radius:12px;padding:12px;border:1px solid var(--gray-light);margin-bottom:12px}.page-progress .progress-svg{width:100%;height:auto;display:block}.page-progress .progress-legend{display:flex;gap:12px;font-size:12px;color:var(--text-light);margin-bottom:8px;flex-wrap:wrap}.page-progress .legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.page-progress .progress-empty{color:var(--text-light);font-size:13px;text-align:center;padding:16px 8px}.page-progress .progress-list{background:#fff;border-radius:0;border:none;overflow:visible}.page-progress .progress-list-wrap{flex:1 1 auto;min-height:0;overflow-y:auto;padding-bottom:0;border:1px solid var(--gray-light);border-radius:12px;background:#fff;scrollbar-width:none;-ms-overflow-style:none;position:relative}.page-progress .progress-list-wrap::-webkit-scrollbar{width:0;height:0;display:none}.page-progress .progress-item{padding:10px 12px;border-bottom:1px solid var(--gray-light)}.page-progress .progress-item:last-child{border-bottom:none}.page-progress .progress-date{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}.page-progress .progress-vals{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text-light)}
