:root {
	--first-color: #d82f4c;
	--second-color: #0093a8;
	--third-color: #f5ba03;
	--fourth-color: #cacaca;
	--first-grey-color: #454146;
	--second-grey-color: #575757;
	--third-grey-color: #8a888e;
	--button-background-color: #f0f0f0;
	--border-color: #eeeeee;
	--input-background-color: #fefefe;
	--input-border-color: #cdcdcd;
	--font-regular: 'brandon_grotesque_regularRg';
	--font-regular-italic: 'brandon_grotesqueRgIt';
	--font-bold: 'brandon_grotesquebold';
	--font-bold-italic: 'brandon_grotesquebold_italic';
}

/* ---------------------------------- raz ------------------------------------ */
* {
	margin: 0;
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	/*font-size: 100%;*/
	/*font: inherit;*/
	vertical-align: baseline;
}
html, body {
  height: 100%;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	display: table;
	line-height: 1;
	width: 100%;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
}

/* ---------------------------------- bootstrap ------------------------------------ */
.row {
	margin-left: 0;
  margin-right: 0;
}

div.narrow {
  width: 150px;
	text-align: left;
}

.modal-content {
	border-radius: 0;
}

.modal-header {
	padding: 10px 15px;
	border-bottom-color: var(--fourth-color);
}

.modal-header h3 {
	display: inline-block !important;
	margin-bottom: 0 !important;
}

.modal-header h3:hover {
	color: var(--second-color);
	background: url("../../images/icons/fleche_droit_bleu.png") 0 35% no-repeat;
	background-size: 12.5px;
}

.modal-header .close {
	margin: 0;
	width: 15px;
	height: 30px;
	opacity : 1;
	background: url("../../images/icons/erreur_bleu.png") 100% 50% no-repeat;
	background-size: 10px;
}

.modal-header .close:hover {
	opacity : 1;
	background: url("../../images/icons/erreur_rouge.png") 100% 50% no-repeat;
	background-size: 10px;
	border: 0;
}

.modal-header .close span {
	display: none;
}

.modal-body .erreur {
	font-family: var(--font-regular-italic);
  color: var(--first-color);
}

.modal-dialog-centered {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	min-height: calc(100% - (.5rem * 2));
}

.modal-footer {
	padding: 5px 10px;
}

@(min-width: 576px) {
	.modal-dialog-centered {
	    min-height: calc(100% - (1.75rem * 2));
	}
}

.popover {
	box-shadow: 2px 2px 2px rgba(0,0,0,.1);
	border: 1px solid var(--fourth-color);
	border-radius: 0;
}

.popover.top > .arrow {
	border-top-color: var(--fourth-color);
}

.popover.right > .arrow {
	border-right-color: var(--fourth-color);
}

.popover.bottom > .arrow {
	border-bottom-color: var(--fourth-color);
}

.popover.left > .arrow {
	border-left-color: var(--fourth-color);
}

.popover-content,
.popover-body {
	padding: 5px 7px;
	font-size: 12px;
	color: var(--first-grey-color);
}

.popover-content p,
.popover-body p {
	margin-bottom: 0;
	font-size: 12px;
}

a[data-toggle="collapse"] {
	padding-right: 25px !important;
	color: var(--second-color) !important;
	border: 2px solid var(--second-color) !important;
}

a[data-toggle="collapse"]:hover {
	color: #fff !important;
	background-color: var(--second-color) !important;
}

a[data-toggle="collapse"][aria-expanded="false"] {
	background: url("../../images/icons/fleche_droit_bleu.png") 97.5% 50% no-repeat;
	background-size: 12.5px;
}

a[data-toggle="collapse"][aria-expanded="false"]:hover {
	background: url("../../images/icons/fleche_bas_blanc.png") 97.5% 50% no-repeat;
	background-size: 12.5px;
}

a[data-toggle="collapse"][aria-expanded="true"] {
	background: url("../../images/icons/fleche_haut_bleu.png") 97.5% 50% no-repeat;
	background-size: 12.5px;
}

a[data-toggle="collapse"][aria-expanded="true"]:hover {
	background: url("../../images/icons/fleche_haut_blanc.png") 97.5% 50% no-repeat;
	background-size: 12.5px;
}

.card {
	border-radius: 0;
}

form li.card:last-child {
	margin-bottom: 0 !important;
}

.card-columns .card:last-child {
	margin-bottom: 0;
}

.card .card-body {
	padding: 10px;
}

.card .card-body ul.block {
	min-height: 40px;
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1.5px dashed var(--fourth-color);
}

.card .card-body ul.block li:last-child {
	margin-bottom: 0 !important;
}

