/**handles:ewd-uasp-style,full-calendar**/
.ewd-uasp-hidden {
  display:none;
}

.ewd-uasp-clear {
  clear:both;
}

.ewd-uasp-dropdown-appointment-selector *{
  box-sizing: border-box;
}

/*Content Fields*/

.ewd-uasp-das-field, .ewd-uasp-dropdown-appointment-selector .form-field {
	margin-top: 14px;
  padding: 0px !important;
}

.ewd-uasp-appointment-message {
  margin: 5px;
}

.ewd-uasp-login-option {
  margin-top: 4px;
  margin-bottom: 10px;
}

#ewd-uasp-facebook-login {
  margin-left: -6px;
}


/****************
SIGN UP CONTAINER
*****************/
.ewd-uasp-das-registrationform {
  border: 2px solid #66A3C2;
  float: left;
  position: relative;
  height: auto;
  margin-right: 2%;
  margin-bottom: 20px;
  width: 49%;

}
.ewd-uasp-das-registrationform-label {
  color: white;
  background-color: #66A3C2;
  height: 65px;
  padding: 20px 10px;
}
.ewd-uasp-das-registrationform-content {
	padding: 10px;
}

/***********************
CHOOSE SERVICE CONTAINER
************************/
.ewd-uasp-das-service {
  border: 2px solid #006699;
  float: left;
  position: relative;
  height: auto;
  margin-bottom: 20px;
  width: 49%;
}
.ewd-uasp-das-service-label {
    color: white;
    background-color: #006699;
    height: 65px;
    padding: 20px 10px;
}
.ewd-uasp-das-service-content {
	padding: 10px;
}
.ewd-uasp-das-text,
.ewd-uasp-das-select {
    width: 100%;
    border: 1px solid lightgray;
  	margin: 0 0 0 0;
  	border-radius: 0px;
  	background-color: white;
}


/*************************
FIND APPOINTMENT CONTAINER
**************************/
.ewd-uasp-das-findappointment {
  width: 100%;
  border: 2px solid #003D5C;
  float: left;
  position: relative;
  min-height: 375px;
  margin-bottom: 20px;
}
.ewd-uasp-das-findappointment-label {
  color: white;
  background-color: #003D5C;
  height: 65px;
  padding: 20px 10px;
}
.ewd-uasp-das-findappointment-content {
	padding: 10px;
}
.ewd-uasp-das-button-container {
	width: 100%;
}
#ewd-uasp-das-find-appointment {
	background-color: #003D5C;
	border: 0px;
	height: 35px;
	padding: 10px;
	margin-bottom: 10px;
	color: white;
	float: left;
	cursor: pointer;
  border-radius: 0;
}
#ewd-uasp-das-find-appointment:hover {
  background-color: #66A3C2;
}
#ewd-uasp-das-find-appointment.ewd-uasp-contemporary {
  background-color: #66A3C2;
}
#ewd-uasp-das-find-appointment.ewd-uasp-contemporary:hover {
  background-color: #003D5C;
}


/*Appointments output*/
.ewd-uasp-das-appointments-provider-label {
  margin: 12px 0 7px;
}
.ewd-uasp-das-available-appointments {
  position: relative;
  float: left;
  width: calc(100% - 1px);
  left: 1px;
  height: auto;
  margin-bottom: 16px;
}

#ewd-uasp-das-appointment-times {
	clear:both;
}
.ewd-uasp-das-appointment-listing {
  position: relative;
  float: left;
  height: 40px;
  width: 96px;
  border: 1px solid lightgray;
  margin-left: -1px;
  margin-top: -1px;
  cursor: pointer;
  -o-transition:.25s;
  -ms-transition:.25s;
  -moz-transition:.25s;
  -webkit-transition:.25s;
  transition:.25s;
}
.ewd-uasp-das-appointment-listing:hover {
	background-color: #003D5C;
}
.ewd-uasp-das-appointment-listing.ewd-uasp-contemporary:hover {
  background-color: #66A3C2;
}
.ewd-uasp-das-appointment-link {
  position: absolute;
  width: 100%;
  padding-top: 4px;
  height: 36px;
  height: calc(100% - 4px);
  text-align: center;
  color: #003D5C;
  text-decoration: none;
  box-shadow: none !important;
}
.ewd-uasp-das-appointment-link.ewd-uasp-contemporary {
  color: #333;
}
.ewd-uasp-das-appointment-listing:hover .ewd-uasp-das-appointment-link {
  color: #fff;
}
.ewd-uasp-selected-appointment-time {
	background-color: #003D5C;
}
.ewd-uasp-selected-appointment-time.ewd-uasp-contemporary {
  background-color: #66A3C2;
}
.ewd-uasp-selected-appointment-time .ewd-uasp-das-appointment-link.ewd-uasp-contemporary {
  color: #fff;
}
.ewd-uasp-selected-appointment-time > a {
	color: white;
}


