/*  
 *  Court Main Style
 *  @oom_sasky
 *  @version: 1.0.0
*/

/** OOm Booking Court Main Style **/

/** Filter Form **/
.oom-court-booking-filter-form {
    background-color: #B60124;
    padding: 40px 20px;
    width: 480px;
    border-radius: 13px 13px 13px 13px;
}

.oom-court-booking-filter-form-field {
     width: 100%;
}

.oom-court-booking-filter-form-fields-row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 20px;
}

.oom-court-booking-filter-form-fields-row label {
    color: #ffffff;
}

.oom-court-booking-filter-form-fields-row input {
    width: 100%;
}


.oom-court-booking-filter-form-fields-row input::placeholder {
   color: #1f2124;
   opacity: 0.5;
}

.oom-court-booking-btn {
    font-size: 16px;
    font-weight: 700;
    border-style: solid;
    border-width: 1px 1px 1px 1px;
    border-radius: 6px 6px 6px 6px;
    padding: 13px 40px 13px 40px;
    margin-top: 20px;
    background-color: #02010100;
    color: #FFFFFF;
    border-color: #FFFFFF;
}

.oom-court-booking-btn:hover {
    background-color: #FFFFFF;
    color: #B60124;
}

/** Calendar **/
.flatpickr-day.holiday,
.flatpickr-day.holiday:hover {
	color: #fff;
    background: #B60124;
}

/** Court List Style **/
#oom-courts-booking-list {
	padding: 60px 60px;
}

.oom-courts-booking.four-column {
  display: grid;
  grid-template-columns: auto auto auto auto;
  padding: 10px;
}

.oom-courts-booking.two-column {
  display: grid;
  grid-template-columns: auto auto;
  padding: 0px;
}

.oom-courts-booking-custom {
    padding: 10px;
}

.oom-courts-booking.court-p {
  grid-template-columns: auto auto;
}

.oom-court-booking {
	font-family: "Poppins", Sans-serif;
    font-weight: bold;
    color: #ffffff;
    text-transform: uppercase;
    cursor: pointer;
    background-color: #2A9B00;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: space-around;
    align-items: center;
    margin: 4px 4px;
    border-radius: 8px;
}

.oom-court-booking.limited-slot {
	background-color: #F59535;
}

.oom-court-booking.fully-booked {
	background-color: #B60124;
}

.four-column .oom-court-booking {
    height: 150px;
}

.two-column .oom-court-booking {
    margin-left: 20px;
    margin-right: 20px;
    height: 40px;
}

.oom-courts-booking-custom .oom-court-booking {
     height: 150px;
}


.oom-courts-booking.court-p .oom-court-booking {
    height: 80px;
}

.oom-courts-booking-custom .oom-court-booking.half {
   height: 72px;
}

/** Court Booking Status Style **/
#oom-courts-booking-status {
	display: grid;
    grid-template-columns: auto auto auto auto;
    padding: 10px;
}

#oom-courts-booking-status .court-status {
	color: #ffffff;
	font-size: 14px;
	font-family: "Poppins", Sans-serif;
    font-weight: 500;
	display: flex;
    flex-direction: row;
    align-content: center;
    flex-wrap: wrap;
    align-items: center;
}
	
#oom-courts-booking-status .court-status span {
	color: #ffffff;
	width: 30px;
    height: 30px;
    display: block;
    border-radius: 6px;
    margin-right: 10px;
}

#oom-courts-booking-status .court-status.available span {
	background: #2A9B00;
}

#oom-courts-booking-status .court-status.limited-slots span {
	background: #F59535;
}

#oom-courts-booking-status .court-status.fully-booked span {
	background: #B60124;
}

/** Court Form Style **/
#oom-court-booking-form {
    box-shadow: -4px 6px 10px 2px #00000029;
    display: flex;
    flex-direction: column;
}

.oom-court-booking-accordion {
  background-color: #eee;
  color: #444;
  cursor: pointer;
  padding: 0px;
  width: 100%;
  border: none;
  border-radius: 0px;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
}

.oom-court-booking-accordion .oom_court_booking_column_10 {
    background: #E0E0E0;
    text-align: center;
    padding: 15px 20px;
}

.oom-court-booking-accordion .oom_court_booking_column_90 {
    background: #FAFAFA;
    text-align: left;
    padding: 15px 20px;
}