.card h3.card-title {
	display: block;
	margin-bottom: 10px;
	padding: 0;
	background: none;
	color: var(--first-color);
	text-align: center;
	font-size: 16px;
}

.card h3.card-title.bleu {
	color: var(--second-color);
}

.card a {
	color: var(--second-color);
}

.card a:hover {
	color: var(--first-color);
	text-decoration: none;
}

.card .table {
	border: 1px solid var(--border-color);
}

.card .table th, .card .table td {
	padding: 5px;
	border: 1px solid var(--border-color);
}

.card .table th {
	font-family: var(--font-regular);
	font-size: 14px;
}

.card input[type="text"]{
	width: 100%;
	padding: 2px 6px 0 !important;
	font-size: 14px;
}

.card.full_salle,
.card-body.full_salle{
	background: repeating-linear-gradient(
	  45deg,
	  rgba(0, 0, 0, 0.05),
	  rgba(0, 0, 0, 0.05) 10px,
	  rgba(0, 0, 0, 0.2) 10px,
	  rgba(0, 0, 0, 0.2) 20px
	);
}

.notification {
	overflow: hidden;
	background-clip: padding-box;
	padding: 0;
	font-size: 16px;
}

.notification p {
	margin-bottom: 0;
}

.notification .notification-header {
	display: flex;
	display: : -ms-flexbox;
	-ms-flex-align: center;
	align-items: center;
	background-clip: padding-box;
	border-bottom: 1px solid var(--border-color);
	padding: 10px 10px 8px !important;
	font-family: var(--font-bold);
	font-size: 18px;
	color: var(--first-grey-color);
	text-transform: uppercase;
}

.notification .notification-header .notification-total {
	padding-left: 5px;
	font-family: var(--font-bold-italic);
}

.notification .notification-body {
	padding: 10px;
}

.notification .notification-body p {
	margin-bottom: 2px;
}

.notification .notification-body li {
	margin-bottom: 10px;
}

.notification.info {
	border-color: var(--second-color);
}

.notification.info .notification-header {
	background-color: var(--second-color);
	border-bottom-color: var(--second-color);
	color: #fff;
}

.notification.info .notification-body {
	background-color: rgba(0, 147, 168, 0.5);
}

.notification.urgent {
	border-color: var(--third-color);
}

.notification.urgent .notification-header {
	background-color: var(--third-color);
	border-bottom-color: var(--third-color);
}

.notification.urgent .notification-body {
	background-color: rgba(245, 186, 3, 0.5);
}

.notification.critique {
	border-color: var(--first-color);
}

.notification.critique .notification-header {
	background-color: var(--first-color);
	border-bottom-color: var(--first-color);
	color: #fff;
}

.notification.critique .notification-body {
	background-color: rgba(216, 47, 76, 0.5);
}

.notification.apres {
	border-color: var(--fourth-color);
}

.notification.apres .notification-header {
	background-color: var(--fourth-color);
	border-bottom-color: var(--fourth-color);
}

.notification.apres .notification-body {
	background-color: rgba(202, 202, 202, 0.5);
}

/*-------------------------------------- Utils ---------------------------------------*/

.clear, #clear {
    height: .1px;
    font-size: .1px;
    line-height: .1px;
    clear: both;
}

p {
  	line-height: 18px;
	margin-bottom: 10px;
}

p:last-child {
	margin-bottom: 0;
}

.diff {
	line-height: 1.5 !important;
	word-wrap: break-word;
	max-width: 1px;
}

a {
    text-decoration: none;
    color: var(--first-color);
}

a:hover {
  color: var(--second-color);
  text-decoration: underline;
  text-decoration-style: dotted;
}

a:focus {
	text-decoration: none;
}

.none {
	display: none;
}

body {
	position: relative;
	min-height: 100%;
  font-family: var(--font-regular);
  color: var(--first-grey-color);
  font-size: 17px;
}

h1, h2, h3, h4 {
  font-family: var(--font-bold);
}

h1 {
  color: var(--first-color);
  font-size: 24px;
  text-transform: uppercase;
}

h2 {
  display: table;
  margin: 0 0 20px -40px;
  padding: 11px 10px 10px 30px;
  background-color: var(--first-color);
	font-size: 19px;
  text-transform: uppercase;
  color: #fff;
}

h3 {
	display: table;
  margin-bottom: 10px;
  padding-left: 15px;
	font-size: 18px;
	text-transform: uppercase;
	color: var(--second-color);
	background: url("../../images/icons/fleche_droit_bleu.png") 0 35% no-repeat;
	background-size: 12.5px;
}

h3 a {
	color: var(--second-color);
}

h3:has(> a) {
	color: var(--first-color);
	background: url("../../images/icons/fleche_droit_rouge.png") 0 35% no-repeat;
	background-size: 12.5px;
}

