* {
	box-sizing: border-box;
}

body {
	background: #f5f5f5;
	height: 100%;
    font-family: 'DM Sans', sans-serif;
    font-weight: normal;
    margin: 0;
	padding: 0;
    overflow-x: hidden;
    font-size: 14px;
}

html {
	height: 100%;
    margin: 0;
	padding: 0;
}


h1{
    font-weight: 600;
}

a{
    text-decoration: none;
    cursor: pointer;
}

button{
    cursor: pointer;
}

:focus {
    outline: -webkit-focus-ring-color auto 0px;
}

::placeholder {
  color: #b1b1b1;
}

.clear{
    clear: both;
}

.middle{
    display: flex;
    align-items: center;
}

textarea, input, select{
    font-family: 'DM Sans', sans-serif;
    font-weight: normal;
}

.wrap{
    position: relative;
    width: 100%;
    margin: 0 auto;
}

.header{
    position: fixed;
    z-index: 3;
    width: 100%;
    background: #f5f5f5;
    transition: all .25s ease-in-out;
}

.header_fake{
    position: relative;
    width: 100%;
    height: 207px;
}

.top1{
    position: relative;
    text-align: center;
    padding: 20px 20px 0 20px;
    z-index: 2;
    height: 135px;
}

.perfil{
    position: relative;
    height: 70px;
    width: 210px;
    background-size: contain;
    background-position: center;
    margin: 0 auto 5px auto;
    background-repeat: no-repeat;
}

.top2-margim{
    position: relative;
    width: 100%;
    height: 20px;
}

.top2{
    position: relative;
    width: 100%;
    padding: 16px 15px 16px 15px;
    display: flex;
    color: #515151;
    align-items: center;
    cursor: pointer;
    flex-wrap: nowrap;
    justify-content: center;
}

.filtros_01{
    font-size: 15px;
    font-weight: 600;
}

.filtros_02{
    margin-right: 8px;
    height: 20px;
}

.filtros_02 i{
    font-size: 20px
}

.endereco_out{
    position: absolute;
    width: 94%;
    bottom: -17px;
    left: 50%;
    max-width: 800px;
    transform: translate(-50%, 0px);
}

.endereco{
    width: 100%;
    padding: 10px;
    border: 0;
    margin: 0;
    border-radius: 4px;
    font-size: 15px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 500;
}

.endereco_out::before {
    content: "\e913";
    font-family: 'icomoon' !important;
    position: absolute;
    right: 12px;
    top: 8px;
    pointer-events: none;
    font-size: 20px;
    color: #8f8f8f;
    z-index: 1;
}

.raio{
    text-align: center;
}

.raio select{
    -webkit-appearance: textfield;
   padding: 5px 10px;
    background: #ffffff;
    color: #393939;
    margin: 4px;
    border: 0px solid #d1d1d1;
    border-radius: 8px;
    text-align: left;
    font-size: 14px;
    font-weight: 600;
}

.points{
    position: relative;
    background: #fff;
    width: 94%;
    margin: 12px auto;
    border-radius: 10px;
    padding: 20px;
    z-index: 1;
    max-width: 800px;
}

.square{
    display: none;
    position: absolute;
    top: 24px;
    width: 7px;
    height: 15px;
    background: #29c6c9;
    border-radius: 2px;
    margin-right: 5px;
}

.points h1{
    display: inline-block;
    color: #000;
    font-size: 18px;
    margin: 0;
    font-weight: 600;
}

.points h2{
    color: #515151;
    font-size: 15px;
    font-weight: 500;
    margin: 5px 0 5px 0;
}

.points h2 a{
    color: #515151;
}

.points h3{
    color: #515151;
    font-size: 15px;
    font-weight: 500;
    margin: 12px 0 10px 0;
}