.oom-court-booking-accordion span {
    color: #000000;
}

.oom-court-booking-accordion .accordion-no,
.oom-court-booking-accordion .accordion-title {
    font-size: 18px;
    font-weight: bold;
}

.oom-court-booking-accordion i {
    color: #000000;
    float: right;
}


.oom-court-booking-panel {
  background-color: white;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out;
}

.oom-court-booking-choose-name {
    cursor: pointer;
    padding: 20px;
    border: 1px solid #D8D1D1;
    margin-bottom: 5px;
}

.oom-court-booking-choose-name.active {
    border: 1px solid #B60124;
}

.oom-court-booking-choose-name i {
    display: none;
}

.oom-court-booking-choose-name.active i {
    display: block;
    color: #B60124;
    border: 1px solid;
    border-radius: 100px;
    padding: 2px;
    font-size: 18px;
    float: right;
}

.oom-court-booking-choose-name span {
    font-size: 18px;
    font-weight: bold;
}


/** Date and Time Style **/
.oom-court-booking-panel-date-picker {
    padding: 20px 0px;
    width: 80%;
    margin: auto;
}

.oom-court-booking-panel-date-picker hr {
    border-color: #BABABA;
}

.oom-court-booking-panel-date-picker p {
	font-size: 12px;
	font-style: italic;
    line-height: 14px;
    padding: 0px;
    margin: 0px;
    text-align: center;
    color: #B60124;
}

input.oom-court-booking-date {
    border: none;
    text-align: center;
}

#oom-courts-booking-items {
	padding-bottom: 120px;
}

.oom-courts-booking-item-date-not-available {
	text-align: center;
    padding-bottom: 300px;
    padding-top: 300px;
}

.oom-courts-booking-item-date-not-available span {
	font-weight: bold;
    color: #B60124;
}

.oom-court-booking-item {
    padding: 0px 20px;
}

.oom-court-booking-item-name {
    display: flex;
    flex-direction: row;
    align-content: space-around;
    align-items: center;
}

.oom-court-booking-item-name h4 {
	font-size: 16px;
    font-weight: bold;
	margin-top: 20px;
}

.oom-court-booking-item-name .clear-filter {
	color: #fff;
    font-size: 14px;
    background: #B60124;
    padding: 0px 6px 0px 6px;
    border-radius: 20px;
    cursor: pointer;
	top: -10px;
	position: relative;
}

.oom-court-booking-item-name .court-icon svg {
    width: 15px;
    fill: #B60124;
    padding-top: 5px;
}

.oom-court-booking-item-name .court-no  {
    font-size: 16px;
    font-weight: bold;
    color: #B60124;
    padding-left: 5px;
}

.oom-court-booking-filter-item {
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    align-content: center;
    align-items: center;
    gap: 5px;
}

.oom-court-booking-filter-item h4 {
    font-size: 16px;
    font-weight: normal;
    margin-top: 20px;
}

.oom-court-booking-filter-item span {
    font-weight: bold;
}

.oom-court-booking-filter-item .clear-filter-checkinout {
    color: #fff;
    font-size: 14px;
    background: #B60124;
    padding: 0px 6px 0px 6px;
    border-radius: 20px;
    cursor: pointer;
    top: -10px;
    position: relative;
}


.oom-court-booking-times {
    display: grid;
    grid-template-columns: auto auto auto auto auto;
    padding: 0px;
}

.oom-court-booking-time {
    cursor: pointer;
    display: flex;
    flex-direction: column;
	justify-content: center;
    background: #E6E6E6;
    padding: 4px;
    margin: 4px;
}

.oom-court-booking-time.selected {
    color: #fff;
    background-color: #B60124;
}

.oom-court-booking-time .time {
    font-weight: bold;
}

.oom-court-booking-time .time,
.oom-court-booking-time .price {
    pointer-events: none;
}

.oom-court-booking-time .time-not-available {
	color: #a2a2a2;
	font-weight: bold;
}

.oom-court-booking-time .time-booked {
	color: #B60124;
    font-weight: bold;
    text-align: left;
    display: flex;
}

.oom-court-booking-panel-available-times {
    position: relative;
}

.oom-court-booking-panel-available-times-container {
    overflow: auto;
    max-height: 680px;
}

.oom-courts-booking-footer-container {
    margin-top: 20px;
    padding: 20px 25px;
    border: 1px solid #c7c7c7;
	position: absolute;
    margin-top: 40px;
    z-index: 999;
    bottom: 0;
    width: 100%;
    background: #ffffff;
}

