
@font-face {
	font-family: 'instrument-sans';
	font-weight: normal;
	font-style: normal;
			src: url('../res/typo/instrument-sans/InstrumentSans-Regular.woff2') format('woff2');
}
@font-face {
	font-family: 'instrument-sans';
	font-weight: bold;
	font-style: normal;
			src: url('../res/typo/instrument-sans/InstrumentSans-SemiBold.woff2') format('woff2');
}
@font-face {
	font-family: 'instrument-sans';
	font-weight: normal;
	font-style: italic;
			src: url('../res/typo/instrument-sans/InstrumentSans-Italic.woff2') format('woff2');
}
@font-face {
	font-family: 'instrument-sans';
	font-weight: bold;
	font-style: italic;
			src: url('../res/typo/instrument-sans/InstrumentSans-SemiBoldItalic.woff2') format('woff2');
}

@font-face {
	font-family: 'ikob';
	font-weight: normal;
	font-style: normal;
			src: url('../res/typo/ikob/happy-times-NG_regular_master_web.woff2') format('woff2');
}
@font-face {
	font-family: 'ikob';
	font-weight: bold;
	font-style: normal;
			src: url('../res/typo/ikob/happy-times-NG_bold_master_web.woff2') format('woff2');
}
@font-face {
	font-family: 'ikob';
	font-style: italic;
			src: url('../res/typo/ikob/happy-times-NG_italic_master_web.woff2') format('woff2');
}

/* Grand menu */

#grand-menu menu {
	margin-top: 3.2rem;
}
#grand-menu li {
	font-size: 1.7rem;
}

/* Menu principal */

header.principal div.ecran {
	position: relative;
	padding-top: 2rem;
	padding-bottom: 2rem;
}

header.principal .logo img {
	height: 8.4rem;
}

header.principal section.nom {
	position: absolute;
	left: 12rem;
	top: 2.8rem;
}
header.principal section.nom span.nom {
	font-size: 3.2rem;
	color: #FF3333;
	font-weight: bold;
	text-transform: lowercase;
}
header.principal section.nom span.nom a {
	color: #FF3333;
}
header.principal section.nom span.nom a:hover , header.principal section.nom span.nom a:focus {
	text-decoration: none;
}
header.principal section.nom span.slogan {
	font-size: 1.125rem;
	margin-left: 20px;
	color: #999;
}

header.principal nav {
	position: absolute;
	left: 12rem;
	bottom: 0.8rem;
}
header.principal nav a {
	display: block;
	float: left;
	font-size: 1.7rem;
	line-height: 3.6rem;
	height: 3.6rem;
	color: #66CC00;
	font-weight: normal;
	transition: all ease-out .6s; -moz-transition: all ease-out .6s; -webkit-transition: all ease-out .6s; -o-transition: all ease-out .6s;
}
header.principal nav a:hover , header.principal nav a:focus {
	text-decoration: none;
	color: #111;
	border-color: #111;
}
header.principal nav a + a {
	margin-left: 3.6rem;
}
header.principal nav a.ici {
	color: #111;
}

@media only screen and (max-width: 679px) {
	header.principal section.nom span.slogan {
		display: block;
		margin-left: 0;
	}
	header.principal nav {
		display: none;
	}
}

/* Titre etc. */

.global.special header.general {
	border-bottom: 0;
}
.global.special header.general h1 {
	float: none;
	font-size: 5.2rem;
	line-height: 1.6em;
	font-family: ikob, 'liberation serif', times, 'times new roman', serif;
	font-weight: normal;
	padding: 1.6rem 0;
	letter-spacing: -0.05em;
}

.global.special header.general nav.miettes ~ h1 {
	font-size: 3.2rem;
	clear: left;
	text-align: center;
}
.global.special header.general h2.sous-titre {
	font-size: 1.7rem;
	line-height: 1em;
	float: none;
	clear: left;
	text-align: center;
	font-family: ikob, 'liberation serif', times, 'times new roman', serif;
}

@media only screen and (max-width: 679px) {
	.global.special header.general h1 {
		font-size: 3.2rem;
		line-height: 1.2em;
	}
}

/* Encadré */

.encadre {
	border: none !important;
	padding: 0 0 0 2.4rem !important;
	box-shadow: -0.2rem 0 0 #66CC00; -moz-box-shadow: -0.2rem 0 0 #66CC00; -webkit-box-shadow: -0.2rem 0 0 #66CC00; -o-box-shadow: -0.2rem 0 0 #66CC00;
}

/* Normal */

.normal h1 {
	font-size: 1.125rem;
	margin: 0 !important;
	color: #66CC00;
}
.normal > .encadre > h1:not(.section):before {
	display: inline-block;
	position: static;
	content: ' ';
	width: 2rem;
	border-bottom: 2px solid #66CC00;
	margin-right: 1rem;
}
.normal h2 {
	font-size: 0.975rem;
	margin: 0.6rem 0 1.2rem 1em !important;
	display: list-item;
	list-style: square;
}
.normal p {
	font-size: 0.975rem;
}
.normal ul {
	margin: 1.6em 0 0 0;
	padding: 0;
}
.normal li {
	font-size: 0.975rem;
	line-height: 1.6em;
	margin: 0 0 0 1em;
	padding: 0;
}
.normal ul li {
	list-style: square;
}
.normal li + li {
	margin-top: 1.6em;
}

/* Dépêche */

h1 + article.depeche {
	margin-top: 1.6rem;
}

article.depeche .normal h1:before {
	border: 0;
	width: 0;
	margin: 0;
	display: inline;
}

/* Long texte, etc. */

section.long-texte h1:not(.section),
section.long-texte h2 {
	color: #66CC00;
	font-size: 1.7rem;
	hyphens: none;
}
section.long-texte h1:not(.section):before,
section.long-texte h2:before {
	display: inline-block;
	position: static;
	content: ' ';
	width: 2rem;
	border-bottom: 2px solid #66CC00;
	margin-right: 1rem;
}
section.long-texte p,
section.long-texte li {
	font-size: 1.3rem;
	hyphens: none;
}
section.long-texte ol {
	padding-left: 1.6em;
}
section.long-texte ul > li {
	list-style: square;
}
section.long-texte b,
section.long-texte strong,
.normal b,
.normal strong {
	background: #CCFF66;
}

section.long-texte a[href],
.normal a[href] {
	color: #111;
	text-decoration: solid underline #111 2.4px;
	text-underline-offset: 4px;
}
.normal a[href] {
	text-decoration: solid underline #111 1.2px;
}
section.long-texte a[href]:hover, section.long-texte a[href]:focus,
.normal a[href]:hover , .normal a[href]:focus {
	color: #3399CC;
	text-decoration-color: #3399CC;
}

/* Clients */

h1.section + ul.dim-clients {
	margin-top: 1.6rem;
}
li.dim-client {
	font-size: 0.975rem;
}
li.dim-client.actif {
	font-size: 1.3rem;
}
li.dim-client.actif > .titre {
	font-weight: bold;
}
li.dim-client.actif .url {
	margin-left: .6rem;
	white-space: nowrap;
}
li.dim-client.actif .url .icone {
	margin-right: 6px;
	font-weight: 300;
}
li.dim-projet {
	list-style: square !important;
	font-size: 0.975rem !important;
}