/*Date picker*/
input[type=date]::-webkit-calendar-picker-indicator {
	color: #003D5C;
  	background-color: white;
}
input[type=date]::-webkit-inner-spin-button,
input[type=date]::-webkit-outer-spin-button {
	-webkit-appearance: none;
}



/***********
BOOK BUTTON
***********/
.uasp-pure-control-group {
  float: right;
  margin-bottom: 12px;
}
.uasp-pure-control-group label {
  float: left;
  width: auto;
  margin-right: 24px;
}
.uasp-pure-control-group input[type='text'] {
  width: 150px;
  float: left;
}


/***********
BOOK BUTTON
***********/
input[type="submit"].ewd-uasp-das-book-button {
  clear: both;
  background-color: #003D5C;
  position: relative;
  float: right;
  border-radius: 0;
}
input[type="submit"].ewd-uasp-das-book-button:hover {
  background-color: #66A3C2;
}
input[type="submit"].ewd-uasp-das-book-button.ewd-uasp-contemporary {
  background-color: #66A3C2;
}
input[type="submit"].ewd-uasp-das-book-button.ewd-uasp-contemporary:hover {
  background-color: #003D5C;
}



/***********
NEW APPOINTMENT CALENDAR
***********/
#ewd-uasp-screen-background {
  height: 100%;
  position: fixed;
  width: 100%;
  background: #888;
  opacity: 0.7;
  top: 0px;
  left: 0px;
  z-index: 100;
}
#ewd-uasp-time-select {
  position: fixed;
  z-index: 101;
  background: rgb(240,240,240);
  padding: 32px;
  width: 500px;
  height: auto;
  top: calc(50vh - 175px);
  left: calc(50% - 250px);
}
@media screen and (max-width: 550px) {
  #ewd-uasp-time-select {
    width: 90%;
    left: 5%;
  }
}
#ewd-uasp-time-select div {
  color: #111;
  margin-bottom: 7px;
}
#ewd-uasp-time-select div select {
  width: auto;
}
#ewd-uasp-time-select div#ewd-uasp-select-time-button {
  cursor: pointer;
  padding: 6px 9px;
  background: #111;
  color: #fff;
  width: auto;
  float: left;
  border-radius: 3px;
  transition: background .3s;
}
#ewd-uasp-time-select div#ewd-uasp-select-time-button:hover {
  background: #555;
}


/**************
SMALLER SCREENS
***************/
@media (max-width: 800px) {
  .ewd-uasp-das-registrationform, .ewd-uasp-das-service, .ewd-uasp-das-findappointment {
    width:100%;
    margin:5px auto;
  }
	  .ewd-uasp-das-book-button{
  		left: 0px;
	}
}



/***********
ADDITIONAL CHANGES
***********/
.ewd-uasp-dropdown-appointment-selector label {
  display: block;
}
.ewd-uasp-dropdown-appointment-selector input[type="text"], .ewd-uasp-dropdown-appointment-selector input[type="email"], .ewd-uasp-dropdown-appointment-selector input[type="tel"], .ewd-uasp-dropdown-appointment-selector textarea {
  padding: 4px;
  border-radius: 0;
  background: #fff;
  margin: 0;
}
.ewd-uasp-dropdown-appointment-selector select {
  padding: 3px;
  border-radius: 0;
  margin: 0;
}

.ewd-uasp-das-registrationform.ewd-uasp-contemporary, .ewd-uasp-das-service.ewd-uasp-contemporary, .ewd-uasp-das-findappointment.ewd-uasp-contemporary {
  border: none;
  background: #f3f3f3;
  box-shadow: 1px 1px 2px #ccc;
}
.ewd-uasp-das-registrationform-label.ewd-uasp-contemporary, .ewd-uasp-das-service-label.ewd-uasp-contemporary, .ewd-uasp-das-findappointment-label.ewd-uasp-contemporary {
  background-color: #66A3C2;
  padding: 20px;
}
.ewd-uasp-das-registrationform-content.ewd-uasp-contemporary, .ewd-uasp-das-service-content.ewd-uasp-contemporary, .ewd-uasp-das-findappointment-content.ewd-uasp-contemporary {
  padding: 0 20px;
  width: 100%;
}