.oom-courts-booking-footer-bottom {
    display: flex;
    flex-direction: row;
    align-items: center;
}

.oom-courts-booking-preview .total {
    font-size: 20px;
    font-weight: bold;
}

.oom-courts-booking-button button {
    float: right;
    font-family: "Poppins", Sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: #FFFFFF;
    background-color: #B60124;
    border-radius: 5px 5px 5px 5px;
    padding: 14px 30px 14px 30px;
}

.oom-courts-booking-button button:hover {
    background-color: #ffffff;
    color: #B60124;
}


/** Rows and Columns */
.oom_court_booking_column_100 {
    float: left;
    width: 100%;
}

.oom_court_booking_column_90 {
    float: left;
    width: 90%;
}

.oom_court_booking_column_80 {
    float: left;
    width: 80%;
}

.oom_court_booking_column_70 {
    float: left;
    width: 70%;
}


.oom_court_booking_column_65 {
    float: left;
    width: 65%;
}

.oom_court_booking_column_60 {
    float: left;
    width: 60%;
}

.oom_court_booking_column_50 {
    float: left;
    width: 50%;
}

.oom_court_booking_column_40 {
    float: left;
    width: 40%;
}

.oom_court_booking_column_35 {
    float: left;
    width: 35%;
}

.oom_court_booking_column_33_33 {
    float: left;
    width: 33.33%;
}

.oom_court_booking_column_33 {
    float: left;
    width: 33%;
}

.oom_court_booking_column_30 {
    float: left;
    width: 30%;
}

.oom_court_booking_column_20 {
    float: left;
    width: 20%;
}

.oom_court_booking_column_10 {
    float: left;
    width: 10%;
}

/* Clear floats after the columns */
.oom_court_booking_row:after {
    content: "";
    display: table;
    clear: both;
}

/** Cover Spin Loading **/
#oom-court-booking-cover-spin {
    position:absolute;
    width:100%;
    left:0;right:0;top:0;bottom:0;
    background-color: rgba(255,255,255,0.7);
    z-index:9999;
    display:none;
}
	
#oom-court-booking-cover-spin::after {
    content:'';
    display:block;
    position:absolute;
    left:calc(50% - 22px);
    top:calc(50% - 22px);
    width:44px;
    height:44px;
    border-style:solid;
    border-color:black;
    border-top-color:transparent;
    border-width: 4px;
    border-radius:50%;
    -webkit-animation: spin .8s linear infinite;
    -moz-animation: spin .8s linear infinite;
    animation: spin .8s linear infinite;
}

@-webkit-keyframes spin {
    from {-webkit-transform:rotate(0deg);}
    to {-webkit-transform:rotate(360deg);}
}

@keyframes spin {
    from {transform:rotate(0deg);}
    to {transform:rotate(360deg);}
}

/** Modal **/
/* The Modal (background) */
.oom_court_booking_modal {
    display: none; 
    position: absolute; 
    z-index: 10; 
    left: 0;
    top: 0;
    width: 100%; 
    height: 100%; 
    overflow: auto; 
    background-color: rgb(0,0,0); 
    background-color: rgba(0,0,0,0.8);
}

/* Modal Content/Box */
.oom_court_booking_content {
    background-color: #ffffff;
    top: 30%;
    position: relative;
    margin: auto;
    border: 1px solid #888;
    width: 90%; 
    padding: 10px 20px;
}

.oom_court_booking_content .message {
    font-size: 20px;
    color: #B60124;
    padding: 0px;
    margin: 0px;
    text-align: center;
}

.oom_court_booking_content .danger {
    color: #B60124;
}

.oom_court_booking_content .success {
    color: #2A9B00;
}

/* The Close Button */
.oom_court_booking_close {
    float: right;
    position: relative;
    cursor: pointer;
    top: 15%;
    right: 2%;
}

.oom_court_booking_close svg {
    height: 25px;
}


@media (max-width: 480px) {
	#oom-courts-booking-status {
		display: flex;
		grid-template-columns: auto auto auto auto;
		padding: 10px;
		align-content: flex-start;
		flex-direction: column;
		flex-wrap: wrap;
		gap: 10px;
	}
	
	#oom-courts-booking-list {
		padding: 0px;
	}
}

