.territory-route-preview{aspect-ratio:280/120;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:10px;width:100%;max-width:100%;overflow:hidden}.territory-route-preview--empty{aspect-ratio:auto;background:var(--color-surface);min-height:7rem}.territory-route-preview__svg{width:100%;height:100%;display:block}.territory-route-preview__bg{fill:var(--color-surface)}
.territory-detail-sheet{z-index:1200;pointer-events:none;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.territory-detail-sheet__backdrop{pointer-events:auto;cursor:pointer;background:#00000073;border:none;position:absolute;inset:0}.territory-detail-sheet__panel{z-index:1;pointer-events:auto;background:var(--color-surface-elevated);border:1px solid var(--color-border-strong);border-radius:14px;width:min(100%,22rem);max-height:min(85vh,520px);padding:1rem 1.1rem 1.15rem;position:relative;overflow-y:auto;box-shadow:0 12px 40px #00000059}.territory-detail-sheet__header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;display:flex}.territory-detail-sheet__title{color:var(--color-text);margin:0;font-size:1.05rem}.territory-detail-sheet__date,.territory-detail-sheet__owner{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.8rem}.territory-detail-sheet__stats{grid-template-columns:repeat(4,1fr);gap:.5rem;margin:.85rem 0 0;display:grid}.territory-detail-sheet__stat{text-align:center}.territory-detail-sheet__stat dt{color:var(--color-text-muted);margin:0 0 .2rem;font-size:.7rem;font-weight:500}.territory-detail-sheet__stat dd{color:var(--color-text);margin:0;font-size:.85rem;font-weight:700}.territory-detail-sheet__empty{color:var(--color-text-muted);margin:.75rem 0 0;font-size:.85rem}.territory-detail-sheet__strava-link{margin:.75rem 0 0}.territory-detail-sheet__loading{justify-content:center;padding:2rem;display:flex}.territory-detail-sheet__spinner{border:3px solid var(--color-border-strong);border-right-color:#0000;border-radius:50%;width:1.5rem;height:1.5rem;animation:.65s linear infinite territory-detail-sheet-spin}@keyframes territory-detail-sheet-spin{to{transform:rotate(360deg)}}@media (max-width:480px){.territory-detail-sheet{padding:.75rem}.territory-detail-sheet__stats{grid-template-columns:repeat(2,1fr)}}
.territory-scope-tabs{background:color-mix(in srgb, var(--color-surface-elevated) 88%, transparent);border:1px solid var(--color-border-strong);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;padding:.2rem;display:inline-flex;box-shadow:0 4px 20px #00000040}.territory-scope-tabs__btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.45rem .85rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.territory-scope-tabs__btn:hover:not(:disabled):not(.is-active){color:var(--color-text);background:var(--color-surface-hover)}.territory-scope-tabs__btn.is-active{color:#0b0d11;background:#facc15}.territory-scope-tabs__btn:disabled{opacity:.45;cursor:not-allowed}
.territory-routes__title{margin:0 0 .5rem;font-size:1.5rem}.territory-routes__desc{color:var(--text-muted,#6b7280);margin:0 0 1rem}.territory-routes__opt-in{cursor:pointer;align-items:flex-start;gap:.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.territory-routes__opt-in input{cursor:pointer;margin-top:.15rem}.territory-routes__actions{margin-bottom:1.25rem}.territory-routes__actions-toolbar{border:1px solid var(--color-border-strong,#d1d5db);background:var(--color-input-bg,#fff);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.65rem .75rem;display:flex}.territory-routes__sync-btn{cursor:pointer;background:var(--color-primary);min-width:10.5rem;min-height:2.25rem;color:var(--color-on-primary);border-color:var(--color-primary);justify-content:center;align-items:center;display:inline-flex}.territory-routes__sync-btn:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.territory-routes__sync-btn:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}.territory-routes__btn-spinner--on-primary{border-color:var(--color-on-primary);border-right-color:#0000}.territory-routes__period-sync{flex-wrap:wrap;align-items:center;gap:.35rem;display:inline-flex}.territory-routes__period-sync-label{color:var(--text-muted,#6b7280);font-size:.8rem}.territory-routes__period-select.form-select,.territory-routes__list-period-select.form-select{border:1px solid var(--color-border-strong,#d1d5db);background:var(--color-input-bg,#fff);min-height:2.25rem;color:var(--color-text);cursor:pointer;border-radius:8px;padding:.35rem .5rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.territory-routes__period-select.form-select:hover:not(:disabled),.territory-routes__list-period-select.form-select:hover:not(:disabled){border-color:var(--color-text-muted)}.territory-routes__period-select.form-select:focus,.territory-routes__list-period-select.form-select:focus{border-color:var(--color-text);box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}.territory-routes__period-select.form-select:disabled,.territory-routes__list-period-select.form-select:disabled{opacity:.55;cursor:not-allowed}.territory-routes__period-btn{background:var(--color-surface);min-height:2.25rem;color:var(--color-text);border-color:var(--color-border-strong)}.territory-routes__period-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-text-muted)}.territory-routes__btn-spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:1rem;height:1rem;animation:.65s linear infinite territory-routes-spin;display:inline-block}@keyframes territory-routes-spin{to{transform:rotate(360deg)}}.territory-routes__layout{grid-template-columns:minmax(220px,320px) 1fr;align-items:start;gap:1rem;display:grid}@media (max-width:768px){.territory-routes__layout{grid-template-columns:1fr}}.territory-routes__list-pagination{border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-top:.75rem;padding-top:.5rem;display:flex}.territory-routes__list-page-indicator{color:var(--color-text-muted);text-align:center;min-width:5rem;font-size:.85rem}.territory-routes__list-panel{border:1px solid var(--border-color,#e5e7eb);border-radius:8px;max-height:480px;padding:.75rem;overflow-y:auto}.territory-routes__sub{margin:0 0 .75rem;font-size:1rem}.territory-routes__list{margin:0;padding:0;list-style:none}.territory-routes__item{text-align:left;border:none;border-left:3px solid color-mix(in srgb, var(--territory-accent,#2563eb) 55%, transparent);cursor:pointer;background:0 0;border-radius:6px;width:100%;padding:.6rem .5rem .6rem .45rem;display:block}.territory-routes__item:hover{background:var(--surface-muted,#f3f4f6)}.territory-routes__item.is-active{background:color-mix(in srgb, var(--territory-accent,#2563eb) 12%, var(--surface-muted,#f3f4f6));border-left-color:var(--territory-accent,#2563eb)}.territory-routes__item-name{font-size:.9rem;font-weight:600;display:block}.territory-routes__item-meta{color:var(--text-muted,#6b7280);margin-top:.15rem;font-size:.8rem;display:block}.territory-routes__map-panel{border:1px solid var(--border-color,#e5e7eb);border-radius:8px;min-height:200px;padding:.75rem}.territory-routes__map-panel .territory-routes__page-loading{min-height:min(360px,55vh)}.territory-routes__map-steps{color:var(--text-muted,#6b7280);margin:0 0 .75rem;font-size:.85rem;line-height:1.45}.territory-routes__detail-meta{flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.territory-routes__hint,.territory-routes__empty{color:var(--text-muted,#6b7280);font-size:.9rem}.territory-routes__map-loading,.territory-routes__page-loading{min-height:12rem;color:var(--text-muted,#6b7280);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.territory-routes--loading{box-sizing:border-box;flex:1;justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 10rem);margin:0;padding:0;display:flex}.territory-routes__loading-text{margin:0;font-size:.9rem}.territory-routes__btn-spinner--page{border-width:3px;width:1.5rem;height:1.5rem}.territory-routes__stat-hint{color:var(--text-muted,#6b7280);margin:.35rem 0 0;font-size:.75rem;line-height:1.4}.territory-routes__item-name-row{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.territory-routes__badge{border-radius:4px;padding:.1rem .35rem;font-size:.65rem;font-weight:600;line-height:1.2}.territory-routes__badge--loop{color:#3730a3;background:#e0e7ff}.territory-routes__badge--territory{background:color-mix(in srgb, var(--territory-accent,#2563eb) 18%, white);color:var(--territory-accent,#2563eb);border:1px solid color-mix(in srgb, var(--territory-accent,#2563eb) 40%, transparent)}.territory-routes__list-header{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.territory-routes__list-header .territory-routes__sub{margin-bottom:0}.territory-routes__list-period{border:1px solid var(--color-border-strong,#d1d5db);background:var(--color-input-bg,#fff);border-radius:8px;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.5rem .6rem;display:flex}.territory-routes__list-period-label{color:var(--text-muted,#6b7280);flex:none;font-size:.8rem}.territory-routes__list-period-select.form-select{flex:1;min-width:4.5rem}.territory-routes__list-loading{min-height:6rem}.territory-routes__prefs{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.territory-routes__colors-label{margin-bottom:.35rem;font-size:.85rem;display:block}.territory-routes__color-row{flex-wrap:wrap;gap:.35rem;display:flex}.territory-routes__color-swatch{cursor:pointer;border:2px solid #0000;border-radius:4px;width:1.5rem;height:1.5rem;padding:0}.territory-routes__color-swatch.is-selected{border-color:var(--text-primary,#111827);box-shadow:0 0 0 1px #fff}.territory-routes__stats-row{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}@media (max-width:640px){.territory-routes__stats-row{grid-template-columns:1fr}}.territory-routes__stat-card{border:1px solid var(--border-color,#e5e7eb);border-radius:8px;padding:.75rem}.territory-routes__leaderboard{margin:0;padding:0;font-size:.85rem;list-style:none}.territory-routes__leaderboard li{align-items:center;gap:.35rem;padding:.25rem 0;display:flex}.territory-routes__lb-color{border-radius:2px;flex-shrink:0;width:.65rem;height:.65rem}.territory-routes__lb-rank{width:1.25rem;color:var(--text-muted,#6b7280)}.territory-routes__lb-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.territory-routes__lb-count{font-weight:600}.territory-routes__hint--sm{margin-bottom:.5rem;font-size:.8rem}.territory-routes__detail-sheet{border:1px solid var(--color-border-strong,#d1d5db);background:var(--color-surface-elevated,#fff);color:var(--color-text);border-radius:8px;margin-top:1rem;padding:1rem 1.1rem;box-shadow:0 1px 3px #0000000f}.territory-routes__detail-sheet--route{border-left:4px solid var(--territory-accent,#2563eb)}.territory-routes__detail-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.65rem;display:flex}.territory-routes__detail-title{color:var(--color-text);flex:1;margin:0;font-size:1rem}.territory-routes__detail-close{flex-shrink:0}.territory-routes__detail-accent{align-items:center;gap:.5rem;margin:0 0 .5rem;display:flex}.territory-routes__detail-route-name{color:var(--color-text);margin:0;font-size:.95rem;font-weight:600}.territory-routes__detail-meta{color:var(--color-text-muted,#6b7280);margin:0 0 .5rem;font-size:.875rem;line-height:1.45}.territory-routes__detail-badges{flex-wrap:wrap;gap:.35rem;margin-bottom:.35rem;display:flex}.territory-routes__detail-sheet .territory-routes__badge--territory{background:color-mix(in srgb, var(--territory-accent,#2563eb) 18%, var(--color-surface));color:var(--territory-accent,#2563eb);border:1px solid color-mix(in srgb, var(--territory-accent,#2563eb) 40%, transparent)}html[data-theme=dark] .territory-routes__detail-sheet .territory-routes__badge--loop{color:#c7d2fe;background:#312e81}.territory-routes--immersive{width:100%;max-width:none;min-height:0;min-height:calc(100dvh - var(--header-height,76px) - 11rem);min-height:calc(100vh - var(--header-height,76px) - 11rem);flex-direction:column;flex:1 1 0;margin:0;padding:0;display:flex;position:relative}.territory-routes__map-shell{background:var(--color-bg-page);flex:1 1 0;width:100%;min-height:0;position:relative;overflow:hidden}@media (max-width:640px){.territory-routes--immersive{min-height:calc(100dvh - var(--header-height,76px) - 14rem);min-height:calc(100vh - var(--header-height,76px) - 14rem)}}.territory-routes__map-top-bar{z-index:1100;pointer-events:auto;flex-direction:column;align-items:center;gap:.45rem;max-width:min(96vw,22rem);display:flex;position:absolute;top:.75rem;left:50%;transform:translate(-50%)}.territory-routes__crew-select-wrap{flex-direction:column;align-items:stretch;gap:.2rem;width:100%;display:flex}.territory-routes__crew-select-label{color:var(--color-text-muted);text-align:center;font-size:.72rem}.territory-routes__crew-select.form-select{width:100%;font-size:.85rem}.territory-routes__crew-filters{border:1px solid var(--color-border-strong);background:color-mix(in srgb, var(--color-surface-elevated) 94%, transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:10px;flex-direction:column;gap:.4rem;width:100%;padding:.5rem .65rem;display:flex}.territory-routes__crew-filter-row{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.territory-routes__crew-filter-check{color:var(--color-text-muted);cursor:pointer;align-items:center;gap:.35rem;font-size:.78rem;display:inline-flex}.territory-routes__crew-filter-select.form-select{flex:4.5rem;min-width:0;padding:.3rem .45rem;font-size:.8rem}.territory-routes__crew-filter-meta{color:var(--color-text-muted);text-align:center;margin:0;font-size:.72rem}.territory-routes__crew-filter-meta--warn{color:var(--color-warning,#b45309)}.territory-routes__crew-member-picker{flex-direction:column;gap:.35rem;display:flex}.territory-routes__crew-member-picker-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.35rem;display:flex}.territory-routes__crew-member-picker-label{color:var(--color-text);font-size:.78rem;font-weight:600}.territory-routes__crew-member-picker-actions{flex-wrap:wrap;gap:.25rem;display:flex}.territory-routes__crew-member-action-btn{border:1px solid var(--color-border-strong);background:var(--color-surface-elevated,#fff);min-height:auto;color:var(--color-text);cursor:pointer;border-radius:6px;padding:.15rem .45rem;font-size:.72rem}.territory-routes__crew-member-action-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.territory-routes__crew-member-action-btn:disabled{opacity:.5;cursor:not-allowed}.territory-routes__crew-member-list{border:1px solid var(--color-border-strong);background:var(--color-input-bg,#fff);border-radius:8px;max-height:9.5rem;margin:0;padding:0;list-style:none;overflow-y:auto}.territory-routes__crew-member-item{border-bottom:1px solid var(--color-border,#e5e7eb)}.territory-routes__crew-member-item:last-child{border-bottom:none}.territory-routes__crew-member-check{cursor:pointer;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.35rem .5rem;font-size:.78rem;display:flex}.territory-routes__crew-member-check input{cursor:pointer;flex-shrink:0}.territory-routes__crew-member-swatch{border:1px solid color-mix(in srgb, var(--color-text) 25%, transparent);border-radius:50%;flex-shrink:0;width:.65rem;height:.65rem}.territory-routes__crew-member-name{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;overflow:hidden}.territory-routes__crew-member-badge{background:color-mix(in srgb, var(--color-primary) 18%, transparent);color:var(--color-primary);border-radius:4px;padding:.05rem .3rem;font-size:.65rem}.territory-routes__crew-member-badge--muted{background:color-mix(in srgb, var(--color-text-muted) 20%, transparent);color:var(--color-text-muted)}.territory-routes__map-fab-col{z-index:1100;pointer-events:auto;flex-direction:column;gap:.45rem;display:flex;position:absolute;top:4.5rem;right:.65rem}.territory-routes__fab{border:1px solid var(--color-border-strong);background:color-mix(in srgb, var(--color-surface-elevated) 92%, transparent);width:2.5rem;height:2.5rem;color:var(--color-text);cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;text-decoration:none;display:inline-flex;box-shadow:0 4px 16px #0003}.territory-routes__fab--link:hover{background:var(--color-surface-hover)}.territory-routes__map-scope-hint{z-index:1090;text-align:center;max-width:min(92vw,22rem);color:var(--color-text-muted);background:color-mix(in srgb, var(--color-surface-elevated) 90%, transparent);border:1px solid var(--color-border-strong);pointer-events:none;border-radius:8px;margin:0;padding:.45rem .65rem;font-size:.75rem;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.territory-routes__map-overlay-message,.territory-routes__map-loading-overlay{z-index:1080;text-align:center;background:color-mix(in srgb, var(--color-bg-page) 82%, transparent);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:1rem;display:flex;position:absolute;inset:0}.territory-routes__settings-drawer{z-index:1300;justify-content:flex-end;display:flex;position:fixed;inset:0}.territory-routes__settings-backdrop{-webkit-backdrop-filter:blur(5px);cursor:pointer;background:#0f172a61;border:none;position:absolute;inset:0}.territory-routes__settings-panel{z-index:1;background:var(--color-surface-elevated);border-left:1px solid var(--color-border-strong);width:min(100vw,420px);max-height:100dvh;position:relative;overflow-y:auto;box-shadow:-8px 0 32px #00000040}.territory-routes__settings-header{border-bottom:1px solid var(--color-border);background:var(--color-surface-elevated);z-index:1;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem;display:flex;position:sticky;top:0}.territory-routes__settings-body{padding:0 1rem 1.25rem}.territory-routes--immersive .territory-routes__list-panel{border:none;border-radius:0;max-height:none;padding:0 0 1rem}.territory-routes--immersive .territory-routes__stats-row{grid-template-columns:1fr;gap:.75rem;display:grid}@media (min-width:480px){.territory-routes--immersive .territory-routes__stats-row{grid-template-columns:1fr 1fr}}
