/* Font imports */
@import url('https://fonts.googleapis.com/css2?family=PT+Sans:ital,wght@0,400;0,700;1,400&display=swap');

! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

body {
  background-color: #ffffff;
  color : rgba( 10, 10, 10, 1 );
  font-family: 'PT Sans', sans-serif;
  font-size: 21px;
  margin: 0;
  /*margin-top: 10rem;*/
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

footer {
  min-height: 50vh;
}
/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
  margin: 1rem 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1rem; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
  transition: all 0.2s;
}

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1rem; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25rem;
}

sup {
  top: -0.5rem;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

  img.responsive {
    box-sizing: border-box;
    max-width: 100%;
    height: auto;
  }

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */

button,
html [type="button"], /* 1 */
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35rem 0.75rem 0.625rem;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details, /* 1 */
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}

/*****************/
/* END NORMALIZE */
/*****************/

/*****************/
/* GLOBAL STYLES */
/*****************/

.top-menu-container {
  /*background-color: #ffffff;*/
  /*box-shadow: 0 1px 5px #666666;*/
  display: block;
  /*left: 0;*/
  /*position: fixed;*/
  /*right: 0;*/
  /*top: 0;*/
  z-index: 9999;
  /*outline: 1px solid red;*/
}

  .top-menu-container h3 {
    border-bottom: 1px solid gray;
    display: none;
    font-size: 1.5rem;
    line-height: 2rem;
    margin: 0 0 1rem 0;
    padding: 1rem 0;
    text-align: center;
    width: 100%;
  }

h1, h2 {
  font-family: Georgia, serif;
  font-weight: normal;
}

h1 {
  font-size: 2.5rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-top: 1rem;
}

  h1.big {
    font-size: 4rem;
    letter-spacing: 3px;
    margin-top: 1rem;
    flex-direction: row; 
    display: flex;
  }

  /* For the stripes :
   * Props to https://www.geeksforgeeks.org/how-to-make-horizontal-line-with-words-in-the-middle-using-css/*/

    h1.big:before, 
    h1.big:after { 
        background-image: url( ../images/site/frise-bg.svg );
        background-repeat: repeat-x;
        background-size:  auto;
        background-position: center;
        content: ""; 
        flex: 1 1; 
        height: 2rem;
        margin: auto;
        /*padding: 1rem; */
        /*outline: 1px solid red;*/
    }

    a h1.big {
      color: rgba( 10, 10, 10, 1 );
    }

    h1.big .main-title-subtitle,
    h1 .subtitle {
      font-family: 'PT Sans', sans-serif;
      font-size: 1rem;
      letter-spacing: initial;
      font-weight: normal;
    }
    
    h1 .subtitle {
      font-size: 1.1rem;
      margin-top: 0.5rem;
    }

h2 {
  font-size: 2rem;
  margin-bottom: 0.5rem;
  margin-top: 1rem;
}

h4 {
  font-size: 1.5rem;
  font-weight: bold;
  margin: 1rem 0 0.5rem 0;
}

h5 {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 1rem 0 0.5rem 0;
}

a {
  color: rgba( 50, 50, 50, 1 );
  background-color: rgba( 225, 225, 225, 1 );
  outline: 5px solid rgba( 225, 225, 225, 1 );
  text-decoration: none;
}

  a button {
    cursor: pointer;
  }

  a.no-outline {
    outline: none;
  }

  a.no-background-color {
    background-color: transparent;
  }

  a:hover {
    color: white;
    background-color: rgba( 50, 50, 50, 1 );
    outline: 5px solid rgba( 50, 50, 50, 1 );
  }

  a.no-outline:hover {
    outline: none;
  }

  a.no-background-color:hover {
    background-color: transparent;
  }

p {
  line-height: 2.0rem;
}

p img {
  max-width: 100%;
  height: auto;
}

ul {
  list-style-type: circle;
  margin: 0;
  padding: 0 1.5rem; 
}

  ul li {
    margin-bottom: 0.5rem;
    line-height: 2.0rem;
  }

/* Modifiers */

.pull-right{
  text-align: right;
}

.align-center {
  text-align: center;
}

.hidden {
  display: none;
}

/* with shadow */
.shadow {
  -webkit-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
  -moz-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
  box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
}

/* Frame (for pictures) */
.framed {
  border: 10px solid white;
}

.picture {
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  display: inline-block;
}

  .picture.picture-xxs {
      height: 1.5rem;
      width: 1.5rem;
  }

  .picture.picture-xs {
      height: 3rem;
      width: 3rem;
  }

  .picture.picture-sm {
      height: 5rem;
      width: 5rem;
  }

  .picture.picture-md {
      height: 7rem;
      width: 7rem;
  }

  .picture.picture-lg {
      height: 10rem;
      width: 10rem;
  }

.round {
  border-radius: 50%;
}

/* Clearfix (as per Nicolas Gallagher - http://nicolasgallagher.com/micro-clearfix-hack/) */
.cf:before,
.cf:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.cf:after {
    clear: both;
}

/**
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.cf {
    *zoom: 1;
}

/* End of clearfix */

/* Mapped BG div */
.bg-map {
  background: url( ../images/site/bg-main.jpg) center center no-repeat;
  background-attachment: fixed;
  background-size: cover;
}

  /* Mapped BG div with vertical margins */
  .bg-map.vm {
    position: absolute;
    top: 1.5rem;
    bottom: 1.5rem;
    left: 0;
    right: 0;
    z-index: -10;
  }

/* Content div going inside relative blocks */
.content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
  /*background-color: lightgreen;*/
}

.filter {
  background-color: rgba( 0, 0, 0, 0.5 );
  /*position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;*/
  /*background-color: lightgreen;*/
}

/**********/
/* NAVBAR */
/**********/
/* Props to https://codepen.io/philhoyt/pen/BnybJ for the code */

/*#primary_nav {*/
.primary-navigation-container {
  z-index: 1;
  position: relative;
}