h3:hover a {
	color: var(--first-color);
}

h3[data-toggle="collapse"]:hover {
  color: var(--first-color);
  background: url("../../images/icons/fleche_droit_rouge.png") 0% 35% no-repeat;
	background-size: 12.5px;
}

h3[data-toggle="collapse"][aria-expanded="true"] {
  color: var(--first-color);
  background: url("../../images/icons/fleche_bas_rouge.png") 0% 35% no-repeat;
	background-size: 12.5px;
}

.upper {
  text-transform: uppercase;
}

.point {
  vertical-align: -10%;
}

.strong {
	font-family: var(--font-bold);
}

.italic {
	font-family: var(--font-regular-italic);
}

.upper.italic {
	text-transform: uppercase;
	font-family: var(--font-regular-italic);
}

.strong.italic {
	font-family: var(--font-bold-italic);
}

.centre {
	text-align: center;
}

.important {
  font-family: var(--font-bold);
  text-decoration: underline;
  color: var(--first-color);
}

.bleu {
	color: var(--second-color);
}

.rouge {
	color: var(--first-color);
}

.jaune {
	color: var(--third-color);
}

.code {
	color: var(--third-grey-color);
	font-family: var(--font-regular-italic);
}

div.message {
	margin: 5px 0;
	padding: 2px 5px;
	font-family: var(--font-regular-italic);
	font-size: 15px;
	background-color: #fff;
	border: 1px solid var(--border-color);
	color: var(--first-color);
}

a.inline {
  display: inline-block;
	color: var(--first-color);
}

a.disabled, a.disabled:hover {
  color: var(--fourth-color);
  cursor: not-allowed;
}

button,
a.button {
	display: table;
	margin: 10px 0;
	padding: 8px 10px 8px 10px;
	font-family: var(--font-bold);
	font-size: 16px;
	text-transform: uppercase;
	background-color: var(--button-background-color);
	border: 1px solid var(--fourth-color);
	color: var(--second-grey-color);
	cursor: pointer;
}

button.submit,
a.button.submit {
	padding: 5px 15px;
	font-family: var(--font-bold);
	font-size: 16px;
	text-transform: uppercase;
	background-color: var(--button-background-color);
	color: var(--first-color);
	cursor: pointer;
	border: none;
	line-height: initial;
}

button.submit:hover,
a.button.submit:hover {
	background-color: var(--first-color);
  color: #fff;
  text-decoration: none;
	border: none;
}

a.button.center {
	margin: 10px auto;
	min-width: 200px;
	text-align: center;
}

a.button.info {
  float: right;
  display: block;
  margin: 0 0 0 5px;
  padding: 3px 5px 2px;
}

button:hover,
a.button:hover {
	background-color: var(--first-color);
	border: 1px solid var(--first-color);
	color: #fff;
	text-decoration: none;
}

a.action {
  padding: 4px 10px 3px;
  font-family: var(--font-bold);
  font-size: 14px;
  text-transform: uppercase;
  border: 2px solid var(--first-color);
  background-color: #fff;
  color: var(--first-color);
  cursor: pointer;
  line-height: initial;
}

a.action:hover {
	border: 2px solid var(--first-color);
  background-color: var(--first-color);
  color: #fff;
}

a.button.ajouter {
	margin-bottom: 10px;
	padding: 8px 10px 8px 22px;
	background: url("../../images/icons/ajouter_gris.png") 9px 47% no-repeat;
	background-color: var(--button-background-color);
	background-size: 9px;
}

a.button.ajouter:hover {
	background: url("../../images/icons/ajouter_blanc.png") 9px 47% no-repeat;
	background-size: 9px;
	background-color: var(--first-color);
	border: 1px solid var(--first-color);
	color: #fff;
	text-decoration: none;
}

a.button.retour {
	padding: 8px 10px 8px 22px;
	background: url("../../images/icons/fleche_gauche_gris.png") 9px 49% no-repeat;
	background-size: 9px;
}

a.button.retour:hover {
	background: url("../../images/icons/fleche_gauche_blanc.png") 9px 49% no-repeat;
	background-size: 9px;
	background-color: var(--first-color);
	border: 1px solid var(--first-color);
	color: #fff;
	text-decoration: none;
}

a.button.disabled, a.button.disabled:hover {
	background-color: var(--button-background-color);
	border : 1px solid var(--fourth-color);
  	color: var(--fourth-color);
  	cursor: not-allowed;
	opacity: 0.25;
}

a:not([href]):not([tabindex]) {
	color: var(--first-color);
}

a:not([href]):not([tabindex]):hover {
	color: #fff;
}

ul.liste_boutons {
  text-align: center;
}

