/* Variables */
:root{
    /* Bootstrap 3 screen widths */
    --max-xs-screen-width: 767px;     /* Phones (max) */
    --max-sm-screen-width: 991px;     /* Tablets (max) */
    --max-md-screen-width: 1119px;    /* Desktops (max) */
    --min-sm-screen-width: 768px;     /* Tablets (min) */
    --min-md-screen-width: 992px;     /* Desktops (min) */
    --min-lg-screen-width: 1200px;    /* Large desktops (min) */

    /* LOUIS heights */
    --widget-height: 300px;

    /* Bootstrap 3 colors */
    --fg-muted: #777;
    --fg-info: #31708f;
    --fg-primary: #337ab7;
    --fg-success: #3c763d;
    --fg-warning: #8a6d3b;
    --fg-danger: #a94442;
    --bg-info: #d9edf7;
    --bg-primary: #337ab7;
    --bg-success: #dff0d8;
    --bg-warning: #fcf8e3;
    --bg-danger: #f2dede;
    --border-danger: #ebccd1;

    /* LOUIS colors */
    --fg-color: #323232;
    --fg-highlight: var(--fg-info);
    --bg-color: white;
    --bg-color-alt: #f2f2f2;
    /* These scoped colors are overridden in certain selectors. Use this if you want an element's color to depend on whether it is inside an element that overrides these values. */
    --scoped-bg-color: var(--bg-color);
    --scoped-bg-color-alt: var(--bg-color-alt);
    --bg-highlight: var(--bg-info);
    /* This color is used by Bootstrap 3 for various borders */
    --bg-bold: #e5e5e5;
    /* This is Bootstrap's alternate row color for striped tables, but we use it for all rows for regular tables */
    --bg-row: #f9f9f9;
    --bg-hover: var(--bg-bold);

    /* Box shadows */
    --shadow-offset-x: 0;
    --shadow-offset-y: 1px;
    --shadow-blur-radius: 5px;
    --shadow-color: rgba(0,0,0,0.65);
    --shadow: var(--shadow-offset-x) var(--shadow-offset-y) var(--shadow-blur-radius) var(--shadow-color);
    --shadow-light-offset-x: 5px;
    --shadow-light-offset-y: 5px;
    --shadow-light-blur-radius: 5px;
    --shadow-light-color: lightgrey;
    --shadow-light: var(--shadow-light-offset-x) var(--shadow-light-offset-y) var(--shadow-light-blur-radius) var(--shadow-light-color);

    /* Borders */
    --border-radius: 4px;
    --xs-border-radius: 3px;
    --border-width: 1px;
    --border-style: solid;
    --border-color: #ddd;
    --input-border-color: #ccc;
    --border: var(--border-width) var(--border-style) var(--border-color);
    --input-border: var(--border-width) var(--border-style) var(--input-border-color);

    /* Spacing */
    --space: 5px;
    --space-lg: 10px;
    --space-push-side: 100px;
    --padding: 10px;
    --padding-sm: 5px;
    --padding-xs: 2px;
    --filter-padding: var(--padding);
    --filter-padding-sm: var(--padding-sm);
    --filter-margin: var(--space);
    --filter-margin-sm: 0 var(--space);
    /* These scoped values are overridden in certain selectors so that filter controls have different padding/spacing depending on whether they are inside certain elements */
    --scoped-filter-padding: var(--filter-padding);
    --scoped-filter-margin: var(--filter-margin);
    --button-padding: 12px;
    --dropdown-button-padding: 8px;
    --navbar-height: 50px;
    --footer-height: 20px;
    --h2-margin-top: 20px;
    --main-header-margin-top: var(--h2-margin-top);

    /* Inputs */
    --input-height: 34px;
    --input-height-sm: 30px;
    --textarea-height: 100px;

    /* Badges */
    --tab-badge-v-position: -4px;
    --tab-badge-h-position: 2px;
    --tab-badge-font-size: .7em;
    --tab-badge-bg-color: #AEAEAE;

    /* Bootstrap 3 Z-Indices */
    --modal-backdrop-z-index: 1040;
    --modal-z-index: 1050;
    --tooltip-z-index: 1070;
    --popover-z-index: 1060;
    --navbar-z-index: 1030;

    /* Leaflet Z-Indices */
    --leaflet-control-z-index: 1000;

    /* LOUIS Z-Indices */
    --map-notice-z-index: 500;
    --leaflet-legend-z-index: 500;
    --dropdown-menu-z-index: calc(var(--leaflet-control-z-index) + 1);
    --fullscreen-z-index: 1100;

    /* Font Sizes */
    --small-font: 85%;
    --header-font: 1.3em;

    /*
    TODO: Come up with a good set of values for the following (so we don't use dozens of different values in our codebase):
    * Opacity
    * Transition speeds
    */
}