.km{
    position: relative;
    color: #878787;
    font-size: 14px;
    margin-top: 5px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.cupom{
    position: relative;
}

.icons{
    margin-top: 15px;
}


.icons i{
    color: #ffffff;
    font-size: 17px;
    margin-right: 7px;
    background: #29c6c9;
    width: 27px;
    text-align: center;
    height: 27px;
    border-radius: 6px;
    display: inline-flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
}

.icons-dest{
    position: relative;
}

.bts_action{
    margin-top: 15px;
    font-size: 15px;
    text-align: center;
    border-radius: 4px;
    padding: 8px;
    width: 100%;
    display: block;
    border: 1px solid #24d366;
    color: #24d366;
    cursor: pointer;
    font-weight: 600;
    display: flex;
    flex-wrap: wrap;
    align-content: stretch;
    justify-content: center;
    align-items: center;
}

.icons-dest i{
    margin-right: 7px;
    font-size: 18px;
}

.bt_whats{
    border: 0;
    background: #24d366;
    color: #fff !important;
}

.flex{
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    justify-content: flex-start;
    align-items: flex-start;
    margin: 10px 0;
}

.flex h3{
    margin: 0;
}

.icon-relogio{
    font-size: 16px;
    margin: 1px 5px 0 0;
    color: #515151;
}

footer{
    position: fixed;
    z-index: 1;
    bottom: 0;
    width: 100%;
    height: 36px;
    background-color: #f7f6f6;
    background-image: url(img/moov-assinatura-cinza.svg);
    background-size: 60px;
    background-position: center;
    background-repeat: no-repeat;
}

.alerta, .cupom-txt{
    display: none;
    position: fixed;
    z-index: 4;
    background: rgba(53, 57, 66, 0.8);
    width: 100%;
    height: 100%;
    top: 0;
}

.alerta-in{
    position: absolute;
    width: 400px;
    max-width: 80%;
    border-radius: 10px;
    left: 50%;
    top: 50%;
    background: #eaebec;
    transform: translate(-50%, -50%);
    text-align: center;
    padding: 30px;
    font-size: 15px
}

.alerta-in h1{
    color: #5d6168;
    font-size: 18px;
    margin: 0 0 20px 0;
}

.alerta-in h2{
    color: #5d6168;
    font-size: 13px;
    margin: 0 0 10px 0;
    font-weight: normal;
}

.alerta-in button{
    cursor: pointer;
    background: #5d6168;
    padding: 8px 15px;
    border-radius: 8px;
    color: #eaebec;
    margin: 10px 0;
    width: 100%;
    font-weight: 600;
    border: 2px solid #5d6168;
}

.alerta-in input{
    padding: 5px;
    width: 100%;
    border-radius: 4px;
    border: 0;
    margin-bottom: 8px;
}

.alerta-in .btn_sim{
    background: transparent;
    color: #5d6168;
}

.alerta-in button:hover{
    background: #29c6c9;
}

.alerta-fechar{
    position: absolute;
    width: 100%;
    height: 100%;
}

.no-result{
    margin: 20px;
    color: #ff0000;
    font-size: 16px;
    text-align: center;
    line-height: 28px;
}

.btngeo{
    font-size: 15px;
    text-align: center;
    border-radius: 4px;
    background: #24d366;
    color: #fff;
    width: 247px;
    margin: 0 auto;
    padding: 15px;
    display: none;
    border: 0;
}

#txt-inicial {
    margin: -20px 20px 20px 20px;
}

.slider_raio_out {
    background: #fff;
    border-radius: 6px;
    padding: 11px 18px 7px 18px;
    margin-top: 10px;
}

#filtros{
    font-weight: 600;
}

.filtros-title{
    text-align: left;
    color: #696969;
}

.filtros-title span{
    font-size: 16px;
    color: #000;
}

.filtros_cat{
    margin-top: 20px;
}
.filtros_cat ul{
    text-align: left;
    list-style: none;
    padding: 0 0 0 10px;
    margin: 0;
    max-height: 450px;
    overflow: auto;
}

.filtros_cat ul li{
    border-bottom: 1px solid #ccc;
    padding: 0px 0 10px 0;
    margin: 10px 0;
    color: #696969;
    cursor: pointer;
    transition: all .2s ease-in-out;
}

.filtros_cat ul li i{
    margin-right: 5px;
}

.filtros_cat ul li.active{
    padding: 0px 0 10px 10px;
}

