/*
Theme Name: Halisol
Author: Prezenz
Author URI: http://www.prezenz.com
Description: Halisol theme
Version: 1.0
License: GNU General Public License v3 or later
License URI: http://www.gnu.org/licenses/gpl-3.0.html
*/

@charset "UTF-8";
/* UTF-8 déclaré avant toute chose */

/******************************************************************
 * RÖCSSTI : une base CSS par Nicolas Hoffmann https://rocssti.net/
 * Builder : https://rocssti.net/builder-css
 * inspiré par http://www.knacss.com/
 *
 * RÖCSSTI est sous licence MIT : https://github.com/nico3333fr/ROCSSTI/blob/master/LICENSE
 * 
 * cette CSS est fournie telle quelle, sans aucune garantie d’aucun type, 
 * l’auteur ne saurait être tenu responsable de quoi que ce soit pour 
 * l’utilisation de RÖCSSTI.
 *
 * convention (à adapter si besoin)
 *  .parent
 *  .parent__enfant
 *  .parent--modifieur  
 * 
 * RTL = Right To Left => 
 * pour adapter un site dans une langue qui se lit de droite à gauche
 * prévu surtout pour sites multilingues avec LTR et RTL
 *
 * 
 * résumé
 * 01 -- reset
 * 02 -- ainsi font font font + structure Hx
 * 03 -- classes utilitaires + fix typos + styles "balises fixes"
 * 04 -- liens + icônes
 * 05 -- layout et modules
 * 06 -- structure (page / skip links / header / main content / footer)
 * 07 -- forms
 * 08 -- dans le contenu
 * 09 -- breakpoints mineurs entre desktop et tablettes
 * 10 -- homo tablettes - breakpoint majeur
 * 11 -- breakpoints mineurs entre tablettes et mobile
 * 12 -- mobile - breakpoint majeur
 * 13 -- breakpoints mineurs tout petit mobile
 * 14 -- print
 * 15 -- fix viewport 
 * 16 -- règles d’état
 * 17 -- bonus : Fixes IE
 */




/*
 *****************************************************************
 * 1 -- reset
 *****************************************************************
 */

/* spécial HTML 5 */
article, aside, datagrid, datalist, details, dialog, figure, footer, header, main, menu, nav, section { display: block; }
audio, canvas, progress, video { display: inline-block; }
abbr, eventsource, mark, meter, time, output, bb { display: inline; }

/* à commenter/fallback si vous vous souciez d’IE<8 */
html { box-sizing: border-box; }
*, *:before, *:after {
  box-sizing: inherit;
}

/* reset minimum */
html, body, blockquote, ul, ol, form, button { margin: 0; padding: 0; }
button { border: 0; }
p, ul, ol, dl, blockquote, pre, td, th, label, textarea {
  font-size: 1em; /* equiv 14px */
  line-height: 1.5;
  margin: 1.5em 0;
}

/* reset buttons, bien les styler ensuite dans les forms */
input, select, textarea, optgroup, button {
  background: transparent;
  border: 0;
  font: inherit;
  /* -webkit-appearance: none; */
}

/* fix display img/iframe */
img,
iframe { vertical-align: middle; }

ul, ol { padding-left: 2em; }

.unstyled {
  padding-left: 0;
  list-style-type: none;
}

/* RTL */
[dir="rtl"] ul, 
[dir="rtl"] ol { 
  padding-left: 0; 
  padding-right: 2em;
}
[dir="rtl"] .unstyled {
  padding-right: 0;
}


/* la base correspond à 10px */
html { 
  font-size: 62.5%;
  /* IE9-IE11 math fixing. Voir https://connect.microsoft.com/IE/feedback/details/816709/ */
  /* Merci à @guardian, @victorbritopro, @eQRoeil & Knacss */
  font-size: calc(1em * 0.625);
  height: 100vh;
}
body {
  background: #fff;
  color: #808080;
  font-family: Arial, sans-serif;
  font-family:'Cresta W05 Regular';
  font-size: 1.5em; /* taille de base équiv à 14px */
  line-height: 1.5; /* à corriger si besoin est */
  min-height: 100vh;
}

.blue {
	color: #0055B1;
}

.bg-whitesmoke {
	/*border: 2px solid #BAD0E9;*/
	background-color: #E5E5E5;
	padding-left: 1em;
	padding-right: 1em;
	padding-top: 0;
	padding-bottom: 0;
	margin: 0;
}

/*
 *****************************************************************
 * 02 -- ainsi font font font + structure Hx
 *****************************************************************
 */ 

/* calculées via https://rocssti.net/builder-css
 * basé sur http://soqr.fr/vertical-rhythm/ merci @goetter & @eQRoeil */

h1,
.h1 {
  display: block;
  font-family:'Cresta W05 Bold';
  font-weight: normal;
  font-size: 50px; 
  line-height: 1.2;
  margin: 0 0 .5em 0;
}
h2,
.h2 {
  display: block;
  font-family:'Cresta W05 Bold';
  font-weight: normal;
  font-size: 1.71429em; /* equiv 24px */
  line-height: 1.2;
  margin: 0 0 1em 0;
}
h3,
.h3 {
  display: block;
  font-family:'Cresta W05 Bold';
  font-size: 1.57143em;  /* equiv 22px */
  line-height: 1.2;
  margin: 0 0 1em 0;
}
h4,
.h4 {
  display: block;
  font-size: 1.42857em; /* equiv 20px */
  line-height: 1.2;
  margin: 0 0 1em 0;
}
h5,
.h5 {
  display: block;
  font-size: 1.28571em;  /* equiv 18px */
  line-height: 1.2;
  margin: 0 0 1em 0;
}
h6,
.h6 {
  display: block;
  font-size: 1.14286em;  /* equiv 16px */
  line-height: 1.2;
  margin: 0 0 1.3125em 0;
}

b, strong {
  font-family:'Cresta W05 Bold';
}

.uppercase {
  text-transform: uppercase;
}

/* autres classes utiles */
.smaller {
  font-size: .71429em; /* equiv 10px */
  line-height: 2.1;
  margin: 2.1em 0;
}
.small {
  font-size: .85714em; /* equiv 12px */
  line-height: 1.75;
  margin: 1.75em 0;
}
.big {
  font-size: 1.14286em; /* equiv 16px */
  line-height: 1.3125;
  margin: 1.3125em 0;
}
.bigger {
  font-size: 1.28571em; /* equiv 18px */
  line-height: 1.16667;
  margin: 1.16667em 0;
}
.biggest {
  font-size: 1.42857em; /* equiv 20px */
  line-height: 1.05;
  margin: 1.05em 0;
}

