/*
 * OpenFaces - JSF Component Library 3.0
 * Copyright (C) 2007-2010, TeamDev Ltd.
 * licensing@openfaces.org
 * Unless agreed in writing the contents of this file are subject to
 * the GNU Lesser General Public License Version 2.1 (the "LGPL" License).
 * This library is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * Please visit http://openfaces.org/licensing/ for more details.
 */

/* ========== REGULAR STYLE GROUP ================== */

/* == Miscellaneous == */

.o_default_css_marker {}

.clearfix {zoom: 1;}
.clearfix: after {
	content: ' ';
	clear: both;
	display: block;
	width: 0; height: 0;
	overflow: hidden;
	font-size: 0;
}

.o_ajax_message {
  width: 1px;
  border: 1px solid #939393;
  background: #ffffff;
  margin: 1px;
  padding: 4px;
  padding-left: 5px;
  padding-right: 15px;
  color: #1f3314;
  font-weight: bold;
}

.o_ajax_blockingLayer {
  position: absolute;
  background: #d8d8d8;
}

/* == Shared among components styles == */

/* DEFAULT_BORDER */
.o_calendar,
  .o_table,
  .o_dropdown,
  .o_dropdown_list,
  .o_spinner,
  .o_popuplayer,
  .o_popup_menu,
  .o_hintlabel_hint,
  .o_timetableView {
  border: 1px solid gray;
}

/* DEFAULT_HEADER_BACKGROUND */
.o_table_header_section,
  .o_calendar_header, .o_calendar_footer,
  .o_confirmation_button_backplane,
  .o_tabset_top, .o_tabset_right, .o_tabset_bottom, .o_tabset_left,
  .o_folding_panel_caption, .o_window_caption,
  .o_tls_caption,
  .o_sidepanel_caption {
  background: #dfdfdf;
}

.o_table_footer_section {

}

/* GRAYED_TEXT_COLOR */
.o_table_no_data_row,
  .o_table_filter_predefined_criterion,
  .o_treetable_auxiliary_node,
  .o_confirmation_details,
  .o_confirmation_details_message,
  .o_tls_disabled_option {
  color: gray;
}

.o_text_color {
  color: WindowText;
}

.o_text_color_safari {
  color: black;
}

.o_background_color {
  background: Window;
}

.o_background_color_safari {
  background: white;
}

/* Specifying transparent background explicitly is required to avoid making absolutely-positioned elements in IE to
  "leak" events to underlying elements */
.o_explicitly_transparent_background,
  .o_popuplayer_modal_layer {
  background: url(clear.gif) repeat center center;
}

.o_debugRow1 {
  vertical-align: top;
  height: 20px;
}

.o_debugRow2 {
  vertical-align: top;
}


/* getDialogControlsFontFamily */
.o_calendar_day,
  .o_calendar_days_header,
  .o_calendar_header,
  .o_calendar_footer,
  .o_dropdown_list,
  .o_dropdown_list_item,
  .o_menu_list_item {
  font-family: MS Shell Dlg, Arial, sans-serif;
}

/* == End of Shared among components styles == */

/* Table styles */
.o_table_header_section {
  font-weight: bold;
  text-align: center;
}

.o_table_sortable_header {
  cursor: pointer;
}

.o_table_sortable_header_rollover {
  background: #d4d4d4;
}

.o_table_sorted_column_header {
  background: #cccccc;
}

.o_table_sorted_column_body {
  background: #f4f4f4;
}

.o_table_sorted_column_footer {
  background: #f4f4f4;
}

.o_filter_row_cells {
  font-weight: normal;
}

.o_table_no_data_row {
  padding: 5px;
  text-align: center;
}

.o_table_paginator_field {
  width: 40px;
  text-align: right;
}

.o_table_layout_fixed {
  table-layout: fixed;
}

.o_table_columnDropTarget {
  position: absolute;
  background: #585858;
  width: 3px;
}

.o_table_draggedColumn {
  border: 1px solid gray;
}

.o_scrollable_table {
  width: 100%;
  height: 300px;
}

.o_noWrapHeaderCell {
  white-space: nowrap;
}

.o_scrolling_area_container {
  width: 100%;
  position: relative;
}

