:root{--color-primary:#0e7c42;--color-dark:#0f172a;--color-light:#f8fafc;--color-accent:#f59e0b;--color-muted:#64748b;--color-red:#dc2626;--color-green:#16a34a;--color-blue:#1e40af;--color-white:#fff}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;background:var(--color-light);color:var(--color-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none;overscroll-behavior:none}body{overflow:hidden}button{font-family:inherit;cursor:pointer;border:none}.loader{font-size:18px;color:var(--color-muted)}.loader,.login-screen{display:flex;align-items:center;justify-content:center;height:100vh}.login-screen{flex-direction:column;text-align:center;padding:24px}.login-screen h1{font-size:32px;color:var(--color-primary);margin-bottom:16px}.login-screen p{font-size:16px;color:var(--color-muted);margin-bottom:32px}.login-button{background:var(--color-primary);color:var(--color-white);padding:16px 32px;border-radius:12px;font-size:18px;font-weight:600}.route-list{height:100vh;display:flex;flex-direction:column}.route-list__header{background:var(--color-primary);color:var(--color-white);padding:16px 20px;display:flex;justify-content:space-between;align-items:center}.route-list__header h1{font-size:18px;font-weight:600}.route-list__logout{background:hsla(0,0%,100%,.15);color:var(--color-white);padding:6px 14px;border-radius:8px;font-size:13px}.route-list__items{flex:1 1;overflow-y:auto;padding:16px}.route-card{background:var(--color-white);border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px rgba(0,0,0,.05);border-left:4px solid var(--color-muted);cursor:pointer}.route-card--in-progress{border-left-color:var(--color-green)}.route-card--paused{border-left-color:var(--color-accent)}.route-card--planned{border-left-color:var(--color-blue)}.route-card--completed{border-left-color:var(--color-muted);opacity:.7}.route-card__name{font-size:16px;font-weight:600;margin-bottom:4px}.route-card__code{font-size:12px;color:var(--color-muted);margin-bottom:8px}.route-card__meta{display:flex;gap:12px;font-size:13px;color:var(--color-muted)}.route-screen{height:100vh;display:flex;flex-direction:column}.route-screen__top{background:var(--color-dark);color:var(--color-white);padding:8px 16px;display:flex;justify-content:space-between;align-items:center;font-size:14px}.route-screen__top-left{display:flex;gap:12px;align-items:center}.route-screen__back{background:transparent;color:var(--color-white);font-size:14px}.route-screen__status{font-size:11px;background:hsla(0,0%,100%,.1);padding:4px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}.route-screen__map{flex:1 1;position:relative}.route-screen__bottom{background:var(--color-white);padding:12px;border-top:1px solid #e2e8f0}.route-screen__controls{display:flex;gap:8px;margin-top:8px}.route-screen__btn{flex:1 1;background:#f1f5f9;color:var(--color-dark);padding:10px 12px;border-radius:8px;font-size:13px;font-weight:600}.route-screen__btn--primary{background:var(--color-primary);color:var(--color-white)}.route-screen__btn--warn{background:var(--color-accent);color:var(--color-white)}.navbanner{position:absolute;top:12px;left:12px;right:12px;background:var(--color-white);border-radius:14px;padding:14px;display:flex;gap:14px;box-shadow:0 4px 14px rgba(0,0,0,.15);z-index:10}.navbanner--empty{background:var(--color-muted);color:var(--color-white)}.navbanner__icon{font-size:38px;width:50px;text-align:center;color:var(--color-primary)}.navbanner__body{flex:1 1;min-width:0}.navbanner__distance{font-size:22px;font-weight:700;color:var(--color-blue);line-height:1.1}.navbanner__instruction{font-size:14px;color:var(--color-dark);margin-top:2px}.navbanner__next{font-size:11px;color:var(--color-muted);margin-top:6px}.navbanner--waypoint{background:var(--color-green);color:var(--color-white);animation:waypointPulse 1.4s ease-in-out infinite alternate}.navbanner--waypoint-ts{background:var(--color-accent)}.navbanner--waypoint .navbanner__icon{font-size:44px;color:var(--color-white)}.navbanner--waypoint .navbanner__distance{color:var(--color-white)}.navbanner--waypoint .navbanner__instruction{color:var(--color-white);font-weight:600;font-size:16px}.navbanner__waypoint-label{font-size:10px;font-weight:700;letter-spacing:1.5px;opacity:.85;margin-bottom:2px}@keyframes waypointPulse{0%{box-shadow:0 4px 14px rgba(22,163,74,.3)}to{box-shadow:0 4px 20px rgba(22,163,74,.7)}}.complete-btn{width:100%;padding:18px;border-radius:12px;text-align:center;background:#cbd5e1;color:var(--color-muted);transition:background .2s}.complete-btn--active{background:var(--color-green);color:var(--color-white)}.complete-btn--active.complete-btn--ts{background:var(--color-accent)}.complete-btn--disabled{cursor:not-allowed}.complete-btn__label{font-size:18px;font-weight:700}.complete-btn__sub{font-size:12px;margin-top:4px;opacity:.85}