body{margin:0}.sf-page{--sf-max-width: 1140px;min-height:100vh;background:radial-gradient(circle at 56% 89%,rgb(224 214 201 / .42),transparent 23rem),linear-gradient(180deg,#f7f3ef,#faf8f6);color:var(--sf-ink);font-family:var(--sf-font);font-size:16px;font-synthesis:none;text-rendering:geometricPrecision}.sf-page *,.sf-page *:before,.sf-page *:after{box-sizing:border-box}.sf-page a{color:inherit;text-decoration:none}.sf-page button:not(.sf-btn){font:inherit;cursor:pointer;border:0;background:none}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sf-shell{width:min(calc(100% - 4.25rem),var(--sf-max-width));margin-inline:auto;padding-inline:0}.sf-shell--lower{position:relative;z-index:2;padding-bottom:2.75rem}.sf-stage{position:relative;background-color:var(--sf-paper);background-size:103% auto;background-position:calc(50% - 10px) -14px;background-repeat:no-repeat;min-height:894px;overflow:hidden}.sf-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,rgb(247 243 239 / .28) 0%,rgb(247 243 239 / .1) 34%,transparent 57%);pointer-events:none}.sf-stage>.sf-hero{position:relative;z-index:1}.sf-header{position:relative;z-index:3;padding-top:23px}.sf-brand{display:inline-flex;align-items:center;gap:12px;color:var(--sf-ink);flex-shrink:0}.sf-nav__link{font-size:14px;font-weight:600;line-height:1.2;color:var(--sf-ink);position:relative;padding-bottom:20px;cursor:pointer;transition:color .14s ease}.sf-nav__link:hover{color:var(--sf-accent-hover)}.sf-nav__link:active{opacity:.88}.sf-nav__link:focus-visible{outline:2px solid var(--sf-accent);outline-offset:4px;border-radius:2px}.sf-nav__link--button{padding:0 0 20px;border:0;background:none;font:inherit}.sf-nav__link.is-active{color:var(--sf-ink)}.sf-nav__link.is-active:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--sf-accent);pointer-events:none}.sf-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:50px;padding:0 27px;border:0;border-radius:var(--sf-radius-pill);font-size:14px;font-weight:600;line-height:1;white-space:nowrap;transition:background .14s ease}.sf-btn:focus-visible{outline:2px solid var(--sf-accent);outline-offset:2px}.sf-btn--primary{background:var(--sf-accent);color:#fff;box-shadow:inset 0 0 0 1px #ffffff1f,0 2px 4px #141c282e}.sf-btn--primary:hover{background:var(--sf-accent-hover)}.sf-btn--primary:active{transform:scale(.98)}.sf-btn__arrow{font-size:.95em;line-height:1}.sf-hero{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.sf-hero a,.sf-hero button{pointer-events:auto}.sf-shell--hero{padding-top:341px;padding-left:37px}.sf-hero__copy{max-width:405px}.sf-hero__title{margin:0;display:grid;gap:0;font-size:55px;font-weight:750;line-height:1.04;letter-spacing:-.048em}.sf-hero__title-line{display:block}.sf-hero__title-period{color:var(--sf-accent)}.sf-hero__lede{margin:26px 0 0;max-width:405px;font-size:17px;font-weight:400;line-height:1.55;color:#252a31}.sf-hero__actions{margin-top:45px;display:flex;flex-wrap:wrap;align-items:center;gap:42px}.sf-hero__actions .sf-btn--primary{width:180px;min-height:51px;padding-inline:0;font-size:14px;justify-content:space-between;padding-left:25px;padding-right:25px}.sf-hero__secondary{font-size:14px;font-weight:600;color:var(--sf-ink);text-decoration:underline;text-underline-offset:10px;text-decoration-thickness:2px;text-decoration-color:var(--sf-accent)}.sf-hero__secondary:hover{text-decoration-color:var(--sf-accent)}.sf-hero__secondary:focus-visible{outline:2px solid var(--sf-accent);outline-offset:2px}.sf-features-wrap{margin-top:0}.sf-features{min-height:271px;padding:45px 0 49px;background:var(--sf-surface);border:1px solid rgb(255 255 255 / .72);border-radius:13px;box-shadow:0 31px 70px #47392a14}.sf-features__grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:0}.sf-feature{display:grid;gap:0;text-align:center;justify-items:center;min-height:177px;padding:0 24px;border-right:1px solid var(--sf-line)}.sf-feature:last-child{border-right:0}.sf-feature__icon{width:64px;height:64px;border-radius:50%;border:1px solid var(--sf-line);background:#f8f6f2;display:grid;place-items:center;color:var(--sf-accent)}.sf-feature__icon svg{width:33px;height:33px;stroke-width:2.2}.sf-feature__title{margin:29px 0 0;font-size:17px;font-weight:750;line-height:1.2;letter-spacing:-.03em}.sf-feature__desc{margin:14px 0 0;max-width:24ch;font-size:14px;font-weight:400;line-height:1.42;color:#242930}.sf-feature__desc span{display:block;white-space:nowrap}.sf-footer{padding:44px 0 0;text-align:center}.sf-footer__links{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem .75rem;margin-bottom:1rem}.sf-footer__link{font-size:14px;font-weight:600;color:var(--sf-accent);text-decoration:underline;text-underline-offset:4px}.sf-footer__link:hover{color:var(--sf-accent-hover)}.sf-footer__link:focus-visible{outline:2px solid var(--sf-accent);outline-offset:2px;border-radius:2px}.sf-page--legal{background:linear-gradient(180deg,#f7f3ef,#faf8f6)}.sf-legal{padding:2rem 0 3rem}.sf-legal__breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;margin-bottom:1.75rem;font-size:13px;font-weight:600;color:var(--sf-muted)}.sf-legal__breadcrumb a{color:var(--sf-accent);text-decoration:underline;text-underline-offset:3px}.sf-legal__article{padding:2.5rem 2.75rem;background:var(--sf-surface);border:1px solid rgb(255 255 255 / .72);border-radius:var(--sf-radius-lg);box-shadow:var(--sf-shadow-card)}.sf-legal__header{margin-bottom:1.25rem}.sf-legal__title{margin:0;font-size:clamp(2rem,4vw,2.75rem);font-weight:750;line-height:1.08;letter-spacing:-.04em}.sf-legal__meta{margin:0 0 1.25rem;font-size:14px;font-weight:600;color:var(--sf-muted)}.sf-legal__lede{margin:0 0 2rem;max-width:68ch;font-size:17px;line-height:1.65;color:#252a31}.sf-legal__section{margin-top:2rem}.sf-legal__section:first-of-type{margin-top:0}.sf-legal__section h2{margin:0 0 .85rem;font-size:1.25rem;font-weight:750;letter-spacing:-.02em}.sf-legal__section h3{margin:1.35rem 0 .55rem;font-size:1rem;font-weight:700}.sf-legal__section p,.sf-legal__section li{margin:0;font-size:15px;line-height:1.65;color:#2a3038}.sf-legal__section p+p,.sf-legal__section p+ul,.sf-legal__section ul+p{margin-top:.85rem}.sf-legal__section ul{margin:0;padding-left:1.25rem}.sf-legal__section li+li{margin-top:.55rem}.sf-legal__section a{color:var(--sf-accent);text-decoration:underline;text-underline-offset:3px}.sf-legal__section a:hover{color:var(--sf-accent-hover)}@media(max-width:639px){.sf-legal__article{padding:1.5rem 1.25rem}.sf-shell{width:min(calc(100% - 2rem),var(--sf-max-width))}.sf-stage{min-height:680px;background-size:auto 680px;background-position:58% top}.sf-header__inner{flex-wrap:wrap;min-height:auto}.sf-nav{display:flex;flex-wrap:wrap;gap:.75rem 1.1rem;order:3;width:100%;margin-left:0;position:static;transform:none}.sf-brand__mark{width:28px;height:28px}.sf-brand__name{font-size:13px}.sf-header__cta.sf-btn--primary{width:auto;min-height:38px;padding-inline:18px;font-size:13px}.sf-shell--hero{padding-top:176px;padding-left:0}.sf-hero__copy{max-width:18rem}.sf-hero__title{font-size:40px}.sf-features__grid{grid-template-columns:1fr;gap:0}.sf-feature{min-height:auto;padding:28px 16px;border-right:0;border-bottom:1px solid var(--sf-line)}.sf-feature:last-child{border-bottom:0}}@media(min-width:640px){.sf-nav{display:flex}}@media(min-width:1024px){.sf-features__grid{grid-template-columns:245px 223px 227px 222px minmax(0,1fr)}}@media(max-width:1023px)and (min-width:640px){.sf-stage{min-height:760px;background-size:auto 760px;background-position:59% top}}@media(prefers-reduced-motion:reduce){.sf-btn{transition:none}}:root{color-scheme:light;--sf-paper: #faf7f5;--sf-ink: #111111;--sf-muted: #6b7280;--sf-muted-light: #9ca3af;--sf-accent: #2f415d;--sf-accent-hover: #243347;--sf-surface: #ffffff;--sf-line: #e8e6e1;--sf-radius-lg: 13px;--sf-radius-pill: 999px;--sf-shadow-card: 0 31px 70px rgb(71 57 42 / .08);--sf-shadow-soft: 0 16px 40px rgba(17, 24, 39, .06);--sf-max-width: 1140px;--sf-font: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ui-density: 1;font-size:calc(16px * var(--ui-density));font-family:var(--sf-font)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-height:100dvh;background:var(--sf-paper);color:var(--sf-ink);font-family:var(--sf-font);font-synthesis:none;text-rendering:geometricPrecision}button,input,textarea,select{font:inherit}a{color:inherit}h1,h2,h3,p{margin:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sf-app{min-height:100dvh;display:grid;grid-template-rows:auto 1fr auto;background:radial-gradient(circle at 56% 89%,rgb(224 214 201 / .42),transparent 23rem),linear-gradient(180deg,#f7f3ef,#faf8f6);color:var(--sf-ink)}.sf-app *,.sf-app *:before,.sf-app *:after{box-sizing:border-box}.sf-shell{width:min(calc(100% - 4.25rem),var(--sf-max-width));margin-inline:auto}.sf-app-main{padding-block:2.75rem}.sf-app--builder{--sf-header-stack-height: 0;--builder-preview-sticky-top: var(--builder-toolbar-height, 56px);height:100dvh;max-height:100dvh;overflow:hidden}.sf-app-main--builder{padding:0;min-height:0;overflow:hidden}.sf-app-content{display:grid;gap:1.75rem}.sf-animate-in{animation:sf-fade-up .52s cubic-bezier(.16,1,.3,1) both}@keyframes sf-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.sf-header{padding-top:23px}.sf-header__inner{position:relative;display:flex;align-items:center;gap:1rem;min-height:50px}.sf-brand{display:inline-flex;align-items:center;gap:12px;color:var(--sf-ink);flex-shrink:0;text-decoration:none}.sf-brand__mark{width:42px;height:42px;color:var(--sf-ink);transform:scale(1.27)}.sf-brand__name{font-size:17px;font-weight:700;letter-spacing:.23em;line-height:1;text-transform:uppercase}.sf-nav{display:none;align-items:center;gap:47px;position:absolute;left:74.7%;top:13px;margin-left:0;transform:translate(-50%)}.sf-nav__link{font-size:14px;font-weight:600;line-height:1.2;color:var(--sf-ink);position:relative;padding-bottom:20px;text-decoration:none;transition:color .14s ease}.sf-nav__link.is-active:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--sf-accent)}.sf-header__actions{display:flex;align-items:center;gap:1rem;margin-left:auto;flex-shrink:0}.sf-header__cta{flex-shrink:0}.sf-nav__user{font-size:13px;font-weight:600;line-height:1.2;color:var(--sf-muted);padding-bottom:20px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sf-footer{padding:2rem 0 2.5rem;text-align:center}.sf-footer__links{display:flex;align-items:center;justify-content:center;gap:.65rem;margin-bottom:1rem}.sf-footer__link{font-size:14px;font-weight:600;color:var(--sf-ink);text-decoration:none}.sf-footer__link:hover{color:var(--sf-accent)}.sf-footer__sep{color:var(--sf-muted);font-weight:600}.sf-footer__copy{margin:0;font-size:16px;line-height:1.25;color:#20252d}.sf-footer__copy strong{color:var(--sf-ink);font-weight:700}.sf-footer__rule{display:block;width:43px;height:3px;margin:22px auto 0;background:var(--sf-accent);border-radius:var(--sf-radius-pill)}.sf-btn,.primary-button,.primary-link,.secondary-button,.secondary-link,.danger-button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:50px;padding:0 27px;border:0;border-radius:var(--sf-radius-pill);font-size:14px;font-weight:600;line-height:1;white-space:nowrap;text-decoration:none;cursor:pointer;transition:background .14s ease,transform .12s ease,box-shadow .14s ease}.sf-btn:focus-visible,.primary-button:focus-visible,.primary-link:focus-visible,.secondary-button:focus-visible,.secondary-link:focus-visible,.tertiary-button:focus-visible,.danger-button:focus-visible,.text-button:focus-visible{outline:2px solid var(--sf-accent);outline-offset:2px}.sf-btn--primary,.primary-button,.primary-link{background:var(--sf-accent);color:#fff;box-shadow:inset 0 0 0 1px #ffffff1f,0 2px 4px #141c282e}.sf-btn--primary:hover,.primary-button:hover:not(:disabled),.primary-link:hover{background:var(--sf-accent-hover)}.sf-btn--primary:active,.primary-button:active:not(:disabled),.primary-link:active{transform:scale(.98)}.sf-header__cta.sf-btn--primary{width:121px;min-height:50px;padding-inline:0;font-size:14px}.secondary-button,.secondary-link{background:var(--sf-surface);border:1px solid var(--sf-line);color:var(--sf-ink)}.secondary-button:hover:not(:disabled),.secondary-link:hover{background:#f8f6f2}.danger-button{background:#fff5f2;border:1px solid #e8c4bb;color:#7a2618}.primary-button:disabled,.secondary-button:disabled,.tertiary-button:disabled{opacity:.55;cursor:not-allowed}.tertiary-button{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-height:auto;padding:.35rem .5rem;border:0;border-radius:6px;background:none;color:var(--sf-muted);font-size:14px;font-weight:600;line-height:1;white-space:nowrap;cursor:pointer;transition:color .14s ease,background .14s ease}.tertiary-button:hover:not(:disabled){color:var(--sf-ink);background:#2f415d0f}.text-button{display:inline;padding:0;border:0;background:none;color:var(--sf-accent);font:inherit;font-weight:600;text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--sf-accent);cursor:pointer}.page-intro{display:grid;gap:.75rem}.page-intro__title{font-size:clamp(1.5rem,3vw,2rem);font-weight:750;line-height:1.12;letter-spacing:-.03em;max-width:24ch}.page-intro__lede,.helper-copy{color:#4f4a42;line-height:1.55;max-width:65ch}.support-page{display:grid;gap:1.5rem}.support-faq__heading{font-size:1rem;font-weight:650;letter-spacing:-.02em;margin:0 0 .75rem}.support-faq__list{display:grid;gap:1rem;margin:0}.support-faq__item{margin:0}.support-faq__question{font-size:.9375rem;font-weight:600;line-height:1.45;margin:0 0 .35rem}.support-faq__answer{color:#4f4a42;font-size:.9375rem;line-height:1.55;margin:0;max-width:65ch}.support-page__footer{margin:0;padding-top:.25rem;border-top:1px solid rgba(0,0,0,.08)}.kicker{color:var(--sf-muted);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.setup-grid,.pair-grid,.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;align-items:start}.setup-grid--split{grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:1.25rem}.metric-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.devices-screen{display:grid;gap:1rem}.devices-screen__toolbar{display:flex;justify-content:flex-end}.devices-screen__claim-form{max-width:min(100%,360px);gap:.75rem}.devices-screen__claim-form .form-label{gap:.4rem}.devices-screen__claim-form .button-row{gap:.5rem}.devices-screen__claim-form .primary-button{min-height:38px;padding:0 1.125rem;font-size:13px;box-shadow:inset 0 0 0 1px #ffffff1f,0 1px 2px #141c281f}.devices-screen__claim-form .tertiary-button{font-size:13px}.add-device-button{display:inline-grid;place-items:center;width:2.5rem;height:2.5rem;padding:0;border:none;border-radius:10px;background:transparent;color:var(--sf-accent);cursor:pointer;transition:color .14s ease,background .14s ease}.add-device-button:hover:not(:disabled){background:#2f415d14}.add-device-button:focus-visible{outline:none;box-shadow:0 0 0 3px #2f415d1f}.add-device-button.is-active{background:#2f415d1a}.add-device-button:disabled{cursor:not-allowed;opacity:.52}.add-device-button__icon{display:block}.device-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:1rem}.device-list--simple{grid-template-columns:minmax(0,1fr);gap:.65rem}.device-list-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;border:1px solid rgb(255 255 255 / .72);background:var(--sf-surface);border-radius:var(--sf-radius-lg);box-shadow:var(--sf-shadow-card);text-decoration:none;color:inherit;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.device-list-item:hover{border-color:#2f415d2e;box-shadow:var(--sf-shadow-card),0 0 0 1px #2f415d0f}.device-list-item__main{display:grid;gap:.3rem;min-width:0}.device-list-item__name{font-weight:650;letter-spacing:-.01em}.device-list-item__strava{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--sf-muted)}.device-list-item__strava .strava-mark{width:.75rem;height:.75rem;flex-shrink:0}.device-list-item__strava--good{color:#2d7a4b}.device-list-item__strava--warn{color:#a66b08}.device-list-item__strava--bad{color:#b5442f}.device-list-item__checkin{color:var(--sf-muted);font-size:.9rem;text-align:right}.device-detail{display:grid;gap:1rem;width:min(100%,720px);margin-inline:auto}.device-detail__preview{gap:1rem}.device-detail__preview .preview-image,.device-detail__preview .preview-image-empty{margin-inline:auto}.device-action-list{display:grid;border:1px solid rgb(255 255 255 / .72);background:var(--sf-surface);border-radius:var(--sf-radius-lg);box-shadow:var(--sf-shadow-card);overflow:hidden}.device-action-row{display:flex;align-items:center;width:100%;padding:.95rem 1.25rem;border:none;border-top:1px solid rgb(47 65 93 / .08);background:transparent;text-decoration:none;color:inherit;font:inherit;font-weight:600;text-align:left;cursor:pointer;transition:background .14s ease}.device-action-row:first-child{border-top:none}.device-action-row:hover:not(:disabled){background:#faf8f6}.device-action-row:disabled{opacity:.65;cursor:not-allowed}.device-action-row--danger{color:#7a2618}.surface,.status-panel{border:1px solid rgb(255 255 255 / .72);background:var(--sf-surface);border-radius:var(--sf-radius-lg);box-shadow:var(--sf-shadow-card)}.surface{padding:2rem 2.25rem;display:grid;gap:1.25rem}.text-surface,.success-surface{max-width:720px}.text-surface p,.success-surface p{max-width:62ch;color:#4f4a42;line-height:1.6}.metric-tile,.status-panel{min-height:auto;padding:1.25rem 1.5rem;display:grid;gap:.35rem;align-content:start}.metric-tile__label,.status-panel p{color:var(--sf-muted);font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.metric-tile__value,.status-panel strong{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:750;line-height:1.1;letter-spacing:-.02em;overflow-wrap:anywhere}.metric-tile--good,.status-panel.good{background:#f1f8f1;border-color:#d4e8d6}.metric-tile--warn,.status-panel.warn{background:#fff9eb;border-color:#f0e0b8}.metric-tile--bad,.status-panel.bad{background:#fff5f2;border-color:#f0d0c8}.meta-list{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.meta-list.dense{grid-template-columns:1fr}.meta-list div{min-height:72px;padding:1rem 1.1rem;border:1px solid var(--sf-line);border-radius:10px;background:#faf8f6;display:grid;gap:.35rem;align-content:start}.meta-list dt{color:var(--sf-muted);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.meta-list dd{margin:0;font-weight:650;overflow-wrap:anywhere}.form-stack{display:grid;gap:1rem}.form-label{display:grid;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--sf-ink)}.text-input,.pair-code-form input{width:100%;min-height:50px;border:1px solid var(--sf-line);border-radius:10px;background:#faf8f6;padding:0 1rem;color:var(--sf-ink);transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}.text-input:focus,.pair-code-form input:focus{outline:none;border-color:var(--sf-accent);background:var(--sf-surface);box-shadow:0 0 0 3px #2f415d1f}.text-input::placeholder{color:var(--sf-muted-light)}.button-row,.action-row{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center}.inline-error,.action-message{color:#7a2618;font-weight:600;font-size:.9rem}.sf-app--login .sf-app-main{display:grid;align-items:center;min-height:calc(100dvh - 180px)}.login-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(2rem,5vw,4rem);align-items:center;padding:1rem 0 2rem}.login-hero{display:grid;gap:1.25rem;padding-right:1rem}.login-hero__title{font-size:clamp(2.25rem,5vw,3.25rem);font-weight:750;line-height:1.04;letter-spacing:-.048em;max-width:12ch}.login-hero__title-accent{color:var(--sf-accent)}.login-hero__lede{font-size:1.05rem;line-height:1.55;color:#252a31;max-width:38ch}.login-card{padding:2.25rem 2.5rem;border:1px solid rgb(255 255 255 / .72);background:var(--sf-surface);border-radius:var(--sf-radius-lg);box-shadow:var(--sf-shadow-card);display:grid;gap:1.25rem}.login-card__head{display:grid;gap:.5rem}.login-card__title{font-size:1.35rem;font-weight:750;letter-spacing:-.02em}.login-status{display:inline-flex;align-items:center;gap:.5rem;width:fit-content;padding:.35rem .85rem;border-radius:var(--sf-radius-pill);border:1px solid var(--sf-line);background:#faf8f6;font-size:.8rem;font-weight:600}.login-status__dot{width:8px;height:8px;border-radius:50%;background:var(--sf-muted-light)}.login-status--good .login-status__dot{background:#2d7a4b}.login-status--warn .login-status__dot{background:#c38a16}.login-mode-toggle{display:inline-flex;padding:4px;border-radius:var(--sf-radius-pill);background:#f3f0eb;border:1px solid var(--sf-line);width:fit-content}.login-mode-toggle button{min-height:36px;padding:0 1rem;border:0;border-radius:var(--sf-radius-pill);background:transparent;font-size:.85rem;font-weight:600;color:var(--sf-muted);cursor:pointer;transition:background .14s ease,color .14s ease}.login-mode-toggle button.is-active{background:var(--sf-surface);color:var(--sf-ink);box-shadow:0 1px 3px #141c2814}.loading-skeleton{display:grid;gap:.75rem;padding:1.5rem 0}.loading-skeleton__bar{height:14px;border-radius:6px;background:linear-gradient(90deg,#ece8e2,#f7f4ef,#ece8e2);background-size:200% 100%;animation:sf-shimmer 1.4s ease-in-out infinite}.loading-skeleton__bar--wide{width:55%;height:28px}.loading-skeleton__bar--short{width:35%}.loading-skeleton__card{height:180px;border-radius:var(--sf-radius-lg);background:linear-gradient(90deg,#ece8e2,#f7f4ef,#ece8e2);background-size:200% 100%;animation:sf-shimmer 1.4s ease-in-out infinite}@keyframes sf-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.device-summary{gap:1.25rem}.preview-image,.preview-image-empty{width:400px;max-width:100%;aspect-ratio:400 / 300;border:1px solid rgb(20 28 40 / .12);border-radius:8px;background:#fff;image-rendering:pixelated}.preview-image{height:auto;display:block;object-fit:contain}.preview-image-empty{display:grid;place-items:center;color:#6a7078;font-size:.875rem;font-weight:600}.builder-preview-image{width:min(100%,368px);aspect-ratio:400 / 300;border:1px solid rgb(20 28 40 / .12);border-radius:8px;background:#fff;image-rendering:pixelated}.device-preview-panel{display:grid;gap:.75rem;justify-items:start}.setup-strava-panel{min-height:85px;padding:1rem 1.25rem;border:1px solid var(--sf-line);border-left:4px solid #fc4c02;border-radius:var(--sf-radius-lg);background:var(--sf-surface);display:flex;align-items:center;justify-content:space-between;gap:1rem}.setup-strava-panel>div{min-width:0;display:grid;gap:.35rem}.setup-strava-panel strong{font-size:1.05rem;line-height:1.15}.setup-strava-panel span{color:#4f4a42;line-height:1.4}.setup-strava-panel.good{border-left-color:#2d7a4b;background:#f1f8f1}.setup-strava-panel.warn{border-left-color:#c38a16;background:#fff9eb}.setup-strava-panel.bad{border-left-color:#b5442f;background:#fff5f2}.screen-toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.65rem}.toggle-row,.select-row{min-height:48px;padding:.75rem 1rem;border:1px solid var(--sf-line);border-radius:10px;background:#faf8f6;display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-weight:600;font-size:.9rem}.toggle-row input{width:18px;height:18px;accent-color:var(--sf-accent)}.select-row select{min-height:36px;border:1px solid var(--sf-line);border-radius:8px;background:var(--sf-surface);padding:0 .65rem}.claim-code-input{display:flex;align-items:center;gap:.3rem}.claim-code-input__sep{color:var(--sf-muted-light);font-size:.95rem;font-weight:500;line-height:1;-webkit-user-select:none;user-select:none}.claim-code-input__segment{width:3.5rem;min-height:38px;border:1px solid var(--sf-line);border-radius:8px;background:#faf8f6;padding:0;color:var(--sf-ink);font-size:.9375rem;font-weight:650;letter-spacing:.08em;text-align:center;text-transform:uppercase;transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}.claim-code-input__segment:focus{outline:none;border-color:var(--sf-accent);background:var(--sf-surface);box-shadow:0 0 0 2px #2f415d1a}.claim-code-input__segment:disabled{opacity:.55;cursor:not-allowed}.pair-code-form{display:grid;gap:1rem}.pair-code-form label{display:grid;gap:.5rem;font-weight:600}.pair-code-form span{color:var(--sf-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.pair-code-form input{max-width:280px;font-size:1.25rem;font-weight:700;letter-spacing:.08em}@media(max-width:639px){.sf-shell{width:min(calc(100% - 2rem),var(--sf-max-width))}.sf-header__inner{flex-wrap:wrap;min-height:auto}.sf-nav{display:flex;flex-wrap:wrap;gap:.75rem 1.1rem;order:3;width:100%;margin-left:0;position:static;transform:none}.sf-brand__mark{width:28px;height:28px}.sf-brand__name{font-size:13px}.sf-header__cta.sf-btn--primary{width:auto;min-height:38px;padding-inline:18px;font-size:13px}.login-layout,.setup-grid--split{grid-template-columns:1fr}.login-hero{padding-right:0}.meta-list{grid-template-columns:1fr}.surface{padding:1.5rem}}.setup-grid--single{grid-template-columns:minmax(0,1fr)}.account-sections{display:grid;gap:1rem}.account-section{margin-top:0}.account-section--danger{border-color:#b4282840}.login-forgot-button{justify-self:start}@media(min-width:640px){.sf-nav{display:flex}.setup-grid:not(.setup-grid--single),.pair-grid,.dashboard-grid{grid-template-columns:minmax(200px,.85fr) minmax(0,1.15fr)}}@media(min-width:900px){.setup-grid--metrics{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){.sf-btn,.primary-button,.secondary-button,.tertiary-button{transition:none}.sf-animate-in{animation:none}}.builder-grid{display:grid;grid-template-columns:minmax(175px,.78fr) minmax(331px,1.34fr) minmax(202px,.88fr);gap:13px;align-items:stretch}.builder-panel,.preview-stage{border:1px solid var(--sf-line);border-radius:var(--sf-radius-lg);background:var(--sf-surface)}.builder-panel{padding:15px;display:grid;gap:15px;align-content:start}.panel-section{display:grid;gap:11px}.panel-section h2{font-size:1.25rem;line-height:1.1;text-transform:capitalize}.preset-list,.module-list,.issue-list{display:grid;gap:7px}.preset-button,.module-chip{min-height:39px;border:1px solid var(--sf-line);border-radius:10px;background:#faf8f6;color:var(--sf-ink);padding:8px 9px;text-align:left;font-weight:700;text-transform:capitalize;cursor:pointer}.preset-button.is-active,.module-chip.is-active{background:var(--sf-accent);border-color:var(--sf-accent);color:#fff}.module-chip:disabled{cursor:not-allowed;opacity:.55}.module-chip{display:flex;justify-content:space-between;gap:7px;align-items:center}.module-chip small{color:var(--sf-muted);font-size:.72rem;text-transform:uppercase}.module-chip.is-active small{color:#ffffffbf}.selected-region-panel{padding:11px;border:1px solid var(--sf-line);border-radius:10px;background:#faf8f6}.assigned-module{display:grid;gap:7px}.assigned-module strong{line-height:1.15}.assigned-module small{color:var(--sf-muted);font-weight:700;text-transform:uppercase}.preview-stage{min-height:425px;padding:17px;display:grid;grid-template-rows:auto 1fr;gap:15px;align-content:start}.preview-toolbar{min-height:44px;display:flex;justify-content:space-between;align-items:center;gap:11px}.preview-toolbar strong{display:block;margin-top:4px}.builder-preview-empty{width:min(100%,368px);aspect-ratio:400 / 300;justify-self:center;align-self:start;border:1px solid rgb(20 28 40 / .12);border-radius:8px;background:#fff;image-rendering:pixelated;display:grid;place-items:center;color:var(--sf-muted);font-weight:700}.issue-list.compact{gap:.35rem}.builder-workbench--mobile{--builder-toolbar-height: 86px;grid-template-rows:auto minmax(0,1fr) auto;height:100dvh;max-height:100dvh;min-height:0;overflow:hidden}.builder-toolbar--mobile{display:block;grid-template-columns:unset;gap:0;padding:8px 12px 10px;min-height:auto}.builder-toolbar-mobile{display:grid;gap:8px;width:100%}.builder-toolbar-mobile-top{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-width:0}.builder-toolbar-mobile-leading{display:flex;align-items:center;gap:6px;min-width:0;flex:1 1 auto}.builder-menu-button{display:inline-grid;place-items:center;width:32px;height:32px;flex-shrink:0;border:none;background:transparent;color:#202326;border-radius:8px;text-decoration:none}.builder-toolbar--mobile .builder-toolbar-title{margin:0;font-size:.92rem;font-weight:700;line-height:1.15;text-align:left;color:#15201c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-toolbar--mobile .builder-status-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:100%}.builder-toolbar--mobile .status-pill{min-height:28px;min-width:0;padding:0 8px;border-radius:8px;gap:5px;font-size:.66rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-toolbar--mobile .status-dot{width:9px;height:9px;flex-shrink:0;border-width:2.5px}.builder-toolbar--mobile .strava-mark{width:11px;height:13px;flex-shrink:0}.builder-toolbar--mobile .strava-disconnect-popover{position:fixed;top:calc(var(--builder-toolbar-height) + 8px);right:12px;left:auto;width:min(294px,calc(100vw - 24px));max-height:calc(50dvh - var(--builder-toolbar-height) - 12px);overflow-y:auto;padding:12px;gap:8px;z-index:40}.builder-toolbar--mobile .strava-disconnect-title{font-size:.82rem;line-height:1.35;overflow-wrap:anywhere}.builder-toolbar--mobile .strava-disconnect-popover .helper-copy{font-size:.72rem;line-height:1.4}.builder-toolbar--mobile .strava-disconnect-actions{flex-direction:column;align-items:stretch;gap:6px}.builder-toolbar--mobile .strava-disconnect-actions .secondary-button,.builder-toolbar--mobile .strava-disconnect-actions .danger-button{width:100%;min-height:36px;padding:0 14px;font-size:.78rem;border-radius:8px}.upload-display-button--compact{width:auto;min-width:0;min-height:32px;padding:6px 10px;border-radius:8px;font-size:.66rem;font-weight:700;gap:5px;white-space:nowrap;flex-shrink:0}.upload-display-button--compact>span[aria-hidden=true]{width:12px;height:12px}.builder-workbench{--builder-toolbar-height: 56px;--builder-accent: #4a5568;--builder-accent-dark: #2d3748;--builder-accent-soft: #f4f5f7;--builder-accent-border: #c5cad3;--builder-border: #e2e5ea;--builder-muted: #6b7280;--builder-surface: #ffffff;--builder-canvas-bg: #f6f7f9;min-height:100vh;background:#f0f1f4;color:#15201c;display:grid;grid-template-rows:auto 1fr auto}.builder-toolbar{min-height:var(--builder-toolbar-height);padding:10px 22px;border-bottom:1px solid #dadde0;background:#fff;display:grid;grid-template-columns:1fr auto;align-items:center;gap:18px;position:sticky;top:0;z-index:20;width:100%;max-width:1649px;justify-self:center}.builder-brand-cluster,.builder-brand,.builder-status-row,.status-pill,.preview-header-actions{display:flex;align-items:center}.builder-brand-cluster{gap:17px;min-width:0}.builder-brand{gap:11px;color:#050505;text-decoration:none;white-space:nowrap;flex-shrink:0}.builder-brand__mark{width:28px;height:28px;color:#050505;display:block}.builder-brand strong{font-size:1.85rem;line-height:1;font-weight:850}.icon-button{width:31px;height:31px;border:1px solid #d7dbdf;border-radius:8px;background:#fbfbfa;color:#202326;display:inline-grid;place-items:center;cursor:pointer}.icon-button:disabled{cursor:not-allowed;opacity:.52}.menu-button{border-color:transparent;background:transparent;gap:4px}.menu-button span{width:18px;height:2px;background:#34383d;display:block}.brand-mark{width:28px;height:33px;border:2px solid #111;display:grid;grid-template-rows:1fr 1fr 1fr;padding:3px;gap:3px}.brand-mark span{border:2px solid #111;background:#fff}.builder-status-row{flex-wrap:wrap;gap:11px;min-width:0}.status-pill{min-height:39px;padding:0 15px;border:1px solid #d9dde1;border-radius:10px;background:#fff;gap:9px;color:#303236;font-weight:650;white-space:nowrap}button.status-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;text-align:left;cursor:pointer}button.status-pill:disabled{cursor:wait;opacity:.72}.status-pill.good{color:#3d4654}.status-pill.warn{color:#8c4b10;border-color:#efd2ad;background:#fff8ef}.status-pill.bad{color:#8a2a1e;border-color:#e4b7ad;background:#fff4f1}.status-pill.neutral{color:#3e4146}.status-dot{width:15px;height:15px;border:5px solid #e2e6ec;border-radius:919px;background:#5c6778}.status-dot.warn{border-color:#f7dfad;background:#b86d0f}.status-dot.bad{border-color:#f0c4ba;background:#b5442f}.status-dot.neutral{border-color:#dde1e5;background:#7a828b}.strava-status-anchor{position:relative}.strava-disconnect-popover{position:absolute;top:calc(100% + 7px);left:0;z-index:30;width:min(294px,calc(100vw - 29px));padding:15px;border:1px solid #d9dde1;border-radius:9px;background:#fff;box-shadow:0 15px 37px #11121329;display:grid;gap:11px}.strava-disconnect-title{margin:0;font-weight:750;color:#202326}.strava-disconnect-actions{display:flex;justify-content:flex-end;gap:9px}.strava-mark{width:15px;height:17px;position:relative;display:inline-block}.strava-mark:before,.strava-mark:after{content:"";position:absolute;left:2px;border-left:6px solid transparent;border-right:6px solid transparent}.strava-mark:before{top:0;border-bottom:10px solid #fc4c02}.strava-mark:after{top:7px;left:6px;border-bottom:8px solid #fc4c02;transform:scale(.75)}.clock-mark{width:17px;height:17px;border:2px solid #77808a;border-radius:919px;position:relative}.clock-mark:before,.clock-mark:after{content:"";position:absolute;left:6px;top:3px;width:2px;height:6px;background:#77808a;transform-origin:bottom}.clock-mark:after{top:7px;height:5px;transform:rotate(90deg)}.upload-display-button{min-height:44px;padding:0 20px;border:1px solid var(--builder-accent-dark);border-radius:10px;background:var(--builder-accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:.95rem;cursor:pointer;box-shadow:0 4px 14px #2d374829}.upload-display-button:disabled{opacity:.54;cursor:not-allowed}.upload-display-button>span[aria-hidden=true]{font-size:0;width:12px;height:14px;position:relative;display:inline-block;flex-shrink:0}.upload-display-button>span[aria-hidden=true]:before{content:"";position:absolute;left:1px;top:0;width:8px;height:8px;border-top:2px solid currentColor;border-right:2px solid currentColor;transform:rotate(-45deg)}.upload-display-button>span[aria-hidden=true]:after{content:"";position:absolute;left:4px;top:1px;width:2px;height:12px;background:currentColor;border-radius:1px}.builder-workbench-grid{min-height:0;width:100%;max-width:1680px;justify-self:center;display:grid;grid-template-columns:320px minmax(560px,1fr) 360px}.display-builder-sidebar,.builder-preview-column,.module-settings-panel{min-width:0;min-height:0;background:var(--builder-surface)}.display-builder-sidebar{border-right:1px solid #dadde0;display:grid;grid-template-rows:1fr;min-height:0}.module-settings-panel{border-right:0;border-left:1px solid #dadde0;display:grid;grid-template-rows:auto 1fr}.sidebar-scroll,.settings-form{overflow:auto}.sidebar-scroll{padding:24px 22px;display:grid;gap:22px;align-content:start}.builder-sidebar-section,.settings-form,.settings-block{display:grid;gap:13px}.builder-sidebar-section h1,.builder-sidebar-section h2,.builder-preview-column h2,.module-settings-panel h2{margin:0;color:#15201c;line-height:1.1}.builder-sidebar-hero{display:flex;align-items:flex-start;gap:12px}.builder-sidebar-hero-icon{width:40px;height:40px;border:1px solid var(--builder-border);border-radius:10px;background:#f8faf9;color:var(--builder-accent-dark);display:inline-grid;place-items:center;flex-shrink:0}.builder-sidebar-hero h1{font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.builder-sidebar-hero p{margin-top:4px;color:var(--builder-muted);font-size:.82rem;font-weight:500;line-height:1.35}.builder-sidebar-section h2,.builder-preview-column h2,.module-settings-panel h2,.settings-block-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--builder-muted)}.section-heading-row{display:flex;align-items:center;justify-content:space-between;gap:11px}.tiny-help{width:17px;height:17px;border:1px solid #979da4;border-radius:919px;color:#555d66;display:inline-grid;place-items:center;font-size:.78rem;font-weight:800}.layout-preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.layout-preset-card{min-height:92px;padding:12px 10px 10px;border:1px solid var(--builder-border);border-radius:14px;background:var(--builder-surface);color:#1f2b26;display:grid;justify-items:center;align-content:center;gap:8px;cursor:pointer;box-shadow:0 1px 2px #1018140a;transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}.layout-preset-card:hover{border-color:#cdd2da}.layout-preset-card.is-active{border-color:var(--builder-accent);background:var(--builder-accent-soft);box-shadow:0 0 0 1px var(--builder-accent) inset}.layout-preset-card span:last-child{min-width:0;font-size:.78rem;line-height:1.12;font-weight:650;text-align:center;overflow-wrap:anywhere}.layout-diagram{width:56px;height:42px;border:1.5px solid #3d4a44;border-radius:4px;display:block;position:relative;background:#fff}.layout-diagram span{position:absolute;border:1px solid #3d4a44;border-radius:1px;background:#ffffffd9}.module-palette-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.module-palette-chip{min-height:40px;padding:8px 10px;border:1px solid var(--builder-border);border-radius:12px;background:var(--builder-surface);color:#1f2b26;display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;text-align:left;cursor:grab;box-shadow:0 1px 2px #1018140a}.module-palette-chip:active{cursor:grabbing}.module-palette-chip.is-active{border-color:var(--builder-accent);background:var(--builder-accent-soft);color:var(--builder-accent-dark);box-shadow:0 0 0 1px var(--builder-accent) inset}.module-palette-chip:hover:not(:disabled){border-color:#cdd2da;background:#f8f9fb}.module-palette-chip:disabled{cursor:not-allowed;opacity:.55}.module-palette-icon{min-width:22px;height:22px;border:1px solid #d5dae1;border-radius:8px;display:inline-grid;place-items:center;color:#4a5568;background:#f4f5f7;flex-shrink:0}.module-palette-icon svg{display:block}.module-palette-chip.is-active .module-palette-icon{border-color:color-mix(in srgb,var(--builder-accent) 45%,#d5dae1);background:color-mix(in srgb,var(--builder-accent-soft) 70%,#f4f5f7);color:var(--builder-accent-dark)}.builder-sidebar-footer{padding-top:20px;border-top:1px solid #e4e7ea;display:grid;gap:15px}.segmented-setting{display:grid;grid-template-columns:85px 1fr;align-items:center;gap:13px}.segmented-setting>span,.settings-row>span,.settings-block-label,.toggle-switch-row>span:first-child{color:#17191b;font-size:.86rem;font-weight:750}.segmented-setting small,.toggle-switch-row small{width:15px;height:15px;margin-left:6px;border:1px solid #9ba2aa;border-radius:919px;color:#69727d;display:inline-grid;place-items:center;font-size:.62rem}.segmented-setting>div{border:1px solid #d9dde1;border-radius:10px;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;overflow:hidden}.segmented-setting button{min-height:33px;border:0;border-right:1px solid #d9dde1;background:#fff;color:#31353a;font-size:.78rem;font-weight:650;cursor:pointer}.segmented-setting button:last-child{border-right:0}.segmented-setting button.is-active{background:var(--builder-accent-soft);color:var(--builder-accent-dark);box-shadow:0 0 0 1px var(--builder-accent-border) inset}.builder-preview-column{position:sticky;top:var(--builder-preview-sticky-top, var(--builder-toolbar-height));height:calc(100vh - var(--builder-preview-sticky-top, var(--builder-toolbar-height)));min-height:calc(100vh - var(--builder-preview-sticky-top, var(--builder-toolbar-height)));padding:20px 24px 24px;background:var(--builder-canvas-bg);display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:14px;align-content:safe center;align-items:stretch;justify-items:stretch}.preview-column-header{width:100%;display:grid;gap:10px;justify-self:stretch}.preview-column-title-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.preview-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}.preview-header-actions{justify-content:space-between;gap:17px;flex-wrap:wrap}.preview-canvas-shell{width:100%;min-height:0;display:grid;align-content:start}.preview-canvas{width:100%;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none}.epaper-screen{width:100%;aspect-ratio:400 / 300;border:1px solid #e2e5ea;border-radius:16px;background:#fff;position:relative;overflow:hidden}.epaper-screen .builder-live-preview-svg,.epaper-screen .builder-preview-image,.epaper-screen .builder-preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;display:block}.epaper-screen .builder-preview-image{z-index:2;image-rendering:pixelated;transition:opacity .14s ease}.epaper-screen .builder-preview-image.is-syncing{opacity:.16}.builder-live-preview-svg{z-index:1;background:#fff}.local-preview-page{fill:#fff}.local-preview-frame{fill:#fff;stroke:#101112;stroke-width:1.5}.local-preview-frame.empty{stroke-dasharray:5 4;stroke:#9099a3}.local-preview-frame-bottom{fill:none}.local-preview-module.is-selected .local-preview-frame{stroke:var(--builder-accent);stroke-width:2.5}.local-preview-title,.local-preview-label,.local-preview-muted,.local-preview-small-value,.local-preview-value,.local-preview-pinned-value,.local-preview-hero-value,.local-preview-setup-url{fill:#111;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Arial,sans-serif}.local-preview-title{font-size:9px;font-weight:850;letter-spacing:0}.local-preview-label,.local-preview-muted{font-size:9px;font-weight:700}.local-preview-muted{fill:#707982}.local-preview-small-value{font-size:10px;font-weight:850}.local-preview-value{font-size:20px;font-weight:850}.local-preview-pinned-value{font-size:28px;font-weight:900}.local-preview-hero-value{font-size:33px;font-weight:850}.local-preview-setup-url{font-size:7px;font-weight:650}.local-preview-progress-track{fill:#fff;stroke:#111;stroke-width:1}.local-preview-progress-fill,.local-preview-split-bar,.local-preview-dot.active{fill:#111}.local-preview-dot{fill:#fff;stroke:#111;stroke-width:1.5}.local-preview-cell-region{transform-box:fill-box;transform-origin:0 0}@media(prefers-reduced-motion:reduce){.local-preview-cell-region{transition:none}}.local-preview-map-grid-fill{fill:#f1f3f1;stroke:#111;stroke-width:.75;opacity:.85}.local-preview-map-grid-line{stroke:#111;stroke-width:.75;stroke-dasharray:3 3;opacity:.38}.local-preview-route{fill:none;stroke:#111;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.epaper-screen .builder-preview-empty{display:grid;place-items:center;color:#6a7078;font-weight:800;z-index:1}.preview-region-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3}.preview-region-hitbox.is-selected{pointer-events:none}.preview-region-hitbox{position:absolute;border:2px solid transparent;border-radius:10px;background:transparent;color:transparent;cursor:pointer;padding:0;overflow:hidden}.preview-region-hitbox span{position:absolute;left:7px;right:7px;top:7px;color:transparent;font-size:.72rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-region-hitbox:hover,.preview-region-hitbox.is-selected,.preview-region-hitbox.is-drag-over{background:#2d37480a;border-color:var(--builder-accent)}.preview-region-hitbox:hover span,.preview-region-hitbox.is-selected span,.preview-region-hitbox.is-drag-over span{color:var(--builder-accent-dark)}.preview-hint{color:#6b7280;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;text-align:center;font-size:.78rem;font-weight:500;line-height:1.4;max-width:52ch;justify-self:center;margin:0}.preview-hint-icon{color:var(--builder-accent);flex-shrink:0}.preview-hint-info{width:16px;height:16px;border:1px solid #d1d5db;border-radius:999px;color:#6b7280;display:inline-grid;place-items:center;font-size:.62rem;font-weight:700;flex-shrink:0;cursor:help}.settings-panel-header{min-height:59px;padding:22px 20px 13px;display:flex;align-items:flex-start;justify-content:space-between;gap:13px;position:sticky;top:0;z-index:4;background:var(--builder-surface);border-bottom:1px solid #eceff2}.settings-form{padding:7px 20px 24px;align-content:start}.settings-row{display:grid;grid-template-columns:107px minmax(0,1fr);align-items:center;gap:13px}.settings-row input,.settings-row select,.unit-input,.settings-form select{min-width:0;width:100%;min-height:35px;border:1px solid #d8dde2;border-radius:6px;background:#fff;color:#202326;padding:0 11px}.settings-row select{cursor:pointer}.unit-input{padding:0;display:grid;grid-template-columns:1fr 42px;overflow:hidden}.unit-input input{border:0;border-radius:0}.unit-input span{border-left:1px solid #d8dde2;background:#f4f5f5;display:grid;place-items:center;color:#424850;font-weight:700}.settings-toggle-list{display:grid;gap:6px}.module-content-controls,.module-custom-settings,.module-settings-section,.module-configuration-settings,.module-header-controls,.content-setting-block,.pb-row-list{display:grid;gap:11px}.module-settings-section{padding-top:11px;border-top:1px solid #e4e8ea}.module-settings-section:first-child{padding-top:0;border-top:0}.module-header-controls{padding:9px;border:1px solid #e8eaee;border-radius:10px;background:#fafbfc}.content-layout-reset-button{justify-self:start;padding:8px 12px;border:1px solid var(--builder-border);border-radius:10px;background:var(--builder-surface);color:var(--builder-accent-dark);font-size:.76rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px}.content-layout-reset-button:hover{background:var(--builder-accent-soft);border-color:var(--builder-accent-border)}.module-content-cell-editor{position:absolute;z-index:4;pointer-events:none}.module-content-cell-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;gap:0;pointer-events:none}.module-content-cell-grid-line{border:0;border-radius:0;background:transparent}.module-content-cell-grid-line.is-drop-target{background:#2d37480f;border:0;box-shadow:none}.module-content-cell-tile.is-drop-origin{pointer-events:none;border-style:dashed;border-color:#4a556859;background:#f4f5f780;z-index:1}.module-content-cell-tile{position:absolute;box-sizing:border-box;border:1.5px solid rgba(74,85,104,.35);border-radius:10px;background:transparent;pointer-events:auto;transition:left .22s cubic-bezier(.22,1,.36,1),top .22s cubic-bezier(.22,1,.36,1),width .22s cubic-bezier(.22,1,.36,1),height .22s cubic-bezier(.22,1,.36,1),transform 80ms linear,border-color .16s ease,box-shadow .16s ease;touch-action:none}.module-content-cell-tile.is-selected{border-color:var(--builder-accent);background:#f4f5f773;box-shadow:0 0 0 1px #4a556838}.module-content-cell-handle{position:absolute;width:9px;height:9px;border:2px solid var(--builder-accent);border-radius:999px;background:#fff;box-shadow:0 1px 3px #1018142e;pointer-events:auto;touch-action:none;z-index:4}.module-content-cell-handle-nw{left:-5px;top:-5px;cursor:nwse-resize}.module-content-cell-handle-n{left:50%;top:-5px;transform:translate(-50%);cursor:ns-resize}.module-content-cell-handle-ne{right:-5px;top:-5px;cursor:nesw-resize}.module-content-cell-handle-e{right:-5px;top:50%;transform:translateY(-50%);cursor:ew-resize}.module-content-cell-handle-se{right:-5px;bottom:-5px;cursor:nwse-resize}.module-content-cell-handle-s{left:50%;bottom:-5px;transform:translate(-50%);cursor:ns-resize}.module-content-cell-handle-sw{left:-5px;bottom:-5px;cursor:nesw-resize}.module-content-cell-handle-w{left:-5px;top:50%;transform:translateY(-50%);cursor:ew-resize}.module-content-cell-editor.is-interacting .module-content-cell-tile.is-dragging.is-pending-disable{z-index:3;border-color:#c96a62;background:#fff4f2f5;box-shadow:0 10px 24px #78282024,0 0 0 1px #c96a626b}.module-content-cell-disable-indicator{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#b42318;pointer-events:none;z-index:4}.module-content-cell-editor.is-interacting .module-content-cell-tile.is-dragging{z-index:3;border-color:var(--builder-accent);background:#ffffffeb;box-shadow:0 10px 24px #1018201f,0 0 0 1px #4a556847;transition:left .22s cubic-bezier(.22,1,.36,1),top .22s cubic-bezier(.22,1,.36,1),width .22s cubic-bezier(.22,1,.36,1),height .22s cubic-bezier(.22,1,.36,1),transform 60ms linear,border-color .16s ease,box-shadow .16s ease}@media(prefers-reduced-motion:reduce){.module-content-cell-tile,.module-content-cell-editor.is-interacting .module-content-cell-tile.is-dragging{transition:border-color .16s ease,box-shadow .16s ease}}.module-content-cell-resize-handle{position:absolute;right:-7px;bottom:-7px;width:14px;height:22px;border:1px solid var(--builder-accent-border);border-radius:6px;background:#fff;color:var(--builder-accent);display:inline-grid;place-items:center;cursor:nwse-resize;box-shadow:0 2px 6px #1018141f;z-index:3}.module-content-cell-tile.is-selected:before{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%);width:10px;height:22px;border-radius:6px;background:#fff;border:1px solid var(--builder-accent-border);box-shadow:0 1px 4px #1018141a;pointer-events:none;z-index:2}.content-option-tile.is-focused{box-shadow:0 0 0 2px #4a556833}.content-option-tile-grid{display:grid;gap:7px}.content-option-tile{border:1px solid #e1e5e8;border-radius:10px;background:#fff;overflow:hidden}.content-option-tile-actions{display:grid;grid-template-columns:minmax(0,1fr) 34px auto;align-items:stretch}.content-option-expand{display:inline-grid;place-items:center;width:34px;border:0;border-left:1px solid #e8eaee;background:#fff;color:#6d7a74;cursor:pointer}.content-option-tile button{width:100%;min-height:35px;padding:7px 9px;border:0;background:#fff;color:#30353a;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px;align-items:center;text-align:left;cursor:pointer}.content-option-tile-actions>button:first-child{border-right:1px solid #e1e5e8}.content-option-tile button span{min-width:0;color:#202326;font-size:.76rem;font-weight:800;overflow-wrap:anywhere}.content-option-tile button small{color:#68717a;font-size:.68rem;font-weight:850;white-space:nowrap}.content-option-tile.is-active{border-color:var(--builder-accent);box-shadow:0 0 0 1px var(--builder-accent) inset}.content-option-tile.is-active button{background:var(--builder-accent-soft)}.pin-content-button{display:inline-grid;place-content:center;color:#667079}.pin-title-star-icon{display:block}.pin-content-button.is-active{background:#e8f6ef;color:#c99212}.content-option-tile.is-disabled button{cursor:not-allowed;opacity:.52}.content-size-selector{width:calc(100% - 18px);min-height:29px;margin:0 9px 9px;border:1px solid #cfd8d3;border-radius:6px;background:#fff;color:#283037;font-size:.72rem;font-weight:750}.content-setting-block{padding:9px;border:1px solid #e1e5e8;border-radius:6px;background:#fff}.content-setting-header{display:flex;align-items:center;justify-content:space-between;gap:11px}.content-setting-header span{color:#17191b;font-size:.86rem;font-weight:750}.content-setting-header small{color:#2b7658;font-size:.72rem;font-weight:850;text-transform:capitalize}.checkbox-option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.content-option-chip{min-height:31px;padding:6px 8px;border:1px solid #dfe3e6;border-radius:6px;background:#fbfbfa;color:#30353a;font-size:.74rem;font-weight:750;text-align:left;cursor:pointer}.content-option-chip.is-active{border-color:#5aa083;background:#f1faf6;color:#155f43;box-shadow:0 0 0 1px #5aa083 inset}.content-option-chip:disabled{cursor:not-allowed;opacity:.48}.pb-row-card{display:grid;grid-template-columns:auto minmax(0,1fr) 34px 34px;align-items:center;gap:0;border:1px solid var(--builder-border);border-radius:10px;background:var(--builder-surface);overflow:hidden}.pb-row-grip{display:inline-grid;place-items:center;padding:0 10px;color:#8b939c;align-self:stretch;border-right:1px solid #e8eaee}.pb-row-fields{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px;padding:8px 10px;min-width:0}.pb-row-distance,.pb-row-metric,.settings-textarea,.settings-number-input input{min-width:0;width:100%;border:1px solid #e3e8e5;border-radius:8px;background:#f9fbfa;color:#1f2b26}.pb-row-distance,.pb-row-metric,.settings-number-input input{min-height:34px;padding:0 10px;font-size:.8rem;font-weight:600}.settings-textarea{min-height:63px;padding:8px 9px;resize:vertical;line-height:1.35}.pb-row-expand,.pb-row-remove{width:34px;height:100%;min-height:50px;border:0;border-left:1px solid #e8eaee;background:#fff;color:#6d7a74;display:inline-grid;place-items:center;cursor:pointer}.pb-row-remove:disabled{cursor:not-allowed;opacity:.42}.add-row-button{min-height:38px;padding:0 14px;border:1px dashed #b8cfc5;border-radius:10px;background:#f8fbf9;color:var(--builder-accent-dark);font-size:.8rem;font-weight:600;cursor:pointer;justify-self:start}.add-row-button:hover:not(:disabled){background:var(--builder-accent-soft);border-color:var(--builder-accent-border)}.add-row-button:disabled{cursor:not-allowed;opacity:.5}.toggle-switch-row{min-height:22px;display:grid;grid-template-columns:1fr 31px;align-items:center;column-gap:9px;position:relative}.toggle-switch-row input{position:absolute;opacity:0;pointer-events:none}.toggle-switch-track{width:31px;height:18px;border-radius:919px;background:#c7cbd0;position:relative;transition:background .12s ease}.toggle-switch-track:after{content:"";position:absolute;width:15px;height:15px;border-radius:919px;left:2px;top:2px;background:#fff;box-shadow:0 1px 2px #0000003d;transition:transform .12s ease}.toggle-switch-row input:checked+.toggle-switch-track{background:var(--builder-accent)}.toggle-switch-row input:checked+.toggle-switch-track:after{transform:translate(13px)}.settings-divider{height:1px;margin:4px 0;background:#e3e6e8}.settings-helper{color:#8a9097;font-size:.82rem;line-height:1.45}.settings-empty-state{margin:7px 20px;padding:18px;border:1px dashed #cbd1d6;border-radius:7px;background:#fbfbfa;display:grid;gap:9px;color:#555d66;line-height:1.45}.settings-empty-state strong{color:#17191b}.issue-list.compact{gap:5px}.issue-list.compact p{font-size:.78rem;line-height:1.35}.builder-bottom-url{position:fixed;right:9px;bottom:4px;z-index:60;max-width:min(46vw,331px);overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;font-weight:650;line-height:1;color:#6b737c;opacity:.72;pointer-events:none}.builder-bottom-url a{color:inherit;text-decoration:none;pointer-events:auto}.upload-preparation-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:#10121480;display:grid;place-items:center;padding:22px}.upload-preparation-modal{width:min(720px,100%);max-height:min(92vh,846px);overflow:auto;border:1px solid #d8d1c2;border-radius:13px;background:#fffdf7;box-shadow:0 26px 74px #11121342;display:grid;gap:17px;padding:22px}.upload-preparation-header,.upload-preparation-footer{display:flex;align-items:center;justify-content:space-between;gap:13px}.upload-preparation-body{display:grid;justify-items:center}.upload-preparation-summary{width:min(100%,662px);display:grid;gap:13px;justify-items:start}.upload-preparation-config-summary{display:grid;gap:.45rem;width:100%}.upload-preparation-config-name{margin:0;font-size:1.05rem;font-weight:700;color:#2b2926}.upload-preparation-config-layout{margin:0;color:#6d675f;font-size:.92rem}.upload-preparation-module-list,.upload-preparation-warning-list{margin:0;padding-left:1.1rem;color:#4f4a42;font-size:.92rem}.upload-preparation-warning-list{color:#9a6b2f}.upload-preparation-status{margin:0;line-height:1.45;font-weight:600;color:#4f4a42}.upload-preparation-status--good{color:#2d7a4b}.upload-preparation-status--bad{color:#b5442f}.upload-preparation-spinner{display:inline-block;width:.85rem;height:.85rem;margin-right:.45rem;border:2px solid rgb(79 74 66 / .2);border-top-color:#4f4a42;border-radius:50%;vertical-align:-.1em;animation:upload-preparation-spin .8s linear infinite}@keyframes upload-preparation-spin{to{transform:rotate(360deg)}}.upload-preparation-preview-panel{width:100%;min-width:0;display:grid;gap:11px;justify-items:center;justify-self:center}.upload-preparation-modal .upload-preparation-preview,.upload-preparation-modal .upload-preparation-preview-empty{width:min(100%,400px);aspect-ratio:400 / 300;border:1px solid #111;background:#fff;image-rendering:pixelated}.upload-preparation-modal .upload-preparation-preview{height:auto;display:block;object-fit:contain}.upload-preparation-preview-empty{display:grid;place-items:center;color:#6a7078;font-weight:800}.upload-preparation-preview-empty--loading{padding:22px}.upload-preparation-preview-loading{display:grid;justify-items:center;gap:17px;text-align:center}.upload-preparation-preview-loading-copy{margin:0;color:#2d7a4b;font-size:.95rem;font-weight:700;letter-spacing:.01em}.upload-preparation-bounce-loader{display:flex;align-items:flex-end;justify-content:center;gap:7px;height:28px}.upload-preparation-bounce-loader span{width:9px;height:9px;border-radius:50%;background:#2f415d;animation:upload-preparation-bounce .72s cubic-bezier(.34,1.45,.64,1) infinite}.upload-preparation-bounce-loader span:nth-child(1){animation-delay:0s}.upload-preparation-bounce-loader span:nth-child(2){animation-delay:.12s}.upload-preparation-bounce-loader span:nth-child(3){animation-delay:.24s}@keyframes upload-preparation-bounce{0%,70%,to{transform:translateY(0) scale(.82);opacity:.42}35%{transform:translateY(-15px) scale(1);opacity:1}}.upload-preparation-footer-actions{display:flex;align-items:center;justify-content:flex-end;gap:13px}@media(max-width:780px){.app-shell{width:min(100%,calc(100% - 22px));padding:17px 0 26px}.topbar{align-items:flex-start;flex-direction:column}.pair-grid,.dashboard-grid,.setup-grid,.builder-grid,.meta-list,.screen-toggle-grid{grid-template-columns:1fr}.builder-grid{gap:11px}.setup-strava-panel{align-items:stretch;flex-direction:column}.preview-stage{order:-1;min-height:auto}.preview-toolbar{align-items:stretch;flex-direction:column}.status-panel{min-height:175px}}@media(max-width:1420px){.builder-workbench-grid{grid-template-columns:300px minmax(420px,1fr) 320px}.settings-row{grid-template-columns:96px minmax(0,1fr)}.content-option-tile-actions{grid-template-columns:minmax(0,1fr) 34px auto}}.builder-mobile-workbench{--builder-mobile-inset: 12px;--builder-mobile-section-gap: 24px;display:grid;grid-template-rows:auto auto minmax(0,1fr);grid-template-areas:"preview" "tabs" "panel";row-gap:var(--builder-mobile-section-gap);min-height:0;height:100%;overflow:hidden;background:var(--builder-canvas-bg, #f6f7f9)}.builder-mobile-workbench__preview{grid-area:preview;z-index:10;min-width:0;padding-inline:var(--builder-mobile-inset);padding-block-start:10px}.builder-mobile-workbench__tabs{grid-area:tabs;z-index:10;min-width:0;padding-inline:var(--builder-mobile-inset);padding-block-end:10px}.builder-preview-column--mobile{position:static;top:auto;height:auto;min-height:0;max-height:none;padding:0;background:transparent;align-content:start;grid-template-rows:auto;gap:0}.builder-preview-column--mobile .preview-column-header h2{font-size:.62rem;letter-spacing:.08em}.builder-preview-column--mobile .preview-canvas-shell{max-height:min(38vh,280px)}.builder-preview-column--mobile .epaper-screen{border-radius:12px}.builder-mobile-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.builder-mobile-tabs button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:44px;padding:6px 4px;border:1px solid #e2e5ea;border-radius:8px;background:#f6f7f9;color:#4a5568;font-size:.66rem;font-weight:600;cursor:pointer}.builder-mobile-tabs__icon{width:16px;height:16px;flex-shrink:0}.builder-mobile-tabs button.is-active{background:var(--builder-accent-dark, #2d3748);border-color:var(--builder-accent-dark, #2d3748);color:#fff}.builder-mobile-panel{grid-area:panel;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;min-height:0;padding-inline:var(--builder-mobile-inset);background:var(--builder-canvas-bg, #f6f7f9)}.builder-mobile-panel-layout{display:grid;gap:12px}.builder-mobile-panel .module-settings-panel{border:none;width:100%;min-height:0;background:transparent}.builder-mobile-panel .builder-sidebar-section,.builder-mobile-panel .settings-form,.builder-mobile-panel .settings-empty-state,.builder-mobile-panel .builder-sidebar-footer{padding:10px 12px;background:var(--builder-surface, #ffffff);border-radius:12px}.builder-mobile-panel .builder-sidebar-footer{padding-block-end:14px;border-top:none}.builder-workbench--mobile .layout-preset-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.builder-workbench--mobile .layout-preset-card{min-height:72px;padding:8px 6px 7px;border-radius:10px;gap:5px}.builder-workbench--mobile .layout-preset-card span:last-child{font-size:.68rem}.builder-workbench--mobile .layout-diagram{width:46px;height:34px}.builder-workbench--mobile .module-palette-grid{gap:6px}.builder-workbench--mobile .module-palette-chip{min-height:34px;padding:6px 8px;border-radius:9px;font-size:.72rem;gap:6px}.builder-workbench--mobile .segmented-setting{gap:6px}.builder-workbench--mobile .segmented-setting span{font-size:.72rem}.builder-workbench--mobile .segmented-setting button{min-height:30px;padding:5px 8px;font-size:.68rem}@media(max-width:1120px){.builder-toolbar--mobile{position:sticky;top:0}}@media(max-width:680px){.builder-toolbar:not(.builder-toolbar--mobile),.sidebar-scroll,.builder-sidebar-footer,.builder-preview-column:not(.builder-preview-column--mobile),.settings-panel-header,.settings-form,.builder-mobile-panel .builder-sidebar-section,.builder-mobile-panel .settings-form,.builder-mobile-panel .settings-empty-state,.builder-mobile-panel .builder-sidebar-footer{padding-left:12px;padding-right:12px}.builder-workbench--mobile .layout-preset-grid{grid-template-columns:1fr}.builder-brand strong{font-size:1.45rem}.builder-brand-cluster{gap:8px}.status-pill,.upload-display-button:not(.upload-display-button--compact){width:100%}.layout-preset-grid,.module-palette-grid{grid-template-columns:1fr}.settings-row,.segmented-setting{grid-template-columns:1fr;gap:7px}.preview-column-title-row{flex-direction:column;align-items:stretch;gap:10px}.preview-toolbar{width:100%}.preview-hint{max-width:none;font-size:.72rem;line-height:1.45;padding-inline:2px}.preview-canvas{padding:0;border-radius:0}.builder-bottom-url{position:static;right:auto;bottom:auto;max-width:none;width:100%;padding:10px 15px 14px;text-align:center;opacity:.82;pointer-events:auto;border-top:1px solid #e4e7ea;background:#f6f7f9}.builder-workbench{padding-bottom:0}.upload-preparation-overlay{padding:13px}.upload-preparation-modal{padding:17px}.upload-preparation-header,.upload-preparation-footer{align-items:stretch;flex-direction:column}.upload-preparation-footer-actions{width:100%;flex-direction:column;align-items:stretch}.upload-preparation-footer .primary-button,.upload-preparation-footer .tertiary-button{width:100%}}