.o_horizontal_scrolling_area {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.o_table_scrolling_area {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.o_scrolling_area_table {
  table-layout: fixed;
}

.o_scrolling_area_spacer {
  width: 1px;
  height: 1px;
  padding: 0;
  border-width: 0;
}

.o_headerAutoScrollArea {
  position: absolute;
  background: gray;
  vertical-align: middle;
  width: 20px;
}

.o_columnMenuInvoker {
  width: 20px;
  text-align: center;
  border-left: 1px solid silver;
  vertical-align: middle;
  background-color: silver;
}

/* Checkbox column */
.o_checkbox_column {
  width: 35px;
  text-align: center;
}

/* Selection column */
.o_selection_column {
  width: 35px;
  text-align: center;
}

/* Paginator */
.o_table_paginator {
  white-space: nowrap;
}

.o_table_paginator_image {
  cursor: pointer;
}

.o_hiddenFocus {
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  font-size: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 none transparent !important;
  background: transparent !important;
  opacity: 0 !important;
}

.o_hiddenFocus:focus {
  outline: none !important;
}

/* TreeTable */
.o_treetable_folding {
  cursor: pointer;
  margin-left: 0;
  margin-right: 0;
}

.o_treetable_expansion_toggle_cell {
  text-align: center;
  vertical-align: middle;
}

.o_treetable_indent {
  width: 16px;
  text-align: center;
}

.o_hiddenRow {
  display: none !important;
}

.o_hiddenRow .ieNonStaticPositionFix {
  /* IE doesn't hide absolute and relative positioned elements of "display:none" parents, so it should be done
  explicitly with this style declaration.

  The application developers should assign "ieNonStaticPositionFix" CSS class to any non-statically positioned elements
  in TreeTable cells. This assignment is intentionally not done automatically since it would considerably degrade
  performance for this quite rare case
  */
  display: none !important;
}

/* Window */
.o_window {
  overflow: hidden;
  border: 2px solid gray;
  padding: 0 ! important;
}

.o_window_table {
  table-layout: fixed;
}

.o_window_caption {
  padding-left: 5px;
  padding-top: 3px;
  padding-bottom: 3px;
  text-align: left;
  font-weight: bold;
  white-space: nowrap;
  cursor: default;
}

.o_default_caption_width {
  width: 100%;
}

.o_window_content {
  position: absolute;
  visibility: hidden;

  overflow: auto;
  vertical-align: top;
  text-align: left;
  padding: 2px;
}

/* Confirmation */
.o_confirmation {
  z-index: 301;
  overflow: hidden;
  cursor: default;
  border: 1px solid gray;
}

.o_confirmation_icon_backplane {
  vertical-align: bottom;
  padding: 15px 15px 5px 15px;
}

.o_confirmation_text_backplane {
  height: 100%;
}

.o_confirmation_header_text {
  font-weight: bold;
  text-align: left;
  vertical-align: middle;
  padding-top: 10px;
  padding-right: 10px;
  padding-bottom: 5px;
}

.o_confirmation_button_backplane {
  padding: 3px;
}

.o_confirmation_yes_button {
  padding-left: 5px;
  padding-right: 5px;
  width: 100%;
}

.o_confirmation_no_button {
  padding-left: 5px;
  padding-right: 5px;
  width: 100%;
}

.o_confirmation_details,
  .o_confirmation_details_message {
  text-align: left;
  vertical-align: top;
  padding-bottom: 10px;
  padding-right: 10px;
  padding-top: 5px;
}

.o_confirmation_details_message {
  padding-top: 0;
}


/* TimeTable styles */

.o_timetableView {
  width: 100%;
  cursor: default;
}

.o_timetableView_header,
.o_timetableView_footer{
  padding: 0 40px;
  width: 100%;
  height: 50px;
}

.o_timetableView_header{
  border-bottom: 1px solid gray;
}

.o_timetableView_footer{
  border-top: 1px solid gray;
}

.o_tinyText {
  font-size: 0 ! important;
}

.o_timetableView_tableRow {
  height: 100%;
  vertical-align: top;
}

.o_timetableView_scroller {
  width: 100%;
  height: 100%;
  position: relative;
  left: 0;
  top: 0;
  overflow-x: hidden;
  overflow-y: scroll;
}

.o_timetableView_table, .o_resourceHeadersTable, .o_weekdayHeadersTable {
  width: 100%;
  table-layout: fixed;
  overflow: hidden;
}

.o_resourceHeadersRow {
  font-family: MS Shell Dlg, Arial, sans-serif;
  font-size: 11pt;
  text-align: center;
  overflow: hidden;
}

.o_weekdayHeadersRow {
}

.o_defaultScrollBarWidth {
  width: 17px;
}

.o_timetableViewRowClass {
  font-size: 0;
  height: 25px;
}

.o_monthTableDayHeaderRow {
}

.o_monthTableRow {
}

.o_monthTableWeekdayHeaderCell {
  text-align: right;
  vertical-align: text-top;
  height: 20px;
  overflow: hidden;
}

.o_monthTableWeekendWeekdayHeaderCell {
  background: #ffe4e1;
}

.o_monthTableCellHeader {
  height: 20px;
  text-align: right;
  vertical-align: text-top;
  overflow: hidden;
}

.o_monthTableCell {
  height: 120px;
  overflow: hidden;
}

.o_monthTableWeekendCellHeader {
  background: #ffe4e1;
}

.o_monthTableWeekendCell {
  background: #ffe4e1;
}

.o_monthTableInactiveMonthCellHeader {
  background: #dcdcdc;
}

.o_monthTableInactiveMonthCell {
  background: #dcdcdc;
}

.o_monthTableTodayCellHeader {
  background: #ffebcd;
}

.o_monthTableTodayCell {
  background: #ffebcd;
}

.o_moreLinkElement {
  height:20px;
  position: absolute;
  text-align: center;
}

.o_moreLink {
  color: black;
}

.o_timeColumn {
  width: 50px;
  background: #f0f0f0;
  text-align: right;
  padding-right: 8px;
  vertical-align: top;

  color: #606060;
  font-family: MS Shell Dlg, Arial, sans-serif;
  font-size: 14pt;
}

.o_majorTimeText {
}

.o_minorTimeText {
}

.o_weekdayText {
}

.o_timeSuffixText {
  font-size: .5em;
  vertical-align: top;
}

.o_timetableEvent,
  .o_reservedTimeEvent {
  position: absolute;

  cursor: default;
  border: 1px solid gray;

  border-radius: 4px;
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
}

.o_timetableEvent {
  padding: 2px;
  overflow: hidden;

  font-family: MS Shell Dlg, Arial, sans-serif;
  font-size: 11pt;
  margin: 4px;
}

.o_monthTableEvent {
  height: 40px;
}

.o_timetableEventName {
  display: block;
  width: 100%;
  font-weight: bold;
  white-space: nowrap;
}

.o_monthTableEventName {
  font-weight: bold;
}

.o_timetableEventDescription {
}

.o_timetableEventResource {
  font-style: italic;
}

.o_timetableEventTime {
}

.o_timetableEventArea {
  position: absolute;
}

.o_rolloverTimetableEvent {
  border: 2px solid gray;
}

.o_reservedTimeEvent {
  background: url(timetable/reservedTimePattern.gif) repeat;
  margin: 4px;
}

.o_eventActionBar {
  position: absolute;
  visibility: hidden;
  text-align: center;

  padding: 1px;
  font-size: 9pt;
  color: white;
}

.o_eventActionButton {
  cursor: pointer;
  padding: 1px 2px 1px 2px;
}

.o_timetableEventBackground {
  position: absolute;
  border: 0 solid gray; /* for Opera to correctly handle background layer boundaries */
}

.o_eventPreview {
  width: 400px;
  padding: 2px;
}

.o_truncatedTimetableEvent {
  border-bottom: none ! important;
}

.o_eventEditorDialog {
  padding: 4px;
  font-size: 9pt;
  font-family: MS Shell Dlg, Arial, sans-serif;
  overflow: hidden;
  left: 0;
  top: 0;
}

.o_eventEditorDialogContent {
  padding: 4px;
  font-size: 9pt;
  font-family: MS Shell Dlg, Arial, sans-serif;
  overflow: hidden;
}

.o_eventEditor_timeField {
  width: 50px;
}

.o_eventEditor_buttonsArea {
  text-align: right;
  padding-top: 6px;
}

.o_eventEditor_modalLayer {
  filter: alpha(opacity = 50);
  -moz-opacity: .50;
  opacity: .50;
  background: gray;
}

.o_zeroPaddings {
  padding: 0 ! important;
}

/* Calendar styles */

/*  Index 0 */

.o_calendar {
  background: white;
  table-layout: fixed;
}

.o_calendarCol {
  width: 25px;
}

.o_cal_week_row {
  text-align: center;
  vertical-align: middle;
}

.o_calendar_day {
  font-size: 11px;
  text-decoration: none;
  width: 25px;
  height: 15px;
  padding-top: 1px;
}

.o_calendar_header {
  font-size: 10px;
  width: 100%;
}

.o_calendar_footer {
  font-size: 10px;
  width: 100%;
}

.o_calendar_days_header {
  text-align: center;
  background: #b3b3d9;
  color: White;
  width: 25px;
  height: 15px;
  padding-top: 1px;
  font-size: 10px;
}

/* Index 2 */
.o_calendar_weekend_day {
  color: red;
}

/* Index 3 */
.o_calendar_inactive_month_day {
  color: gray;
}

/*  Index 5 */
.o_calendar_today {
  font-weight: bold;
}

/* Popup layer styles */

.o_popuplayer {
  position: absolute;
  display: none;
}

.o_popuplayer_modal {
  z-index: 301;
}

.o_popuplayer_modal_layer {
  z-index: 300;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

/* Dropdown field */
.o_dropdown {
  background: white;
  width: 140px;
  height: 20px;
  table-layout: fixed;
}

.o_selectonemenu {
  width: 175px;
}

.o_slider {
  margin: 5px;
  padding: 10px;
  border: 0;
  text-align: left;
}

.o_slider_focused {
  padding: 9px;
  border: 1px dotted black;
}

.o_slider_horizontal {
  width: 400px;
  height: 70px;
}

.o_slider_vertical {
  height: 400px;
  width: 70px;
}

.o_slider_horizontal_center {
  width: 400px;
  height: 80px;
}

.o_slider_vertical_center {
  height: 400px;
  width: 80px;
}

.o_slider_tooltip {
  background: #ffffe2;
  border: 1px solid #dfdfe2;
  width: 30px;
  height: 20px;
  font-size: 8pt;
  text-align: center;
  vertical-align: middle;
  visibility: hidden;
  color: gray;
  margin: 0;
  padding: 0;
}

.o_slider_text_field {
  width: 40px;
  font-size: 8pt;
  text-align: center;
  overflow: hidden;
  border: 1px solid #dfdfe2;
  margin: 0;
  padding: 0;
}

.o_slider_disabled {
  color: gray;
}

.o_slider_disabled_text_field {
  background: #fefefe;
  color: graytext;
  border: 1px solid #eee;
}

.o_slider_disabled_text_field hover {
  cursor: default;
}

.o_slider_active_element_rollover {
  cursor: pointer;
}

.o_spinner {
  background: white;
  width: 60px;
  height: 20px;
}

.o_spinner_button {
  line-height: 0;
  font-size:0;
  height: 50%;
}

.o_spinner_field {
  text-align: right;
}

.o_dropdown_field {
  background: url(clear.gif) repeat center center !important; /*"important" overrides RichFaces default skin's border */

  margin: 0;
  padding: 2px 2px 0 2px;
  border: 0 solid !important; /*"important" overrides RichFaces default skin's border */
  width: 100%;
  outline: none;
}

.o_dropdown_list {
  background-color: window;
  cursor: default;
}

.o_dropdownfield_list {
  position: absolute;
  visibility: hidden;
  overflow: auto;
  width: 0;
  height: 200px;
}

.o_dropdown_button {
  height: 100%;
}

.o_dropdown_list_item {
  padding: 0 2px 0 2px;
  text-align: left;
  font-size: 10pt;
}

.o_dropdown_prompt {
  color: #7e7e7e;
  text-align: left;
}

.o_combo_button {
  background-color: #cfcfcf;
  margin: 0;
  padding: 0;
  border: 0 solid;
  white-space: nowrap;
  width: 15px;
}

.o_combo_button_rollover {
  background-color: #b8b8b8;
}

.o_combo_button_pressed {
  background-color: #989898;
}

.o_combo_button_disabled {
  background: #a0a0a0;
}

.o_combo_field_disabled {
}

.o_dropdown_disabled {
  background: #ebebeb;
}

/* Folding panel */
.o_folding_panel {
  border: 1px solid gray;
}

.o_folding_panel_content {
  padding-left: 2px;
  padding-right: 2px;
  background: white;
}

.o_folding_panel_caption {
  width: 100%;
  border-bottom: 1px solid gray;
  padding-left: 2px;
  padding-right: 2px;
  text-align: left;
}

/* TwoListSelection */
.o_twoListSelection {
  width: 500px;
}

.o_tls_caption {
  font-weight: bold;
  padding: 4px 4px 2px;
}

.o_tls_list {
  width: 100%;
  padding: 0;
  margin: 0;
}

/* TabSet */
.o_tabset_empty_space_top,
  .o_tabset_empty_space_right,
  .o_tabset_empty_space_bottom,
  .o_tabset_empty_space_left {
  font-size: 1px;
}

.o_tabset_moz_empty_space {
  width: 1px;
  height: 1px;
}

.o_tabset_empty_space_top {
  border-bottom: #dbdad5 1px solid;
}

.o_tabset_empty_space_right {
  border-left: #dbdad5 1px solid;
}

.o_tabset_empty_space_bottom {
  border-top: #dbdad5 1px solid;
}

.o_tabset_empty_space_left {
  border-right: #dbdad5 1px solid;
}

.o_tabset_front_border_top,
  .o_tabset_front_border_right,
  .o_tabset_front_border_bottom,
  .o_tabset_front_border_left {
  border: #dbdad5 1px solid;
}

.o_tabset_front_border_top {
  border-bottom: 0;
}

.o_tabset_front_border_right {
  border-left: 0;
}

.o_tabset_front_border_bottom {
  border-top: 0;
}

.o_tabset_front_border_left {
  border-right: 0;
}

.o_tabset_back_border_top,
  .o_tabset_back_border_right,
  .o_tabset_back_border_bottom,
  .o_tabset_back_border_left {
  border: 0;
}

.o_tabset_back_border_top {
  border-bottom: #dbdad5 1px solid;
}

.o_tabset_back_border_right {
  border-left: #dbdad5 1px solid;
}

.o_tabset_back_border_bottom {
  border-top: #dbdad5 1px solid;
}

.o_tabset_back_border_left {
  border-right: #dbdad5 1px solid;
}

.o_tabset_top,
  .o_tabset_right,
  .o_tabset_bottom,
  .o_tabset_left {
  white-space: nowrap;
  width: 1%;
  padding-left: 2px;
  padding-right: 2px;
  cursor: default;
}

.o_tabset_top {
  border-top: 3px solid #dfdfdf;
  border-left: 1px solid #dfdfdf;
  border-right: 1px solid #dfdfdf;
}

.o_tabset_right {
  border-right: 3px solid #dfdfdf;
  border-top: 1px solid #dfdfdf;
  border-bottom: 1px solid #dfdfdf;
}

.o_tabset_bottom {
  border-bottom: 3px solid #dfdfdf;
  border-left: 1px solid #dfdfdf;
  border-right: 1px solid #dfdfdf;
}

.o_tabset_left {
  border-left: 3px solid #dfdfdf;
  border-top: 1px solid #dfdfdf;
  border-bottom: 1px solid #dfdfdf;
}

.o_tabset_selected_top,
  .o_tabset_selected_right,
  .o_tabset_selected_bottom,
  .o_tabset_selected_left {
  background-color: transparent;
}

.o_tabset_selected_top {
  border-top: #c9d8f5 3px solid;
}

.o_tabset_selected_right {
  border-right: #c9d8f5 3px solid;
}

.o_tabset_selected_bottom {
  border-bottom: #c9d8f5 3px solid;
}

.o_tabset_selected_left {
  border-left: #c9d8f5 3px solid;
}

/* TabbedPane */
.o_tabbedpane_border_top {
  border-right: #dbdad5 1px solid;
  border-bottom: #dbdad5 1px solid;
  border-left: #dbdad5 1px solid;
}

.o_tabbedpane_border_right {
  border-bottom: #dbdad5 1px solid;
  border-left: #dbdad5 1px solid;
  border-top: #dbdad5 1px solid;
}

.o_tabbedpane_border_bottom {
  border-left: #dbdad5 1px solid;
  border-top: #dbdad5 1px solid;
  border-right: #dbdad5 1px solid;
}

.o_tabbedpane_border_left {
  border-top: #dbdad5 1px solid;
  border-right: #dbdad5 1px solid;
  border-bottom: #dbdad5 1px solid;
}

.o_tabbedpane_container {
  padding: 2px 2px 2px 2px;
  vertical-align: top;
}

/* HintLabel */
.o_hintlabel_label,
  .o_hintlabel_label_ie {
  table-layout: fixed;
  white-space: nowrap;
  overflow: hidden;
}

.o_hintlabel_label_ie {
  text-overflow: ellipsis;
}

.o_hintlabel_hint {
  position: absolute;
  visibility: hidden;
  display: none;
}

/* Text Field */
.o_inputtext_prompt {
  color: #7e7e7e;
}

/* Popup Menu */

.o_popup_menu {
  padding: 1px;
  margin: 0;
  position: absolute;
  visibility: hidden;
  font-size: 0;
  line-height: 0;
  list-style: none;
  white-space: nowrap;
  text-align: left;
  background: #f0f0f0;
}
.o_popup_menu_iequirks {
  width: 0;
}

.o_popup_menu_indent {
  width: 26px;
  background: #e0e0e0;
  text-align: left;
  padding-left: 2px;
}

.o_columnVisibilityMenuIndent {
  padding-left: 4px;
}

.o_menu_list_item {
  display: block;
  list-style: none outside none;

  white-space: nowrap;
  border: 0;
  margin: 0;
  padding: 0;
  zoom: 1;
}

.o_menu_list_item_image_span {
  display: table-cell;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 21px;
  text-align: center;
  vertical-align: middle;
}

.o_menu_list_item_arrow_span {
  display: table-cell;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 20px;
  text-align: center;
  vertical-align: middle;
}

.o_menu_list_item_span {
  display: block;
  position: relative;
  padding: 1px;
  cursor: default;
  color: black;
  font-family: tahoma, arial, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  height: 21px;
  line-height: 21px;
  /*text-align: left;
  text-decoration: none;
  border: 1px solid transparent;
  margin: 0;
  outline: none;*/
}

.o_menu_list_item_content {
  display: block;
  padding: 0 3px;
  text-align: left;
}

.o_menu_list_item_img_fakespan {
  display: inline-block;
  height: 100%;
  width: 1px;
  vertical-align: middle;
}

.o_menu_list_item_img {
  border: 0;
  vertical-align: middle;
}

.o_menu_item_selected {
  background: #b8d8f0;
  border: 1px solid #7090b8;
  color: black;
}

.o_menu_list_item_disabled {
  color: gray;
}

.o_menu_list_item_separator {
  padding: 1px;
}

.o_menu_list_item_icon {
  vertical-align: middle;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 21px;
  text-align: center;
}

.o_menu_separator {
  display: block;
  position: relative;
  padding: 0;
  line-height: 1px;
  border-top: 1px solid silver;

  margin: 0 2px 0 2px;
}

/* SidePanel */
.o_sidepanel_container {
  position: absolute;
  height: 100%;
  width: 100%;
  padding: 0;
  border: 0;
  margin: 0;
}

.o_sidepanel_splitter {
  position: absolute;
  background-color: #f4f4f4;
  height: 4px;
  width: 4px;
  overflow: hidden;
  padding: 0;
  border: 0;
  margin: 0;
}

.o_sidepanel_panel {
  position: absolute;
  overflow: hidden;
  height: 100%;
  width: 100%;
  padding: 0;
  border: 0;
  margin: 0;
}

.o_sidepanel_caption {
  position: absolute;
  border-width: 0;
  border-bottom: 1px solid gray;
  overflow-x: hidden;
  white-space: nowrap;
  width: 100%;
  padding: 0;
  margin: 0;
  top: 0;
  right: 0;
}

.o_sidepanel_content {
  position: absolute;
  overflow: auto;
  height: 100%;
  width: 100%;
  padding: 0;
  border: 0;
  margin: 0;
  bottom: 0;
  right: 0;
}

.o_sidepanel_container_left {
  left: 0;
}

.o_sidepanel_panel_left {
  top: 0;
  left: 0;
}

.o_sidepanel_splitter_left {
  height: 100%;
  border-left: 2px groove gray;
  border-right: 1px outset gray;
  cursor: e-resize;
  cursor: col-resize;
  top: 0;
  right: 0;
}

.o_sidepanel_container_right {
  right: 0;
}

.o_sidepanel_panel_right {
  top: 0;
  right: 0;
}

.o_sidepanel_splitter_right {
  height: 100%;
  border-left: 2px groove gray;
  border-right: 1px outset gray;
  cursor: e-resize;
  cursor: col-resize;
  top: 0;
  left: 0;
}

.o_sidepanel_container_top {
  top: 0;
}

.o_sidepanel_panel_top {
  top: 0;
  left: 0;
}

.o_sidepanel_splitter_top {
  width: 100%;
  border-top: 2px groove gray;
  border-bottom: 1px outset gray;
  cursor: n-resize;
  cursor: row-resize;
  right: 0;
  bottom: 0;
}

.o_sidepanel_container_bottom {
  bottom: 0;
}

.o_sidepanel_panel_bottom {
  bottom: 0;
  left: 0;
}

.o_sidepanel_splitter_bottom {
  width: 100%;
  border-top: 2px groove gray;
  border-bottom: 1px outset gray;
  cursor: n-resize;
  cursor: row-resize;
  top: 0;
  left: 0;
}

.o_borderlayoutpanel_container {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  padding: 0;
  border: 0;
  margin: 0;
}

.o_borderlayoutpanel_content {
  width: 100%;
  height: 100%;
  overflow: auto;
  position: absolute;
  padding: 0;
  border: 0;
  margin: 0;
  top: 0;
  left: 0;
}

/* Validation */

.o_floatingIconMessage {
  background: #f8d3d4;
}

/* Other */
.o_chart {
  border: 0;
}


.o_debug {
  z-index: 10000;
}


/* ========== ROLLOVER STYLE GROUP ================== */

/* == Shared among components styles == */

/* ROLLOVER_BACKGROUND_COLOR */
.o_calendar_rollover_day, .o_calendar_rollover_inactive_month_day {
  background: #cfcfcf;
}

/* == End of Shared among components styles == */

.o_initially_invisible {
  visibility: hidden;
}

/* Calendar */
/* Index 0 */
.o_calendar_rollover_day {
  color: white;
  cursor: pointer;
}

/* Index 2 */
.o_calendar_rollover_weekend_day {
  background: #cfcfcf;
  color: white;
}

.o_calendar_disabled_day {
  background: #f0f0f0;
  color: gray;
  cursor: default;
}

/* Index 3 */
.o_calendar_rollover_inactive_month_day {
  color: white;
}

/* Index 5 */
.o_calendar_rollover_today {
  background: #cfcfcf;
  color: white;
}

/* Tabset */
.o_tabset_rollover_top {
  border-top-color: #f8c838;
}

.o_tabset_rollover_right {
  border-right-color: #f8c838;
}

.o_tabset_rollover_bottom {
  border-bottom-color: #f8c838;
}

.o_tabset_rollover_left {
  border-left-color: #f8c838;
}

.o_tabset_selected_rollover_top {
  border-top-color: #c9d8f5;
}

.o_tabset_selected_rollover_right {
  border-right-color: #c9d8f5;
}

.o_tabset_selected_rollover_bottom {
  border-bottom-color: #c9d8f5;
}

.o_tabset_selected_rollover_left {
  border-left-color: #c9d8f5;
}

.o_filter_row .o_spinner,
.o_filter_row .o_dropdown{
  height: 22px;
}

.o_filter_row {
  padding-top: 5px;
  width: 100%;
  clear: both;
  overflow:hidden;
}

.o_filter_row: after {
  content: '';
  clear: both;
  display: block;
  width: 0;
  height: 0;
  overflow: hidden;
  font-size: 0;
}

.o_filter_row_item {
  margin-right: 5px;
  float: left;
  display:inline;
}

.o_filter_no_text{
  margin-top: 5px;
  margin-right:10px;
  font-style: italic;
}

.o_filter_row_item_input {
  margin-top: 3px;
}

.o_filter_row_item_checkbox {
  height:38px;
}

.o_filter_parameter {
  float: left;
  padding:2px 0;
  margin:0 5px 0 0;
  display:inline;
  border:1px solid #808080;
  height:22px;
}
table.o_filter_parameter {
  padding:0;
}
.o_dropdown.o_filter_parameter{
  display:inline-table;
}

.o_filter_add_button,
.o_filter_delete_button {
  width: 25px;
  height:25px;
  margin-top:1px;
  padding:0;
}

.o_filter_inverse_checkbox {
  height: 16px;
  margin:3px 4px;
}

.o_filter_inverse_label {
  font-size:9px;
  display:block;
  margin-top:-7px;
  text-align:center;
}
/* Checkbox */
.o_checkbox_image {
  cursor: default;
}


/* == Shared among components styles (higher priority than usual component's default styles) == */

.o_captionButton {
  width: 16px;
  text-align: center;
}

.o_captionButton_rollover {
  background: #a0a0a0;
}

.o_captionButton_pressed {
  background: #808080;
}

.o_fullWidth {
  width: 100%;
}
.o_fullWidthAndHeight {
  width: 100%;
  height: 100%;
}

/*Day Switcher*/
.o_daySwitcher {
  font-size:14pt;
  font-family:MS Shell Dlg,Arial,sans-serif;
  padding: 0 2px;
}

.o_daySwitcher_previous_button,
  .o_daySwitcher_next_button {
  cursor: pointer;
}

.o_daySwitcher_previous_button {
  border-right: 1px solid #939393;
}

.o_daySwitcher_next_button {
  border-left: 1px solid #939393;
}

.o_daySwitcher_previous_button img,
  .o_daySwitcher_next_button img {
  padding: 0 5px;
}

.o_daySwitcher_upper_text {
  font-size: .55em;
  padding:0 0.5em;
  line-height:1.5em;
  margin: 0;
}

.o_daySwitcher_text {
  font-size: 1em;
  line-height:0.8em;
  padding-bottom:0.2em;
  padding-left:5px;
  padding-right:5px;
  margin: 0;
}

/*Week Switcher*/
.o_weekSwitcher {
  font-size:14pt;
  font-family:MS Shell Dlg,Arial,sans-serif;
  padding: 0 2px;
}

.o_weekSwitcher_previous_button,
  .o_weekSwitcher_next_button {
  cursor: pointer;
}

.o_weekSwitcher_previous_button {
  border-right: 1px solid #939393;
}

.o_weekSwitcher_next_button {
  border-left: 1px solid #939393;
}

.o_weekSwitcher_previous_button img,
  .o_weekSwitcher_next_button img {
  padding: 0 5px;
}

.o_weekSwitcher_text {
  font-size: 1em;
  line-height:0.8em;
  padding-bottom:0.2em;
  padding-left:5px;
  padding-right:5px;
  margin: 0 0 -5px 0;
}

/* Level Indicator */
.o_levelIndicator{
  display:block;
  padding: 5px;
}

.o_levelIndicator.horizontal {
  width: 250px;
  height: 22px;
}

.o_levelIndicator.vertical {
  width: 22px;
  height: 250px;
}

.o_levelIndicator_displayArea {
	background:black;
	overflow:hidden;
	height:100%;
	float:left;
}

.o_levelIndicator_segment.h{
	float:left;
	height:100%;
	margin:0 2px 0 0;
	font-size:0;
}

.o_levelIndicator_segment.v{
	width:100%;
	margin:0 0 2px 0;
	float:left;
}

.o_levelIndicator_segment.on{
	background:#0F0;
}

.o_levelIndicator_segment.off{
	background:#060;
}

.o_levelIndicator_label{
  font-family: MS Shell Dlg, Arial, sans-serif;
	float:right;
	text-align: center;
	width:2.6em;
}

.o_tagCloud_rectangle,
.o_tagCloud_vertical,
.o_tagCloud_oval {
  z-index: 0;
  position: relative;
  overflow: hidden;
  margin: 0;
  padding: 5px;
  border: 0 none;

  font-family: "Lucida Grande", Tahoma, Arial, Helvetica, sans-serif;
  line-height: 2em;
}

.o_tagCloud_rectangle,
.o_tagCloud_oval {
  width: 400px;
}

.o_tagCloud_rectangle{
  text-align:center;
}

.o_tagCloud_vertical {
  width: 250px;
  text-align: center;
}

.o_tagCloud_oval {
  text-align: left;
  overflow:visible;
}

.o_tagCloud_rectangle  a:focus,
.o_tagCloud_oval  a:focus,
.o_tagCloud_vertical a:focus {
  outline: none;
}

.o_tagCloud_rollover {
  border: 1px dotted black;
}

.o_tagCloud_item {
  display: inline-block;

  z-index: 1;
  position: relative;

  border: 0 none;
  margin: 0;
  padding: 0;

  margin-left: 0.5em;
  margin-right: 0.5em;

  text-decoration: none;
}

.o_tagCloud_item_rollover {
  text-decoration: underline;
}