.ewd-uasp-dropdown-appointment-selector input[type="text"].ewd-uasp-datepicker {
  cursor: pointer;
  width: 50%;
  margin-top: 8px;
}
@media screen and (max-width: 800px) {
  .ewd-uasp-dropdown-appointment-selector input[type="text"].ewd-uasp-datepicker {
    width: 100%;
  }
}


/***********************************
* MULTI-STEP INDICATORS AND FORM
***********************************/
.ewd-uasp-multistep-indicators {
  position: relative;
  float: left;
  padding: 12px 0px 20px;
  margin-left: calc(50% - 75px);
}
.ewd-uasp-multistep-indicators-connecting-line {
  position: absolute;
  width: 130px;
  left: calc(50% - 65px);
  height: 4px;
  top: 25px;
  background: #66A3C2;
}
.ewd-uasp-multistep-indicator {
  position: relative;
  float: left;
  height: 30px;
  width: 30px;
  padding: 1px 8px;
  border-radius: 1000px;
  border: 3px solid;
  margin: 0 10px;
  font-size: 14px;
  line-height: 1.5;
}
.ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected {
 cursor: pointer;
}
.ewd-uasp-multistep-indicator[data-indicator="registrationform"] {
 background: #fff;
 border-color: #66A3C2;
 color: #66A3C2;
}
.ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected[data-indicator="registrationform"] {
 background: #66A3C2;
 color: #fff;
}
.ewd-uasp-multistep-indicator[data-indicator="service"] {
 background: #fff;
 border-color: #006699;
 color: #006699;
}
.ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected[data-indicator="service"] {
 background: #006699;
 color: #fff;
}
.ewd-uasp-multistep-indicators.ewd-uasp-contemporary .ewd-uasp-multistep-indicator[data-indicator="service"] {
 background: #fff;
 border-color: #66A3C2;
 color: #66A3C2;
}
.ewd-uasp-multistep-indicators.ewd-uasp-contemporary .ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected[data-indicator="service"] {
 background: #66A3C2;
 color: #fff;
}
.ewd-uasp-multistep-indicator[data-indicator="findappointment"] {
 background: #fff;
 border-color: #003D5C;
 color: #003D5C;
}
.ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected[data-indicator="findappointment"] {
 background: #003D5C;
 color: #fff;
}
.ewd-uasp-multistep-indicators.ewd-uasp-contemporary .ewd-uasp-multistep-indicator[data-indicator="findappointment"] {
 background: #fff;
 border-color: #66A3C2;
 color: #66A3C2;
}
.ewd-uasp-multistep-indicators.ewd-uasp-contemporary .ewd-uasp-multistep-indicator.ewd-uasp-indicator-selected[data-indicator="findappointment"] {
 background: #66A3C2;
 color: #fff;
}

@media screen and (min-width: 801px) {
  .ewd-uasp-multistep-form .ewd-uasp-das-registrationform,
  .ewd-uasp-multistep-form .ewd-uasp-das-service {
    margin-left: 25.5%;
  }
}






/*!
 * FullCalendar v3.4.0 Stylesheet
 * Docs & License: https://fullcalendar.io/
 * (c) 2017 Adam Shaw
 */

.fc-icon,
body .fc {
    font-size: 1em
}

.fc-button-group,
.fc-icon {
    display: inline-block
}

.fc-bg,
.fc-row .fc-bgevent-skeleton,
.fc-row .fc-highlight-skeleton {
    bottom: 0
}

.fc-icon,
.fc-unselectable {
    -khtml-user-select: none;
    -webkit-touch-callout: none
}

.fc {
    direction: ltr;
    text-align: left
}

.fc-rtl {
    text-align: right
}

.fc th,
.fc-basic-view td.fc-week-number,
.fc-icon,
.fc-toolbar {
    text-align: center
}

.fc-unthemed .fc-content,
.fc-unthemed .fc-divider,
.fc-unthemed .fc-list-heading td,
.fc-unthemed .fc-list-view,
.fc-unthemed .fc-popover,
.fc-unthemed .fc-row,
.fc-unthemed tbody,
.fc-unthemed td,
.fc-unthemed th,
.fc-unthemed thead {
    border-color: #ddd
}