.filtros_cat ul li.selected{
    padding: 0px 0 10px 5px;
}

.filtros_cat ul li:first-child {
  border-top: 1px solid #ccc;
    padding-top: 10px;
}

.alerta-in .icon-fechar{
    position: absolute;
    right: 18px;
    top: 18px;
    cursor: pointer;
}

/* === range theme and appearance === */
input[type="range"] {
	width: 100%;
}

input[type="range"] {
	--thumb-height: 18px;
	--track-height: 2px;
	--track-color: rgba(0, 0, 0, 0.2);
	--brightness-hover: 180%;
	--brightness-down: 80%;
	--clip-edges: 0.125em;
}

	input[type="range"] {
		--track-color: #ccc;
	}


/* === range commons === */
input[type="range"] {
	position: relative;
	background: #fff0;
	overflow: hidden;
}

input[type="range"]:active {
	cursor: grabbing;
}

/* === WebKit specific styles === */
input[type="range"],
input[type="range"]::-webkit-slider-runnable-track,
input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	transition: all ease 100ms;
	height: var(--thumb-height);
}

input[type="range"]::-webkit-slider-runnable-track,
input[type="range"]::-webkit-slider-thumb {
	position: relative;
}

input[type="range"]::-webkit-slider-thumb {
	--thumb-radius: calc((var(--thumb-height) * 0.5) - 1px);
	--clip-top: calc((var(--thumb-height) - var(--track-height)) * 0.5 - 0.5px);
	--clip-bottom: calc(var(--thumb-height) - var(--clip-top));
	--clip-further: calc(100% + 1px);
	--box-fill: calc(-100vmax - var(--thumb-width, var(--thumb-height))) 0 0
		100vmax currentColor;

	width: var(--thumb-width, var(--thumb-height));
	background: linear-gradient(currentColor 0 0) scroll no-repeat left center /
		50% calc(var(--track-height) + 1px);
	background-color: currentColor;
	box-shadow: var(--box-fill);
	border-radius: var(--thumb-width, var(--thumb-height));

	clip-path: polygon(
		100% -1px,
		var(--clip-edges) -1px,
		0 var(--clip-top),
		-100vmax var(--clip-top),
		-100vmax var(--clip-bottom),
		0 var(--clip-bottom),
		var(--clip-edges) 100%,
		var(--clip-further) var(--clip-further)
	);
}



input[type="range"]::-webkit-slider-runnable-track {
	background: linear-gradient(var(--track-color) 0 0) scroll no-repeat center /
		100% calc(var(--track-height) + 1px);
}

input[type="range"]:disabled::-webkit-slider-thumb {
	cursor: not-allowed;
}

/* === Firefox specific styles === */
input[type="range"],
input[type="range"]::-moz-range-track,
input[type="range"]::-moz-range-thumb {
	appearance: none;
	transition: all ease 100ms;
	height: var(--thumb-height);
}

input[type="range"]::-moz-range-track,
input[type="range"]::-moz-range-thumb,
input[type="range"]::-moz-range-progress {
	background: #fff0;
}

input[type="range"]::-moz-range-thumb {
	background: currentColor;
	border: 0;
	width: var(--thumb-width, var(--thumb-height));
	border-radius: var(--thumb-width, var(--thumb-height));
	cursor: grab;
}

input[type="range"]:active::-moz-range-thumb {
	cursor: grabbing;
}

input[type="range"]::-moz-range-track {
	width: 100%;
	background: var(--track-color);
}

input[type="range"]::-moz-range-progress {
	appearance: none;
	background: currentColor;
	transition-delay: 30ms;
}

input[type="range"]::-moz-range-track,
input[type="range"]::-moz-range-progress {
	height: calc(var(--track-height) + 1px);
	border-radius: var(--track-height);
}

input[type="range"]::-moz-range-thumb,
input[type="range"]::-moz-range-progress {
	filter: brightness(100%);
}

input[type="range"]:hover::-moz-range-thumb,
input[type="range"]:hover::-moz-range-progress {
	filter: brightness(var(--brightness-hover));
}