p.to-justify-text, .justify {
    text-align: justify;
}


/*
 *****************************************************************
 * 03 -- classes utilitaires + fix typos + styles "balises fixes"
 *****************************************************************
 */

.noborder,
iframe,
dialog { border: 0; }

/*
 * repris de http://tinytypo.tetue.net/ de @tetue
 * tuné avec l’aide de http://www.nicolas-hoffmann.net/utilitaires/codes-hexas-ascii-unicode-utf8-caracteres-usuels.php
 *
 * voir https://en.wikipedia.org/wiki/Quotation_mark#Summary_table pour les références
 */
q {
  quotes: "\201C" "\201D" "\2018" "\2019";
}
:lang(fr) > q {
  quotes: "\00AB\A0" "\A0\00BB" "\201C" "\201D" "\2018" "\2019";
}
:lang(en) > q {
  quotes: "\201C" "\201D" "\2018" "\2019";
}
:lang(es) > q {
  quotes: "\00AB" "\00BB" "\201C" "\201D";
}
:lang(it) > q {
  quotes: "\00AB\A0" "\A0\00BB" "\201C" "\201D";
}
:lang(de) > q {
  quotes: "\201e" "\201c" "\201a" "\2018";
}
q:before {
  content: open-quote;
}
q:after {
  content: close-quote;
}

/* éviter interlignage disgracieux */
sup,
sub {
  vertical-align: 0;
  position: relative;
}
sup {
  bottom: 1ex;
}
sub {
  top: .5ex;
}

/* éviter marges supplémentaires sur éléments imbriqués */
li p,
li ul {
  margin-bottom: 0;
  margin-top: 0;
}
/* Vous ne passerez PAS (Gandalf) */
/*textarea,
table,
td,
th,
code,
pre,
samp,
div,
p,*/
.cut {
  word-wrap: break-word;
}
@supports (-webkit-hyphens: auto) or (-ms-hyphens: auto) or (hyphens: auto) {
  /*textarea,
  table,
  td,
  th,
  code,
  pre,
  samp,
  div,
  p,*/
  .cut {
    word-wrap: normal;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
  }
}
/* pour supprimer la césure si besoin */
.nocut {
  word-wrap: normal;
}
@supports (-webkit-hyphens: auto) or (-ms-hyphens: auto) or (hyphens: auto) {
  .nocut {
    -webkit-hyphens: none;
    -ms-hyphens: none;
    hyphens: none;
  }
}

code,
pre,
samp {
  white-space: pre-wrap;
}
code {
  line-height: 1;
}
kbd {
  border: solid 1px;
  border-top-left-radius: .5em;
  border-top-right-radius: .5em;
  padding: 0 .25em;
}
table {
  margin-bottom: 1.5em;
  table-layout: fixed;
}
/* j’y tiens, les abbr c’est bon pour la planète */
/* seuls ceux ayant un title sont signalés */
abbr[title] {
  border-bottom: dotted 1px; 
  cursor: help;
  text-decoration: none;
  /* couleur héritée du texte */
} 

/* alignements de textes */
.alignright  { text-align: right; }
.aligncenter { text-align: center; }
.alignleft   { text-align: left; }

/* RTL */
[dir="rtl"] .alignright  { text-align: left; }
[dir="rtl"] .alignleft   { text-align: right; }





/*
 *****************************************************************
 * 04 -- liens + icônes
 *****************************************************************
 */

/* Liens */
a {
  color: #2573be;
  cursor: pointer;
  text-decoration: none;
}
/* penser au focus */
a:focus,
a:hover,
a:active {
  color: #000;
}
/* éviter la bordure sur une image comprise dans un lien + fix bordure image IE */
a:link img,
a:visited img, 
img {
  border-style: none;
}

.nodecoration {
  text-decoration: none;
}

/* liens avec icônes, on peut utiliser les DATA-URI */

/* pour signaler liens externes */
/*a[href^="http://"],
a[href^="https://"] {

}*/
/* si URL complète sur un lien interne, virer signalement liens externes */
/*a[href^="http://www.mondomaine.com"] {

}*/
/* contact, liens mailto */
/*.mail,
a[href^="mailto:"] {

}*/
/* dont l’URL se termine par .pdf ou ce que vous voulez comme extension */
/*a[href$=".pdf"] {

}*/

/* facto icons */
/*[class*=icon-30] {
display: inline-block;
width: 30px;
height: 30px;
}*/





/*
 *****************************************************************
 * 05 -- layout et modules
 *****************************************************************
 */

/**
 * layout
 */


/* ça dépend, ça dépasse */
img,
table,
td,
blockquote,
code,
pre,
textarea,
input,
svg {
  height: auto;
  max-width: 100%;
}
/* pas de reset sur embed, object et video, ça fait foirer certains players */

/* utile pour gérer les floattants */
/* contient des floats */
.mod { 
  overflow: auto;
}
.mod--hidden,
.no-scroll { 
  overflow: hidden;
}

/* quelques floattants */
.left {
  float: left;
}
.right {
  float: right;
}


/* clearer les floats */
.clear {
  clear: both;
}
/*
.clearleft {
  clear: left;
}
.clearright {
  clear: right;
}
.clearhidden {
  clear: both;
  margin: 0;
  padding: 0;
  visibility: hidden;
}
.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}
*/

/* RTL */
[dir="rtl"] .left {
  float: right;
}
[dir="rtl"] .right {
  float: left;
}

/*[dir="rtl"] .clearleft {
  clear: right;
}
[dir="rtl"] .clearright {
  clear: left;
}*/


/* gouttière */
.gut {
  height: 1px;
}

/* gestion du table-design en CSS */
.row {
  display: table;
  table-layout: fixed;
}
.inline-row {
  display: inline-table;
  table-layout: fixed;
}
.line {
  display: table-row;
}
.col {
  display: table-cell;
  vertical-align: top;
}
.col-noalign {
  display: table-cell;
}

