*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{height:100%;-webkit-tap-highlight-color:transparent;}
body{font-family:'Barlow',sans-serif;-webkit-font-smoothing:antialiased;background:#fff;color:#191C1F;height:100%;overflow:hidden;overscroll-behavior:none;}
a{color:inherit;text-decoration:none;}
button,input,textarea,select{font-family:'Barlow',sans-serif;}
button{cursor:pointer;border:none;-webkit-appearance:none;}
::-webkit-scrollbar{width:4px;}::-webkit-scrollbar-thumb{background:#C6C6CE;border-radius:4px;}
:root{
  --w:#FFFFFF;--off:#F7F7F3;--off2:#F0F0EC;--bdr:#E4E4DE;--bdr2:#C6C6CE;
  --navy:#1B2340;--navy2:#242E4C;--navy3:#0E1220;
  --lime:#395f94;--lime2:#2d4f7d;
  --muted:#45464D;--muted2:#76767E;
  --green:#16A34A;--greenl:#DCFCE7;
  --red:#BA1A1A;--redl:#FFDAD6;
  --blue:#395F94;--bluel:#D5E3FF;
  --fd:'Barlow Condensed',sans-serif;
  --sat:env(safe-area-inset-top,0px);--sab:env(safe-area-inset-bottom,0px);
  --bn:calc(60px + var(--sab));
}
/* ── PARKLY MARK ── */
.pk-mark{--sz:32px;display:inline-block;width:var(--sz);height:var(--sz);border-radius:calc(var(--sz) * 0.22);flex-shrink:0;background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3E%3Cpolygon points='144.02,330.29 367.98,330.29 256,440' fill='%23FFFFFF'%3E%3C/polygon%3E%3Ccircle cx='256' cy='216' r='160' fill='%23FFFFFF'%3E%3C/circle%3E%3Crect x='189' y='149' width='60' height='60' rx='8' fill='%231B2340'%3E%3C/rect%3E%3Crect x='263' y='149' width='60' height='60' rx='8' fill='%231B2340'%3E%3C/rect%3E%3Crect x='189' y='223' width='60' height='60' rx='8' fill='%231B2340'%3E%3C/rect%3E%3Crect x='263' y='223' width='60' height='60' rx='8' fill='%231B2340'%3E%3C/rect%3E%3Crect x='271.69' y='231.69' width='11.96' height='11.96' rx='2' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='302.35' y='231.69' width='11.96' height='11.96' rx='2' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='287.02' y='247.02' width='11.96' height='11.96' rx='2' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='271.69' y='262.35' width='11.96' height='11.96' rx='2' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='302.35' y='262.35' width='11.96' height='11.96' rx='2' fill='%23FFFFFF'%3E%3C/rect%3E%3C/svg%3E") center/contain no-repeat;}
.pk-mark.inv{background-color:transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'%3E%3Cpolygon points='144.02,330.29 367.98,330.29 256,440' fill='%231B2340'%3E%3C/polygon%3E%3Ccircle cx='256' cy='216' r='160' fill='%231B2340'%3E%3C/circle%3E%3Crect x='189' y='149' width='60' height='60' rx='8' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='263' y='149' width='60' height='60' rx='8' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='189' y='223' width='60' height='60' rx='8' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='263' y='223' width='60' height='60' rx='8' fill='%23FFFFFF'%3E%3C/rect%3E%3Crect x='271.69' y='231.69' width='11.96' height='11.96' rx='2' fill='%231B2340'%3E%3C/rect%3E%3Crect x='302.35' y='231.69' width='11.96' height='11.96' rx='2' fill='%231B2340'%3E%3C/rect%3E%3Crect x='287.02' y='247.02' width='11.96' height='11.96' rx='2' fill='%231B2340'%3E%3C/rect%3E%3Crect x='271.69' y='262.35' width='11.96' height='11.96' rx='2' fill='%231B2340'%3E%3C/rect%3E%3Crect x='302.35' y='262.35' width='11.96' height='11.96' rx='2' fill='%231B2340'%3E%3C/rect%3E%3C/svg%3E");}
/* ── APP SHELL ── */
#app-shell{display:flex;height:100vh;height:100dvh;overflow:hidden;}
#sidebar{width:232px;flex-shrink:0;background:var(--w);border-right:1px solid var(--bdr);display:flex;flex-direction:column;height:100%;}
.sb-brand{display:flex;align-items:center;gap:10px;padding:20px 16px;border-bottom:1px solid var(--bdr);}
.sb-logo{--sz:32px;}
.sb-name{font-family:var(--fd);font-weight:900;font-size:18px;color:var(--navy);}
.sb-nav{flex:1;padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:1px;}
.sb-grp{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);padding:12px 10px 5px;}
.nl{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:transparent;color:var(--muted);width:100%;text-align:left;cursor:pointer;transition:background .13s,color .13s;}
.nl:hover{background:var(--off);color:var(--navy);}
.nl.on{background:var(--off2);color:var(--navy);}
.nl-ico{flex-shrink:0;line-height:0;}
.nl-txt{font-family:var(--fd);font-weight:700;font-size:14px;letter-spacing:.2px;}
.nl-badge{margin-left:auto;background:var(--navy);color:#fff;font-size:9px;font-weight:800;font-family:var(--fd);letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:100px;}
.sb-foot{padding:8px 8px 12px;border-top:1px solid var(--bdr);}
.sb-user{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--off);border-radius:10px;}
.sb-av{width:30px;height:30px;border-radius:8px;background:var(--navy);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:900;font-size:13px;color:#fff;flex-shrink:0;}
.sb-uname{font-size:13px;font-weight:600;color:var(--navy);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sb-uphon{font-size:11px;color:var(--muted);}
.sb-out{background:none;color:var(--muted);padding:4px;line-height:0;border-radius:6px;margin-left:auto;flex-shrink:0;transition:color .13s;}
.sb-out:hover{color:var(--red);}
/* Content */
#content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}
#topbar{display:none;align-items:center;justify-content:space-between;padding:0 18px;height:calc(56px + var(--sat));padding-top:var(--sat);background:var(--w);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:50;flex-shrink:0;}
.tb-logo{display:flex;align-items:center;gap:8px;}
.tb-logo-ico{--sz:28px;}
.tb-logo-nm{font-family:var(--fd);font-weight:900;font-size:17px;color:var(--navy);}
.tb-av-btn{width:38px;height:38px;border-radius:10px;background:var(--off);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;}
#pages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
.page{padding:22px 20px;max-width:900px;animation:fin .3s ease;}
#botnav{display:none;align-items:stretch;height:var(--bn);padding-bottom:var(--sab);background:var(--w);border-top:1px solid var(--bdr);flex-shrink:0;}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:transparent;color:var(--muted2);padding:0;cursor:pointer;border:none;transition:color .13s;padding-bottom:2px;}
.bn.on{color:var(--navy);}
.bn-ico{line-height:0;position:relative;}
.bn-dot{position:absolute;top:-2px;right:-4px;width:6px;height:6px;border-radius:50%;background:var(--red);border:1.5px solid var(--w);}
.bn-lbl{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.3px;white-space:nowrap;}
@media(max-width:1023px){#sidebar{display:none;}#topbar{display:flex;}#botnav{display:flex;}}
@media(min-width:1024px){.page{padding:28px 32px;}}
/* Typography */
.ph{font-family:var(--fd);font-weight:900;font-size:26px;color:var(--navy);letter-spacing:-.5px;line-height:1.05;}
.ph-sub{font-size:14px;color:var(--muted);margin-top:5px;line-height:1.5;}
.sh{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:12px 22px;border-radius:100px;font-family:var(--fd);font-size:14px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .15s;white-space:nowrap;border:none;min-height:44px;}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy2);}
.btn-navy:active{transform:scale(.97);}
.btn-lime{background:var(--blue);color:#fff;}
.btn-lime:hover{background:var(--lime2);}
.btn-out{background:var(--w);color:var(--navy);border:1.5px solid var(--bdr2);}
.btn-out:hover{border-color:var(--navy);background:var(--off);}
.btn-red{background:var(--redl);color:var(--red);}
.btn-sm{padding:12px 18px;font-size:12px;min-height:44px;}
.btn-xs{padding:11px 14px;font-size:11px;min-height:44px;}
.btn-full{width:100%;}
/* Cards */
.card{background:var(--w);border:1px solid var(--bdr);border-radius:16px;box-shadow:0 2px 12px rgba(27,35,64,.06);}
.card-p{padding:18px 20px;}
.surface{background:var(--off);border-radius:14px;padding:16px 18px;}
/* Inputs */
.inp{width:100%;padding:13px 16px;background:var(--off);border:1.5px solid var(--bdr);border-radius:12px;font-size:15px;color:var(--navy);outline:none;transition:border-color .15s;-webkit-appearance:none;}
.inp:focus{border-color:var(--navy);background:var(--w);}
.inp::placeholder{color:var(--muted2);}
textarea.inp{resize:none;line-height:1.5;}
.lbl{display:block;font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.fg{display:flex;flex-direction:column;gap:16px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
/* Tags */
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;}
.t-green{background:var(--greenl);color:var(--green);}
.t-red{background:var(--redl);color:var(--red);}
.t-blue{background:var(--bluel);color:var(--blue);}
.t-muted{background:var(--off2);color:var(--muted);}
/* Chips */
.chip-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px;}
.chip{padding:8px 16px;border-radius:100px;border:1.5px solid var(--bdr);background:var(--w);font-family:var(--fd);font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .13s;min-height:36px;}
.chip:hover,.chip.on{border-color:var(--navy);background:var(--navy);color:#fff;}
.tgl-row{display:flex;gap:7px;flex-wrap:wrap;}
.tgl{padding:8px 16px;border-radius:100px;border:1.5px solid var(--bdr);background:var(--w);font-family:var(--fd);font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .13s;min-height:36px;}
.tgl:hover,.tgl.on{border-color:var(--navy);background:var(--navy);color:#fff;}
/* ── A11y: keyboard focus ring (keyboard nav only — mouse clicks unaffected) + disabled ── */
.btn:focus-visible,.chip:focus-visible,.tgl:focus-visible,.nl:focus-visible,a:focus-visible,button:focus-visible,[role="button"]:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--blue);outline-offset:2px;}
.inp:focus-visible{outline:3px solid var(--blue);outline-offset:1px;}
.btn:disabled,.btn[disabled],.btn.is-disabled{opacity:.5;cursor:not-allowed;}
/* List items */
.li{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--w);border:1px solid var(--bdr);border-radius:14px;margin-bottom:8px;cursor:pointer;transition:border-color .13s,box-shadow .13s;-webkit-tap-highlight-color:transparent;}
.li:hover{border-color:var(--bdr2);box-shadow:0 2px 10px rgba(27,35,64,.06);}
.li:active{background:var(--off);}
.li-ico{width:44px;height:44px;border-radius:12px;background:var(--off);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px;}
.li-main{flex:1;overflow:hidden;}
.li-title{font-family:var(--fd);font-weight:700;font-size:16px;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.li-sub{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.li-right{flex-shrink:0;text-align:right;}
/* Stats */
.stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:22px;}
@media(min-width:600px){.stat-row{grid-template-columns:repeat(4,1fr);}}
.sc{background:var(--off);border:1px solid var(--bdr);border-radius:14px;padding:16px 18px;box-shadow:0 2px 8px rgba(27,35,64,.05);}
.sc-val{font-family:var(--fd);font-weight:900;font-size:28px;line-height:1;letter-spacing:-.5px;color:var(--navy);}
.sc-lbl{font-size:12px;font-weight:600;color:var(--muted);margin-top:4px;}
/* Map */
.map-box{background:var(--navy3);border-radius:16px;position:relative;overflow:hidden;border:1px solid var(--bdr);}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:36px 36px;}
.map-road-h{position:absolute;height:7px;background:rgba(255,255,255,.05);left:0;right:0;}
.map-road-v{position:absolute;width:7px;background:rgba(255,255,255,.05);top:0;bottom:0;}
.map-pin{position:absolute;display:flex;flex-direction:column;align-items:center;cursor:pointer;transform:translateX(-50%);}
.map-bub{background:var(--w);color:var(--navy);border:1px solid var(--bdr);padding:4px 8px;border-radius:8px;font-family:var(--fd);font-size:11px;font-weight:800;box-shadow:0 4px 14px rgba(0,0,0,.25);white-space:nowrap;transition:background .13s;}
.map-bub.sel,.map-bub:hover{background:var(--navy);color:var(--w);border-color:var(--navy);}
.map-dot{width:5px;height:5px;border-radius:50%;background:var(--muted2);margin-top:2px;}
.map-dot.sel{background:var(--navy);}
.map-me{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--blue);border:2.5px solid white;box-shadow:0 0 0 4px rgba(57,95,148,.25);transform:translate(-50%,-50%);}
.map-live{position:absolute;bottom:10px;right:10px;background:rgba(10,13,24,.9);border:1px solid rgba(255,255,255,.1);color:#fff;padding:5px 11px;border-radius:100px;font-family:var(--fd);font-size:10px;font-weight:700;display:flex;align-items:center;gap:6px;}
.live-dot{width:6px;height:6px;border-radius:50%;background:#16A34A;animation:pulse 1.4s ease-in-out infinite;}
/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(27,35,64,.5);z-index:800;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
@media(min-width:600px){.modal-bg{align-items:center;padding:20px;}}
.modal{background:var(--w);border-radius:24px 24px 0 0;width:100%;max-height:90vh;overflow-y:auto;animation:slideup .25s ease;-webkit-overflow-scrolling:touch;padding-bottom:var(--sab);}
@media(min-width:600px){.modal{border-radius:20px;max-width:440px;max-height:88vh;animation:fin .2s ease;}}
.m-handle{width:36px;height:4px;border-radius:2px;background:var(--bdr2);margin:12px auto 4px;}
.m-hd{padding:16px 22px 14px;border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:flex-start;}
.m-sup{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.m-title{font-family:var(--fd);font-weight:900;font-size:22px;color:var(--navy);letter-spacing:-.3px;}
.m-close{background:var(--off);border:1px solid var(--bdr);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;flex-shrink:0;}
.m-close:hover{background:var(--off2);color:var(--navy);}
.m-body{padding:20px 22px 24px;}
.m-foot{display:flex;gap:8px;margin-top:4px;}
.m-foot .btn{flex:1;}
/* Toast */
#toasts{position:fixed;bottom:calc(var(--bn) + 10px);left:50%;transform:translateX(-50%);z-index:999;display:flex;flex-direction:column;align-items:center;gap:7px;pointer-events:none;}
@media(min-width:1024px){#toasts{bottom:22px;}}
.toast{display:flex;align-items:center;gap:8px;padding:11px 20px;background:var(--navy);border-radius:100px;font-size:14px;font-weight:600;color:#fff;box-shadow:0 8px 32px rgba(27,35,64,.25);white-space:nowrap;animation:tin .2s ease;}
/* Steps */
.steps{display:flex;gap:6px;margin-bottom:20px;}
.step-b{flex:1;}
.sf{height:3px;border-radius:2px;background:var(--bdr2);}
.sf.on{background:var(--navy);}
.sn{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted2);margin-top:4px;}
.sn.on{color:var(--navy);}
/* Plans */
.plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;}
.plan{padding:16px;border-radius:14px;border:2px solid var(--bdr);background:var(--off);cursor:pointer;transition:all .15s;text-align:center;}
.plan.on{border-color:var(--navy);background:var(--w);}
.plan-price{font-family:var(--fd);font-weight:900;font-size:32px;letter-spacing:-1px;color:var(--navy2);margin-bottom:3px;}
.plan.on .plan-price{color:var(--navy);}
.plan-name{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--muted2);}
.plan.on .plan-name{color:var(--navy);}
.plan-sub{font-size:10px;color:var(--muted);margin-top:2px;}
/* Success */
.succ-ico{width:64px;height:64px;border-radius:50%;background:var(--greenl);border:1px solid rgba(22,163,74,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;animation:popin .5s cubic-bezier(.34,1.56,.64,1);}
/* Empty */
.empty{text-align:center;padding:52px 24px;background:var(--off);border-radius:16px;border:1px dashed var(--bdr2);}
.empty-ico{font-size:44px;margin-bottom:14px;}
.empty-h{font-family:var(--fd);font-weight:900;font-size:22px;color:var(--navy);margin-bottom:6px;}
.empty-p{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.6;max-width:280px;margin-left:auto;margin-right:auto;}
/* Contact box */
.cbox{background:var(--off);border-radius:14px;overflow:hidden;}
.crow{display:flex;align-items:center;gap:12px;padding:14px 16px;}
.crow+.crow{border-top:1px solid var(--bdr);}
/* QR Banner */
.qr-banner{background:var(--navy);border-radius:16px;padding:18px 20px;display:flex;align-items:center;gap:14px;margin-bottom:22px;position:relative;overflow:hidden;}
.qr-banner::after{content:'';position:absolute;right:-20px;top:-20px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05),transparent);pointer-events:none;}
/* Install prompt */
#install-prompt{position:fixed;bottom:calc(var(--bn) + 12px);left:12px;right:12px;z-index:700;background:var(--navy);border-radius:16px;padding:16px 18px;display:none;align-items:center;gap:14px;box-shadow:0 8px 32px rgba(27,35,64,.3);animation:slideup .3s ease;}
@media(min-width:1024px){#install-prompt{left:auto;right:22px;bottom:22px;width:320px;}}
/* Landing */
#landing{width:100%;height:100vh;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--w);}
.l-nav{position:sticky;top:0;z-index:100;padding-top:var(--sat);background:rgba(255,255,255,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s;}
.l-nav.scrolled{border-color:var(--bdr);}
.l-nav-inner{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;}
@media(min-width:900px){.l-nav-inner{padding:0 48px;}}
.l-logo{display:flex;align-items:center;gap:9px;}
.l-logo-ico{--sz:30px;}
.l-logo-nm{font-family:var(--fd);font-weight:900;font-size:17px;color:var(--navy);}
.l-navlinks{display:none;}
@media(min-width:900px){.l-navlinks{display:flex;gap:28px;align-items:center;}.l-navlinks a{font-size:14px;font-weight:500;color:var(--muted);transition:color .15s;}.l-navlinks a:hover{color:var(--navy);}}
.l-navbtns{display:flex;gap:8px;}
.l-ghost{padding:8px 18px;border-radius:100px;border:1.5px solid var(--bdr2);background:transparent;font-family:var(--fd);font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .15s;min-height:40px;}
.l-ghost:hover{border-color:var(--navy);color:var(--navy);}
.l-cta{padding:10px 22px;border-radius:100px;background:var(--navy);border:none;font-family:var(--fd);font-size:13px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s;min-height:40px;}
.l-cta:hover{background:var(--navy2);}
.l-sec{padding:64px 24px;}
@media(min-width:900px){.l-sec{padding:80px 48px;}}
.l-inner{max-width:1180px;margin:0 auto;}
.l-label{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.l-h2{font-family:var(--fd);font-weight:900;font-size:clamp(32px,4vw,52px);letter-spacing:-1.5px;color:var(--navy);line-height:1;margin-bottom:40px;}
.hero-wrap{max-width:1180px;margin:0 auto;padding:24px 24px 40px;}
@media(min-width:900px){.hero-wrap{display:grid;grid-template-columns:1fr 400px;gap:60px;align-items:center;padding:36px 48px 56px;}}
.hero-h1{font-family:var(--fd);font-weight:900;font-size:clamp(52px,6vw,80px);line-height:.95;letter-spacing:-2px;color:var(--navy);margin-bottom:18px;display:flex;flex-direction:column;gap:0;}
.hero-h1 em{font-style:normal;}
.hero-p{font-size:16px;line-height:1.7;color:var(--muted);max-width:400px;margin-bottom:28px;}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;}
.l-primary{padding:14px 28px;border-radius:100px;background:var(--navy);border:none;font-family:var(--fd);font-size:14px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .15s;min-height:48px;}
.l-primary:hover{background:var(--navy2);}
.l-outline{padding:13px 24px;border-radius:100px;background:transparent;border:1.5px solid var(--bdr2);font-family:var(--fd);font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .15s;min-height:48px;}
.l-outline:hover{border-color:var(--navy);color:var(--navy);}
.srch-mock{background:var(--w);border:1.5px solid var(--bdr);border-radius:20px;overflow:hidden;box-shadow:0 8px 40px rgba(27,35,64,.1);}
.srch-map{height:180px;position:relative;}
.srch-results{padding:14px 16px;}
.srch-lbl{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.srch-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;background:var(--off);margin-bottom:6px;cursor:pointer;transition:background .13s;border:1px solid transparent;}
.srch-item.sel{background:var(--w);border-color:var(--navy);}
.srch-nm{font-size:13px;font-weight:600;color:var(--navy);}
.srch-dist{font-size:11px;color:var(--muted);}
.srch-price{margin-left:auto;font-family:var(--fd);font-size:16px;font-weight:900;color:var(--navy);}
.hiw-grid{display:grid;grid-template-columns:1fr;gap:2px;background:var(--bdr);border:1px solid var(--bdr);border-radius:16px;overflow:hidden;}
@media(min-width:600px){.hiw-grid{grid-template-columns:repeat(3,1fr);}}
.hiw-card{background:var(--w);padding:32px 28px;transition:background .2s;}
.hiw-card:hover{background:var(--off);}
.hiw-n{font-family:var(--fd);font-weight:900;font-size:44px;color:var(--bdr2);letter-spacing:-2px;margin-bottom:14px;line-height:1;}
.hiw-t{font-family:var(--fd);font-weight:900;font-size:20px;color:var(--navy);margin-bottom:8px;}
.hiw-b{font-size:13px;color:var(--muted);line-height:1.7;}
.stats-band{background:var(--navy);padding:48px 24px;}
@media(min-width:900px){.stats-band{padding:48px;}}
.stats-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(255,255,255,.06);border-radius:12px;overflow:hidden;}
@media(min-width:600px){.stats-grid{grid-template-columns:repeat(4,1fr);}}
.stat-b{background:var(--navy3);padding:28px 22px;transition:background .2s;}
.stat-b:hover{background:var(--navy2);}
.stat-v{font-family:var(--fd);font-weight:900;font-size:38px;color:#fff;letter-spacing:-1.5px;margin-bottom:4px;}
.stat-l{font-size:12px;color:rgba(255,255,255,.55);}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:16px;}
@media(min-width:600px){.pricing-grid{grid-template-columns:repeat(3,1fr);}}
.pc{background:var(--w);border:1.5px solid var(--bdr);border-radius:18px;padding:28px 24px;transition:border-color .2s,box-shadow .2s;}
.pc:hover{border-color:var(--bdr2);box-shadow:0 8px 32px rgba(27,35,64,.07);}
.pc.feat{background:var(--navy);border-color:var(--navy);}
.pc-badge{display:inline-flex;padding:4px 10px;border-radius:100px;font-family:var(--fd);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px;}
.pc.feat .pc-badge{background:var(--blue);color:#fff;}
.pc:not(.feat) .pc-badge{background:var(--off2);color:var(--muted);}
.pc-name{font-family:var(--fd);font-weight:900;font-size:20px;margin-bottom:4px;}
.pc.feat .pc-name{color:var(--w);}
.pc:not(.feat) .pc-name{color:var(--navy);}
.pc-price{font-family:var(--fd);font-weight:900;font-size:46px;letter-spacing:-2px;line-height:1;margin-bottom:4px;}
.pc.feat .pc-price{color:#fff;}
.pc:not(.feat) .pc-price{color:var(--navy);}
.pc-per{font-size:12px;margin-bottom:18px;}
.pc.feat .pc-per{color:rgba(255,255,255,.4);}
.pc:not(.feat) .pc-per{color:var(--muted);}
.pc-div{height:1px;background:var(--bdr);margin-bottom:14px;}
.pc.feat .pc-div{background:rgba(255,255,255,.1);}
.pc-list{list-style:none;margin-bottom:22px;}
.pc-list li{display:flex;align-items:flex-start;gap:8px;padding:4px 0;font-size:12px;line-height:1.5;}
.pc.feat .pc-list li{color:rgba(255,255,255,.6);}
.pc:not(.feat) .pc-list li{color:var(--muted);}
.pc-chk path{stroke:#fff;}
.pc-chk-d path{stroke:var(--navy);}
.qr-lbox{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;}
@media(min-width:900px){.qr-lbox{grid-template-columns:1fr 340px;}}
.qr-cmock{background:var(--w);border:1.5px solid var(--bdr);border-radius:18px;padding:20px;box-shadow:0 4px 24px rgba(27,35,64,.08);}
.l-foot{background:var(--navy3);padding:48px 24px 28px;}
@media(min-width:900px){.l-foot{padding:52px 48px 28px;}}
.l-foot-inner{max-width:1180px;margin:0 auto;}
.l-foot-top{display:flex;flex-direction:column;gap:32px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:22px;}
@media(min-width:600px){.l-foot-top{flex-direction:row;justify-content:space-between;}}
.l-foot-cols{display:flex;gap:44px;flex-wrap:wrap;}
.l-foot-col h4{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:12px;}
.l-foot-col ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.l-foot-col a{font-size:13px;color:rgba(255,255,255,.65);transition:color .15s;}
.l-foot-col a:hover{color:var(--w);}
#auth-page{width:100%;height:100vh;height:100dvh;background:var(--off);display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto;}
.auth-box{width:100%;max-width:380px;}
.auth-hd{text-align:center;margin-bottom:24px;}
.auth-logo{--sz:48px;margin:0 auto 12px;}
.auth-nm{font-family:var(--fd);font-weight:900;font-size:24px;color:var(--navy);}
.auth-sub{font-size:13px;color:var(--muted);margin-top:3px;}
.auth-card{background:var(--w);border:1.5px solid var(--bdr);border-radius:20px;padding:26px 24px;}
.auth-tabs{display:flex;gap:4px;background:var(--off);border-radius:12px;padding:4px;margin-bottom:22px;}
.auth-tab{flex:1;padding:9px;border-radius:9px;border:none;font-family:var(--fd);font-size:13px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;cursor:pointer;background:transparent;color:var(--muted);transition:all .15s;}
.auth-tab.on{background:var(--navy);color:#fff;}
.auth-err{padding:10px 14px;background:var(--redl);border-radius:10px;font-size:12px;color:var(--red);margin-top:10px;}
.auth-foot{text-align:center;margin-top:14px;font-size:12px;color:var(--muted);}
.auth-foot a{color:var(--navy);font-weight:600;}
#scan-page{width:100%;min-height:100dvh;background:var(--off);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 60px);box-sizing:border-box;}
.scan-back{display:flex;align-items:center;gap:7px;margin-bottom:18px;opacity:.5;cursor:pointer;transition:opacity .15s;}
.scan-back:hover{opacity:1;}
.scan-card{width:100%;max-width:400px;background:var(--w);border:1.5px solid var(--bdr);border-radius:22px;overflow:hidden;box-shadow:0 8px 40px rgba(27,35,64,.08);}
.scan-veh{background:var(--off);padding:18px 20px;border-bottom:1px solid var(--bdr);}
.scan-body{padding:18px 20px 22px;}
.scan-anon{display:inline-flex;align-items:center;gap:6px;background:var(--greenl);border-radius:100px;padding:5px 12px;margin-bottom:16px;}
.scan-anon span{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--green);}
.aopt{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1.5px solid var(--bdr);border-radius:12px;cursor:pointer;transition:all .13s;background:var(--w);margin-bottom:7px;-webkit-tap-highlight-color:transparent;}
.aopt:hover{border-color:var(--bdr2);background:var(--off);}
.aopt.on{border-color:var(--navy);background:var(--off);}
.aopt-em{font-size:20px;flex-shrink:0;width:28px;text-align:center;}
.aopt-lbl{font-family:var(--fd);font-size:14px;font-weight:700;color:var(--navy);}
.aopt-sub{font-size:11px;color:var(--muted);margin-top:1px;}
@keyframes fin{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes popin{from{transform:scale(.75);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes tin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes scanv{0%{top:18%}50%{top:72%}100%{top:18%}}
.spinner{width:32px;height:32px;border:3px solid var(--bdr2);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite;}
/* Spot mascot — hero greeter. Brand yellow #FFC937 lives ONLY on Spot. See docs/brand/SPOT.md */
.spot-hero{width:72px;margin-bottom:6px;}
@media(min-width:900px){.spot-hero{width:80px;}}
.spot-hero svg{width:100%;height:auto;display:block;overflow:visible;}
.spot-body{animation:spotbob 3.4s ease-in-out infinite;}
.spot-eyes{transform-box:fill-box;transform-origin:center;animation:spotblink 4.6s ease-in-out infinite;}
.spot-shadow{transform-box:fill-box;transform-origin:center;opacity:.14;animation:spotshadow 3.4s ease-in-out infinite;}
.spot-spark{transform-box:fill-box;transform-origin:center;opacity:0;animation:spotsnap 5s ease-in-out infinite;}
@keyframes spotbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes spotblink{0%,90%,100%{transform:scaleY(1)}95%{transform:scaleY(.12)}}
@keyframes spotshadow{0%,100%{transform:scaleX(1);opacity:.14}50%{transform:scaleX(.82);opacity:.08}}
@keyframes spotsnap{0%,80%,100%{opacity:0;transform:scale(.4)}87%{opacity:1;transform:scale(1.05)}94%{opacity:.9;transform:scale(1)}}
@media(prefers-reduced-motion:reduce){.spot-body,.spot-eyes,.spot-shadow,.spot-spark{animation:none}.spot-spark{opacity:0}}
/* Honour reduced-motion app-wide: near-instant animations/transitions (page fades, modals, toasts, pulse, spinner) */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}}
.notif-panel{position:fixed;top:calc(56px + var(--sat));right:0;width:min(320px,100vw);background:var(--w);border-left:1px solid var(--bdr);border-bottom:1px solid var(--bdr);border-radius:0 0 0 16px;box-shadow:-4px 4px 24px rgba(27,35,64,.12);z-index:600;max-height:70vh;overflow-y:auto;display:none;}
@media(min-width:1024px){.notif-panel{top:0;right:0;border-radius:0 0 0 16px;}}
.notif-item{display:flex;align-items:flex-start;gap:11px;padding:13px 16px;border-bottom:1px solid var(--bdr);transition:background .13s;}
.notif-item:hover{background:var(--off);}
.notif-item.unread{background:rgba(57,95,148,.04);}
.notif-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
