/* ═══════════════════════════════════════════════════════════
   EqualPath — Global Styles
   Frontend Човек 1: HTML структура + CSS дизайн
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#1e9e75;--brand-dark:#148060;--brand-light:#edfaf5;--brand-border:#a9e7ce;
  --ink:#111827;--ink-soft:#374151;--ink-muted:#6b7280;--ink-faint:#9ca3af;
  --surface:#F7F8FA;--white:#ffffff;--border:#e5e7eb;--border-soft:#f3f4f6;
  --red:#dc2626;--red-dark:#b91c1c;--sidebar-w:320px;--header-h:60px;
}
/* ── Dark theme ──────────────────────────────────────────── */
[data-theme="dark"]{
  --brand:#22c98e;--brand-dark:#1aab78;--brand-light:#0d2d22;--brand-border:#1a5c42;
  --ink:#e5e7eb;--ink-soft:#d1d5db;--ink-muted:#9ca3af;--ink-faint:#6b7280;
  --surface:#111827;--white:#1f2937;--border:#374151;--border-soft:#283548;
  --red:#ef4444;--red-dark:#dc2626;
  color-scheme:dark;
}
[data-theme="dark"] .geo-input,
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-textarea{background:var(--surface)}
[data-theme="dark"] .form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
[data-theme="dark"] .geo-input:focus,
[data-theme="dark"] .form-input:focus,
[data-theme="dark"] .form-select:focus,
[data-theme="dark"] .form-textarea:focus{background:var(--white)}
[data-theme="dark"] .sr-body{background:var(--surface)}
[data-theme="dark"] .leaflet-control-attribution{background:rgba(31,41,55,.85)!important;color:var(--ink-muted)!important}
[data-theme="dark"] .leaflet-control-zoom a{background:var(--white)!important;color:var(--ink)!important;border-color:var(--border)!important}
[data-theme="dark"] #btn-login{background:var(--brand);color:#fff}
[data-theme="dark"] #btn-login:hover{background:var(--brand-dark)}
[data-theme="dark"] .comfort-badge{color:var(--brand)}
[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.65)}
[data-theme="dark"] #route-info{background:linear-gradient(135deg,var(--brand-light) 0%,#0f2a1f 100%)}

html{height:100%;background:var(--surface)}
body{font-family:'DM Sans',sans-serif;background:var(--surface);color:var(--ink);height:100dvh;display:flex;flex-direction:column;overflow:hidden}
[data-theme="dark"] html{background:var(--surface)}

/* ── Header ──────────────────────────────────────────────── */
#app-header{height:var(--header-h);background:var(--white);border-bottom:none;display:flex;align-items:center;padding:0 .75rem;gap:.5rem;flex-shrink:0;z-index:1000;position:relative;overflow:visible}

/* Centered logo */
.logo-wordmark{font-family:'Fraunces',serif;font-weight:900;font-size:1.35rem;color:var(--ink);letter-spacing:-.02em;line-height:1;text-decoration:none;z-index:2;white-space:nowrap;flex:1;text-align:center;min-width:0}
.logo-wordmark span{color:var(--brand)}