/* alignements */
.aligntop    { vertical-align: top; }
.alignbottom { vertical-align: bottom; }
.alignmiddle { vertical-align: middle; }

/* block */
.bl {
  display: block;
}

/* inline-block, utile pour les grilles et pas seulement */
.inbl,
.grid {
  display: inline-block;
}

/* grid = élément d’une inline-grid */
.grid {
  vertical-align: top;
}

/* pour relativiser */
.relative {
  position: relative;
}

/* bloc centré */
.center {
  margin-left: auto;
  margin-right: auto;
}

/* activation de l’accélération matérielle */
.hardware-accelerated {
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
  transform: translateZ(0);
}


/* largeurs de blocks */
.w1   { width: 1%; }
.w2   { width: 2%; }
.w3   { width: 3%; }
.w4   { width: 4%; }
.w5   { width: 5%; }
.w10  { width: 10%; }
.w20  { width: 20%; }
.w25  { width: 25%; }
.w30  { width: 30%; }
.w33  { width: 33.333%; }
.w40  { width: 40%; }
.w45  { width: 45%; }
.w49  { width: 49%; }
.w48  { width: 48%; }
.w50  { width: 50%; }
.w60  { width: 60%; }
.w66  { width: 66.666%; }
.w70  { width: 70%; }
.w75  { width: 75%; }
.w80  { width: 80%; }
.w90  { width: 90%; }
.w100 { width: 100%; }

/* ici ajouter les largeurs en em */
/*.w960e { width: 60em; }*/

/* ici ajouter les largeurs en pixels */
.w160p { width: 160px; }

/* ici ajouter les largeurs max en em */
/*.mw960e { max-width: 60em; }*/

/* ici ajouter les largeurs max en pixels */
/*.mw960p { max-width: 960px; }*/

/* margins */
.mt0 { margin-top: 0; }
.mt1 { margin-top: 1em; }
.mt2 { margin-top: 2em; }
.mr0 { margin-right: 0; }
.mr1 { margin-right: 1em; }
.mr2 { margin-right: 2em; }
.mb0 { margin-bottom: 0; }
.mb1 { margin-bottom: 1em; }
.mb2 { margin-bottom: 2em; }
.ml0 { margin-left: 0; }
.ml1 { margin-left: 1em; }
.ml2 { margin-left: 2em; }
.m0  { margin: 0; }
.m1  { margin: 1em; }
.m2  { margin: 2em; }

.mtauto { margin-top: auto; }
.mrauto { margin-right: auto; }
.mbauto { margin-bottom: auto; }
.mlauto { margin-left: auto; }
.mauto  { margin: auto; }

/* RTL = attention, utiliser avec précaution */
[dir="rtl"] .mr0 { margin-left: 0; }
[dir="rtl"] .mr1 { margin-right: inherit; margin-left: 1em; }
[dir="rtl"] .mr2 { margin-right: inherit; margin-left: 2em; }
[dir="rtl"] .ml0 { margin-right: 0; }
[dir="rtl"] .ml1 { margin-left: inherit; margin-right: 1em; }
[dir="rtl"] .ml2 { margin-left: inherit; margin-right: 2em; }

/* paddings */
.pt0 { padding-top: 0; }
.pt0-5 { padding-top: .5em; }
.pt1 { padding-top: 1em; }
.pt2 { padding-top: 2em; }
.pr0 { padding-right: 0; }
.pr1 { padding-right: 1em; }
.pr2 { padding-right: 2em; }
.pb0 { padding-bottom: 0; }
.pb1 { padding-bottom: 1em; }
.pb2 { padding-bottom: 2em; }
.pl0 { padding-left: 0; }
.pl1 { padding-left: 1em; }
.pl2 { padding-left: 2em; }
.p0  { padding: 0; }
.p1  { padding: 1em; }
.p2  { padding: 2em; }

/* RTL = attention, utiliser avec précaution */
[dir="rtl"] .pr0 { padding-left: 0; }
[dir="rtl"] .pr1 { padding-right: 0; padding-left: 1em; }
[dir="rtl"] .pr2 { padding-right: 0; padding-left: 2em; }
[dir="rtl"] .pl0 { padding-right: 0; }
[dir="rtl"] .pl1 { padding-left: 0; padding-right: 1em; }
[dir="rtl"] .pl2 { padding-left: 0; padding-right: 2em; }

/* spécial hr de 1px de haut */
hr {
  background-color: #000;
  border: 0;
  color: #000;
  height: 1px;
  margin: 0 0 1em;
  padding: 0;
}

