/* #main_form, #main_form * 
{
    border: 1px solid red;
} */



/* ::-webkit-scrollbar {
    width: 15px;
  }
  
  ::-webkit-scrollbar-track {
    box-shadow: inset 0 0 5px grey; 
    border-radius: 10px;
  }
   
  ::-webkit-scrollbar-thumb {
    background: #979a9c; 
    border-radius: 10px;
  }

  ::-webkit-scrollbar-thumb:hover {
    background: #c61914; 
  } */


.width_fill_available
{
    width: 100%;
    width: -moz-available;
    /* width: inherit; */
    width: -webkit-fill-available;
    width: fill-available;    
}

.height_fill_available
{
    height: 100%;
    height: -moz-available;
    height: inherit;
    height: -webkit-fill-available;
    height: fill-available;    
}




[jsui_datalist_wrapper] > *
{
    vertical-align: middle;
}



.prevent_text_selection {
-webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
    -khtml-user-select: none; /* Konqueror HTML */
        -moz-user-select: none; /* Old versions of Firefox */
        -ms-user-select: none; /* Internet Explorer/Edge */
            user-select: none; /* Non-prefixed version, currently
                                supported by Chrome, Edge, Opera and Firefox */
}


.ib
{ display: inline-block; }
.mrr
{ margin-right: 10px; }
.bl
{ 
    border-right: 4px solid gray; 
    padding-right: 10px !important;
}



.hr_div_inline__wrapper
{
    display:flex;
    flex-direction:row;
    align-items: center;
}
.hr_div_inline__hr
{
    flex-grow:1;
    height: 2px;
    background-color: #9f9f9f;
}
.hr_div_inline__div
{ 
    flex-grow:0; 
    margin-right: 10px;
}


[tbl_name]
{ display: none; }

[tbl_name], [tbl_name_wrapper], [tbl_name_test]
{ vertical-align: top; }

[elem_wrap] > *
{
    vertical-align: middle;
}

[elem_wrap] > label.ib 
{
    width: 150px;
    text-align: right;
}

[elem_wrap] label input
{ vertical-align: middle; }

[elem_wrap][flex_sb]
{
    display: flex;
    justify-content: space-between;
}

[elem_wrap][flex_r]
{
    display: flex;
    justify-content: right;
}



div[uploaded_file=view]
{
    text-align:left; 
    cursor: pointer; 
    padding: 5px;
    min-width: 250px;
}

div[uploaded_file=view]:hover
{
    background-color: lightgray;
}



.home_page_links
{
    display: inline-block;
    margin: 10px;
    box-shadow: var(--box-shadow_1);
    background-color: white;
    vertical-align: middle;

    /* border-radius: 50%; */
}

.home_page_links:hover
{ box-shadow: var(--box-shadow_2); }

.home_page_links > a
{
    display: flex;
    justify-content: center;
    align-items: center; 

    width: 250px;
    height: 250px;
}

.home_page_links_img
{
    width: 130px; 
    height: 130px;
}


/* #groups_info > div
{
    padding: 20px 20px;
} */

/* #groups_info, #groups_info *
{ border: 1px solid red; } */

.div_tr
{
    max-width: 320px;
    border-radius: 50px;
    box-shadow: var(--box-shadow_2);
    display: inline-block;
    /* padding: 7px 10px; */
}

.div_tr > div
{ 
    display: inline-block; 
    margin-left: 15px;
    margin-right: 15px;
    max-width: 200px;
    overflow: hidden;
    white-space: nowrap;
}



/* .input_flex_container, .input_flex_container *
{ border: 1px solid red; } */

.input_flex_container
{
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;

    width: 90%;
    margin: 0 auto;
}