/* Right controls group */
.header-right{margin-left:auto;display:flex;align-items:center;gap:.75rem;z-index:2}
#theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1.5px solid var(--border);background:var(--white);border-radius:50%;cursor:pointer;color:var(--ink-muted);transition:all .15s;flex-shrink:0}
#theme-toggle:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}
.comfort-badge{display:flex;align-items:center;gap:.375rem;background:var(--brand-light);border:1.5px solid var(--brand-border);border-radius:100px;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#0d4336;position:relative}
.comfort-badge:hover{cursor:pointer}
.ci-tooltip{position:absolute;right:0;top:calc(100% + 8px);background:var(--brand-light);color:var(--brand-dark);border:1.5px solid var(--brand-border);box-shadow:0 10px 30px rgba(16,185,129,0.12);padding:.5rem .8rem;border-radius:10px;font-size:.78rem;line-height:1.3;max-width:300px;white-space:normal;opacity:0;transform:translateY(-6px);transition:opacity .15s,transform .15s;pointer-events:none;z-index:2000}
.ci-tooltip strong{display:block;font-size:.82rem;margin-bottom:4px}
.ci-tooltip .ci-body{font-size:.78rem;color:var(--brand-dark);opacity:0.95}
.comfort-badge:hover .ci-tooltip,.comfort-badge:focus .ci-tooltip{opacity:1;transform:translateY(0);pointer-events:auto;cursor:pointer}
#btn-login{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--ink);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;border:none;border-radius:100px;cursor:pointer;flex-shrink:0;transition:background .15s}
#btn-login:hover{background:#1f2937}
#user-chip{display:none;align-items:center;gap:.5rem;padding:.4rem .875rem;background:var(--brand-light);border:1.5px solid var(--brand-border);border-radius:100px;font-size:.8rem;font-weight:600;color:var(--brand-dark);cursor:pointer}
#user-chip:hover{background:#d2f3e5}

/* Decorative path curves */
.header-path{position:absolute;inset:0;pointer-events:none;z-index:0}
.hp-line{stroke:#10b981;stroke-width:3.5;stroke-linecap:round;opacity:.28;transition:opacity .3s}
.hp-2{stroke:#34d399;stroke-width:2.5;stroke-dasharray:8 10;opacity:.35}
.hp-3{stroke:#059669;stroke-width:2;stroke-dasharray:4 6;opacity:.2}
#app-header:hover .hp-1{opacity:.38}
#app-header:hover .hp-2{opacity:.48}
#app-header:hover .hp-3{opacity:.3}
[data-theme="dark"] .hp-line{stroke:#22c98e;opacity:.18}
[data-theme="dark"] .hp-2{stroke:#34d399;opacity:.24}
[data-theme="dark"] .hp-3{stroke:#10b981;opacity:.12}
[data-theme="dark"] #app-header:hover .hp-1{opacity:.28}
[data-theme="dark"] #app-header:hover .hp-2{opacity:.35}
[data-theme="dark"] #app-header:hover .hp-3{opacity:.22}

/* ── Layout ──────────────────────────────────────────────── */
#app-body{display:flex;flex:1;overflow:hidden;position:relative}

/* ── Sidebar ─────────────────────────────────────────────── */
#sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--white);border-right:1.5px solid var(--border);overflow-y:auto;padding:1.25rem 1rem 1.5rem;display:flex;flex-direction:column;gap:1.4rem;flex-shrink:0;z-index:100;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.section-title{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.5rem}
.divider{height:1px;background:var(--border);margin:0 -.25rem}

/* ── Geocoding inputs ────────────────────────────────────── */
.geo-wrapper{position:relative}
.geo-input-row{position:relative;display:flex;align-items:center}
.geo-input{width:100%;padding:.65rem 2.5rem .65rem .875rem;border:1.5px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--ink);background:#f9fafb;transition:border-color .15s,box-shadow .15s,background .15s;outline:none}
.geo-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(30,158,117,.15);background:var(--white)}
.geo-input.is-set{border-color:var(--brand);background:var(--brand-light)}
.geo-input::placeholder{color:var(--ink-faint)}
.geo-spinner{position:absolute;right:.65rem;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;display:none;pointer-events:none}
.geo-spinner.visible{display:block}
.geo-clear{position:absolute;right:.5rem;width:20px;height:20px;background:var(--ink-faint);border:none;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;color:#fff;font-size:.65rem;font-weight:700;transition:background .15s}
.geo-clear.visible{display:flex}
.geo-clear:hover{background:var(--ink)}
.geo-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--white);border:1.5px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:5000;display:none;max-height:240px;overflow-y:auto}
.geo-dropdown.visible{display:block}
.geo-dropdown-item{display:flex;align-items:center;gap:.6rem;padding:.65rem .875rem;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border-soft)}
.geo-dropdown-item:last-child{border-bottom:none}
.geo-dropdown-item:hover,.geo-dropdown-item.active{background:var(--brand-light)}
.geo-item-icon{font-size:1rem;flex-shrink:0}
.geo-item-name{font-size:.875rem;font-weight:600;color:var(--ink)}
.geo-item-addr{font-size:.75rem;color:var(--ink-muted);margin-top:1px}
.geo-dropdown-empty{padding:.875rem;font-size:.85rem;color:var(--ink-muted);text-align:center}
#btn-pick-on-map{width:100%;padding:.5rem .875rem;background:transparent;border:1.5px dashed var(--border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.8rem;color:var(--ink-muted);cursor:pointer;text-align:center;transition:all .15s;margin-top:.375rem}
#btn-pick-on-map:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}

/* ── Profile cards ───────────────────────────────────────── */
.profile-option{position:relative}
.profile-option input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.profile-card{display:flex;align-items:center;gap:.75rem;padding:.7rem .875rem;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s;background:var(--white);user-select:none}
.profile-card:hover{border-color:var(--brand);background:var(--brand-light)}
.profile-option input:checked+.profile-card{border-color:var(--brand);background:var(--brand-light);box-shadow:0 0 0 3px rgba(30,158,117,.15)}
.profile-icon{font-size:1.4rem;line-height:1;flex-shrink:0}
.profile-label{font-size:.875rem;font-weight:600;color:var(--ink)}
.profile-sublabel{font-size:.72rem;color:var(--ink-muted);margin-top:1px}

/* ── Filters ─────────────────────────────────────────────── */
.filter-option{display:flex;align-items:center;gap:.625rem;padding:.45rem .25rem;cursor:pointer;border-radius:8px;transition:background .1s}
.filter-option:hover{background:var(--border-soft)}
.filter-option input[type="checkbox"]{width:1.1rem;height:1.1rem;accent-color:var(--brand);cursor:pointer;flex-shrink:0}
.filter-label{font-size:.85rem;font-weight:500;color:var(--ink-soft)}

/* ── Route info panel ────────────────────────────────────── */
#route-info{background:linear-gradient(135deg,var(--brand-light) 0%,#f0fdf7 100%);border:1.5px solid var(--brand-border);border-radius:14px;padding:1rem;display:none;flex-direction:column;gap:.75rem}
#route-info.visible{display:flex}
.route-info-title{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--brand)}
.route-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}
.route-stat{background:var(--white);border-radius:10px;padding:.6rem .5rem;text-align:center;border:1px solid var(--brand-border)}
.route-stat-value{font-size:1.2rem;font-weight:700;color:var(--ink);font-family:'Fraunces',serif;line-height:1}
.route-stat-label{font-size:.65rem;color:var(--ink-muted);margin-top:3px;font-weight:500}
.route-comfort{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--white);border-radius:10px;border:1px solid var(--brand-border)}
.comfort-dots{display:flex;gap:3px;flex:1}
.comfort-dot{height:6px;flex:1;border-radius:3px;background:var(--border);transition:background .3s}
.comfort-dot.filled{background:var(--brand)}
.comfort-label{font-size:.75rem;font-weight:700;color:var(--brand-dark);white-space:nowrap}
#btn-clear-route{width:100%;padding:.75rem;background:#fef2f2;border:2px solid var(--red);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;color:var(--red);cursor:pointer;transition:all .15s}
#btn-clear-route:hover{background:var(--red);color:#fff;box-shadow:0 4px 12px rgba(220,38,38,.3)}
#btn-save-route{width:100%;padding:.75rem;background:var(--brand-light);border:2px solid var(--brand);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;color:var(--brand-dark);cursor:pointer;transition:all .15s;margin-top:.5rem}
#btn-save-route:hover{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(30,158,117,.3)}
#btn-save-route:disabled{opacity:.5;pointer-events:none}

/* ── Find route button ───────────────────────────────────── */
#btn-find-route{display:block;width:100%;padding:.9rem 1.25rem;background:var(--brand);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;text-align:center;transition:background .15s,transform .1s}
#btn-find-route:hover{background:var(--brand-dark)}
#btn-find-route:active{transform:scale(.98)}
#btn-find-route:disabled{opacity:.6;pointer-events:none}
.btn-hint{font-size:.695rem;color:var(--ink-faint);text-align:center;margin-top:.5rem;line-height:1.4}
.btn-hint strong{color:var(--brand)}

/* ── Map ─────────────────────────────────────────────────── */
#map-wrapper{flex:1;position:relative;overflow:hidden;min-height:0}
#map{width:100%;height:100%}
#map.pick-mode{cursor:crosshair!important}
#map-mode-badge{position:absolute;top:1rem;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--white);padding:.6rem 1.25rem;border-radius:100px;font-size:.875rem;font-weight:600;font-family:'DM Sans',sans-serif;z-index:1000;pointer-events:none;display:none;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.2)}
#map-mode-badge.visible{display:block}

/* ═══════════════════════════════════════════════════════════
   ROUTE LOADING OVERLAY
   ═══════════════════════════════════════════════════════════ */
.route-loading-overlay{position:fixed;inset:0;background:rgba(17,24,39,.7);backdrop-filter:blur(6px);z-index:9500;display:none;align-items:center;justify-content:center;padding:1rem}
.route-loading-overlay.visible{display:flex}
.route-loading-card{background:var(--white);border-radius:24px;padding:2.5rem 2rem;width:100%;max-width:340px;box-shadow:0 24px 64px rgba(0,0,0,.2);animation:gateIn .3s ease;text-align:center}
.rl-header{margin-bottom:1.5rem}
.rl-logo{font-family:'Fraunces',serif;font-weight:900;font-size:1.5rem;color:var(--ink);letter-spacing:-.02em}
.rl-logo span{color:var(--brand)}
.rl-anim{margin-bottom:1.25rem}
.rl-spinner{width:56px;height:56px;border:4px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}
.rl-status{font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.75rem;min-height:1.5em}
.rl-countdown-row{font-size:.85rem;color:var(--ink-muted);margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;gap:.3rem}
.rl-countdown{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:900;color:var(--brand)}
.rl-progress{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.rl-progress-fill{height:100%;background:var(--brand);border-radius:3px;transition:width .8s ease;width:0%}

[data-theme="dark"] .route-loading-overlay{background:rgba(0,0,0,.8)}

/* ── FAB Report ──────────────────────────────────────────── */
#fab-report{position:absolute;bottom:2rem;right:1.5rem;z-index:500;display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:var(--red);color:#ffffff;font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:600;border:none;border-radius:100px;cursor:pointer;box-shadow:0 4px 18px rgba(220,38,38,.4);transition:all .15s;white-space:nowrap}
#fab-report:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(220,38,38,.4)}
#fab-report:active{transform:scale(.97)}

/* ── Sidebar toggle (mobile) ─────────────────────────────── */
#sidebar-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;cursor:pointer;border-radius:8px;color:var(--ink-soft);flex-shrink:0}
#sidebar-toggle:hover{background:var(--border-soft)}

/* ── Modals ──────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(17,24,39,.55);backdrop-filter:blur(4px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .2s;min-height:100vh;min-height:100lvh}
.modal-overlay.is-open{opacity:1;pointer-events:auto}
.modal-box{background:var(--white);border-radius:20px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,.18);transform:translateY(16px) scale(.97);transition:transform .25s cubic-bezier(.34,1.56,.64,1);position:relative;max-height:85vh;max-height:85dvh;overflow-y:auto;scrollbar-width:thin}
.modal-overlay.is-open .modal-box{transform:none}
.modal-close-x{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:var(--border-soft);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);transition:background .15s;z-index:10}
.modal-close-x:hover{background:var(--border)}
.modal-title{font-family:'Fraunces',serif;font-size:1.375rem;font-weight:700;color:var(--ink);margin-bottom:.375rem}
.modal-subtitle{font-size:.875rem;color:var(--ink-muted);margin-bottom:1.5rem}

/* ── Forms ───────────────────────────────────────────────── */
.form-label{display:block;font-size:.8125rem;font-weight:600;color:var(--ink-soft);margin-bottom:.375rem}
.form-input,.form-select,.form-textarea{display:block;width:100%;font-family:'DM Sans',sans-serif;font-size:.9375rem;color:var(--ink);background:#f9fafb;border:1.5px solid var(--border);border-radius:10px;padding:.7rem .875rem;transition:all .15s;appearance:none;outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(30,158,117,.2);background:var(--white)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;background-color:#f9fafb;padding-right:2.5rem;cursor:pointer}
.form-textarea{resize:vertical;min-height:80px}
.form-error{font-size:.8rem;color:var(--red);margin-top:.375rem;font-weight:500;display:none}
.form-error.vis{display:block}
.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}
.btn-cancel{flex:1;padding:.75rem 1rem;background:var(--border-soft);color:var(--ink-soft);font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:background .15s}
.btn-cancel:hover{background:var(--border)}
.btn-primary{flex:2;padding:.75rem 1rem;background:var(--brand);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .15s}
.btn-primary:hover{background:var(--brand-dark)}
.btn-primary:active{transform:scale(.97)}
.btn-primary:disabled{opacity:.6;pointer-events:none}
.btn-full{display:block;width:100%;padding:.875rem;background:var(--brand);color:var(--white);font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .15s;text-align:center}
.btn-full:hover{background:var(--brand-dark)}
.btn-full:disabled{opacity:.6;pointer-events:none}

/* ── Auth modal ──────────────────────────────────────────── */
#auth-modal-box{max-width:480px;padding:2rem}
.auth-tabs{display:flex;background:var(--border-soft);border-radius:10px;padding:3px;margin-bottom:1.5rem;margin-top:2rem}
.auth-tab{flex:1;padding:.55rem;text-align:center;font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;color:var(--ink-muted);border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s}
.auth-tab.active{background:var(--white);color:var(--ink);box-shadow:0 1px 6px rgba(0,0,0,.1)}
.auth-panel{display:none}
.auth-panel.active{display:block}

/* ── Onboarding steps ────────────────────────────────────── */
.onboarding-step{display:none}
.onboarding-step.active{display:block}
.step-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}
.step-dot{width:28px;height:6px;border-radius:3px;background:var(--border);transition:background .3s,width .3s}
.step-dot.active{background:var(--brand)}
.step-dot.done{background:var(--brand-border)}
.step-lbl{font-size:.75rem;color:var(--ink-muted);font-weight:500;margin-left:auto}

.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;margin-bottom:.75rem}
.access-card-opt{position:relative}
.access-card-opt input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.access-card{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.875rem .5rem;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s;text-align:center;background:var(--white)}
.access-card:hover{border-color:var(--brand);background:var(--brand-light)}
.access-card-opt input:checked+.access-card{border-color:var(--brand);background:var(--brand-light);box-shadow:0 0 0 3px rgba(30,158,117,.15)}
.access-card-icon{font-size:1.75rem;line-height:1}
.access-card-name{font-size:.8rem;font-weight:600;color:var(--ink)}
.access-card-sub{font-size:.68rem;color:var(--ink-muted);line-height:1.3}