.main-navigation {
  /*margin-top:10px;*/
}

  /*Hamburger button for mobile navigation */
  .main-navigation .close-button {
    display: none;
  }

  .main-navigation ul {
    display:  inline-block;
    font-size: 1rem;
    list-style: none;
    position: relative;
    margin: 0;
    padding: 0;
    /*display:  flex;
    justify-content:  space-between;*/
  }

  .main-navigation ul li a {
    background-color: transparent;
    outline: none;
    display: block;
    color: inherit;
    text-decoration: none;
    padding:  0.5rem 1.5rem 0.5rem 0;
    line-height:  100%;
  }

  .main-navigation ul li {
    position: relative;
    float: left;
    margin: 0;
    padding: 0;
  }

  .main-navigation ul li.current-menu-item {
    /*background: #ddd;*/
    /*border-bottom:  2px solid #000;*/
    text-decoration: underline;
  }

  .main-navigation ul li a:hover {
    /*background: #ffffff;*/
    text-decoration: underline;
  }

  .main-navigation ul ul {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: #e3e3e3;
    padding: 0;
  }

  .main-navigation ul ul li {
    float: none;
    width: 200px;
  }

  .main-navigation ul ul a {
    line-height: 120%;
    padding: 8px 15px;
  }

  .main-navigation ul ul ul {
    top: 0;
    left: 100%;
  }

  .main-navigation ul li:hover > ul {
    display: block;
  }

.main-navigation-hamburger-container {
  display: none;
}

/**************/
/* END NAVBAR */
/**************/

/*--------------------------------------------------------------
# Cookies
--------------------------------------------------------------*/
  
.cookie-consent-container {
  background-color: rgba( 0, 0, 0, 0.8 );
  bottom: 0;
  color: white;
  /*line-height: 1.25rem;*/
  margin: 0 1rem 1rem 1rem;
  padding: 0.8rem;
  position: fixed;
  right: 0;
  width: 50%;
  z-index: 1000000;
}

  .cookie-consent-container h4 {
    font-size: 1.0rem;
    margin: 0 0 0.5rem 0;
  }

  .cookie-consent-container p {
    font-size: 1.0rem;
    line-height: 1.5rem;
    margin: 0 0 0.5rem 0;
  }

  .cookie-consent-container button {
    background-color: #ffffff;
    border: none; 
    border-radius: 2px;
    cursor: pointer;
    float: right;
    font-weight: bold; 
    line-height: 2.0rem;
    margin: none;
  }



/*************/
/* HEADER    */
/*************/

.initial-language-selection {
  /*background-color: rgba( 166, 166, 166, 0.4 );*/
  box-shadow: 0 2px 3px rgba( 0, 0, 0, 0.5 );
  color: white;
  line-height: 2.5rem;
  margin-bottom: 0.5rem;
  padding: 1rem;
  text-align: center;
}

.language-picker-container {
  display: inline-block;
  white-space: nowrap;
}

  .language-picker-container .lg-flag {
    vertical-align: middle;
  }

.main-title-container {
  /*margin-bottom: 4rem;*/
}
  
  /*.main-title-container .main-title-content {
    background-image: url( ../images/site/frise-bg.svg );
    background-repeat: repeat-x;
    background-size: 10% auto;
    background-position: center;
  }*/

    .main-title-container .mega-title h1 {
      background-color: #ffffff;
    }

    .main-title-container .mega-title h4 {
      padding-top: 5rem;
      margin-bottom: -6rem;
    }

    .main-title-container .mega-title h6 {
      font-size: 1rem;
      font-weight: normal;
      margin-top: -4rem;
      padding-bottom: 5rem;
    }

/*************/
/* HOME PAGE */
/*************/

/* Grids */
.home-grid-item {
  float: left;
  position: relative;
  transition-duration: 0.25s;
}

  .home-grid-item:hover{
    background-size: 110% auto;
    cursor: pointer;
  }

  .home-grid-item .label {
    bottom: 0;
    color: #ffffff;
    font-size: 1.5rem;
    left: 0;
    padding-left: 1rem;
    position: absolute;
    right: 0;
  }  

/* Top grid */
.home-grid-top-container  {
  position: relative;
}

/* Necessary for box shadow (no other div has the right size) */
.home-grid-top-height-definer {
  /*background-color: #ffffff;*/
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50%;
}

.home-grid-item.landscape {
  background-size: auto 100%;
}

.home-grid-item.portrait {
  background-size: 101% auto;
}

  .home-grid-item.landscape:hover{
    background-size: auto 110%;
  }

  .home-grid-item.portrait:hover {
    background-size: 110% auto;
  }

.home-grid-top-left-item {
  background: url( ../images/site/home-grid-top-left-item.jpg) top center no-repeat #ffffff;
  background-size: 100% auto;
  /*border-radius: 7px 7px 0 0;*/
  padding-bottom: 50%; /* https://stackoverflow.com/questions/1495407/maintain-the-aspect-ratio-of-a-div-with-css */
  /*outline: 1px solid blue;*/
  width: 100%;
}

  .home-grid-top-left-item .label {
    background-color: rgba( 0, 0, 0, 0.5 );
  }  

.home-grid-top-right-top-item {
  background: url( ../images/site/home-grid-top-right-top-item.jpg) top center no-repeat #ffffff;
  background-size: 100% auto;
  /*border-radius: 0 0 0 7px;*/
  padding-bottom: 25%;
  /*outline: 1px solid blue; */
  width: 50%;  
}

  .home-grid-top-right-top-item .label {
    background-color: rgba( 0, 0, 0, 0.5 );
  } 

.home-grid-top-right-bottom-left-item,
.home-grid-top-right-bottom-right-item {
  padding-bottom: 25%;
  /*outline: 1px solid blue;*/
  width: 25%;
}

.home-grid-top-right-bottom-right-item {
  /*border-radius: 0 0 7px 0;*/
}

.home-grid-top-right-bottom-left-item {
  background: url( ../images/site/home-grid-top-right-bottom-left-item.jpg) top center no-repeat #ffffff;
  background-size: 100% auto;
}

  .home-grid-top-right-bottom-left-item .label {
    background-color: rgba( 0, 0, 0, 0.5 );
  } 

.home-grid-top-right-bottom-right-item {
  background: url( ../images/site/home-grid-top-right-bottom-right-item.jpg) top center no-repeat #ffffff;
  background-size: 100% auto;
}

  .home-grid-top-right-bottom-right-item .label {
    background-color: rgba( 0, 0, 0, 0.5 );
  } 

/* End of top grid */

/* News block */
.home-grid-news-container  {
  position: relative;
}