/* pour cacher du texte de manière accessible… toussââââ */
.invisible {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.nonvisible { visibility: hidden; }

.hidden, [hidden] { display: none; } /* caché partout */
.nodesktop { display: none; } /* caché sur desktop */
/*.noprint   {} /* caché sur print */
/*.notablet  {} /* caché sur tablettes */
/*.nomobile  {} /* caché sur mobile */


/**
 * modules
 */

p, ul, ol, dl, blockquote, pre, td, th, label, textarea {
	margin: 0 0 1em 0;
}

.hvr-grow, .menu-submenustrategy-en-container .menu-item, .menu-submenustrategy-fr-container .menu-item {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-grow:hover, .hvr-grow:focus, .hvr-grow:active, .menu-submenustrategy-en-container .menu-item:hover, .menu-submenustrategy-fr-container .menu-item:hover {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.animate-reveal {
  opacity: 0;
  -webkit-animation: reveal 1s cubic-bezier(0, 1, 0.5, 1) 1 normal forwards;
     -moz-animation: reveal 1s ease-in 1 normal forwards;
       -o-animation: reveal 1s cubic-bezier(0, 1, 0.5, 1) 1 normal forwards;
          animation: reveal 1s cubic-bezier(0, 1, 0.5, 1) 1 normal forwards;
}

.animate-first {
  -webkit-animation-delay: 0;
     -moz-animation-delay: 0;
       -o-animation-delay: 0;
          animation-delay: 0;
}

@-webkit-keyframes reveal {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
       -moz-transform: translateX(100%);
         -o-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
         -o-transform: translateX(0);
            transform: translateX(0);
  }
}

@-moz-keyframes reveal {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
       -moz-transform: translateX(100%);
         -o-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
         -o-transform: translateX(0);
            transform: translateX(0);
  }
}

@-o-keyframes reveal {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
       -moz-transform: translateX(100%);
         -o-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
         -o-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes reveal {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
       -moz-transform: translateX(100%);
         -o-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
         -o-transform: translateX(0);
            transform: translateX(0);
  }
}

/*
 *****************************************************************
 * 06 -- structure globale 
 *      (page / skip links / header / contenu principal / footer)
 *****************************************************************
 */

/* === page === */
body::before {
  content: 'desktop';
  display: none;
}

.pagecontent {
  margin: 0 auto;
  position: relative;
  min-height:100vh;
}

.pageback {
	background-image: url(images/backgrounds/home-desktop@2x.jpg);
	background-repeat: no-repeat;
	background-position: right top;
	background-size: contain;
	left:0;
	right: 0;
	top:120px;
	bottom: 0;
	position: fixed;
}

.page-id-62 .pageback,
.page-id-7 .pageback ,
.page-id-216 .pageback,
.page-id-209 .pageback {
	background-image: url(images/backgrounds/home-desktop@2x.jpg);
	background-size: contain;
}

.page-id-64 .pageback,
.page-id-9 .pageback {
	background-image: url(images/backgrounds/groupe-desktop@2x.jpg);
	background-size: contain;
}

.page-id-14 .pageback,
.page-id-67 .pageback,
.page-id-369 .pageback,
.page-id-367 .pageback,
.page-id-365 .pageback,
.page-id-346 .pageback {
	background-image: url(images/backgrounds/strategie-desktop@2x.jpg);
	background-size: contain;
}

.page-id-71 .pageback,
.page-id-16 .pageback,
.page-id-524 .pageback {
	background-image: url(images/backgrounds/equipe-desktop@2x.jpg);
	background-size: contain;
}

.page-id-339 .pageback {
	background-image: url(images/backgrounds/strategie-desktop@2x.jpg);
	background-size: contain;
}

.page-id-342 .pageback {
	background-image: url(images/backgrounds/strategie-desktop@2x.jpg);
	background-size: contain;
}


.blog .pageback {
	background-image: url(images/backgrounds/actualites-desktop@2x.jpg);
	background-size: contain;
}

.page-id-60 .pageback,
.page-id-20 .pageback {
	background-image: url(images/backgrounds/contact-desktop@2x.jpg);
	background-size: contain;
}

/* === skip links = liens d’évitement === */
.skip {
	/* v2 */
	position: absolute;
	left: 20em;
}
/* skip__link = un lien d’évitement  */
/* idéalement mettez-les visibles pas uniquement au focus */
.skip__link {
	color: #fff;
	/* v2 */
	color: #064178;
}
/* sinon pensez à les rendre visibles au focus */
.skip__link:focus,
.skip__link:hover,
.skip__link:active {
	color: #333;
}

.container {
	min-height: calc(100vh);
	height: calc(100vh);
	padding: 120px 0 0 0;
}

.content {
    padding: 0 4em 0 8em;
	min-height: 100%;
	height: 100%;
	background: rgba(255,255,255,.8);
}

.sidebar {
	min-height: 100%;
	height: 100%;
	position: fixed;
    min-height: 100%;
    height: 100%;
    position: relative;
}

.team {
	position: fixed;
    /*width: 75%;
	background: rgba(255,255,255,.85);
	height: auto;
    top: 100px;
	padding: 2em;
	border-left:1px solid #808080;
	text-align: center;
    font-size: 1em;
    right: 0;
    border: 0 none;
	z-index: 3000;
	overflow: auto;
	border-radius: 50px 0px 0px 50px;*/
	top:120px;
	width:33%;
	background: #bfd4eb;
	padding: 2em;
	text-align: center;
    right: 0;
    height: 100vh;
    font-size: 1em;
}

.team .bl {
	max-width: 640px;
}

.grid-team {
	width: 30%;
	text-align: center;
	margin: 0 0 2em 0;
}

.grid-team--sep {
	width: 3%;
}

.grid-team--title {
	font-weight: bold;
	color: #808080;
}

.wp-block-image figcaption {
	font-size: 1em;
	font-weight: normal;
	font-family: 'Cresta W05 Regular';
}

.wp-block-image figcaption strong {
	font-family: 'Cresta W05 Regular';
}

.block-person {
	background: #e3e3e3;
	padding: 2em;
}

.grid-team--role {
	font-weight: normal;
}

.grid-team--picture {
	border-radius: 50%;
	width: 75%;
    max-width: 280px;
	margin: 0 0 1em 0;
}

.team--picture {
	border-radius: 50%;
    max-width: 200px;
	margin: 0 0 1em 0;
}

.picture-radius {
	margin: 0 auto 1em auto;
	text-align: center;
}

.picture-radius img {
	border-radius: 50%;
    max-width: 280px;
}

.strategy {
	position: fixed;
	min-height: 100%;
	height: 100%;
    width: 33.5%;
	padding: 2em;
	background: #fff;
	border-left:1px solid #808080;
	text-align: left;
    font-size: 1em;
    right: 0;
    border: 0 none;
	z-index: 3000;
	
	
}

.grid-strategy {
	width: 24%;
	text-align: center;
	position: relative;
}

.grid-strategy--sep {
	width: 1%;
}

.grid-strategy--title {
	font-weight: bold;
	color: #fff;
	position: absolute;
	top:calc(50% - 20px);
	text-align: center;
	display: block;
	left: 0;
	right: 0;
}

.grid-strategy--picture {
	border-radius: 50%;
	width: 100%;
    max-width: 175px;
	margin: 0 0 1em 0;
}

.entry-content, .entry-title {
	max-width: 640px;
}

/* === header === */
.header {
    padding: 1em 0 0 0;
    /* v2 */
    background: /*#064178*/ #0055B1;
    padding: 1em 1em 1em 8em;
    margin: 0;
    position: fixed;
    z-index: 100;
}
.logo {

}
.navigation-container {
}

.menu { margin: 0; padding: 0; position: absolute; top:.5em; right:8.5em; }

.menu-item {
	display: inline-block;
}
.menu-item a {
	text-transform: uppercase;
	color: #fff;
	padding: 0 1em;
}
.menu-item a:hover, a[aria-current=page] {
  color: rgba(255,255,255,.75)
}

.menu-item-has-children:after {
	content: "";
	display: inline-block;
	background: url(images/icons/ssmenu.svg) no-repeat center center;
	background-size: contain;
	width: 12px;
	height: 12px;
	position: relative;
	left:-5px;
}

.sub-menu {
	display: none;
	position: absolute;
	max-width: 300px;
	background: /*rgba(0,85,177,.95)*/ #bfd4eb;
	padding: 1em;
	text-align: left;
}

.sub-menu .menu-item  {
	display: block;
}

.sub-menu .menu-item a {
	color: /*rgba(255,255,255,.75)*/#064178;
	text-transform: none;
	display: block;
	padding: .3em 0;
}

.sub-menu .menu-item a:hover, .sub-menu .menu-item a[aria-current=page] {
	color: #fff;
}

.menu-item:hover .sub-menu {
	display: block;
}

.widget_icl_lang_sel_widget {
	position: absolute;
	top: 0;
	right: 0;
	border-left : 1px solid #fff;
}

.widget_icl_lang_sel_widget ul { margin: 0; padding: 0 ;}

.widget_icl_lang_sel_widget .wpml-ls-link {
	color: #fff;
	display: inline-block;
	padding: 0 1em;
}

.widget_icl_lang_sel_widget .wpml-ls-current-language {
	font-weight: bold;
}

.wpml-ls-legacy-list-horizontal a span {
	vertical-align: inherit;
}

/* === contenu principal === */
.main {
  outline: 0;
  padding: 4em 0 6em 0;
  text-align: justify;
  position: relative;
}

.main h1 { text-align: left; }

.home-columns {
	margin-top: 5em;
}

.home-columns > .wp-block-column:first-child p.intro {
    width: 75%;
}
.block60 .wp-block-column:first-child {
	flex-basis: 60%;
}
.block50 .wp-block-column:first-child {
	flex-basis: 50%;
}
.block30 .wp-block-column:first-child {
	flex-basis: 30%;
}

.block20 .wp-block-column:first-child {
	flex-basis: 20%;
}

.wp-block-column {
	padding-right:2em;
}

.wp-block-column_last-child {
	padding-right:0;
}

.intro {
	font-size:1.2em;
	font-weight: bold;
	padding-top:0;
}

.column {
	column-count: 3;
}

.column p:first-child {
	padding-top: 0;
	margin-top: 0;
}

.world:before {
	content: "";
	display: inline-block;
    width: 80px;
    height: 80px;
	background: url(images/icons/blurb-world.svg) no-repeat center center;
	background-size: contain;
	float: left;
	margin: 0 1em 0 0;
}

.link:before {
	content: "";
	display: inline-block;
    width: 80px;
    height: 80px;
	background: url(images/icons/blurb-link.svg) no-repeat center center;
	background-size: contain;
	float: left;
	margin: 0 1em 0 0;
}

.collaboration:before {
	content: "";
	display: inline-block;
    width: 80px;
    height: 80px;
	background: url(images/icons/blurb-collaboration.svg) no-repeat center center;
	background-size: contain;
	float: left;
	margin: 0 1em 0 0;
}

.wp-block-columns {
    margin: 2em 0 0 0;
    
  text-align: left;
}

.wp-block-columns-alignedmiddle {
	align-items: center
}

.wp-block-columns li {
	list-style-image: url(images/icons/icon20-checked.svg);
}

.main a[href^="mailto:"]:before {
	content: "";
	display: inline-block;
	width: 42px;
	height: 42px;
	background: url(images/icons/icon42-mail.svg) no-repeat bottom center;
	background-size: contain;
	float: left;
	margin: 0 .5em 0 0;
}

.main a[href^="tel:"]:before {
	content: "";
	display: inline-block;
	width: 42px;
	height: 42px;
	background: url(images/icons/icon42-phone.svg) no-repeat bottom center;
	background-size: contain;
	float: left;
	margin: 0 .5em 0 0;
}

.main .location:before {
	content: "";
	display: inline-block;
	width: 42px;
	height: 42px;
	background: url(images/icons/icon42-location.svg) no-repeat bottom center;
	background-size: contain;
	float: left;
	margin: 0 .5em 0 0;
}

.menu-submenustrategy-en-container .menu, .menu-submenustrategy-fr-container .menu {
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
	display: block;
	position: relative;
	top:0;
	right: 0;
}

.menu-submenustrategy-en-container .menu-item, .menu-submenustrategy-fr-container .menu-item {
	margin: 0;
	padding: 0;
	list-style: none;
	width: 175px;
	height: 175px;
	display: inline-block;
	background: url(images/rond.svg) no-repeat center top;
	background-size: contain;
	position: relative;
	padding: 0;
	text-align: center;
	margin: 1em;
	font-size: 14px;
}

.menu-submenustrategy-en-container .menu-item a, .menu-submenustrategy-fr-container .menu-item a {
	color: #fff;
	text-transform: none;
	text-align: center;
	display: inline-block;
	display: flex;
    justify-content: center;
    align-items: center;  
	position: absolute;
	top:0;
	left:0;
	right:0;
	bottom: 0;
	padding: 0 1em 0 1em;
	height: 100%;
}

/* === footer === */
.footer {
	position: absolute;
	bottom:0;
    /* v2 */
    background: #0055B1;
	color: #fff;	
	padding: 1em 1em 1em 8em;
	font-size: 0.85em;
}

.footer a {
	color: #fff;
}

.footer a:hover {
	text-decoration: underline;
}

.footer a[href^="mailto:"]:before {
	content: "";
	display: inline-block;
	width: 12px;
	height: 12px;
	background: url(images/icons/icon12-mail.svg) no-repeat bottom center;
	background-size: contain;
	margin: 0 .5em 0 0;
}

.footer a[href^="tel:"]:before {
	content: "";
	display: inline-block;
	width: 12px;
	height: 12px;
	background: url(images/icons/icon12-phone.svg) no-repeat bottom center;
	background-size: contain;
	margin: 0 .5em 0 0;
}

/* needed for old browsers */
dialog {
  display: block;
}
/* removes scroll when modal is opened */
.no-scroll {
  overflow: hidden;
}
/* overlay covers everything */
.simple-modal-overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background: #fff;
  opacity: .8;
  z-index: 666; 
  cursor: pointer;
}
/* modal */
.simple-modal {
  position: fixed;
  left: 15%;
  top: 5%;
  width: 70%;
  max-height: 98vh;
  right: auto;
  border: 2px solid #000; 
  background: #fff;
  z-index: 667;
  padding: 2em;
  overflow: auto;
}
.simple-modal-close {
  float: right;
  background: #000;
  border-radius: 1em;
  color: #fff;
  padding: .25em;
  text-decoration: none;
  line-height: 1.2;
  text-align: center;
  outline: 0;
}
.simple-modal-close:focus,
.simple-modal-close:hover,
.simple-modal-close:active {
  background: #000;
}
.simple-modal-overlay[data-background-click="disabled"] {
  cursor: auto;
}


