@import url(https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700&subset=latin,greek,greek-ext,cyrillic,cyrillic-ext,latin-ext,vietnamese);
html, body {
	height: 100%;
}
@font-face{
	font-family:'digital-clock-font';
	src: url('../theme/fonts/digital-7.regular.ttf');
}
body {
	padding: 63px 15px 15px 15px;
	background: #f8f8f8;
	font-family: -apple-system, system-ui, BlinkMacSystemFont;	
	color: #444444;	
	font-weight: 500;	
	font-size: 13.5px;
}

#loading_panel {
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	right: 0px;
	z-index: 99999;
	background-color: ghostwhite;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	height: 100%;
	overflow: hidden;
}
#loading_data_panel {
	background-color: #021929;
	opacity: 0.6;
	filter: Alpha(Opacity=30);
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	right: 0px;
	z-index: 99999;
}
.icon-only i {
	font-size: 18px;
	color: #ffffff;
	margin-top: 2px;
}

.width10 { width: 10%; }
.width20 { width: 20%; }
.width33 { width: 33.33333%; }
.width40 { width: 40%; }
.width45 { width: 45%; }
.width50 { width: 50%; }
.width100 { width: 100%; }
.clearfix { display: table; width: 100%; }
.block1 { padding-right: 5px; }
.block2 { padding-left: 5px; }

.object-item {
	display: table;
	width: 100%;
	cursor: pointer;
}

a,
a:hover { text-decoration: none; color: #021929; }
b, strong{ font-weight: 600; }

#page_object_list .visible,
#page_object_list .follow,
#page_object_list .details {
	cursor: pointer;
}

#event_list_page {
	text-align: left;
	border: none;
}
#event_list_page option {
	text-align: center;
}

/*#################################################*/
/* PAGES
/*#################################################*/

.page
{
	display: none;
	overflow-x: hidden;
	overflow-y: auto;
}

.page-map { padding: 0px; position: absolute; top: 49px; bottom: 0px; left: 0px; right: 0px; }

/*#################################################*/
/* MAP DIVS
/*#################################################*/

#map { position: absolute; top: 0px; bottom: 0px; left: 0px; right: 0px; }

#map_layer
{
	border: none;
	font-size: 15px;	
	padding: 0 !important;	
	height: 32px !important;	
	padding-left: 3px;	
	margin-top: 9px;	
	text-align-last:center; 	
	z-index: 999;
}

#history_playback
{
	display: none;
	position: absolute;
	bottom: 49px;
	left: 15px;
	background-color: #5d95d5;
	padding: 3px;
	border-radius: 5px;
	box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
	z-index: 10;
	font-size: 12px;
}

#history_playback a
{
	color: #ffffff;
	margin: 5px;
}

#history_playback select
{
    height: 22px;
    padding: 0;
    margin-right: 5px;
}


.leaflet-left .leaflet-control
{
	margin-top: 15px;
	margin-left: 15px;
}

/*#################################################*/
/* DATALIST
/*#################################################*/

#bottom_panel {
	position: absolute;
	bottom: 0px;
	left: 0px;
	right: 0px;	
	display: none;
	background: #ffffff;
}

.datalist {
	padding: 10px;
}

.datalist-object-name {
	display: block;
	width: 100%;
	height: 26px;
	padding-top: 5px;
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
	z-index: 999999;	
	background-color: #f5f5f5;
	font-weight: 600;
	font-size: 11px;
}

.datalist-object-name-close-icon {
	float: right;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 10px 10px;
	width: 16px;
	height: 16px;
	margin-left: 10px;
}

.datalist-item-list {	
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-content: flex-start;
	overflow-x: auto;
	height: 96px;
	font-size: 11px;
}

.data-item-text {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	font-size: 20px;
	text-align: center;
	vertical-align: middle;
	color: #aaaaaa;
}

.datalist-item {
	display: flex;
	float: left;
	width: 270px;
	min-width: 270px;
	margin-right: 15px;
	padding-left: 5px;
	padding-right: 5px;
	line-height: 24px;
}

.datalist-item.even {
	background-color: #f5f5f5;
}

.datalist-item.odd {
	background-color: #ffffff;
}

.datalist-item-icon {
	float: left;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 14px 14px;
	width: 24px;
	height: 24px;
}

