/*----------------------------------------------*/
/*  Calendar                                    */
/*----------------------------------------------*/
.new-calendar
{
	width: 100%;
	display: block;
	margin-bottom: 15px;
	background-color: transparent;
	/* padding: 15px; */
	position: relative;
	/* font-family: 'Montserrat', sans-serif !important; */
}

.new-calendar .loading-calendar
{
	position: absolute;
	top: 0;
	left: 0;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.85);
	display: none;
}

.new-calendar .loading-calendar .loading
{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.new-calendar .loading-calendar .loading .fa
{
	margin: 0;
	position: absolute;				/* 2 */
	top: 50%;						/* 3 */
	transform: translate(0, -50%);	/* 4 */
	display: block;
	text-align: center;
	color: #D3D3D3;
}

.new-calendar .calendar-content
{
	background-color: #FFF;
	/* box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19); */
}

.new-calendar .calendar-content .calendar-header
{
	padding-top: 20px;
	padding-bottom: 20px;
	margin-bottom: 5px;
	border-bottom: 1px solid rgba(0,0,0,0.2);
	position: relative;
	text-align: center;
	height: auto;
	position: relative;
}

.new-calendar .btn-calendar
{
	background-color: transparent;
	border: none;
	cursor: pointer;
	font-size: 16px;
	padding: 5px;
	transition: 0.3s all linear;
	opacity: 0.5;
}

.new-calendar .btn-calendar:hover,
.new-calendar .btn-calendar:focus,
.new-calendar .btn-calendar:active
{
	transition: 0.3s all linear;
	opacity: 1;
	transform: scale(1.2);
}


.new-calendar .calendar-content .calendar-header .btn-search
{
	position: absolute;
	top: 20px;
	left: 15px;
	font-size: 16px;
}

.new-calendar .calendar-content .calendar-header .btn-today
{
	position: absolute;
	top: 14px;
	right: 15px;
	font-size: 18px;
}

.new-calendar .calendar-content .calendar-header .calendar-header-info
{
	margin-left: auto;
	margin-right: auto;
	display: inline-block;
	height: auto;
}

.new-calendar .calendar-content .calendar-header .calendar-header-info .month-calendar,
.new-calendar .calendar-content .calendar-header .calendar-header-info .year-calendar
{
	font-size: 18px;
	line-height: 18px;
	display: inline-block;
	height: auto;
}

.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-prev-month
{

	font-size: 20px;
	position: absolute;
	top: 14px;
	left: 45px;
}

.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-next-month
{
	font-size: 20px;
	position: absolute;
	top: 14px;
	right: 45px;
}


.new-calendar .calendar-content .calendar-rows
{
	position: relative;
	clear: both;
	display: table;
	width: 100%;
	box-sizing: border-box;
}

.new-calendar .calendar-content .calendar-rows .calendar-weekdays
{
	position: relative;
	clear: both;
	display: table;
	width: 100%;
	height: auto;
	box-sizing: border-box;
	padding: 5px;
}

.new-calendar .calendar-content .calendar-rows .calendar-weekdays .calendar-weekday-item
{
	margin: 0;
	padding-left: 15px;
	padding-right: 15px;
	font-size: 12px;
	width: 14.28571428%;
	float: left;
	height: auto;
	min-height: 1px;
	text-align: center;
	box-sizing: border-box;
	color: #c6c6c6;

}

.new-calendar .calendar-content .calendar-rows .calendar-days
{
	box-sizing: border-box;
	position: relative;
	clear: both;
	display: table;
	width: 100%;
	height: auto;
	padding: 5px;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day
{
	margin: 0;
	padding: 2.5px;
	font-size: 14px;
	width: 14.28571428%;
	float: left;
	height: 30px;
	min-height: 1px;
	text-align: center;
	box-sizing: border-box;
	color: #000;
	display: table;
	transition: 0.3s all linear;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day:hover
{
	transition: 0.3s all linear;
	transform: scale(1.08);
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day .calendar-day-content
{
	background-color: #f1f3f4;
	height: 100%;
	width: 100%;
	text-align: center;
	display: table-cell;
	vertical-align: middle;
	border: 1px solid rgba(0, 0, 0, 0.05);
}

/*has event*/

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day.empty .calendar-day-content
{
	background-color: #FFF;
	border: none;
	color: transparent;
	position: relative;
	cursor: not-allowed;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day.has-events .calendar-day-content
{
	background-color: rgba(231, 76, 60,0.3);
	border: 1px solid rgba(231, 76, 60,0.7);
	color: rgba(231, 76, 60,1) !important;
	font-weight: 700;
	font-size: 17px;
	position: relative;
	cursor: pointer;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day.has-events .calendar-day-content > span,
.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day.today .calendar-day-content > span
{
	font-size: 10px;
	position: absolute;
	width: 100%;
	text-align: center;
	height: 15px;
	display: block;
	bottom: 5px;
	left: 0;
	font-weight: initial;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day.today .calendar-day-content
{
	background-color: rgba(241, 196, 15,0.2);
	border: 1px solid rgba(241, 196, 15,0.5);
	color: rgba(230, 126, 34,1.0) !important;
	font-weight: 700;
	font-size: 17px;
	position: relative;
	cursor: pointer;
}

.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day:hover > .calendar-day-content
{
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.1);
}




/*----------------------------------------------*/
/*  Modals                                      */
/*----------------------------------------------*/
.mask-float-calendar
{
	background-color: rgba(0, 0, 0, 0.8);
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99999999999;
	font-family: 'Montserrat', sans-serif !important;
	box-sizing: border-box;
	display: none;
}


.mask-float-calendar .mask-content
{
	z-index: 999999999999;
	background-color: #FFF;
	width: 660px;
	height: 500px;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	flex-direction: column;
	margin: auto;
	padding: 20px;
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
	box-sizing: border-box;
}

.mask-float-calendar .mask-content .btn-close-mask
{
	background-color: transparent;
	border: none;
	cursor: pointer;
	font-size: 18px;
	position: absolute;
	top: 22px;
	right: 20px;
}

.mask-float-calendar .mask-content .title-mask
{
	margin-top: 0;
	font-size: 20px;
	font-family: 'Montserrat', sans-serif !important;
}

.mask-float-calendar .mask-content .input-search-calendar
{
	width: 100%;
	height: 40px;
	padding-top: 5px;
	padding-bottom: 5px;
	box-sizing: border-box;
}

.mask-float-calendar .mask-content .mask-result
{
	flex-grow: 1;
	width: 100%;
	overflow-x: auto;
	background-color: #F1F3F4;
	padding: 5px;
}

.mask-float-calendar .mask-content .mask-result .item-result
{
	background-color: #FFF;
	box-sizing: border-box;
	width: 100%;
	padding: 5px;
	border-radius: 3px;
	margin-bottom: 7px;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.07);
}

.mask-float-calendar .mask-content .mask-result .item-result p
{
	margin-bottom: 3px;
}

.mask-float-calendar .mask-content .mask-result .item-result .title-item
{
	font-size: 16px;
	font-weight: 700;
}

.mask-float-calendar .mask-content .mask-result .item-result .local-item
{
	text-align: right;
}

.mask-float-calendar .mask-content .mask-result .item-result .data-item:before
{
	content: "\f274";
	font-family: FontAwesome;
	margin-right: 5px;
}

.mask-float-calendar .mask-content .mask-result .item-result .local-item:before
{
	content: "\f041";
	font-family: FontAwesome;
	margin-right: 5px;
}

.block-right-calendar
{
	float:right;
	width:265px;
	padding-top:15px;
}

/*----------------------------------------------*/
/*  Media Querys                                */
/*----------------------------------------------*/

/*######$ Tablets na horizontal $######*/
@media (max-width: 1024px)
{

}

/*######$ Tablets na vertical $######*/
@media (max-width: 992px)
{

	.new-calendar
	{
		padding: 0;
	}

	.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-prev-month
	{
		left: 100px;
	}

	.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-next-month
	{
		right: 100px;
	}

	.block-right-calendar
	{
		width: 219px;
	}

}

/*######$ Telemoveis $######*/
@media (max-width: 468px)
{

	.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day
	{
		height: 60px;
	}

	.new-calendar .calendar-content .calendar-rows .calendar-days .calendar-day .caption
	{
		display: none;
	}

	.new-calendar .calendar-content .calendar-rows .calendar-weekdays .calendar-weekday-item
	{
		padding: 0;
	}

	.new-calendar .calendar-content .calendar-header .calendar-header-info .month-calendar,
	.new-calendar .calendar-content .calendar-header .calendar-header-info .year-calendar
	{
		font-size: 18px;
	}

	.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-prev-month
	{
		left: 45px;
	}

	.new-calendar .calendar-content .calendar-header .calendar-header-info .btn-next-month
	{
		right: 45px;
	}

	.mask-float-calendar .mask-content
	{
		width: 95%;
	}

	.block-right-calendar
	{
		float: none;
	}

}