/* Necessary for box shadow (no other div has the right size) */
.home-grid-news-height-definer {
  background-color: #ffffff;
  display: inline-block;
  position: relative;
  width: 100%;
  height: 50%;
}

.home-grid-news-item {
  background: url( ../images/site/home-grid-top-right-bottom-right-item.jpg) top center no-repeat #ffffff;
  background-size: 100% auto;
  padding-bottom: 33.3333%;
  width: 33.3333%;
  /*outline: 1px solid red;*/
}

  .home-grid-news-item.landscape {
    background-size: auto 100%;
  }

  .home-grid-news-item.portrait {
    background-size: 100% auto;
  }

    .home-grid-news-item.landscape:hover{
      background-size: auto 110%;
    }

    .home-grid-news-item.portrait:hover {
      background-size: 110% auto;
    }


  .home-grid-news-item .content p {
    color: #ffffff;
    margin: 1.5rem;
  }

    .home-grid-news-item .content p.author {
      font-size: 1rem;
      line-height: 1.5rem;
      margin-top: -1rem;
    }

    .home-grid-news-item .content .date {
      color: #ffffff;
      float: left;
      height: 100%;
      margin: 0 1.0rem;
      text-align: center;
      /*outline: 1px solid red;*/
    }

      .home-grid-news-item .content .date .day {
        font-size: 2.5rem;
        margin-top: 1.0rem;
      }

      .home-grid-news-item .content .date .month{
        font-size: 1.75rem;
        margin-top: -0.35rem;
      }

      .home-grid-news-item .content .date .time {
        font-size: 1.0rem;
        margin-top: 0.75rem;
      }

/* End of news block */

/* Bottom navigation block */
.home-bottom-navigation-block {
  display: inline-block;
  position: relative;
  /*outline: 1px dotted red;*/
  vertical-align: top;
  width: 33%;
}

  .home-bottom-navigation-block h2 {
    font-size: 1.75rem;
    margin-bottom: 0.5rem;
  }

  .home-bottom-navigation-block ul {
    line-height: 2rem;
    list-style: none;
    padding: 0;
    margin: 0;
  }

    .home-bottom-navigation-block ul li a {
      color: inherit;
    }

      .home-bottom-navigation-block ul li a:hover {
        text-decoration: underline;
      }

/* Guide promo on home page */

.guide-cover-container {
  text-align: right;
  /*outline: 1px dotted green;*/
}

.guide-cover {
  transform: perspective( 150px ) translateZ( 0 ) rotateY( -8deg ) rotateX( 2deg ); /* https://desandro.github.io/3dtransforms/examples/perspective-01.html */
  z-index: 1;
}

  .guide-cover img {
    -webkit-box-shadow: 2px 3px 3px 1px rgba( 0, 0, 0, 0.7 );
    -moz-box-shadow: 2px 3px 3px 1px rgba( 0, 0, 0, 0.7 );
    box-shadow: 2px 3px 3px 1px rgba( 0, 0, 0, 0.7 );
    height: 12rem;
  }

.guide-cta-btn {
  /*background-color: #758d5c;*/
  background: rgb( 133,166, 98 );
  background: -moz-linear-gradient(top, rgba( 133, 166, 98, 1 ) 0%, rgba( 96, 108, 83, 1 ) 100% );
  background: -webkit-linear-gradient(top, rgba( 133, 166, 98, 1 ) 0%,rgba( 96, 108, 83, 1 ) 100% );
  background: linear-gradient(to bottom, rgba( 133, 166, 98, 1 ) 0%,rgba( 96, 108, 83, 1 ) 100% );
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#85a662', endColorstr='#606c53',GradientType=0 );
  
  border-radius: 50%;
  bottom: -2rem;
  cursor: pointer;
  display: inline-block;
  height: 5rem;
  right: 5rem;
  padding: 1rem;
  position: absolute; 
  transform: perspective( 0 ) translateZ( 15px );
  width: 5rem;
  /*z-index: 9999;*/
}

.guide-cta-btn-label {
  color: #ffffff;
  line-height: 1.75rem;
  position: relative; 
  text-align: center;
  text-shadow: -1px 0px 0px rgba( 255, 255, 255, 0.3 ), 0px 1px 0px rgba( 120, 120, 120, 0.5 );
  top: 50%; 
  transform: translateY( -50% ); /* Vertically center : https://stackoverflow.com/questions/35388462/vertically-center-a-div-inside-another-div */
}

/* End of bottom navigation block */

/* Guide promo on top of footer */

.guide-promo-insert-container {
}

  .guide-promo-insert-container .guide-promo-insert-cover {
    display: inline-block;
    vertical-align: top;
    width: 33%;
  }

    .guide-promo-insert-container .guide-promo-insert-cover img {
      max-width: 80%;
      height: auto;
      width: auto;
      transform: perspective( 350px ) translateZ( 0 ) rotateY( 5deg ) rotateX( 2deg ); /* https://desandro.github.io/3dtransforms/examples/perspective-01.html */
      z-index: 1;
    }

  .guide-promo-insert-container .guide-promo-insert-intro {
    display: inline-block;
    vertical-align: top;
    width: 65%;
  }

/* End of Guide promo on top of footer */


/* Footer */

.footer-language-selection-container,
.footer-miscellaneous-container {
  display: inline-block;
  vertical-align: top;
  width: 50%;
  /*outline: 1px solid red;*/
}

.footer-copyright-container,
.footer-link-author-container,
.footer-privacy-container {
  /*color: #ffffff;*/
  font-size: 0.9rem;
  margin-bottom: 0.5rem;
  text-align: right;
}

  .footer-copyright-container a,
  .footer-link-author-container a,
  .footer-privacy-container a {
    color: white;
    text-decoration: underline;
  }

    .footer-copyright-container a:hover,
    .footer-link-author-container a:hover,
    .footer-privacy-container a:hover {
      color: lightgray;
      text-decoration: underline;
    }

.footer-copyright-container {
  font-weight: bold;
}