/*
 *****************************************************************
 * 07 -- forms
 *****************************************************************
 */

/* donne envie de cliquer sur un bouton */
label,
button,
input[type="submit"],
input[type="button"],
input[type="reset"] {
  cursor: pointer;
}
button[disabled],
input[type="submit"][disabled],
input[type="button"][disabled],
input[type="reset"][disabled] {
  cursor: default;
}

/* évite un resize potentiellement foireux */
textarea {
  resize: vertical;
}
/* supprime un bug Firefox sur button */
button::-moz-focus-inner { border: 0; padding: 0; }

label,
button,
input,
select {
  vertical-align: middle;
}

/* à adapter selon le design voulu */
input,
select,
textarea {
  border: 1px solid #000;
  padding: .5em;
  width: 250px;
}

/* pour les textes des champs */
.label {
  display: inline-block;
}

/* à adapter selon le design voulu */
.button {
  background: #064178;
  color: #fff;
  border-radius: 10px;
  outline: 0;
}

.button2 {
  background: none;
  color: #2573be;
  padding: 1em;
  outline: 0;
}

.team_close {
	position: absolute;
	right: 1em;
	top:1em;
}

/* 
 * évite dimensionnement des radios, checkboxes et images
 * et un affichage différent sous IE 
 */
input[type="radio"],
input[type="checkbox"],
input[type="image"] {
  background-color: transparent;
  border: 0;
  width: auto;
}