.datalist-item-name {
	display: inline-block;
	width: 80px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.datalist-item-value {
	display: inline-block;
	width: 156px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	text-align: right;
}

/*#################################################*/
/* PLACES NAVBAR
/*#################################################*/

#places_navbar
{
	min-height: 0px;
}

/*#################################################*/
/* MARKERS, ROUTES, ZONES PANEL
/*#################################################*/

.markers-panel,
.routes-panel,
.zones-panel {
	display: none;
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	right: 0px;
	background-color: #f8f8f8;
	padding-top: 70px;
	padding-left: 15px;
	padding-right: 15px;
	padding-bottom: 15px;
	z-index: 10;
	overflow-x: hidden;
	overflow-y: auto;
}

/*#################################################*/
/* HISTORY NAVBAR
/*#################################################*/

#history_navbar
{
	display: none;
	min-height: 0px;
}

#history_navbar a
{
	color: #fff;
	border-radius: 0;
}

#history_navbar_map
{
	display: none;
}

#history_navbar_graph
{
	display: block;
}

#history_navbar_details
{
	display: block;
}

/*#################################################*/
/* GRAPH PANEL
/*#################################################*/

.graph-panel {
	display: none;
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	right: 0px;
	background-color: #f8f8f8;
	padding-top: 20px;
	padding-left: 15px;
	padding-right: 15px;
	padding-bottom: 15px;
	z-index: 10;
	overflow: hidden;
}
.graph-panel-label
{
	position: absolute;
	right: 25px;
	top: 75px;
}
.graph-panel-plot
{
	height: 100%;
	width: 100%;
}

.graph-controls
{
	margin-bottom: 10px;
	display: table;
	width: 100%;
}
.graph-controls div
{
	display: inline-block;
	vertical-align: middle;
}
.graph-controls-left
{
	float: left;
}
.graph-controls-right
{
	float: right;
}
.graph-controls a
{
	margin: 5px;
	display: inline-block;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-ms-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.graph-controls a:hover { opacity: 0.9; }

/*#################################################*/
/* ROUTE PANEL
/*#################################################*/

.details-panel {
	display: none;
	position: absolute;
	top: 0px;
	bottom: 0px;
	left: 0px;
	right: 0px;
	background-color: #f8f8f8;
	padding-top: 20px;
	padding-left: 15px;
	padding-right: 15px;
	padding-bottom: 15px;
	z-index: 10;
	overflow-x: hidden;
	overflow-y: auto;
}

/*#################################################*/
/* LOGIN PAGE
/*#################################################*/

.login-page .navbar-brand {
        height: auto;
}

.login-page {
		padding: 0 15px 15px 15px;
		background: url(images/bgmobile.jpg) no-repeat center center fixed;
		-webkit-background-size: cover;
		-moz-background-size: cover;
		-o-background-size: cover;
		background-size: cover;
		height: 100%;
		overflow: hidden;
}

.login-page .navbar-default {
        margin-left: -15px;
        margin-right: -15px;
}

.login-page .buttons-block {
	padding-top: 0px;
	border-top: 1px solid #dddddd;
}

.login-page .remember-me
{
	padding-top: 6px;
	font-weight: 600;
}

.login-page .btn-remember-me
{
	padding-right: 10px;
}

/*#################################################*/
/* MENU PANEL
/*#################################################*/

.show-menu {
	margin-top: 15px;
}
.page-menu .page-title {
	box-sizing: border-box;
	margin-bottom: 15px;
	font-size: 18px;
	line-height: 50px;
	padding: 0 15px;
	height: 49px;
	display: table;
	width: 100%;
	color: #ffffff;
	background: #4693d3;
	border-bottom-left-radius: 10px; /* Adjust the radius as needed */
	border-bottom-right-radius: 10px; 
}
.page-menu .title-block i {
	color: #ffffff;
	position: absolute;
	right: 10px;
	top: 8px;
}
.page-menu .button-block {
	margin: 30px auto;
	display: table;
}
.page-menu .button-block a {
	color: #444444;
}
.page-menu {
	display: none;
}
.menu-block {
	position: absolute;
	top: 0px;
	left: 0px;
	bottom: 0px;
	width: 100%;
	height: 100%;
	color: #696969;
	z-index: 999999;
	box-shadow: 3px 0px 3px 0px rgba(0, 0, 0, 0.3);
	background: #f8f8f8;
	  /* background-image: url('./theme/images/back.png'); */
  /* background-size: cover; /* Ensures the background covers the entire div */ */
  /* background-position: center; */
}
.page-menu ul {
	padding: 0 15px 30px 0;
	margin: 0;
	display: table;
	width: 100%;
	list-style: none;
}
.page-menu ul li {
	width: 33.333%;
	float: left;
	padding-top: 15px;
	padding-left: 15px;
	box-sizing: border-box;
	
}
.page-menu ul li a {
	color: #696969 !important;
	font-size: 13px;
	padding: 20px 10px;
	display: block;
	text-decoration: none;
	position: relative;
	font-weight: 400;
	text-align: center;
	background: #ffffff;
	-webkit-box-shadow: 0 0 5px 0 #eaeaea;
	box-shadow: 0 0 5px 0 #eaeaea;
}
.page-menu ul li a:hover { opacity: 0.8; }
.page-menu ul li a.selected { }
.page-menu ul li a i {
	width: 100%;
	font-size: 25px;
	margin-bottom: 10px;
}
/*#################################################*/
/* MENU
/*#################################################*/

.ui-menu { position: absolute; min-width: 150px; white-space: nowrap;border-radius: 5px; z-index: 99999999; }
.ui-menu .ui-menu-icon {
    top: 8px;
}
.menu {
	background: #ffffff;
	-webkit-box-shadow: 0 0 5px 0 #9b9b9b;
	box-shadow: 0 0 5px 0 #9b9b9b;
}
.menu ul {
	background: #ffffff;
	-webkit-box-shadow: 3px 0 5px 0 #9b9b9b;
	box-shadow: 3px 0 5px 0 #9b9b9b;
}
.menu li { border-top: 1px solid #f5f5f5; }
.menu li:first-child { border: none; }
.menu li a:hover { background-color: #f5f5f5; }
.menu.ui-menu .first-item { border-top: 3px solid #2b82d4;border-radius: 5px 5px 0px 0px;}
.menu ul li a,
.menu .ui-menu-icon { background: url(images/arrow-right.svg) left center no-repeat; background-size: 10px 10px; overflow: visible; }
.menu.ui-menu .ui-menu-item a {
	background-repeat: no-repeat;
	background-position: 10px center;
	background-size: 10px 10px;
	padding: 5px 15px 5px 28px;
	color: #444444;
}
/*#################################################*/
/* ICONS
/*#################################################*/

.leaflet-control-zoom-in,
.leaflet-control-zoom-out,
.leaflet-control a span {
	display: table;
	width: 100%;
	height: 100%;
	background-size: 12px 12px;
	background-repeat: no-repeat;
	background-position: center center;
}
.leaflet-control a span.disabled {
	opacity: 0.5;
}
.leaflet-control-zoom-in { background-image: url(images/plus.svg); }
.leaflet-control-zoom-out { background-image: url(images/minus.svg); }
.icon-objects { background-image: url(images/object-arrow.svg); }
.icon-text { background-image: url(images/text.svg); }
.icon-marker { background-image: url(images/marker.svg); }
.icon-markers { background-image: url(images/markers.svg); }
.icon-routes { background-image: url(images/routes.svg); }
.icon-zones { background-image: url(images/zones.svg); }
.icon-kml { background-image: url(images/kml.svg); }
.icon-clusters { background-image: url(images/clusters.svg); }
.icon-traffic { background-image: url(images/traffic.svg); }

.icon-time { background-image: url(images/time.svg); }
.icon-warning { background-image: url(images/warning.svg); }
.icon-nearest-marker { background-image: url(images/nearest-marker.svg); }
.icon-nearest-zone { background-image: url(images/nearest-zone.svg); }
.icon-address { background-image: url(images/address.svg); }
.icon-altitude { background-image: url(images/altitude.svg); }
.icon-angle { background-image: url(images/angle.svg); }
.icon-speed { background-image: url(images/speed.svg); }
.icon-engine-hours { background-image: url(images/engine-hours.svg); }
.icon-odometer { background-image: url(images/odometer.svg); }
.icon-model { background-image: url(images/model.svg); }
.icon-plate-number { background-image: url(images/plate-number.svg); }
.icon-sim { background-image: url(images/sim.svg); }
.icon-vin { background-image: url(images/vin.svg); }
.icon-user { background-image: url(images/user.svg); }
.icon-trailer { background-image: url(images/trailer.svg); }
.icon-default-custom-fields { background-image: url(images/default-custom-fields.svg); }
.icon-default-sensor { background-image: url(images/default-sensor.svg); }
.icon-status { background-image: url(images/status.svg); }
.icon-battery-lev-0 { background-image: url(images/battery-lev-0.svg); }
.icon-battery-lev-1 { background-image: url(images/battery-lev-1.svg); }
.icon-battery-lev-2 { background-image: url(images/battery-lev-2.svg); }
.icon-battery-lev-3 { background-image: url(images/battery-lev-3.svg); }
.icon-di { background-image: url(images/di.svg); }
.icon-do { background-image: url(images/do.svg); }
.icon-fuel { background-image: url(images/fuel.svg); }
.icon-engine { background-image: url(images/engine.svg); }
.icon-gsm { background-image: url(images/gsm.svg); }
.icon-gps { background-image: url(images/gps.svg); }
.icon-temperature { background-image: url(images/temperature.svg); }
.icon-action2 { background-image: url(images/action2.svg); }
.icon-maintenance { background-image: url(images/maintenance.svg); }
.icon-route-event { background-image: url(images/route-event.svg); }
.icon-time { background-image: url(images/time.svg); }
.icon-arrow-right { background-image: url(images/arrow-right.svg); }
.icon-close { background-image: url(images/remove.svg); }


.leaflet-control a span.disabled {
	opacity: 0.5;
}

/*#################################################*/
/* BUTTONS
/*#################################################*/

a i,
.btn i { margin-right: 5px; }
.btn.btn-green { background-color: #9CC602; color: #ffffff; border-color: #9CC602; }
.btn.btn-blue { background-color: #2b82d4; color: #ffffff; border-color: #2b82d4; }

.btn.back-btn {
	margin-bottom: 15px;
}

.btn.login-btn {
	margin-bottom: 15px;
}

.btn.desktop-btn {
	margin-bottom: 15px;
}

/*#################################################*/
/* TABLELESS STYLING
/*#################################################*/

.table{
	display: table;
	height: 100%;
	width: 100%;
	margin: 0;
	padding: 0;
}

.table-cell{
	display: table-cell;
	margin: 0;
	padding: 0;
}

.center-middle{
	vertical-align: middle;
	text-align: center;
}

/*#################################################*/
/* BOOTSTRAP
/*#################################################*/

/*THEME*/

@font-face {
  font-family: 'Glyphicons Halflings';

  src: url('../theme/fonts/custom/glyphicons-custom.eot');
  src: url('../theme/fonts/custom/glyphicons-custom.eot?#iefix') format('embedded-opentype'), url('../theme/fonts/custom/glyphicons-custom.woff2') format('woff2'), url('../theme/fonts/custom/glyphicons-custom.woff') format('woff'), url('../theme/fonts/custom/glyphicons-custom.ttf') format('truetype'), url('../theme/fonts/custom/glyphicons-custom.svg#glyphicons_halflingsregular') format('svg');
}

.modal-content { border-radius: 10px; }
.modal-body { padding: 20px 15px 15px 15px; }
.btn-primary, .btn-primary:hover, .btn-primary:focus { background-color: #2b82d4; border: 1px; border-color: #2b82d4; }
.btn-group { width: 100%; }
.btn { border-radius: 0px; border-color: #e8e8e8; overflow: hidden;font-weight: 500;border-radius: 5px; }
.panel { border-radius: 0px; border-color: #e8e8e8; box-shadow: none;}
.form-control { /* border-radius: 0px;*/ border-color: #e8e8e8;}
.input-group-addon { border-radius: 0px; border-color: #e8e8e8; }
.list-group-item:first-child { border-radius: 0px; border-color: #e8e8e8; }
.list-group-item:last-child { border-radius: 0px; border-bottom-color: #e8e8e8; }
.dropdown-menu {
	min-width: auto;
	width: 100%;
}
.dropdown-toggle {
	min-width: auto;
	width: 100%;
}
.vertical-align {
    display: flex;
    align-items: center;
}
.form-control {
	box-shadow: none;
	font-size:13px;
}
@media (min-width: 768px) {
  .navbar > .container .navbar-brand,
  .navbar > .container-fluid .navbar-brand {
    margin-left: 0;
  }
}
/* CUSTOM ICONS */

.glyphicon-desktop:before {
  content: "\e261";
}
.glyphicon-exit:before {
  content: "\e262";
}
.glyphicon-cheeckbook:before {
  content: "\e263";
}
.glyphicon-history:before {
  content: "\e264";
}
.glyphicon-openlock:before {
  content: "\e265";
}

/*SEARCH*/

.search-clear {
    position: absolute;
	right: 25px;
    top: 80px;
    cursor: pointer;
    color: #ccc;
	z-index: 1;
}

/* DATEPICKER */
.dtpicker-content {
	background: #fff;
	height: 200px;
}
.dtpicker-components .dtpicker-comp {
	border: 1px solid #e8e8e8;
	margin-right: 3px;
}
.dtpicker-components .dtpicker-compValue {
	margin: 0;
	border-top: 1px solid #e8e8e8;
	border-bottom: 1px solid #e8e8e8;
}
.dtpicker-buttonCont {
	margin: 10px 0;
	padding: 5px 0;
}
.dtpicker-components .dtpicker-compButton,
.dtpicker-components .dtpicker-compButton:hover {
	background: #f8f8f8;
	color: #444444;
	text-decoration: none;
}
.dtpicker-components .dtpicker-compValue,
.dtpicker-components .dtpicker-compValue:hover {
	color: #444444;
}

/*LIST GROUP*/

#page_object_list a
{
	color: none;
}

#page_object_list_header .row,
#page_object_list .row {
	margin-left: 0px;
	margin-right: 0px;
}

#page_object_list_header
{
	margin-bottom: -1px;
}

#page_object_list_header .object-group
{
	margin-bottom: 5px;
}

#page_object_list_header .list-group-item
{
	padding: 1px 7px;
}

#page_object_list_header .object-list-item .name
{
	display: table-cell;
	vertical-align: middle;
	height: 30px;
	text-align: center;
	font-size: 13px;
	color: #999;
}

#page_object_list_header .object-list-item .details
{
	width: 19px;
}

.list-group-btn { border: 0px; }
.list-group-item { padding: 2px 5px 7px 5px; font-size: 12px;font-weight: 500;border: 1px solid #f2f2f2;line-height: 1.3; }
.list-group-item .icon { float:left; margin-top: 4px; margin-right: 6px; }
.adjuste{
	 padding: 4px 4px 4px 4px !important;
}
.object-list-item {
	height: 46px;	
	width: 100%;
}
.object-list-item .left {
	float: left;
	width: 150px;
}
.object-list-item .right {
	display: table;
	float: right;
	Height:60%;
}
.object-list-item .name {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: 12.8px;
	color: #004c8c;
	margin-bottom: 1px;
}
.object-list-item .status {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: #747171;
	font-size: 12px;
}
.object-list-item .speed,
.object-list-item .engine,
.object-list-item .connection,
.object-list-item .visible,
.object-list-item .follow,
.object-list-item .details {
	display: table-cell;
	vertical-align: middle;
	height: 100%;
	text-align: center;
	padding: 0px 3px;
}
.object-list-item .speed {
	font-size: 14px;
    font-weight: 600;
    letter-spacing: 1px;
    color: #636363;
    max-width: 80px;
    font-family: 'digital-clock-font';
    text-overflow: ellipsis;
    overflow: hidden;
}
.object-list-item .visible,
.object-list-item .follow{
	font-size: 16px;
	color: #BBB;
}
.object-list-item .details{
	padding-right: 0px;
	font-size: 16px;
	color: #5394d4f7;
}

.object-list-item .checked { color: #198FCE; }

@media only screen and (max-width: 354px) {
	.list-group-item .icon {
		display: none;
	}
	.object-list-item-status {
        gap: 3px !important;
    }
}

/*CHECKBOX*/

.form-group input[type="checkbox"] {
	display: none;
}

.form-group input[type="checkbox"] + .btn-group > label span {
	width: 20px;
}

.form-group input[type="checkbox"] + .btn-group > label span:first-child {
	display: none;
}

.form-group input[type="checkbox"] + .btn-group > label span:last-child {
	display: inline-block;   
}

.form-group input[type="checkbox"]:checked + .btn-group > label span:first-child {
	display: inline-block;
}

.form-group input[type="checkbox"]:checked + .btn-group > label span:last-child {
	display: none;   
}

/*NAVBAR*/

.navbar { border-radius: 0px;border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; }
.navbar-default { background: #4693d3; border: none;border-bottom: 1px solid #73a4d4; }
.navbar-default .navbar-brand,
.navbar-default .navbar-brand:hover { color: #ffffff;font-size:17px !important ;font-weight: 600;}

.container > .navbar-header,
.container-fluid > .navbar-header,
.container > .navbar-collapse,
.container-fluid > .navbar-collapse {
	margin-right: auto;
	margin-left: auto;
}

/*#################################################*/
/* LOADER
/*#################################################*/

.loader {
	width: 70px;
	display: block;
	margin: 25px auto;
}

.loader span {
	float: left;
	vertical-align: middle;
	width: 8px;
	height: 8px;
	margin-right: 2px;
	background: #4299eb;
	opacity: 0.1;
	animation: loader 0.7s infinite alternate;
}

.loader span:nth-of-type(2) {
        animation-delay: 0.2s;
}
.loader span:nth-of-type(3) {
        animation-delay: 0.3s;
}
.loader span:nth-of-type(4) {
        animation-delay: 0.4s;
}
.loader span:nth-of-type(5) {
        animation-delay: 0.5s;
}
.loader span:nth-of-type(6) {
        animation-delay: 0.6s;
}
.loader span:nth-of-type(7) {
        animation-delay: 0.7s;
}

@keyframes loader {
        0% {
                opacity: 1;
        }
        100% {
                opacity: 0.1;
        }
}
.loader1 {
	width: 54px;
	height: 54px;
	display: block;
	margin: 0px auto;
	box-sizing: border-box;
	position: relative;
  }
  .loader1::after {
	content: '';  
	box-sizing: border-box;
	width: 54px;
	height: 54px;
	left: 0;
	bottom: 0;
	position: absolute;
	border-radius: 50% 50% 0;
	border: 15px solid #62b1d2;
	transform: rotate(45deg) translate(0, 0);
	box-sizing: border-box;
	animation: animMarker 0.4s ease-in-out infinite alternate;
  }
  .loader1::before {
	content: '';  
	box-sizing: border-box;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 150%;
	width: 24px;
	height: 4px;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.2);
	animation: animShadow 0.4s ease-in-out infinite alternate;
  }
  
  @keyframes animMarker {
	0% {
	  transform: rotate(45deg) translate(5px, 5px);
	}
	100% {
	  transform: rotate(45deg) translate(-5px, -5px);
	}
  }
  
  @keyframes animShadow {
	0% {
	  transform: scale(0.5);
	}
	100% {
	  transform: scale(1);
	}
  }
  .boxdata{
	-webkit-box-shadow: 0px 2px 8px 0px rgba(159,161,171,0.55);
	-moz-box-shadow: 0px 2px 8px 0px rgba(159,161,171,0.55);
	box-shadow: 0px 2px 8px 0px rgba(159,161,171,0.55);
	width:auto;
	margin:auto;
	top:49px;
	margin-top: 20px;
	padding: 5px 5px 5px;
	font-size : 12px;
	margin-left: 6px;
	margin-right: 6px;
	border-radius: 8px;
	-moz-border-radius: 8px;
	-webkit-border-radius: 8px;
	border: 0px solid #000000;
}
.nopad{
	padding:1px;
	font-weight:500;
	font-family: "Roboto", Arial, sans-serif;
	color: #6e6e6e;
}
.nopad1{
	color: #477fb6;
	padding:1px;
	font-weight:500;
	font-family: "Roboto", Arial, sans-serif;
}
.cartitle{
	font-size: 13px;
	background-image: linear-gradient(to right,#5394d4,#2193b0);
    color: white;
    font-weight: 700;
    border-radius: 5px;
}
.cartitle1{
	padding-bottom: 5;
	color:#477fb6;
	font-size:13px;
	font-weight:700;
}
.bnt-neutralisation {
	text-align: center;
}
.lange_bottom{
	width: 80px;
	margin-left: auto;
	margin-right: auto;
	padding: 3px 5px;
	height: auto;
	font-size: 13px;
}
h4{
	font-size:16px;
}
      .marker-icon {
        background-color: red;
        border-radius: 16px;
        position: relative;
      }
	  
.cnf_left{
	    margin-left: 60px;
}
.cnf_right{
	    margin-right: 60px;
}
.web-app {
	overflow: hidden;
	height: 100%
}

.web-app {
	min-height: 600px;
}
.cat-boxes .cat-box .inner {
	-webkit-transition: all, 0.2s, ease-in;
	transition: all, 0.2s, ease-in
}
.cat-boxes .cat-box {
	display: block;
	text-decoration: none;
	width: 16.66666667%;
	float: left;
	padding: 3px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	text-align: center;
	color: #151515;
    font-family: 'Open Sans', sans-serif !important;
}

.uzr-panel .cat-boxes .cat-box {
	width: 33.3333334%;
	padding: 15px
}

@media (max-width: 767px) {
	.uzr-panel .cat-boxes .cat-box {
		width: 50%
	}
}

@media (max-width: 400px) {
	.uzr-panel .cat-boxes .cat-box {
		width: 100%;
		float: none;
		padding: 0;
		margin-bottom: 10px
	}
}

.cat-boxes .cat-box .inner {
	position: relative;
	padding: 15px 5px;
	background: #fff;
	border-radius: 10px;
	-webkit-box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
	box-shadow: 0 0 0 0 rgba(0, 0, 0, 0)
}

.cat-boxes .cat-box .inner:hover {
	z-index: 20;
	-webkit-box-shadow: 0 0 21px 9px rgba(0, 0, 0, 0.14);
	box-shadow: 0 0 21px 9px rgba(0, 0, 0, 0.14)
}

.cat-boxes .cat-box .inner>div {
	width: 75px;
	height: 75px;
	border-radius: 50%;
	line-height: 75px;
	color: #fff;
	font-size: 50px;
	margin: 0 auto 17px;
	background: #0083c9
}

.uzr-panel .cat-boxes .cat-box .inner>div {
	font-size: 35px
}

@media (max-width: 1023px) {
	.cat-boxes .cat-box {
		width: 25%
	}
}

@media (max-width: 767px) {
	.cat-boxes .cat-box {
		width: 33.3333334%
	}
}

@media (max-width: 500px) {
	.cat-boxes .cat-box {
		width: 50%
	}
}
.bg1,
.bg1-icon-wrap:hover span,
.bg1-icon-wrap.active span {
	background: #4693d3 !important;
	font-size : 48px !important;
}

.bg2,
.bg2-icon-wrap:hover span,
.bg2-icon-wrap.active span {
	background: #db6989 !important;
	font-size : 40px !important;
}

.bg3,
.bg3-icon-wrap:hover span,
.bg3-icon-wrap.active span {
	background: #ffaf02 !important;
	font-size : 40px !important;
}

.bg4,
.bg4-icon-wrap:hover span,
.bg4-icon-wrap.active span {
	background: #bd967a !important
}

.bg5,
.bg5-icon-wrap:hover span,
.bg5-icon-wrap.active span {
	background: #00a8c6 !important;
	font-size : 40px !important;
}

.bg6,
.bg6-icon-wrap:hover span,
.bg6-icon-wrap.active span {
	background: #77c04b !important
}

.bg7,
.bg7-icon-wrap:hover span,
.bg7-icon-wrap.active span {
	background: #ff7200 !important;
	font-size : 35px !important;
}

.bg8,
.bg8-icon-wrap:hover span,
.bg8-icon-wrap.active span {
	background: #767690 !important;
	font-size : 37px !important;
}

.bg9,
.bg9-icon-wrap:hover span,
.bg9-icon-wrap.active span {
	background: #9db10b !important;
	font-size : 40px !important;
}

.bg10,
.bg10-icon-wrap:hover span,
.bg10-icon-wrap.active span {
	background: #a868c2 !important;
	font-size : 42px !important;
}

.bg11,
.bg11-icon-wrap:hover span,
.bg11-icon-wrap.active span {
	background: #f465af !important
}

.bg12,
.bg12-icon-wrap:hover span,
.bg12-icon-wrap.active span {
	background: #f95858 !important;
	font-size : 37px !important;
}
#page_dashboard {
    position: absolute;
    margin: 0;
    right: 0;
    left: 0;
    top: 49px;
}
.dashfont {
font-weight:400;
letter-spacing:1px
}

.dashpage {
min-width:317px;
text-align:center;
position:fixed;
width:100%
}

.movedash {
position:absolute;
width:100%;
min-width:317px;
top:37px;
right:18px
}

.dashnumber {
font-family:'Helvetica Neue',Arial,Helvetica,sans-serif;
font-weight:700;
font-size:20px;
color:#fff
}

.nodatadash {
text-align:center;
min-width:317px;
padding-right:167px;
position:absolute;
width:100%;
top:105px
}

.dashtotal {
text-align:center;
min-width:317px;
padding-left:28px;
position:absolute;
width:100%;
top:125px
}

.totalnumber {
font-family:'Helvetica Neue',Arial,Helvetica,sans-serif;
font-weight:700;
font-size:30px;
color:#504c4c
}

.stopeddash {
text-align:center;
min-width:317px;
margin-left:97px;
position:absolute;
width:100%;
top:105px
}

.inactivedash {
position: absolute;
right: 63px;
width: 100%;
top: 220px;
}

.idledash {
position:absolute;
width: 100%;
top: 220px;
left: 69px;
}

.alertdash {
text-align:center;
position:fixed;
width:100%;
bottom:0
}
.event-name{
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
font-size: 12.8px;
color: #004c8c;
margin-bottom: 1px;
}
.event-date{
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
color: #747171;
font-size: 11.6px;
}
#report_d{
	padding-bottom:20px;
}
#page_settings h4{
    margin-bottom: 10px;
    padding-bottom: 5px;
    border-bottom: 1px solid #edeaea;
    font-weight: 600;
    font-size: 16px;
    color: #2b82d4;
}
/*#################################################*/
/* DASHBOARD
/*#################################################*/

/* General Dashboard Styling */
#dialog_dashboard {
    background-color: #f5f5f5;
	        width: 100% !important;
        height: auto;
}

.dashboard-container {
    display: flex; /* Keeps the flexible box model */
    flex-direction: column; /* Aligns children vertically */
    min-width: 300px; /* Minimum width of the container */
    width: auto; /* Allows the container to grow based on its content up to max-width or the parent container's width */
    max-width: 600px; /* Maximum width of the container */
    min-height: 200px; /* Minimum height of the container */
    height: auto; /* Allows the container's height to grow based on its content */
    background-color: #ffffff;
    box-sizing: border-box; /* Includes padding and border in the element's total width and height */
    overflow-x: auto; /* Adds a horizontal scrollbar if the content overflows */
	text-align: -webkit-center;
}



.dashboard-container-header {
	width: 100%;
	height: 30px;
	line-height: 30px;
	background: #e5e5e5;
	margin-bottom: 10px;
}

.dashboard-container-header-icon {
	float: left;
	width: 30px;
	height: 30px;
}

.dashboard-container-header-icon span {
	display: inline-block;
	width: 100%;
	height: 100%;
	background-size: 20px 20px;
	background-repeat: no-repeat;
	background-position: center center;
}
.dashboard-container-header-title {
	float: left;
	font-size: 14px;
}
.dashboard-container-header-menu {
	float: right;
	width: 30px;
	height: 30px;
}
.dashboard-container-header-menu span {
	display: inline-block;
	width: 100%;
	height: 100%;
	background-size: 17px 17px;
	background-repeat: no-repeat;
	background-position: center center;
}
.dashboard-container-text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 17px;
    padding-top: 12vh;
    padding-bottom: 12vh;
    text-align: center;
    vertical-align: middle;
    color: #aaaaaa;
    margin: 10px;
    font-weight: 600;
}

.dashboard-container-graph-plot {
    margin: 10px;
}

/* Chart Containers */
#dashboard_objects_graph_plot, 
#dashboard_maintenance_graph_plot, 
#dashboard_odometer_graph_plot,
#dashboard_events_graph_plot {
    max-height: 33vh; /* Adjusted for better responsiveness */
    min-height: 150px;
}

/* Legend Styling */
#dialog_dashboard_events,
#legend-container,
#legend-container-object,
#legend-container-odo,
#legend-container-maintenance {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    text-align: center;
}

.legend-item {
    display: inline-flex;
    align-items: baseline;
    margin: 5px;
}

.legend-color {
    width: 16px;
    height: 9px;
    margin-right: 5px;
}

.disabled-legend-item {
    text-decoration: line-through;
}

/* Mobile Specific Adjustments */
@media (max-width: 480px) {
    #dialog_dashboard {
        width: 100%;
        height: auto;
    }

    .dashboard-container-graph-plot {
        margin: 5px; /* Reduced margin for more space */
    }

    .dashboard-container-text {
        font-size: 15px; /* Adjusted for smaller screens */
		    padding-top: 12vh;
    padding-bottom: 12vh;
    }

    /* Adjust legend and icon sizes for better readability and touch interaction */
    .legend-item {
        margin: 5px 2px; /* Tighter spacing */
    }

    .dashboard-container-header-icon span,
    .dashboard-container-header-menu span {
        background-size: 12px 12px; /* Smaller icons */
    }
}
.dashboard-container-graph-plot canvas {
    min-width: 250px; /* Set a minimum width */
    min-height: 250px; /* Set a minimum height */
}

@media (max-width: 480px) {
    .dashboard-container-graph-plot canvas {
        min-width: 200px; /* Adjust for mobile devices */
        min-height: 200px; /* Adjust for mobile devices */
    }
}
#dialog_dashboard_objects,
#dialog_dashboard_events,
#dialog_dashboard_maintenance, {
    width: 60vw; /* Adjust based on preference, vw units help maintain responsiveness */
    max-width: 600px; /* Maximum width to ensure it doesn't get too large */
    min-width: 300px; /* Minimum width to ensure it's still visible on smaller screens */
    height: auto; /* Height can adjust based on the content, or set a fixed height if preferred */
    margin: 20px auto; /* Center the container */
}
#osm-map {
position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}
.map-container{
	position: relative;
    width: 100%;
    min-height: 150px;
	max-height: 267px;
	margin:auto;
    max-width: 535px;
    aspect-ratio: 1/.5;
	border: 1px solid transparent;
    border-color: #e8e8e8;
	border-top: none;
}
/* Mileage Panel Styles */
.mileage-panel {
  margin-bottom: 20px;
}

.mileage-heading {
  padding: 10px 15px;
  background-color: #f5f5f5;
  border-bottom: 1px solid #ddd;
  font-size: 16px;
}

.mileage-body {
  padding: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 250px;
}

.mileage-container {
  width: 100%;
  max-width: 535px;
  height: 250px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.chart-container-details {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.mileage-chart {
  max-height: 267px;
  max-width: 535px;
  width: 100%;
  height: 100%;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .mileage-body {
    padding: 10px;
  }
  
  .mileage-container {
    height: 220px;
  }
}
.object-list-item-status {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px; /* Adjust the space between boxes */
}
.image-box {
  display: inline-block;
  text-align: center;
  border-radius: 7px;
  box-shadow: rgba(60, 64, 67, 0.3) 0px 1px 2px 0px, rgba(60, 64, 67, 0.15) 0px 2px 6px 2px;
  padding: 5px; /* Adjust padding around the image */
  background-color: #fff; /* Background color of the box */
}

.image-box img {
width: 45px;
padding: 5px 5px 0px 5px;
}

.number {
font-weight: 700;
font-size: 13px;
color: #4693d3;
}
@media (max-width: 380px) {
    .object-list-item-status {
        gap: 10px;
    }
}
.container-dash {
    text-align: center; /* Center content */
    width: 100%; /* Ensure container takes full width */
}

.stylish-button {
background: linear-gradient(#6bace2, #4693d3 50%, #6bace2);
    border-radius: 12px;
    padding: 7px 17px;
    color: #f3faff;
    border-color: #4693d34a;
    display: inline-block;
    font: normal 600 16px / 1 "Open Sans", sans-serif;
    text-align: center;
}

.navwhitestyle {
    background: #f8f8f8;
    position: absolute;
    top: 0px;
    height: 50px;
    width: 170px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 50px;
    z-index: 1;
}
.panel>.list-group {
	padding-right : 0px ;
}
.odometer-car {
	font-weight: 600;
    white-space: nowrap;
    color: #747171;
    font-size: 13px;
    letter-spacing: 1.5px;
    font-family: 'digital-clock-font';
    text-overflow: ellipsis;
    overflow: hidden;
}
.odo-unite{
	font-weight: 600;
    font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
    font-size: 12.5px;
    color: #808080;
}
.right-bottom{
	position: absolute; 
	display: flex; 
	bottom: 6px; 
	right: 10px;
}
  /* Spinner styling */
  .spinner {
    border: 4px solid rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    border-top: 4px solid #3498db;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
  }

  @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
  }

  /* Panel styling */
  .panel-default {
    border: 1px solid #ddd;
    border-radius: 4px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  }

  .panel-heading {
    padding: 10px 15px;
    background-color: #f5f5f5;
    border-bottom: 1px solid #ddd;
    font-size: 12.8px;
  }

.vehicle-card {
  margin-top: 5px;
  padding: 5px 10px;
  border: 1px solid #ccc;
  border-radius: 10px;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  transition: box-shadow 0.3s ease;
  background: #fff;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.vehicle-header {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #222;
  min-height: 42px;
  user-select: none;
  font-size: 12.8px;
}

.vehicle-icon img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  margin-right: 10px;
  vertical-align: middle;
  display: inline-block;
}


.vehicle-info {
  flex-grow: 1;
  text-align: left;
  display: flex;
  flex-direction: column;
}

.vehicle-name {
  font-weight: 600;
}

.vehicle-model {
  font-size: 11px;
  color: #666;
  margin-top: 2px;
  font-style: italic;
}

/* Flèche */
.vehicle-arrow {
  transition: transform 0.3s ease;
  display: inline-block;
  /* other styles */
}

.vehicle-arrow.rotated {
  transform: rotate(90deg);
}


.command-buttons {
  margin-top: 10px;
  display: none;
  gap: 10px;
}

.command-buttons.visible {
  display: flex;
  justify-content: space-between;
}

.btn-on, .btn-off {
  flex: 1;
  padding: 8px 0;
  font-weight: 600;
  border: none;
  border-radius: 6px;
  color: white;
  font-size: 13px;
  cursor: pointer;
  transition: background-color 0.3s ease;
  margin: 0 5px;
}

.btn-on {
  background-color: #28a745; /* vert */
}

.btn-on:hover {
  background-color: #218838;
}

.btn-off {
  background-color: #dc3545; /* rouge */
}

.btn-off:hover {
  background-color: #c82333;
}

#page_cmd_object_list {
  overflow-y: auto;            /* active le scroll vertical */
  scrollbar-width: none;       /* Firefox : cache la scrollbar */
  -ms-overflow-style: none;    /* IE et Edge : cache la scrollbar */
}

#page_cmd_object_list::-webkit-scrollbar {
  display: none;               /* Chrome, Safari et Opera : cache la scrollbar */
}
#objectSearchInput {
  width: 100%;
  padding: 18px 12px;
  border: 1px solid #ccc;
  border-radius: 10px;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  font-size: 13px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
  margin-bottom: 10px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

#objectSearchInput:focus {
  outline: none;
  border-color: #999;
  box-shadow: 0 0 5px rgba(100, 100, 100, 0.2);
}
@keyframes bounce {
  0%   { transform: scale(1); }
  30%  { transform: scale(1.4); }
  50%  { transform: scale(0.9); }
  70%  { transform: scale(1.2); }
  100% { transform: scale(1); }
}

.bounce {
  animation: bounce 0.5s ease;
}
