:root{
  --bg:#e9ebef;
  --card:#ffffff;
  --ink:#15171c;
  --ink-2:#5a616e;
  --ink-3:#5f6673; /* darkened from the mockup's #9298a4 for AA contrast on card+bg */
  --amber-strong:#b45309; /* amber for text/white-on chips (the token amber is 2.1:1) */
  --line:#ebedf1;
  --line-2:#e0e3e8;
  --field:#f3f4f7;
  --energy:#1f9d57;
  --energy-soft:#e7f5ec;
  --amber:#f0a526;
  --amber-soft:#fdf3e0;
  --red:#dc2626;
  --red-soft:#fdecec;
  --blue:#2563eb;
  --blue-soft:#e8effe;
  --tesla:#e3242b;
  --cfa:#dc0a2d;
  --sbux:#0a6b4f;
  --ionna:#1f6feb;
  --gray-dot:#9aa1ad;
  --shadow-card:0 1px 2px rgba(16,24,40,.05), 0 6px 20px -8px rgba(16,24,40,.14);
  --shadow-pop:0 8px 30px -6px rgba(16,24,40,.22);
  --r-lg:20px; --r-md:14px; --r-sm:10px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv01";
}
.num{font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
svg{display:block}
.icon{width:18px;height:18px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}
.icon.sm{width:15px;height:15px}
.icon.xs{width:13px;height:13px}

/* ============ TOP BAR ============ */
.topbar{
  height:64px;display:flex;align-items:center;gap:16px;
  padding:0 18px;background:var(--card);
  border-bottom:1px solid var(--line-2);
  position:relative;z-index:1200;
}
.brand{display:flex;align-items:center;gap:9px;padding-right:6px}
.brand-mark{
  width:32px;height:32px;border-radius:9px;display:grid;place-items:center;
  background:var(--ink);color:#fff;
}
.brand-mark .icon{width:19px;height:19px;stroke-width:2}
.brand-name{font-size:19px;font-weight:700;letter-spacing:-.02em;color:var(--ink-3)}
.brand-name b{color:var(--ink);font-weight:800}

.route-fields{display:flex;align-items:center;gap:8px;flex:1;max-width:740px}
.field{
  flex:1;display:flex;align-items:center;gap:9px;height:42px;
  padding:0 14px;background:var(--field);border:1px solid transparent;
  border-radius:12px;transition:.15s;min-width:0;position:relative;
}
.field:focus-within{background:#fff;border-color:var(--line-2);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.field .pin{flex:none}
.field .pin .ring{width:11px;height:11px;border-radius:50%;border:2.5px solid var(--ink);display:block}
.field.dest .pin .ring{background:var(--ink);border-color:var(--ink)}
.field input{
  border:none;background:none;outline:none;width:100%;
  font-size:14.5px;font-weight:600;color:var(--ink);min-width:0;
}
.field input::placeholder{color:var(--ink-3);font-weight:500}
.field-clear[hidden]{display:none} /* class display beats the hidden attr */
.field-clear{flex:none;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;color:var(--ink-3)}
.field-clear:hover{color:var(--ink);background:#e7e9ee}
.swap{
  width:38px;height:38px;flex:none;border-radius:11px;display:grid;place-items:center;
  background:var(--card);border:1px solid var(--line-2);color:var(--ink-2);transition:.15s;
}
.swap:hover{color:var(--ink);background:var(--field);transform:rotate(180deg)}
.topbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.filter-chip{
  display:flex;align-items:center;gap:8px;height:42px;padding:0 12px 0 13px;
  background:var(--field);border-radius:12px;font-size:14px;font-weight:600;color:var(--ink);
}
.filter-chip .bolt{color:var(--energy)}
.filter-chip .chev{color:var(--ink-3);margin-left:2px}
.filter-chip:hover{background:#eceef2}
.icon-btn{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--field);color:var(--ink-2);
}
.icon-btn:hover{background:#eceef2;color:var(--ink)}
.btn-primary{
  height:42px;padding:0 20px;border-radius:12px;background:var(--ink);color:#fff;
  font-size:14.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;
  box-shadow:0 1px 2px rgba(0,0,0,.2);transition:.15s;
}
.btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 6px 16px -6px rgba(0,0,0,.4)}
.btn-primary:disabled{opacity:.65;cursor:wait;transform:none}

/* ============ APP LAYOUT ============ */
.app{display:flex;height:calc(100vh - 64px)}
.sidebar{
  width:432px;flex:none;display:flex;flex-direction:column;
  background:var(--bg);border-right:1px solid var(--line-2);position:relative;z-index:10;
}
.sidebar-scroll{flex:1;overflow-y:auto;padding:16px 16px 8px}
.sidebar-scroll::-webkit-scrollbar{width:9px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:#d3d7de;border-radius:9px;border:2px solid var(--bg)}
.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:#c2c7d0}

/* alt tabs */
.alt-tabs{display:flex;gap:8px;margin-bottom:14px}
.alt{
  flex:1;height:46px;border-radius:13px;background:var(--card);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;gap:7px;
  padding:0 10px;transition:.15s;box-shadow:0 1px 2px rgba(16,24,40,.04);
}
.alt .t{font-size:15px;font-weight:700;letter-spacing:-.02em;white-space:nowrap}
.alt .s{font-size:11px;font-weight:600;color:var(--ink-3);white-space:nowrap}
.alt .s.rec{color:var(--blue)}
.alt:hover{border-color:var(--line-2)}
.alt.active{background:var(--ink);border-color:var(--ink);color:#fff;box-shadow:var(--shadow-card)}
.alt.active .s{color:rgba(255,255,255,.7)}
.alt.active .s.rec{color:#9ec1ff}

/* card base */
.card{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--shadow-card)}

/* summary */
.summary{padding:18px 18px 14px;margin-bottom:6px}
.summary-top{display:flex;align-items:flex-start;justify-content:space-between}
.big-time{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1}
.summary-sub{font-size:13px;font-weight:600;color:var(--ink-3);margin-top:5px;white-space:nowrap}
.badge-rec{
  font-size:12px;font-weight:700;color:var(--blue);background:var(--blue-soft);
  padding:5px 11px;border-radius:999px;letter-spacing:-.01em;white-space:nowrap;
}
.badge-rec.warn-badge{color:#b45309;background:var(--amber-soft)}
.stat-row{display:flex;flex-wrap:wrap;gap:7px 18px;margin-top:16px}
.stat{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;color:var(--ink);white-space:nowrap}
.stat .icon{color:var(--ink-3);flex:none}
.stat .lbl{color:var(--ink-3);font-weight:600;margin-left:1px}
.reset{
  margin-top:5px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
  font-size:12.5px;font-weight:600;color:var(--ink-3);
}
.reset .icon{flex:none;width:13px;height:13px}
.reset:hover{color:var(--blue)}

.section-label{
  font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:var(--ink-3);margin:18px 4px 10px;
}

/* ============ TIMELINE ============ */
.timeline{position:relative}
.timeline::before{
  content:"";position:absolute;left:19px;top:14px;bottom:18px;width:2.5px;border-radius:2px;
  background:linear-gradient(180deg,#cdd2da 0%, var(--blue) 12%, var(--blue) 88%, #cdd2da 100%);
}
.tl-row{position:relative;padding-left:48px;margin-bottom:10px}
.node{
  position:absolute;left:8px;top:6px;width:24px;height:24px;border-radius:50%;
  display:grid;place-items:center;background:#fff;box-shadow:0 0 0 4px var(--bg);z-index:2;
  font-size:12px;font-weight:800;color:#fff;
}
.node.endpoint{background:#fff;border:2.5px solid var(--ink);top:14px}
.node.endpoint.finish{background:var(--ink)}
.node.charge{background:var(--blue);box-shadow:0 0 0 4px var(--bg),0 2px 6px rgba(37,99,235,.4)}
.node.charge.g{background:var(--energy);box-shadow:0 0 0 4px var(--bg),0 2px 6px rgba(31,157,87,.4)}
.node.charge.y{background:var(--amber-strong);box-shadow:0 0 0 4px var(--bg),0 2px 6px rgba(180,83,9,.4)}
.node.gap-node{background:var(--amber-strong);box-shadow:0 0 0 4px var(--bg)}

/* endpoint row */
.endpoint-row{padding:10px 0 10px 48px;position:relative;margin-bottom:6px}
.endpoint-row .place{font-size:15.5px;font-weight:700;letter-spacing:-.015em;line-height:1.25}
.endpoint-row .sub{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.endpoint-meta{display:flex;align-items:center;gap:10px;margin-top:8px}
.batt{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700}
.batt.neg{color:var(--red)}
.batt.low{color:#b45309}
.batt-glyph{width:26px;height:14px;border:1.8px solid var(--ink);border-radius:3px;position:relative;padding:1.6px}
.batt-glyph::after{content:"";position:absolute;right:-3.4px;top:3.5px;width:2px;height:5px;background:var(--ink);border-radius:0 1px 1px 0}
.batt-glyph i{display:block;height:100%;border-radius:1px;background:var(--energy)}
.batt.neg .batt-glyph i{background:var(--red)}
.batt.low .batt-glyph i{background:var(--amber)}
.endpoint-time{font-size:12.5px;font-weight:700;color:var(--ink-2);margin-left:auto;white-space:nowrap}

/* leg */
.leg{position:relative;padding:2px 0 2px 48px;margin:2px 0 12px}
.leg-pill{
  position:absolute;left:6px;top:5px; /* centered on .leg-inner (2px pad + 17 − 14) */
  width:28px;height:28px;border-radius:50%;background:#fff;border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink-2);box-shadow:0 0 0 4px var(--bg);z-index:2;
}
.leg-inner{display:flex;align-items:center;gap:10px;min-height:34px}
.leg-dist{font-size:13px;font-weight:700;color:var(--ink-2);white-space:nowrap}
.leg-dist .sep{color:var(--ink-3);margin:0 2px;font-weight:600}
.leg-dist .t{color:var(--ink-3);font-weight:600}
.add-stop{
  display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;color:var(--blue);
  margin-left:auto;padding:4px 0;white-space:nowrap;
}
.add-stop .icon{flex:none}
.add-stop:hover{text-decoration:underline}
.add-stop .n{color:var(--ink-3);font-weight:600}

/* stop card */
.stop{padding:15px 16px 14px;position:relative;transition:.16s;border:1px solid transparent;cursor:pointer}
.stop:hover{box-shadow:var(--shadow-pop);transform:translateY(-1px)}
.stop:focus-visible{outline:2.5px solid var(--blue);outline-offset:2px}
.stop-top{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.power{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}
.bolts{display:flex;gap:1px}
.bolts .icon{width:14px;height:15px;fill:var(--energy);stroke:var(--energy);stroke-width:1}
.bolts .icon.off{fill:#d7dbe1;stroke:#d7dbe1}
.stop-top .cnt{font-size:13px;font-weight:600;color:var(--ink-3);white-space:nowrap}
.stop-top .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-3);flex:none}
.stop-eta{margin-left:auto;font-size:13px;font-weight:700;color:var(--ink-2);white-space:nowrap}
.sortbtn{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:var(--ink-3)}
.sortbtn:hover{background:var(--field);color:var(--ink)}
.pin-flag{font-size:12px;flex:none}

.stop-brand{display:flex;align-items:flex-start;gap:11px;margin-bottom:13px}
.stop-brand>div{min-width:0;flex:1}
.brand-badge{
  width:30px;height:30px;flex:none;border-radius:9px;display:grid;place-items:center;
  font-size:14px;font-weight:800;color:#fff;letter-spacing:-.02em;margin-top:1px;
}
.brand-badge.chip-badge{width:22px;height:22px;border-radius:7px;font-size:10px}
.stop-name{
  font-size:15px;font-weight:700;letter-spacing:-.015em;line-height:1.25;
  background:none;border:0;padding:0;font-family:inherit;color:inherit;text-align:left;cursor:pointer;
}
.stop-name:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}
.stop-sub{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-top:3px}

.poi-chip{
  display:flex;align-items:center;gap:7px;width:fit-content;
  margin:10px auto 0;  /* horizontally centered in its card */
  padding:5px 11px 5px 6px;background:var(--energy-soft);border-radius:999px;
  font-size:12px;font-weight:700;color:var(--energy);
}
.poi-chip .tag{background:var(--energy);color:#fff;font-size:10px;padding:2px 7px;border-radius:999px;font-weight:700;letter-spacing:.02em}
.poi-chip .walk{color:var(--ink-3);font-weight:600}
.poi-chip.nearby{background:var(--amber-soft);color:var(--amber-strong)}
.poi-chip.nearby .tag{background:var(--amber-strong)}

/* charge meter */
.charge{margin-top:13px}
.charge-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.charge-range{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:800;letter-spacing:-.01em;white-space:nowrap}
.charge-range .lo{color:var(--amber-strong)}
.charge-range .lo.low{color:var(--amber-strong)}
.charge-range .lo.neg{color:var(--red)}
.charge-range .hi{color:var(--energy)}
.charge-range .arrow{color:var(--ink-3);flex:none}
.charge-meta{font-size:12px;font-weight:600;color:var(--ink-3);white-space:nowrap}
.meter{position:relative;height:11px;border-radius:6px;background:#f0f1f4;overflow:visible;cursor:pointer}
.meter-track{position:absolute;inset:0;border-radius:6px;overflow:hidden}
.meter-base{position:absolute;left:0;top:0;height:100%;background:#cfe8da;border-radius:6px 0 0 6px}
.meter-gain{
  position:absolute;top:0;height:100%;border-radius:0 6px 6px 0;
  background:linear-gradient(90deg,var(--amber),var(--energy));
}
.meter-gain::after{
  content:"";position:absolute;inset:0;border-radius:inherit;opacity:.5;
  background-image:repeating-linear-gradient(115deg,transparent 0 6px,rgba(255,255,255,.45) 6px 8px);
}
.meter-knob{position:absolute;top:50%;width:4px;height:17px;border-radius:3px;background:#fff;box-shadow:0 0 0 1.5px rgba(16,24,40,.25);transform:translate(-2px,-50%);z-index:3;pointer-events:none}
.meter-input{
  position:absolute;inset:-16px 0;width:100%;height:43px;margin:0;opacity:0;cursor:pointer;z-index:4;
}
.meter-input:focus-visible ~ .meter-knob{box-shadow:0 0 0 3px rgba(37,99,235,.5)}

.amenities{display:flex;gap:6px;margin-top:13px}
.amenity{
  width:27px;height:27px;border-radius:8px;display:grid;place-items:center;
  background:var(--energy-soft);color:var(--energy);
}
.amenity .icon{width:15px;height:15px;stroke-width:1.8}

.stop-actions{
  display:flex;align-items:center;gap:14px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);
}
.stop-actions button{font-size:12.5px;font-weight:700;color:var(--ink-2);display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.stop-actions .icon{flex:none;width:14px;height:14px}
.stop-actions button:hover{color:var(--blue)}
.stop-actions .rm:hover{color:var(--tesla)}
.stop-actions .swap-link{margin-left:auto;color:var(--blue)}

/* ============ OPTIONS (swap / add / gap) ============ */
.opt-panel{
  margin-top:12px;border-top:1px dashed var(--line-2);padding-top:8px;
}
.leg .opt-panel{
  background:var(--card);border-radius:var(--r-md);box-shadow:var(--shadow-card);
  border-top:none;margin-top:8px;padding:10px 12px;
}
.opt-hint{font-size:11.5px;font-weight:600;color:var(--ink-3);margin:0 0 6px 2px}
.opt-row{
  display:flex;align-items:center;gap:10px;padding:9px 6px;border-radius:10px;cursor:pointer;
  border-bottom:1px solid var(--line);
}
.opt-row:last-child{border-bottom:none}
.opt-row:hover{background:var(--field)}
.opt-row:focus-visible{outline:2.5px solid var(--blue);outline-offset:-2px}
.opt-row.active{background:var(--blue-soft);box-shadow:inset 0 0 0 1.5px var(--blue)}
.opt-letter{
  flex:none;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;
  font-size:12px;font-weight:800;color:#fff;
}
.opt-main{flex:1;min-width:0}
.opt-name{font-size:13px;font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.opt-sub{font-size:11.5px;font-weight:600;color:var(--ink-3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.opt-tag{
  display:inline-block;font-size:9.5px;font-weight:700;color:#fff;border-radius:999px;
  padding:1.5px 6px;margin-right:5px;vertical-align:1px;letter-spacing:.02em;
}
.opt-use{
  flex:none;height:30px;padding:0 14px;border-radius:9px;background:var(--ink);color:#fff;
  font-size:12px;font-weight:700;transition:.15s;
}
.opt-use:hover{background:#000}

/* gap card */
.gap-card{
  border:2px dashed var(--amber);background:var(--amber-soft);border-radius:var(--r-md);
  padding:12px 14px;margin-top:8px;
}
.gap-title{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:800;color:#b45309}
.gap-title .icon{width:16px;height:16px}
.gap-sub{font-size:12px;font-weight:600;color:var(--amber-strong);margin-top:3px}
.gap-card .opt-panel{border-top-color:rgba(240,165,38,.4)}
.gap-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px}
.gap-row .add-stop{margin-left:0} /* .add-stop defaults to margin-left:auto in legs */
.gap-toggle{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--amber-strong);cursor:pointer;white-space:nowrap}
.gap-toggle input{accent-color:var(--amber-strong);width:14px;height:14px;margin:0}
.gap-card .opt-row:hover{background:rgba(255,255,255,.6)}

/* warnings */
.warn-card{
  background:var(--amber-soft);border-radius:var(--r-md);padding:11px 14px;margin:0 0 10px;
  font-size:12.5px;font-weight:600;color:#b45309;display:flex;gap:8px;align-items:flex-start;
}
.warn-card .icon{flex:none;width:15px;height:15px;margin-top:1px}

/* ============ FOOTER ACTIONS ============ */
.sidebar-actions{
  flex:none;background:var(--card);border-top:1px solid var(--line-2);
  padding:12px 16px 14px;box-shadow:0 -8px 24px -16px rgba(16,24,40,.25);
}
.quick-actions{display:flex;align-items:center;justify-content:space-around;margin-bottom:12px}
.quick-actions button{display:inline-flex;flex-direction:column;align-items:center;gap:5px;font-size:11.5px;font-weight:700;color:var(--ink-2)}
.quick-actions button .icon{width:18px;height:18px}
.quick-actions button:hover{color:var(--ink)}
.cta-row{display:flex;gap:10px}
.btn-outline{
  flex:1;height:48px;border-radius:13px;border:1.5px solid var(--line-2);background:#fff;
  font-size:14.5px;font-weight:700;color:var(--ink);display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s;
}
.btn-outline:hover{background:var(--field)}
.btn-dark{
  flex:1.5;height:48px;border-radius:13px;background:var(--ink);color:#fff;
  font-size:15px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;justify-content:center;gap:9px;
  box-shadow:0 6px 16px -6px rgba(0,0,0,.45);transition:.15s;
}
.btn-dark:hover{background:#000;transform:translateY(-1px)}
.btn-dark .icon{width:18px;height:18px;stroke-width:2.2}

/* ============ MAP ============ */
.map-wrap{flex:1;position:relative}
#map{position:absolute;inset:0;background:#dfe6e1;z-index:1}
.leaflet-container{font-family:inherit;background:#e6eae8}
.map-ctrl{
  position:absolute;left:14px;top:14px;z-index:500;display:flex;flex-direction:column;
  background:#fff;border-radius:11px;box-shadow:var(--shadow-card);overflow:hidden;
}
.map-ctrl button{width:38px;height:38px;display:grid;place-items:center;color:var(--ink);font-size:18px;font-weight:600}
.map-ctrl button:first-child{border-bottom:1px solid var(--line)}
.map-ctrl button:hover{background:var(--field)}
/* basemap thumbnail switcher (replaces the layers menu) */
.switcher{
  position:absolute;right:14px;top:14px;z-index:600;display:flex;gap:8px;
  background:#fff;border-radius:15px;padding:8px;box-shadow:var(--shadow-card);
}
.bswatch{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0}
.bswatch:focus-visible{outline:2.5px solid var(--blue);outline-offset:2px;border-radius:12px}
.sw-img{
  width:64px;height:48px;border-radius:10px;border:2px solid transparent;overflow:hidden;
  position:relative;transition:.14s;box-shadow:inset 0 0 0 1px rgba(16,24,40,.06);display:block;
}
.bswatch:hover .sw-img{border-color:var(--line-2)}
.bswatch.on .sw-img{border-color:var(--blue);box-shadow:0 0 0 2px rgba(37,99,235,.2)}
.sw-voyager{background:linear-gradient(135deg,#eef1ee,#e3ebe2)}
.sw-voyager::after{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,transparent 47%,#e9b84d 47%,#e9b84d 52%,transparent 52%),linear-gradient(0deg,transparent 58%,#cfdfe6 58%,#cfdfe6 63%,transparent 63%)}
.sw-osm{background:#f0e9dd}
.sw-osm::after{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,transparent 38%,#d8c4a0 38%,#d8c4a0 43%,transparent 43%),linear-gradient(50deg,transparent 54%,#bcd0a8 54%,#bcd0a8 60%,transparent 60%)}
.sw-sat{background:linear-gradient(135deg,#3c4a39,#56603f)}
.sw-sat::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 40%,#6b7a4a 0 13px,transparent 14px),radial-gradient(circle at 70% 66%,#48543a 0 17px,transparent 18px);opacity:.85}
.sw-lbl{font-size:11px;font-weight:700;color:var(--ink-3);white-space:nowrap}
.bswatch.on .sw-lbl{color:var(--ink)}
.legend{
  position:absolute;left:14px;bottom:24px;z-index:500;background:#fff;border-radius:var(--r-md);
  box-shadow:var(--shadow-card);padding:13px 15px;min-width:208px;
}
.legend-title{font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-3);margin-bottom:9px}
.legend-div{height:1px;background:var(--line);margin:9px 0}
.legend-toggle{display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;padding:2px 0}
.mini-toggle{
  width:36px;height:21px;border-radius:999px;background:#d7dbe1;position:relative;
  flex:none;margin-left:auto;transition:.18s;cursor:pointer;padding:0;
}
.mini-toggle .k{
  position:absolute;top:2.5px;left:2.5px;width:16px;height:16px;border-radius:50%;
  background:#fff;box-shadow:0 1px 2px rgba(16,24,40,.3);transition:.18s;display:block;
}
.mini-toggle.on{background:var(--energy)}
.mini-toggle.on .k{transform:translateX(15px)}
.mini-toggle:focus-visible{outline:2.5px solid var(--blue);outline-offset:2px}
.legend-row{display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;color:var(--ink);padding:3px 0;white-space:nowrap}
.legend-row .swatch{width:11px;height:11px;border-radius:50%;flex:none;box-shadow:0 0 0 2px #fff}
.legend-row .swatch.sm{width:8px;height:8px}
.attribution{position:absolute;right:8px;bottom:6px;z-index:500;font-size:10px;color:#8a909c;background:rgba(255,255,255,.8);padding:2px 7px;border-radius:6px}

/* leaflet marker styling */
.mk{display:grid;place-items:center;font-weight:800;color:#fff;border-radius:50%;box-shadow:0 2px 6px rgba(16,24,40,.35),0 0 0 3px #fff}
.mk.num{width:30px;height:30px;font-size:14px;background:var(--blue)}
.mk.num.g{background:var(--energy)}
.mk.num.y{background:var(--amber-strong)}
.mk.end{width:18px;height:18px;background:#fff;border:3px solid var(--ink);box-shadow:0 2px 5px rgba(16,24,40,.3)}
.mk.end.finish{background:var(--ink)}
.mk.dot{width:13px;height:13px;border-radius:50%;box-shadow:0 1px 3px rgba(16,24,40,.4),0 0 0 2px #fff}
.mk.poi{width:15px;height:15px;border-radius:50%;box-shadow:0 1px 3px rgba(16,24,40,.4),0 0 0 2px #fff}
.mk.letter{
  width:26px;height:26px;border-radius:8px;font-size:13px;
  border:2.5px dashed #fff;box-shadow:0 2px 6px rgba(16,24,40,.4);
}
.leaflet-popup-content-wrapper{border-radius:var(--r-md);box-shadow:var(--shadow-pop);font-family:inherit}
.leaflet-popup-content{margin:13px 16px;font-size:12.5px;line-height:1.5}
/* ===== polished map popups (zip JB3Z3Z mockup) ===== */
/* padding:1px (not 0) - zero lets the content's margins collapse through the
   wrapper, so the card renders with NO visible inner padding */
.leaflet-popup-content-wrapper{border-radius:16px;box-shadow:var(--shadow-pop);padding:1px}
.leaflet-popup-content{margin:12px 13px;width:272px !important;font-family:inherit}
.leaflet-popup-tip-container{display:none}
.leaflet-popup-content-wrapper{position:relative}
.leaflet-popup-content-wrapper::after{
  content:"";position:absolute;left:50%;bottom:-8px;width:16px;height:16px;background:var(--card);
  transform:translateX(-50%) rotate(45deg);border-radius:0 0 4px 0;
  box-shadow:5px 5px 12px -4px rgba(16,24,40,.18);
}
.leaflet-container a.leaflet-popup-close-button{
  top:9px;right:9px;width:22px;height:22px;border-radius:7px;color:var(--ink-3);
  font:400 16px/22px "Hanken Grotesk",sans-serif;text-align:center;padding:0;
}
.leaflet-container a.leaflet-popup-close-button:hover{background:var(--field);color:var(--ink)}
.popup .pop-top{display:flex;align-items:center;gap:7px;margin-bottom:9px;padding-right:26px}
.popup .power{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:800;letter-spacing:-.02em;white-space:nowrap;color:var(--ink)}
.popup .pop-top .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-3);flex:none}
.popup .cnt{font-size:12.5px;font-weight:600;color:var(--ink-3);white-space:nowrap}
.popup .net-tag{
  margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;
  color:var(--ink-2);background:var(--field);padding:3px 8px;border-radius:999px;
  white-space:nowrap;min-width:0;flex:0 1 auto;
}
.popup .net-tag .nt-name{display:block;max-width:84px;overflow:hidden;text-overflow:ellipsis}
.popup .pop-brand{display:flex;align-items:center;gap:10px}
.popup .pop-brand .brand-badge{width:27px;height:27px;border-radius:8px;font-size:13px}
.popup .brand-badge.tesla-badge{background:#e3242b}
.popup .pop-brand>div{min-width:0;flex:1}
.popup .pop-name{font-size:14.5px;font-weight:700;letter-spacing:-.015em;line-height:1.22;color:var(--ink)}
.popup .pop-addr{font-size:12px;font-weight:600;color:var(--ink-3);margin-top:2px}
.popup .poi-chip{display:flex;width:fit-content;margin:9px auto 0}
.popup .meta-row{display:flex;align-items:center;gap:8px;margin-top:11px}
.popup .meta-row .amenities{margin:0;display:flex;gap:5px}
.popup .maps-link{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;color:var(--blue);text-decoration:none}
.popup .maps-link .icon{width:14px;height:14px}
.popup .maps-link:hover{text-decoration:underline}

/* ============ DROPDOWNS, MENUS, PANELS ============ */
.dropdown{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:1400;
  background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-pop);
  overflow:hidden;display:none;
}
.dropdown.open{display:block}
.dropdown div{
  display:flex;align-items:center;min-height:44px;padding:8px 14px;cursor:pointer;
  font-size:13px;font-weight:600;color:var(--ink-2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.dropdown div:hover,.dropdown div.active{background:var(--blue-soft);color:var(--ink)}

.menu-wrap{position:relative}
.menu{
  position:absolute;top:calc(100% + 8px);right:0;z-index:1400;min-width:230px;
  background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-pop);padding:6px;
}
.menu[hidden]{display:none}
.menu>button{
  display:flex;align-items:center;gap:10px;width:100%;min-height:42px;padding:0 12px;
  border-radius:9px;font-size:13.5px;font-weight:600;color:var(--ink);text-align:left;
}
.menu>button:hover{background:var(--field)}
.menu>button .tick{margin-left:auto;color:var(--blue);visibility:hidden}
.menu>button[aria-pressed="true"] .tick{visibility:visible}
.menu>button[aria-pressed="true"]{background:var(--blue-soft)}
.mini-badge{
  width:20px;height:20px;border-radius:6px;display:grid;place-items:center;flex:none;
  font-size:9.5px;font-weight:800;color:#fff;letter-spacing:-.02em;
}
.mini-badge.tesla{background:var(--tesla)}

.settings-panel{padding:12px;min-width:250px}
.settings-title{font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-3);margin:2px 4px 8px}
.settings-panel label{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:13.5px;font-weight:600;color:var(--ink);padding:5px 4px;
}
.set-field{display:flex;align-items:center;gap:6px;background:var(--field);border-radius:9px;padding:0 10px 0 0}
.set-field input{
  width:64px;height:34px;border:none;background:none;outline:none;text-align:right;
  font-size:14px;font-weight:700;color:var(--ink);padding:0 2px 0 10px;
}
.set-field i{font-style:normal;font-size:12px;font-weight:600;color:var(--ink-3)}
.set-field:focus-within{box-shadow:0 0 0 2.5px rgba(37,99,235,.25)}
.eff-line{font-size:11.5px;font-weight:600;color:var(--ink-3);padding:2px 4px 0;text-align:right}

.filter-panel{padding:12px;min-width:230px}

/* ============ CAR PANEL (right slide-out) ============ */
.car-panel{
  flex:none;width:0;overflow:hidden;visibility:hidden;
  background:var(--bg);border-left:0 solid var(--line-2);
  display:flex;flex-direction:column;
  transition:width .28s cubic-bezier(.2,.8,.2,1),visibility 0s .3s;
}
.car-panel.open{
  width:396px;visibility:visible;border-left-width:1px;
  box-shadow:-14px 0 36px -20px rgba(16,24,40,.35);
  transition:width .28s cubic-bezier(.2,.8,.2,1),visibility 0s 0s;
}
.car-panel>*{width:396px;margin-left:auto}
.car-head{
  display:flex;align-items:center;gap:11px;padding:13px 16px;flex:none;
  background:var(--card);border-bottom:1px solid var(--line-2);
}
.car-title{min-width:0}
.car-title .car-name{font-weight:800;font-size:16px;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.car-head .icon-btn{margin-left:auto;flex:none}
.car-scroll{flex:1;overflow-y:auto;padding:14px}
.car-scroll::-webkit-scrollbar{width:9px}
.car-scroll::-webkit-scrollbar-thumb{background:#d3d7de;border-radius:9px;border:2px solid var(--bg)}
.car-card{padding:16px;margin-bottom:12px}
.car-card label{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:13.5px;font-weight:600;color:var(--ink);padding:5px 0;
}
.charge-now{display:flex;align-items:center;gap:13px;margin:6px 0 10px}
.batt.big .batt-glyph{width:48px;height:23px;border-width:2.5px;border-radius:5px;padding:3px}
.batt.big .batt-glyph::after{right:-5.5px;top:5.5px;width:3px;height:9px}
.soc-now{font-size:27px;font-weight:800;letter-spacing:-.02em}
.soc-slider{width:100%;accent-color:var(--energy);height:34px;cursor:pointer;margin:0;display:block}
.car-hero{margin-bottom:13px;padding-bottom:13px;border-bottom:1px solid var(--line)}
.car-hero-top{display:flex;align-items:center;gap:9px}
.car-hero-name{font-size:16.5px;font-weight:800;letter-spacing:-.02em;flex:1;min-width:0;line-height:1.25}
.car-stats.stat-row{margin-top:11px;gap:7px 16px}
.car-search{margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed var(--line-2)}
.car-fields{padding-top:2px}
.field-hint{text-align:right;font-size:11px;padding:1px 4px 0}
.car-actions{display:flex;gap:18px;margin-top:12px;padding-top:11px;border-top:1px solid var(--line)}
.car-actions[hidden]{display:none} /* class display beats the hidden attr */
.car-action{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.car-action[hidden]{display:none} /* class display beats the hidden attr otherwise */
.car-action:hover{color:var(--blue)}
.car-action .icon{flex:none}
#change-car{margin-left:auto;color:var(--blue)}
.car-sel{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:5px 0}
.car-sel>label{font-size:13.5px;font-weight:600;color:var(--ink);flex:none}
.car-field{
  position:relative;flex:1;max-width:246px;display:flex;align-items:center;
  background:var(--field);border-radius:10px;border:1px solid transparent;transition:.15s;
}
.car-field:focus-within{background:#fff;border-color:var(--line-2);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.car-field input{
  flex:1;min-width:0;height:38px;border:none;background:none;outline:none;
  font:inherit;font-size:13.5px;font-weight:600;color:var(--ink);padding:0 4px 0 12px;
}
.car-field input::placeholder{color:var(--ink-3);font-weight:500}
.car-field input:disabled{cursor:default}
.car-field:has(input:disabled){opacity:.45}
.car-field .chev{flex:none;color:var(--ink-3);margin-right:9px;pointer-events:none}
.car-dd{max-height:264px;overflow-y:auto;z-index:1450}
.car-dd div{min-height:38px;font-size:13px}
.car-dd .no-match{color:var(--ink-3);cursor:default}
.car-dd .no-match:hover{background:none;color:var(--ink-3)}
.car-omni{max-width:none;width:100%}
.car-omni .search-ic{flex:none;color:var(--ink-3);margin-left:12px}
.car-omni input{padding-left:8px}
.car-dd [role=option]{display:flex;align-items:center;justify-content:space-between;gap:10px}
.car-res-name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.car-res-sub{flex:none;font-size:11.5px;font-weight:600;color:var(--ink-3)}
.car-dd [role=option].active .car-res-sub,.car-dd [role=option]:hover .car-res-sub{color:inherit}

.trim-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 8px;border-radius:10px;cursor:pointer;border-bottom:1px solid var(--line);font-size:12.5px;font-weight:600;
}
.trim-row:last-child{border-bottom:none}
.trim-row:hover{background:var(--field)}
.trim-row span:first-child{min-width:0}
.trim-row:focus-visible{outline:2.5px solid var(--blue);outline-offset:-2px}
#car-trims{margin-top:8px}
.alt-tabs.flash{animation:tabflash 1s ease 2}
@keyframes tabflash{50%{box-shadow:0 0 0 3px rgba(37,99,235,.4);border-radius:13px}}
.area-search{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:600;
  height:38px;padding:0 18px;border-radius:999px;background:var(--ink);color:#fff;
  font-size:13px;font-weight:700;box-shadow:var(--shadow-pop);
}
.area-search:hover{background:#000}

/* info tooltip */
.lbl-wrap{display:inline-flex;align-items:center;gap:6px}
.info-tip{
  width:15px;height:15px;border-radius:50%;display:inline-grid;place-items:center;
  background:var(--field);color:var(--ink-3);font-size:10px;font-weight:800;font-style:normal;
  cursor:help;position:relative;border:1px solid var(--line-2);
}
.info-tip:hover,.info-tip:focus-visible{color:var(--blue);border-color:var(--blue)}
.info-tip::after{
  content:attr(data-tip);position:fixed;z-index:2000;
  left:var(--tip-x,-9999px);top:var(--tip-y,auto);bottom:var(--tip-up,auto);
  width:230px;background:var(--ink);color:#fff;border-radius:10px;padding:9px 11px;
  font-size:11.5px;font-weight:500;line-height:1.45;text-align:left;
  white-space:normal;box-shadow:var(--shadow-pop);opacity:0;pointer-events:none;transform:translateY(3px);
  transition:.15s;
}
.info-tip:hover::after,.info-tip:focus-visible::after{opacity:1;transform:none}
.epa-tag{
  font-size:9.5px;background:var(--blue-soft);color:var(--blue);
  padding:2px 7px;border-radius:999px;margin-left:6px;letter-spacing:.03em;vertical-align:1px;
}
.car-preview{margin-top:8px;min-height:18px;font-weight:600}
.car-preview b{color:var(--ink)}
.car-apply{width:100%;margin-top:10px;height:42px;flex:none}
.car-apply:disabled{opacity:.45;cursor:default;transform:none;box-shadow:none}
@media (max-width:980px){
  /* compact vertical basemap stack: clears the center pills */
  .switcher{flex-direction:column;gap:6px;padding:6px;border-radius:13px;right:10px;top:10px}
  .sw-img{width:48px;height:36px;border-radius:8px}
  .sw-lbl{font-size:9.5px}
  .car-panel{
    position:fixed;top:0;right:0;bottom:0;width:100%;max-width:420px;z-index:1500;
    visibility:visible;overflow:visible;border-left:1px solid var(--line-2);
    box-shadow:-14px 0 36px -20px rgba(16,24,40,.35);
    transform:translateX(103%);transition:transform .28s cubic-bezier(.2,.8,.2,1);
  }
  .car-panel.open{transform:none;width:100%}
  .car-panel>*{width:auto;margin-left:0}
}

/* ============ EMPTY / LOADING / TOAST ============ */
.empty-state{padding:26px 22px;text-align:center}
.empty-icon{
  width:46px;height:46px;border-radius:14px;background:var(--blue-soft);color:var(--blue);
  display:grid;place-items:center;margin:0 auto 14px;
}
.empty-icon .icon{width:24px;height:24px}
.empty-title{font-size:16.5px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.empty-sub{font-size:13px;font-weight:500;color:var(--ink-2);line-height:1.55}
.sbux-t{color:var(--sbux)}
.cfa-t{color:var(--cfa)}

.loading{padding:42px 20px;text-align:center;color:var(--ink-3);font-size:13px;font-weight:600}
.spinner{
  width:34px;height:34px;margin:0 auto 14px;border-radius:50%;
  border:4px solid var(--line-2);border-top-color:var(--blue);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

#toast{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:11px 20px;border-radius:12px;
  box-shadow:var(--shadow-pop);z-index:3000;font-size:13.5px;font-weight:600;
  max-width:88vw;cursor:pointer;
}
#toast.error{background:var(--red)}

/* ============ RESPONSIVE ============ */
@media (max-width:1180px){
  .sidebar{width:400px}
}
@media (max-width:980px){
  .topbar{height:auto;flex-wrap:wrap;padding:10px 14px;gap:10px}
  .route-fields{order:3;flex-basis:100%;max-width:none}
  .app{height:auto;flex-direction:column}
  /* browse mode: the map owns the screen; it cedes room once a plan exists.
     Height animates; setHasPlan() re-measures Leaflet after it settles. */
  /* /0.82 compensates the laptop-zoom vh shrink (see CLAUDE.md UI sizing) */
  .map-wrap{order:-1;height:calc(86vh/0.82);flex:none;transition:height .28s cubic-bezier(.2,.8,.2,1)}
  body.has-plan .map-wrap{height:calc(59vh/0.82)}
  /* touch targets: phones render at .82 zoom so desktop dots are ~11px real.
     scale(2) about center keeps markers anchored (iconAnchor math unchanged)
     and grows the tap area with the visual; hierarchy is preserved since
     every tier scales by the same factor. */
  .mk.dot,.mk.poi,.mk.ring{transform:scale(2)}
  /* numbered/lettered markers end up just SLIGHTLY larger than the dots
     (33/32.5px vs 26px layout) instead of dominating the map */
  .mk.num{transform:scale(1.1)}
  .mk.letter{transform:scale(1.25)}
  .mk.end{transform:scale(1.5)}
  .sidebar{width:100%;border-right:none;border-top:1px solid var(--line-2)}
  .sidebar-scroll{max-height:none}
  .field input,.set-field input{font-size:16px} /* prevent iOS focus zoom */
  /* legend collapses to a tappable badge; expanding it also surfaces the
     layer toggles on phones */
  .legend{display:none}
  .legend.open{display:block;left:10px;bottom:62px;max-width:80vw}
  .legend-badge{
    position:absolute;left:10px;bottom:10px;z-index:610;display:grid;place-items:center;
    width:42px;height:42px;border-radius:50%;background:#fff;box-shadow:var(--shadow-card);
  }
  .opt-use{height:42px}
  .stop-actions button,.add-stop,.reset{min-height:44px}
}
.popup-add{
  display:flex;align-items:center;justify-content:center;gap:7px;width:100%;margin-top:10px;height:38px;
  border-radius:11px;background:var(--energy);color:#fff;font-size:13.5px;font-weight:700;
  box-shadow:0 5px 14px -6px rgba(31,157,87,.6);transition:.15s;
}
.popup-add:hover{filter:brightness(1.05)}
.popup-add.popup-rm{background:#fff;border:1.5px solid var(--line-2);color:var(--ink-2);box-shadow:none}
.popup-add.popup-rm:hover{border-color:#e3242b;color:#e3242b;background:#fdf3f3}

/* ===== consolidated vehicle spec card ===== */
.vc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.vc-head-text{min-width:0}
.vc-title{font-size:18px;font-weight:800;letter-spacing:-.025em;line-height:1.15}
.vc-sub{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-top:2px}
.epa-badge{flex:none;font-size:11.5px;font-weight:700;color:var(--blue);background:var(--blue-soft);padding:5px 11px;border-radius:999px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px}
.spec{position:relative;background:var(--field);border:1px solid transparent;border-radius:13px;padding:11px 11px 10px;transition:.15s;cursor:text}
.spec:focus-within{background:#fff;border-color:var(--line-2,#e0e3e8);box-shadow:0 0 0 3px rgba(37,99,235,.13)}
.spec-lbl{display:flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-bottom:7px}
.spec-lbl .icon{width:13px;height:13px;stroke-width:2;flex:none}
.spec-val{display:flex;align-items:baseline;gap:3px}
.spec-val input{border:none;background:none;outline:none;width:100%;min-width:0;padding:0;font-size:19px;font-weight:800;letter-spacing:-.03em;color:var(--ink)}
.spec-val input::-webkit-outer-spin-button,.spec-val input::-webkit-inner-spin-button{-webkit-appearance:none}
.spec-val input[type=number]{-moz-appearance:textfield}
.spec-unit{font-size:11.5px;font-weight:700;color:var(--ink-3);flex:none}
.spec .info-tip{position:absolute;top:7px;right:7px}
.vc-div{height:1px;background:var(--line);margin:14px 0 12px}
.eff-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.eff-l{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700;letter-spacing:-.01em}
.eff-pct{font-size:16px;font-weight:800;letter-spacing:-.02em}
.eff-slider{-webkit-appearance:none;appearance:none;width:100%;height:7px;border-radius:6px;outline:none;
  background:linear-gradient(90deg,var(--energy) 0 var(--p,80%),#e3e6ea var(--p,80%) 100%)}
.eff-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:grab;
  box-shadow:0 1px 4px rgba(16,24,40,.32),0 0 0 1.5px var(--energy) inset}
.eff-slider::-moz-range-thumb{width:20px;height:20px;border:none;border-radius:50%;background:#fff;cursor:grab;
  box-shadow:0 1px 4px rgba(16,24,40,.32),0 0 0 1.5px var(--energy) inset}
.eff-note{font-size:12px;font-weight:600;color:var(--ink-3);margin-top:9px;text-align:center}
.vc-foot{display:flex;justify-content:flex-end;gap:14px;margin-top:13px;padding-top:12px;border-top:1px solid var(--line)}
.vc-foot[hidden]{display:none}
.filters-title{display:flex;align-items:center;justify-content:space-between}
.filters-title .sub{font-weight:700}
.sub-title{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin:10px 0 4px}
.sub-title .info-tip{text-transform:none;letter-spacing:0}
/* .car-card label is flex/space-between for pref rows - undo for specs + filter rows */
.car-card label.spec{display:block;padding:11px 11px 10px}

/* ===== Option B filter chips (in slideout) ===== */
.filters-card .sub-title{margin:12px 0 7px}
.filters-card .sub-title:first-of-type{margin-top:4px}
.speed-row{display:flex;gap:8px}
.speed{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;height:42px;border-radius:12px;
  background:var(--field);border:1.5px solid transparent;font-size:13.5px;font-weight:700;color:var(--ink-3);
  transition:.14s;cursor:pointer;white-space:nowrap;
}
.speed .icon{fill:var(--ink-3);stroke:none}
.speed input{position:absolute;opacity:0;width:0;height:0}
.speed:has(input:checked){background:var(--energy-soft,#e7f5ec);border-color:var(--energy);color:var(--energy)}
.speed:has(input:checked) .icon{fill:var(--energy)}
.chip-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.chip{
  display:flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 8px;border-radius:12px;
  background:var(--field);border:1.5px solid transparent;font-size:12.5px;font-weight:700;color:var(--ink-3);
  transition:.14s;cursor:pointer;min-width:0;
}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip .chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.chip:has(input:checked){background:var(--energy-soft,#e7f5ec);border-color:var(--energy);color:var(--ink)}
.chip .mini-badge{width:20px;height:20px;font-size:9.5px;flex:none}
.net-row{display:flex;align-items:center;gap:10px;height:46px;cursor:pointer;padding:0;justify-content:flex-start}
.net-text{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.net-name{font-size:14px;font-weight:700;color:var(--ink)}
.net-desc{font-size:11.5px;font-weight:600;color:var(--ink-3)}
.net-row input{position:absolute;opacity:0;width:0;height:0}
.net-row .switch{margin-left:auto;flex:none;width:44px;height:26px;border-radius:999px;background:#d7dbe1;position:relative;transition:.18s}
.net-row .switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(16,24,40,.3);transition:.18s}
.net-row:has(input:checked) .switch{background:var(--energy)}
.net-row:has(input:checked) .switch::after{transform:translateX(18px)}
/* override .car-card label space-between for the chip/speed/net controls */
.car-card label.speed{justify-content:center}
.car-card label.chip{justify-content:center}
.car-card label.net-row{justify-content:flex-start;gap:10px}
.co-row{margin-top:6px}
.co-row .net-name{font-size:13.5px}

/* Laptop scaling: the layout is sized for an ultrawide; below that, scale the
   whole shell down (mirrors a manual ~90% browser zoom). Ultrawide untouched. */
@media (max-width: 1536px) {
  body { zoom: 0.9; }
  .app { height: calc(100vh / 0.9 - 64px); }   /* zoom shrinks vh too - compensate so it still fills */
}
@media (max-width: 1200px) {
  body { zoom: 0.82; }
  .app { height: calc(100vh / 0.82 - 64px); }
}

/* Leaflet hover tooltips (Start/Destination, chain POIs) - match the design */
.leaflet-tooltip{
  font-family:inherit;font-size:12px;font-weight:700;color:var(--ink);
  background:var(--card);border:none;border-radius:8px;padding:6px 11px;
  box-shadow:0 2px 6px rgba(16,24,40,.16),0 10px 26px -12px rgba(16,24,40,.32);
}
.leaflet-tooltip-top::before{border-top-color:var(--card)}
.leaflet-tooltip-bottom::before{border-bottom-color:var(--card)}
.leaflet-tooltip-left::before{border-left-color:var(--card)}
.leaflet-tooltip-right::before{border-right-color:var(--card)}

/* ===== summary card: B (compact) on big screens, C (dense) on laptops ===== */
.card.summary{padding:0}
.sum-a{padding:18px 18px 15px}
.sum-b{display:none;padding:16px 17px 14px}
.a-top{display:flex;align-items:flex-start;justify-content:space-between}
.a-time{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1}
.a-sub{font-size:13px;font-weight:600;color:var(--ink-3);margin-top:6px;white-space:nowrap}
.a-strip{display:grid;grid-template-columns:repeat(4,1fr);margin-top:16px;padding-top:15px;border-top:1px solid var(--line)}
.a-cell{display:flex;flex-direction:column;gap:3px;padding:0 12px}
.a-cell:first-child{padding-left:0}
.a-cell + .a-cell{border-left:1px solid var(--line)}
.a-cell .v{font-size:16px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}
.a-cell .k{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}
.a-foot{margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.a-foot:empty,.a-foot .reset-slot:empty{display:none}
.badge-rec.sm{font-size:11px;padding:3px 9px}
.b-top{display:flex;align-items:center;gap:10px}
.b-time{font-size:25px;font-weight:800;letter-spacing:-.03em;line-height:1;white-space:nowrap}
.b-arrival{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-left:auto;white-space:nowrap}
.b-sub{font-size:12.5px;font-weight:600;color:var(--ink-3);margin-top:5px}
.b-stats{display:flex;align-items:center;flex-wrap:wrap;gap:6px 0;margin-top:13px;padding-top:13px;border-top:1px solid var(--line)}
.b-stat{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;white-space:nowrap}
.b-stat .icon{color:var(--ink-3);width:15px;height:15px;flex:none}
.b-stat .lbl{color:var(--ink-3);font-weight:600}
.b-sep{width:1px;height:13px;background:var(--line-2);margin:0 13px}
.b-foot{display:flex;align-items:center;justify-content:space-between;margin-top:13px;padding-top:12px;border-top:1px solid var(--line)}
.c-top{display:flex;align-items:center;gap:9px}
.c-time{font-size:21px;font-weight:800;letter-spacing:-.025em;line-height:1;white-space:nowrap}
.c-dot{width:3px;height:3px;border-radius:50%;background:var(--ink-3);flex:none}
.c-arrival{font-size:13px;font-weight:600;color:var(--ink-2);white-space:nowrap}
.c-top .badge-rec{margin-left:auto}
.c-stats{display:flex;align-items:center;gap:14px;margin-top:11px;flex-wrap:wrap}
.c-stat{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;white-space:nowrap}
.c-stat .icon{color:var(--ink-3);width:15px;height:15px;flex:none}
.c-stat .lbl{color:var(--ink-3);font-weight:600}
.c-stats .reset-slot{margin-left:auto}
.reset-slot{display:inline-flex}
@media (max-width: 1536px) {
  .sum-a{display:none}
  .sum-b{display:block}
}


/* ===== gap alert card (zip 1PSxQ5 mockup) ===== */
:root{--amber-ink:#9a5a16;--amber-bg:#fdf3e2;--amber-line:#f0cd92;--amber-detail:#bd8546}
.gap-card{background:var(--amber-bg);border:1.5px solid var(--amber-line);border-radius:16px;padding:15px 16px}
.alert-head{display:flex;align-items:center;gap:9px}
.alert-head .icon{color:var(--amber);width:19px;height:19px;flex:none;stroke-width:2.1}
.alert-title{font-size:15.5px;font-weight:800;color:var(--amber-ink);letter-spacing:-.02em;white-space:nowrap}
.alert-body{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-top:9px}
.ab-lead{font-size:14px;font-weight:700;color:#b07327;letter-spacing:-.005em;white-space:nowrap}
.ab-lead .pct{color:#d92d20;font-weight:800}
.ab-lead .pct.ok{color:var(--energy)}
.ab-detail{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--amber-detail);white-space:nowrap}
.ab-detail .d{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.5;flex:none}
.resolve{
  margin-top:13px;width:100%;height:42px;border-radius:11px;background:#fff;border:1.5px solid var(--amber-line);white-space:nowrap;
  display:flex;align-items:center;gap:10px;padding:0 14px;font-size:13.5px;font-weight:700;color:var(--amber-ink);transition:.15s;
}
.resolve:hover{background:#fffaf1}
.resolve .icon{width:16px;height:16px;flex:none;color:var(--amber)}
.resolve .count{margin-left:auto;font-weight:600;color:var(--ink-3);white-space:nowrap}
.resolve .chev{width:15px;height:15px;color:var(--ink-3);transition:.2s}
.resolve.open .chev{transform:rotate(180deg)}
.gap-list{margin-top:11px;background:#fff;border:1px solid var(--line);border-radius:13px;overflow:visible;padding:0}
.gap-list[hidden]{display:none}
.list-head{display:flex;align-items:center;gap:8px;padding:11px 12px 10px}
.seg{display:flex;background:var(--field);border-radius:9px;padding:3px}
.seg button{height:27px;padding:0 11px;border-radius:7px;font-size:12px;font-weight:700;color:var(--ink-3);display:flex;align-items:center;gap:5px;white-space:nowrap}
.seg button .n{font-weight:600;opacity:.7}
.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(16,24,40,.14)}
.list-head .info-tip{margin-left:auto}
.list-head .info-tip:hover::after,.list-head .info-tip:focus-visible::after{transform:none}
.drow{display:flex;align-items:center;gap:11px;padding:11px 12px;border-top:1px solid var(--line);cursor:pointer}
.drow:hover{background:var(--field)}
.drow:focus-visible{outline:2.5px solid var(--blue);outline-offset:-2px}
.drow-empty{padding:14px 12px;border-top:1px solid var(--line);font-size:12.5px;font-weight:600;color:var(--ink-3);text-align:center}
.cmark{width:30px;height:30px;flex:none;border-radius:9px;display:grid;place-items:center;color:#fff;font-size:14px;font-weight:800}
.cmark.g{background:var(--energy)}.cmark.b{background:var(--blue)}
.cmid{min-width:0;flex:1}
.dname{display:flex;align-items:center;gap:7px;min-width:0}
.dname .t{font-size:13.5px;font-weight:700;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.dnet{width:19px;height:19px;flex:none;border-radius:6px;display:grid;place-items:center;color:#fff;font-size:10px;font-weight:800}
.dnet .icon{width:13px;height:13px;color:#fff}
.dnet.tesla{background:#e3242b}
.brand-logo{width:23px;height:23px;flex:none;border-radius:6px;background:#fff;display:grid;place-items:center;overflow:hidden}
.brand-logo img{width:100%;height:100%;object-fit:contain;display:block}
.brand-logo .mini-badge{width:19px;height:19px;font-size:9px}
.samelot{font-size:9.5px;font-weight:700;color:#fff;background:var(--energy);padding:2px 6px;border-radius:999px;white-space:nowrap;flex:none}
.dmeta{display:flex;align-items:center;gap:11px;margin-top:6px}
.dstat{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;color:var(--ink-2);white-space:nowrap}
.dstat .icon{width:13px;height:13px;flex:none;color:var(--ink-3)}
.dstat.power{color:var(--energy)}
.dstat.power .icon{color:var(--energy);fill:var(--energy);stroke:var(--energy)}
.dstat.arr-good{color:var(--energy)}.dstat.arr-good .icon{color:var(--energy)}
.dstat.arr-low{color:var(--amber)}.dstat.arr-low .icon{color:var(--amber)}
.cadd{flex:none;height:34px;padding:0 16px;border-radius:10px;background:var(--ink);color:#fff;font-size:13px;font-weight:700;transition:.15s}
.cadd:hover{background:#000;transform:translateY(-1px)}
.list-more{padding:9px 12px;text-align:center;font-size:12.5px;font-weight:700;color:var(--blue);border-top:1px solid var(--line);white-space:nowrap;width:100%}
.list-more:hover{background:var(--field)}
/* gap-list rows reuse the option-row hover/active visuals; neutralize the old
   opt-panel/opt-row metrics inside the new list */
.opt-panel.gap-list{padding:0 6px 6px;border-top:none;margin-top:11px}
.gap-card .gap-list .opt-row:hover{background:var(--field)}
.amenity.txt{font-size:9px;font-weight:800;letter-spacing:.02em}
.pop-top .maps-link{margin-left:auto;flex:none}
.pop-top .net-tag ~ .maps-link{margin-left:7px}

/* unified option rows: drow icons at the old list's density - compact,
   rounded, old hover/active colors, light separators */
.drow{padding:7px 8px;border-radius:10px;border-top:none;border-bottom:1px solid var(--line);margin:0}
.drow:last-of-type{border-bottom:none}
.drow:hover{background:var(--field)}
.drow.active{background:var(--blue-soft);box-shadow:inset 0 0 0 1.5px var(--blue)}
.drow .cmark{width:24px;height:24px;border-radius:7px;font-size:12px}
.drow .dname .t{font-size:13px}
.drow .dnet{width:17px;height:17px}
.drow .brand-logo{width:20px;height:20px}
.drow .dmeta{margin-top:3px;gap:9px}
.drow .cadd{height:28px;padding:0 12px;border-radius:8px;font-size:12px}
.gap-list .list-head{padding:9px 6px 7px}
/* poi chips centered in stop cards (popups already center theirs) */
.stop .poi-chip{display:flex;width:fit-content;margin-left:auto;margin-right:auto}
.car-btn-labeled{
  display:flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:12px;
  background:var(--field);border:1px solid var(--line-2,#e0e3e8);font-size:13.5px;font-weight:700;color:var(--ink);
  transition:.15s;white-space:nowrap;
}
.car-btn-labeled:hover{background:#eceef2}
.car-btn-labeled .icon{width:18px;height:18px}
/* hovering a lettered row highlights its marker */
.mk{transition:transform .12s, box-shadow .12s}
.leaflet-marker-icon.hl .mk{transform:scale(1.3);box-shadow:0 0 0 3px #fff,0 0 0 5.5px var(--blue),0 4px 12px rgba(16,24,40,.45)}
/* clear-x morphs into a subtle spinner while geocoding */
.field.is-loading .field-clear{display:grid !important}
.field.is-loading .field-clear .icon{display:none}
.field.is-loading .field-clear::after{
  content:"";width:13px;height:13px;border-radius:50%;
  border:2px solid var(--line-2);border-top-color:var(--ink-3);
  animation:fc-spin .7s linear infinite;
}
@keyframes fc-spin{to{transform:rotate(360deg)}}
.legend-row.dim,.legend-brand.dim{opacity:.35}
.legend-brands{display:flex;flex-wrap:wrap;gap:4px 10px}
.legend-brand{display:inline-flex;align-items:center;gap:5px}
.line-swatch{width:14px;height:4px;border-radius:2px;flex:none;display:inline-block}

/* ===== vias: off-route rings, preview bar, stop badge ===== */
.mk.ring{width:13px;height:13px;border-radius:50%;opacity:.88;box-shadow:0 1px 3px rgba(16,24,40,.3),0 0 0 1.5px #fff}
.mk.num.via-mk{box-shadow:0 2px 6px rgba(16,24,40,.35),0 0 0 3px #fff,0 0 0 5px #7c3aed}
.legend-row .swatch.ring{background:#fff;border:2.5px solid var(--blue);box-sizing:border-box}
.via-bar{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:650;
  display:flex;align-items:center;gap:10px;height:42px;padding:0 8px 0 16px;
  border-radius:999px;background:var(--ink);color:#fff;font-size:13px;font-weight:600;
  box-shadow:var(--shadow-pop),0 0 0 1px rgba(255,255,255,.16);
  white-space:nowrap;max-width:min(92%,580px);
}
.via-bar.busy::before{
  content:"";width:14px;height:14px;flex:none;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  animation:spin .8s linear infinite;
}
/* the preview bar replaces the search pill while it is up (same spot) */
.map-wrap:has(#via-bar:not([hidden])) .area-search{display:none}
.via-bar b{
  font-weight:800;display:inline-block;max-width:220px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom;
}
#via-text{overflow:hidden;text-overflow:ellipsis}
.via-bar button:focus-visible{outline:2.5px solid #fff;outline-offset:2px}
.via-bar button{height:30px;border-radius:999px;padding:0 14px;font-size:12.5px;font-weight:700;flex:none;transition:.15s}
.via-commit{background:#7c3aed;color:#fff}
.via-commit:hover{background:#6d28d9}
.via-cancel{background:rgba(255,255,255,.14);color:#fff}
.via-cancel:hover{background:rgba(255,255,255,.26)}
.via-bar.busy .via-commit{display:none}
.via-bar.busy{padding-right:16px}
.popup-add.popup-via{background:#7c3aed;box-shadow:0 5px 14px -6px rgba(124,58,237,.6)}
.via-flag{
  font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  background:#ede9fe;color:#6d28d9;border-radius:6px;padding:2px 6px;flex:none;
}
.via-bar[hidden]{display:none}

/* mobile legend badge (hidden on desktop; positioned in the 980px block) */
@media (min-width:981px){.legend-badge{display:none}}
.lb-dots{display:flex;flex-wrap:wrap;gap:3px;width:18px;justify-content:center}
.lb-dots i{width:7px;height:7px;border-radius:50%;display:block}

/* ===== condensed car panel (mockups 4fuyEc + dpzJM1) ===== */
.change-car-pill{
  display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 11px;flex:none;
  border-radius:9px;background:var(--field);font-size:12px;font-weight:700;color:var(--ink-2);
  transition:.14s;
}
.change-car-pill:hover{background:#eceef2;color:var(--ink)}
.change-car-pill[hidden]{display:none}

.pref-grid{display:flex;gap:14px}
.pref-grid .pref{flex:1;min-width:0}
.pref-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.corridor-row{display:flex;align-items:center;justify-content:space-between;margin-top:13px;position:relative}
.step{display:flex;align-items:center;gap:8px}
.step button{
  width:28px;height:28px;border-radius:8px;background:var(--field);display:grid;
  place-items:center;color:var(--ink-2);font-size:16px;font-weight:700;transition:.13s;
}
.step button:hover{background:#eceef2;color:var(--ink)}
.step .sv{font-size:14px;font-weight:800;min-width:30px;text-align:center}
.step .u{font-size:11px;font-weight:700;color:var(--ink-3)}

.home-card .home-set{display:flex;align-items:center;gap:13px}
.home-card .home-set[hidden],.home-card .home-hint[hidden],.home-card .home-empty[hidden]{display:none}
.home-ico{
  width:44px;height:44px;flex:none;border-radius:13px;background:#e7f5ec;
  color:var(--energy);display:grid;place-items:center;
}
.home-ico .icon{width:22px;height:22px}
.home-ico.dim{background:var(--field);color:var(--ink-3)}
.home-body{flex:1;min-width:0}
.home-eyebrow{display:flex;align-items:center;gap:7px;margin-bottom:2px}
.home-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.home-pill{
  font-size:10px;font-weight:700;letter-spacing:.02em;color:var(--energy);
  background:#e7f5ec;padding:2px 7px;border-radius:999px;
}
.home-addr{font-size:14.5px;font-weight:700;letter-spacing:-.01em;line-height:1.3}
.home-edit{
  width:34px;height:34px;flex:none;border-radius:10px;display:grid;place-items:center;
  color:var(--ink-3);background:var(--field);transition:.14s;
}
.home-edit:hover{background:#eceef2;color:var(--ink)}
.home-edit .icon{width:16px;height:16px}
.home-hint{
  display:flex;align-items:center;gap:8px;margin-top:13px;padding-top:13px;
  border-top:1px solid var(--line);font-size:12.5px;font-weight:500;color:var(--ink-2);line-height:1.4;
}
.home-hint .icon{width:14px;height:14px;color:var(--ink-3);flex:none}
.home-hint .kbd{
  font-weight:700;color:var(--ink);background:var(--field);border:1px solid var(--line-2);
  padding:1px 7px;border-radius:6px;font-size:12px;
}
.home-empty .empty-top{display:flex;align-items:center;gap:13px;margin-bottom:13px}
.home-empty-title{font-size:15px;font-weight:800;letter-spacing:-.015em}
.home-empty-desc{font-size:12.5px;font-weight:500;color:var(--ink-3);margin-top:2px;line-height:1.35}
.addr-field{
  display:flex;align-items:center;gap:10px;height:46px;padding:0 6px 0 14px;
  background:var(--field);border:1px solid transparent;border-radius:12px;
  transition:.15s;position:relative;
}
.addr-field:focus-within{background:#fff;border-color:var(--line-2);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.addr-field .pin{color:var(--ink-3);flex:none}
.addr-field input{
  flex:1;min-width:0;border:none;background:none;outline:none;
  font-size:14px;font-weight:600;color:var(--ink);
}
.addr-field input::placeholder{color:var(--ink-3);font-weight:500}
.addr-field .dropdown{top:calc(100% + 6px);left:0;right:0}
.addr-save{
  height:34px;padding:0 14px;border-radius:9px;background:var(--ink);color:#fff;
  font-size:13px;font-weight:700;flex:none;transition:.14s;
}
.addr-save:hover{background:#000}

/* freshly diffed-in dots fade in fast */
@keyframes mkin{from{opacity:0}}
.leaflet-marker-icon.mk-in{animation:mkin .18s ease}