/* START BOOTSTRAP 4 */
/* Bootstrap 4 utilities not in 3 */
.float-left{float: left;}
.float-right{float: right;}
.d-block{ display: block; }
.d-inline{ display: inline; }
.d-flex{ display: flex; }
.d-none{ display: none; }
@media (min-width: 768px) {
    .float-sm-left{ float: left; }
    .float-sm-right{ float: right; }
    .d-sm-block{ display: block; }
    .d-sm-inline{ display: inline; }
    .d-sm-flex{ display: flex; }
    .d-sm-none{ display: none; }
}
@media (min-width: 992px) {
    .float-md-left{ float: left; }
    .float-md-right{ float: right; }
    .d-md-block{ display: block; }
    .d-md-inline{ display: inline; }
    .d-md-flex{ display: flex; }
    .d-md-none{ display: none; }
}
@media (min-width: 1200px) {
    .float-lg-left{ float: left; }
    .float-lg-right{ float: right; }
    .d-lg-block{ display: block; }
    .d-lg-inline{ display: inline; }
    .d-lg-flex{ display: flex; }
    .d-lg-none{ display: none; }
}
/* END BOOTSTRAP 4 */

.btn-group-xs-wide > .btn{
    padding-left: var(--button-padding);
    padding-right: var(--button-padding);
}
.input-group-xs > .btn, .input-group-xs > .form-control, .input-xs{
    height: 22px;
    padding: 1px 5px;
    font-size: 12px;
    line-height: 1.5;
    border-radius: var(--xs-border-radius);
}

.media_container{
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    height: fit-content;
    height: -webkit-fit-content;
    height: -moz-fit-content;
    position: relative;
}
.media_container.audio{
    width: 100%;
    max-width: 450px;
}
.media_container.audio > .media_loading{
    display: none !important;
}
.media_controls{
    width: 100%;
    color: white;
    font-size: 16px;
    display: none;
    padding-left: var(--padding-sm);
    padding-right: var(--padding-sm);
}
.media_controls.video{
    position: absolute;
    left: 0;
    bottom: 5px;
    background-color: rgba(0, 0, 0, 0.5);
}
.media_controls.audio{
    background-color: black;
    border-radius: var(--border-radius);
    display: flex;
}
.media_container:hover > .media_controls{
    display: flex;
}
.media_control{
    cursor: pointer;
    padding: var(--padding-sm);
    flex: 0;
    border-radius: var(--border-radius);
    transition: background-color 0.1s ease-in-out;
}
.media_control:hover{
    color: lightgray;
}
.media_group:hover{
    background-color: #444;
}
.media_slider{
    cursor: pointer;
    height: 3px;
    background-color: #444;
    position: relative;
    width: 100%;
}
.media_slider > input{
    -webkit-appearance: none;
    appearance: none;
    background: none;
    outline: none;
    width: 100%;
    height: 5px;
    position: absolute;
    left: 0;
    top: 0;
    cursor: pointer;
}
.media_slider > input::-webkit-slider-thumb{
    -webkit-appearance: none;
    appearance: none;
    width: 12px;
    height: 12px;
    margin-bottom: 2px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
}
.media_slider > input::-moz-range-thumb{
    -webkit-appearance: none;
    appearance: none;
    width: 10px;
    height: 10px;
    margin-bottom: 2px;
    border-radius: 50%;
    background: white;
    cursor: pointer;
}
.media_slider > input:disabled::-webkit-slider-thumb{
    background: #555;
    cursor: default;
}
.media_slider > input:disabled::-moz-range-thumb{
    background: #555;
    cursor: default;
}
.media_progress{
    height: 3px;
    position: absolute;
    left: 0;
    top: 0;
    background-color: white;
    cursor: pointer;
}

