/* latin-ext */
@font-face {
  font-family: 'Oxygen';
  font-style: normal;
  font-weight: 400;
  src: local('Oxygen'), local('Oxygen-Regular'), url(font/oxygen-regular-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-024F, U+1E00-1EFF, U+20A0-20AB, U+20AD-20CF, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Oxygen';
  font-style: normal;
  font-weight: 400;
  src: local('Oxygen'), local('Oxygen-Regular'), url(font/oxygen-regular-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215, U+E0FF, U+EFFD, U+F000;
}

.material-icons-font {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}
@font-face {
  font-family: 'icomoon';
  src: url('font/icomoon.woff?9btq6a') format('woff');
  font-weight: normal;
  font-style: normal;
}
.icomoon {
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.center-cont,
.cc {
  display: flex;
  align-items: center;
  justify-content: center;
}

.material-icons-font {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}
@font-face {
  font-family: 'icomoon';
  src: url('font/icomoon.woff?9btq6a') format('woff');
  font-weight: normal;
  font-style: normal;
}
.icomoon {
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.center-cont,
.cc {
  display: flex;
  align-items: center;
  justify-content: center;
}
body.fullscreen #excel-app {
  width: 100%;
  height: 100%;
  padding-top: 2rem;
  padding-left: 1rem;
  background: #FFF;
}
body.fullscreen #excel-app::before {
  content: "Appuyez sur ECHAP (ou F11) pour quitter le mode plein écran";
  position: fixed;
  top: 5px;
  right: 5px;
  font-weight: bold;
  border: 1px solid #BBB;
  padding: 10px;
  color: #999;
}
body.fullscreen .excel-container {
  height: calc(100% - 5rem) !important;
}
.excel-container {
  position: relative;
  overflow: auto;
  display: inline-block;
  width: auto;
  max-width: 100%;
  padding-right: 10px;
}
table.excel {
  max-width: 100%;
  width: auto;
}
table.excel .empty-filler {
  border-right: none;
}
table.excel .empty-filler + th {
  border-left: none;
}
table.excel.excel--fixed-header thead {
  position: absolute;
  top: 0;
  left: 0;
  background: #FFF;
  z-index: 30;
  overflow: hidden;
}
table.excel.excel--fixed-header tbody th {
  position: absolute;
  left: 0;
  background: #FFF;
  border-top: none;
}
table.excel.excel--fixed-header thead tr:first-child th:first-child {
  position: absolute;
  height: 100%;
  left: 0;
  background: #FFF;
  z-index: 35;
}
table.excel.excel--fixed-header tbody tr:first-child td {
  border-top-color: #FFF;
}
table.excel.excel--fixed-header .fixed-col {
  z-index: 25;
}
table.excel.excel--fixed-header tr td:nth-child(2),
table.excel.excel--fixed-header thead tr th:nth-child(2),
table.excel.excel--fixed-header thead tr th:first-child:not(.fixed-col) {
  border-left: none;
}
table.excel.excel--fixed-header thead tr th[rowspan]:not(.fixed-col) {
  border-right: none;
}
table.excel thead th {
  font-size: 0.8rem;
}
table.excel tbody th {
  white-space: nowrap;
  text-align: right;
  font-size: 0.8rem;
}
table.excel td,
table.excel th {
  border: 0.05rem solid #e7e9ed;
  width: 150px;
  min-width: 150px;
  max-width: 150px;
}
table.excel td.l,
table.excel th.l {
  width: 150px;
  min-width: 150px;
  max-width: 150px;
}
table.excel tbody th.s13 {
  width: calc(150px / 3);
  min-width: calc(150px / 3);
}
table.excel tbody th.p2 {
  margin-left: calc(150px / 3);
}
table.excel tbody th.p3 {
  margin-left: calc((150px / 3) * 2);
}
table.excel th[colspan="1"] {
  width: 150px;
  min-width: 150px;
  max-width: 150px;
}
table.excel th[colspan="2"] {
  width: 300px;
  min-width: 300px;
  max-width: 300px;
}
table.excel th[colspan="3"] {
  width: 450px;
  min-width: 450px;
  max-width: 450px;
}
table.excel th[colspan="4"] {
  width: 600px;
  min-width: 600px;
  max-width: 600px;
}
table.excel th[colspan="5"] {
  width: 750px;
  min-width: 750px;
  max-width: 750px;
}
table.excel th[colspan="6"] {
  width: 900px;
  min-width: 900px;
  max-width: 900px;
}
table.excel th[colspan="7"] {
  width: 1050px;
  min-width: 1050px;
  max-width: 1050px;
}
table.excel th[colspan="8"] {
  width: 1200px;
  min-width: 1200px;
  max-width: 1200px;
}
table.excel th[colspan="9"] {
  width: 1350px;
  min-width: 1350px;
  max-width: 1350px;
}
table.excel th[colspan="10"] {
  width: 1500px;
  min-width: 1500px;
  max-width: 1500px;
}
table.excel th[colspan="11"] {
  width: 1650px;
  min-width: 1650px;
  max-width: 1650px;
}
table.excel th[colspan="12"] {
  width: 1800px;
  min-width: 1800px;
  max-width: 1800px;
}
table.excel th[colspan="13"] {
  width: 1950px;
  min-width: 1950px;
  max-width: 1950px;
}
table.excel th[colspan="14"] {
  width: 2100px;
  min-width: 2100px;
  max-width: 2100px;
}
table.excel th[colspan="15"] {
  width: 2250px;
  min-width: 2250px;
  max-width: 2250px;
}
table.excel th[colspan="16"] {
  width: 2400px;
  min-width: 2400px;
  max-width: 2400px;
}
table.excel th[colspan="17"] {
  width: 2550px;
  min-width: 2550px;
  max-width: 2550px;
}
table.excel th[colspan="18"] {
  width: 2700px;
  min-width: 2700px;
  max-width: 2700px;
}
table.excel th[colspan="19"] {
  width: 2850px;
  min-width: 2850px;
  max-width: 2850px;
}
table.excel th[colspan="20"] {
  width: 3000px;
  min-width: 3000px;
  max-width: 3000px;
}
table.excel th[rowspan="1"] {
  height: 26px;
  min-height: 26px;
}
table.excel th[rowspan="2"] {
  height: 52px;
  min-height: 52px;
}
table.excel th[rowspan="3"] {
  height: 78px;
  min-height: 78px;
}
table.excel th[rowspan="4"] {
  height: 104px;
  min-height: 104px;
}
table.excel th[rowspan="5"] {
  height: 130px;
  min-height: 130px;
}
table.excel th[rowspan="6"] {
  height: 156px;
  min-height: 156px;
}
table.excel th[rowspan="7"] {
  height: 182px;
  min-height: 182px;
}
table.excel th[rowspan="8"] {
  height: 208px;
  min-height: 208px;
}
table.excel th[rowspan="9"] {
  height: 234px;
  min-height: 234px;
}
table.excel th[rowspan="10"] {
  height: 260px;
  min-height: 260px;
}
table.excel th[rowspan="11"] {
  height: 286px;
  min-height: 286px;
}
table.excel th[rowspan="12"] {
  height: 312px;
  min-height: 312px;
}
table.excel th[rowspan="13"] {
  height: 338px;
  min-height: 338px;
}
table.excel th[rowspan="14"] {
  height: 364px;
  min-height: 364px;
}
table.excel th[rowspan="15"] {
  height: 390px;
  min-height: 390px;
}
table.excel th[rowspan="16"] {
  height: 416px;
  min-height: 416px;
}
table.excel th[rowspan="17"] {
  height: 442px;
  min-height: 442px;
}
table.excel th[rowspan="18"] {
  height: 468px;
  min-height: 468px;
}
table.excel th[rowspan="19"] {
  height: 494px;
  min-height: 494px;
}
table.excel th[rowspan="20"] {
  height: 520px;
  min-height: 520px;
}
table.excel th[rowspan="21"] {
  height: 546px;
  min-height: 546px;
}
table.excel th[rowspan="22"] {
  height: 572px;
  min-height: 572px;
}
table.excel th[rowspan="23"] {
  height: 598px;
  min-height: 598px;
}
table.excel th[rowspan="24"] {
  height: 624px;
  min-height: 624px;
}
table.excel th[rowspan="25"] {
  height: 650px;
  min-height: 650px;
}
table.excel th[rowspan="26"] {
  height: 676px;
  min-height: 676px;
}
table.excel th[rowspan="27"] {
  height: 702px;
  min-height: 702px;
}
table.excel th[rowspan="28"] {
  height: 728px;
  min-height: 728px;
}
table.excel th[rowspan="29"] {
  height: 754px;
  min-height: 754px;
}
table.excel th[rowspan="30"] {
  height: 780px;
  min-height: 780px;
}
table.excel th[rowspan="31"] {
  height: 806px;
  min-height: 806px;
}
table.excel th[rowspan="32"] {
  height: 832px;
  min-height: 832px;
}
table.excel td {
  padding: 0;
}

.material-icons-font {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}
@font-face {
  font-family: 'icomoon';
  src: url('font/icomoon.woff?9btq6a') format('woff');
  font-weight: normal;
  font-style: normal;
}
.icomoon {
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.center-cont,
.cc {
  display: flex;
  align-items: center;
  justify-content: center;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html,
body {
  height: 100%;
  overflow: hidden;
  padding: 0;
  margin: 0;
  font-size: 15px;
  font-family: 'Oxygen', Verdana, Geneva, sans-serif;
  font-style: normal;
  font-weight: 400;
  cursor: default;
  background: #EEE url('/img/bg/subtle_carbon_white.png');
}
ul,
li {
  list-style: none;
  padding: 0;
}
header {
  height: 108px;
  background: rgba(255, 255, 255, 0.5);
  text-align: center;
  z-index: 10;
}
#main-cont nav {
  position: fixed;
  width: 220px;
  top: 0;
  height: calc(100% - 30px);
  left: 0;
  background: rgba(255, 255, 255, 0.5);
  color: #333;
}
#main-cont nav h4 {
  text-align: center;
}
#main-cont nav ul {
  padding: 0;
  margin: 0;
  height: calc(100% - 70px);
  overflow: auto;
}
#main-cont nav li {
  list-style: none;
  border-left: 3px solid transparent;
}
#main-cont nav li a {
  display: block;
  height: 40px;
  line-height: 40px;
  padding: 0 10px;
  color: #333;
  text-decoration: none;
}
#main-cont nav li a i {
  margin-top: 8px;
  float: right;
}
#main-cont nav li.selected {
  background: #FFF;
  border-left: 3px solid #c8700b;
  background: #F8EBF0;
}
#main-cont nav li:hover {
  border-left: 3px solid #c8700b;
}
#main-cont nav li:hover a {
  color: #c8700b;
}
#main-cont nav li.with-submenu > a:after {
  content: "\E315";
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
  font-size: 24px;
  height: 40px;
  line-height: 42px;
  display: inline-block;
  vertical-align: top;
  margin-left: 4px;
}
#main-cont nav li.with-submenu ul {
  display: none;
}
#main-cont nav li.with-submenu ul li {
  padding-left: 15px;
}
#main-cont nav li.with-submenu.expanded > a:after {
  content: "\E313";
}
#main-cont nav li.with-submenu.expanded ul {
  display: block;
  overflow: visible;
}
#main-cont nav li.with-submenu:hover {
  border-left: 3px solid transparent;
}
#main-cont nav li.with-submenu:hover a {
  color: #333;
}
#main-cont {
  height: calc(100% - 30px);
  overflow: auto;
}
#main-cont.with-left-menu {
  margin-left: 220px;
  width: calc(100% - 220px);
  border: 1px solid #DDD;
  box-shadow: inset 0 0 10px #DDD;
}
body.guest #main-cont {
  margin-left: 0;
  width: 100%;
}
main {
  min-width: 600px;
  /* Largeur minimum du site */
  height: 100%;
  color: #333;
}
main section {
  padding: 20px;
}
main section h1:first-child {
  margin-top: 0;
}
.guest main {
  padding-left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
footer {
  background: rgba(255, 255, 255, 0.5);
  height: 30px;
  line-height: 30px;
  text-align: center;
  overflow: hidden;
  z-index: 10;
}
#sql-stats {
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  background: #FFF;
  padding: 20px;
  width: 95%;
  display: none;
  max-height: 90%;
  overflow: auto;
  box-shadow: 0 0 10px #333;
}
#sql-stats li {
  margin: 10px 0;
}
h1 {
  color: #c8700b;
  margin-bottom: 40px;
}
h2 {
  margin-top: 40px;
}
a,
a:visited {
  color: #c8700b;
  text-decoration: underline;
}
a:hover {
  text-decoration: none;
}
a.with-icon {
  display: inline-block;
  height: 24px;
  line-height: 24px;
}
a.with-icon .material-icons,
a.with-icon .material-symbols-outlined {
  vertical-align: middle;
}
blockquote {
  padding: 10px 20px;
  margin: 20px 60px 30px 20px;
  background: rgba(144, 144, 144, 0.5);
  color: #111;
  border-left: 3px solid #111;
}
blockquote.important {
  background: rgba(200, 112, 11, 0.4);
  border-left: 3px solid #c8700b;
}
blockquote.hero {
  padding: 30px 60px;
  font-size: 1.5rem;
}
blockquote.no-margin-bottom {
  margin-bottom: 0;
}
.xdebug-var-dump {
  font-size: 0.8em;
}
.polaroid {
  box-sizing: content-box;
  border: 6px solid #FFF;
  box-shadow: 0 0 5px #666;
}
.date-picker {
  min-width: 100px;
  width: 110px;
  text-align: center;
}
.date-picker.imp {
  min-width: 100px !important;
  width: 110px !important;
  text-align: center !important;
}
.time-picker {
  min-width: 60px;
  width: 60px;
  text-align: center;
}
.time-picker.imp {
  min-width: 60px !important;
  width: 60px !important;
  text-align: center !important;
}
.single-row .text-center .time-picker {
  display: inline-block;
}
.split-2 > div {
  display: inline-block;
  vertical-align: top;
}
.split-2 > div:first-child {
  margin-right: 20px;
}
.mid {
  vertical-align: middle;
}
.gold {
  color: #c8700b;
}
.member-editable-list .member {
  display: inline-block;
  height: 24px;
  line-height: 24px;
  background: #EEE;
}
.member-editable-list .btn-add {
  cursor: pointer;
  display: inline-block;
  height: 24px;
  line-height: 24px;
  background: #c8700b;
  color: #FFF;
}
#badgingSummary {
  margin: 20px 0;
}
table {
  border-collapse: collapse;
}
table.--hide-inactive .inactive {
  display: none;
}
table caption {
  padding: 10px 0;
  font-style: italic;
}
table caption.bold {
  font-style: normal;
  font-weight: bold;
}
table a.ico-link {
  color: #333;
  text-decoration: none;
  font-size: 1.6rem;
}
table a .material-icons,
table a [class^="icon-"],
table a [class*=" icon-"],
table a .material-symbols-outlined {
  color: #333;
}
table th {
  font-weight: normal;
}
table th,
table td {
  padding: 10px 15px;
}
table th.good,
table td.good {
  color: #4A9E4A;
}
table th.bad,
table td.bad {
  color: #bf3431;
}
table.small th,
table.small td {
  padding: 3px 6px;
}
table.small-body tbody th,
table.small-body tbody td {
  padding: 3px 6px;
}
table tr.alert th,
table tr.alert td {
  background: rgba(193, 73, 73, 0.25);
}
table tr.selected th,
table tr.selected td {
  background: rgba(0, 104, 123, 0.25);
}
table tr.selected.alert th,
table tr.selected.alert td {
  background: rgba(193, 73, 73, 0.25);
}
table tr.inactive th,
table tr.inactive td,
table tr.inactive a .material-icons,
table tr.inactive a .material-symbols-outlined {
  color: #BBB;
}
table tr.inactive .initials {
  background: #BBB;
}
table tr.empty th,
table tr.empty td {
  text-align: center;
  font-style: italic;
}
table tr.important,
table tr.role-charge,
table tr.role-chef {
  background: rgba(0, 104, 123, 0.25);
}
table tr td.important {
  background: rgba(0, 104, 123, 0.25) !important;
}
table thead {
  background: rgba(190, 162, 21, 0.25);
}
table td.vertical div,
table th.vertical div {
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
table.active tbody tr {
  cursor: pointer;
}
table.active tbody tr:hover td,
table.active tbody tr:hover th {
  background: rgba(211, 211, 211, 0.25);
}
table.planning thead {
  border: 1px solid #808080;
  border-left: none;
}
table.planning thead tr th {
  border: none;
  border-right: 1px solid #808080;
  background: #efe8c4 !important;
}
table.planning thead tr th.fixed-col {
  border-left: 1px solid #808080;
}
table.planning thead tr th:first-child[colspan="3"] {
  width: 150px;
  min-width: 150px;
  max-width: 150px;
  display: inline-block;
}
table.planning thead tr th:last-child {
  border-right: none;
}
table.planning thead tr:nth-child(2) th {
  border-top: 1px solid #808080;
}
table.planning thead tr:nth-child(2) th.w3 {
  border-top: none;
}
table.planning caption {
  max-width: 800px;
}
table.planning caption a {
  margin: 3px 6px;
}
table.planning caption .date-picker {
  min-width: 120px;
  width: 120px;
  margin: 0 5px;
}
table.planning td,
table.planning th {
  text-align: center;
}
table.planning td.day,
table.planning th.day {
  height: 26px;
}
table.planning td.selected,
table.planning th.selected {
  border: 2px solid #eda618;
}
table.planning td .event,
table.planning th .event {
  position: relative;
  display: inline-block;
  width: 100%;
  height: 100%;
  line-height: 25px;
  white-space: nowrap;
  overflow: hidden;
  vertical-align: top;
}
table.planning td .event.morning-only:before,
table.planning th .event.morning-only:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
  z-index: 10;
  box-shadow: inset 0 -12px rgba(0, 0, 0, 0.7);
}
table.planning td .event.morning-only.pending:before,
table.planning th .event.morning-only.pending:before {
  box-shadow: inset 0 -12px rgba(0, 0, 0, 0.7);
}
table.planning td .event.afternoon-only:before,
table.planning th .event.afternoon-only:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
  z-index: 10;
  box-shadow: inset 0 12px rgba(0, 0, 0, 0.7);
}
table.planning td .event.afternoon-only.pending:before,
table.planning th .event.afternoon-only.pending:before {
  box-shadow: inset 0 12px rgba(0, 0, 0, 0.7);
}
table.planning td .event.disabled,
table.planning th .event.disabled {
  background: url('/img/bg/hazard_small_40pc.png') center center repeat !important;
}
table.planning td .event.pending:before,
table.planning th .event.pending:before,
table.planning td .event.comments:before,
table.planning th .event.comments:before {
  content: "\E88B";
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
  color: #c17600;
  background: rgba(255, 255, 255, 0.6);
  font-weight: bold;
  font-size: 1rem;
  line-height: 25px;
  text-align: left;
  text-indent: 3px;
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
  z-index: 10;
}
table.planning td .event.pending:hover:before,
table.planning th .event.pending:hover:before,
table.planning td .event.comments:hover:before,
table.planning th .event.comments:hover:before {
  content: "" !important;
}
table.planning td .event.pending.comments:before,
table.planning th .event.pending.comments:before {
  content: "\E88B \E0B9";
}
table.planning td .event.comments:not(.pending):before,
table.planning th .event.comments:not(.pending):before {
  content: "\E0B9";
  background: transparent;
}
table.planning td .event.has-label::after,
table.planning th .event.has-label::after {
  content: "" !important;
}
table.planning td .event::after,
table.planning th .event::after {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 100%;
  text-align: center;
}
table.planning td .event.event-post_am,
table.planning th .event.event-post_am {
  background: #9999BB;
}
table.planning td .event.event-post_am:after,
table.planning th .event.event-post_am:after {
  content: 'Matin';
}
table.planning td .event.event-post_pm,
table.planning th .event.event-post_pm {
  background: #99BB99;
}
table.planning td .event.event-post_pm:after,
table.planning th .event.event-post_pm:after {
  content: 'Aprem';
}
table.planning td .event.event-ast,
table.planning th .event.event-ast {
  background: #99BB99;
}
table.planning td .event.event-ast:after,
table.planning th .event.event-ast:after {
  content: 'AST';
}
table.planning td .event.event-post_perm,
table.planning th .event.event-post_perm {
  background: #9999BB;
}
table.planning td .event.event-post_perm:after,
table.planning th .event.event-post_perm:after {
  content: 'Perm.';
}
table.planning td .event.event-night,
table.planning th .event.event-night {
  background: #EE6666;
}
table.planning td .event.event-night:after,
table.planning th .event.event-night:after {
  content: 'Nuit';
}
table.planning td .event.event-absence,
table.planning th .event.event-absence {
  color: #EE6666;
  background: #400505;
}
table.planning td .event.event-absence:after,
table.planning th .event.event-absence:after {
  content: 'Absence';
}
table.planning td .event.event-vacation,
table.planning th .event.event-vacation {
  color: #99BB99;
  background: #054005;
}
table.planning td .event.event-vacation:after,
table.planning th .event.event-vacation:after {
  content: 'Congé';
}
table.planning td .event.event-custom,
table.planning th .event.event-custom {
  color: #222;
  background: #EEE;
}
table.planning td[nb-events="2"] .event,
table.planning th[nb-events="2"] .event {
  width: 50%;
}
table.planning td[nb-events="3"] .event,
table.planning th[nb-events="3"] .event {
  width: 33.3333%;
}
table.planning td[nb-events="4"] .event,
table.planning th[nb-events="4"] .event {
  width: 25%;
}
table.planning td[nb-events="5"] .event,
table.planning th[nb-events="5"] .event {
  width: 20%;
}
table.planning th {
  background: #FFF;
}
table.planning th.important {
  background: #bfd9de !important;
}
table.planning tr.disabled th.day {
  background: #d6d6d6;
}
table.planning tbody tr.disabled td {
  background: rgba(50, 50, 50, 0.2);
}
table.planning tbody tr.disabled td.month,
table.planning tbody tr.disabled td.week {
  background: transparent;
}
table.planning tbody td {
  padding: 0;
}
table.planning tbody .go,
table.planning tbody [go] {
  position: relative;
}
table.planning tbody .go .event,
table.planning tbody [go] .event {
  cursor: pointer;
}
table.planning tbody .go .event:hover,
table.planning tbody [go] .event:hover {
  text-decoration: underline;
}
table.planning tbody .go .event:hover.morning-only:before,
table.planning tbody [go] .event:hover.morning-only:before {
  box-shadow: inset 0 -12px rgba(0, 0, 0, 0.2);
}
table.planning tbody .go .event:hover.morning-only.pending:before,
table.planning tbody [go] .event:hover.morning-only.pending:before {
  box-shadow: inset 0 -12px rgba(0, 0, 0, 0.2);
}
table.planning tbody .go .event:hover.afternoon-only:before,
table.planning tbody [go] .event:hover.afternoon-only:before {
  box-shadow: inset 0 12px rgba(0, 0, 0, 0.2);
}
table.planning tbody .go .event:hover.afternoon-only.pending:before,
table.planning tbody [go] .event:hover.afternoon-only.pending:before {
  box-shadow: inset 0 12px rgba(0, 0, 0, 0.2);
}
table.planning tbody .go .event:hover:after,
table.planning tbody [go] .event:hover:after {
  text-decoration: underline;
}
table.planning tbody .go .add,
table.planning tbody [go] .add,
table.planning tbody .go i[add],
table.planning tbody [go] i[add] {
  z-index: 20;
  font-style: normal;
  cursor: pointer;
  display: none;
  position: absolute;
  top: 2px;
  right: 2px;
  width: 20px;
  height: 20px;
  border: 1px solid #222;
  color: #222;
  background: #19a1c2;
}
table.planning tbody .go .add:after,
table.planning tbody [go] .add:after,
table.planning tbody .go i[add]:after,
table.planning tbody [go] i[add]:after {
  content: "+";
}
table.planning tbody .go .add:hover,
table.planning tbody [go] .add:hover,
table.planning tbody .go i[add]:hover,
table.planning tbody [go] i[add]:hover {
  border-color: #111;
  color: #111;
  background: #4fb3c2;
}
table.planning tbody .go:hover .add,
table.planning tbody [go]:hover .add,
table.planning tbody .go:hover i[add],
table.planning tbody [go]:hover i[add] {
  display: block;
}
table.planning .month,
table.planning .month div {
  width: 20px;
  white-space: nowrap;
  text-align: center;
}
table.planning .cell {
  width: 120px;
  text-align: center;
}
table.excel.excel--fixed-header tbody th {
  margin-top: 1px;
}
table.planning tbody tr,
table.planning tbody td,
table.planning tbody th {
  height: 26px;
  min-height: 26px;
  max-height: 26px;
}
@media screen {
  .table-container {
    overflow-x: auto;
    overflow-y: hidden;
  }
  table.planning {
    border-collapse: collapse;
    border-spacing: 0;
  }
  table.planning thead .cell {
    overflow: hidden;
    box-sizing: border-box;
  }
  table.planning tbody td,
  table.planning tbody th {
    border: 1px solid #808080;
    border-left: none;
    margin: 0;
  }
  table.planning tbody .vertical.month {
    border-left: 1px solid #808080;
  }
}
form {
  padding: 10px 20px;
}
label {
  display: inline-block;
  height: 26px;
  line-height: 26px;
  vertical-align: top;
}
input[type=checkbox] {
  position: absolute;
  left: -9999px;
}
input[type=checkbox] + label {
  position: relative;
  text-indent: 30px;
}
input[type=checkbox] + label:before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  border: 2px solid #999;
  background: #FFF;
  position: absolute;
  top: 50%;
  left: 3px;
  margin-top: -10px;
  color: #555;
  font-size: 12px;
  line-height: 12px;
  font-weight: bold;
  text-align: center;
  text-indent: 0;
}
input[type=checkbox].mini + label {
  text-indent: 0;
}
input[type=checkbox]:checked + label:before {
  content: "\02713";
}
input[type=checkbox]:disabled + label {
  color: #888 !important;
}
input[type=checkbox]:disabled + label:before {
  color: #888 !important;
  border-color: #888 !important;
}
input[type=checkbox].gold + label {
  color: #F7D31B;
}
input[type=checkbox].gold + label:before {
  color: #F7D31B;
  border-color: #F7D31B;
}
input[type=radio] {
  position: absolute;
  left: -9999px;
}
input[type=radio] + label {
  position: relative;
  text-indent: 30px;
}
input[type=radio] + label:before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  border: 2px solid #999;
  background: #FFF;
  position: absolute;
  top: 50%;
  left: 3px;
  margin-top: -10px;
  color: #555;
  font-size: 1.1rem;
  line-height: 15px;
  font-weight: bold;
  text-align: center;
  text-indent: 0;
  border-radius: 50%;
}
input[type=radio].mini + label {
  text-indent: 0;
}
input[type=radio]:checked + label:after {
  content: "";
  width: 10px;
  height: 10px;
  background: #666;
  border-radius: 50%;
  display: block;
  position: absolute;
  top: 50%;
  margin-top: -7px;
  left: 6px;
}
input[type=radio]:disabled + label {
  color: #888 !important;
}
input[type=radio]:disabled + label:before {
  color: #888 !important;
  border-color: #888 !important;
}
input[type=radio]:disabled + label:after {
  background: #888 !important;
}
input[type=radio].gold + label {
  color: #F7D31B;
}
input[type=radio].gold + label:before {
  color: #F7D31B;
  border-color: #F7D31B;
}
input[type=radio].gold + label:after {
  background: #F7D31B;
}
form.inline label {
  height: 34px;
  line-height: 20px;
  padding: 7px 0;
  width: 200px;
}
form.inline.--large label {
  width: 250px;
}
form.inline.--large input {
  min-width: 250px;
}
form p.--password {
  position: relative;
}
form p.--password input {
  padding-right: 2.2rem;
}
form p.--password input[type=text] {
  font-size: 0.9rem;
  font-family: 'Courier New', monospace;
}
form p.--password span.--toggle {
  position: absolute;
  left: 500px;
  top: 2px;
  margin-left: -1.5rem;
  cursor: pointer;
}
form p.--password span.--toggle::after {
  content: "\e8f4";
  display: inline-block;
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
  font-size: 1.5rem;
  height: 2rem;
  line-height: 2rem;
  width: 2rem;
  text-align: center;
}
form p.--password span.--toggle.--visible::after {
  content: "\e8f5";
}
input[type=date],
input[type=time],
input[type=text],
input[type=password],
input[type=email],
input[type=number] {
  min-width: 200px;
  height: 34px;
  line-height: 32px;
  padding: 0 5px;
  outline: none;
  border: 2px solid #999;
  background: #FFF;
}
input[type=date].small,
input[type=time].small,
input[type=text].small,
input[type=password].small,
input[type=email].small,
input[type=number].small {
  min-width: 50px;
  width: 60px;
}
input[type=date].small2,
input[type=time].small2,
input[type=text].small2,
input[type=password].small2,
input[type=email].small2,
input[type=number].small2 {
  min-width: 65px;
  width: 75px;
}
input[type=date]:focus,
input[type=time]:focus,
input[type=text]:focus,
input[type=password]:focus,
input[type=email]:focus,
input[type=number]:focus {
  background: #FFF7E8;
}
input[type=date]:disabled,
input[type=time]:disabled,
input[type=text]:disabled,
input[type=password]:disabled,
input[type=email]:disabled,
input[type=number]:disabled {
  border-color: #888 !important;
  background: #DDD !important;
}
input[type=number] {
  min-width: 50px;
  padding-right: 0;
}
input[type=number].small {
  width: 60px;
  margin: 0;
  display: inline-block;
}
textarea {
  min-width: 200px;
  height: 80px;
  padding: 5px;
  outline: none;
  border: 2px solid #999;
  background: #FFF;
}
textarea:focus {
  background: #FFF7E8;
}
textarea:disabled {
  border-color: #888 !important;
  background: #DDD !important;
}
select {
  min-width: 200px;
  height: 34px;
  line-height: 34px;
  padding: 0 5px;
  outline: none;
  border: 2px solid #999;
  background: #FFF;
}
select:focus {
  background: #FFF7E8;
}
select:disabled {
  border-color: #888 !important;
  background: #DDD !important;
}
label + input,
label + textarea,
label + select {
  margin-left: 10px;
}
label.gold {
  color: #F7D31B;
}
label.gold.disabled {
  color: #FFF;
}
label.gold + input[type=text],
label.gold + textarea,
label.gold + select {
  border-color: #F7D31B;
}
button,
.btn,
a.btn,
input[type=submit],
form.inline .btn {
  display: inline-block;
  height: 34px;
  line-height: 34px;
  background: #c8700b;
  color: #FFF;
  padding: 0 10px;
  border: none;
  text-decoration: none;
  cursor: pointer;
  outline: none;
  width: auto;
}
button.btn-small,
.btn.btn-small,
a.btn.btn-small,
input[type=submit].btn-small,
form.inline .btn.btn-small {
  height: 24px;
  line-height: 24px;
  padding: 0 5px;
}
button.btn-small .material-icons,
.btn.btn-small .material-icons,
a.btn.btn-small .material-icons,
input[type=submit].btn-small .material-icons,
form.inline .btn.btn-small .material-icons,
button.btn-small .material-symbols-outlined,
.btn.btn-small .material-symbols-outlined,
a.btn.btn-small .material-symbols-outlined,
input[type=submit].btn-small .material-symbols-outlined,
form.inline .btn.btn-small .material-symbols-outlined {
  font-size: 15px;
  margin-right: 6px;
  margin-top: 4px;
}
button .material-icons,
.btn .material-icons,
a.btn .material-icons,
input[type=submit] .material-icons,
form.inline .btn .material-icons,
button [class^="icon-"],
.btn [class^="icon-"],
a.btn [class^="icon-"],
input[type=submit] [class^="icon-"],
form.inline .btn [class^="icon-"],
button [class*=" icon-"],
.btn [class*=" icon-"],
a.btn [class*=" icon-"],
input[type=submit] [class*=" icon-"],
form.inline .btn [class*=" icon-"],
button .material-symbols-outlined,
.btn .material-symbols-outlined,
a.btn .material-symbols-outlined,
input[type=submit] .material-symbols-outlined,
form.inline .btn .material-symbols-outlined {
  display: inline-block;
  margin-top: 5px;
  vertical-align: top;
  margin-right: 10px;
}
button.btn-red,
.btn.btn-red,
a.btn.btn-red,
input[type=submit].btn-red,
form.inline .btn.btn-red {
  background-color: #DD6666;
}
button.btn-red:hover,
.btn.btn-red:hover,
a.btn.btn-red:hover,
input[type=submit].btn-red:hover,
form.inline .btn.btn-red:hover {
  background-color: #dd8282;
}
button.btn-red:focus,
.btn.btn-red:focus,
a.btn.btn-red:focus,
input[type=submit].btn-red:focus,
form.inline .btn.btn-red:focus {
  background-color: #dd8282;
}
button.btn-green,
.btn.btn-green,
a.btn.btn-green,
input[type=submit].btn-green,
form.inline .btn.btn-green {
  background-color: #66DD66;
}
button.btn-green:hover,
.btn.btn-green:hover,
a.btn.btn-green:hover,
input[type=submit].btn-green:hover,
form.inline .btn.btn-green:hover {
  background-color: #8fdd88;
}
button.btn-green:focus,
.btn.btn-green:focus,
a.btn.btn-green:focus,
input[type=submit].btn-green:focus,
form.inline .btn.btn-green:focus {
  background-color: #8fdd88;
}
button:hover,
.btn:hover,
a.btn:hover,
input[type=submit]:hover,
form.inline .btn:hover {
  background-color: #eda618;
}
button:focus,
.btn:focus,
a.btn:focus,
input[type=submit]:focus,
form.inline .btn:focus {
  background-color: #eda618;
}
button[disabled],
.btn[disabled],
a.btn[disabled],
input[type=submit][disabled],
form.inline .btn[disabled],
button.disabled,
.btn.disabled,
a.btn.disabled,
input[type=submit].disabled,
form.inline .btn.disabled {
  background-color: #888 !important;
  cursor: default;
  pointer-events: none;
}
.buttons {
  margin: 20px 0;
  text-align: center;
}
.buttons.left {
  text-align: left;
}
.buttons.left .btn:first-child,
.buttons.left .button:first-child,
.buttons.left button:first-child,
.buttons.left input[type=button]:first-child,
.buttons.left input[type=submit]:first-child {
  margin-left: 0;
}
.buttons .btn,
.buttons .button,
.buttons button,
.buttons input[type=button],
.buttons input[type=submit] {
  margin: 0 10px;
}
.buttons.two-btns .btn,
.buttons.two-btns .button,
.buttons.two-btns button,
.buttons.two-btns input[type=button],
.buttons.two-btns input[type=submit] {
  display: inline-block;
  width: calc(50% - 2px);
  vertical-align: top;
  margin: 0;
}
.buttons.two-btns .btn:first-child,
.buttons.two-btns .button:first-child,
.buttons.two-btns button:first-child,
.buttons.two-btns input[type=button]:first-child,
.buttons.two-btns input[type=submit]:first-child {
  margin-right: 4px;
}
.input-file {
  position: relative;
  overflow: hidden;
}
.input-file [type=file] {
  display: block;
  position: absolute;
  top: -100px;
  left: -100px;
  width: calc(100% + 200px);
  height: calc(100% + 200px);
  font-size: 999px;
  filter: alpha(opacity=0);
  opacity: 0;
  cursor: pointer;
}
.widget {
  display: inline-block;
  margin: 20px 0;
}
.widget h3 {
  background: rgba(190, 162, 21, 0.25);
  padding: 8px 20px;
  margin: 0;
}
.widget > div {
  background: rgba(211, 211, 211, 0.25);
  padding: 8px;
}
form .switch,
form.split .switch,
.switch {
  display: block;
  margin: 1em 0;
}
form .switch[readonly],
form.split .switch[readonly],
.switch[readonly] {
  cursor: default;
}
form .switch[readonly] label,
form.split .switch[readonly] label,
.switch[readonly] label {
  cursor: default;
}
form .switch span,
form.split .switch span,
.switch span {
  display: inline-block;
  margin-right: 0.5em;
  vertical-align: middle;
}
form .switch input,
form.split .switch input,
.switch input {
  display: none;
}
form .switch input::selection,
form.split .switch input::selection,
.switch input::selection,
form .switch input::after::selection,
form.split .switch input::after::selection,
.switch input::after::selection,
form .switch input::before::selection,
form.split .switch input::before::selection,
.switch input::before::selection,
form .switch input *::selection,
form.split .switch input *::selection,
.switch input *::selection,
form .switch input *::after::selection,
form.split .switch input *::after::selection,
.switch input *::after::selection,
form .switch input *::before::selection,
form.split .switch input *::before::selection,
.switch input *::before::selection,
form .switch input + label::selection,
form.split .switch input + label::selection,
.switch input + label::selection {
  background: none;
}
form .switch input + label,
form.split .switch input + label,
.switch input + label {
  outline: 0;
  display: inline-block;
  vertical-align: middle;
  text-indent: 0;
  width: 4rem;
  height: 2rem;
  position: relative;
  cursor: pointer;
  user-select: none;
}
form .switch input + label::after,
form.split .switch input + label::after,
.switch input + label::after,
form .switch input + label::before,
form.split .switch input + label::before,
.switch input + label::before {
  position: relative;
  display: block;
  border: none;
  font-weight: normal;
  margin: 0;
  content: "";
  width: 50%;
  height: 100%;
}
form .switch input + label::after,
form.split .switch input + label::after,
.switch input + label::after {
  left: 0;
}
form .switch input + label::before,
form.split .switch input + label::before,
.switch input + label::before {
  display: none;
}
form .switch input:checked + label::after,
form.split .switch input:checked + label::after,
.switch input:checked + label::after {
  left: 50%;
}
form .switch.switch-flip input + label,
form.split .switch.switch-flip input + label,
.switch.switch-flip input + label,
form .switch.switch-flipv input + label,
form.split .switch.switch-flipv input + label,
.switch.switch-flipv input + label {
  width: 6rem;
  transition: all 0.2s ease;
  perspective: 100px;
}
form .switch.switch-flip input + label::after,
form.split .switch.switch-flip input + label::after,
.switch.switch-flip input + label::after,
form .switch.switch-flipv input + label::after,
form.split .switch.switch-flipv input + label::after,
.switch.switch-flipv input + label::after,
form .switch.switch-flip input + label::before,
form.split .switch.switch-flip input + label::before,
.switch.switch-flip input + label::before,
form .switch.switch-flipv input + label::before,
form.split .switch.switch-flipv input + label::before,
.switch.switch-flipv input + label::before {
  display: inline-block;
  transition: all 0.4s ease;
  width: 100%;
  text-align: center;
  position: absolute;
  line-height: 2rem;
  height: 2rem;
  font-size: 1rem;
  color: #fff;
  top: 0;
  left: 0;
  backface-visibility: hidden;
  border-radius: 4px;
}
form .switch.switch-flip input + label::after,
form.split .switch.switch-flip input + label::after,
.switch.switch-flip input + label::after,
form .switch.switch-flipv input + label::after,
form.split .switch.switch-flipv input + label::after,
.switch.switch-flipv input + label::after {
  content: attr(data-switch-on);
  background: #66DD66;
  transform: rotateY(-180deg);
}
form .switch.switch-flip input + label::before,
form.split .switch.switch-flip input + label::before,
.switch.switch-flip input + label::before,
form .switch.switch-flipv input + label::before,
form.split .switch.switch-flipv input + label::before,
.switch.switch-flipv input + label::before {
  background: #DD6666;
  content: attr(data-switch-off);
}
form .switch.switch-flip input + label:active::before,
form.split .switch.switch-flip input + label:active::before,
.switch.switch-flip input + label:active::before,
form .switch.switch-flipv input + label:active::before,
form.split .switch.switch-flipv input + label:active::before,
.switch.switch-flipv input + label:active::before {
  transform: rotateY(-20deg);
}
form .switch.switch-flip input:checked + label::before,
form.split .switch.switch-flip input:checked + label::before,
.switch.switch-flip input:checked + label::before,
form .switch.switch-flipv input:checked + label::before,
form.split .switch.switch-flipv input:checked + label::before,
.switch.switch-flipv input:checked + label::before {
  transform: rotateY(180deg);
}
form .switch.switch-flip input:checked + label::after,
form.split .switch.switch-flip input:checked + label::after,
.switch.switch-flip input:checked + label::after,
form .switch.switch-flipv input:checked + label::after,
form.split .switch.switch-flipv input:checked + label::after,
.switch.switch-flipv input:checked + label::after {
  transform: rotateY(0);
  left: 0;
  background: #66DD66;
}
form .switch.switch-flip input:checked + label:active::after,
form.split .switch.switch-flip input:checked + label:active::after,
.switch.switch-flip input:checked + label:active::after,
form .switch.switch-flipv input:checked + label:active::after,
form.split .switch.switch-flipv input:checked + label:active::after,
.switch.switch-flipv input:checked + label:active::after {
  transform: rotateY(20deg);
}
form .switch.switch-invert-colors input + label::after,
form.split .switch.switch-invert-colors input + label::after,
.switch.switch-invert-colors input + label::after {
  background: #DD6666;
}
form .switch.switch-invert-colors input + label::before,
form.split .switch.switch-invert-colors input + label::before,
.switch.switch-invert-colors input + label::before {
  background: #66DD66;
}
form .switch.switch-invert-colors input:checked + label::after,
form.split .switch.switch-invert-colors input:checked + label::after,
.switch.switch-invert-colors input:checked + label::after {
  background: #DD6666;
}
form .switch.switch-flipv input + label::after,
form.split .switch.switch-flipv input + label::after,
.switch.switch-flipv input + label::after {
  transform: rotateX(-180deg);
}
form .switch.switch-flipv input + label:active::before,
form.split .switch.switch-flipv input + label:active::before,
.switch.switch-flipv input + label:active::before {
  transform: rotateX(-20deg);
}
form .switch.switch-flipv input:checked + label::before,
form.split .switch.switch-flipv input:checked + label::before,
.switch.switch-flipv input:checked + label::before {
  transform: rotateX(180deg);
}
form .switch.switch-flipv input:checked + label::after,
form.split .switch.switch-flipv input:checked + label::after,
.switch.switch-flipv input:checked + label::after {
  transform: rotateX(0);
}
form .switch.switch-flipv input:checked + label:active::after,
form.split .switch.switch-flipv input:checked + label:active::after,
.switch.switch-flipv input:checked + label:active::after {
  transform: rotateX(20deg);
}
form .switch.--small input + label,
form.split .switch.--small input + label,
.switch.--small input + label {
  width: 4rem;
  height: 1.5rem;
}
form .switch.--small input + label::before,
form.split .switch.--small input + label::before,
.switch.--small input + label::before,
form .switch.--small input + label::after,
form.split .switch.--small input + label::after,
.switch.--small input + label::after {
  line-height: 1.5rem;
  height: 1.5rem;
  font-size: 0.8rem;
}
dl dt,
dl dd {
  display: inline;
  vertical-align: middle;
  margin: 0.2rem 0;
}
dl dt {
  display: inline-block;
  width: 7rem;
  font-weight: bold;
}
dl dd::after {
  content: "\A";
  white-space: pre;
}
.ico-warning {
  color: #ff640d;
}
.ib {
  display: inline-block;
}
.ico-button {
  cursor: pointer;
}
.ico-button.good:hover {
  color: #66DD66;
}
.ico-button.bad:hover {
  color: #DD6666;
}
.h2h3margin h2 {
  margin-top: 50px;
}
.h2h3margin h2:first-child {
  margin-top: 0;
}
.h2h3margin h3 {
  margin-top: 35px;
}
.h2h3margin h3:first-child {
  margin-top: 0;
}
form h2 {
  margin-top: 50px;
}
form h2:first-child {
  margin-top: 0;
}
form h3 {
  margin-top: 35px;
}
form h3:first-child {
  margin-top: 0;
}
form fieldset {
  border: 3px dashed #2C3E50;
  margin: 20px 0;
  padding: 30px 10px 10px 10px;
  position: relative;
}
form fieldset legend {
  position: absolute;
  top: 5px;
  left: 10px;
  color: #4D6782;
  font-size: 1.3rem;
  font-weight: bolder;
}
form.full label {
  width: 40%;
  height: 34px;
  line-height: 34px;
  vertical-align: top;
}
form.full input[type=date],
form.full input[type=time],
form.full input[type=text],
form.full input[type=password],
form.full input[type=email],
form.full input[type=number],
form.full textarea,
form.full select {
  width: 60%;
  margin-left: 0;
}
form.full input[type=checkbox] + label,
form.full input[type=radio] + label {
  width: 100%;
}
form.full .with-num label {
  width: 70%;
}
form.full .with-num input[type=number] {
  width: 30%;
}
.w300 {
  width: 300px;
}
.w400 {
  width: 400px;
}
.w500 {
  width: 500px;
}
.w600 {
  width: 600px;
}
.w700 {
  width: 700px;
}
.w30p {
  width: 30%;
}
.w40p {
  width: 40%;
}
.w50p {
  width: 50%;
}
.w60p {
  width: 60%;
}
.w70p {
  width: 70%;
}
.center {
  margin: 0 auto;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.msg-info {
  padding: 10px;
  margin: 20px 0;
  background: #505760;
}
.msg-error {
  padding: 10px;
  margin: 20px 0;
  background: #FF9999;
}
.margin-v-10 {
  margin: 10px 0;
}
.margin-v-20 {
  margin: 20px 0;
}
.margin-v-30 {
  margin: 30px 0;
}
.margin-l-10 {
  margin-left: 10px;
}
.no-margin {
  margin: 0;
}
.no-padding {
  padding: 0;
}
.iceberg {
  background: #F5F5F5;
  color: #333;
  padding: 10px;
  box-shadow: 0 0 20px #000;
}
.iceberg h5 {
  color: #333;
  font-size: 1.1rem;
  text-align: center;
  margin: 10px 0;
}
.single-row input[type=date],
.single-row input[type=time],
.single-row input[type=text],
.single-row input[type=email],
.single-row input[type=password],
.single-row input[type=number],
.single-row textarea,
.single-row select,
.single-row button {
  display: block;
  margin: 10px 0;
  width: 100%;
}
.single-row input[type=date].small,
.single-row input[type=time].small,
.single-row input[type=text].small,
.single-row input[type=email].small,
.single-row input[type=password].small,
.single-row input[type=number].small,
.single-row textarea.small,
.single-row select.small,
.single-row button.small {
  min-width: 60px;
  width: 60px;
  margin: 0;
  display: inline-block;
}
.single-row .inline button,
.single-row .inline .btn,
.single-row .inline input[type=submit] {
  display: inline-block;
  width: auto;
  margin: 0 5px;
}
.single-row .cols2 > label {
  width: 50%;
  height: 34px;
  line-height: 34px;
  vertical-align: top;
}
.single-row .cols2 > span {
  display: inline-block;
  width: 50%;
  height: 34px;
  line-height: 34px;
  vertical-align: top;
}
.single-row .cols2 > span input,
.single-row .cols2 > span select,
.single-row .cols2 > span textarea {
  display: inline-block;
  width: auto;
  margin: 0;
}
.initials {
  background: #333;
  color: #FFF;
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 30px;
  font-weight: normal;
  text-transform: uppercase;
  text-align: center;
  border-radius: 50%;
}
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.4);
  z-index: 1000;
}
.modal {
  display: none;
  overflow: auto;
  position: fixed;
  top: 5%;
  left: 50%;
  max-height: 90%;
  min-width: 300px;
  max-width: 700px;
  padding: 10px;
  background: #F5F5F5;
  color: #111;
  box-shadow: 0 0 10px #171717;
  z-index: 1010;
  border-radius: 2px;
}
.modal.maxw-300 {
  max-width: 300px;
}
.modal.maxw-400 {
  max-width: 400px;
}
.modal.maxw-500 {
  max-width: 500px;
}
.modal.maxw-600 {
  max-width: 600px;
}
.modal.maxw-700 {
  max-width: 700px;
}
.modal.minw-300 {
  min-width: 300px;
}
.modal.minw-400 {
  min-width: 400px;
}
.modal.minw-500 {
  min-width: 500px;
}
.modal.minw-600 {
  min-width: 600px;
}
.modal.minw-700 {
  min-width: 700px;
}
.modal h4 {
  font-size: 1.15rem;
  margin-top: 10px;
  cursor: move;
}
.modal h5 {
  font-size: 1rem;
  margin-bottom: 10px;
}
.modal blockquote {
  margin: 20px 10px 30px 10px;
}
.modal .buttons {
  margin: 30px 0 10px 0;
}
.modal > h5:first-child {
  margin-top: 0;
}
.modal form {
  padding: 0;
}
.modal .action-validate > form {
  width: calc(50% - 2px);
  display: inline-block;
  margin-left: 0;
  margin-right: 4px;
}
.modal .action-validate > form:last-child {
  margin-right: 0;
}
.modal .action-reply > * {
  width: calc(33.333333% - 2px);
  display: inline-block;
  margin-left: 3px;
  text-align: center;
}
.modal .action-reply > *:first-child {
  margin-left: 0;
}
#ui-blocker {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.5);
  z-index: 1000000;
}
#ui-blocker #ui-blocker-text {
  color: #FFF;
  font-weight: bold;
  font-size: 2rem;
  width: 100%;
  text-align: center;
  height: 100px;
  line-height: 100px;
  position: relative;
  top: 30%;
  background: rgba(0, 0, 0, 0.5);
}
.pika-lendar button:hover {
  background-color: transparent;
  color: #111;
}
.tabs > ul {
  margin: 0;
  padding: 0;
}
.tabs > ul li {
  display: inline-block;
  padding: 5px 10px;
  margin: 0 2px;
  height: 29px;
  cursor: pointer;
}
.tabs > ul li.img {
  height: 38px;
}
.tabs > ul li:hover {
  border-bottom: 2px solid #666;
}
.tabs > ul li.selected {
  background: transparent;
  border-bottom: 2px solid #eda618;
}
.tabs > ul li.disabled {
  color: #CCC;
  cursor: default;
}
.tabs > ul li.disabled:hover {
  background: transparent;
  border: none;
}
.tabs .tab {
  display: none;
}
.tabs .tab.selected {
  display: block;
}
#tab-vacation table input[type=number] {
  display: inline-block;
  width: 65px;
  margin: 0;
}
.event-details > div > span {
  display: inline-block;
  width: 100px;
}
.event-details > div > span + b {
  display: inline-block;
  width: calc(100% - 100px);
  vertical-align: top;
}
.comments li {
  margin: 10px 0;
}
.comments li p {
  margin: 2px 0;
}
.tooltipster-sidetip.tooltipster-punk .tooltipster-box {
  background: #F5F5F5;
  box-shadow: 0 0 0 1px #666;
  border-bottom: 1px solid #666;
}
.tooltipster-sidetip.tooltipster-punk .tooltipster-content {
  color: #222;
}
.tooltipster-sidetip.tooltipster-top .tooltipster-arrow {
  bottom: -2px;
}
.tooltipster-sidetip.tooltipster-punk.tooltipster-top .tooltipster-arrow-border {
  border-top-color: #666;
}
.tabs2 {
  margin-bottom: 0;
}
.tabs2 li {
  display: inline-block;
  padding: 0.8rem;
  background: #CFCBC7;
  cursor: pointer;
  vertical-align: bottom;
}
.tabs2 li:hover {
  background: #F5F5F5;
}
.tabs2 li.selected {
  padding: 1rem;
  background: #FFF;
  cursor: default;
  border: 1px solid #999;
  border-bottom: none;
}
.tabs2 + ul {
  margin-top: 0;
  border: 1px solid #999;
}
.tabs2 + ul li {
  display: none;
  padding: 1rem;
}
.tabs2 + ul li:first-child {
  display: block;
}
#ajaxWait {
  display: none;
  position: fixed;
  top: 0;
  z-index: 30000;
  left: 50%;
  width: 200px;
  margin-left: -100px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  background: #33AA33;
  box-shadow: 0 0 6px #444;
  border-radius: 0 0 3px 3px;
  opacity: 0.8;
}

.material-icons-font {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}
@font-face {
  font-family: 'icomoon';
  src: url('font/icomoon.woff?9btq6a') format('woff');
  font-weight: normal;
  font-style: normal;
}
.icomoon {
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  font-size: 22px;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.center-cont,
.cc {
  display: flex;
  align-items: center;
  justify-content: center;
}
#page-install h1 {
  text-align: center;
}

@media print {
  .btn-fullscreen,
  .hide-print {
    display: none !important;
  }
  .excel-container {
    display: block;
    height: auto !important;
    padding: 0 !important;
  }
  table.excel.excel--fixed-header thead,
  table.excel.excel--fixed-header tbody th,
  table.excel.excel--fixed-header thead tr:first-child th:first-child {
    position: static;
    height: auto;
  }
  table.excel.excel--fixed-header tbody th,
  table.excel.excel--fixed-header thead tr:first-child th:first-child {
    display: table-cell;
  }
}