/* pour annuler la taille des inputs ou autres */
.auto {
  width: auto;
}

/* messages d’erreur ou de confirmation */
.alert,
.alert input,
.alert textarea,
.alert select {
  color: #bf0000;
  font-weight: bold;
}
/* .redborder sert à débugger uniquement */
.alert input,
.alert textarea,
.alert select,
.redborder {
  border: 1px solid #bf0000;
}
.alert img {
  border: 0;
}
/*.ok {

}*/

/* 
 * peut être complété par les attributs HTML5 required
 * exemple avec une couleur, penser à ne pas uniquement transmettre l’info ainsi
 */
/*select:required:invalid,
input:required:invalid,
input:focus:invalid,
textarea:required:invalid,
textarea:focus:invalid {
  background: #fef6f6;
  -moz-box-shadow: none;
}

input:focus:required:valid,
textarea:focus:required:valid,
select:focus:required:valid {
  background: #efe;
  -moz-box-shadow: none;
}*/




/*
 *****************************************************************
 * 08 -- dans le contenu (contenus spécifiques aux pages)
 *****************************************************************
 */

/* home */





/*
 *****************************************************************
 * 09 -- breakpoints mineurs entre desktop et tablettes
 *****************************************************************
 */

@media (max-width: 100em) {
.header__logocontainer {
    width: 120px;
}

	
.content {
    padding: 0 4em 0 4em;
}

.header {
	padding: 1em 1em 1em 4em;
}
	
}
 
@media (max-width: 87.5em) {
.header__logocontainer {
    width: 120px;
}

	
.content {
    padding: 0 4em 0 4em;
}

.header {
	padding: 1em 1em 1em 4em;
}


	
}

@media (max-width: 1280px) {
	
.world:before {
	display: block;
    width: 100%;
	float: none;
	margin: 0 1em 0.5em 0;
	text-align: center;
}

.link:before {
	display: block;
    width: 100%;
	float: none;
	margin: 0 1em 0.5em 0;
	text-align: center;
}

.collaboration:before {
	display: block;
    width: 100%;
	float: none;
	margin: 0 1em 0.5em 0;
	text-align: center;
}
.world, .link, .collaboration {
	display: block;
	text-align: center;
}

.team {
	position: fixed;
	top:120px;
	width:50%;
	background: #bfd4eb;
	padding: 2em;
	text-align: center;
    right: 0;
    height: 100vh;
    font-size: 1em;
}

.team .bl {
	max-width: auto;
}
	
}

@media (max-width: 91em) {

	.content {
		padding: 2em;
	}

.header {
	padding: 1em 1em 1em 2em;
} 

	.menu-item a {
		padding: 0 .5em;
	}
	.header__logocontainer {
		width: 120px
	}
	.ondesktop-w75 {width: 75%;}
	.ondesktop-w25 {width: 25%;}
	.menu-item a {font-size: 14px; 
	}
	
	/*.team, .strategy { width: 25%; }*/
	
}



/*
 *****************************************************************
 * 10 -- homo tablettes - breakpoint majeur
 *****************************************************************
 */ 