.fc-unthemed .fc-popover {
    background-color: #fff
}

.fc-unthemed .fc-divider,
.fc-unthemed .fc-list-heading td,
.fc-unthemed .fc-popover .fc-header {
    background: #eee
}

.fc-unthemed .fc-popover .fc-header .fc-close {
    color: #666
}

.fc-unthemed td.fc-today {
    background: #fcf8e3
}

.fc-highlight {
    background: #bce8f1;
    opacity: .3
}

.fc-bgevent {
    background: #8fdf82;
    opacity: .3
}

.fc-nonbusiness {
    background: #d7d7d7
}

.fc-unthemed .fc-disabled-day {
    background: #d7d7d7;
    opacity: .3
}

.ui-widget .fc-disabled-day {
    background-image: none
}

.fc-icon {
    height: 1em;
    line-height: 1em;
    overflow: hidden;
    font-family: "Courier New", Courier, monospace;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.fc-icon:after {
    position: relative
}

.fc-icon-left-single-arrow:after {
    content: "\02039";
    font-weight: 700;
    font-size: 200%;
    top: -7%
}

.fc-icon-right-single-arrow:after {
    content: "\0203A";
    font-weight: 700;
    font-size: 200%;
    top: -7%
}

.fc-icon-left-double-arrow:after {
    content: "\000AB";
    font-size: 160%;
    top: -7%
}

.fc-icon-right-double-arrow:after {
    content: "\000BB";
    font-size: 160%;
    top: -7%
}

.fc-icon-left-triangle:after {
    content: "\25C4";
    font-size: 125%;
    top: 3%
}

.fc-icon-right-triangle:after {
    content: "\25BA";
    font-size: 125%;
    top: 3%
}

.fc-icon-down-triangle:after {
    content: "\25BC";
    font-size: 125%;
    top: 2%
}

.fc-icon-x:after {
    content: "\000D7";
    font-size: 200%;
    top: 6%
}

.fc button {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: 0;
    height: 2.1em;
    padding: 0 .6em;
    font-size: 1em;
    white-space: nowrap;
    cursor: pointer
}

.fc button::-moz-focus-inner {
    margin: 0;
    padding: 0
}

.fc-state-default {
    border: 1px solid;
    background-color: #f5f5f5;
    background-image: -moz-linear-gradient(top, #fff, #e6e6e6);
    background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#fff), to(#e6e6e6));
    background-image: -webkit-linear-gradient(top, #fff, #e6e6e6);
    background-image: -o-linear-gradient(top, #fff, #e6e6e6);
    background-image: linear-gradient(to bottom, #fff, #e6e6e6);
    background-repeat: repeat-x;
    border-color: #e6e6e6 #e6e6e6 #bfbfbf;
    border-color: rgba(0, 0, 0, .1) rgba(0, 0, 0, .1) rgba(0, 0, 0, .25);
    color: #333;
    text-shadow: 0 1px 1px rgba(255, 255, 255, .75);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .2), 0 1px 2px rgba(0, 0, 0, .05)
}

.fc-state-default.fc-corner-left {
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px
}

.fc-state-default.fc-corner-right {
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px
}

.fc button .fc-icon {
    position: relative;
    top: -.05em;
    margin: 0 .2em;
    vertical-align: middle
}

.fc-state-active,
.fc-state-disabled,
.fc-state-down,
.fc-state-hover {
    color: #333;
    background-color: #e6e6e6
}

.fc-state-hover {
    color: #333;
    text-decoration: none;
    background-position: 0 -15px;
    -webkit-transition: background-position .1s linear;
    -moz-transition: background-position .1s linear;
    -o-transition: background-position .1s linear;
    transition: background-position .1s linear
}

.fc-state-active,
.fc-state-down {
    background-color: #ccc;
    background-image: none;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, .15), 0 1px 2px rgba(0, 0, 0, .05)
}

.fc-state-disabled {
    cursor: default;
    background-image: none;
    opacity: .65;
    box-shadow: none
}

.fc-event.fc-draggable,
.fc-event[href],
.fc-popover .fc-header .fc-close,
a[data-goto] {
    cursor: pointer
}

.fc .fc-button-group>* {
    float: left;
    margin: 0 0 0 -1px
}

.fc .fc-button-group>:first-child {
    margin-left: 0
}

.fc-popover {
    position: absolute;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .15)
}

.fc-popover .fc-header {
    padding: 2px 4px
}

.fc-popover .fc-header .fc-title {
    margin: 0 2px
}

.fc-ltr .fc-popover .fc-header .fc-title,
.fc-rtl .fc-popover .fc-header .fc-close {
    float: left
}

.fc-ltr .fc-popover .fc-header .fc-close,
.fc-rtl .fc-popover .fc-header .fc-title {
    float: right
}

.fc-unthemed .fc-popover {
    border-width: 1px;
    border-style: solid
}

.fc-unthemed .fc-popover .fc-header .fc-close {
    font-size: .9em;
    margin-top: 2px
}

.fc-popover>.ui-widget-header+.ui-widget-content {
    border-top: 0
}

.fc-divider {
    border-style: solid;
    border-width: 1px
}

hr.fc-divider {
    height: 0;
    margin: 0;
    padding: 0 0 2px;
    border-width: 1px 0
}

.fc-bg table,
.fc-row .fc-bgevent-skeleton table,
.fc-row .fc-highlight-skeleton table {
    height: 100%
}

.fc-clear {
    clear: both
}

.fc-bg,
.fc-bgevent-skeleton,
.fc-helper-skeleton,
.fc-highlight-skeleton {
    position: absolute;
    top: 0;
    left: 0;
    right: 0
}

.fc table {
    width: 100%;
    box-sizing: border-box;
    table-layout: fixed;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 1em
}

.fc td,
.fc th {
    border-style: solid;
    border-width: 1px;
    padding: 0;
    vertical-align: top
}

.fc td.fc-today {
    border-style: double
}

a[data-goto]:hover {
    text-decoration: underline
}

.fc .fc-row {
    border-style: solid;
    border-width: 0
}

.fc-row table {
    border-left: 0 hidden transparent;
    border-right: 0 hidden transparent;
    border-bottom: 0 hidden transparent
}

.fc-row:first-child table {
    border-top: 0 hidden transparent
}

.fc-row {
    position: relative
}

.fc-row .fc-bg {
    z-index: 1
}

.fc-row .fc-bgevent-skeleton td,
.fc-row .fc-highlight-skeleton td {
    border-color: transparent
}

.fc-row .fc-bgevent-skeleton {
    z-index: 2
}

.fc-row .fc-highlight-skeleton {
    z-index: 3
}

.fc-row .fc-content-skeleton {
    position: relative;
    z-index: 4;
    padding-bottom: 2px
}

.fc-row .fc-helper-skeleton {
    z-index: 5
}

.fc-row .fc-content-skeleton td,
.fc-row .fc-helper-skeleton td {
    background: 0 0;
    border-color: transparent;
    border-bottom: 0
}

.fc-row .fc-content-skeleton tbody td,
.fc-row .fc-helper-skeleton tbody td {
    border-top: 0
}

.fc-scroller {
    -webkit-overflow-scrolling: touch
}

.fc-row.fc-rigid,
.fc-time-grid-event {
    overflow: hidden
}

.fc-scroller>.fc-day-grid,
.fc-scroller>.fc-time-grid {
    position: relative;
    width: 100%
}

.fc-event {
    position: relative;
    display: block;
    font-size: .85em;
    line-height: 1.3;
    border-radius: 3px;
    border: 1px solid #3a87ad;
    font-weight: 400
}

.fc-event,
.fc-event-dot {
    background-color: #3a87ad
}

.fc-event,
.fc-event:hover,
.ui-widget .fc-event {
    color: #fff;
    text-decoration: none
}

.fc-not-allowed,
.fc-not-allowed .fc-event {
    cursor: not-allowed
}

.fc-event .fc-bg {
    z-index: 1;
    background: #fff;
    opacity: .25
}

.fc-event .fc-content {
    position: relative;
    z-index: 2
}

.fc-event .fc-resizer {
    position: absolute;
    z-index: 4;
    display: none
}

.fc-event.fc-allow-mouse-resize .fc-resizer,
.fc-event.fc-selected .fc-resizer {
    display: block
}

.fc-event.fc-selected .fc-resizer:before {
    content: "";
    position: absolute;
    z-index: 9999;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    margin-left: -20px;
    margin-top: -20px
}

.fc-event.fc-selected {
    z-index: 9999!important;
    box-shadow: 0 2px 5px rgba(0, 0, 0, .2)
}

.fc-event.fc-selected.fc-dragging {
    box-shadow: 0 2px 7px rgba(0, 0, 0, .3)
}

.fc-h-event.fc-selected:before {
    content: "";
    position: absolute;
    z-index: 3;
    top: -10px;
    bottom: -10px;
    left: 0;
    right: 0
}

.fc-ltr .fc-h-event.fc-not-start,
.fc-rtl .fc-h-event.fc-not-end {
    margin-left: 0;
    border-left-width: 0;
    padding-left: 1px;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0
}

.fc-ltr .fc-h-event.fc-not-end,
.fc-rtl .fc-h-event.fc-not-start {
    margin-right: 0;
    border-right-width: 0;
    padding-right: 1px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.fc-ltr .fc-h-event .fc-start-resizer,
.fc-rtl .fc-h-event .fc-end-resizer {
    cursor: w-resize;
    left: -1px
}

.fc-ltr .fc-h-event .fc-end-resizer,
.fc-rtl .fc-h-event .fc-start-resizer {
    cursor: e-resize;
    right: -1px
}

.fc-h-event.fc-allow-mouse-resize .fc-resizer {
    width: 7px;
    top: -1px;
    bottom: -1px
}

.fc-h-event.fc-selected .fc-resizer {
    border-radius: 4px;
    border-width: 1px;
    width: 6px;
    height: 6px;
    border-style: solid;
    border-color: inherit;
    background: #fff;
    top: 50%;
    margin-top: -4px
}

.fc-ltr .fc-h-event.fc-selected .fc-start-resizer,
.fc-rtl .fc-h-event.fc-selected .fc-end-resizer {
    margin-left: -4px
}

.fc-ltr .fc-h-event.fc-selected .fc-end-resizer,
.fc-rtl .fc-h-event.fc-selected .fc-start-resizer {
    margin-right: -4px
}

.fc-day-grid-event {
    margin: 1px 2px 0;
    padding: 0 1px
}

tr:first-child>td>.fc-day-grid-event {
    margin-top: 2px
}

.fc-day-grid-event.fc-selected:after {
    content: "";
    position: absolute;
    z-index: 1;
    top: -1px;
    right: -1px;
    bottom: -1px;
    left: -1px;
    background: #000;
    opacity: .25
}

.fc-day-grid-event .fc-content {
    white-space: nowrap;
    overflow: hidden
}

.fc-day-grid-event .fc-time {
    font-weight: 700
}

.fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer,
.fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer {
    margin-left: -2px
}

.fc-ltr .fc-day-grid-event.fc-allow-mouse-resize .fc-end-resizer,
.fc-rtl .fc-day-grid-event.fc-allow-mouse-resize .fc-start-resizer {
    margin-right: -2px
}

a.fc-more {
    margin: 1px 3px;
    font-size: .85em;
    cursor: pointer;
    text-decoration: none
}

a.fc-more:hover {
    text-decoration: underline
}

.fc-limited {
    display: none
}

.fc-day-grid .fc-row {
    z-index: 1
}

.fc-more-popover {
    z-index: 2;
    width: 220px
}

.fc-more-popover .fc-event-container {
    padding: 10px
}

.fc-now-indicator {
    position: absolute;
    border: 0 solid red
}

.fc-unselectable {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent
}

.fc-toolbar.fc-header-toolbar {
    margin-bottom: 1em
}

.fc-toolbar.fc-footer-toolbar {
    margin-top: 1em
}

.fc-toolbar .fc-left {
    float: left
}

.fc-toolbar .fc-right {
    float: right
}

.fc-toolbar .fc-center {
    display: inline-block
}

.fc .fc-toolbar>*>* {
    float: left;
    margin-left: .75em
}

.fc .fc-toolbar>*>:first-child {
    margin-left: 0
}

.fc-toolbar h2 {
    margin: 0
}

.fc-toolbar button {
    position: relative
}

.fc-toolbar .fc-state-hover,
.fc-toolbar .ui-state-hover {
    z-index: 2
}

.fc-toolbar .fc-state-down {
    z-index: 3
}

.fc-toolbar .fc-state-active,
.fc-toolbar .ui-state-active {
    z-index: 4
}

.fc-toolbar button:focus {
    z-index: 5
}

.fc-view-container *,
.fc-view-container:after,
.fc-view-container:before {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box
}

.fc-view,
.fc-view>table {
    position: relative;
    z-index: 1
}

.fc-basicDay-view .fc-content-skeleton,
.fc-basicWeek-view .fc-content-skeleton {
    padding-bottom: 1em
}

.fc-basic-view .fc-body .fc-row {
    min-height: 4em
}

.fc-row.fc-rigid .fc-content-skeleton {
    position: absolute;
    top: 0;
    left: 0;
    right: 0
}

.fc-day-top.fc-other-month {
    opacity: .3
}

.fc-basic-view .fc-day-number,
.fc-basic-view .fc-week-number {
    padding: 2px
}

.fc-basic-view th.fc-day-number,
.fc-basic-view th.fc-week-number {
    padding: 0 2px
}

.fc-ltr .fc-basic-view .fc-day-top .fc-day-number {
    float: right
}

.fc-rtl .fc-basic-view .fc-day-top .fc-day-number {
    float: left
}

.fc-ltr .fc-basic-view .fc-day-top .fc-week-number {
    float: left;
    border-radius: 0 0 3px
}

.fc-rtl .fc-basic-view .fc-day-top .fc-week-number {
    float: right;
    border-radius: 0 0 0 3px
}

.fc-basic-view .fc-day-top .fc-week-number {
    min-width: 1.5em;
    text-align: center;
    background-color: #f2f2f2;
    color: grey
}

.fc-basic-view td.fc-week-number>* {
    display: inline-block;
    min-width: 1.25em
}

.fc-agenda-view .fc-day-grid {
    position: relative;
    z-index: 2
}

.fc-agenda-view .fc-day-grid .fc-row {
    min-height: 3em
}

.fc-agenda-view .fc-day-grid .fc-row .fc-content-skeleton {
    padding-bottom: 1em
}

.fc .fc-axis {
    vertical-align: middle;
    padding: 0 4px;
    white-space: nowrap
}

.fc-ltr .fc-axis {
    text-align: right
}

.fc-rtl .fc-axis {
    text-align: left
}

.ui-widget td.fc-axis {
    font-weight: 400
}

.fc-time-grid,
.fc-time-grid-container {
    position: relative;
    z-index: 1
}

.fc-time-grid {
    min-height: 100%
}

.fc-time-grid table {
    border: 0 hidden transparent
}

.fc-time-grid>.fc-bg {
    z-index: 1
}

.fc-time-grid .fc-slats,
.fc-time-grid>hr {
    position: relative;
    z-index: 2
}

.fc-time-grid .fc-content-col {
    position: relative
}

.fc-time-grid .fc-content-skeleton {
    position: absolute;
    z-index: 3;
    top: 0;
    left: 0;
    right: 0
}

.fc-time-grid .fc-business-container {
    position: relative;
    z-index: 1
}

.fc-time-grid .fc-bgevent-container {
    position: relative;
    z-index: 2
}

.fc-time-grid .fc-highlight-container {
    z-index: 3;
    position: relative
}

.fc-time-grid .fc-event-container {
    position: relative;
    z-index: 4
}

.fc-time-grid .fc-now-indicator-line {
    z-index: 5
}

.fc-time-grid .fc-helper-container {
    position: relative;
    z-index: 6
}

.fc-time-grid .fc-slats td {
    height: 1.5em;
    border-bottom: 0
}

.fc-time-grid .fc-slats .fc-minor td {
    border-top-style: dotted
}

.fc-time-grid .fc-slats .ui-widget-content {
    background: 0 0
}

.fc-time-grid .fc-highlight {
    position: absolute;
    left: 0;
    right: 0
}

.fc-ltr .fc-time-grid .fc-event-container {
    margin: 0 2.5% 0 2px
}

.fc-rtl .fc-time-grid .fc-event-container {
    margin: 0 2px 0 2.5%
}

.fc-time-grid .fc-bgevent,
.fc-time-grid .fc-event {
    position: absolute;
    z-index: 1
}

.fc-time-grid .fc-bgevent {
    left: 0;
    right: 0
}

.fc-v-event.fc-not-start {
    border-top-width: 0;
    padding-top: 1px;
    border-top-left-radius: 0;
    border-top-right-radius: 0
}

.fc-v-event.fc-not-end {
    border-bottom-width: 0;
    padding-bottom: 1px;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0
}

.fc-time-grid-event.fc-selected {
    overflow: visible
}

.fc-time-grid-event.fc-selected .fc-bg {
    display: none
}

.fc-time-grid-event .fc-content {
    overflow: hidden
}

.fc-time-grid-event .fc-time,
.fc-time-grid-event .fc-title {
    padding: 0 1px
}

.fc-time-grid-event .fc-time {
    font-size: .85em;
    white-space: nowrap
}

.fc-time-grid-event.fc-short .fc-content {
    white-space: nowrap
}

.fc-time-grid-event.fc-short .fc-time,
.fc-time-grid-event.fc-short .fc-title {
    display: inline-block;
    vertical-align: top
}

.fc-time-grid-event.fc-short .fc-time span {
    display: none
}

.fc-time-grid-event.fc-short .fc-time:before {
    content: attr(data-start)
}

.fc-time-grid-event.fc-short .fc-time:after {
    content: "\000A0-\000A0"
}

.fc-time-grid-event.fc-short .fc-title {
    font-size: .85em;
    padding: 0
}

.fc-time-grid-event.fc-allow-mouse-resize .fc-resizer {
    left: 0;
    right: 0;
    bottom: 0;
    height: 8px;
    overflow: hidden;
    line-height: 8px;
    font-size: 11px;
    font-family: monospace;
    text-align: center;
    cursor: s-resize
}

.fc-time-grid-event.fc-allow-mouse-resize .fc-resizer:after {
    content: "="
}

.fc-time-grid-event.fc-selected .fc-resizer {
    border-radius: 5px;
    border-width: 1px;
    width: 8px;
    height: 8px;
    border-style: solid;
    border-color: inherit;
    background: #fff;
    left: 50%;
    margin-left: -5px;
    bottom: -5px
}

.fc-time-grid .fc-now-indicator-line {
    border-top-width: 1px;
    left: 0;
    right: 0
}

.fc-time-grid .fc-now-indicator-arrow {
    margin-top: -5px
}

.fc-ltr .fc-time-grid .fc-now-indicator-arrow {
    left: 0;
    border-width: 5px 0 5px 6px;
    border-top-color: transparent;
    border-bottom-color: transparent
}

.fc-rtl .fc-time-grid .fc-now-indicator-arrow {
    right: 0;
    border-width: 5px 6px 5px 0;
    border-top-color: transparent;
    border-bottom-color: transparent
}

.fc-event-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 5px
}

.fc-rtl .fc-list-view {
    direction: rtl
}

.fc-list-view {
    border-width: 1px;
    border-style: solid
}

.fc .fc-list-table {
    table-layout: auto
}

.fc-list-table td {
    border-width: 1px 0 0;
    padding: 8px 14px
}

.fc-list-table tr:first-child td {
    border-top-width: 0
}

.fc-list-heading {
    border-bottom-width: 1px
}

.fc-list-heading td {
    font-weight: 700
}

.fc-ltr .fc-list-heading-main {
    float: left
}

.fc-ltr .fc-list-heading-alt,
.fc-rtl .fc-list-heading-main {
    float: right
}

.fc-rtl .fc-list-heading-alt {
    float: left
}

.fc-list-item.fc-has-url {
    cursor: pointer
}

.fc-list-item:hover td {
    background-color: #f5f5f5
}

.fc-list-item-marker,
.fc-list-item-time {
    white-space: nowrap;
    width: 1px
}

.fc-ltr .fc-list-item-marker {
    padding-right: 0
}

.fc-rtl .fc-list-item-marker {
    padding-left: 0
}

.fc-list-item-title a {
    text-decoration: none;
    color: inherit
}

.fc-list-item-title a[href]:hover {
    text-decoration: underline
}

.fc-list-empty-wrap2 {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.fc-list-empty-wrap1 {
    width: 100%;
    height: 100%;
    display: table
}

.fc-list-empty {
    display: table-cell;
    vertical-align: middle;
    text-align: center
}

.fc-unthemed .fc-list-empty {
    background-color: #eee
}



/***** Additional Etoile CSS *****/
.fc-event-container {
  cursor: pointer;
}
@media screen and (max-width: 800px) {
  .fc-toolbar .fc-right {
    float: left;
    clear: both;
    width: 100%;
    margin: 10px 0;
  }
  .fc-toolbar .fc-center {
    float: left;
    clear: both;
    width: 100%;
  }
}