.welcome-page{box-sizing:border-box;text-align:center;background:linear-gradient(135deg,#4361ee 0%,#3a0ca3 100%);flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:100vh;padding:40px 20px;display:flex}.welcome-icon-container{background:#fff;border-radius:24px;justify-content:center;align-items:center;width:120px;height:120px;margin-bottom:16px;display:flex;box-shadow:0 8px 32px #ffffff40}.welcome-icon-container .welcome-icon{object-fit:contain;width:80px;height:80px}.welcome-page .welcome-pretitle{color:#ffffffd9;letter-spacing:.5px;margin:0;font-size:16px}.welcome-title{color:#fff;letter-spacing:-.5px;margin:4px 0 8px;font-size:36px;font-weight:700}.welcome-subtitle{color:#fffc;margin:0 0 24px;font-size:16px}.welcome-countdown{color:#ffffffb3;margin:16px 0 32px;font-size:14px}.welcome-social-row{justify-content:center;align-items:center;gap:16px;margin-bottom:40px;display:flex}.welcome-social-icon{color:#fff;background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;text-decoration:none;transition:background .2s,transform .2s;display:flex}.welcome-social-icon:hover{background:#ffffff4d;transform:scale(1.1)}.welcome-social-icon svg{width:20px;height:20px}.welcome-footer{color:#fffffff2;text-shadow:0 1px 2px #0000004d;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}@media (width<=480px){.welcome-title{font-size:28px}.welcome-icon-container{width:100px;height:100px}.welcome-icon-container .welcome-icon{width:64px;height:64px}}.login-page{box-sizing:border-box;background:#f8f9fa;flex-direction:column;align-items:center;min-height:100vh;padding:0;display:flex}.login-header{box-sizing:border-box;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:10px;width:100%;padding:16px 24px;display:flex}.login-header-icon{object-fit:contain;border-radius:8px;width:40px;height:40px}.login-header-title{color:#1a1a2e;letter-spacing:-.3px;font-family:Outfit,Inter,sans-serif;font-size:18px;font-weight:700}.login-form-section{box-sizing:border-box;width:100%;max-width:420px;padding:32px 24px}.login-heading{color:#1a1a2e;letter-spacing:-.5px;margin:0 0 4px;font-family:Outfit,Inter,sans-serif;font-size:28px;font-weight:700}.login-subtitle{color:#6c757d;margin:0 0 28px;font-size:15px}.login-field{text-align:left;margin-bottom:18px}.login-label{color:#1a1a2e;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.login-input{color:#1a1a2e;box-sizing:border-box;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.login-input.login-input-error{border-color:#ef4444}.login-input::placeholder{color:#9ca3af}.login-password-wrapper{position:relative}.login-eye-toggle{cursor:pointer;color:#6c757d;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-error-msg{color:#ef4444;text-align:left;margin:6px 0 0;font-size:13px}.login-form-error{text-align:center;margin-bottom:12px}.login-forgot-row{text-align:right;margin-bottom:20px}.login-forgot-link{color:#4361ee;font-size:14px;font-weight:500;text-decoration:none}.login-forgot-link:hover{text-decoration:underline}.login-btn-primary{color:#fff;cursor:pointer;background:#4361ee;border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:16px;font-weight:600;transition:background .2s,transform .1s}.login-btn-primary:hover:not(:disabled){background:#3a0ca3}.login-btn-primary:active:not(:disabled){transform:scale(.98)}.login-btn-primary:disabled{opacity:.6;cursor:not-allowed}.login-divider{align-items:center;gap:12px;margin:24px 0;display:flex}.login-divider-line{background:#d1d5db;flex:1;height:1px}.login-divider-text{color:#9ca3af;white-space:nowrap;font-size:13px;font-weight:500}.login-btn-google{color:#1a1a2e;cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px;font-family:inherit;font-size:15px;font-weight:500;transition:background .2s,border-color .2s;display:flex}.login-btn-google:hover{background:#f3f4f6;border-color:#9ca3af}.login-helper-text{color:#6c757d;text-align:center;margin:16px 0 0;font-size:13px;line-height:1.5}.login-social-section{text-align:center;padding:24px}.login-social-label{color:#9ca3af;letter-spacing:1px;margin:0 0 12px;font-size:12px;font-weight:600}.login-social-icon{color:#6c757d;background:#f3f4f6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;text-decoration:none;transition:background .2s,color .2s;display:flex}.login-social-icon:hover{color:#fff;background:#4361ee}.ad-banner-space{box-sizing:border-box;width:100%;max-width:420px;padding:0 24px 24px}@media (width<=480px){.login-form-section{padding:24px 20px}.login-heading{font-size:24px}}.create-password-page{background:var(--color-surface);min-height:100dvh;padding:var(--space-xl) var(--space-lg);padding-top:calc(var(--safe-top,0px) + var(--space-xl))}.create-password-back{cursor:pointer;width:36px;height:36px;color:var(--color-text);border-radius:var(--radius-full);transition:background var(--transition-fast);margin-bottom:var(--space-lg);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.create-password-back:hover{background:var(--color-surface-alt)}.create-password-content{max-width:400px;margin:0 auto}.create-password-title{font-size:var(--font-2xl);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.create-password-subtitle{color:var(--color-text-secondary);font-size:var(--font-base);margin-bottom:var(--space-xl)}.create-password-field{margin-bottom:var(--space-md)}.create-password-label{font-size:var(--font-sm);font-weight:var(--fw-semibold);color:var(--color-text);margin-bottom:var(--space-xs);display:block}.create-password-input-wrapper{align-items:center;display:flex;position:relative}.create-password-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-base);color:var(--color-text);background:var(--color-surface);transition:all var(--transition-fast);outline:none;padding:14px 48px 14px 16px}.create-password-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4361ee1f}.create-password-input-error{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef444414}.create-password-eye{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:14px}.create-password-error{font-size:var(--font-sm);color:var(--color-danger);margin-top:var(--space-xs);animation:.2s slideDown}.create-password-form-error{text-align:center;margin:var(--space-md) 0}.create-password-btn-primary{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);width:100%;font-size:var(--font-base);font-weight:var(--fw-semibold);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-md);border:none;padding:14px 24px}.create-password-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.create-password-btn-primary:disabled{opacity:.5;cursor:not-allowed}.create-password-btn-cancel{width:100%;color:var(--color-primary);font-size:var(--font-base);font-weight:var(--fw-medium);cursor:pointer;margin-top:var(--space-sm);background:0 0;border:none;padding:12px 24px}.alarms-page{background:var(--color-bg,#f8f9fa);min-height:100vh;font-family:var(--font-family,"Inter", sans-serif);flex-direction:column;padding-bottom:80px;display:flex;position:relative}.alarms-error{color:var(--color-danger,#ef4444);text-align:center;background:#fdecea;padding:10px 20px;font-size:14px}.alarms-loading,.alarms-empty{color:var(--color-text-secondary,#6c757d);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.alarms-loading .spinner{border:3px solid #dee2e6;border-top-color:var(--color-primary,#4361ee);border-radius:50%;width:32px;height:32px;margin-bottom:12px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.alarms-empty-icon{margin-bottom:12px;font-size:48px}.alarms-empty p{color:var(--color-text,#1a1a2e);margin:0;font-size:16px;font-weight:600}.alarms-empty-sub{color:var(--color-text-secondary,#6c757d)!important;margin-top:4px!important;font-size:13px!important;font-weight:400!important}.alarms-list{flex-direction:column;flex:1;gap:12px;padding:12px 16px;display:flex}.alarm-card{background:var(--color-surface,#fff);border-radius:var(--radius-lg,12px);box-shadow:var(--shadow-sm,0 1px 3px #00000014);-webkit-user-select:none;user-select:none;cursor:default;border-left:4px solid #dee2e6;align-items:center;padding:16px;transition:border-color .3s,box-shadow .2s;display:flex}.alarm-card--active{border-left-color:var(--color-success,#4caf50);box-shadow:var(--shadow-md,0 4px 12px #0000001a)}.alarm-card-body{flex:1;min-width:0}.alarm-name{color:var(--color-text,#1a1a2e);white-space:nowrap;text-overflow:ellipsis;margin:0 0 6px;font-size:16px;font-weight:700;overflow:hidden}.alarm-route{color:var(--color-text-secondary,#6c757d);flex-wrap:wrap;align-items:center;gap:6px;margin:0 0 6px;font-size:13px;display:flex}.alarm-from,.alarm-to{white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.alarm-arrow{color:var(--color-primary,#4361ee);font-weight:700}.alarm-travel{color:var(--color-text-secondary,#6c757d);border-radius:var(--radius-sm,4px);background:#f1f3f5;align-items:center;gap:4px;padding:2px 8px;font-size:12px;display:inline-flex}.alarm-card-actions{flex-shrink:0;margin-left:12px}.toggle-switch{cursor:pointer;width:48px;height:26px;display:inline-block;position:relative}.fab{bottom:calc(80px + env(safe-area-inset-bottom,0px));background:var(--color-primary,#4361ee);color:#fff;cursor:pointer;z-index:90;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;font-weight:300;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;right:max(20px,50% - 220px);box-shadow:0 6px 20px #4361ee66}.fab:hover{transform:scale(1.08);box-shadow:0 8px 28px #4361ee80}.popup-overlay{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.popup-card{background:var(--color-surface,#fff);border-radius:var(--radius-lg,12px);width:100%;max-width:340px;box-shadow:var(--shadow-lg,0 8px 24px #0003);text-align:center;padding:24px}.popup-message{color:var(--color-text,#1a1a2e);margin:0 0 6px;font-size:15px;line-height:1.5}.popup-sub{color:var(--color-text-secondary,#6c757d);margin:0 0 16px;font-size:13px}.popup-actions{justify-content:center;gap:10px;margin-top:16px;display:flex}.popup-btn{border-radius:var(--radius-md,8px);cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s}.popup-btn:hover{opacity:.85}.popup-btn--primary{background:var(--color-primary,#4361ee);color:#fff}.popup-btn--secondary{background:var(--color-surface-alt,#f1f3f5);color:var(--color-text,#1a1a2e)}.popup-btn--danger{background:var(--color-danger,#ef4444);color:#fff}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;top:0;left:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:0 0}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{-webkit-transform-origin:0 0;width:1600px;height:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{width:auto;padding:0;max-width:none!important;max-height:none!important}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:#33b5e566}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;z-index:800;width:0;height:0}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{z-index:800;pointer-events:visiblePainted;pointer-events:auto;position:relative}.leaflet-top,.leaflet-bottom{z-index:1000;pointer-events:none;position:absolute}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{outline-offset:1px;background:#ddd}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{text-align:center;color:#000;background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;text-decoration:none;display:block}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.leaflet-bar a.leaflet-disabled{cursor:default;color:#bbb;background-color:#f4f4f4}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-right-radius:2px;border-bottom-left-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{text-indent:1px;font:700 18px Lucida Console,Monaco,monospace}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{color:#333;background:#fff;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{padding-right:5px;overflow:hidden scroll}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{font-size:1.08333em;display:block}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;padding:0 5px;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{width:1em;height:.6669em;vertical-align:baseline!important;display:inline!important}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{white-space:nowrap;box-sizing:border-box;text-shadow:1px 1px #fff;background:#fffc;border:2px solid #777;border-top:none;padding:2px 5px 1px;line-height:1.1}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{text-align:center;margin-bottom:20px;position:absolute}.leaflet-popup-content-wrapper{text-align:left;border-radius:12px;padding:1px}.leaflet-popup-content{min-height:1px;margin:13px 24px 13px 20px;font-size:1.08333em;line-height:1.3}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{pointer-events:none;width:40px;height:20px;margin-top:-1px;margin-left:-20px;position:absolute;left:50%;overflow:hidden}.leaflet-popup-tip{pointer-events:auto;width:17px;height:17px;margin:-10px auto 0;padding:1px;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{color:#333;background:#fff;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{text-align:center;color:#757575;background:0 0;border:none;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;text-decoration:none;position:absolute;top:0;right:0}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";width:24px;filter:progid:DXImageTransform.Microsoft.Matrix(M11=.707107, M12=.707107, M21=-.707107, M22=.707107);margin:0 auto}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{color:#222;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;background-color:#fff;border:1px solid #fff;border-radius:3px;padding:6px;position:absolute;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{pointer-events:none;content:"";background:0 0;border:6px solid #0000;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{margin-left:-6px;left:50%}.leaflet-tooltip-top:before{border-top-color:#fff;margin-bottom:-12px;bottom:0}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-top:-12px;margin-left:-6px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;margin-left:-12px;left:0}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.form-page{background:var(--color-bg,#f8f9fa);min-height:100vh;font-family:var(--font-family,"Inter", sans-serif);flex-direction:column;padding-bottom:80px;display:flex}.form-header{background:var(--color-surface,#fff);z-index:100;border-bottom:1px solid #e9ecef;align-items:center;padding:14px 16px;display:flex;position:sticky;top:0}.form-back-btn{width:36px;height:36px;color:var(--color-text,#1a1a2e);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:background .2s;display:flex}.form-back-btn:hover{background:#f1f3f5}.form-title{text-align:center;color:var(--color-text,#1a1a2e);letter-spacing:-.2px;flex:1;margin:0;font-size:18px;font-weight:700}.form-header-spacer{width:36px}.form-loading{color:var(--color-text-secondary,#6c757d);flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.form-loading .spinner{border:3px solid #dee2e6;border-top-color:var(--color-primary,#4361ee);border-radius:50%;width:28px;height:28px;margin-bottom:10px;animation:.7s linear infinite spin}.form-error-banner{color:var(--color-danger,#ef4444);text-align:center;background:#fdecea;padding:10px 20px;font-size:14px}.form-body{flex-direction:column;gap:20px;padding:20px 16px;display:flex}.form-field{flex-direction:column;gap:8px;display:flex}.form-field--row{flex-direction:row;justify-content:space-between;align-items:center}.form-label{color:var(--color-text-secondary,#6c757d);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.form-input,.form-select{color:var(--color-text,#1a1a2e);background:var(--color-surface,#fff);border-radius:var(--radius-md,8px);box-sizing:border-box;border:1.5px solid #dee2e6;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.form-input:focus,.form-select:focus{border-color:var(--color-primary,#4361ee)}.form-input--error{border-color:var(--color-danger,#ef4444)!important}.form-error{color:var(--color-danger,#ef4444);margin-top:-2px;font-size:12px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236c757d' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.current-location-btn{color:var(--color-primary,#4361ee);border:2px solid var(--color-primary,#4361ee);border-radius:var(--radius-md,8px);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;transition:background .2s,color .2s;display:flex}.current-location-btn:hover{background:var(--color-primary,#4361ee);color:#fff}.current-location-btn:disabled{opacity:.6;cursor:not-allowed}.spinner-sm{border:2px solid;border-top-color:#0000;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.search-container{z-index:1050;position:relative}.search-dropdown{background:var(--color-surface,#fff);border:1px solid var(--color-border,#dee2e6);border-radius:0 0 var(--radius-md,8px) var(--radius-md,8px);z-index:1050;max-height:200px;box-shadow:var(--shadow-md,0 4px 12px #0000001a);border-top:none;margin:0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-dropdown li{color:var(--color-text,#1a1a2e);cursor:pointer;border-bottom:1px solid var(--color-border-light,#f1f3f5);padding:10px 14px;font-size:14px;transition:background .15s}.search-dropdown li:last-child{border-bottom:none}.search-dropdown li:hover{background:var(--color-surface-hover,#f8f9fa)}.location-chip{border-radius:var(--radius-md,8px);background:#fffbeb;border:1.5px solid #f59e0b;align-items:center;gap:8px;padding:10px 14px;display:flex}.location-chip--green{background:#f0fdf4;border-color:#22c55e}.location-chip-marker{flex-shrink:0;font-size:16px}.location-chip-name{color:var(--color-text,#1a1a2e);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;overflow:hidden}.location-chip-clear{width:24px;height:24px;color:var(--color-text-secondary,#6c757d);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:background .2s;display:flex}.location-chip-clear:hover{background:#0000000f}.map-container{border-radius:var(--radius-lg,12px);border:1px solid #e9ecef;overflow:hidden}.distance-text{color:var(--color-text-secondary,#6c757d);text-align:center;margin:4px 0 0;font-size:14px}.distance-text strong{color:var(--color-primary,#4361ee)}.radio-group{flex-direction:column;gap:10px;display:flex}.radio-option{color:var(--color-text,#1a1a2e);cursor:pointer;align-items:center;gap:10px;font-size:15px;display:flex}.radio-option input[type=radio]{width:18px;height:18px;accent-color:var(--color-primary,#4361ee)}.form-file-input{color:var(--color-text-secondary,#6c757d);margin-top:4px;font-size:14px}.toggle-switch{cursor:pointer;flex-shrink:0;width:48px;height:26px;display:inline-block;position:relative}.toggle-slider{background:#ced4da;border-radius:26px;transition:background .25s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .25s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--color-success,#4caf50)}.save-btn{color:#fff;background:var(--color-primary,#4361ee);border-radius:var(--radius-md,8px);cursor:pointer;border:none;width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:700;transition:opacity .2s}.save-btn:hover{opacity:.9}.save-btn:disabled{opacity:.6;cursor:not-allowed}.sound-selector{flex-direction:column;gap:8px;display:flex}.sound-option{background:var(--color-surface,#fff);border-radius:var(--radius-md,8px);cursor:pointer;border:1.5px solid #e5e7eb;align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.sound-option:hover{background:#f8fafc;border-color:#93c5fd}.sound-option--active{background:#eef2ff;border-color:#4361ee}.sound-option input[type=radio]{accent-color:#4361ee;flex-shrink:0;width:18px;height:18px}.sound-option-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sound-option-name{color:var(--color-text,#1a1a2e);font-size:14px;font-weight:600}.sound-option-desc{color:#9ca3af;font-size:11px}.sound-preview-btn{color:#4361ee;cursor:pointer;background:#f1f3f5;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;transition:all .2s;display:flex}.sound-preview-btn:hover{color:#fff;background:#4361ee}.location-fetching{border-radius:var(--radius-md,8px);color:#2563eb;background:#f0f7ff;border:1.5px solid #93c5fd;align-items:center;gap:10px;padding:12px 14px;font-size:14px;display:flex}.location-error{border-radius:var(--radius-md,8px);color:#dc2626;background:#fef2f2;border:1.5px solid #fca5a5;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;font-size:13px;display:flex}.location-chip--blue{background:#eff6ff;border-color:#3b82f6}.form-hint{color:#9ca3af;margin:-4px 0 4px;font-size:12px;line-height:1.4}.radius-slider-container{align-items:center;gap:10px;padding:8px 0;display:flex}.radius-label-min,.radius-label-max{color:#9ca3af;white-space:nowrap;min-width:32px;font-size:11px;font-weight:600}.radius-label-max{text-align:right}.radius-slider{appearance:none;cursor:pointer;background:linear-gradient(90deg,#93c5fd,#4361ee,#7c3aed);border-radius:6px;outline:none;flex:1;height:6px}.radius-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#fff;border:3px solid #4361ee;border-radius:50%;width:22px;height:22px;transition:transform .15s;box-shadow:0 2px 6px #4361ee4d}.radius-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.radius-slider::-moz-range-thumb{cursor:pointer;background:#fff;border:3px solid #4361ee;border-radius:50%;width:22px;height:22px;box-shadow:0 2px 6px #4361ee4d}.radius-value{color:#4361ee;font-size:15px}.radius-marks{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.radius-mark{cursor:pointer;color:#6b7280;background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s}.radius-mark:hover{color:#2563eb;background:#f0f7ff;border-color:#93c5fd}.radius-mark.active{color:#4361ee;background:#eef2ff;border-color:#4361ee}.layout-header-right{align-items:center;gap:8px;display:flex}.header-earn-btn{color:#4361ee;cursor:pointer;white-space:nowrap;background:#eef2ff;border:1.5px solid #c7d2fe;border-radius:16px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.header-earn-btn:hover{color:#fff;background:#4361ee}.header-points{color:#d97706;white-space:nowrap;background:#fffbeb;border-radius:16px;align-items:center;gap:3px;padding:4px 10px;font-size:12px;font-weight:700;display:flex}.back-arrow-btn{width:36px;height:36px;color:var(--color-text,#1a1a2e);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:background .2s;display:flex}.back-arrow-btn:hover{background:#f1f3f5}:root{--color-primary:#4361ee;--color-primary-dark:#3a0ca3;--color-primary-light:#4cc9f0;--color-primary-hover:#3651d4;--color-primary-bg:#4361ee14;--color-accent:#f72585;--color-accent-light:#f725851a;--color-success:#4caf50;--color-success-light:#4caf501a;--color-warning:#ff9800;--color-warning-light:#ff98001a;--color-danger:#ef4444;--color-danger-light:#ef44441a;--color-bg:#f5f6fa;--color-surface:#fff;--color-surface-alt:#f8f9fa;--color-text:#050505;--color-text-secondary:#4b5563;--color-text-muted:#6b7280;--color-border:#e5e7eb;--color-border-light:#f0f1f3;--color-overlay:#00000080;--color-overlay-dark:#000000d9;--gradient-primary:linear-gradient(135deg, #4361ee 0%, #3a0ca3 100%);--gradient-card:linear-gradient(180deg, #ffffff0d 0%, #fff0 100%);--gradient-alarm:linear-gradient(135deg, #022c22 0%, #064e3b 50%, #047857 100%);--gradient-welcome:linear-gradient(180deg, #5a7df4 0%, #4361ee 40%, #3a0ca3 100%);--font-family:"Outfit", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display:"Outfit", "Inter", sans-serif;--font-xs:.7rem;--font-sm:.8rem;--font-base:.95rem;--font-md:1.05rem;--font-lg:1.25rem;--font-xl:1.6rem;--font-2xl:2rem;--font-3xl:2.5rem;--fw-light:300;--fw-normal:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--fw-extrabold:800;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 30px #0000001f;--shadow-xl:0 16px 48px #00000029;--shadow-glow:0 0 20px #4361ee4d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.6;overflow-x:hidden}body.no-scroll{overflow:hidden}#root{min-height:100dvh}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-dark)}img{max-width:100%;display:block}input,button,textarea,select{font-family:inherit;font-size:inherit}ul,ol{list-style:none}.app-container{background:var(--color-bg);max-width:480px;min-height:100dvh;margin:0 auto;position:relative}.welcome-page{background:var(--gradient-welcome);min-height:100dvh;padding:var(--space-xl);text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.welcome-page:before{content:"";background:radial-gradient(circle,#ffffff0d 0%,#0000 70%);width:200%;height:200%;animation:8s ease-in-out infinite welcomeGlow;position:absolute;top:-50%;left:-50%}@keyframes welcomeGlow{0%,to{transform:translate(0)}50%{transform:translate(5%,5%)}}.welcome-icon-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-xl);width:130px;height:130px;margin-bottom:var(--space-lg);z-index:1;background:#ffffff26;justify-content:center;align-items:center;display:flex;position:relative;box-shadow:0 8px 32px #00000026}.welcome-icon-container img{border-radius:var(--radius-lg);width:100px;height:100px}.welcome-subtitle-small{font-size:var(--font-md);font-weight:var(--fw-light);opacity:.85;margin-bottom:var(--space-xs);z-index:1;position:relative}.welcome-title{font-family:Pacifico,cursive;font-size:var(--font-3xl);font-weight:var(--fw-extrabold);margin-bottom:var(--space-sm);letter-spacing:-.5px;z-index:1;position:relative}.welcome-tagline{font-size:var(--font-base);font-weight:var(--fw-medium);opacity:.9;margin-bottom:var(--space-xl);z-index:1;position:relative}.welcome-countdown{font-size:var(--font-sm);opacity:.65;margin-bottom:var(--space-2xl);z-index:1;position:relative}.welcome-social-row{gap:var(--space-lg);margin-bottom:var(--space-xl);z-index:1;display:flex;position:relative}.welcome-social-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:2px;opacity:.7;margin-bottom:var(--space-md);z-index:1;position:relative}.welcome-social-icon{border-radius:var(--radius-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;width:48px;height:48px;font-size:var(--font-lg);transition:all var(--transition-base);cursor:pointer;background:#ffffff26;border:none;justify-content:center;align-items:center;text-decoration:none;display:flex}.welcome-social-icon:hover{color:#fff;background:#ffffff40;transform:translateY(-2px)}.welcome-social-icon svg{fill:#fff;width:22px;height:22px}.welcome-footer{align-items:center;gap:var(--space-sm);font-size:var(--font-sm);z-index:1;padding-top:var(--space-lg);margin-top:auto;display:flex;position:relative}.welcome-footer img{object-fit:contain;border-radius:var(--radius-sm);width:auto;height:30px}.welcome-footer-divider{width:60px;height:1px;margin:var(--space-md) 0;z-index:1;background:#fff3;position:relative}.login-page{background:var(--color-surface);min-height:100dvh;padding:var(--space-xl) var(--space-lg);padding-top:calc(var(--safe-top) + var(--space-xl));flex-direction:column;display:flex}.login-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);background:0 0;display:flex}.login-header img,.login-header-icon{border-radius:var(--radius-md);object-fit:contain;background:0 0;width:auto;max-width:100%;height:48px}.login-header-title{font-family:Pacifico,cursive;font-size:var(--font-lg);font-weight:var(--fw-bold);color:var(--color-text)}.login-welcome{margin-bottom:var(--space-xl)}.login-heading{font-family:Pacifico,cursive;font-size:var(--font-2xl);font-weight:var(--fw-bold);color:var(--color-text);margin-bottom:var(--space-xs)}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-base);margin-bottom:var(--space-xl)}.login-field{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.login-label{font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--color-text-secondary)}.login-input{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:12px 16px}.login-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.login-input-error{border-color:var(--color-danger)}.login-error-msg{color:var(--color-danger);font-size:var(--font-xs);margin-top:4px}.login-password-wrapper{align-items:center;display:flex;position:relative}.login-password-wrapper .login-input{padding-right:48px}.login-eye-toggle{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;padding:4px;display:flex;position:absolute;right:12px}.login-eye-toggle:hover{color:var(--color-text)}.login-forgot-row{margin-top:-8px;margin-bottom:var(--space-md);justify-content:flex-end;display:flex}.login-forgot-link{font-size:var(--font-sm);color:var(--color-primary);font-weight:var(--fw-medium);text-decoration:none}.login-btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-lg);width:100%;font-weight:var(--fw-bold);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:8px;padding:14px;display:flex}.login-btn-primary:active{transform:scale(.98)}.login-btn-google{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;color:var(--color-text);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:14px;display:flex}.login-btn-google:active{transform:scale(.98)}.login-form{gap:var(--space-md);flex-direction:column;flex:1;display:flex}.login-divider{align-items:center;gap:var(--space-md);margin:var(--space-md) 0;color:var(--color-text-muted);font-size:var(--font-sm);display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.login-helper{text-align:center;font-size:var(--font-sm);color:var(--color-text-muted);margin-top:var(--space-md);line-height:1.5}.login-social-section{padding-top:var(--space-lg);margin-top:auto}.login-social-title{text-align:center;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:2px;color:var(--color-primary);font-weight:var(--fw-semibold);margin-bottom:var(--space-md)}.login-social-row{justify-content:center;gap:var(--space-md);display:flex}.login-social-icon{border-radius:var(--radius-full);background:var(--color-surface-alt);border:1px solid var(--color-border);width:42px;height:42px;color:var(--color-text-secondary);transition:all var(--transition-base);cursor:pointer;justify-content:center;align-items:center;text-decoration:none;display:flex}.login-social-icon:hover{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.login-social-icon svg{fill:currentColor;width:20px;height:20px}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{font-size:var(--font-sm);font-weight:var(--fw-semibold);color:var(--color-text)}.form-input-wrapper{align-items:center;display:flex;position:relative}.form-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-base);color:var(--color-text);background:var(--color-surface);transition:all var(--transition-fast);outline:none;padding:14px 16px}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4361ee1f}.form-input::placeholder{color:var(--color-text-muted)}.form-input.error{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef444414}.form-input-icon{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:14px}.form-input-icon:hover{color:var(--color-text-secondary)}.form-input-icon svg{width:20px;height:20px}.form-error{font-size:var(--font-sm);color:var(--color-danger);align-items:center;gap:var(--space-xs);animation:.2s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-link{font-size:var(--font-sm);color:var(--color-primary);font-weight:var(--fw-medium);text-align:right;cursor:pointer;transition:color var(--transition-fast)}.form-link:hover{color:var(--color-primary-dark)}.form-select{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-base);background:var(--color-surface);appearance:none;cursor:pointer;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:20px 20px;outline:none;padding:14px 40px 14px 16px}select option{background-color:var(--color-surface);color:var(--color-text)}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4361ee1f}.toggle-switch{flex-shrink:0;width:50px;height:28px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--color-border);border-radius:var(--radius-full);transition:var(--transition-base);position:absolute;inset:0}.toggle-slider:before{content:"";width:22px;height:22px;transition:var(--transition-base);box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-base);font-weight:var(--fw-semibold);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;padding:14px 24px;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";background:#ffffff26;border-radius:50%;width:0;height:0;transition:width .4s,height .4s,top .4s,left .4s;position:absolute;top:50%;left:50%}.btn:active:after{width:200px;height:200px;top:calc(50% - 100px);left:calc(50% - 100px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #4361ee4d}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 14px #4361ee66}.btn-outline{color:var(--color-text);border:1.5px solid var(--color-border);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-text-secondary)}.btn-danger{background:var(--color-danger);color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-success{background:var(--color-success);color:#fff}.btn-ghost{color:var(--color-primary);background:0 0;padding:10px 16px}.btn-ghost:hover:not(:disabled){background:var(--color-primary-bg)}.btn-full{width:100%}.btn-sm{font-size:var(--font-sm);padding:8px 16px}.btn-lg{font-size:var(--font-md);padding:16px 32px}.btn-google{background:var(--color-surface);color:var(--color-text);border:1.5px solid var(--color-border);font-weight:var(--fw-semibold)}.btn-google:hover:not(:disabled){background:var(--color-surface-alt);box-shadow:var(--shadow-md)}.btn-google svg{width:20px;height:20px}.btn-reward-ad{background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border)}.btn-reward-ad:hover:not(:disabled){background:var(--color-primary-bg)}.layout{background:var(--color-bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}@media (width>=481px){.layout{max-width:480px;margin:0 auto}}.layout-header{z-index:100;background:var(--color-surface);padding:calc(var(--safe-top) + 10px) var(--space-md) 10px;border-bottom:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:8px;display:flex;position:sticky;top:0}.layout-header-left{align-items:center;gap:6px;min-width:0;display:flex}.layout-header-logo{object-fit:cover;border-radius:8px;flex-shrink:0;width:28px;height:28px}.layout-title{font-family:Pacifico,cursive;font-size:1rem;font-weight:var(--fw-bold);color:var(--color-text);white-space:nowrap;letter-spacing:-.3px;text-overflow:ellipsis;overflow:hidden}.layout-header-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.header-earn-btn{background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:11px;font-weight:var(--fw-semibold);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #4361ee33;align-items:center;gap:4px;padding:4px 8px;display:inline-flex}.header-earn-btn:hover{background:#4361ee26}.header-points{font-size:12px;font-weight:var(--fw-semibold);color:var(--color-text);white-space:nowrap;align-items:center;gap:2px;display:inline-flex}.layout-content{padding:var(--space-md);padding-bottom:var(--space-md);-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.tab-bar{background:var(--color-surface);border-top:1px solid var(--color-border-light);width:100%;padding:8px 0 calc(8px + var(--safe-bottom));z-index:100;flex-shrink:0;justify-content:space-around;display:flex;box-shadow:0 -2px 10px #0000000d}.tab-item{color:var(--color-text-muted);font-size:var(--font-xs);font-weight:var(--fw-medium);transition:color var(--transition-fast);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:6px 20px;text-decoration:none;display:flex;position:relative}.tab-item.active{color:var(--color-primary)}.tab-item.active:before{content:"";background:var(--color-primary);border-radius:var(--radius-full);width:24px;height:3px;position:absolute;top:-8px;left:50%;transform:translate(-50%)}.tab-icon{width:24px;height:24px}.tab-icon svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:24px;height:24px}.tab-label{font-size:11px;font-weight:var(--fw-medium)}.ad-banner{width:100%;max-width:320px;height:50px;margin:var(--space-md) auto;border:2px dashed var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-alt);color:var(--color-text-muted);letter-spacing:.5px;justify-content:center;align-items:center;font-family:Courier New,monospace;font-size:11px;display:flex}.ad-banner-bottom{bottom:calc(64px + var(--safe-bottom));z-index:50;position:fixed;left:50%;transform:translate(-50%)}.alarm-list{gap:var(--space-md);flex-direction:column;display:flex}.alarm-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);align-items:center;gap:var(--space-md);transition:all var(--transition-base);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.alarm-card:hover{box-shadow:var(--shadow-md)}.alarm-card:active{transform:scale(.98)}.alarm-card-icon{border-radius:var(--radius-md);background:var(--color-primary-bg);width:44px;height:44px;font-size:var(--font-xl);flex-shrink:0;justify-content:center;align-items:center;display:flex}.alarm-card-content{flex:1;min-width:0}.alarm-card-name{font-weight:var(--fw-semibold);font-size:var(--font-base);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;overflow:hidden}.alarm-card-route{font-size:var(--font-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.alarm-card-route span{color:var(--color-primary);font-weight:var(--fw-medium)}.alarm-card-meta{font-size:var(--font-xs);color:var(--color-text-muted);align-items:center;gap:var(--space-xs);margin-top:2px;display:flex}.alarm-travel{background:var(--color-surface-alt);color:var(--color-text-secondary);border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:var(--fw-medium);border:1px solid var(--color-border);align-items:center;margin-top:4px;padding:4px 8px;display:inline-flex}.alarm-empty{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.alarm-empty-icon{margin-bottom:var(--space-md);opacity:.3;font-size:64px}.alarm-empty h3{font-size:var(--font-lg);font-weight:var(--fw-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.alarm-empty p{font-size:var(--font-sm)}.fab{bottom:calc(80px + var(--safe-bottom));border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:52px;height:52px;font-size:28px;font-weight:var(--fw-light);box-shadow:var(--shadow-lg), var(--shadow-glow);cursor:pointer;transition:all var(--transition-base);z-index:90;border:none;justify-content:center;align-items:center;display:flex;position:fixed;right:max(20px,50vw - 220px)}.fab:hover{box-shadow:var(--shadow-xl), 0 0 30px #4361ee66;transform:scale(1.1)}.fab:active{transform:scale(.95)}.reward-points-display{align-items:center;gap:var(--space-xs);background:var(--color-warning-light);color:var(--color-warning);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--fw-semibold);padding:6px 12px;display:flex}.reward-points-display svg{width:16px;height:16px}.alarm-form-page{background:var(--color-surface);min-height:100dvh;padding-top:var(--safe-top)}.alarm-form-header{padding:var(--space-md);border-bottom:1px solid var(--color-border-light);align-items:center;display:flex}.alarm-form-back{cursor:pointer;width:36px;height:36px;color:var(--color-text);font-size:var(--font-xl);border-radius:var(--radius-full);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.alarm-form-back:hover{background:var(--color-surface-alt)}.alarm-form-title{text-align:center;font-size:var(--font-lg);font-weight:var(--fw-bold);flex:1}.alarm-form-cancel{color:var(--color-text-secondary);font-size:var(--font-sm);font-weight:var(--fw-medium);cursor:pointer;padding:var(--space-sm);background:0 0;border:none}.alarm-form-body{padding:var(--space-md);gap:var(--space-lg);flex-direction:column;display:flex}.alarm-form-section{gap:var(--space-sm);flex-direction:column;display:flex}.alarm-form-section-label{font-size:var(--font-sm);font-weight:var(--fw-bold);color:var(--color-text);text-transform:uppercase;letter-spacing:.5px}.location-chip{align-items:center;gap:var(--space-sm);background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--fw-medium);max-width:100%;padding:8px 14px;display:inline-flex}.location-chip.from{color:#f59e0b;background:#ffc1071f}.location-chip.to{color:var(--color-success);background:#4caf501f}.location-chip-remove{color:inherit;cursor:pointer;font-size:var(--font-lg);opacity:.7;background:0 0;border:none;line-height:1}.location-chip-remove:hover{opacity:1}.distance-badge{align-items:center;gap:var(--space-xs);background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--fw-semibold);padding:6px 12px;display:inline-flex}.map-container{border-radius:var(--radius-lg);border:1px solid var(--color-border);width:100%;height:250px;box-shadow:var(--shadow-sm);overflow:hidden}.map-container .leaflet-container{border-radius:var(--radius-lg);font-family:var(--font-family)}.custom-map-marker{background:0 0!important;border:none!important}.location-search-results{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:220px;animation:.2s slideDown;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.location-search-item{padding:12px var(--space-md);cursor:pointer;border-bottom:1px solid var(--color-border-light);font-size:var(--font-sm);color:var(--color-text);transition:background var(--transition-fast)}.location-search-item:last-child{border-bottom:none}.location-search-item:hover{background:var(--color-primary-bg)}.modal-overlay{background:var(--color-overlay);z-index:1000;padding:var(--space-md);justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;max-width:400px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.25s scaleIn;position:relative;overflow-y:auto}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-close{top:var(--space-md);right:var(--space-md);border-radius:var(--radius-full);background:var(--color-surface-alt);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);font-size:var(--font-lg);transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex;position:absolute}.modal-close:hover{background:var(--color-border)}.modal-title{font-size:var(--font-xl);font-weight:var(--fw-bold);text-align:center;margin-bottom:var(--space-md)}.modal-subtitle{text-align:center;color:var(--color-text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-lg)}.interstitial-overlay{background:var(--color-overlay-dark);z-index:2000;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.interstitial-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;width:90%;max-width:360px;box-shadow:var(--shadow-xl)}.interstitial-placeholder{width:300px;height:250px;margin:var(--space-md) auto;background:var(--color-surface-alt);border:2px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-family:Courier New,monospace;font-size:var(--font-sm);justify-content:center;align-items:center;display:flex}.interstitial-close-btn{margin-top:var(--space-md)}.rewarded-overlay{background:var(--color-overlay-dark);z-index:2000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.rewarded-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;width:90%;max-width:360px}.rewarded-progress-bar{background:var(--color-border);border-radius:var(--radius-full);width:100%;height:8px;margin:var(--space-md) 0;overflow:hidden}.rewarded-progress-fill{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width .1s linear}.premium-overlay{background:var(--color-overlay);z-index:1000;padding:var(--space-md);justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.premium-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-lg);width:100%;max-width:380px;box-shadow:var(--shadow-xl);text-align:center;animation:.25s scaleIn}.premium-icon{margin-bottom:var(--space-md);font-size:48px}.premium-title{font-size:var(--font-xl);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.premium-subtitle{color:var(--color-text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-lg)}.premium-list{text-align:left;margin-bottom:var(--space-lg);padding-left:var(--space-md)}.premium-list li{font-size:var(--font-sm);color:var(--color-text-secondary);gap:var(--space-sm);padding:6px 0;display:flex}.premium-list li:before{content:"";display:none}.premium-actions{gap:var(--space-md);margin-top:var(--space-md);justify-content:center;display:flex}.notification-bell{cursor:pointer;color:var(--color-text);background:0 0;border:none;padding:6px;position:relative}.notification-badge{background:var(--color-danger);color:#fff;width:16px;height:16px;font-size:10px;font-weight:var(--fw-bold);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:2px;right:2px}.notification-dropdown{background:var(--color-surface);border-radius:var(--radius-lg);width:300px;box-shadow:var(--shadow-xl);border:1px solid var(--color-border);z-index:200;max-height:350px;animation:.2s slideDown;position:absolute;top:100%;right:0;overflow-y:auto}.notification-dropdown-title{padding:var(--space-md);font-weight:var(--fw-semibold);font-size:var(--font-sm);border-bottom:1px solid var(--color-border-light);color:var(--color-text)}.notification-item{padding:12px var(--space-md);border-bottom:1px solid var(--color-border-light);align-items:center;gap:var(--space-sm);display:flex}.notification-item:last-child{border-bottom:none}.notification-item-icon{width:28px;height:28px;font-size:var(--font-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.notification-item-icon.credit{background:var(--color-success-light);color:var(--color-success)}.notification-item-icon.debit{background:var(--color-danger-light);color:var(--color-danger)}.notification-item-content{flex:1}.notification-item-text{font-size:var(--font-sm);color:var(--color-text)}.notification-item-time{font-size:var(--font-xs);color:var(--color-text-muted)}.profile-page{gap:var(--space-md);flex-direction:column;display:flex}.profile-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.profile-user-info{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.profile-avatar{border-radius:var(--radius-full);background:var(--color-primary-bg);width:52px;height:52px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-avatar svg{width:28px;height:28px}.profile-email{font-size:var(--font-base);font-weight:var(--fw-semibold);color:var(--color-text)}.profile-tier{border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--fw-semibold);margin-left:var(--space-sm);padding:2px 8px;display:inline-flex}.profile-tier.free{background:var(--color-primary-bg);color:var(--color-primary)}.profile-tier.paid{background:var(--color-success-light);color:var(--color-success)}.profile-stats{gap:var(--space-xs);padding-top:var(--space-md);border-top:1px solid var(--color-border-light);flex-direction:column;display:flex}.profile-stat{font-size:var(--font-sm);justify-content:space-between;display:flex}.profile-stat-label{color:var(--color-primary);font-weight:var(--fw-medium)}.profile-stat-value{color:var(--color-text);font-weight:var(--fw-semibold)}.profile-action{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);cursor:pointer;transition:all var(--transition-base);text-align:left;width:100%;font-size:var(--font-base);color:var(--color-text);display:flex}.profile-action:hover{background:var(--color-surface-alt);box-shadow:var(--shadow-sm)}.profile-action-icon{border-radius:var(--radius-md);background:var(--color-surface-alt);width:36px;height:36px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-social-card{background:var(--color-surface-alt);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center}.profile-social-title{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:2px;color:var(--color-primary);font-weight:var(--fw-semibold);margin-bottom:var(--space-md)}.profile-social-row{justify-content:center;gap:var(--space-md);display:flex}.profile-footer{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-md);color:var(--color-text-muted);font-size:var(--font-sm);display:flex}.profile-footer img{border-radius:var(--radius-sm);width:28px;height:28px}.history-list{gap:var(--space-md);flex-direction:column;display:flex}.history-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);position:relative}.history-card-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:flex-start;display:flex}.history-card-route{font-weight:var(--fw-semibold);font-size:var(--font-base)}.history-card-route .from-text{color:#f59e0b}.history-card-route .to-text{color:var(--color-success)}.history-card-route .arrow{color:var(--color-text-muted);margin:0 var(--space-xs)}.history-card-via{font-size:var(--font-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.history-card-times{gap:var(--space-sm);font-size:var(--font-xs);color:var(--color-text-muted);grid-template-columns:1fr 1fr;display:grid}.history-card-time-label{font-weight:var(--fw-semibold);color:var(--color-text-secondary)}.history-card-actions{gap:var(--space-sm);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border-light);justify-content:flex-end;display:flex}.header-earn-btn{background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--fw-bold);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:4px;padding:4px 10px;display:inline-flex}.history-share-btn{align-items:center;gap:var(--space-xs);background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);border:none;padding:6px 12px;display:inline-flex}.history-share-btn:hover{background:var(--color-primary);color:#fff}.alarm-ringing-overlay{background:var(--gradient-alarm);z-index:3000;color:#fff;text-align:center;padding:var(--space-xl);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.alarm-ringing-icon{margin-bottom:var(--space-lg);font-size:80px;animation:.6s ease-in-out infinite alternate ringPulse}@keyframes ringPulse{0%{transform:scale(1)rotate(-10deg)}to{transform:scale(1.15)rotate(10deg)}}.alarm-ringing-title{font-size:var(--font-2xl);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.alarm-ringing-destination{font-size:var(--font-lg);opacity:.9;margin-bottom:var(--space-xs)}.alarm-ringing-distance{font-size:var(--font-base);opacity:.7;margin-bottom:var(--space-2xl)}.alarm-ringing-actions{gap:var(--space-lg);display:flex}.alarm-ringing-btn{border-radius:var(--radius-full);font-size:var(--font-md);font-weight:var(--fw-bold);cursor:pointer;transition:all var(--transition-base);border:none;min-width:130px;padding:16px 36px}.alarm-ringing-btn.stop{color:var(--color-danger);background:#fff}.alarm-ringing-btn.snooze,.alarm-ringing-btn.dismiss{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border:1px solid #ffffff4d}.alarm-ringing-btn:hover{transform:scale(1.05)}.terms-page{background:var(--color-surface);min-height:100dvh;padding-top:var(--safe-top);flex-direction:column;display:flex}.terms-header{padding:var(--space-md);border-bottom:1px solid var(--color-border-light)}.terms-header h1{font-size:var(--font-xl);font-weight:var(--fw-bold)}.terms-content{padding:var(--space-md);flex:1;max-height:calc(100vh - 200px);overflow-y:auto}.terms-content h2{font-size:var(--font-md);font-weight:var(--fw-bold);margin:var(--space-lg) 0 var(--space-sm);color:var(--color-text)}.terms-content p{font-size:var(--font-sm);color:var(--color-text-secondary);margin-bottom:var(--space-md);line-height:1.7}.terms-footer{padding:var(--space-md);border-top:1px solid var(--color-border-light);background:var(--color-surface)}.terms-checkbox{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);cursor:pointer;display:flex}.terms-checkbox input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer}.terms-checkbox label{font-size:var(--font-sm);color:var(--color-text);cursor:pointer}.password-page{background:var(--color-surface);min-height:100dvh;padding:var(--space-xl) var(--space-lg);padding-top:calc(var(--safe-top) + var(--space-xl))}.password-page-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);display:flex}.password-page-back{cursor:pointer;width:36px;height:36px;color:var(--color-text);font-size:var(--font-xl);border-radius:var(--radius-full);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.password-page-back:hover{background:var(--color-surface-alt)}.password-page h2{font-size:var(--font-2xl);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.password-page .subtitle{color:var(--color-text-secondary);font-size:var(--font-base);margin-bottom:var(--space-xl)}.password-form{gap:var(--space-md);flex-direction:column;display:flex}.permission-page{background:var(--color-surface);min-height:100dvh;padding:var(--space-xl) var(--space-lg);padding-top:calc(var(--safe-top) + var(--space-xl));flex-direction:column;display:flex}.permission-list{gap:var(--space-md);margin:var(--space-lg) 0;padding:var(--space-md);background:var(--color-surface-alt);border-radius:var(--radius-lg);flex-direction:column;display:flex}.permission-item{align-items:center;gap:var(--space-md);font-size:var(--font-base);color:var(--color-text);display:flex}.permission-item-icon{border-radius:var(--radius-full);background:var(--color-primary-bg);width:36px;height:36px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.manual-overlay{background:var(--color-overlay);z-index:1000;padding:max(16px, var(--safe-top)) 16px max(16px, var(--safe-bottom)) 16px;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.manual-card{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:440px;max-height:100%;box-shadow:var(--shadow-xl);flex-direction:column;animation:.25s scaleIn;display:flex;overflow:hidden}.manual-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.manual-title{font-size:var(--font-xl);font-weight:var(--fw-bold)}.manual-close{border-radius:var(--radius-full);background:var(--color-surface-alt);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);font-size:var(--font-lg);z-index:10;border:none;justify-content:center;align-items:center;display:flex;position:sticky;top:0}.manual-content{padding:var(--space-lg);flex:1;overflow-y:auto}.manual-got-it{flex-shrink:0;margin-top:12px}.manual-section{margin-bottom:var(--space-lg)}.manual-section h3{font-size:var(--font-md);font-weight:var(--fw-bold);color:var(--color-primary);margin-bottom:var(--space-sm)}.manual-section p,.manual-section li{font-size:var(--font-sm);color:var(--color-text-secondary);line-height:1.6}.manual-section ul,.manual-section ol{padding-left:var(--space-lg)}.manual-section ul{list-style:outside}.manual-section ol{list-style:decimal}.manual-back-btn{border-radius:var(--radius-full);background:var(--color-surface-alt);cursor:pointer;width:36px;height:36px;color:var(--color-text);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.manual-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border-light)}.share-overlay{background:var(--color-overlay);z-index:1000;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.share-card{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:90dvh;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + var(--safe-bottom));animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.share-preview{background:var(--color-surface-alt);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg);font-size:var(--font-sm)}.share-preview-item{justify-content:space-between;padding:4px 0;display:flex}.share-preview-label{color:var(--color-text-muted)}.share-preview-value{color:var(--color-text);font-weight:var(--fw-medium)}.share-options{gap:var(--space-sm);margin-bottom:var(--space-md);flex-direction:column;display:flex}.share-option{align-items:center;gap:var(--space-md);padding:14px var(--space-md);border-radius:var(--radius-md);background:var(--color-surface-alt);cursor:pointer;text-align:left;width:100%;font-size:var(--font-base);color:var(--color-text);transition:all var(--transition-fast);border:none;display:flex}.share-option:hover{background:var(--color-primary-bg)}.share-social{justify-content:center;gap:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border-light);display:flex}.confirm-overlay{background:var(--color-overlay);z-index:1500;padding:var(--space-md);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;width:100%;max-width:320px}.confirm-title{font-size:var(--font-lg);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.confirm-message{color:var(--color-text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-lg)}.confirm-actions{gap:var(--space-md);justify-content:center;display:flex}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);width:32px;height:32px;margin:var(--space-lg) auto;border-radius:50%;animation:.8s linear infinite spin}.loading-page{justify-content:center;align-items:center;min-height:100dvh;display:flex}@media (width>=481px){.app-container,.layout{border-left:1px solid var(--color-border-light);border-right:1px solid var(--color-border-light);box-shadow:var(--shadow-lg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right{display:none}.map-marker{cursor:pointer;width:30px;height:30px}.map-marker-from{background:#f59e0b;border:3px solid #fff;border-radius:50% 50% 50% 0;width:24px;height:24px;transform:rotate(-45deg);box-shadow:0 2px 6px #0000004d}.map-marker-to{background:#4caf50;border:3px solid #fff;border-radius:50% 50% 50% 0;width:24px;height:24px;transform:rotate(-45deg);box-shadow:0 2px 6px #0000004d}[data-theme=dark]{--color-bg:#0d0d0d;--color-surface:#1a1a1a;--color-surface-alt:#262626;--color-text:#fff;--color-text-secondary:#d1d5db;--color-text-muted:#9ca3af;--color-border:#333;--color-border-light:#2c2c2c;--color-overlay:#000000b3;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #00000080, 0 2px 4px -1px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -2px #0000004d;--shadow-xl:0 20px 25px -5px #00000080, 0 10px 10px -5px #0006}.toast{top:calc(var(--safe-top) + 20px);background:var(--color-text);color:#fff;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:var(--fw-medium);box-shadow:var(--shadow-lg);z-index:5000;padding:12px 24px;animation:.3s toastIn;position:fixed;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast.error{background:var(--color-danger)}.toast.success{background:var(--color-success)}[data-theme=dark] .leaflet-control-geosearch form{background-color:var(--color-bg-elevated);color:var(--color-text)}[data-theme=dark] .leaflet-control-geosearch form input{color:var(--color-text);background-color:#0000}[data-theme=dark] .leaflet-control-geosearch .results{background-color:var(--color-bg-elevated);border-color:var(--color-border)}[data-theme=dark] .leaflet-control-geosearch .results>*{color:var(--color-text);border-bottom:1px solid var(--color-border)}[data-theme=dark] .leaflet-control-geosearch .results>:hover,[data-theme=dark] .leaflet-control-geosearch .results>.active{background-color:var(--color-primary-light);color:#fff}
