.saunter-app{display:flex;height:100vh;height:100dvh;background:var(--bg);color:var(--ink)}.saunter-app.loading{align-items:center;justify-content:center}.loading-message{font-family:Fraunces,serif;font-style:italic;font-size:1.125rem;color:var(--ink-light)}.panel{width:400px;min-width:400px;background:var(--bg);border-right:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:32px 28px 24px;border-bottom:1px solid var(--line);position:relative}.admin-badge{position:absolute;top:16px;right:16px;background:var(--accent);color:var(--bg);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;padding:3px 10px;border-radius:3px;display:flex;align-items:center;gap:6px}.eyebrow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-light);margin-bottom:10px}.panel-header h1{font-family:Fraunces,serif;font-size:36px;font-weight:500;line-height:1;letter-spacing:-.02em}.panel-header h1 em{font-style:italic;font-weight:400;color:var(--accent)}.panel-header .subtitle{font-family:Fraunces,serif;font-size:15px;font-style:italic;color:var(--ink-soft);margin-top:12px;line-height:1.4}.live-status{margin:20px 28px 0;background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--accent);padding:16px 18px}.live-status-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.live-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--accent)}.live-status-text{font-family:Fraunces,serif;font-size:16px;line-height:1.45}.live-status-text .name{font-weight:600;color:var(--accent)}.live-status-text .mile{font-weight:600}.live-status-text .mile-est{font-size:10px;font-weight:500;color:var(--ink-light);margin-left:3px;font-style:normal;vertical-align:middle}.live-status-note{font-size:13px;color:var(--ink-soft);font-style:italic;margin-top:8px;line-height:1.4}.live-status-text .companion{font-style:italic}.live-tracker-btn{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:var(--bg);padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;margin-top:14px;text-decoration:none;transition:opacity .2s}.live-tracker-btn:hover{opacity:.85}.last-updated{font-family:Fraunces,serif;font-style:italic;font-size:12px;color:var(--ink-light);margin-top:10px}.admin-panel{padding:18px 28px;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.admin-panel-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;border:none;padding:0;margin-bottom:12px;cursor:pointer;font-family:Inter,sans-serif;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-light)}.admin-panel-toggle:hover{color:var(--ink-soft)}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.admin-field{display:flex;flex-direction:column;gap:4px}.admin-field label{font-size:10px;color:var(--ink-light);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.admin-field input{font-size:13px;padding:7px 10px}.im-here-section{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:12px}.im-here-btn{background:var(--accent);color:#fff;border:none;padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.im-here-btn:hover{opacity:.9}.im-here-btn:disabled{opacity:.6;cursor:not-allowed}.im-here-btn.locating{animation:pulse-bg 1s infinite}@keyframes pulse-bg{0%,to{opacity:.8}50%{opacity:.5}}.location-error{color:#c44;font-size:12px}.last-update{font-size:11px;color:var(--ink-light);font-style:italic}.status-section{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.status-section label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:500;color:var(--ink-light);margin-bottom:6px}.status-section input{width:100%;padding:10px 12px;font-size:14px;border:1px solid var(--line);background:var(--bg)}.status-section input:focus{outline:none;border-color:var(--accent)}.currently-with-section{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.currently-with-section label{font-size:10px;color:var(--ink-light);text-transform:uppercase;letter-spacing:.1em;font-weight:500;display:block;margin-bottom:8px}.currently-with-list{display:flex;flex-wrap:wrap;gap:6px}.walker-toggle{background:var(--bg);border:1px solid var(--line);color:var(--ink-soft);padding:5px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.walker-toggle:hover{border-color:var(--ink-soft);color:var(--ink)}.walker-toggle.active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.no-walkers{font-size:12px;color:var(--ink-light);font-style:italic}.add-walker-row{display:flex;gap:6px;margin-top:10px}.add-walker-row input{flex:1;font-size:12px;padding:6px 10px}.add-walker-row .btn{padding:6px 12px;font-size:14px}.panel-content{flex:1;overflow-y:auto;padding:20px 28px;-webkit-overflow-scrolling:touch;min-height:0}.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.draw-prompt{margin-bottom:16px;background:var(--accent-soft);border:1px solid var(--accent);padding:14px 16px;font-size:13px;line-height:1.5;color:var(--ink)}.draw-prompt.saving{background:var(--bg-2);border-color:var(--line)}.draw-prompt.saving .step{color:var(--ink-soft);animation:pulse-text 1.5s infinite}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.5}}.draw-prompt .step{font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.12em;font-size:10px;display:block;margin-bottom:4px}.draw-prompt .live-mileage{font-family:Fraunces,serif;font-size:18px;font-weight:600;color:var(--accent);margin-top:8px}.draw-prompt .live-mileage em{font-size:13px;font-weight:400;color:var(--ink-soft);font-style:italic}.draw-prompt button{background:transparent;border:1px solid var(--ink);color:var(--ink);padding:5px 12px;font-size:12px;font-weight:500;cursor:pointer;margin-top:10px}.draw-prompt button:hover{background:var(--bg)}.add-segment-btn{width:100%;background:var(--bg);border:1.5px dashed var(--line);color:var(--ink-soft);padding:16px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;cursor:pointer;margin-bottom:16px;transition:all .15s}.add-segment-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.segment-card{background:var(--bg);border:1px solid var(--line);padding:14px 16px;margin-bottom:8px;cursor:pointer;transition:all .15s;position:relative}.segment-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--seg-color, var(--ink-light))}.segment-card:hover{border-color:var(--ink-light);background:var(--bg-2)}.segment-card.selected{border-color:var(--accent);background:var(--accent-soft)}.segment-card.mine{background:var(--bg-2)}.segment-card.mine:before{width:4px}.segment-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.segment-walker{display:flex;align-items:center;gap:8px;font-family:Fraunces,serif;font-size:16px;font-weight:500}.segment-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:var(--seg-color, var(--ink-light))}.mine-tag{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);background:var(--bg);padding:2px 6px;border:1px solid var(--accent);border-radius:2px}.active-tag{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--bg);background:var(--accent);padding:2px 6px;border-radius:2px;animation:pulse 2s infinite}.segment-card.passed{opacity:.5}.segment-card.passed:before{background:var(--ink-light)}.segment-card.active{border-color:var(--accent);background:var(--accent-soft)}.segment-card.active:before{background:var(--accent);width:4px}.segment-range{font-size:13px;color:var(--ink-soft);font-family:Fraunces,serif;font-style:italic}.segment-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-light);margin-top:6px}.segment-meta .distance{color:var(--ink-soft);font-weight:500}.segment-meta .eta{color:var(--ink);font-weight:600}.segment-meta .dot{color:var(--line)}.segment-actions{display:flex;gap:6px;margin-top:10px}.segment-actions button{background:transparent;border:1px solid var(--line);color:var(--ink-soft);padding:4px 10px;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.segment-actions button:hover{border-color:var(--ink-soft);color:var(--ink)}.segment-actions button.danger:hover{border-color:var(--accent);color:var(--accent)}.empty-state{text-align:center;padding:30px 16px;color:var(--ink-light);font-family:Fraunces,serif;font-style:italic;font-size:14px;line-height:1.5}.person-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}.person-row:last-child{border-bottom:none}.person-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Fraunces,serif;font-weight:500;font-size:16px;color:#fff;flex-shrink:0}.person-info{flex:1;min-width:0}.person-name{font-family:Fraunces,serif;font-weight:500;font-size:15px}.person-name .walking-now{color:var(--accent);font-size:10px;font-weight:600;margin-left:6px;text-transform:uppercase;letter-spacing:.12em}.person-segments{font-size:12px;color:var(--ink-light);margin-top:2px;line-height:1.3}.person-actions{display:flex;gap:4px}.person-actions button{background:transparent;border:1px solid var(--line);color:var(--ink-soft);padding:3px 8px;font-size:10px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.08em;transition:all .15s}.person-actions button.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.person-actions button:hover:not(.active){border-color:var(--ink-soft);color:var(--ink)}.identity-row{display:flex;gap:8px;align-items:center}.identity-name{flex:1;font-family:Fraunces,serif;font-size:18px;font-weight:600}input[type=text],input[type=time],input[type=number]{flex:1;background:var(--bg-2);border:1px solid var(--line);padding:10px 14px;color:var(--ink);font-family:Inter,sans-serif;font-size:14px;outline:none;transition:border-color .15s}input:focus{border-color:var(--accent)}input::placeholder{color:var(--ink-light)}.btn{background:var(--ink);color:var(--bg);border:none;padding:10px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.btn:hover{opacity:.85}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-link{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}.btn-link:hover{border-color:var(--ink-soft);color:var(--ink);opacity:1}.map-container{flex:1;position:relative}.mode-switcher{position:absolute;top:16px;left:16px;background:var(--bg);border:1px solid var(--line);padding:4px;z-index:1000;display:flex;gap:2px;align-items:center;box-shadow:0 2px 12px #0000000f}.mode-label{color:var(--ink-light);padding:0 8px 0 6px;font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:600}.mode-btn{background:transparent;border:none;color:var(--ink-light);padding:5px 12px;border-radius:2px;cursor:pointer;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.08em}.mode-btn:hover{color:var(--ink)}.mode-btn.active{background:var(--ink);color:var(--bg)}.map-legend{position:absolute;bottom:24px;left:24px;background:var(--bg);border:1px solid var(--line);padding:14px 18px;z-index:1000;box-shadow:0 2px 12px #0000000f}.legend-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-light);margin-bottom:10px}.legend-item{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:12px;color:var(--ink-soft)}.legend-item:last-child{margin-bottom:0}.legend-line{width:22px;height:3px;border-radius:2px;flex-shrink:0}.legend-line.thick{height:6px}.legend-line.dashed{background:repeating-linear-gradient(90deg,var(--ink) 0,var(--ink) 3px,transparent 3px,transparent 6px);opacity:.7}:global(.section-tooltip){background:var(--bg)!important;border:1px solid var(--ink)!important;color:var(--ink)!important;font-family:Fraunces,serif!important;font-size:13px!important;padding:10px 14px!important;border-radius:3px!important;box-shadow:0 4px 12px #0000001a!important}:global(.section-tooltip strong){color:var(--accent);font-weight:600}:global(.leaflet-tooltip-left.section-tooltip:before),:global(.leaflet-tooltip-right.section-tooltip:before){display:none!important}:global(.route-eta-popup .leaflet-popup-content-wrapper){background:var(--bg)!important;border:1px solid var(--ink)!important;border-radius:4px!important;box-shadow:0 4px 16px #00000026!important;padding:0!important}:global(.route-eta-popup .leaflet-popup-content){margin:0!important;padding:12px 16px!important}:global(.route-eta-popup .leaflet-popup-tip-container){display:none!important}:global(.rep-mile){font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-light);margin-bottom:4px}:global(.rep-eta){font-family:Fraunces,serif;font-size:20px;font-weight:500;color:var(--ink);line-height:1}:global(.seg-popup .leaflet-popup-content-wrapper){background:var(--bg)!important;border:1px solid var(--ink)!important;border-radius:4px!important;box-shadow:0 4px 16px #00000026!important;padding:0!important}:global(.seg-popup .leaflet-popup-content){margin:0!important;padding:0!important;min-width:180px}:global(.seg-popup .leaflet-popup-tip-container){display:none!important}:global(.sp-body){padding:2px 0}:global(.sp-row){display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line)}:global(.sp-row:last-child){border-bottom:none}:global(.sp-dot){width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}:global(.sp-walker){font-family:Fraunces,serif;font-size:15px;font-weight:500;color:var(--ink);margin-bottom:2px}:global(.sp-range){font-size:11px;color:var(--ink-light);font-style:italic;margin-bottom:3px}:global(.sp-times){font-family:Fraunces,serif;font-size:14px;font-weight:500;color:var(--ink)}.saunter-app[data-drawing=true] .map-container{cursor:crosshair}.panel-top{flex-shrink:0}.panel-handle,.panel-size-btn{display:none}.draw-error{background:#fee;border:1px solid #c44;color:#a33;padding:10px 14px;font-size:13px;margin-bottom:12px}@media(max-width:768px){.saunter-app{flex-direction:column-reverse}.panel{width:100%;min-width:unset;height:42vh;border-right:none;border-top:1px solid var(--line);transition:height .3s cubic-bezier(.32,.72,0,1)}.map-container{min-height:0;overflow:hidden}.fullscreen-btn{display:none}.panel-header{padding:10px 16px}.panel-header h1{font-size:20px}.eyebrow{font-size:9px;margin-bottom:5px}.admin-badge{top:12px;right:12px;padding:4px 10px}.panel-content{padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.identity-inline{padding:14px 0 16px;margin-bottom:14px}.identity-inline h3{font-size:10px;margin-bottom:8px}.identity-row{gap:10px}.identity-row input{font-size:16px;padding:12px 14px}.identity-row .btn{padding:12px 18px;font-size:14px}.identity-compact{padding:6px 0 10px;margin-bottom:6px}.identity-pill{font-size:13px;padding:5px 10px 5px 7px}.segments-header{padding:14px 16px;font-size:14px}.fullscreen-btn{bottom:90px;right:10px;width:44px;height:44px}.live-status{margin:8px 16px 0;padding:10px 14px}.live-status-header{display:none}.live-status-text{font-size:14px}.live-tracker-btn{margin-top:8px;padding:8px 14px;font-size:12px;width:auto;justify-content:flex-start}.last-updated{display:none}.admin-panel{padding:14px 16px}.admin-grid{gap:8px}.admin-field input{font-size:16px;padding:10px 12px}.currently-with-section{margin-top:12px;padding-top:12px}.currently-with-list{gap:8px}.walker-toggle{padding:10px 14px;font-size:13px;min-height:44px}.add-walker-row{margin-top:12px}.add-walker-row input{font-size:16px;padding:12px 14px}.add-walker-row .btn{padding:12px 16px;min-width:44px}.add-segment-btn{padding:18px 16px;font-size:14px;min-height:56px}.segment-card{padding:16px;margin-bottom:10px}.segment-walker{font-size:17px}.segment-range{font-size:14px;margin-top:4px}.segment-meta{font-size:13px;margin-top:8px}.segment-actions{margin-top:12px}.segment-actions button{padding:10px 16px;font-size:13px;min-height:44px}.mode-switcher{top:10px;left:10px;right:10px;width:auto;justify-content:center}.mode-label{display:none}.mode-btn{padding:10px 16px;font-size:12px;min-height:40px}.map-legend{display:none}.token-modal{padding:24px 20px;margin:16px;width:calc(100% - 32px);max-width:none}.token-modal h3{font-size:20px}.token-modal p{font-size:14px}.token-modal input{font-size:16px;padding:14px}.token-modal-actions{flex-direction:column-reverse;gap:8px}.token-modal-actions .btn,.token-modal-actions .btn-link{width:100%;padding:14px;font-size:15px;min-height:48px;justify-content:center}.panel-handle{display:flex;justify-content:center;align-items:flex-end;gap:5px;padding:10px 0 6px}.panel-size-btn{border:none;background:var(--line);cursor:pointer;border-radius:2px;padding:0;width:5px;transition:background .15s,transform .15s}.panel-size-btn:nth-child(1){height:4px}.panel-size-btn:nth-child(2){height:9px}.panel-size-btn:nth-child(3){height:14px}.panel-size-btn.active{background:var(--ink)}.panel-size-btn:hover{background:var(--ink-light);transform:scaleX(1.4)}.panel.collapsed{height:44px}.panel.expanded{height:100dvh;border-top:none}.map-draw-btn{display:flex;align-items:center;gap:6px;position:absolute;bottom:100px;right:16px;background:var(--accent);color:#fff;border:none;padding:12px 18px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;z-index:1000;box-shadow:0 2px 14px #00000040;border-radius:24px;cursor:pointer;white-space:nowrap;transition:transform .1s,opacity .1s}.map-draw-btn:active{opacity:.9;transform:scale(.96)}.map-draw-banner{display:flex;align-items:center;justify-content:space-between;position:absolute;top:0;left:0;right:0;background:var(--ink);color:var(--bg);padding:14px 16px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;z-index:1001;line-height:1.3}.map-draw-banner button{background:transparent;border:none;color:var(--bg);font-size:20px;cursor:pointer;padding:0 0 0 14px;opacity:.65;flex-shrink:0;line-height:1}}@media(max-width:380px){.panel-header h1{font-size:24px}.segment-walker{font-size:16px}.mode-btn{padding:8px 12px;font-size:11px}}.token-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.token-modal{background:var(--bg);border:1px solid var(--line);padding:28px 32px;max-width:380px;width:90%;box-shadow:0 8px 32px #00000026}.token-modal h3{font-family:Fraunces,serif;font-size:22px;font-weight:500;margin-bottom:8px}.token-modal p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-bottom:18px}.token-modal input{width:100%;margin-bottom:6px;box-sizing:border-box}.token-modal .error{color:#c44;font-size:12px;margin-bottom:12px}.token-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.admin-badge .admin-logout{background:transparent;border:none;color:var(--bg);opacity:.7;cursor:pointer;padding:0;font-size:12px;line-height:1}.admin-badge .admin-logout:hover{opacity:1}.error-banner{position:fixed;top:0;left:0;right:0;background:#c44;color:#fff;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;z-index:3000;font-size:14px}.error-banner button{background:transparent;border:none;color:#fff;font-size:18px;cursor:pointer;padding:0 4px;opacity:.8}.error-banner button:hover{opacity:1}.token-error{background:#fee;border:1px solid #c44;color:#a33;padding:10px 12px;font-size:13px;margin-bottom:12px}.identity-inline{padding:16px 0 20px;border-bottom:1px solid var(--line);margin-bottom:16px}.identity-inline h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-light);margin-bottom:10px}.identity-compact{display:flex;align-items:center;gap:12px;padding:8px 0 12px;margin-bottom:8px}.identity-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;background:var(--bg-2);border:1px solid var(--line);border-left-width:3px;font-family:Fraunces,serif;font-size:14px;font-weight:500;color:var(--ink)}.identity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.btn-change{background:none;border:none;color:var(--ink-light);font-size:12px;cursor:pointer;padding:4px 8px;text-decoration:underline;text-underline-offset:2px}.btn-change:hover{color:var(--ink)}.segments-section{margin-top:8px}.segments-header{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--bg-2);border:1px solid var(--line);padding:12px 16px;font-size:13px;font-weight:600;color:var(--ink-soft);cursor:pointer;margin-bottom:12px}.segments-header:hover{background:var(--bg-3)}.collapse-icon{font-size:10px;transition:transform .2s}.collapse-icon.expanded{transform:rotate(180deg)}.map-draw-btn,.map-draw-banner{display:none}.fullscreen-btn{position:absolute;bottom:100px;right:10px;background:var(--bg);border:1px solid var(--line);width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;z-index:1000;box-shadow:0 2px 8px #0000001a;border-radius:4px}.fullscreen-btn:hover{background:var(--bg-2)}.saunter-app.fullscreen .panel{display:none}.saunter-app.fullscreen .map-container{width:100%;height:100vh}