ul.liste_boutons > li {
  display: inline-block;
  margin-right: 5px;
	margin-bottom: 0 !important;
	padding: 0;
  vertical-align: middle;
	background: none;
}

ul.liste_boutons > li:last-child {
  margin-right: 0;
	margin-bottom: 0 !important;
}

ul.liste_boutons > li input,
ul.liste_boutons > li a,
ul.liste_boutons > li a.button {
  margin: 0;
}

ul.liste_boutons > li a.button {
	background-color: var(--button-background-color);
}

ul.liste_boutons > li a.button.action {
	padding: 6px 10px 5px;
	background-color: #fff;
}

ul.liste_boutons > li:hover a.button {
	background-color: var(--first-color);
}

.creer {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/ajouter_bulle_bleu.png") 0 no-repeat;
	background-size: 20px;
}

.creer:hover {
	background: url("../../images/icons/ajouter_bulle_rouge.png") 0 no-repeat;
	background-size: 20px;
}

.creer_blanc {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/ajouter_bulle_blanc.png") 0 no-repeat;
	background-size: 24px;
}

.creer_blanc:hover {
	background: url("../../images/icons/ajouter_bulle_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.creer_small {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/ajouter_bleu.png") 0 no-repeat;
	background-size: 20px;
}

.creer_small:hover {
	background: url("../../images/icons/ajouter_rouge.png") 0 no-repeat;
	background-size: 20px;
}

.creer > p,
.creer_blanc > p,
.creer_small > p {
	display: none;
}