/* Definitions for basic page layout */
#content_wrapper{
    overflow-x: hidden;
    overflow-y: auto;
    position: absolute;
    top: var(--navbar-height); bottom: var(--footer-height); left: 0; right: 0;
}
#content_wrapper.flex_height > #main_container{
    display: flex;
    flex-direction: column;
    height: 100%;
}
#content_wrapper.flex_height > #main_container > #main_header_container{
    flex: 0;
}
#content_wrapper.flex_height > #main_container > #main_row{
    flex: 1;
    /* So tab badges, box shadows, etc. aren't clipped */
    padding-top: var(--space);
    margin-top: calc(-1 * var(--space));
}
#content_wrapper.flex_height > #main_container > #main_row > [class*="col-"]{
    padding-bottom: var(--space-lg);
}
#content_wrapper.flex_height > #main_container > #main_row > [class*="col-"] > *{
    max-height: 750px;
}
#content_wrapper.flex_height > #main_container > #main_row > [class*="col-"] > .tab-content{
    height: 750px;
}
#content_wrapper.flex_height > #main_container > #main_row > [class*="col-"] > .tab-content > .tab-pane{
    height: 100%;
}
@media (min-width: 768px) {
    #content_wrapper.flex_height_sm,
    #content_wrapper.flex_height_sm > #main_container,
    #content_wrapper.flex_height_sm > #main_container > #main_row{
        overflow-y: hidden;
    }
    #content_wrapper.flex_height_sm > #main_container > #main_row > [class*="col-"] > *{
        max-height: initial;
    }
    #content_wrapper.flex_height_sm > #main_container > #main_row > [class*="col-"] > .tab-content{
        height: initial;
    }
}
@media (min-width: 992px) {
    #content_wrapper.flex_height_md,
    #content_wrapper.flex_height_md > #main_container,
    #content_wrapper.flex_height_md > #main_container > #main_row{
        overflow-y: hidden;
    }
    #content_wrapper.flex_height_md > #main_container > #main_row > [class*="col-"] > *{
        max-height: initial;
    }
    #content_wrapper.flex_height_md > #main_container > #main_row > [class*="col-"] > .tab-content{
        height: initial;
    }
}
@media (min-width: 1200px) {
    #content_wrapper.flex_height_lg,
    #content_wrapper.flex_height_lg > #main_container,
    #content_wrapper.flex_height_lg > #main_container > #main_row{
        overflow-y: hidden;
    }
    #content_wrapper.flex_height_lg > #main_container > #main_row > [class*="col-"] > *{
        max-height: initial;
    }
    #content_wrapper.flex_height_lg > #main_container > #main_row > [class*="col-"] > .tab-content{
        height: initial;
    }
}
nav.navbar{
    margin-bottom: 0px;
}
.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    /* Set the fixed height of the footer here */
    height: var(--footer-height);
}
.footer p{
    margin: 0px;
    margin-top: 1px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow:hidden;
}

hr{margin-bottom: var(--space-lg); margin-top: var(--space-lg);}