.lg-flag {
  /*outline: 1px solid red;*/
  border-radius: 2rem;
  display: inline-block;
  height: 2rem;
  margin: 0 0.25rem 0.25rem 0;
  cursor: pointer;
  width: 2rem;
  transform-origin: center center;
}

  .lg-flag:hover {
    box-shadow: 0 1px 3px rgba( 0, 0, 0, 0.5 );
    opacity: 0.9;
  }

  .lg-flag:active {
    transform: scale( 0.9, 0.9 );
  }

  .lg-flag.en-GB {
    background: url( ../images/site/flags/en-GB.gif ) center center no-repeat;
    background-size: auto 100%; 
  }

  .lg-flag.fr-FR {
    background: url( ../images/site/flags/fr-FR.gif ) center center no-repeat;
    background-size: auto 100%; 
  }

  .lg-flag.de-DE {
    background: url( ../images/site/flags/de-DE.gif ) center center no-repeat;
    background-size: auto 100%; 
  }

  .lg-flag.nl-NL {
    background: url( ../images/site/flags/nl-NL.gif ) center center no-repeat;
    background-size: auto 100%; 
  }
/* End of footer */

/* Books pages */

.book-thumbnail-container {
  display: inline-block;
  position: relative;
  vertical-align: top;
  width: 25%;
}

  .book-thumbnail-container a:hover {
    text-decoration: none;
  }

  .book-thumbnail-content {
    padding: 1.250rem;
    padding-bottom: 1.5rem;
  }

    .book-thumbnail-content:hover{
      background-color: #cccccc;
      box-shadow: 0px 2px 5px #999999;
    }

    .book-thumbnail-content .title {
      color: initial;
      line-height: 1.9rem;
      margin: 0;
    }

    .book-thumbnail-content .author {
      color: #555555;
      font-size: 0.9rem;
    }

    .book-thumbnail-content img {
      /*border: 1px solid #cccccc;*/
      height: auto;
      margin-bottom: 1rem;
      width: 100%;
      box-shadow: 0px 2px 5px #999999;
    }

.book-item .book-item-description {
  display: inline-block;
  vertical-align: top;
  width: 70%;
}

  .book-item .book-item-description .book-item-description-content {
    padding-right: 4rem;
    text-align: justify;
  }

    .book-item .book-item-description .book-item-description-content p:first-of-type {
      margin-top: 0;
    }

.book-item .book-item-file {
  display: inline-block;
  vertical-align: top;
  width: 30%;
}

  .book-item .book-item-file img {
    box-shadow: 0px 2px 5px #999999;
  }

  .book-item .book-item-file .book-item-file-title {
    font-weight: bold;
    margin: 0.5rem 0;
  }

  .book-item .book-item-file .book-item-file-author {
    font-size: 1rem;
  }

  .book-item .book-item-file-editor {
    font-size: 1rem;
  }

  .book-item .book-item-file-publication-date {
    font-size: 1rem;
  }

/**********************/
/* Protagonists block */
/**********************/

ul.protagonists-armies-list {
  text-align: center;

}

  /*ul.protagonists-armies-list li {
    display: inline-block;
  }

    ul.protagonists-armies-list li a {
      color: inherit;
    }

      ul.protagonists-armies-list li a:hover {
        text-decoration: underline;
      }

  ul.protagonists-armies-list li .protagonists-item-picture,
  ul.protagonists-armies-list li .protagonist-item-content {
    display: inline-block;
    vertical-align: top;
  }

  ul.protagonists-armies-list li .protagonists-item-picture {
    margin: 0 0.5rem;
  }*/

.protagonist-thumbnail-container {
  display: inline-block;
  position: relative;
  vertical-align: top;
  width: 25%;
}

  .protagonist-thumbnail-container a:hover {
    text-decoration: none;
  }

  .protagonist-thumbnail-content {
    padding: 1.250rem;
    padding-bottom: 1.5rem;
  }

    .protagonist-thumbnail-content:hover{
      background-color: #cccccc;
      box-shadow: 0px 2px 5px #999999;
    }

    .protagonist-thumbnail-content .protagonist-picture {
      width: 100%;
      height: auto;
    }

      .protagonist-thumbnail-content .protagonist-picture img {
        height: auto;
        width: 100%;
      }

    .protagonist-thumbnail-content .title {
      color: initial;
      line-height: 1.9rem;
      margin: 1rem 0 0 0;
    }

    .protagonist-thumbnail-content .side {
      color: #555555;
      font-size: 0.9rem;
    }

.protagonist-item .protagonist-item-description {
  display: inline-block;
  vertical-align: top;
  width: 70%;
}

  .protagonist-item .protagonist-item-description .protagonist-item-description-content {
    padding-right: 4rem;
    text-align: justify;
  }

    .protagonist-item .protagonist-item-description .protagonist-item-description-content p:first-of-type {
      margin-top: 0;
    }

.protagonist-item .protagonist-item-file {
  display: inline-block;
  vertical-align: top;
  width: 30%;
}

  .protagonist-item .protagonist-item-file img {
    box-shadow: 0px 2px 5px #999999;
  }

  .protagonist-item .protagonist-item-file .protagonist-item-file-title {
    font-weight: bold;
    margin: 0.5rem 0;
  }

  .protagonist-item .protagonist-item-file .protagonist-item-file-army {
    font-size: 1rem;
  }

  .protagonist-item .protagonist-item-gallery .protagonist-item-gallery-item {
    display: inline-block;
    margin: 0.5rem;
    /*outline: 2px solid green;*/
  }

    .protagonist-item .protagonist-item-gallery .protagonist-item-gallery-item img {
      max-height: 150px;
      width: auto;
    }

/**********************/
/* Activities  blocks */
/**********************/