@media (max-width: 66em) { /* equiv 768px */
   
  /**
   * layout/modules
   */

  /* affichage des éléments */
  .nodesktop { display: block; }

  /* cachage des éléments inutiles, chabitte ! */
  .notablet { display: none; }
  
  /* linéarisation contenus flottants/table-layout */
  .autotablet {
    float: none;
    display: block;
    width: auto;
  }

  /* margins */
  .ontablet-mt0 { margin-top: 0; }
  .ontablet-mt1 { margin-top: 1em; }
  .ontablet-mt2 { margin-top: 2em; }
  .ontablet-mr0 { margin-right: 0; }
  .ontablet-mr1 { margin-right: 1em; }
  .ontablet-mr2 { margin-right: 2em; }
  .ontablet-mb0 { margin-bottom: 0; }
  .ontablet-mb1 { margin-bottom: 1em; }
  .ontablet-mb2 { margin-bottom: 2em; }
  .ontablet-ml0 { margin-left: 0; }
  .ontablet-ml1 { margin-left: 1em; }
  .ontablet-ml2 { margin-left: 2em; }
  .ontablet-m0  { margin: 0; }
  .ontablet-m1  { margin: 1em; }
  .ontablet-m2  { margin: 2em; }

  /* paddings */
  .ontablet-pt0 { padding-top: 0; }
  .ontablet-pt1 { padding-top: 1em; }
  .ontablet-pt2 { padding-top: 2em; }
  .ontablet-pr0 { padding-right: 0; }
  .ontablet-pr1 { padding-right: 1em; }
  .ontablet-pr2 { padding-right: 2em; }
  .ontablet-pb0 { padding-bottom: 0; }
  .ontablet-pb1 { padding-bottom: 1em; }
  .ontablet-pb2 { padding-bottom: 2em; }
  .ontablet-pl0 { padding-left: 0; }
  .ontablet-pl1 { padding-left: 1em; }
  .ontablet-pl2 { padding-left: 2em; }
  .ontablet-p0  { padding: 0; }
  .ontablet-p1  { padding: 1em; }
  .ontablet-p2  { padding: 2em; }
  
  /* alignements de textes */
  .ontablet-alignleft   { text-align: left; }
  .ontablet-aligncenter { text-align: center; }
  .ontablet-alignright  { text-align: right; }
  .ontablet-display { display: inline-block; }
  /**
   * adaptation structure globale (page / skip links / header / contenu principal / footer)
   */
  body::before {
    content: 'tablet';
  }
  
  
  
  /**
   * dans le contenu (contenus spécifiques aux pages)
   */
   
  .pageback {
	  display: none
  }
  
  .header {
	  position: relative;
  }
  
  .banner {
	  position: relative;
	  left:0;
	  right: 0;
  }
  
  .container {
	min-height: auto;
	height: auto;
	padding: 0;
	}
	
	.content {
	padding: 0;
	min-height: auto;
	height: auto;
	background: #fff;
    float: none;
   /* display: block;*/
    width: auto;
	}
	
	.content .header {
		padding: 1em 2em;
	}
	
	.content .main {
		padding: 2em;
		background: rgba(255,255,255,.8);
		position: relative;
		top:-100px
	}
	
	.sidebar {
	min-height: auto;
	height: auto;
	position: relative;
    float: none;
    display: block;
    width: auto;
	}
	
	.footer {
		position: relative;
		padding: 2em;
	}
	
	.widget_icl_lang_sel_widget {
	border-left : 0;
	}
	
	.displaymenu {
    display: block;
    position: absolute;
    right: 1em;
    top:3em;
    text-decoration: none;
    color: #000;
    line-height: 1;
    width: 30px;
    height: 30px;
    background: url(images/icons/burgericon.svg) 0 0 no-repeat;
    background-size: contain;
    z-index: 2000;
  }
  .displaymenuclose {
	content: "";  
    background-image: url(images/icons/burgericon-close.svg);
    position: fixed;
    top:1.5em;
    right:2em
  }
  .navigation-container[aria-hidden=true] {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    z-index: 1000;
    background: rgba(0,85,177,.95);
    padding: 0;
    max-width: 300px;
    text-align: left;
    max-height: 0px;
    overflow: hidden;
    transition: ease max-height 1s, ease padding 1s;
  }
  .navigation-container[aria-hidden=false] {
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    z-index: 1000;
    background: rgba(0,85,177,.95);
    padding: 2em;
    max-width: 300px;
    text-align: left;
    height: 100%;
    transition: ease max-height 1s, ease padding 1s;
  }
  .navigation {
    display: block;
    width: 100%;
  }
  .menu {
	  position: relative;
	  right: auto;
	  top: auto;
  }
  .menu-item {
	  display: block;
	  margin: 0 0 1em 0
  }
  .menu-item a {
	  color: #fff;
  }

.sub-menu {
	display: block;
	position: relative;
	max-width: auto;
	background: none;
	padding: 1em 0 0 2em;
}

.sub-menu .menu-item a {
	text-transform: none;
	padding: 0;
	  color: #fff;
	  font-size: 12px;
}
.sub-menu .menu-item a:hover, .sub-menu .menu-item a[aria-current=page] {
  color: rgba(255,255,255,.75)
}

.menu-item-has-children:after {
	display: none
}

.grid-team {
	width: 48%;
}

.grid-team--sep {
	width: 4%;
}

.grid-team--nodesktop {
	display: inline-block;
}

.grid-team--notablet {
	display: none;
}

.content { padding: 0; }
	.ontablet-w100 {width: 100%;}
	
	.menu-item a {
    text-transform: uppercase;
    color: #FFF;
    padding: 0 0.5em;
}
	.content .main {
    padding: 5em 2em 2em;
}
	
	.content .header {
    padding: 0 2em 2em;
}

.team, .strategy {
	width: auto;
	top: 0;
	position: fixed;
	height: 100vh;
	overflow: auto
}

}




/*
 *****************************************************************
 * 11 -- breakpoints mineurs entre tablettes et mobile
 *****************************************************************
 */






/*
 *****************************************************************
 * 12 -- mobile - breakpoint majeur
 *****************************************************************
 */