/* Definitions for additional bootstrap table functionality */
@media (max-width: 800px) {
    .unimportant {
        display: none !important;
    }
    
}
.flex_list_panel{
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.fixed_header_table, .fixed_footer_table{
    border-collapse: separate;
}
.fixed_header_table > thead > tr > th{
    position: sticky;
	top: 0;
    z-index: 3;
    background-color: var(--scoped-bg-color-alt);
}
.fixed_footer_table > tfoot > tr > td{
    position: sticky;
	bottom: 0;
    z-index: 3;
    background-color: var(--scoped-bg-color-alt);
}
.fixed_header_table > tbody > tr:first-child > td{
    border-top: none;
}
.table_subheader{
    font-size: var(--small-font);
    font-weight: bold;
    background-color: var(--bg-color-alt) !important;
}
div.table-responsive table:not(.table-striped) > tbody > tr{
    background-color: var(--bg-row);
}
div.table-responsive table.table-hover > tbody > tr:hover{
    background-color: var(--bg-hover);
}
div.table-responsive table > thead > tr > th{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
td .action_buttons{
    display: flex;
    flex-direction: row-reverse;
}
tr:not(:hover) .show-on-mouseover{pointer-events: none; visibility: hidden;}
.table-super-condensed > tbody > tr > td, .table-super-condensed > tbody > tr > th, .table-super-condensed > tfoot > tr > td, .table-super-condensed > tfoot > tr > th, .table-super-condensed > thead > tr > td, .table-super-condensed > thead > tr > th{padding: 0px;}

/* Definitions for additional bootstrap modal functionality */
.modal-body{
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
}

div.modal.wide .modal-dialog{
    max-width: 80vw;
    width: auto;
}

/* Definitions for additional bootstrap dropdown functionality */
.dropdown-menu{
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
    z-index: var(--dropdown-menu-z-index);
}
ul.dropdown-menu > li > a.disabled{
    cursor: default;
    color: #777;
}
ul.dropdown-menu > li > a.disabled:hover{
    background: none;
}


/* Definitions for additional bootstrap form functionality */
form input[type="file"]{display: inline-block;}
form input.form-control[type="checkbox"]{width: auto;}
form input.form-control[type="range"]{padding: 0px;}
form textarea.form-control{min-height: 60px; height: var(--textarea-height); resize: vertical;}
.input-container.resize_n{
    top: 0 !important;
    width: 100% !important;
    min-height: var(--textarea-height);
    padding-top: 20px !important;
}
.input-container.resize_n > textarea{
    height: 100% !important;
    resize: none !important;
}
.input-container.resize_n > .n_handle{
    height: 20px;
    top: 0 !important;
    z-index: 90;
    display: flex;
    align-items: center;
}
.input-container.resize_n > .n_handle > .handle_indicator{
    background-image: repeating-linear-gradient(180deg, var(--input-border-color) 0 2px, transparent 2px 4px);
    height: 10px;
    width: 40px;
    margin-left: var(--space);
    margin-right: var(--space);
}
form input[type="checkbox"], input[type="radio"] {margin: 0px;}

/* Modifications to alerts */
div.alert, p.alert{
    margin-bottom: 0px;
}
.alert-muted{
    background-image: linear-gradient(to bottom,#e8e8e8 0,#d4d4d4 100%);
    background-repeat: repeat-x;
    border-color: #c2c2c2;
    color: #606060;
}
table:not(.tiles) > tbody > tr > td.alert{
    /* Remove border radius so border actually fits to alert in corners */
    border-radius: 0;
    /* Remove side borders so the table does not scroll horizontally */
    border-left: none;
    border-right: none;
}
/* Modifications to pagination */
.pagination{
    margin: 0 0!important;
}

/* Modifications to Progress Bars */
.progress {
    position: relative;
    margin-bottom: 0px;
}
.progress-bar-muted {
    background-image: linear-gradient(to bottom, #b8b8b8 0px, #9d9d9d 100%);
    background-repeat: repeat-x;
}

.box_subheader{
    font-size: var(--header-font);
    border-radius: var(--border-radius);
    background-color: var(--bg-bold);
    padding: var(--padding-sm) var(--padding);
    margin-bottom: var(--space);
    overflow-wrap: break-word;
}

/* Modifications to Tabs */
div.tab-pane{
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
    background-color: var(--bg-color);
    border-bottom: var(--border);
    border-left: var(--border);
    border-right: var(--border);
    padding: var(--padding);
}
div.tab-pane div.tab-header{
    font-size: var(--header-font);
    border-bottom: var(--border);
    margin-bottom: var(--space);
    margin-top: var(--space);
    overflow-wrap: break-word;
}
div.tab-content div.tab-pane{
    border-bottom-left-radius: var(--border-radius);
    border-bottom-right-radius: var(--border-radius);
}
.tab-danger{
    color: var(--fg-danger) !important;
}
.active > .tab-danger{
    border-top-color: var(--fg-danger) !important;
    border-left-color: var(--fg-danger) !important;
    border-right-color: var(--fg-danger) !important;
    background-color: var(--bg-danger) !important;
}
.tab-badge{
    /* Use !important so that this can be used on buttons too */
    position: absolute !important;
    top: -4px !important;
    right: 2px;
    font-size: 0.7em;
    background-color: #AEAEAE !important;
}
/* Modifications to tooltips */
body .tooltip.in {opacity: 1; filter: alpha(opacity=100);}
body .tooltip > .tooltip-inner{background-color: #e5e5e5; border: 1px solid var(--fg-color); color: var(--fg-color); padding: var(--padding-sm) var(--padding); text-align: left; max-width: inherit;}
body .tooltip > .tooltip-inner > ul {padding-left: 8px; margin-bottom: 0px;}
body .tooltip > .tooltip-inner .label{color: var(--fg-color); display: block; font-size: inherit; padding: 0px; font-weight: bold; text-align: left;}
body .tooltip > .tooltip-inner .label:not(:first-child){margin-top: var(--space-lg);}
body .tooltip > .tooltip-inner > div:not(.label){margin-left: var(--space-lg);}
body .tooltip.top > .tooltip-arrow{border-top: 5px solid var(--fg-color);}
body .tooltip.bottom  > .tooltip-arrow{border-bottom : 5px solid var(--fg-color);}
body .tooltip.left > .tooltip-arrow{border-left: 5px solid var(--fg-color);}
body .tooltip.right > .tooltip-arrow{border-right: 5px solid var(--fg-color);}

/* Modifications to Buttons */
/*:not(.btn-group) .btn{white-space: normal;}*/

/* Modifications to Forms */
.form-horizontal .control-text {
    /*margin-bottom: 0;
    padding-top: 7px;*/
}
.form-group {
    /*margin-bottom: 5px;*/
}
.form-group label{
    /*margin-bottom: 0px;*/
}

div.input-list-select{
    overflow-y: auto;
    min-height: 200px;
    min-width: 200px;
    text-align: default;
}
div.input-list-select input[type='checkbox']{
    margin-right: var(--space);
}

.progress span {
    position: absolute;
    display: block;
    width: 100%;
    color: black;
 }
 
 span.help-block{
    font-size: .85em;
    font-style: italic;
    margin-top: 0px;
    margin-bottom: 0px;
 }
 span.form_field_text{
    display: block;
    font-size: .85em;
    font-style: italic;
    margin-top: 0px;
    margin-bottom: 0px;
 }
 
 div.hovering_alert_container{
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 2;
 }
 div.hovering_alert{
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: var(--padding);
    border-radius: var(--border-radius);
    background-color: var(--bg-color);
    position: relative;
    left: -50%;
    top: -50%;
    box-shadow: var(--shadow);
 }
 div.hovering_alert > div.alert{
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
 }

/* custom generic definitions  */
.big_badge{
    min-width: 45px;
    max-width: 45px;
    width: 45px;
    min-height: 45px;
    max-height: 45px;
    height: 45px;
    padding: 4px;
    border-radius: var(--border-radius);
    text-align: center;
    font-weight: bold;
    color: #fff;
    background-color: #777;
}
.big_badge .badge_header{
    min-height: 12px;
    max-height: 12px;
    height: 12px;
    font-size: 10px;
}
.big_badge .badge_body{
    font-size: 19px;
}
.help_toggle{float: right; font-size: 21px; opacity: 0.5; cursor: pointer;}
.field_create_new_help_toggle{opacity: 0.5; cursor: pointer;}
.field_create_new_help_toggle:hover{opacity: 0.75;}
.help-example{font-size: .9em; background-color: var(--bg-color); border-radius: var(--border-radius); padding: var(--padding-sm) var(--padding); color: var(--fg-color); margin: var(--space);}
div.label_content_group{margin-bottom: 15px;}
div.label_content_group:last-child{margin-bottom: 0px;}
div.list-cell{margin-bottom: var(--space); border: var(--border); border-radius: var(--border-radius); padding: 2px 0;}
.no-show{display: none;}
.alert{padding-top: var(--padding-sm); padding-bottom: var(--padding-sm);}
.alert-sm{
    padding-left: var(--padding-sm);
    padding-top: 2px;
    padding-bottom: 2px;
}
.alert-sm:not(.alert-dismissible){
    padding-right: var(--padding-sm);
}
.icon-slash::after{
    content: "|";
    font-size: 133%;
    font-weight: 600;
    position: absolute;
    /*
        We can't use pixel values because this has to scale to any font size
        and still be positioned over the glyphicon correctly
    */
    left: -0.05em;
    top: -0.25em;
    text-shadow: -0.05em 0 0 white;
    transform: scale(1.5, 1) rotate(-55deg);
}
.fa.icon-slash::after{
    left: 0.15em;
}
.fa{position: relative;}
body span.glyphicon.text-muted, body span.fa.text-muted, body .fas.text-muted{color:#AAAAAA;}
span.glyphicon.glyphicon-padded{padding: 5px 6px; font-size: 12px;}
.hidden{display: none!important;}
.roundedbox{
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
    border: var(--border);
    border-radius: var(--border-radius);
    margin-bottom: var(--space-lg);
    padding: var(--padding);
    background-color: var(--bg-color);
}
.rounded_box{
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
    border-radius: var(--border-radius);
    background-color: var(--bg-color);
    padding: var(--padding);
    border: var(--border);
    width: 100%;
}
.panel-list {
    --scoped-bg-color: var(--bg-color-alt);
    --scoped-bg-color-alt: var(--bg-color);
    --scoped-filter-padding: var(--filter-padding-sm);
    --scoped-filter-margin: var(--filter-margin-sm);
    padding: var(--padding);
}
.row-eq-height {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

.row:not(.wide_gap){
    margin-right: calc(-1 * var(--space));
    margin-left: calc(-1 * var(--space));
}
[class*="col-"]:not(.wide_gap){
    padding-right: var(--space);
    padding-left: var(--space);
}
div.row.padded:not(:first-of-type) > div[class*="col-"]{margin-top: var(--space-lg);}
.rounded_box > .header{
    font-size: var(--header-font);
    border-bottom: var(--border);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    /* To make headers the same height as tabs */
    padding-bottom: 4px;
}

.rounded_box .subheader{font-weight: bold;}
div.row > div[class*="col-"] > .rounded_box {height: 100%;}
.rounded_box > .header + .body{margin-top: var(--space-lg);}
.single-line-text{text-overflow: ellipsis;white-space: nowrap;overflow: hidden}
.no-padding-right{padding-right: 0px;}

/* css for controlling list pages */
div.filter_controls{
    border: var(--border);
    border-radius: var(--border-radius);
    background-color: var(--scoped-bg-color);
    padding: var(--scoped-filter-padding);
}
div.filter_controls > form.form-inline{
    text-align: center;
}
div.filter_controls div.form-group,
div.filter_controls > form.form-inline > div.btn-group > button.dropdown-toggle,
div.filter_controls .filter_button{
    margin: var(--scoped-filter-margin);
}
table.table-hover > thead > tr > th[sortable_field]{cursor: pointer;}
table.table-hover > thead > tr > th[sortable_field]:hover{background-color: var(--scoped-bg-color);}

/* css for controlling custom widgets */
.tag_container{display: table; width: 100%;}
div.multi-select-checkbox, div.multi-select-checkbox-tiles {
    overflow-y: auto;
    overflow-x: hidden;
    min-height: 50px;
    height: auto;
    resize: vertical;
}
div.multi-select-checkbox{
    max-height: 200px;
}
div.multi-select-checkbox-tiles{
    max-height: 325px;
    box-shadow: none;
    border: none;
    padding: 0;
    resize: none;
}
.tile_info_text{
    font-size: 0.85em;
    font-style: italic;
    margin-left: var(--space);
}
div.multi-select-checkbox .group .group_header{
    font-size: 1.25em;
}
div.multi-select-checkbox .group > input{
    margin-left: 15px;
}

/* css for controlling listpage stats */
div.listpage-stats-container {
    display: none;
    border-top: 1px solid #e5e5e5;
    margin-top:10px;
}
div.listpage-status-bar {
    height: 100px;
    padding-top: 10px;
}
div.listpage-bar-label {
    padding-top: 0px;
    font-weight: bold;
}

.simple_filter_controls .input-group,
.simple_filter_controls .btn-group,
.simple_filter_controls .form-group,
.filter_controls .input-group,
.filter_controls .btn-group,
.filter_controls .form-group{
    position:relative;
}

.simple_filter_controls .active-filter,
.filter_controls .active-filter{
    position: absolute; 
    top: 2px; 
    left: 2px;
    z-index: 10;
    font-size: .75em;
    pointer-events: none;
}

.toggle_more_container a.show_more, .toggle_more_container a.show_less{
    font-size: 11px;
    font-weight: normal;
    cursor: pointer;
}

/* css for controlling the show more/less expandable text */
div.show_more_less_container:not(.expanded)::before{
    content: '';
    width: 100%;
    height: 30px;
    position: absolute;
    left: 0;
    bottom: 0;
    background: linear-gradient(transparent, #fff);
}
div.show_more_less_container:not(.expanded):hover .show_more{
    display: block;
}
div.show_more_less_container .show_more{
    display: none;
    width: 100%;
    height: 20px;
    position: absolute;
    left: 0;
    bottom: 0;
    text-align: center;
    color: #808080;
    background: linear-gradient(transparent, #fff);
    cursor: pointer;
}
div.show_more_less_container.expanded .show_less{
    display: block;
}
div.show_more_less_container .show_less{
    display: none;
    text-align: center;
    color: #808080;
    cursor: pointer;
}

div.show_more_less_container:not(.expanded){
    max-height: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    position: relative;
}

div.panel-group div.panel div.panel-heading{
    cursor: pointer;
}

.panel-sm > .panel-heading{padding: var(--padding-sm) var(--padding); height: fit-content;}
.panel-sm .panel-body{padding: var(--padding-sm) var(--padding);}
.panel-sm > .panel-heading > .panel-title > .tab-badge{top: -2px !important;}

@media (max-width: 767px){
    div.filter_controls button.dropdown-toggle span.caret{
        margin-left: auto;
        margin-top: 0.5em;
    }
    div.filter_controls ul.dropdown-menu{
        min-width: 100%;
    }
    form .input-group{
        width: 100%;
    }
    div.filter_controls div.btn-group, div.filter_controls button.dropdown-toggle{
        width: 100%;
        display: flex;
    }
    .nav-tabs.nav-justified {
        border-radius: 4px;
    }
    .tab-content > .tab-pane{
        border-top: 1px solid #ddd;
        border-radius: 4px;
    }
    .tab-badge{
        top: 2px;
    }
}

.ui-resizable{
    position: relative;
}
.ui-resizable-handle.ui-resizable-e{
    cursor: e-resize;
    width: 8px;
    right: -4px;
    position: absolute;
    top: 0;
    height: 100%;
}
.ui-resizable-handle.ui-resizable-n{
    cursor: n-resize;
    height: 8px;
    top: -4px;
    position: absolute;
    left: 0;
    width: 100%;
}

select option:disabled{
    cursor: not-allowed;
}

.highlighted_result > .message_container{
    border-width: calc(var(--border-width) + 1);
    border-color: var(--fg-highlight);
}
.reply_link_container, .edit_link_container, .delete_link_container{
    display: none;
}
.message_container:hover .reply_link_container,
.message_container:hover .edit_link_container,
.message_container:hover .delete_link_container{
    display: initial;
}

.tooltip-inner {
    padding-left: 0px;
    /*min-width: 150px;*/
}
.tooltip-inner div.tooltip-label{
    padding: 1px 4px;
    border-radius: var(--xs-border-radius);
    margin-left: 0px;
}
.tooltip-inner > div.margin-fix {margin-left: 0px!important;}

.embedded_recaptcha > div{margin-left: auto;}

/* This was added so that datetimepickers within dropdowns (such as for date filters on list pages) wouldn't break out of their parent elements due to the bootstrap css rule on .dropdown-header */
.datepicker table tr td {
    white-space: normal;
}