.needs-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.need-chip-opt{position:relative}
.need-chip-opt input[type="checkbox"]{position:absolute;opacity:0;width:0;height:0}
.need-chip{padding:.45rem .875rem;border:1.5px solid var(--border);border-radius:100px;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:all .15s;white-space:nowrap;display:block}
.need-chip:hover{border-color:var(--brand);color:var(--brand)}
.need-chip-opt input:checked+.need-chip{border-color:var(--brand);background:var(--brand-light);color:var(--brand-dark)}

.pw-wrap{position:relative}
.pw-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);border:none;background:none;cursor:pointer;color:var(--ink-faint);padding:0;line-height:1;font-size:1rem}
.pw-toggle:hover{color:var(--ink)}

/* ── User banner (sidebar) ───────────────────────────────── */
#profile-user-banner{display:none;align-items:center;gap:.625rem;padding:.75rem .875rem;background:var(--brand-light);border:1.5px solid var(--brand-border);border-radius:12px}
#profile-user-banner.vis{display:flex}
.pub-avatar{width:32px;height:32px;border-radius:50%;background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.pub-name{font-size:.8rem;font-weight:700;color:var(--ink)}
.pub-profile{font-size:.7rem;color:var(--brand-dark)}

/* ── Obstacle modal ──────────────────────────────────────── */
#obs-modal-box{max-width:460px;padding:1.75rem}
#modal-coords-badge{display:none;background:var(--brand-light);border:1px solid var(--brand-border);border-radius:8px;padding:.4rem .75rem;font-size:.8rem;color:var(--brand-dark);font-weight:600;margin-bottom:1rem}

/* ── User dropdown menu ──────────────────────────────────── */
#user-menu{position:fixed;top:calc(var(--header-h) + 6px);right:1.25rem;background:var(--white);border:1.5px solid var(--border);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:9500;display:none;min-width:260px;overflow:hidden}
.history-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .25rem;border-radius:8px;cursor:pointer;transition:background .1s;font-size:.75rem;color:var(--ink)}
.history-item:hover{background:var(--brand-light)}
.history-item .hi-icon{flex-shrink:0;font-size:.85rem}
.history-item .hi-text{flex:1;min-width:0}
.history-item .hi-route{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.history-item .hi-meta{font-size:.65rem;color:var(--ink-muted)}

/* ── Leaflet overrides ───────────────────────────────────── */
.leaflet-control-zoom a{font-size:1.1rem!important;width:36px!important;height:36px!important;line-height:34px!important;border-radius:8px!important}
.leaflet-control-zoom{border-radius:10px!important;overflow:hidden}
.leaflet-control-attribution{font-size:.65rem!important;background:rgba(255,255,255,.85)!important;backdrop-filter:blur(4px);border-radius:6px 0 0 0!important}

/* ── Toast ───────────────────────────────────────────────── */
#eq-toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--white);padding:.75rem 1.25rem;border-radius:100px;font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:99999;transition:opacity .3s,transform .3s;opacity:0;white-space:nowrap;max-width:calc(100vw - 2rem);pointer-events:none}

@keyframes spin{to{transform:rotate(360deg)}}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:768px){
  #sidebar{position:absolute;top:0;left:0;height:100%;transform:translateX(-100%);transition:transform .25s;box-shadow:4px 0 24px rgba(0,0,0,.12);z-index:900}
  #sidebar.is-open{transform:translateX(0)}
  body.sidebar-open .leaflet-control-zoom{opacity:0;pointer-events:none;transition:opacity .2s}
  #sidebar-toggle{display:flex}
  .logo-wordmark{font-size:1.05rem}
  .header-right .comfort-badge{display:none}
  .header-right{gap:.35rem;flex-shrink:0}
  #btn-login{padding:.4rem .65rem;font-size:.78rem}
  #theme-toggle{width:30px;height:30px}
  .header-path{opacity:.5}
  #fab-report{bottom:1.25rem;right:1rem;padding:.75rem 1rem;font-size:.875rem}
}

