:root{
  --midnight:#0B1F33;--midnight-2:#0E2A47;--poppy:#FF6A13;--poppy-dark:#E55A09;
  --gold:#FFC83D;--save:#1FA971;--cloud:#F7F9FC;--white:#fff;--ink:#0B1F33;--slate:#5B6B7B;--mist:#E3E9F0;
  --font:"Manrope","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:var(--font);color:var(--ink);background:var(--cloud);overscroll-behavior:none}
#app{position:fixed;inset:0;display:flex;flex-direction:column}

/* top bar */
.topbar{height:60px;flex:0 0 auto;background:var(--midnight);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:20}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em}
.topbar .brand b{color:var(--poppy)}
.savechip{background:rgba(31,169,113,.18);color:#7ef0bd;font-weight:800;font-size:13px;padding:7px 12px;border-radius:999px;border:1px solid rgba(31,169,113,.35)}

/* views */
.view{flex:1;position:relative;overflow:hidden;display:none}
.view.active{display:block}
#view-map{display:block}
.view.scroll{overflow-y:auto;-webkit-overflow-scrolling:touch}

/* map */
#map{position:absolute;inset:0}
.maptools{position:absolute;top:12px;left:12px;right:12px;z-index:10;display:flex;gap:8px;flex-wrap:wrap}
.search{flex:1;min-width:160px;display:flex;align-items:center;background:#fff;border-radius:999px;box-shadow:0 4px 18px rgba(11,31,51,.16);padding:0 14px;height:44px}
.search input{border:0;outline:0;font-size:15px;font-family:inherit;flex:1;background:0}
.chiprow{display:flex;gap:8px}
.fchip{background:#fff;border:1.5px solid transparent;border-radius:999px;height:44px;padding:0 16px;font-weight:700;font-size:14px;box-shadow:0 4px 18px rgba(11,31,51,.16);cursor:pointer;color:var(--ink)}
.fchip.on{background:var(--poppy);color:#fff}
.filterbtn{background:#fff;border:0;border-radius:999px;height:44px;padding:0 18px;font-weight:800;font-size:14px;box-shadow:0 4px 18px rgba(11,31,51,.16);cursor:pointer;color:var(--midnight);flex:0 0 auto}
.filterpanel{position:absolute;top:64px;left:12px;right:12px;z-index:14;background:#fff;border-radius:16px;box-shadow:0 12px 40px rgba(11,31,51,.22);padding:16px 16px 18px;display:none}
.filterpanel.open{display:block}
.filterpanel .fgroup{margin-bottom:12px}
.filterpanel .flabel{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);margin-bottom:8px}
.filterpanel .frow{display:flex;flex-wrap:wrap;gap:8px}
.filterpanel .fchip{box-shadow:none;border:1.5px solid var(--mist);height:auto;padding:9px 14px}
.filterpanel .fchip.on{border-color:var(--poppy)}
.geobtn{position:absolute;right:14px;bottom:24px;z-index:10;width:50px;height:50px;border-radius:50%;background:#fff;border:0;box-shadow:0 6px 20px rgba(11,31,51,.22);font-size:22px;cursor:pointer}
.mapmsg{position:absolute;inset:0;display:grid;place-items:center;background:var(--midnight);color:#fff;text-align:center;padding:30px;z-index:5}
.mapmsg .card{max-width:340px}.mapmsg code{background:rgba(255,255,255,.1);padding:2px 6px;border-radius:6px;font-size:13px}

/* marker */
.mk{width:26px;height:26px;border-radius:50% 50% 50% 0;background:var(--poppy);transform:rotate(-45deg);border:2px solid #fff;box-shadow:0 3px 8px rgba(0,0,0,.3);cursor:pointer;display:grid;place-items:center}
.mk.diesel{background:var(--midnight)} .mk span{transform:rotate(45deg);color:#fff;font-size:12px;font-weight:800}

/* bottom sheet */
.sheet{position:absolute;left:0;right:0;bottom:0;z-index:30;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -8px 30px rgba(11,31,51,.18);padding:18px 18px 26px;transform:translateY(110%);transition:transform .22s ease}
.sheet.up{transform:translateY(0)}
.sheet .grab{width:42px;height:5px;border-radius:999px;background:var(--mist);margin:0 auto 14px}
.sheet h3{margin:0 0 2px;font-size:19px}
.sheet .addr{color:var(--slate);font-size:14px;margin-bottom:12px}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.badge{font-size:12px;font-weight:800;padding:6px 11px;border-radius:999px;background:var(--cloud);border:1px solid var(--mist);text-transform:uppercase;letter-spacing:.04em}
.badge.gas{color:#0c6b46;background:#F0FBF6;border-color:#C9EFDD}
.badge.diesel{color:#1b3c5c;background:#EEF4FB;border-color:#D5E4F2}
.sheet .acts{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;font-size:15px;padding:13px 18px;border-radius:12px;border:0;cursor:pointer;font-family:inherit;flex:1;text-decoration:none}
.btn-primary{background:var(--poppy);color:#fff}.btn-dark{background:var(--midnight);color:#fff}

/* list */
.list{padding:14px 16px 90px}
.scard{background:#fff;border:1px solid var(--mist);border-radius:14px;padding:16px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.scard b{font-size:16px}.scard .sub{color:var(--slate);font-size:13.5px;margin-top:2px}
.scard .dist{font-weight:800;color:var(--poppy);font-size:14px;white-space:nowrap;margin-left:12px}

/* card view */
.pad{padding:22px 18px 90px}
.memcard{aspect-ratio:1.586;border-radius:18px;background:radial-gradient(120% 140% at 80% -10%,#16395c,#0B1F33 55%);color:#fff;padding:22px;position:relative;box-shadow:0 12px 40px rgba(11,31,51,.25);margin-bottom:22px}
.memcard .b{font-weight:800;letter-spacing:-.02em}.memcard .b i{color:var(--poppy);font-style:normal}
.memcard .chip{width:42px;height:30px;border-radius:6px;background:linear-gradient(135deg,var(--gold),#E0A920);margin:34px 0 auto}
.memcard .num{letter-spacing:.18em;font-size:16px;color:#cfe;position:absolute;bottom:46px;left:22px}
.memcard .nm{position:absolute;bottom:20px;left:22px;font-size:13px;letter-spacing:.05em}
.memcard .tier{position:absolute;bottom:20px;right:22px;font-size:11px;font-weight:800;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}
.barcode{height:70px;background:repeating-linear-gradient(90deg,#0B1F33 0 2px,#fff 2px 5px);border-radius:10px;margin-bottom:8px}
.muted{color:var(--slate);font-size:13.5px;text-align:center}
.stat{display:flex;justify-content:space-between;padding:15px 0;border-bottom:1px solid var(--mist)}
.stat .big{font-size:22px;font-weight:800;color:var(--save)}
h2.vh{margin:4px 0 16px;font-size:24px;letter-spacing:-.02em}

/* bottom nav */
.botnav{flex:0 0 auto;height:64px;background:#fff;border-top:1px solid var(--mist);display:flex;z-index:40}
.botnav button{flex:1;border:0;background:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-family:inherit;font-size:11px;font-weight:700;color:var(--slate);cursor:pointer}
.botnav button .i{font-size:20px}
.botnav button.on{color:var(--poppy)}