.activity-summary-container {
  /*outline: 1px solid red;*/
  padding-bottom: 50%; /* https://stackoverflow.com/questions/1495407/maintain-the-aspect-ratio-of-a-div-with-css */
  position: relative;
  width: 50%;
}

  .activity-summary-container .activity-summary-content {
    /*outline: 1px solid red;*/
    bottom: 0;
    left: 0;
    margin: 0 1.5rem;
    position: absolute;
    top: 0;
    right: 0;
    overflow: auto;
  }

    .activity-summary-container .activity-summary-content .speaker {
      color: #555555;
      font-size: 1rem;
      line-height: 1.5rem;
      margin-bottom: -0.5rem;
      margin-top: -1.0rem;
    }
    
    .activity-summary-container .activity-summary-content .date {
      margin-bottom: -0.5rem;
    }

    .activity-summary-container .activity-summary-content .details {
      margin-top: -0.5rem;
    }

    .activity-summary-container .activity-summary-content h3 a {
      color: inherit;
    }

      .activity-summary-container .activity-summary-content h3 a:hover {
        text-decoration: underline;
      }

  .activity-summary-container .activity-summary-image {
    background-color: lightgrey;
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 100% auto;
    height: 100%;
    position: absolute;
    top: 0;
    transition-duration: 0.25s;
    width: 100%;
    /*outline: 1px solid green;*/
  }

    .activity-summary-container .activity-summary-image:hover {
      background-size: 120% auto;
      cursor: pointer;
      opacity: 0.9;
    }

    .activity-summary-container .activity-summary-image.portrait {
      background-size: 100% auto;
    }

      .activity-summary-container .activity-summary-image.portrait:hover{
        background-size: 120% auto;
      }

    .activity-summary-container .activity-summary-image.landscape {
      background-size: auto 100%;
    }

      .activity-summary-container .activity-summary-image.landscape:hover{
        background-size: auto 120%;
      }

  .activity-summary-container:nth-child(even) {
    margin-left: 50%;
  }

    .activity-summary-container:nth-child(even) .activity-summary-image {
      right: 100%;
    }

      .activity-summary-container:nth-child(odd) .activity-summary-image {
      left: 100%;
    }

  .activity-summary-container .activity-summary-image-mobile {
    display: none;
  }

.activities-archives-container .activity-item-container {
  clear: both;
  display: block;
  margin: 0;
  padding: 0;
  /*outline: 1px solid red;*/
}

  .activities-archives-container .activity-item-container .activity-item-picture,
  .activities-archives-container .activity-item-container .activity-item-content {
    /*display: inline-block;*/
    margin-bottom: 1.5rem;
    vertical-align: top;
    /*width: 10%;*/
    /*outline: 1px solid red;*/
  }

  .activities-archives-container .activity-item-container .activity-item-picture {
    margin-right: 1rem;
    float: left;
  }

  .activities-archives-container .activity-item-container .activity-item-content {
    padding-left: 7rem;
  }

  .activities-archives-container .activity-item-container .activity-item-content h5 {
    padding-top: 0.75rem;
}

  .activities-archives-container .activity-item-container .activity-item-content h5 a {
    color: inherit;
  }

    .activities-archives-container .activity-item-container .activity-item-content h5 a:hover {
      text-decoration: underline;
    }

.activity-item-title-container {
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  text-align: center;
  position: relative;
}

  .activity-item-title-container * {
    color: #ffffff;
  }

  .activity-item-title-container h1 {
    padding-bottom: 1rem;
    padding-top: 5rem;
  }

  .activity-item-title-container h4 {
    padding-bottom: 3rem;
  }

  .activity-item-title-container h6 {
    font-size: 1rem;
    font-weight: normal;
    margin-top: -1rem;
    padding-bottom: 5rem;
  }

.activity-item .activity-item-description-content {
  /*text-align: justify;*/
}

  .activity-item .activity-item-description-content img {
    max-width: 100%;
    max-height: auto;
  }

.turn-history-item {
  background-color: #ffffff;
  border: 2px solid black;
  border-radius: 3px;
  color: rgba( 10, 10, 10, 1 );
  display: inline-block;
  /*font-weight: bold;*/
  margin: 0 0.5rem 0.5rem 0;
  padding: 0.5rem 1rem;
  text-decoration: none;
  transition: all 0.2s linear;
}

  .turn-history-item:hover {
    background-color: rgba( 10, 10, 10, 1 );
    color: white;
  }

/*****************/
/* Links  blocks */
/*****************/

.link-item-container {
  clear: both;
  display: block;
  margin: 0;
  padding: 0;
  /*outline: 1px solid red;*/
}

.link-item-container .link-item-picture,
.link-item-container .link-item-content {
  /*display: inline-block;*/
  margin-bottom: 1.5rem;
  vertical-align: top;
  /*width: 10%;*/
  /*outline: 1px solid red;*/
}

.link-item-container .link-item-picture {
  margin-right: 1rem;
  float: left;
}

.link-item-container .link-item-content {
  padding-left: 7rem;
}

.link-item-container .link-item-content h5 {
  padding-top: 0.75rem;
}

/*****************/
/* Battle blocks */
/*****************/

.animation-container {
  position: relative;
  padding-bottom: 76.30%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
  max-width: 100%;
}

  .animation-container iframe,
  .animation-container object,
  .animation-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

.animation-item-container {
  display: inline-block; 
}

  .animation-item-container .animation-item-picture,
  .animation-item-container .animation-item-content {
    display: inline-block;
    margin-bottom: 1.5rem;
    vertical-align: top;
    /*width: 10%;*/
    /*outline: 1px solid red;*/
  }

  .animation-item-container .animation-item-picture {
    margin: 0 0.5rem 0 1rem;
  }

/***************/
/* Site blocks */
/***************/

.places-map-container {
  position: relative;
}

  .places-map-container .places-map-image{
    display: block;
    height: 100%;
    width: 100%;
  }

  .places-map-container .marker {
    /*background: url( '../images/site/crosshair.jpg' ) no-repeat center center;*/
    /*background-size: cover;*/
    /*display: inline-block;*/
    /*font-size: 1rem;*/
    /*height: 1rem;*/
    cursor: pointer;
    line-height: 1rem;
    margin: 0;
    padding: 0;
    position: absolute;
    /*width: 1rem;*/
    /*opacity: 0.25;*/
    /*outline: 1px solid red;*/
  }

    /* This is the drop shadow (not used after all) */
    /*.places-map-container .marker:after {
      background-color: rgba( 0, 0, 0, 0.25 );
      border-radius: 50%;
      content: '';
      position: absolute;
      left: 0;
      top: 50%;
      height: 100%;
      width: 100%;
    }*/

    /*.places-map-container .marker .active {
      transform: scale( 0.9, 0.9 );
      transform-origin: bottom;
    }*/

  .map-tooltip-container {
    max-width: 100%;
    margin: 0;
    padding: 0; 
    text-align: left;
    width: 500px;
  }

    .map-tooltip-container.right-image {
      overflow: hidden;
    }

    .map-tooltip-container .tooltip-content-thumbnail {
      background-repeat: no-repeat;
      background-position: top center;
      background-size: cover;
      border-radius: 4px 4px 0 0;
      height: 200px;
    }

      .map-tooltip-container .tooltip-content-thumbnail.right-image {
        border-radius: 0 4px 4px 0;
        height: 100%;
        position: absolute;
        right: 0;
        width: 30%;
      }

    .map-tooltip-container .tooltip-content-text {
      display: inline-block;
      margin: 1rem;
      text-align: left;
      /*outline: 1px solid green;*/
    }

      .map-tooltip-container .tooltip-content-text.right-image{
        width: 65%;
        margin-right: 0;
      }

    .map-tooltip-container .tooltip-content-text h3 {
      margin: 0;
      padding: 0;
    }
    
    .map-tooltip-container .tooltip-content-text p {
      margin-top: 0.5rem;
    }


