:root{
  --bg:#050615;
  --bg2:#0b0a1a;
  --panel:#171022;
  --panel2:#1f142c;
  --card:#1b102a;
  --card-soft:#241735;
  --text:#fff7ff;
  --muted:#d8c8e6;
  --muted2:#a897b8;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.20);
  --pink:#ff4fb3;
  --pink2:#ff2d9a;
  --purple:#a86cff;
  --purple2:#7c45ff;
  --gold:#f7d887;
  --green:#2cff62;
  --shadow:0 18px 45px rgba(0,0,0,.42);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at 8% -6%, rgba(158,62,255,.18), transparent 34%),
    radial-gradient(circle at 100% 10%, rgba(255,72,174,.13), transparent 32%),
    linear-gradient(180deg,#050612 0%,#0a0818 45%,#04040d 100%);
}
a{color:inherit}
img{max-width:100%;display:block}
.page-shell{
  width:min(100%,430px);
  margin:0 auto;
  padding:12px 10px 78px;
}
.site-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:6px 2px 12px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand img{
  width:42px;height:42px;border-radius:14px;
  box-shadow:0 0 0 1px rgba(255,255,255,.14),0 8px 22px rgba(255,79,179,.16);
}
.brand strong{display:block;font-size:18px;letter-spacing:.1px;line-height:1}
.brand em{display:block;font-style:normal;font-size:11px;color:var(--muted2);margin-top:5px}
.top-btn{
  height:38px;
  padding:0 15px;
  border-radius:999px;
  display:flex;
  align-items:center;
  text-decoration:none;
  font-weight:900;
  font-size:13px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.07);
}
.hero-section,.gallery-section,.bottom-cta,.download-card-v2{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.hero-section{
  border-radius:28px;
  padding:18px 12px 14px;
}
.hero-section:before,.gallery-section:before,.bottom-cta:before,.download-card-v2:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 16% 0%,rgba(255,79,179,.16),transparent 38%),
    radial-gradient(circle at 92% 0%,rgba(168,108,255,.14),transparent 40%);
  pointer-events:none;
}
.hero-copy{position:relative;z-index:2;text-align:left;padding:0 4px 14px}
.eyebrow{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:7px 12px;
  background:rgba(247,216,135,.13);
  border:1px solid rgba(247,216,135,.30);
  color:#ffe7a7;
  text-transform:uppercase;
  font-weight:900;
  font-size:10px;
  letter-spacing:.25px;
}
.eyebrow.small{font-size:9px;padding:6px 10px}
.hero-copy h1{font-size:31px;line-height:1.03;letter-spacing:-1px;margin:12px 0 8px}
.hero-copy p{font-size:14px;line-height:1.5;color:var(--muted);margin:0;max-width:360px}
.featured-slot{position:relative;z-index:2}
.profile-card{
  position:relative;
  display:block;
  overflow:hidden;
  text-decoration:none;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(38,24,56,.98),rgba(23,12,34,.99));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 12px 28px rgba(0,0,0,.34);
}
.profile-card + .profile-card{margin-top:16px}
.featured-card{
  border-color:rgba(255,79,179,.34);
  box-shadow:0 0 0 1px rgba(255,79,179,.15),0 20px 55px rgba(0,0,0,.42);
}
.profile-image-wrap{
  position:relative;
  display:block;
  height:300px;
  background:#1a1028;
  overflow:hidden;
}
.profile-card.featured-card .profile-image-wrap{height:330px}
.profile-image{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:saturate(1.05) contrast(1.02);
}
.image-shade{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(10,0,18,.05) 46%,rgba(10,0,18,.78) 100%);
}
.verified-badge{
  position:absolute;
  z-index:2;
  top:14px;
  right:14px;
  border-radius:999px;
  padding:9px 13px;
  background:linear-gradient(135deg,#ff73c2,#ff3aa5);
  font-size:12px;
  font-weight:950;
  box-shadow:0 10px 24px rgba(255,58,165,.28);
}
.online-badge{
  position:absolute;
  z-index:2;
  left:14px;
  bottom:14px;
  border-radius:999px;
  padding:8px 11px;
  background:rgba(9,38,17,.86);
  border:1px solid rgba(44,255,98,.36);
  color:#67ff79;
  font-size:12px;
  font-weight:950;
}
.online-badge:before{
  content:"";
  display:inline-block;
  width:10px;height:10px;
  background:#28ff3d;
  border-radius:999px;
  margin-right:6px;
  vertical-align:-1px;
  box-shadow:0 0 10px rgba(44,255,98,.7);
}
.profile-body{padding:16px 17px 18px}
.name-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.name-row h3{font-size:25px;line-height:1.05;margin:0;letter-spacing:-.55px}
.distance-mini{
  flex:0 0 auto;
  border-radius:999px;
  padding:7px 10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.11);
  color:#efe4fb;
  font-size:12px;
  font-weight:800;
}
.facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.facts span{
  min-height:37px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(255,255,255,.10);
  color:#f1e7fa;
  font-size:12px;
  font-weight:750;
}
.checked-box{
  border-radius:15px;
  padding:12px 13px;
  margin-bottom:14px;
  background:rgba(255,255,255,.065);
  border:1px solid rgba(255,255,255,.10);
  font-size:13px;
  line-height:1.35;
  font-weight:820;
  color:#fff;
}
.checked-box b{color:#ff67bd}
.thumb-row{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:15px}
.thumb{
  position:relative;
  height:84px;
  border-radius:13px;
  overflow:hidden;
  background:#2b173e;
  border:1px solid rgba(255,255,255,.11);
}
.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:blur(4.5px) saturate(1.05) brightness(.78) contrast(1.06);
  transform:scale(1.12);
}
.thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,8,36,.18),rgba(12,3,20,.48))}
.play-dot{
  position:absolute;
  left:50%;top:50%;z-index:2;
  transform:translate(-50%,-50%);
  width:42px;height:42px;
  border-radius:999px;
  background:linear-gradient(135deg,#ff6bc2,#ff2f9c);
  box-shadow:0 12px 24px rgba(255,47,156,.32);
  display:grid;place-items:center;
}
.play-dot:before{content:"";width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:12px solid #fff;margin-left:3px}
.card-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  height:50px;
  border-radius:999px;
  background:linear-gradient(135deg,#d8a2ff,#a65eff 58%,#8e4cff);
  color:#fff;
  text-decoration:none;
  font-weight:950;
  box-shadow:0 14px 30px rgba(166,94,255,.25);
  border:1px solid rgba(255,255,255,.18);
}
.gallery-section{
  margin-top:18px;
  padding:0;
  border:0 !important;
  border-radius:0;
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  overflow:visible !important;
}
.gallery-section:before{display:none !important}
.section-head{position:relative;z-index:2;display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-bottom:14px;padding:0 2px}
.section-head h2{margin:0;font-size:23px;line-height:1.05;letter-spacing:-.7px}
.live-pill{
  flex:0 0 auto;
  border-radius:999px;
  padding:8px 10px;
  background:rgba(44,255,98,.10);
  border:1px solid rgba(44,255,98,.28);
  color:#e4fff0;
  font-weight:900;
  font-size:12px;
}
.premium-card-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:16px}
.premium-card-grid .profile-card{box-shadow:0 12px 32px rgba(0,0,0,.30)}
.bottom-cta{margin-top:14px;border-radius:28px;padding:22px 18px;text-align:center}
.bottom-cta h2{position:relative;z-index:2;margin:12px 0 8px;font-size:27px;letter-spacing:-.8px;line-height:1.05}
.bottom-cta p{position:relative;z-index:2;margin:0 auto 16px;max-width:350px;color:var(--muted);font-size:14px;line-height:1.5}
.primary-btn{
  position:relative;z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  height:52px;
  border-radius:999px;
  background:linear-gradient(135deg,#ff6fc8,#a461ff);
  color:#fff;text-decoration:none;font-weight:950;
  box-shadow:0 14px 34px rgba(255,79,179,.22);
}
.bottom-cta small{position:relative;z-index:2;display:block;margin-top:12px;color:var(--muted2);font-size:12px}
.download-wrap{width:min(100%,430px);margin:0 auto;padding:16px 10px 80px}
.download-card-v2{border-radius:28px;padding:20px 16px 18px;text-align:center}
.download-head{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px}
.download-head img{width:62px;height:62px;border-radius:18px;box-shadow:0 0 0 1px rgba(255,255,255,.15),0 10px 25px rgba(255,79,179,.17)}
.download-head-copy{text-align:left}.download-head-copy strong{display:block;font-size:22px}.download-head-copy em{display:inline-flex;margin-top:6px;border-radius:999px;padding:5px 9px;font-style:normal;font-size:10px;font-weight:950;color:#bdfcdb;border:1px solid rgba(44,255,98,.28);background:rgba(44,255,98,.10);text-transform:uppercase;letter-spacing:.3px}
.selected-profile{position:relative;z-index:2;display:inline-flex;margin:2px auto 12px;padding:8px 12px;border-radius:999px;border:1px solid rgba(247,216,135,.28);background:rgba(247,216,135,.09);color:#ffe7a7;font-weight:900;font-size:12px}
.download-card-v2 h1{position:relative;z-index:2;margin:0 0 8px;font-size:36px;line-height:1.05;letter-spacing:-1px}.download-card-v2 p{position:relative;z-index:2;color:var(--muted);font-size:15px;line-height:1.48;margin:0 auto 14px;max-width:340px}.download-chips{position:relative;z-index:2;display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin:12px 0 16px}.download-chips span{border-radius:999px;padding:8px 10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:800;font-size:12px}.apk-btn{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;height:58px;border-radius:18px;background:linear-gradient(135deg,#28e36d,#16b85a);color:#06140a;text-decoration:none;font-weight:950;font-size:17px;margin:0 auto 14px;box-shadow:0 14px 34px rgba(22,184,90,.24)}.download-help,.inapp-notice,.install-box{position:relative;z-index:2;border-radius:18px;padding:14px;background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.10);text-align:left;margin-top:12px}.download-help{background:rgba(247,216,135,.08);border-color:rgba(247,216,135,.22);color:#fff1c7}.download-help strong,.install-box strong{display:block;margin-bottom:8px}.download-help ol,.install-box ol{margin:0;padding-left:18px;font-size:13px;line-height:1.45}.download-help li+li,.install-box li+li{margin-top:6px}.inapp-notice{background:rgba(255,79,179,.08);border-color:rgba(255,79,179,.18);color:#ffd4ec;font-size:13px;line-height:1.45}.browser-tools{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.browser-tools a,.browser-tools button{height:46px;border-radius:15px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;text-decoration:none;font-weight:900;font-size:13px;display:flex;align-items:center;justify-content:center}.browser-tools button{font:inherit;cursor:pointer}
@media(min-width:760px){
  .page-shell,.download-wrap{width:min(100%,760px)}
  .hero-section{padding:22px}
  .hero-copy{text-align:center}
  .hero-copy h1{font-size:40px}
  .featured-card{max-width:460px;margin:0 auto}
  .premium-card-grid{grid-template-columns:repeat(2,1fr)}
  .profile-image-wrap{height:300px}
}
@media(max-width:385px){
  .page-shell{padding-left:8px;padding-right:8px}
  .hero-section,.gallery-section,.bottom-cta{border-radius:24px}
  .profile-image-wrap{height:275px}
  .profile-card.featured-card .profile-image-wrap{height:305px}
  .profile-body{padding:14px 14px 16px}
  .thumb{height:76px}
  .name-row h3{font-size:22px}
  .facts span{font-size:11px}
  .download-card-v2 h1{font-size:31px}
  .download-head-copy strong{font-size:19px}
}


/* v5 refinements: lighter page background, no outer gallery wrapper, synced blurred thumbnails */
.premium-card-grid .profile-card{
  border-color:rgba(255,255,255,.13);
}
.gallery-section .profile-card{
  margin-top:0;
}
@media(max-width:430px){
  .premium-card-grid{gap:18px}
}

/* v6: flatten the three highlighted controls so the card feels lighter */
.verified-badge{
  top:12px;
  right:12px;
  padding:6px 11px;
  font-size:11px;
  line-height:1.05;
  border-radius:999px;
  box-shadow:0 5px 14px rgba(255,58,165,.18);
}
.online-badge{
  left:13px;
  bottom:13px;
  padding:6px 10px;
  font-size:11px;
  line-height:1.05;
  border-radius:999px;
  border-color:rgba(44,255,98,.30);
  box-shadow:0 5px 13px rgba(44,255,98,.10);
}
.online-badge:before{
  width:8px;
  height:8px;
  margin-right:5px;
  vertical-align:-1px;
  box-shadow:0 0 7px rgba(44,255,98,.55);
}
.card-btn{
  height:44px;
  border-radius:18px;
  font-size:14px;
  box-shadow:0 8px 20px rgba(166,94,255,.18);
  border-color:rgba(255,255,255,.14);
}
@media(max-width:385px){
  .verified-badge{padding:6px 10px;font-size:10.5px;top:10px;right:10px}
  .online-badge{padding:6px 9px;font-size:10.5px;left:11px;bottom:11px}
  .card-btn{height:43px;font-size:14px;border-radius:17px}
}

/* v7: make the profile CTA button slightly narrower and more premium */
.card-btn{
  width:86%;
  margin-left:auto;
  margin-right:auto;
}
@media(max-width:385px){
  .card-btn{width:88%;}
}


/* v8: Online badge uses a transparent grey glass background, and the old dark image mask behind it is removed */
.image-shade{
  display:none !important;
}
.online-badge{
  background:rgba(42,42,54,.48) !important;
  border:1px solid rgba(255,255,255,.18) !important;
  color:#ffffff !important;
  box-shadow:none !important;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.online-badge:before{
  background:#2cff62 !important;
  box-shadow:0 0 7px rgba(44,255,98,.55) !important;
}

/* v9: enlarge status badges, round CTA button, and give the removed name row space back to the image */
.profile-image-wrap{
  height:342px;
}
.profile-card.featured-card .profile-image-wrap{
  height:372px;
}
.name-row{
  display:none !important;
}
.profile-body{
  padding-top:14px;
}
.verified-badge{
  top:12px;
  right:12px;
  padding:8px 14px;
  font-size:12px;
  line-height:1.05;
}
.online-badge{
  left:14px;
  bottom:14px;
  padding:8px 12px;
  font-size:12px;
  line-height:1.05;
}
.online-badge:before{
  width:9px;
  height:9px;
  margin-right:6px;
}
.card-btn{
  border-radius:999px;
}
@media(max-width:385px){
  .profile-image-wrap{
    height:318px;
  }
  .profile-card.featured-card .profile-image-wrap{
    height:348px;
  }
  .profile-body{
    padding-top:12px;
  }
  .verified-badge{
    top:11px;
    right:11px;
    padding:7px 13px;
    font-size:11.5px;
  }
  .online-badge{
    left:12px;
    bottom:12px;
    padding:7px 11px;
    font-size:11.5px;
  }
  .online-badge:before{
    width:9px;
    height:9px;
    margin-right:6px;
  }
  .card-btn{
    border-radius:999px;
  }
}

/* v10: homepage first-screen bubble map with clickable mini profile images */
.home-page{
  background:
    radial-gradient(circle at 50% 0%, rgba(180,31,255,.18), transparent 38%),
    radial-gradient(circle at 8% 35%, rgba(255,45,154,.15), transparent 33%),
    radial-gradient(circle at 92% 22%, rgba(92,111,242,.14), transparent 32%),
    linear-gradient(180deg,#21002d 0%,#170026 46%,#0b0616 100%);
}
.home-page:before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  opacity:.48;
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    radial-gradient(circle, rgba(255,255,255,.18) 1px, transparent 1.5px);
  background-size:34px 34px,34px 34px,22px 22px;
}
.home-page .page-shell{
  padding-top:0;
}
.home-page .site-top{
  display:none;
}
.home-page .hero-section{
  border:0;
  border-radius:0;
  padding:20px 2px 8px;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  overflow:visible;
}
.home-page .hero-section:before{
  display:none;
}
.home-hero-copy{
  text-align:center;
  padding:0 12px 12px;
}
.home-hero-copy h1{
  margin:0 auto 10px;
  max-width:380px;
  font-size:34px;
  line-height:1.08;
  letter-spacing:-1px;
  font-weight:1000;
  background:linear-gradient(90deg,#ff00d4 0%,#bf22ff 44%,#3e7cff 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow:0 0 28px rgba(208,42,255,.20);
}
.home-hero-copy p{
  margin:0 auto;
  color:#fff;
  max-width:310px;
  font-size:14px;
  line-height:1.28;
  font-weight:850;
  text-shadow:0 2px 12px rgba(0,0,0,.30);
}
.hero-start-btn{
  width:180px;
  height:46px;
  margin:16px auto 14px;
  border-radius:999px;
  background:linear-gradient(135deg,#ff4f83 0%,#ff5a99 38%,#5276ff 100%);
  box-shadow:0 12px 28px rgba(255,73,154,.22),0 8px 20px rgba(82,118,255,.16);
  font-size:14px;
}
.hero-bubble-map{
  position:relative;
  z-index:2;
  height:266px;
  margin:0 6px;
  border-radius:10px;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 50%, rgba(138,64,255,.16), transparent 32%),
    radial-gradient(circle at 50% 78%, rgba(255,45,154,.10), transparent 34%),
    rgba(29,0,55,.50);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.025),0 18px 42px rgba(0,0,0,.22);
}
.map-grid{
  position:absolute;
  inset:0;
  opacity:.60;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:33px 33px;
}
.map-grid:after{
  content:"";
  position:absolute;
  inset:-1px;
  background:radial-gradient(circle at 50% 50%, transparent 0 36%, rgba(12,0,25,.20) 76%, rgba(12,0,25,.42) 100%);
}
.map-dot{
  position:absolute;
  width:6px;
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.42);
  box-shadow:0 0 14px rgba(255,255,255,.16);
  animation:mapDotFloat 4s ease-in-out infinite;
}
.map-dot.dot-a{left:15%;top:31%;animation-delay:.1s}
.map-dot.dot-b{left:29%;top:47%;animation-delay:.5s}
.map-dot.dot-c{left:48%;top:25%;animation-delay:.9s}
.map-dot.dot-d{left:66%;top:62%;animation-delay:1.3s}
.map-dot.dot-e{left:82%;top:32%;animation-delay:1.7s}
.map-radar-core{
  position:absolute;
  left:50%;
  top:50%;
  z-index:2;
  width:18px;
  height:18px;
  border-radius:999px;
  transform:translate(-50%,-50%);
  border:3px solid rgba(255,255,255,.92);
  background:linear-gradient(135deg,#7d69ff,#ff61e6);
  box-shadow:0 0 0 5px rgba(139,88,255,.28),0 0 30px rgba(255,97,230,.62);
  animation:mapCoreBlink 1.15s ease-in-out infinite;
}
.map-radar-core:before,
.map-radar-core:after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:100%;
  height:100%;
  border-radius:999px;
  border:2px solid rgba(191,99,255,.55);
  transform:translate(-50%,-50%) scale(1);
  animation:mapCoreRipple 2s ease-out infinite;
}
.map-radar-core:after{
  animation-delay:.72s;
  border-color:rgba(255,97,230,.42);
}
.mini-profile-pin{
  position:absolute;
  left:var(--x);
  top:var(--y);
  z-index:4;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:0;
  border:0;
  background:transparent;
  color:#fff;
  cursor:pointer;
  font:inherit;
  transform:translate(-50%,-50%) scale(1);
  transform-origin:center center;
  transition:transform .18s ease, filter .18s ease, z-index .18s ease;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.mini-profile-pin:hover,
.mini-profile-pin:focus-visible,
.mini-profile-pin.is-active{
  z-index:10;
  transform:translate(-50%,-50%) scale(1.14);
  filter:drop-shadow(0 14px 20px rgba(0,0,0,.32));
}
.mini-profile-pin:focus-visible{
  outline:0;
}
.mini-avatar{
  position:relative;
  display:block;
  width:var(--s);
  height:var(--s);
  border-radius:999px;
  padding:2px;
  background:#fff;
  box-shadow:0 8px 18px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.35);
}
.mini-avatar img{
  width:100%;
  height:100%;
  border-radius:inherit;
  object-fit:cover;
}
.mini-online-dot{
  position:absolute;
  right:-3px;
  bottom:2px;
  width:13px;
  height:13px;
  border-radius:999px;
  background:#2cff36;
  border:2px solid #fff;
  box-shadow:0 0 12px rgba(44,255,54,.78);
  animation:miniOnlineBlink 1.18s ease-in-out infinite;
  animation-delay:var(--d);
}
.mini-online-dot:after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:999px;
  border:1px solid rgba(44,255,54,.48);
  animation:miniOnlineRipple 1.55s ease-out infinite;
  animation-delay:var(--d);
}
.mini-distance{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:45px;
  height:18px;
  margin-top:4px;
  padding:0 8px;
  border-radius:999px;
  background:linear-gradient(135deg,#b56aff,#784bf2);
  color:#fff;
  font-size:10px;
  font-weight:950;
  line-height:1;
  white-space:nowrap;
  box-shadow:0 8px 16px rgba(98,58,218,.26);
}
@keyframes miniOnlineBlink{
  0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 9px rgba(44,255,54,.65)}
  50%{opacity:.62;transform:scale(.78);box-shadow:0 0 20px rgba(44,255,54,1)}
}
@keyframes miniOnlineRipple{
  0%{opacity:.70;transform:scale(.35)}
  70%,100%{opacity:0;transform:scale(1.55)}
}
@keyframes mapCoreBlink{
  0%,100%{opacity:1;box-shadow:0 0 0 5px rgba(139,88,255,.28),0 0 30px rgba(255,97,230,.62)}
  50%{opacity:.68;box-shadow:0 0 0 8px rgba(139,88,255,.18),0 0 46px rgba(255,97,230,.95)}
}
@keyframes mapCoreRipple{
  0%{opacity:.85;transform:translate(-50%,-50%) scale(.65)}
  80%,100%{opacity:0;transform:translate(-50%,-50%) scale(3.4)}
}
@keyframes mapDotFloat{
  0%,100%{transform:translateY(0);opacity:.34}
  50%{transform:translateY(-8px);opacity:.72}
}
.home-page .gallery-section{
  margin-top:18px;
}
@media(max-width:385px){
  .home-page .hero-section{
    padding-top:18px;
  }
  .home-hero-copy h1{
    font-size:31px;
  }
  .home-hero-copy p{
    font-size:13px;
  }
  .hero-start-btn{
    width:176px;
    height:44px;
    margin-top:14px;
  }
  .hero-bubble-map{
    height:250px;
    margin-left:4px;
    margin-right:4px;
  }
  .mini-distance{
    min-width:42px;
    height:17px;
    font-size:9px;
  }
}

/* v11: make the hero bubble panel lighter/clearer and add soft decorative details */
.hero-bubble-map{
  isolation:isolate;
  background:
    radial-gradient(circle at 50% 50%, rgba(149,76,255,.15), transparent 34%),
    radial-gradient(circle at 18% 16%, rgba(255,72,190,.13), transparent 28%),
    radial-gradient(circle at 88% 82%, rgba(91,127,255,.13), transparent 34%),
    rgba(58,0,92,.28);
  border-color:rgba(255,255,255,.13);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 24px 70px rgba(255,255,255,.025),
    0 16px 36px rgba(0,0,0,.16);
}
.hero-bubble-map:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 12% 22%, rgba(255,255,255,.12) 0 2px, transparent 3px),
    radial-gradient(circle at 23% 58%, rgba(255,255,255,.18) 0 2px, transparent 3px),
    radial-gradient(circle at 67% 24%, rgba(255,255,255,.15) 0 2px, transparent 3px),
    radial-gradient(circle at 82% 66%, rgba(255,255,255,.16) 0 2px, transparent 3px),
    linear-gradient(135deg, rgba(255,255,255,.05), transparent 42%, rgba(255,255,255,.035));
  opacity:.78;
}
.hero-bubble-map:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 10% 88%, rgba(255,72,190,.12), transparent 24%),
    radial-gradient(circle at 91% 13%, rgba(125,104,255,.13), transparent 22%);
  opacity:.82;
}
.map-grid{
  z-index:1;
  opacity:.42;
}
.map-grid:after{
  background:radial-gradient(circle at 50% 50%, transparent 0 48%, rgba(12,0,25,.08) 78%, rgba(12,0,25,.16) 100%);
}
.map-dot{
  z-index:2;
  background:rgba(255,255,255,.48);
  box-shadow:0 0 16px rgba(255,255,255,.20);
}
.map-radar-core{
  z-index:3;
}
.map-deco{
  position:absolute;
  z-index:2;
  pointer-events:none;
  user-select:none;
  opacity:.66;
  filter:drop-shadow(0 0 12px rgba(255,107,213,.16));
  animation:mapDecoFloat 5.2s ease-in-out infinite;
}
.deco-ring{
  border:1.5px solid rgba(255,255,255,.18);
  border-radius:999px;
  box-shadow:inset 0 0 16px rgba(255,255,255,.04),0 0 20px rgba(255,86,203,.08);
}
.deco-ring-a{
  left:7%;
  top:14%;
  width:34px;
  height:34px;
  border-color:rgba(255,72,190,.25);
  animation-delay:.2s;
}
.deco-ring-b{
  right:9%;
  bottom:11%;
  width:46px;
  height:46px;
  border-color:rgba(137,118,255,.22);
  animation-delay:1.1s;
}
.deco-heart{
  color:rgba(255,218,245,.46);
  font-size:15px;
  line-height:1;
  text-shadow:0 0 16px rgba(255,105,202,.22);
}
.deco-heart-a{
  right:7%;
  top:16%;
  animation-delay:.7s;
}
.deco-plus{
  color:rgba(255,255,255,.22);
  font-size:19px;
  font-weight:900;
  line-height:1;
}
.deco-plus-a{
  left:14%;
  top:40%;
  animation-delay:1.6s;
}
.deco-plus-b{
  right:21%;
  top:28%;
  font-size:15px;
  color:rgba(255,92,203,.26);
  animation-delay:2.3s;
}
.deco-star{
  color:rgba(184,123,255,.38);
  font-size:22px;
  line-height:1;
}
.deco-star-a{
  left:6%;
  bottom:25%;
  animation-delay:1s;
}
.deco-tiny-dot{
  width:5px;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,.34);
  box-shadow:0 0 13px rgba(255,255,255,.20);
}
.deco-tiny-dot-a{left:36%;top:18%;animation-delay:.4s}
.deco-tiny-dot-b{left:58%;bottom:17%;animation-delay:1.4s}
.deco-tiny-dot-c{right:15%;top:56%;animation-delay:2.1s}
@keyframes mapDecoFloat{
  0%,100%{transform:translate3d(0,0,0) rotate(0deg);opacity:.46}
  50%{transform:translate3d(0,-8px,0) rotate(8deg);opacity:.78}
}
@media(max-width:385px){
  .deco-ring-a{width:30px;height:30px}
  .deco-ring-b{width:40px;height:40px}
  .deco-heart{font-size:14px}
  .deco-plus{font-size:17px}
  .deco-star{font-size:20px}
}