[call_popup]:hover, [call_edit]:hover
{ color: #dc7139; }



/* ============================================== */



.tr_del, [status="delete"]
{ box-shadow: inset 0 0 4px red; }

.tr_add, [status="insert"]
{ box-shadow: inset 0 0 4px lightgreen; }

.tr_edit, [status="update"]
{ box-shadow: inset 0 0 4px lightyellow; }

.tr_edit, [status="done"]
{ box-shadow: inset 0 0 4px lightblue; }



[selected_row]
{ box-shadow: -4px 0 0px gray; }


[selected_row][status="delete"]
{ box-shadow: inset 0 0 4px red, -4px 0 0px gray; }

[selected_row][status="insert"]
{ box-shadow: inset 0 0 4px lightgreen, -4px 0 0px gray; }

[selected_row][status="update"]
{ box-shadow: inset 0 0 4px lightyellow, -4px 0 0px gray; }

[selected_row][status="done"]
{ box-shadow: inset 0 0 4px lightblue, -4px 0 0px gray; }
/* ============================================== */








/* .not_active_a
{ color: #979a9c; } */

a,
a:link, 
a:visited, 
a:hover, 
a:active 
{ 
    text-decoration: none; 
    outline : none;
}

a, [a_link]
{ 
    color: #f4813e; 
    /* display: inline-block; */
}

a:hover
{ color: #dc7139 !important; }

[a_link]:hover, [a_link]:hover a
{ 
    color: #dc7139;
    cursor: pointer; 
}



.div_two_columns {
    -webkit-column-count: 2; /* Chrome, Safari, Opera */
    -moz-column-count: 2; /* Firefox */
    column-count: 2;
  }



.all_on:hover
{ cursor: pointer; }

.inline
{display: inline-block;}


#logout
{
    width: 90%;
    background-color: #f4813e;
    display: inline-block;
    padding: 10px;
    color: white;
}

#logout:hover
{
    cursor: pointer;
    /* border-bottom: 3px solid #dc7139; */
    /* box-shadow: 1px 1px 5px #dc7139; */
}



.menu_bar
{
	background: #fff;
    box-shadow: var(--box-shadow_1);
    text-align: center;
    margin-bottom: 2px;
}

.menu_bar_pu
{
	background: #fff;
    box-shadow: var(--box-shadow_4);
    text-align: center;
    margin-bottom: 5px;
}


#background_cover
{
    z-index: 1000;
    position: fixed;
    top: 0px;
    left: 0px;
    background-color:rgba(192,192,192,0.5);
    height: 100vh; /* For 100% screen height */
    width:  100vw; /* For 100% screen width */
    /* display: none; */
    visibility: hidden;
    /* visibility: visible; */
}

h1 {
    font-size: 32px;
	/* color: var(--dark_gray);
	text-align: center;
    font-weight: normal; */
}

h2
{ 
    text-align: center; 
    font-size: 24px;
    /* color: var(--dark_gray); */
}

H3 {
	font-size: 20px;
}
H4 {
	font-size: 16px;
}

.padding_margin_0
{
    padding: 0px;
    margin: 0px;
}


input:focus,
select:focus,
textarea:focus,
button:focus,
datalist:focus
{
    outline: 0 none;
    box-shadow: var(--box-shadow_2) !important;

/* 
    border-color: inherit;
    -webkit-box-shadow: none;
    box-shadow: none; */
}

input:invalid,
select:invalid,
textarea:invalid,
button:invalid,
datalist:invalid
{
    outline: 0 none;
    box-shadow: none;
}

/* input, */
input:not([type="radio"]),
select,
textarea,
button,
datalist
{
    /* outline: 0 none;
    padding: 4px;
    border: 1px solid var(--shadow);
    border-radius: 3px;
    font-size: 14px; */

    /* display: block; */
    /* width: 300px; */
    padding: 0px 3px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    color: #212529;
    /* background-color: #fff; */
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: .25rem;
	margin: 5px 0px;
    /* display: inline-block; */
}

select[e_name$="_sw"] option[value="1"]
, select[e_name$="_sw"]:has(> option[value="1"]:checked) {
   background: lightgreen;
}

select[e_name$="_sw"] option[value="0"]
, select[e_name$="_sw"]:has(> option[value="0"]:checked) {
   background: lightpink;
}





.input_color
{
    padding: 0px;
    height: 28px !important;
    border: 2px solid var(--shadow);
}


.input_color:hover
{ cursor: pointer; }


.input_block_1
{ 
    /* border: 1px solid red; */

    margin: 20px 20px 20px 20px;
    text-align: left !important;
}  

.input_block_1,
.input_block_1 label,
.input_block_1 input,
.input_block_1 select
{ 
    display: inline-block; 
}


.input_block_1 input, .input_block_1 select,
.input_block_2 input, .input_block_2 select
{ width: 300px; }


.input_block_1 > label, .input_block_2 > label, .input_block_2 > [label]
{
    font-size: 14px;
    color: var(--light_gray);
    margin-right: 10px;
}

.input_block_2 > [label]
{
    width: 140px; 
    display: inline-block; 
    text-align: right !important;
}

.input_block_2
{
    text-align: left;
}


.input_required
{
   box-shadow: 0 0 5px 1px red !important;
}

.fixed 
{
   position: fixed;
   top: 0;
}
.sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}



.label_text
{
    /* color: var(--light_gray); */
    cursor: default;
	font-size: 14px;
    font-weight: 400;
    line-height: 2;
    color: #555555;
	margin: 5px 0px; 
}






.on_hover_bounce
{
 cursor: pointer;
 box-shadow: 0 0 1px rgba(0, 0, 0, 0);
 -webkit-transition-duration: 0.5s;
 transition-duration: 0.5s;
}

.on_hover_bounce:hover, .on_hover_bounce:focus, .on_hover_bounce:active
{
 -webkit-transform: scale(1.2);
 transform: scale(1.2);
 -webkit-transition-timing-function: cubic-bezier(0.47, -0.36);
 transition-timing-function: cubic-bezier(0.47, -0.36);
}

.on_hover_bounce_rotate_180
{
 cursor: pointer;
 box-shadow: 0 0 1px rgba(0, 0, 0, 0);
 -webkit-transition-duration: 0.5s;
 transition-duration: 0.5s;
 transform: rotate(180deg);
}

.on_hover_bounce_rotate_180:hover, .on_hover_bounce_rotate_180:focus, .on_hover_bounce_rotate_180:active 
{
 -webkit-transform: scale(1.2);
 transform: scale(1.2) rotate(180deg);
 -webkit-transition-timing-function: cubic-bezier(0.47, -0.36);
 transition-timing-function: cubic-bezier(0.47, -0.36);
}







.btn_next_prev
{
    cursor: pointer; 
    position: absolute; 
    top: 50vh; 
    box-shadow: var(--box-shadow_2); 
    height: 50px; 
    width: 50px; 
    border-radius: 50%; 
    transition-duration: 0.2s;
}

.btn_next_prev:hover
{
    box-shadow: var(--box-shadow_3);  
    top: 49.5vh;
    height: 60px; 
    width: 60px; 
}




.button_icon_100
{
	width: 100px;
	height: 100px;
	vertical-align:middle;
}

.button_icon_32
{
	width: 32px;
	height: 32px;
	vertical-align:middle;
}

.button_icon
{
	width: 24px;
	height: 24px;
	vertical-align:middle;
}

.button_icon_absolute
{
	/* position: absolute;
	top: 50%; left: 10%;
    transform: translate(-50%,-50%); */
    
	width: 24px;
	/* height: 24px; */
	vertical-align:middle;
}






.button_gray
{
    background: var(--shadow);
    color: var(--light_gray);
    text-decoration: none;
    padding: 4px 18px;
	margin: 0px 7px 0px 7px;
    border-radius: 3px;
    font-size: 15px/18px;
	font-weight: normal !important;
    text-shadow: 1px 1px rgba(0,0,0,0.2);
    display: inline-block;
    text-align: center;    
    display: inline-block;

}
.button_gray:hover
{ cursor: pointer; }

.button, .button_with_icon
{
    /* background: #e2211c;
    color: #fff;
    text-decoration: none;
    padding: 4px 18px;
	margin: 0px 7px 0px 7px;
    border-radius: 3px;
    font-size: 15px/18px;
	font-weight: bold;
    text-shadow: 1px 1px rgba(0,0,0,0.2);
    border: 1px solid #e2211c;
    display: inline-block;
    text-align: center; */

    display: inline-block;
	font-weight: 600;
    line-height: 1.5;
    color: #ffffff;
    background-color: #f58144;
    text-align: center;
    text-decoration: none;
	text-transform: uppercase;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    padding: 2px 30px;
    font-size: 14px;
    border-radius: .25rem;
	border-bottom: 3px solid #dc7139;
	margin: 5px 0px; 

}

.button_slim
{
    padding: 5px 15px;
	margin: 3px;    
}


.button_with_icon
{
    height: 32px;
}


.button:hover{
    background: #dc7139;
}
.button:hover, .button_with_icon:hover 
{
    cursor: pointer;
}


.sub_button 
{
    /* background: #fff;
    color: #e2211c;
    text-decoration: none;
    padding: 4px 18px;
	margin: 0 7px 0 7px;
    border-radius: 3px;
    font-size: 15px/18px;
	font-weight: bold;
    
    display: inline-block;
    text-align: center; */

    border: 1px solid #f58144;
    display: inline-block;
	font-weight: 600;
    line-height: 1.5;
    color: #f58144;
    background-color: #ffffff;
    text-align: center;
    text-decoration: none;
	text-transform: uppercase;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    padding: 2px 30px;
    font-size: 14px;
    border-radius: .25rem;
	border-bottom: 3px solid #dc7139;
	margin: 5px 0px; 

}

.sub_button:hover 
{
    color: #dc7139;
    border: 1px solid #dc7139;
    border-bottom: 3px solid #dc7139;
    cursor: pointer;
}

.main_border
{
    border-radius: 3px;
    border: var(--box-border);
}

















/*==========================================================*/
/* ---------------- container ----------------  */ 
.container 
{
    text-align: left;
	border: 1px solid #c7c7c7;
	border-radius: .125rem;
	background-color: #FFFFFF;
	padding: 30px;
	margin: 30px;
}

.content 
{
	border: 1px solid #c7c7c7;
	border-radius: .125rem;
	background-color: #FFFFFF;
	padding: 30px;
    display: none;
}
/* ---------------- container ----------------  */ 



/* ---------------- TABS ----------------  */ 
.tabs-icon 
{
	width: 20px;
	height: 20px;
	margin-right: 10px;
}


.nav-icon-left 
{
	width: 32px;
	height: 32px;
	vertical-align: middle;
	margin-right: 36px;
}

.nav-icon-right 
{
	width: 32px;
	height: 32px;
	vertical-align: middle;
	margin-left: 36px;
}

.tabs 
{
	background-color: #f3f3f3;
	width: 100%;
}

.tab-link, .tab-active 
{
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    align-items: center;
    padding: 1rem 2rem;
    margin-right: 0.2rem;
    cursor: pointer;
    margin-bottom: -1px;
    z-index: 10;
}

.tab-link 
{
    background-color: #f3f3f3;
    color: #f58144;
}
 
.tab-active
{
    background-color: #ffffff;
    color: #000000;

    border-left: 1px solid #ced4da;
    border-right: 1px solid #ced4da;
    border-bottom: 1px solid #ffffff;
    border-top: 1px solid #ced4da;
}
/* ---------------- TABS ----------------  */ 


/* ---------------- BOOKING LIST ELEMENTS ----------------  */
.booking-card 
{
	border-radius: 5px;
	width: 240px;
	box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
	margin-top: 30px; 
	margin-right: 30px;
    vertical-align: top;
}

.booking-card-date 
{
	border-radius: 5px 5px 0px 0px;
	box-sizing: border-box;
	width: 100%;
	/* background-color: #13cd00; */
	padding: 20px;
	font-weight: 800;
	color: #ffffff;
} 

.booking-card-info 
{
	width: 100%;
	border-radius: 0px 0px 5px 5px;
	box-sizing: border-box;
	background-color: #ffffff;
	padding: 20px;
	color: #000000;
	line-height: 1.5;
	border: 1px solid #f2f2f2;
} 
/* ---------------- TABS ELEMENTS ----------------  */
/*==========================================================*/






@media only screen and (max-width:720px) /*, (max-device-width : 720px)*/ /* desktop and mobile orientation: portrait */
{ 
    .container
    {
        padding: 0px;
        margin: 0px;
    }

    .home_page_links
    {
        display: inline-block;
        margin: 5px;
        box-shadow: var(--box-shadow_1);
    }
    
    .home_page_links > a
    {
        width: 150px;
        height: 150px;
    }

    .home_page_links_img
    {
        width: 80px; 
        height: 80px;
    }



}

@media (min-width:720px) and (max-width:1200px) and (min-device-width : 720px) /* desktop and mobile orientation: landscape */
{ 
    .container
    {
        padding: 0px;
        margin: 0px;
    }
}

@media (min-width:1200px) /* all other */
{ 

}