.location-item-container {
  clear: both;
  display: block;
  margin: 0;
  padding: 0;
  /*outline: 1px solid red;*/
}

  .location-item-container .location-item-picture,
  .location-item-container .location-item-content {
    /*display: inline-block;*/
    margin-bottom: 1.5rem;
    vertical-align: top;
    /*width: 10%;*/
    /*outline: 1px solid red;*/
  }

  .location-item-container .location-item-picture {
    margin-right: 1rem;
    float: left;
  }

  .location-item-container .location-item-content {
    padding-left: 12rem;
  }

    .location-item-container .location-item-content h5 {
      /*padding-top: 0.75rem;*/
    }

  .location-item .location-item-gallery .location-item-gallery-item {
    display: inline-block;
    margin: 0.5rem;
    /*outline: 2px solid green;*/
  }

    .location-item .location-item-gallery .location-item-gallery-item img {
      max-height: 150px;
      width: auto;
    }


/*****************/
/* Custom blocks */
/*****************/

.column-half {
  display: inline-block;
  vertical-align: top;
  width: 49%;
  /*outline: 1px dotted blue;*/
}

/* Filter */
input.input-filter {
  border: 1px solid #cccccc;
  /*box-shadow: 0px 2px 5px #999999;*/
  padding: 0.5rem;
  width: 300px;
  max-width: 95%;
}

/* Buttons */
.btn {
  /*background-color: #758d5c;*/

  background: rgb( 133,166, 98 );
  background: -moz-linear-gradient(top, rgba( 133, 166, 98, 1 ) 0%, rgba( 96, 108, 83, 1 ) 100% );
  background: -webkit-linear-gradient(top, rgba( 133, 166, 98, 1 ) 0%,rgba( 96, 108, 83, 1 ) 100% );
  background: linear-gradient(to bottom, rgba( 133, 166, 98, 1 ) 0%,rgba( 96, 108, 83, 1 ) 100% );
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#85a662', endColorstr='#606c53',GradientType=0 );
  
  border-radius: 0.5rem;
  cursor: pointer;
  display: inline-block;
  padding: 1rem 1.5rem;
  /*transform: perspective( 0 ) translateZ( 15px );*/
}

  .btn:hover{
    opacity: 0.95;
  }

  .btn:active{

  }

.btn-label {
  color: #ffffff;
  line-height: 1.75rem;
  position: relative; 
  text-align: center;
  text-shadow: -1px 0px 0px rgba( 255, 255, 255, 0.3 ), 0px 1px 0px rgba( 120, 120, 120, 0.5 );
  top: 50%; 
  transform: translateY( -50% ); /* Vertically center : https://stackoverflow.com/questions/35388462/vertically-center-a-div-inside-another-div */
}



/**********************/
/* MARGINS & PADDINGS */
/**********************/

/* Sets the margin for the lateral columns */
.wm {
  margin: 0 auto;
  width: 85%;
  /*outline: 1px dotted orange;*/
}

/* Sets the margin for the lateral columns and adds extra margin for visual impact */
.wem {
  margin: 0 auto;
  width: 70%;
  /*outline: 1px dotted red;*/
}

/* Vertical margins */
.mt {
  margin-top: 3rem;
}

.mb {
  margin-bottom: 3rem;
}

.mb-small {
  margin-bottom: 2rem;
}

.mb-xsmall {
  margin-bottom: 1rem;
}

.pt {
  padding-top: 1rem;
}

.pt-large {
  padding-top: 2rem;
}

.pb {
  padding-bottom: 1rem;
}
.pb-large {
  padding-bottom: 2rem;
}

.pl {
  padding-left: 1rem;
}

.pr {
  padding-right: 1rem;
}

.pl-large {
  padding-left: 2rem;
}

.pr-large {
  padding-right: 2rem;
}

/*****************/
/* Media Queries */
/*****************/

@media (max-width: 1023px) {
  h1.big {
    font-size: 3.5rem;
  }

  /* Battle Animation */
  .animation-container {
    padding-bottom: 75.10%;
  }
}

@media (max-width: 900px) {
  h1.big {
    font-size: 2.9rem;
  }

  /* Battle Animation */
  .animation-container {
    padding-bottom: 74.60%;
  }
}