.modifier {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/modifier_bulle_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.modifier_blanc {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/modifier_bulle_blanc.png") 0 no-repeat;
	background-size: 24px;
}

.modifier_rouge {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/modifier_bulle_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.modifier:hover,
.modifier_blanc:hover {
	background: url("../../images/icons/modifier_bulle_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.modifier_rouge:hover {
	background: url("../../images/icons/modifier_bulle_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.modifier > p,
.modifier_blanc > p,
.modifier_rouge > p {
	display: none;
}

.modifier.disabled {
	opacity: 0.25;
}

.reinitialiser {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/reinitialiser_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.reinitialiser.disabled {
	opacity: 0.25;
}

.reinitialiser:hover {
	background: url("../../images/icons/reinitialiser_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.reinitialiser.disabled:hover {
	background: url("../../images/icons/reinitialiser_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.reinitialiser > p {
	display: none;
}

.telecharger {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/telecharger_bulle_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.telecharger:hover {
	background: url("../../images/icons/telecharger_bulle_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.telecharger > p {
	display: none;
}

.supprimer {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/supprimer_bulle_bleu.png") 0 no-repeat;
	background-size: 24px;
}

.supprimer_blanc {
	display: block;
	width: 24px;
	height: 24px;
	background: url("../../images/icons/supprimer_bulle_blanc.png") 0 no-repeat;
	background-size: 24px;
}

.supprimer:hover,
.supprimer_blanc:hover {
	background: url("../../images/icons/supprimer_bulle_rouge.png") 0 no-repeat;
	background-size: 24px;
}

.supprimer > p,
.supprimer_blanc > p {
	display: none;
}

.supprimer.disabled {
	opacity: 0.25;
}

.enlever {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/enlever_bleu.png") 0 no-repeat;
	background-size: 20px;
}

.enlever_blanc {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/enlever_blanc.png") 0 no-repeat;
	background-size: 20px;
}

.enlever:hover,
.enlever_blanc:hover {
	background: url("../../images/icons/enlever_rouge.png") 0 no-repeat;
	background-size: 20px;
}

.enlever > p,
.enlever_blanc > p {
	display: none;
}

.interdit {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/interdit_gris.png") 0 no-repeat;
	background-size: 20px;
}

.interdit > p {
	display: none;
}

.valide {
	display: block;
	width: 20px;
	height: 20px;
	background: url("../../images/icons/succes_bleu.png") 0 no-repeat;
	background-size: 20px;
}

.valide > p {
	display: none;
}

.valide:hover {
	background: url("../../images/icons/succes_bleu.png") 0 no-repeat;
	background-size: 20px;
}

.non_valide {
	display: block;
	width: 18px;
	height: 18px;
	background: url("../../images/icons/erreur_rouge.png") 0 no-repeat;
	background-size: 18px;
}

.non_valide > p {
	display: none;
}

.non_valide:hover {
	background: url("../../images/icons/erreur_bleu.png") 0 no-repeat;
	background-size: 18px;
}

.voir_bleu {
	display: block;
	width: 30px;
	height: 16px;
	background: url("../../images/icons/oeil_bleu.png") 50% no-repeat;
	background-size: 30px;
}

.voir_bleu:hover {
	background: url("../../images/icons/oeil_rouge.png") 50% no-repeat;
	background-size: 30px;
}

.voir_bleu > p {
	display: none;
}

.voir_rouge {
	display: block;
	width: 30px;
	height: 19px;
	background: url("../../images/icons/oeil_rouge.png") 50% no-repeat;
	background-size: 33px;
}

.voir_rouge:hover {
	background: url("../../images/icons/oeil_bleu.png") 50% no-repeat;
	background-size: 33px;
}

.voir_rouge > p {
	display: none;
}

.voir_blanc {
	display: block;
	width: 30px;
	height: 16px;
	background: url("../../images/icons/oeil_blanc.png") 50% no-repeat;
	background-size: 30px;
}

.voir_blanc:hover {
	background: url("../../images/icons/oeil_bleu.png") 50% no-repeat;
	background-size: 30px;
}

.voir_blanc > p {
	display: none;
}

.voir_bleu.disabled,
.voir_rouge.disabled,
.voir_blanc.disabled {
	opacity: 0.25;
}

.voir_bleu.disabled:hover {
	background: url("../../images/icons/oeil_bleu.png") 0 no-repeat;
	background-size: 30px;
}

.voir_rouge.disabled:hover {
	background: url("../../images/icons/oeil_rouge.png") 0 no-repeat;
	background-size: 30px;
}

.voir_blanc.disabled:hover {
	background: url("../../images/icons/oeil_blanc.png") 0 no-repeat;
	background-size: 30px;
}

.refus {
	display: block;
	width: 24px;
	height: 18px;
	background: url("../../images/icons/erreur_rouge.png") 50% no-repeat;
	background-size: 22px;
}

.refus:hover {
	background: url("../../images/icons/erreur_rouge.png") 0 no-repeat;
	background-size: 21px;
}

.refus > p {
	display: none;
}

.attente {
	display: block;
	width: 30px;
	height: 26px;
	background: url("../../images/icons/attente1.png") 50% no-repeat;
	background-size: 33px;
}

.attente:hover {
	background: url("../../images/icons/attente1.png") 0 no-repeat;
	background-size: 32px;
}

.attente > p {
	display: none;
}

.alerte {
	display: block;
	width: 30px;
	height: 30px;
	background: url("../../images/icons/notification_rouge.png") 0 no-repeat;
	background-size: 30px;
}

.alerte.disabled {
	opacity: 0.25;
}

.alerte:hover {
	background: url("../../images/icons/notification_bleu.png") 0 no-repeat;
	background-size: 30px;
}

.alerte.disabled:hover {
	background: url("../../images/icons/notification_rouge.png") 0 no-repeat;
	background-size: 30px;
}

.alerte > p {
	display: none;
}

.icon_cloture {
	width: 24px;
	height: 24px;
	vertical-align: middle;
}

.icon {
	width: 18px;
	height: auto;
	vertical-align: middle;
}

/*-------------------------------------- Login As ---------------------------------------*/
#login_as {
	display: block;
	position: fixed;
	width: 100%;
	padding: 8px;
	z-index: 100;
	top: 0;
	left: 0;
	background-color: rgba(245, 186, 3, 0.75);
}

#login_as div:first-of-type {
	display: block;
	float: left;
	width: 90%;
}

#login_as div:first-of-type p {
	padding-top: 5.5px;
}

#login_as div:last-of-type {
	display: block;
	float: right;
	width: 10%;
	font-size: 14px;
}

#login_as div:last-of-type a {
	float: right;
	margin: 0;
	padding: 3px 6px;
	font-size: 14px;
}

/*-------------------------------------- Ariane ---------------------------------------*/

nav#ariane {
  width: 100%;
  font-family: var(--font-regular);
  font-size: 17px;
  color: var(--first-color);
}

nav#ariane ul li {
	display: inline-block;
}

nav#ariane a,
nav#ariane p {
	margin: 0 5px;
}

nav#ariane a.active,
nav#ariane p.active {
  font-family: var(--font-bold);
}

/*-------------------------------------- Plan du site ---------------------------------------*/

ul#plandusite li.level_1 {
	display: table;
	margin-bottom: 10px;
	font-family: var(--font-bold);
	font-size: 18px;
	text-transform: uppercase;

}

ul#plandusite li.level_1 a {
	color: var(--second-color);
}

ul#plandusite li.level_1 > p {
	color: var(--second-grey-color);
}

ul#plandusite li.level_1 > a {
	padding-left: 15px;
	background: url("../../images/icons/fleche_droit_bleu.png") 0 45% no-repeat;
	background-size: 12.5px;
}

ul#plandusite li.level_1 > p {
	padding-left: 15px;
	background: url("../../images/icons/fleche_droit_gris.png") 0 45% no-repeat;
	background-size: 12.5px;
}