/* ── Auth gate overlay ───────────────────────────────────── */
#auth-gate-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:10000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#auth-gate-overlay.is-open{display:flex}
.auth-gate-card{background:var(--white);border-radius:20px;padding:2.5rem 2rem 2rem;max-width:340px;width:90%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.18);animation:gateIn .25s ease}
@keyframes gateIn{from{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}
.auth-gate-icon{font-size:2.5rem;margin-bottom:.75rem}
.auth-gate-title{font-family:'Fraunces',serif;font-weight:900;font-size:1.25rem;color:var(--ink);margin-bottom:.5rem}
.auth-gate-desc{font-size:.85rem;color:var(--ink-muted);line-height:1.5;margin-bottom:1.5rem}
.auth-gate-btn{display:block;width:100%;padding:.75rem;border:none;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s;margin-bottom:.5rem}
.auth-gate-login{background:var(--brand);color:#fff}
.auth-gate-login:hover{background:var(--brand-dark)}
.auth-gate-register{background:var(--brand-light);color:var(--brand-dark);border:1.5px solid var(--brand-border)}
.auth-gate-register:hover{background:#d2f3e5}
.auth-gate-close{background:none;border:none;color:var(--ink-muted);font-family:'DM Sans',sans-serif;font-size:.8rem;cursor:pointer;padding:.5rem;width:100%}
.auth-gate-close:hover{color:var(--ink)}

/* ── Account Modal ──────────────────────────────────────── */
.acc-section{border:1.5px solid var(--border);border-radius:12px;margin-bottom:.75rem;overflow:hidden}
.acc-section-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--border-soft);cursor:pointer;font-size:.875rem;font-weight:600;color:var(--ink);user-select:none;transition:background .15s}
.acc-section-header:hover{background:var(--border)}
.acc-chevron{transition:transform .2s}
.acc-section-header.open .acc-chevron{transform:rotate(180deg)}
.acc-section-body{display:none;padding:1rem}
.acc-section-body.open{display:block}

/* Saved routes */
.sr-item{border:1.5px solid var(--border);border-radius:10px;margin-bottom:.5rem;overflow:hidden}
.sr-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--ink);transition:background .15s;gap:.5rem}
.sr-header:hover{background:var(--border-soft)}
.sr-chevron{transition:transform .2s;flex-shrink:0}
.sr-header.open .sr-chevron{transform:rotate(180deg)}
.sr-body{display:none;padding:.75rem;border-top:1px solid var(--border);background:#fafbfc}
.sr-body.open{display:block}
.sr-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.375rem;margin-bottom:.625rem}
.sr-stat{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:.4rem;text-align:center}
.sr-stat-val{font-size:.9rem;font-weight:700;color:var(--ink);font-family:'Fraunces',serif}
.sr-stat-lbl{font-size:.6rem;color:var(--ink-muted);margin-top:2px}
.sr-analysis{font-size:.75rem;color:var(--ink-soft);line-height:1.45;margin-bottom:.625rem;padding:.5rem;background:var(--white);border-radius:8px;border:1px solid var(--border)}
.sr-actions{display:flex;gap:.5rem}
.sr-btn{flex:1;padding:.5rem;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}
.sr-btn-load{background:var(--brand);color:#fff}
.sr-btn-load:hover{background:var(--brand-dark)}
.sr-btn-del{background:#fef2f2;color:var(--red);border:1px solid #fca5a5}
.sr-btn-del:hover{background:var(--red);color:#fff}

/* Delete account */
.acc-delete-section{margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--border)}
.acc-delete-btn{width:100%;padding:.75rem 1rem;background:transparent;border:none;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:500;color:var(--ink-faint);cursor:pointer;transition:color .15s;text-align:center}
.acc-delete-btn:hover{color:var(--red)}

/* ═══════════════════════════════════════════════════════════
   ROLE SELECTION (Registration Step 2)
   ═══════════════════════════════════════════════════════════ */
.role-grid{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.role-card-opt{position:relative}
.role-card-opt input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.role-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;border:2px solid var(--border);border-radius:16px;cursor:pointer;transition:all .2s;text-align:center;background:var(--white);position:relative;overflow:hidden}
.role-card:hover{border-color:var(--brand);background:var(--brand-light)}
.role-card-opt input:checked+.role-card{border-color:var(--brand);background:var(--brand-light);box-shadow:0 0 0 3px rgba(30,158,117,.15)}
.role-card-badge{position:absolute;top:.6rem;right:.75rem;padding:.2rem .65rem;border-radius:100px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.user-badge{background:#e0f2fe;color:#0369a1}
.buddy-badge{background:#dcfce7;color:#15803d}
.role-card-icon{font-size:2rem;line-height:1}
.role-card-name{font-size:1rem;font-weight:700;color:var(--ink)}
.role-card-sub{font-size:.78rem;color:var(--ink-muted);line-height:1.4;max-width:280px}

/* ═══════════════════════════════════════════════════════════
   BUDDY SYSTEM
   ═══════════════════════════════════════════════════════════ */
.buddy-action-btn{width:100%;padding:.65rem .875rem;border:1.5px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:600;color:var(--ink);background:var(--white);cursor:pointer;transition:all .15s;text-align:center;margin-bottom:.4rem}
.buddy-action-btn:hover{border-color:var(--brand);background:var(--brand-light);color:var(--brand-dark)}
.buddy-browse{border-color:var(--brand-border);color:var(--brand-dark);background:var(--brand-light)}
.buddy-browse:hover{background:var(--brand);color:#fff}

/* Buddy cards */
.buddy-card{border:1.5px solid var(--border);border-radius:14px;padding:1rem;margin-bottom:.75rem;background:var(--white);transition:box-shadow .2s}
.buddy-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.buddy-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.buddy-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--brand-light);border:2px solid var(--brand-border);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.buddy-card-info{flex:1;min-width:0}
.buddy-card-name{font-size:.9rem;font-weight:700;color:var(--ink)}
.buddy-card-date{font-size:.75rem;color:var(--ink-muted);margin-top:2px}
.buddy-card-route{padding:.625rem .75rem;background:var(--border-soft);border-radius:10px;margin-bottom:.5rem}
.buddy-route-point{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--ink-soft);padding:.2rem 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.buddy-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.buddy-dot-a{background:var(--brand)}
.buddy-dot-b{background:var(--ink)}
.buddy-route-line{width:1px;height:12px;background:var(--border);margin-left:4px}
.buddy-card-note{font-size:.8rem;color:var(--ink-muted);line-height:1.45;padding:.5rem .75rem;background:var(--border-soft);border-radius:8px;margin-bottom:.5rem;font-style:italic}
.buddy-card-actions{display:flex;gap:.5rem;align-items:center}
.buddy-btn{flex:1;padding:.55rem .75rem;border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}
.buddy-btn-accept{background:var(--brand);color:#fff}
.buddy-btn-accept:hover{background:var(--brand-dark)}
.buddy-btn-complete{background:#f0fdf4;color:#15803d;border:1px solid #86efac}
.buddy-btn-complete:hover{background:#15803d;color:#fff}
.buddy-btn-del{background:#fef2f2;color:var(--red);border:1px solid #fca5a5;flex:0}
.buddy-btn-del:hover{background:var(--red);color:#fff}
.buddy-completed-label{font-size:.78rem;font-weight:600;color:#15803d}
.buddy-card-completed{opacity:.7;border-color:var(--border)}
.buddy-card-completed .buddy-card-route{opacity:.6}
.buddy-card-hint{font-size:.75rem;color:var(--ink-faint);font-style:italic}
.buddy-empty{text-align:center;padding:2rem 0;color:var(--ink-muted);font-size:.85rem}
.buddy-empty-icon{font-size:2.5rem;margin-bottom:.5rem}
.buddy-loading{text-align:center;padding:2rem 0;color:var(--ink-muted);font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:.5rem}
.buddy-loading-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}

/* Accepted state */
.buddy-card-accepted{border-color:var(--brand-border);background:var(--brand-light)}
.buddy-accepted-badge{padding:.2rem .6rem;border-radius:100px;font-size:.65rem;font-weight:700;background:#dcfce7;color:#15803d;flex-shrink:0}
.buddy-status{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:10px;margin-bottom:.5rem;background:#f0fdf4;border:1px solid #bbf7d0}
.buddy-status-icon{font-size:1.1rem;flex-shrink:0}
.buddy-status-body{flex:1;min-width:0}
.buddy-status-title{font-size:.78rem;font-weight:700;color:#15803d}
.buddy-status-detail{font-size:.75rem;color:#166534;margin-top:1px}

/* ═══════════════════════════════════════════════════════════
   CUSTOM CALENDAR PICKER
   ═══════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════
   CUSTOM PICKERS — Full-screen overlay on mobile
   ═══════════════════════════════════════════════════════════ */
.eq-picker-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(3px);z-index:10000;display:none;align-items:center;justify-content:center;padding:1rem}
.eq-picker-overlay.open{display:flex}
.eq-picker-box{background:var(--white);border-radius:18px;box-shadow:0 16px 48px rgba(0,0,0,.2);padding:1.25rem;width:100%;max-width:340px;animation:gateIn .2s ease}

/* Calendar */
.eq-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.eq-cal-nav{width:36px;height:36px;border:none;background:var(--border-soft);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);transition:all .15s}
.eq-cal-nav:hover{background:var(--brand-light);color:var(--brand)}
.eq-cal-title{font-size:1rem;font-weight:700;color:var(--ink)}
.eq-cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;text-align:center}
.eq-cal-day-name{font-size:.7rem;font-weight:600;color:var(--ink-faint);padding:.35rem 0;text-transform:uppercase}
.eq-cal-empty{padding:.35rem}
.eq-cal-day{width:100%;aspect-ratio:1;border:none;background:none;border-radius:10px;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:500;color:var(--ink);cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center}
.eq-cal-day:hover:not(.past){background:var(--brand-light);color:var(--brand-dark)}
.eq-cal-day.today{font-weight:700;border:2px solid var(--brand)}
.eq-cal-day.selected{background:var(--brand);color:#fff;font-weight:700}
.eq-cal-day.past{color:var(--ink-faint);opacity:.35;cursor:default}

/* Time picker */
.eq-time-title{font-size:.9rem;font-weight:700;color:var(--ink);text-align:center;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:.5rem}
.eq-time-back{border:none;background:none;font-size:.9rem;font-weight:700;color:var(--brand);cursor:pointer;padding:0}
.eq-time-grid{display:grid;gap:6px}
.eq-time-hours{grid-template-columns:repeat(6,1fr)}
.eq-time-mins{grid-template-columns:repeat(4,1fr)}
.eq-time-cell{border:none;background:var(--border-soft);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:600;color:var(--ink);cursor:pointer;padding:.7rem .25rem;text-align:center;transition:all .12s}
.eq-time-cell:hover{background:var(--brand-light);color:var(--brand-dark)}
.eq-time-cell.selected{background:var(--brand);color:#fff}

[data-theme="dark"] .eq-picker-box{box-shadow:0 16px 48px rgba(0,0,0,.5)}

[data-theme="dark"] .user-badge{background:#0c4a6e;color:#7dd3fc}
[data-theme="dark"] .buddy-badge{background:#14532d;color:#86efac}
.buddy-status-phone{margin-top:4px}
.buddy-status-phone a{color:#15803d;font-weight:700;font-size:.82rem;text-decoration:none}
.buddy-status-phone a:hover{text-decoration:underline}
[data-theme="dark"] .buddy-status-phone a{color:#86efac}
[data-theme="dark"] .buddy-card-accepted{background:#0d2d22}
[data-theme="dark"] .buddy-accepted-badge{background:#14532d;color:#86efac}
[data-theme="dark"] .buddy-status{background:#052e16;border-color:#166534}

/* Buddy tabs */
.buddy-tabs{display:flex;background:var(--border-soft);border-radius:10px;padding:3px;margin-bottom:1rem}
.buddy-tab{flex:1;padding:.5rem;text-align:center;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;color:var(--ink-muted);border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s}
.buddy-tab.active{background:var(--white);color:var(--ink);box-shadow:0 1px 6px rgba(0,0,0,.1)}

/* Password change toggle */
.pw-change-section{margin-top:.25rem}
.btn-pw-change-toggle{width:100%;padding:.55rem;background:var(--border-soft);border:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;color:var(--ink-muted);cursor:pointer;transition:all .15s}
.btn-pw-change-toggle:hover{background:var(--border);color:var(--ink)}

/* Buddy map pick button */
.br-pick-map-btn{width:100%;padding:.5rem .875rem;background:transparent;border:1.5px dashed var(--border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.8rem;color:var(--ink-muted);cursor:pointer;text-align:center;transition:all .15s;margin-bottom:.25rem}
.br-pick-map-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}

/* ── GPS Start button ───────────────────────────────────── */
#btn-gps-start{width:100%;padding:.55rem .875rem;background:var(--brand-light);border:1.5px solid var(--brand-border);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;color:var(--brand-dark);cursor:pointer;text-align:center;transition:all .15s;margin-top:.25rem}
#btn-gps-start:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
#btn-gps-start:disabled{opacity:.5;pointer-events:none}

/* ── Map floating buttons ───────────────────────────────── */
.map-fab{position:absolute;z-index:500;width:46px;height:46px;border-radius:50%;border:none;background:var(--white);box-shadow:0 2px 12px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.04);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:all .2s}
.map-fab:hover{box-shadow:0 4px 20px rgba(0,0,0,.2);color:var(--brand)}
.map-fab:active{transform:scale(.9)}
.locate-fab{bottom:7.5rem;right:1.25rem}
.locate-fab.locating{color:var(--brand)}
.locate-fab.locating svg{animation:pulse-locate 1.2s ease infinite}
.recenter-fab{bottom:11rem;right:1.25rem;display:none;background:var(--brand);color:#fff;box-shadow:0 2px 12px rgba(30,158,117,.4)}
.recenter-fab:hover{background:var(--brand-dark);color:#fff}
@keyframes pulse-locate{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

/* ── Start navigation button ────────────────────────────── */
#btn-start-nav{display:none;width:100%;padding:.85rem;background:linear-gradient(135deg,#4285F4 0%,#1a73e8 100%);color:#fff;font-family:'DM Sans',sans-serif;font-size:.9375rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:all .15s;margin-top:.5rem;box-shadow:0 4px 14px rgba(66,133,244,.3)}
#btn-start-nav:hover{box-shadow:0 6px 20px rgba(66,133,244,.4);transform:translateY(-1px)}
#btn-start-nav:active{transform:scale(.97)}
#btn-start-nav:disabled{opacity:.6;pointer-events:none;transform:none}

/* ═══════════════════════════════════════════════════════════
   NAVIGATION UI — Google Maps style
   ═══════════════════════════════════════════════════════════ */

/* ── Top instruction bar ────────────────────────────────── */
.nav-top-bar{position:absolute;top:0;left:0;right:0;z-index:800;background:#1a6b54;color:#fff;display:none;flex-direction:column;box-shadow:0 4px 20px rgba(0,0,0,.25);padding-top:env(safe-area-inset-top,0)}
body.navigating .nav-top-bar{display:flex}
.nav-turn-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem .75rem}
.nav-turn-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-turn-body{flex:1;min-width:0}
.nav-turn-street{font-size:1.2rem;font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-next-turn{display:none;padding:.4rem 1.25rem .6rem;font-size:.82rem;font-weight:600;opacity:.85}
.nav-next-turn.visible{display:flex;align-items:center;gap:.5rem}

/* ── Bottom sheet ───────────────────────────────────────── */
.nav-bottom-sheet{position:absolute;bottom:0;left:0;right:0;z-index:800;background:var(--white);border-radius:16px 16px 0 0;box-shadow:0 -2px 24px rgba(0,0,0,.12);transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,.32,1);padding-bottom:env(safe-area-inset-bottom,0)}
body.navigating .nav-bottom-sheet{transform:translateY(0)}
.nav-handle{width:32px;height:4px;background:var(--border);border-radius:2px;margin:8px auto 0;cursor:grab}
.nav-sheet-summary{display:flex;align-items:center;padding:.75rem 1rem .75rem 1.25rem;gap:.75rem}
.nav-eta-block{flex-shrink:0}
.nav-eta-time{font-family:'Fraunces',serif;font-size:2.2rem;font-weight:900;color:var(--brand);line-height:1}
.nav-eta-label{font-size:.6rem;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.nav-eta-detail{flex:1;font-size:.82rem;color:var(--ink-muted);font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-exit-btn{flex-shrink:0;padding:.65rem 1.5rem;background:#dc2626;color:#fff;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:700;border:none;border-radius:100px;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px rgba(220,38,38,.3)}
.nav-exit-btn:hover{background:#b91c1c}
.nav-exit-btn:active{transform:scale(.95)}

/* Expanded section */
.nav-sheet-expanded{display:none;padding:0 1.25rem 1rem;border-top:1px solid var(--border)}
.nav-bottom-sheet.expanded .nav-sheet-expanded{display:block}
.nav-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;padding-top:.875rem}
.nav-info-item{background:var(--border-soft);border-radius:10px;padding:.65rem .75rem;display:flex;flex-direction:column;gap:2px}
.nav-info-icon{font-size:1rem;line-height:1}
.nav-info-label{font-size:.65rem;color:var(--ink-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em}
.nav-info-value{font-size:.9rem;font-weight:700;color:var(--ink)}
.nav-info-dest{font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-progress-track{height:4px;background:var(--border);margin-top:.875rem;border-radius:2px;overflow:hidden}
.nav-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),#4285F4);border-radius:2px;transition:width .6s ease;width:0%}

/* ── Navigating state ───────────────────────────────────── */
body.navigating #app-header{display:none}
body.navigating #sidebar{display:none!important}
body.navigating #fab-report{display:none}
body.navigating .locate-fab{bottom:7.5rem;right:1rem}
body.navigating .recenter-fab{bottom:11rem;right:1rem}

/* ── Dark mode nav ──────────────────────────────────────── */
[data-theme="dark"] .nav-top-bar{background:#0f3d2e}
[data-theme="dark"] .nav-bottom-sheet{box-shadow:0 -2px 24px rgba(0,0,0,.4)}
[data-theme="dark"] .nav-info-item{background:var(--surface)}
[data-theme="dark"] .map-fab{box-shadow:0 2px 12px rgba(0,0,0,.3)}
[data-theme="dark"] .recenter-fab{box-shadow:0 2px 12px rgba(30,158,117,.5)}

/* ── Mobile nav responsive ──────────────────────────────── */
@media(max-width:768px){
  .locate-fab{bottom:6rem;right:.875rem}
  .recenter-fab{bottom:9.5rem;right:.875rem}
  body.navigating .locate-fab{bottom:7rem;right:.875rem}
  body.navigating .recenter-fab{bottom:10.5rem;right:.875rem}
  .nav-turn-street{font-size:1.1rem}
  .nav-eta-time{font-size:1.75rem}
}