@media (max-width: 768px) {
  
  /* Global styles */
  h2 {
    font-size: 2rem;
  }

  /* Top menu */
  .top-menu-container {
    /*width: 100%;*/
  }

    .top-menu-container h3 {
      display: block;
    }

  .main-navigation {
      position: fixed;
      overflow: auto;
      z-index: 100000;
      width: 100%;
      
      bottom: 0;
      left: -101%;
      top: 0;

      padding: 2rem 0;
      
      /*background-color: #f6f6f6;*/
      background-color: hsla( 222, 80%, 20%, 0.95 );
      color: white;
      
      transition: left 0.25s;
    }

      .main-navigation.active {
        left: 0;
      }

        .main-navigation.active .close-button {
          left: 0;
        }

      .main-navigation .primary-navigation-container {
        /*outline: 1px solid red;*/
      }

    .main-navigation .close-button {
      cursor: pointer;
      display: block;
      font-size: 2.5rem;
      left: -100%;
      margin: 0;
      padding: 1rem;
      position: fixed;
      top: 0;
      transition: left 0.35s;
      z-index: 10000;
    }

      .main-navigation ul {
        margin: 0 0 1rem 0;
        text-align: center;
      }

        .main-navigation ul li {
          width: 100%;
          margin: 0;
          padding: 0;
        }

          .main-navigation ul li a,
          .main-navigation ul li .false-link {
            font-size: 1.25rem;
            margin-bottom: 1rem;
            padding: 0;
          }

            .main-navigation ul li a:hover {
              color: inherit;
            }
          
        .main-navigation .primary-navigation-container > li > a,
        .main-navigation ul li .false-link {
          font-weight: bold;
          margin-top: 1em;
        }

        .main-navigation ul li .false-link {
          text-decoration: underline;
        }

          .main-navigation ul li.current-menu-item {
            text-decoration: none;
          }

        .main-navigation ul ul {
          background-color: transparent;
          box-shadow: none;
          display: block;
          position: relative;
        }

          .main-navigation ul ul:before {
            display: none; 
          }

          .main-navigation ul.no-bullet ul {
            margin-left: 0;
          }

        .main-navigation ul ul li {
          /*float: none;*/
          margin: 0;
          width: 100%;
        }

        .main-navigation ul ul a {
          padding: 0;
          font-weight: 100;
        }

        .main-navigation ul ul ul {
        }

  .main-navigation-hamburger-container {
    display: block;
    height: 3rem;
    /*position: relative;*/
    /*outline: 1px solid red;*/
  }
  
    .main-navigation-hamburger-container .open-button {
      cursor: pointer;
      font-size: 1rem;
      padding: 3px 6px;
      position: absolute;
      right: 8px;
      top: 8px;
    }

      /* Credits to css-tricks for the burger icon: https://css-tricks.com/three-line-menu-navicon/ */
      .main-navigation-hamburger-container .open-button:before {
        border-bottom: 0.125rem solid #000000;
        border-top: 0.375rem double #000000;
        content: '';
        height: 0.125rem;
        position: absolute;
        right: 100%;
        top: 0.5rem;
        width: 1rem;
      }

  /* Main title */
  .main-title-container {
    margin-bottom: 2rem;
  }

  /* Mega title */
    .main-title-container .mega-title h1 {
      font-size: 1.75rem;
      line-height: 2.5rem;
      padding-bottom: 2rem;
      padding-top: 2rem;
    }

    .main-title-container .mega-title h4 {
      font-size: 1.1rem;
      padding-top: 2rem;
      margin-bottom: -4rem;
    }

    .main-title-container .mega-title h6 {
      font-size: 1rem;
      font-weight: normal;
      margin: -2rem 1rem 1rem 1rem;
      padding-bottom: 2rem;
    }

  /* Home page */
  h1 {
    font-size: 2.5rem;
    letter-spacing: 2px;
    margin-top: 1rem;
  }
  
    h1.big {
      font-size: 3rem;
      /* letter-spacing: 3px; */
      margin-top: 1rem;
      margin-bottom: 3rem;
      text-align: center;
    }
    
    h1.big .main-title-subtitle, h1 .subtitle {
      font-size: 1rem;
      letter-spacing: initial;
      margin-top: 1rem;
    }

  h2 {
    text-align: center;
  }

  .home-grid-item .label {
    font-size: 1.4rem;
    text-align: center;
    padding-left: 0; 
  }

  /* Home page */

  .home-grid-item .label {
    font-size: 1.4rem;
    text-align: center;
    padding-left: 0; 
  }

  .home-grid-top-left-item {
    border-radius: 0;
    /*background-size: cover;*/
    /*min-height: 30vh;*/
    padding-bottom: 50%;
    width: 100%;
  }

    .home-grid-top-left-item h3 {
      margin: 0;
    }

    .home-grid-top-left-item .description {
      display: none;
    }

  .home-grid-top-right-top-item {
    border-radius: 0;
    padding-bottom: 50%;
    /*outline: 1px solid blue; */
    width: 100%;  
  }

  .home-grid-top-right-bottom-left-item,
  .home-grid-top-right-bottom-right-item {
    border-radius: 0;
    padding-bottom: 50%;
    width: 50%;
  }

  .home-bottom-navigation-container {
    text-align: center;
  }

    .home-bottom-navigation-block {
      text-align: center;
      min-width: 300px;
    }

      .home-bottom-navigation-block.mb {
        margin-bottom: 1.5rem;
      }

    .guide-cover-container {
      margin-bottom: 2rem;
      text-align: center;
    }

      .guide-cover-container .guide-cta-btn {
        bottom: -1rem;
        right: inherit;
      }

  /* Protagonists */
  .protagonist-thumbnail-container {
    width: 50%;
  }

  .protagonist-item .protagonist-item-description {
    width: 100%;
  }

    .protagonist-item .protagonist-item-description .protagonist-item-description-content {
      padding-right: 0;
    }

    .protagonist-item .protagonist-item-file {
      display: inline-block;
      margin: 0.5rem;
      float: left;
    }

      .protagonist-item .protagonist-item-file {
        width: auto;
          margin-right: 0.5rem;
      }


        .protagonist-item .protagonist-item-file img.responsive {
          max-height: 150px;
          width: auto;
          max-width: 100%;
        }

    .protagonist-item .protagonist-item-gallery .protagonist-item-gallery-item {
      margin: 0.5rem 0 0.5rem 0.5rem;
    }

      .protagonist-item .protagonist-item-gallery .protagonist-item-gallery-item img {
        max-width: 100%;
      }

      .protagonist-item .protagonist-item-file .protagonist-item-file-army,
      .protagonist-item .protagonist-item-file .protagonist-item-file-title {
        display: none;
      }

  /*Publications */
  .books-filter-container {
    text-align: center;
  }

  .book-thumbnail-container {
    width: 50%;
  }

  /* Activities */
  .activity-summary-container {
    padding-bottom: 0;
    width: 100%;
  }

    .activity-summary-container:nth-child(even) {
      margin-left: 0;
    }

    .activity-summary-container .activity-summary-image {
      display: none;
    }

    .activity-summary-container .activity-summary-content {
      margin: 0;
      position: relative;
    }

    .activity-summary-container .activity-summary-image-mobile {
      display: block;
    }


  .activities-archives-container .activity-item-container .activity-item-picture {
    display: none;
  }

  .activities-archives-container .activity-item-container .activity-item-content {
    padding-left: 0rem;
  }

  /* links */
  .link-item-container .link-item-picture .picture.picture-sm {
    height: 4rem;
    width: 4rem;
  }

  .link-item-container .link-item-content {
    padding-left: 5rem;
    word-wrap: break-word;
    /*overflow: hidden;*/
  }

  /* Guide promo */
  .guide-promo-insert-container .guide-promo-insert-cover {
    width: 100%;
  }

    .guide-promo-insert-container .guide-promo-insert-cover img {
      max-height: 15rem;
    }

  .guide-promo-insert-container .guide-promo-insert-intro {
    width: 100%;
    text-align: center;
  }

  /* Footer */

  .footer-language-selection-container {
    text-align: center;
    margin: 0.5rem 0 1rem 0;
    width: 100%;
  }

  .footer-miscellaneous-container {
    width: 100%;
  }

    .footer-miscellaneous-container .footer-link-author-container,
    .footer-miscellaneous-container .footer-copyright-container {
      text-align: center;
    }

    .footer-miscellaneous-container .footer-privacy-container {

    }

  /* Modifiers */
  .wm {
    width: 100%;
  }

  .wem {
    width: 90%;
  }

    /*.wem img.responsive {
      max-width: 100%;
      box-sizing: border-box;
    }*/
  
  .main-title-container .wem {
    width: 95%;
  }

  /* For elements hidden in small screens */
  .sm-hidden {
    display: none;
  }

  /* For elements that are displayed full width on small screens */
  .sm-full-width {
    width: 100%;
  }

  /* Battle Animation */
  .animation-container {
    padding-bottom: 75.00%;
  }

}