ul#plandusite li.level_1 a:hover {
	color: var(--first-color);
	text-decoration: none;
}

ul#plandusite li.level_1 > a:hover {
	background: url("../../images/icons/fleche_droit_rouge.png") 0 45% no-repeat;
	background-size: 12.5px;
	text-decoration: none;
}

ul#plandusite li.level_1 > ul {
	margin-top: 5px;
	padding-left: 20px;
}

ul#plandusite li.level_1 > ul li {
	font-family: var(--font-regular);
	font-size: 17px;
	text-transform: initial;
}

ul#plandusite li.level_1 > ul > li.level_2 > a {
	padding-left: 10px;
	text-transform: uppercase;
	background: url("../../images/icons/fleche_droit_bleu.png") 0px 45% no-repeat;
	background-size: 8px;
}

ul#plandusite li.level_1 > ul > li.level_2 > p {
	padding-left: 10px;
	text-transform: uppercase;
	background: url("../../images/icons/fleche_droit_gris.png") 0px 45% no-repeat;
	background-size: 8px;
}

ul#plandusite li.level_1 > ul > li.level_2 > a:hover {
	text-decoration: none;
	background: url("../../images/icons/fleche_droit_rouge.png") 0px 45% no-repeat;
	background-size: 8px;
}

ul#plandusite li.level_1 > ul > li.level_2 ul {
	margin-top: 5px;
	padding-left: 20px;
}

ul#plandusite li.level_1 > ul > li.level_2 ul li {
	margin-bottom: 5px;
}

ul#plandusite li.level_1 > ul > li.level_2 > ul li a {
	padding-left: 10px;
	background: url("../../images/icons/cercle_bleu.png") 0px 45% no-repeat;
	background-size: 4px;
}

ul#plandusite li.level_1 > ul > li.level_2 > ul li p {
	padding-left: 10px;
	background: url("../../images/icons/cercle_gris.png") 0px 45% no-repeat;
	background-size: 4px;
}

/*-------------------------------------- Messages ---------------------------------------*/

#messages {
	width: 100%;
	margin-bottom: 10px;
	font-family: var(--font-regular-italic);
	font-size: 16px;
	background-color: #fff;
	border: 1px solid var(--border-color);
}

#messages li {
	padding: 4px 5px 3px 5px;
}

#messages li.error {
	padding-left: 25px;
	color: var(--first-color);
	background: url("../../images/icons/erreur_rouge.png") 0.6% 45% no-repeat;
  background-size: 14px;
}

#messages li.error ul li {
	padding-left: 25px;
	background: url("../../images/icons/cercle_rouge.png") 17px 60% no-repeat;
	background-size: 4px;
}

#messages li.success {
	padding-left: 25px;
	font-size: 20px;
	color: var(--second-grey-color);
	border: 1px solid var(--second-grey-color);
	background: url("../../images/icons/succes_gris.png") 0.6% 45% no-repeat;
  background-size: 14px;
	background-color: var(--third-color);
}

#messages.info {
	border: 1px solid var(--second-color);
}

#messages li.info {
	padding-left: 25px;
	font-family: var(--font-regular-italic);
	font-size: 16px;
	color: var(--second-color);
	background: url("../../images/icons/temps_bleu.png") 0.6% 45% no-repeat;
  background-size: 16px;
}

#messages.visiteur {
	width: 98%;
	margin: 0 auto;
}

/*-------------------------------------- Content ---------------------------------------*/

section#content article {
	margin-bottom: 20px;
  padding: 20px 30px;
  background-color: #fff;
  border: 1px solid var(--border-color);
	-moz-box-shadow: 3px 3px 2px 0px #ededed;
	-webkit-box-shadow: 3px 3px 2px 0px #ededed;
	-o-box-shadow: 3px 3px 2px 0px #ededed;
	box-shadow: 3px 3px 2px 0px #ededed;
	filter:progid:DXImageTransform.Microsoft.Shadow(color=#ededed, Direction=134, Strength=2);
}

section#content article:last-child {
	margin-bottom: 0;
}

#container div.clearfix::after {
  content: "";
  clear: both;
  display: table;
}

#container div.clearfix .left {
	float: left;
}

#container div.clearfix .right {
	float: right;
}

section#content article ul.liste > li > a,
section#content article ul.liste > li > p {
	margin-bottom: 2px;
	padding-left: 15px;
	font-family: var(--font-bold);
	text-transform: uppercase;
	background: url("../../images/icons/fleche_droit_bleu.png") 0 45% no-repeat;
	background-size: 12.5px;
	color: var(--second-color);
}