@media (max-width: 40em) { /* equiv 640px */

  /**
   * layout/modules
   */

  /* affichage des éléments */
  .notablet { display: block; }

  /* cachage des éléments inutiles, chabitte ! */
  .nomobile { display: none; }

  /* linéarisation contenus flottants/table-layout */
  .automobile {
    float: none;
    display: block;
    width: auto;
  }
  
  /* margins */
  .onmobile-mt0 { margin-top: 0; }
  .onmobile-mt1 { margin-top: 1em; }
  .onmobile-mt2 { margin-top: 2em; }
  .onmobile-mr0 { margin-right: 0; }
  .onmobile-mr1 { margin-right: 1em; }
  .onmobile-mr2 { margin-right: 2em; }
  .onmobile-mb0 { margin-bottom: 0; }
  .onmobile-mb1 { margin-bottom: 1em; }
  .onmobile-mb2 { margin-bottom: 2em; }
  .onmobile-ml0 { margin-left: 0; }
  .onmobile-ml1 { margin-left: 1em; }
  .onmobile-ml2 { margin-left: 2em; }
  .onmobile-m0  { margin: 0; }
  .onmobile-m1  { margin: 1em; }
  .onmobile-m2  { margin: 2em; }

  /* paddings */
  .onmobile-pt0 { padding-top: 0; }
  .onmobile-pt1 { padding-top: 1em; }
  .onmobile-pt2 { padding-top: 2em; }
  .onmobile-pr0 { padding-right: 0; }
  .onmobile-pr1 { padding-right: 1em; }
  .onmobile-pr2 { padding-right: 2em; }
  .onmobile-pb0 { padding-bottom: 0; }
  .onmobile-pb1 { padding-bottom: 1em; }
  .onmobile-pb2 { padding-bottom: 2em; }
  .onmobile-pl0 { padding-left: 0; }
  .onmobile-pl1 { padding-left: 1em; }
  .onmobile-pl2 { padding-left: 2em; }
  .onmobile-p0  { padding: 0; }
  .onmobile-p1  { padding: 1em; }
  .onmobile-p2  { padding: 2em; }
  
  /* alignements de textes */
  .onmobile-alignleft   { text-align: left; }
  .onmobile-aligncenter { text-align: center; }
  .onmobile-alignright  { text-align: right; }

  /**
   * adaptation structure globale (page / skip links / header / contenu principal / footer)
   */
  body::before {
    content: 'mobile';
  }
  
  /**
   * dans le contenu (contenus spécifiques aux pages)
   */
   
   h1 { font-size: 30px; }

.grid-team {
	width: 100%;
}

.grid-team--sep {
	display: none
}

h1 {
    font-size: 40px;
}
h2 {
    font-size: 24px;
}
	.grid-strategy {
		width: 100%;
	}

.grid-strategy--sep {
	display: none
}

}




/*
 *****************************************************************
 * 13 -- breakpoints mineurs tout petit mobile
 *****************************************************************
 */

@media (min-width: 37.5em) {
.wp-block-column {
    flex-basis: 100%;
    flex-grow: 0;
}

.wp-block-column:not(:first-child), .wp-block-column:nth-child(2n) {
    margin-left: 0;
}

}

@media (max-width: 20em) { /* equiv 320px */

  /**
   * layout/modules
   */

  /* affichage des éléments */
  /*.nomobile { display: block; }*/

  /* cachage des éléments inutiles ! */
  .notinymobile { display: none; }

  /* linéarisation contenus flottants/table-layout */
  .autotinymobile {
    float: none;
    display: block;
    width: auto;
  }

  /**
   * adaptation structure globale (page / skip links / header / contenu principal / footer)
   */
  body::before {
    content: 'tinymobile';
  }
  
  /**
   * dans le contenu (contenus spécifiques aux pages)
   */

}





/*
 *****************************************************************
 * 14 -- print
 *****************************************************************
 */

@media print {

  /* Fixe un bug délirant de Edge au print */
  html {
      -ms-overflow-style: -ms-autohiding-scrollbar;
  }

  /** 
   * ajouter là-dedans les éléments qui ont besoin d’être
   * resetés de manière très bourrine pour le print
   */
  body,
  html,
  .pagecontent,
  .reset4print {
    background-color: #fff;
    background-image: none;
    border: 0;
    box-shadow: none;
    color: #000;
    float: none;
    height: auto;
    margin: 0;
    max-width: 100%;
    min-height: 0;
    padding: 0;
    position: static;
    width: auto;
    opacity: 1;
    visibility: visible;
    max-height: none;
    display: block;
  }

  body {
    padding: .5em;
    overflow: auto;
  }

  /* cachage des éléments inutiles, chabitte ! */
  .noprint {
    display: none;
  }
  
  /* affichage éléments spécifiques au print */
  .onprint {
    display: block;
  }
  
  /* éviter saut de page hasardeux */
  blockquote, ul, ol {
    page-break-inside: avoid;
  }
  h1, h2, h3, caption {
    page-break-after: avoid;
  }
  
  /* affichage des liens, sauf pour image contenue */
  /* attention, penser à vérifier le résultat et penser 
   * à limiter cette possibilité aux liens dans le contenu */
  /*a:after {
    content: " (" attr(href) ") ";
  }
  a:after img {
    content: "";
  }*/

  /* ici fix propriétés particulières */


} /* end print */




/*
 *****************************************************************
 * 15 -- fix viewport
 *****************************************************************
 */

/* fix viewport pour Win8 (snap mode) et préparer le jour 
 * où le viewport sera supporté par tous les moteurs 
 *  
 * Exemples : http://dev.opera.com/articles/view/an-introduction-to-meta-viewport-and-viewport/
 * width=device-width   => width: device-width;
 * height=device-height => height: device-height;
 * initial-scale=2      => zoom: 2;
 * maximum-scale=2      => max-zoom: 2;
 * minimum-scale=0.5    => min-zoom: 0.5;
 * user-scalable=no     => user-zoom: fixed;
 * 
 * pour le snap mode de Win8 => seul width: device-width; fonctionne pour l’instant  
 */

@-webkit-viewport {
  width: device-width;
}
@-moz-viewport {
  width: device-width;
}
@-ms-viewport {
  width: device-width;
}
@-o-viewport {
  width: device-width;
}
@viewport {
  width: device-width;
}




/*
 *****************************************************************
 * 16 -- règles d’état
 *****************************************************************
 */

/*
 * Règles d’état = mises en bas pour être prioritaires
 *
 */

/*
.is-hidden,
[aria-hidden=true] {
  display: none;
}
*/




/*
 *****************************************************************
 * 17 -- bonus : Fixes IE
 *****************************************************************
 */

/*  
 * basé sur les classes conditionnelles sur l’élément HTML
 *  
 * à utiliser seulement si peu de corrections et 
 * pas d’impact sur les perfs sur les autres navigateurs
 *       
 */

/* less than IE 9 */
.oldies .nooldies {
  display: none;
}

.ie6 .noie6 {
  display: none;
}
.ie7 .noie7 {
  display: none;
}
.ie8 .noie8 {
  display: none;
}
.ie9 .noie9 {
  display: none;
}

.ie7 .col,
.ie7 .col-noalign,
.ie6 .col,
.ie6 .col-noalign {
  float: left;
}
.ie7 .row,
.ie6 .row {
  overflow: auto;
}

/* RTL */
[dir="rtl"] .ie7 .col,
[dir="rtl"] .ie7 .col-noalign,
[dir="rtl"] .ie6 .col,
[dir="rtl"] .ie6 .col-noalign {
  float: right;
}
