html, body { -ms-overflow-style: -ms-autohiding-scrollbar; margin: 0; padding: 0; background-color: #ffffff; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 10pt; overflow: hidden; height: 100%; } #layout_container { display: flex; height: calc(100% - 60px); } #selected_infoblock { position: absolute; bottom: 0; margin: 0; background: #ffffff; width: 100%; height: 400px; } .infoblock-container { overflow: scroll; height: 100%; } #sidebar_canvas { padding: 10px; overflow: auto; } #sidebar_container { display: flex; flex-direction: column; width: 500px; left: 0 !important; height: 100%; } #map_container { flex: 1 1 auto; position: relative; height: 100%; } #map_canvas { position: absolute; width: 100%; height: 100%; } #planes_table_container { width: 100%; display: flex; flex-direction: column; } #planes_table { overflow-x: scroll; } .columnOptionContainer { position: relative; display: table; padding-top: 5px; left: 20px; } .columnOptionSelectAllContainer { position: relative; display: table; padding-top: 5px; } .columnOptionText { position: relative; line-height: 10px; display: table-cell; width: 100%; left: 5px; } #toggle_sidebar_control { display: block; position: absolute; top: 16px; right: -3px; } #toggle_sidebar_button { cursor: pointer; float: right; width: 24px; height: 25px; background-size: 24px 25px; background-repeat: no-repeat; background-position: 0px; background-color: transparent; border: none; } #toggle_sidebar_button.show_sidebar { background-image: url("images/table-icon.png"); background-size: cover; } #toggle_sidebar_button.hide_sidebar { background-image: url("images/map-icon.png"); background-size: cover; } #expand_sidebar_control { display: block; position: absolute; top: 48px; right: -3px; } #expand_sidebar_button { cursor: pointer; float: right; width: 24px; height: 25px; background-size: 24px 25px; background-repeat: no-repeat; background-position: 0px; background-color: transparent; border: none; } #expand_sidebar_button { background-image: url("images/table-icon.png"); background-size: cover; } #splitter { cursor: ew-resize; display: block; position: absolute; top: 125px; left: -24px; float: right; width: 24px; height: 25px; background-size: 24px 25px; background-repeat: no-repeat; background-position: 0px; background-color: transparent; border: none; background-image: url("images/toggle-width@2x.png"); background-size: cover; } #splitter-infoblock { cursor: ns-resize; display: inline-block; position: absolute; top: 0px; right: 0; margin-left: auto; width: 24px; height: 4px; background-size: 24px 25px; background-repeat: no-repeat; background-position: 0px; border: none; width: 100%; border-bottom: #234c75; background-color: #65819e; border-bottom-width: 1px; border-bottom-style: solid; } #close-button { display: inline-block; position: absolute; top: 18px; color: #00a0e2; right: 30px; margin-left: auto; font-size: 75%; text-decoration: underline; cursor: pointer; background: #fff; padding: 3px; border-radius: 2px; } .ol-zoom-in { background-image: url("images/zoom-in.png"); background-size: cover; color: transparent !important; width: 19px !important; height: 19px !important; background-color: transparent !important; margin-bottom: 5px !important; } .ol-zoom-out { background-image: url("images/zoom-out.png"); background-size: cover; color: transparent !important; width: 19px !important; height: 19px !important; background-color: transparent !important; } .ol-zoom { background-color: transparent !important; left: 10px !important; } .ol-attribution { max-width: calc(100% - 160px); } @media (max-width: 560px) { .ol-attribution { font-size: 10px; } } div#SpecialSquawkWarning { position: absolute; bottom: 25px; right: 430px; border: 2px solid red; background-color: #ffffa3; opacity: 0.75; filter: alpha(opacity=75); padding: 5px; text-align: center; } div#update_error { position: absolute; bottom: 25px; left: 25px; border: 2px solid red; background-color: #ffffa3; opacity: 0.75; filter: alpha(opacity=75); padding: 5px; text-align: center; } div#loader { z-index: 99; position: absolute; left: 0; top: 0; bottom: 0; right: 0; background: #000; opacity: 0.8; filter: alpha(opacity=80); } #spinny { width: 128px; height: 128px; position: absolute; top: 50%; left: 50%; margin: -64px 0 0 -64px; } #loader_progress { width: 250px; height: 20px; position: absolute; top: 50%; left: 50%; margin: 128px 0 0 -125px; } #tableinfo { font-size: small; } #sudo_buttons { display: flex; padding: 15px 40px 15px 40px; justify-content: space-between; } #units_container, #altitude_filter_form { font-size: small; margin: 10px 0 10px 0; } .aircraft_table_header { background-color: #002f5d; color: #ffffff; cursor: pointer; white-space: nowrap; } .aircraft_table_header td { font-size: smaller; padding: 5px; text-align: center; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; } .verticalRateTriangle { font-family: "Courier New", monospace; } .icaoCodeColumn { font-family: monospace; text-transform: uppercase; } .vPosition { background-color: #e5f6fc; } .uat { background-color: #cdf7d0; } .mlat { background-color: #fdf2e5; } .other { background-color: #ccd5f8; } .tisb { background-color: #fff3b8; } .squawk7500 { font-weight: bold; background-color: #ff5555; } .squawk7600 { font-weight: bold; background-color: #00ffff; } .squawk7700 { font-weight: bold; background-color: #ffff00; } .selected { background-color: #dddddd; } .plane_table_row { cursor: pointer; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; } .ident_normal { font-weight: normal; font-style: normal; } .ident_fallback { font-weight: bold; font-style: italic; } .hidden { display: none; } .infoblock_heading { display: flex; font-size: larger; } #skyaware_version { margin-left: auto; } .infoblock_heading a { text-decoration: none; color: blue; font-size: x-small; } .dim { opacity: 0.3; filter: alpha(opacity=30); /* For IE8 and earlier */ } .pointer { cursor: pointer; } .sidebarButton { background-color: #409edf; padding: 4px 15px 4px 15px; color: #ffffff; font-weight: normal; font-size: small; } .sidebarButton:hover { background-color: #3c6ea3; } .altitudeFilterInput { width: 50px; } .aircraftFilterInput { width: 80px; } .rangeRingsInput { width: 30px; float: right; } .rangeOptions { width: 170px; padding-top: 8px; text-indent: 10px; } .set_range_rings_button { padding-top: 8px; } select.error, textarea.error, input.error { color: #ff0000; } .layer-switcher { bottom: 80px !important; top: auto !important; right: 10px !important; } /* new css */ .rangeRingText { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-weight: bold; font-size: 8px; color: #333333; color: rgb(51, 51, 51); } .dateTime { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-weight: bold; font-size: 14px; line-height: 18px; color: white; text-align: right; display: inline-block; } .infoHeading { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 12px; font-weight: bold; line-height: 16px; color: #002f5d; } .infoHeading sub { font-weight: normal; } .infoData { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 12px; line-height: 16px; color: #000000; } .sectionTitle { width: 100%; text-transform: uppercase; color: #fff; background: #002f5d; font-size: 14px; } .section-title-content { padding: 5px 20px; } .legend { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; width: 100%; font-size: 12px; color: #000000; color: rgb(0, 0, 0); display: inline-flex; flex-wrap: wrap; justify-content: flex-end; padding-top: 10px; gap: 1em; } .legend label { display: flex; cursor: pointer; } .settingsHeading { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 14px; line-height: 20px; color: #002f5d; color: rgb(0, 47, 93); } .settingsText { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 14px; line-height: 20px; text-indent: 16px; color: rgb(0, 0, 0); } .link { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 10px; line-height: 20px; color: #0000c8; color: rgb(0, 0, 200); text-decoration: underline; } #header { position: relative; width: 100%; height: 60px; background: #002f5d; background: -webkit-linear-gradient(#002f5d, #002f5d 60%, #021624); background: -moz-linear-gradient(#002f5d, #002f5d 60%, #021624); background: -ms-linear-gradient(#002f5d, #002f5d 60%, #021624); background: linear-gradient(#002f5d, #002f5d 60%, #021624); display: flex; box-shadow: -6px 0px 8px #999999; z-index: 99999; } .flightawareLogo { background-color: #fff; padding-top: 7px; padding-bottom: 6px; padding-left: 20px; padding-right: 20px; width: 121px; height: 46px; box-shadow: inset -12px 0 12px -12px #000000; } .adsbLogo { padding-left: 20px; padding-top: 30px; padding-bottom: 5px; } .piAwareLogo { width: 235px; height: 24px; } .flightfeederLogo { width: 229px; height: 24px; } .logoContainer { flex: 1; } .menuContainer { display: flex; align-items: center; gap: 1em; margin-left: auto; margin-right: 2em; } .buttonContainer { display: flex; gap: 1em; } .menuContainer .navToggle { display: none; } /** * Hide the header buttons behind a hamburger menu */ @media (max-width: 1023px) { .menuContainer .navToggle { position: relative; display: block; width: 22px; height: 22px; border: none; background: none; outline: none; } .menuContainer .navToggle:before, .menuContainer .navToggle:after, .menuContainer .navToggle span:before, .menuContainer .navToggle span:after { content: ""; position: absolute; left: 0; right: 0; height: 3px; background-color: #cbcbcc; transition: 0.15s ease; transition-delay: 0; } .menuContainer .navToggle:before, .menuContainer .navToggle:after { top: calc(50% - 2px); } .menuContainer .navToggle span:before { top: 2px; } .menuContainer .navToggle span:after { bottom: 3px; } .menuContainer .navToggle:before, .menuContainer .navToggle:after { transition-delay: 0.15s; } .navOpen .menuContainer .navToggle:before, .navOpen .menuContainer .navToggle:after { transition-delay: 0; } .navOpen .menuContainer .navToggle:before { transform: rotate(45deg); } .navOpen .menuContainer .navToggle:after { transform: rotate(-45deg); } .navOpen .menuContainer .navToggle span:before { opacity: 0; top: 50%; } .navOpen .menuContainer .navToggle span:after { opacity: 0; bottom: 50%; } .buttonContainer { position: absolute; flex-direction: column; top: 100%; right: 0; padding: 1em; background-color: white; box-shadow: 0 0 10px 6px rgba(0, 0, 0, 0.2); opacity: 0; visibility: hidden; pointer-events: none; transition: 0.15 ease; } .navOpen .buttonContainer { opacity: 1; visibility: visible; pointer-events: auto; } } /** * Reduce the logo sizes */ @media (max-width: 680px) { #header { height: 40px; } .logoContainer { display: flex; height: 100%; } .logoContainer a { display: block; height: 100%; } .logoContainer img { display: block; box-sizing: border-box; } .flightawareLogo { width: auto; height: 100%; padding: 5px 1em; } .adsbLogo { width: auto; height: auto; padding: 1em; } .menuContainer { margin-right: 1em; } } @media (max-width: 600px) { .dateTime { font-weight: normal; opacity: 0.9; font-size: 12px; letter-spacing: 0.04em; line-height: 1; } } @media (max-width: 480px) { #header { height: 36px; } .dateTime { display: none; } } .buttonText { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-weight: bold; font-size: 12px; color: #ffffff; color: rgb(255, 255, 255); line-height: 28px; padding-left: 10px; padding-right: 10px; } .button { background: #00a0e2; background: rgba(0, 160, 226, 1); min-width: 80px; height: 28px; border-radius: 4px; -moz-border-radius: 4px; -webkit-border-radius: 4px; display: inline-block; cursor: pointer; text-align: center; } .lightblue-link, .lightblue-link a { color: #00a0e2; } .buttonTable { margin-bottom: 5px; } .settingsContainer { display: flex; align-items: center; cursor: pointer; } .settingsContainer .buttonText { display: none; } #highlighted_infoblock { position: absolute; left: 40px; top: 60px; min-width: 168px; padding-right: 5px; background: #ffffff; box-shadow: 4px 4px 10px #444444; cursor: pointer; z-index: 9999; display: none; } .highlightedTitle { height: 36px; border-bottom: 1px solid #00a0e2; padding-left: 18px; padding-top: 18px; } .highlightedInfo { padding-left: 10px; } .identLarge { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 24px; line-height: 20px; color: #002f5d; color: rgb(0, 47, 93); font-weight: lighter; } .identSmall { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 12px; font-weight: bold; line-height: 20px; color: #00a0e2; color: rgb(0, 160, 226); } .highlightedInfo { padding-bottom: 12px; } .infoRowTitle { display: inline-block; } .infoRowContent { display: inline-block; } .infoRowFluid { display: inline-block; } .infoRow { padding-top: 10px; } .infoRowLine { width: 49%; display: inline-block; padding-top: 2px; padding-bottom: 2px; } .removePadding { padding: 0; } .rightLink { float: right; padding-right: 5px; } .infoBlockTopSection { padding-top: 14px; padding-bottom: 14px; padding-left: 8px; } .infoBlock45pxSection { height: 45px; line-height: 45px; padding-left: 10px; } .infoBlockSection { padding-top: 14px; padding-bottom: 14px; padding-left: 10px; } .lightGreyBackground { background-color: #efefef; } #dump1090_infoblock { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; } #dump1090_infoblock dl { display: flex; justify-content: space-between; gap: 2em; font-weight: bold; color: #002f5d; } #dump1090_infoblock dl dt { white-space: nowrap; } #dump1090_infoblock .counters { display: flex; width: 160px; flex-wrap: wrap; justify-content: space-between; } #dump1090_infoblock .message-rates { display: flex; flex-direction: column; width: 220px; } #dump1090_infoblock .counters > div, #dump1090_infoblock .message-rates > div { display: flex; justify-content: space-between; flex-basis: 100%; } @media (max-width: 440px) { #dump1090_infoblock dl { flex-direction: column; gap: 1em; } #dump1090_infoblock .counters, #dump1090_infoblock .message-rates { width: 100%; } } #dump1090_infoblock dl dt:after { content: ":"; } #dump1090_infoblock dl dd { margin: 0; } .infoBlockTitleText { font-weight: bold; color: #002f5d; } .legendBox { width: 15px; height: 15px; border: 1px solid #efefef; border-radius: 4px; -moz-border-radius: 4px; -webkit-border-radius: 4px; } .legendTitle { line-height: 19px; display: inline-block; padding-right: 5px; padding-left: 5px; border-radius: 5px; } #settings_infoblock { position: absolute; right: 1px; top: 60px; width: 398px; min-height: 180px; background: #ffffff; box-shadow: 4px 4px 10px #444444; padding: 20px; z-index: 9999; display: none; } .settingsColumn { display: table-cell; width: 199px; } .settingsOptionContainer { display: table; padding-bottom: 10px; } .settingsCheckbox, .columnSelectCheckbox, .columnSelectAllCheckbox { width: 20px; height: 11px; background-image: url("images/box-empty.png"); background-repeat: no-repeat; background-position: center; background-size: contain; cursor: pointer; } .settingsCheckboxChecked { background-image: url("images/box-checked.png") !important; } .sourceCheckbox { width: 13px; height: 13px; background-image: url("images/box-empty.png"); background-repeat: no-repeat; background-position: center; background-size: contain; cursor: pointer; margin-top: 3px; margin-right: 3px; } div.sourceCheckbox.sourceCheckboxChecked, label.sourceCheckboxChecked div.sourceCheckbox { background-image: url("images/box-checked.png") !important; } .settingsCloseBox { position: absolute; right: 8px; top: 8px; background-image: url("images/close-settings.png"); background-size: cover; width: 20px; height: 20px; cursor: pointer; } .settingsText { line-height: 20px; display: table-cell; } #altitude_chart { float: right; width: calc(100% - 5px); max-width: 800px; right: 5px; bottom: 35px; background-color: #ffffff; border: solid medium; } #altitude_chart_button { background-image: url("images/alt_legend_feet.svg"); background-size: cover; background-color: transparent; width: 100%; height: 0; padding: 0; padding-bottom: calc(100% * 56 / 1815); } .altitudeMeters { background-image: url("images/alt_legend_meters.svg") !important; } /* remove the blue highlighting around the map buttons */ .ol-control button { outline: none; } .bottom-container { width: 100%; margin-top: 8px; padding: 40px 0px; text-align: center; background-color: #eee; } #selected_flightaware_link a { background-color: #00a0e2; color: white; text-decoration: none; padding: 10px; border-radius: 4px; float: right; margin-right: 25px; margin-top: 10px; } .bottom-info-container { padding-top: 10px; padding-bottom: 10px; text-align: center; color: #002f5d; line-height: 18px; } .bottom-info-container img { vertical-align: middle; } .bottom-info-container .bottom-info-text { vertical-align: middle; display: inline; } .selected_airframe a { color: #002f5d; } .infoblock-container-small .infoRowFluid { display: block; } /* Retina 2x images */ @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) { .settingsCloseBox { background-image: url("images/close-settings@2x.png"); } .settingsCheckboxChecked { background-image: url("images/box-checked@2x.png") !important; } .settingsCheckbox { background-image: url("images/box-empty@2x.png"); } .ol-zoom-out { background-image: url("images/zoom-out@2x.png"); } .ol-zoom-in { background-image: url("images/zoom-in@2x.png"); } #toggle_sidebar_button.show_sidebar { background-image: url("images/table-icon@2x.png"); } #expand_sidebar_button { background-image: url("images/table-icon@2x.png"); } #toggle_sidebar_button.hide_sidebar { background-image: url("images/map-icon@2x.png"); } } /* Retina 3x images */ @media (-webkit-min-device-pixel-ratio: 3), (min-resolution: 192dpi) { .settingsCloseBox { background-image: url("images/close-settings@3x.png"); } .settingsCheckboxChecked { background-image: url("images/box-checked@3x.png") !important; } .settingsCheckbox { background-image: url("images/box-empty@3x.png"); } .ol-zoom-out { background-image: url("images/zoom-out@3x.png"); } .ol-zoom-in { background-image: url("images/zoom-in@3x.png"); } #toggle_sidebar_button.show_sidebar { background-image: url("images/table-icon@3x.png"); } #expand_sidebar_button { background-image: url("images/table-icon@3x.png"); } #toggle_sidebar_button.hide_sidebar { background-image: url("images/map-icon@3x.png"); } } .config_button { position: relative; background-color: #febc11; color: #002f5d; cursor: pointer; text-align: center; width: auto; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; } .italicize { font-style: italic; } .stats_button { position: relative; background-color: rgba(0, 160, 226, 1); color: #ffffff; font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-weight: bold; font-size: 12px; cursor: pointer; width: auto; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; margin-top: 5px; padding: 5px 8px 5px 8px; } .config_button:hover, .config_button_active { background-color: #abcad8; } .config_button_row { position: relative; margin-top: 10px; padding: 3px 0 3px 0; } .panel { background-color: white; position: relative; padding: 3px 3px 10px 3px; display: none; margin-bottom: 5px; border: solid; border-color: #002f5d; height: auto; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; } .wrapper { display: grid; grid-template-columns: repeat(3, 1fr); } #altitude_slider, #speed_slider { position: relative; display: block; margin-left: 10px; margin-right: 10px; width: auto; margin-top: 10px; margin-bottom: 5px; height: 10px; } .align_right { float: right; } .noUi-horizontal .noUi-handle, .noUi-vertical .noUi-handle { background: #febc11; height: 20px !important; width: 10px !important; right: -5px !important; /* must be (width / 2) * -1 */ } .noUi-handle:before, .noUi-handle:after { display: none !important; } .noUi-connect { background: #00a0e2 !important; } #aircraft_type_filter_form, #aircraft_ident_filter_form { position: relative; padding: 5px 5px 5px 5px; } .group { padding: 5px 5px 5px 5px; margin-top: 5px; border-radius: 4px; -webkit-border-radius: 4px; -moz-border-radius: 4px; background-clip: padding-box; border: 1px solid #e5e9f9; background: #fff; color: #060d46; width: auto; } .filter_input_group { margin-top: 10px; margin-bottom: 5px; } @media (max-width: 1024px) { #sidebar_container { width: 50%; } } @media (max-width: 800px) { html, body { overflow: auto; height: auto; } #layout_container { flex-direction: column; } #map_container { width: 100vw; height: calc(90vw - 60px); } #sidebar_container { width: 100%; } #altitude_chart { width: auto; left: 5px; } } @media (max-width: 800px) and (orientation: landscape) { #map_container { width: 100vw; height: calc(90vh - 60px); } }