input[type="range"]:active::-moz-range-thumb,
input[type="range"]:active::-moz-range-progress {
	filter: brightness(var(--brightness-down));
}

input[type="range"]:disabled::-moz-range-thumb {
	cursor: not-allowed;
}


#loader_circ {
    position: absolute;
    width: 50px;
    left: 50%;
    margin-left: -25px;
    z-index: 0;
    top: 250px;
    aspect-ratio: 1;
    border-radius: 50%;
    border: 8px solid #838383;
  animation:
    l20-1 0.8s infinite linear alternate,
    l20-2 1.6s infinite linear;
}
@keyframes l20-1{
   0%    {clip-path: polygon(50% 50%,0       0,  50%   0%,  50%    0%, 50%    0%, 50%    0%, 50%    0% )}
   12.5% {clip-path: polygon(50% 50%,0       0,  50%   0%,  100%   0%, 100%   0%, 100%   0%, 100%   0% )}
   25%   {clip-path: polygon(50% 50%,0       0,  50%   0%,  100%   0%, 100% 100%, 100% 100%, 100% 100% )}
   50%   {clip-path: polygon(50% 50%,0       0,  50%   0%,  100%   0%, 100% 100%, 50%  100%, 0%   100% )}
   62.5% {clip-path: polygon(50% 50%,100%    0, 100%   0%,  100%   0%, 100% 100%, 50%  100%, 0%   100% )}
   75%   {clip-path: polygon(50% 50%,100% 100%, 100% 100%,  100% 100%, 100% 100%, 50%  100%, 0%   100% )}
   100%  {clip-path: polygon(50% 50%,50%  100%,  50% 100%,   50% 100%,  50% 100%, 50%  100%, 0%   100% )}
}
@keyframes l20-2{ 
  0%    {transform:scaleY(1)  rotate(0deg)}
  49.99%{transform:scaleY(1)  rotate(135deg)}
  50%   {transform:scaleY(-1) rotate(0deg)}
  100%  {transform:scaleY(-1) rotate(-135deg)}
}

.conteudo{
    position: relative;
    width: 100%;
    max-width: 1200px;
    display: flex;
    justify-content: center;
    margin: 0 auto;
}

.pontos_out{
    width: 40%;
    height: 100%;
    overflow-y: auto;
}

.map_out{
    width: 60%;
    height: auto;
    padding: 12px 15px 4px 0;
}

#map{
    width: 100%;
    height: 100%;
    border-radius: 10px;
}

.gm-ui-hover-effect {
    opacity: 1;
    position: absolute !important;
    background: #fff !important;
    border-radius: 50%;
    height: 32px !important;
    width: 32px !important;
    top: -18px;
    right: -18px;
    box-shadow: 0 0 4px #0000007a;
    display: flex !important;
    align-items: center;
    justify-content: space-around;
}

.gm-style .gm-style-iw-c {
    overflow: visible;
}

.gm-ui-hover-effect>span {
    background-color: #4b4b4b;
    margin: 0 !important;
}

.gm-style-iw-ch {
    padding-top: 10px;
}

/* ----------------------------------------------------------------*/

@media screen and (min-width: 751px) {
    .wrap {
       min-height: 760px;
        height: 100%;
}
    
    .conteudo{
    height: calc(100% - 237px);
    gap: 12px;
    min-height: 515px;
}
}


/* ----------------------------------------------------------------*/

@media screen and (max-width: 750px) {
    .map_out {
    display: none;
}
    .pontos_out {
    width: 100%;
    height: auto;
    }
}


/* ----------------------------------------------------------------*/

@media screen and (min-width: 1200px) {
    
    ::-webkit-scrollbar {
  width: 14px;               /* width of the entire scrollbar */
}

::-webkit-scrollbar-track {
  background: #f7f6f6;  /* color of the tracking area */
}

::-webkit-scrollbar-thumb {
  background-color: #afafaf;    /* color of the scroll thumb */
  border-radius: 20px;       /* roundness of the scroll thumb */
  border: 3px solid #f7f6f6;  /* creates padding around scroll thumb */
}

    
}