/* v12: simplified profile section heading */
.section-head-simple {
  justify-content: flex-start;
  align-items: center;
}
.section-head-simple h2 {
  margin: 0;
}


/* v13: bottom CTA rebuilt to match the lonely/singles reference card */
.lonely-cta{
  margin-top:22px;
  border:0;
  border-radius:20px;
  padding:39px 22px 36px;
  text-align:center;
  background:
    radial-gradient(circle, rgba(255,255,255,.12) 1px, transparent 1.8px),
    linear-gradient(135deg,#ff456d 0%,#e753b7 46%,#3268ff 100%);
  background-size:14px 14px, 100% 100%;
  background-position:0 0, center;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.lonely-cta:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.18), transparent 22%),
    radial-gradient(circle at 84% 18%, rgba(255,255,255,.10), transparent 24%),
    radial-gradient(circle at 50% 100%, rgba(255,255,255,.08), transparent 34%);
  opacity:.62;
}
.lonely-cta:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
}
.lonely-cta h2{
  position:relative;
  z-index:2;
  margin:0;
  color:#fff;
  font-size:26px;
  line-height:1.35;
  letter-spacing:-.45px;
  font-weight:1000;
  text-shadow:0 3px 14px rgba(0,0,0,.18);
}
.contact-now-btn{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  width:min(260px,100%);
  height:50px;
  margin:24px auto 22px;
  border-radius:18px;
  background:#08bd4e;
  color:#fff;
  text-decoration:none;
  font-size:16px;
  font-weight:950;
  box-shadow:0 12px 24px rgba(0,0,0,.14);
}
.lonely-cta p{
  position:relative;
  z-index:2;
  margin:0 auto;
  max-width:315px;
  color:#fff;
  font-size:16px;
  line-height:1.45;
  font-weight:700;
  text-shadow:0 2px 10px rgba(0,0,0,.14);
}
@media(max-width:385px){
  .lonely-cta{
    margin-top:20px;
    border-radius:19px;
    padding:36px 18px 33px;
  }
  .lonely-cta h2{
    font-size:24px;
  }
  .contact-now-btn{
    width:min(260px,100%);
    height:49px;
    margin:23px auto 21px;
  }
  .lonely-cta p{
    font-size:15px;
  }
}