section#content article ul.liste > li > a:hover {
	background: url("../../images/icons/fleche_droit_rouge.png") 0 45% no-repeat;
	background-size: 12.5px;
	color: var(--first-color);
	text-decoration: none;
}

section#content article ul.liste > li > ul > li {
	margin-bottom: 5px;
	padding-left: 15px;
}

section#content article ul.liste > li > ul > li > a {
	padding-left: 10px;
	background: url("../../images/icons/cercle_rouge.png") 0 55% no-repeat;
	background-size: 4px;
}

section#content article ul.liste > li > ul > li > a:hover {
	background: url("../../images/icons/cercle_bleu.png") 0 55% no-repeat;
	background-size: 4px;
}

section#content article ul.liste_item h3 {
	display: table;
  width: 100%;
  margin-bottom: 10px;
  padding: 10px 10px 9px;
  background-color: var(--border-color);
  font-family: var(--font-bold-italic);
	font-size: 18px;
  text-transform: uppercase;
  color: var(--second-color);
}

section#content article ul.liste_item h3[data-toggle="collapse"] {
	padding-left: 24px;
  background: url("../../images/icons/fleche_droit_bleu.png") 8px 46% no-repeat;
  background-size: 12.5px;
  background-color: var(--border-color);
  cursor: pointer;
}

section#content article ul.liste_item h3[data-toggle="collapse"]:hover {
  color: #fff;
  background: url("../../images/icons/fleche_droit_blanc.png") 8px 46% no-repeat;
  background-size: 12.5px;
  background-color: var(--second-color);
}

section#content article ul.liste_item h3[aria-expanded="true"],
section#content article ul.liste_item h3[aria-expanded="true"]:hover {
  background: url("../../images/icons/fleche_bas_blanc.png") 8px 46% no-repeat;
  background-size: 12.5px;
  background-color: var(--second-color);
  color: #fff;
}

section#content article ul.liste_item h3[data-toggle="collapse"]:hover .info,
section#content article ul.liste_item h3[aria-expanded="true"] .info,
section#content article ul.liste_item h3[aria-expanded="true"]:hover .info {
	color: #fff;
}

section#content article ul li {
	color : var(--second-grey-color);
	margin-bottom: 10px;
}

section#content article .info_item {
	margin: 0 auto 15px;
	padding: 10px;
	color: var(--second-grey-color);
	background-color: #f9f9f9;
	border: 1px solid var(--fourth-color);
}

section#content article .info_item.bleu {
	color: var(--second-color);
	background-color: #f6feff;
	border: 1px solid var(--second-color);
}

section#content article .info_item.rouge {
	color: var(--first-color);
	background-color: #fff4f6;
	border: 1px solid var(--first-color);
}

section#content article .info_item.jaune {
	color: var(--third-color);
	background-color: #fffcf3;
	border: 1px solid var(--third-color);
}

section#content article .info_item .info_item_title {
	margin-bottom: 3px;
	font-family: var(--font-bold);
	text-transform: uppercase;
}

section#content article .info_item ul li {
	margin-bottom: 2px;
	padding-left: 15px;
	background: url("../../images/icons/fleche_droit_gris.png") 0 15% no-repeat;
	background-size: 12.5px;
}

section#content article .info_item.bleu ul li {
	margin-bottom: 2px;
	padding-left: 15px;
	background: url("../../images/icons/fleche_droit_bleu.png") 0 15% no-repeat;
	background-size: 12.5px;
	color: var(--second-color);
}

section#content article .info_item.rouge ul li {
	margin-bottom: 2px;
	padding-left: 15px;
	background: url("../../images/icons/fleche_droit_rouge.png") 0 15% no-repeat;
	background-size: 12.5px;
	color: var(--first-color);
}

section#content article ul.bleu li,
section#content article ul li.bleu {
	color : var(--second-color);
	background-image: url("../../images/icons/fleche_droit_bleu.png");
}

section#content article ul.rouge li,
section#content article ul li.rouge {
	color : var(--first-color);
	background-image: url("../../images/icons/fleche_droit_rouge.png");
}

section#content article ul.jaune li,
section#content article ul li.jaune {
	color : var(--third-color);
	background-image: url("../../images/icons/fleche_droit_jaune.png");
}

section#content article .info_item form ul li,
section#content article form .info_item ul li {
	margin-bottom: 0;
	padding-left: 10px;
	background: none;
}

section#content article .info_item ul.liste_item li,
section#content article .info_item form ul li {
	padding: 0 !important;
	background: initial !important;
}

section#content article .info_item form ul li:last-child,
section#content article form .info_item ul li:last-child {
	margin-bottom: 0 !important;
}

section#content article .info_item form input[type="submit"] {
	margin-top: 10px;
}