@media (max-width: 700px) {

  .home-grid-news-container .wm {
    width: 90%;
  }

  .home-grid-news-container .bg-map {
    background: none;
  }

  /* Remove shadow and BG color between the blocks */
  .home-grid-news-height-definer {
    background-color: transparent;
    box-shadow: none;
  }
  
    .home-grid-news-height-definer .home-grid-news-item {
      padding-bottom: 100%;
      width: 100%;
      /* Insert a small separation between the news blocks */  
      margin-bottom: 1rem;
      -webkit-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
      -moz-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
      box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
    }

      .home-grid-news-height-definer .home-grid-item .label {
        text-align: center;
      }

  /* Cookie consent policy */
  .cookie-consent-container {
    width: auto;
  }

  /* Battle Animation */
  .animation-container {
    padding-bottom: 74.60%;
  }
}

@media (max-width: 500px) {

  p {
    hyphens: auto;
  }

  /* Home page */
  .home-grid-item .label {
    font-size: 1.1rem;
  }

  .home-grid-news-container .wm {
    width: 90%;
  }

  .home-grid-news-container .bg-map {
    background: none;
  }

  /* Remove shadow and BG color between the blocks */
  .home-grid-news-height-definer {
    background-color: transparent;
    box-shadow: none;
  }
  
    .home-grid-news-height-definer .home-grid-news-item {
      padding-bottom: 100%;
      width: 100%;
      /* Insert a small separation between the news blocks */  
      margin-bottom: 1rem;
      -webkit-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
      -moz-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
      box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
    }

      .home-grid-news-height-definer .home-grid-item .label {
        text-align: center;
      } 


  /* Locations */ 
  .location-map-container {
    display: none;
  }
  
  .location-item-picture {
    display: block;
    clear: both;
    width: 100%;
    /*outline: 1px solid red;*/
  }

  .location-item-picture .picture-lg {
    border-radius: 0;
    /*height: 6rem;*/
    width: 100%;
    /*outline: 1px solid green;*/
  }

  .location-item-container .location-item-content {
    padding-left: 0;
  }

  /* Publications */
  .book-item .book-item-description {
    width: 100%;
  }

    .book-item .book-item-description .book-item-description-content {
      padding-right: 0;
    }

  .book-item .book-item-file {
    width: 100%;
  }

    .book-item .book-item-file img.responsive {
      max-width: 100%;
    }

  /* Battle Animation */
  .animation-container {
    padding-bottom: 72.50%;
  }

}

@media (max-width: 350px) {
  /* Battle Animation */
  .animation-container {
    padding-bottom: 69.00%;
  }
}

/* Modifiers */

.pull-right{
  text-align: right;
}

.align-center {
  text-align: center;
}

.text-xs {
  font-size: 65%;
}

.text-sm {
  font-size: 75%;
}

.text-reg {
  font-size: 100%;
}

.text-med {
  font-size: 125%;
  line-height: 1.5rem ;
}

.text-lg {
  font-size: 150%;
}

.text-xl {
  font-size: 175%;
}

.text-xxl {
  font-size: 200%;
}

.text-small-caps {
  font-variant: small-caps;
}

.hidden {
  display: none;
}

/* with shadow */
.shadow {
  -webkit-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
  -moz-box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
  box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
}

.yellow-shadow {
  /*box-shadow: 0px 5px 50px 0px rgba( 249, 236, 163, 0.75 ); /* Whitish yellow / Yellowish white */
  box-shadow: 0px 2px 5px 1px rgba( 0, 0, 0, 0.4 );
}

/* Frame (for pictures) */
.framed {
  border: 10px solid white;
}

.picture {
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  display: inline-block;
}

  .picture.picture-xxs {
      height: 1.5rem;
      width: 1.5rem;
  }

  .picture.picture-xs {
      height: 3rem;
      width: 3rem;
  }

  .picture.picture-sm {
      height: 5rem;
      width: 5rem;
  }

  .picture.picture-md {
      height: 7rem;
      width: 7rem;
  }

  .picture.picture-lg {
      height: 10rem;
      width: 10rem;
  }

.round {
  border-radius: 50%;
}

/* Clearfix (as per Nicolas Gallagher - http://nicolasgallagher.com/micro-clearfix-hack/) */
.cf:before,
.cf:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.cf:after {
    clear: both;
}

/**
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.cf {
    *zoom: 1;
}

/* End of clearfix */

/* Frame */
.frame {
  border: 10px solid;
  border-radius: 10px;
  display: inline-block;
  padding: 0 7px;
}

  .frame.yellow {
    color: #fddf0b;
  }

/* Rounded corners for div */
.rounded-corners {
  border-radius: 7px;
}

/* Box inset shadow */
.inset-shadow {
  box-shadow: inset 2px 2px 10px grey;
}

/* White BG div */
.bg-white {
  background-color: #e3e3e3;
}

  /* Mapped BG div with vertical margins */
  .bg-white.vm {
    position: absolute;
    top: 1.5rem;
    bottom: 1.5rem;
    left: 0;
    right: 0;
    z-index: -10;
  }