/* v14: larger mobile-friendly type, lighter font weight, centered English layout */
body{
  font-size:17px;
  font-weight:400;
  text-align:center;
}
body *{
  font-weight:400 !important;
}
h1,h2,h3,strong,b,
.top-btn,.primary-btn,.card-btn,.contact-now-btn,.download-btn-main,
.download-head-copy strong,.download-badge,.download-tags span,
.verified-badge,.online-badge,.mini-distance{
  font-weight:500 !important;
}
.page-shell,
.download-wrap,
.hero-copy,
.home-hero-copy,
.section-head,
.profile-body,
.download-card-v2,
.download-head-copy,
.checked-box,
.facts span{
  text-align:center;
}
.site-top,
.brand,
.download-head,
.section-head,
.facts span,
.browser-tools a,
.browser-tools button{
  justify-content:center;
}
.site-top{
  gap:12px;
  flex-wrap:wrap;
}
.brand{
  flex:1 1 100%;
}
.brand span{
  text-align:center;
}
.top-btn{
  margin:0 auto;
}
.home-hero-copy h1{
  font-size:36px;
  line-height:1.08;
  letter-spacing:-.65px;
}
.home-hero-copy p{
  font-size:15px;
  line-height:1.35;
}
.hero-start-btn{
  font-size:15px;
}
.section-head,
.section-head-simple{
  justify-content:center;
  align-items:center;
}
.section-head h2{
  font-size:25px;
  line-height:1.15;
  letter-spacing:-.45px;
}
.verified-badge,
.online-badge{
  font-size:13px;
}
.facts span{
  font-size:13px;
  line-height:1.25;
  padding:0 8px;
}
.checked-box{
  font-size:14px;
  line-height:1.45;
}
.card-btn{
  font-size:15px;
}
.mini-distance{
  min-width:48px;
  height:19px;
  font-size:11px;
}
.lonely-cta h2{
  font-size:28px;
  line-height:1.32;
  letter-spacing:-.25px;
}
.contact-now-btn{
  font-size:17px;
}
.lonely-cta p{
  font-size:17px;
  line-height:1.45;
}
.download-head{
  flex-direction:column;
}
.download-head-copy{
  text-align:center;
}
.download-head-copy strong{
  display:block;
  font-size:24px;
  line-height:1.15;
}
.download-head-copy span{
  display:inline-flex;
  margin-top:8px;
  border-radius:999px;
  padding:6px 10px;
  color:#bdfcdb;
  border:1px solid rgba(44,255,98,.28);
  background:rgba(44,255,98,.10);
  text-transform:uppercase;
  letter-spacing:.3px;
  font-size:11px;
}
.download-badge{
  position:relative;
  z-index:2;
  display:inline-flex;
  justify-content:center;
  margin:4px auto 14px;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(247,216,135,.28);
  background:rgba(247,216,135,.09);
  color:#ffe7a7;
  font-size:13px;
}
.download-card-v2 h1{
  font-size:38px;
  line-height:1.08;
  letter-spacing:-.5px;
}
.download-card-v2 p,
.download-copy{
  font-size:16px;
  line-height:1.55;
}
.download-tags{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
  margin:14px 0 17px;
}
.download-tags span{
  border-radius:999px;
  padding:8px 10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:13px;
}
.download-btn-main{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  padding:0 18px;
  border-radius:20px;
  background:linear-gradient(135deg,#28e36d,#16b85a);
  color:#06140a;
  text-decoration:none;
  font-size:17px;
  line-height:1.2;
  margin:0 auto 14px;
  box-shadow:0 14px 34px rgba(22,184,90,.24);
}
.download-help,
.inapp-notice,
.install-box{
  text-align:center;
  font-size:14px;
  line-height:1.5;
}
.download-help ol,
.install-box ol{
  display:inline-block;
  width:auto;
  max-width:100%;
  padding-left:20px;
  text-align:left;
  font-size:14px;
}
.browser-tools a,
.browser-tools button{
  font-size:14px;
}
@media(max-width:385px){
  body{
    font-size:16px;
  }
  .home-hero-copy h1{
    font-size:33px;
  }
  .home-hero-copy p{
    font-size:14px;
  }
  .section-head h2{
    font-size:23px;
  }
  .verified-badge,
  .online-badge{
    font-size:12px;
  }
  .facts span{
    font-size:12px;
  }
  .checked-box{
    font-size:13px;
  }
  .card-btn{
    font-size:14px;
  }
  .mini-distance{
    min-width:45px;
    font-size:10px;
  }
  .lonely-cta h2{
    font-size:26px;
  }
  .contact-now-btn,
  .lonely-cta p{
    font-size:16px;
  }
  .download-card-v2 h1{
    font-size:34px;
  }
  .download-card-v2 p,
  .download-copy{
    font-size:15px;
  }
  .download-head-copy strong{
    font-size:22px;
  }
}


/* v15: blinking online card dot, editable first-screen mini photos, stronger glowing hero title, and refined section spacing */
.home-hero-copy h1{
  font-weight:950 !important;
  background:linear-gradient(92deg,#ff14df 0%,#d54cff 42%,#62b0ff 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  filter:
    drop-shadow(0 0 10px rgba(255,20,223,.62))
    drop-shadow(0 0 24px rgba(156,76,255,.46))
    drop-shadow(0 7px 18px rgba(0,0,0,.28));
}
.online-badge{
  overflow:visible;
}
.online-badge:before{
  animation:onlineBadgeDotBlink 1.12s ease-in-out infinite;
}
.online-badge:after{
  content:"";
  position:absolute;
  left:16.5px;
  top:50%;
  width:9px;
  height:9px;
  border-radius:999px;
  border:1px solid rgba(44,255,98,.46);
  transform:translate(-50%,-50%) scale(.45);
  opacity:.75;
  pointer-events:none;
  animation:onlineBadgeDotRipple 1.55s ease-out infinite;
}
@keyframes onlineBadgeDotBlink{
  0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 8px rgba(44,255,98,.70)}
  50%{opacity:.58;transform:scale(.76);box-shadow:0 0 18px rgba(44,255,98,1)}
}
@keyframes onlineBadgeDotRipple{
  0%{opacity:.72;transform:translate(-50%,-50%) scale(.55)}
  75%,100%{opacity:0;transform:translate(-50%,-50%) scale(2.25)}
}
.home-page .gallery-section{
  margin-top:24px;
  padding-left:6px;
  padding-right:6px;
}
.home-page .section-head,
.home-page .section-head-simple{
  margin:0 auto 18px;
  padding:0;
}
.home-page .section-head h2{
  font-size:28px;
  line-height:1.14;
  font-weight:500 !important;
}
@media(max-width:385px){
  .home-page .gallery-section{
    margin-top:22px;
    padding-left:4px;
    padding-right:4px;
  }
  .home-page .section-head,
  .home-page .section-head-simple{
    margin-bottom:16px;
  }
  .home-page .section-head h2{
    font-size:25px;
  }
  .online-badge:after{
    left:15px;
    width:9px;
    height:9px;
  }
}