section#content article form .info_item ul.liste_item li li {
	margin-bottom: 0 !important;
}

section#content article .info_item.rouge ul.liste_item li h3 {
	background: url("../../images/icons/fleche_droit_rouge.png") 8px 46% no-repeat;
	background-color: #fff;
	background-size: 12.5px;
	color: var(--first-color);
}

section#content article .info_item ul.liste_boutons {
	text-align:left;
}

section#content article .info_item ul.liste_boutons li {
	padding-left: 0;
	background: none;
}

/*-------------------------------------- Popup date ---------------------------------------*/
#date_popup {
	display: block;
	position: fixed;
	width: 200px;
	padding: 15px;
	z-index: 100;
	bottom: 0;
	right: 0;
	border: 1px solid var(--third-grey-color);
	background-color: #cdcdcd;
}

#date_popup form {
	margin-bottom: 0;
}

#date_popup form input {
	width: 100%;
}

/*-------------------------------------- Footer ---------------------------------------*/

footer #footer_logos {
  display: block;
  float: left;
  width: 380px;
  height: 48px;
	padding-top: 5px;
}

footer #footer_logos .level_2 li {
	display: inline-block;
	margin-right: 7px;
}

footer #footer_logos .level_2 li:last-child {
	margin-right: 0;
}

footer #footer_logos .level_2 li a {
	display: block;
	width: 100%;
	height: 40px;
}

footer #footer_logos li p {
	display: none;
}

footer #footer_logos .level_2 li.reseau_scpo a {
	//float: left;
	width: 80px;
	margin: 0 5px;
	background: url("../../images/logo_reseau_scpo.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.reseau_scpo a::after {
	content: "";
	position: relative;
	float: right;
  width: 1px;
  height: 30px;
  background-color: var(--second-color);
	top: 8px;
  right: -8px;
}

footer #footer_logos .level_2 li.scpo_aix a {
	width: 40px;
	background: url("../../images/logo_aix.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_lille a {
	width: 25px;
	background: url("../../images/logo_lille.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_lyon a {
	width: 35px;
	background: url("../../images/logo_lyon.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_rennes a {
	width: 25px;
	background: url("../../images/logo_rennes.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_saintgermain a {
	width: 30px;
	background: url("../../images/logo_saintgermain.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_strasbourg a {
	width: 25px;
	background: url("../../images/logo_strasbourg.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_logos .level_2 li.scpo_toulouse a {
	width: 20px;
	background: url("../../images/logo_toulouse.png") 50% no-repeat;
  background-size: 100%;
}

footer #footer_links {
  display: flex;
  float: left;
  height: 100%;
  padding-left: 20px;
  border-left: 1px solid var(--border-color);
  align-items: center;
}

footer #footer_links li {
  display: inline-block;
}

footer #footer_links li a::before {
	content: "";
	position: relative;
	float: left;
	width: 10px;
	height: 10px;
	top: 3px;
  left: -1px;
	background: url("../../images/icons/cercle_rouge.png") 50% 50% no-repeat;
	background-size: 4px;
}

footer #footer_links li:first-child a::before {
	display: none;
}

footer #footer_links li a {
  font-family: var(--font-regular);
  font-size: 16px;
}

footer #footer_links li a.active {
  text-decoration: underline;
	font-family: var(--font-bold);
}

/*--------------------------------- Session security modal ----------------------------------*/
.session_security_modal {
	padding: 20px !important;
	text-align: left !important;
}

.session_security_modal h3 {
	color: var(--first-color);
	background: url("../../images/icons/fleche_droit_rouge.png") 0 35% no-repeat;
	background-size: 12.5px;
}

/*-------------------------------------- Responsive ---------------------------------------*/

@media screen and (max-width: 1200px) {
	header #logo h1 {
		font-size: 20px;
	}

	header #logo p {
		font-size: 17px;
	}

	header #profil {
		width: 195px;
	}

	header #profil > a {
		font-size: 16px;
		padding-left: 25px;
		background-position: 90% 48%;
	  background-size: 22px;
	}

	header #profil > a:hover {
		background-position: 90% 48%;
	  background-size: 22px;
	}
}

@media screen and (max-width: 500px) {
	body {
    font-size: 16px;
  }

	button,
	a.button {
		margin: 5px 0;
		padding: 8px 8px 6px;
		font-size: 15px;
		width: 100%;
	}

	a.button.info {
		width: auto;
	}

	nav#ariane a,
	nav#ariane p {
		font-size: 16px;
	}

	section#content article {
		margin-bottom: 10px;
		padding: 15px;
	}

	section#content article .info_item .info_item_title {
		font-size: 15px;
	}

	ul.liste_boutons > li {
		display: block;
		margin-right: 0;
	}
}
