@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 300;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-300.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-300.woff') format('woff');
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: italic;
  font-weight: 300;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-300italic.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-300italic.woff') format('woff');
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-regular.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-regular.woff') format('woff');
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: italic;
  font-weight: 400;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-italic.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-italic.woff') format('woff');
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 600;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-600.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-600.woff') format('woff');
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: italic;
  font-weight: 600;
  src: local(''),
       url('fonts/source-sans-pro-v14-latin-600italic.woff2') format('woff2'),
       url('fonts/source-sans-pro-v14-latin-600italic.woff') format('woff');
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
        margin: 0;
        padding: 0;
        border: 0;
        font-size: 100%;
        font: inherit;
        vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
        display: block;
}
body {
        line-height: 1;
}
ol, ul {
        list-style: none;
}
blockquote, q {
        quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
        content: '';
        content: none;
}
table {
        border-collapse: collapse;
        border-spacing: 0;
}

/*----*/

body {
  font-size: 19px;
  line-height: 125%;
  font-family: 'Source Sans Pro', sans-serif;
  font-weight: 300;
  margin-bottom: 50px;
}

a {
  color: #08335f;
}

b, strong {
  font-weight: 400;
}

i, em {
  font-style: italic;
}

.topbar {
  background-color: #116fcf;
  height: 10px;
}

ul.langnav {
  font-size: 75%;
  max-width: 1060px;
  margin: 0 auto;
  text-align: right;
  margin-bottom: 10px;
}

ul.langnav li {
  display: inline;
  margin-left: 8px;
}

ul.langnav a {
  color: #666;
  text-decoration: none;
}

ul.langnav a:hover {
  color: #000;
  text-decoration: underline;
}


.logo {
  max-width: 1060px;
  margin: 0 auto;
  margin-bottom: -20px;
  padding: 0 0 0 0;
  font-weight: 400;
  font-size: 125%;
  line-height: 125%;
}

.logo-text {
  display: inline-block;
  vertical-align: top;
}

.logo-text img {
  width: 220px;
}

.logo small {
  font-size: 75%;
  line-height: 125%;
  font-weight: 300;
}

ul.nav {
  max-width: 1060px;
  margin: 0 auto;
  text-align: right;
  padding-right: 3px;
  font-weight: 400;
}

ul.nav li {
  display: inline-block;
  height: 5ex;
}

ul.nav a {
  margin-right: 18px;
  text-decoration: none;
  color: #000;
  padding-bottom: 14px;
}

ul.nav a:hover {
  background-image: url("nav_arrow_select.png");
  background-repeat: no-repeat;
  background-position: bottom center;
}

ul.nav a.active {
  background-image: url("nav_arrow_active.png");
  background-repeat: no-repeat;
  background-position: bottom center;
}

ul.nav li:last-child a {
  margin-right: 0;
}

.mainbox {
  xbackground-color: #116fcf;
  color: #fff;
  overflow: auto;
}

.page-index .mainbox {
  margin-top: 20px;
}

.mainbox a {
  color: #fff;
}

.mainbox-inner {
  background-color: #116fcf;
  max-width: 1060px;
  margin: 0 auto;
  border-radius: 3px;
}

.mainbox-image {
  height: 320px;
  width: 512px;
  display: inline-block;
  position: relative;
  overflow: hidden;
}

.mainbox-image img {
  position: absolute;
  height: 320px;
  left: 512px;
  border-radius: 3px 0 0 3px;
}

.mainbox-image img:first-child {
  position: absolute;
  width: 100%;
  left: 0;
}

.mainbox-content {
  margin-top: 10px;
  margin-left: 40px;
  display: inline-block;
  width: 316px;
  vertical-align: top;
}

.mainbox-content > div {
  width: 446px;
  position: absolute;
  opacity: 0;
  display: none;
}
  


.mainbox-content > div:first-child {
  position: absolute;
  opacity: 1;
  display: block;
}

.mainbox h1 {
  max-width: 1060px;
  margin: 0 auto;
  font-size: 125%;
  line-height: 125%;
  font-weight: 600;
  padding: 20px 0;
}

.mainbox > h1 {
  color: #000;
  border-top: 5px solid #116fcf;
  padding-top: 40px;
  font-size: 150%;
}

.mainbox p {
  padding-bottom: 1ex;
  font-weight: 300;
  text-align: justify;
  font-size: 90%;
  line-height: 125%;
}

.mainbox p.big {
  font-size: 100%;
  font-weight: 300;
}

.path {
  max-width: 1060px;
  margin: 0 auto;
}

.page {
  max-width: 1060px;
  margin: 0 auto;
  margin-top: 10px;
}

.page-index .page {
  margin-top: 40px;
}

.page .main {
  vertical-align: top;
  display: inline-block;
  width: 689px;
  padding-top: 0px;
  padding-right: 50px;
  font-size: 90%;
  line-height: 125%;
}

.page .main h2 {
  margin-top: 3ex;
  font-weight: 400;
  font-size: 133%;
  line-height: 110%;
  margin-bottom: 0.5ex;
}


.page .main .tag {
  font-size: 85%;
  background: #aaa;
  color: #fff;
  line-height: 125%;
  display: inline-block;
  border-radius: 3px;
  padding: 0 2px;
  font-weight: 600;
}


.page .main h2 a {
  color: #000;
  text-decoration: none;
}

.page .main h2 a:hover {
  color: #116fcf;
  text-decoration: underline;
}

.page .main h2 small {
  font-size: 75%;
}

.page .main .article {
  margin-bottom: 40px;
}

.page .main .article .readmore {
  margin-top: 1ex;
}

.page .main .author {
  margin-bottom: 2ex;
}

.page .main .article p {
  margin-bottom: 1ex;
}

.page .main ol {
 list-style-type: decimal;
 padding-left: 2em;
 margin-bottom: 2ex;
 line-height: 133%;
}

.page .sidebar {
  vertical-align: top;
  display: inline-block;
  width: 320px;
  margin-top: 60px;
  font-size: 90%;
  line-height: 125%;
}

.page .sidebar > div {
  xborder: 1px solid #bbb;
  padding: 5px 0px;
  margin-bottom: 4ex;
}

.page .sidebar img {
  max-width: 320px;
  width: 320px;
  border-radius: 3px;
}

.page .sidebar .caption {
  border-top: none;
}

.page .sidebar div img {
  max-width: 297px;
}

.page .sidebar a {
  font-weight: 400;
}

.page .sidebar .reference {
  font-style: italic;
  float: right;
}

.col3 > div:last-child {
  margin-right: 0;
}

.page h3 {
  font-weight: 400;
  margin-top: 3ex;
  margin-bottom: 0.5ex;
  font-size: 111.1%;
  line-height: 125%;
}

.page h4 {
  font-weight: 400;
  margin-top: 0.5ex;
  margin-bottom: 0.5ex;
  font-size: 111.1%;
  line-height: 125%;
}

.page .main blockquote {
  background-color: #ddd;
  padding: 1ex 1em;
  margin: 2ex 0 3ex 0;
}

.page .main ul {
  padding-left: 2em;
  list-style-type: disc;
  margin-bottom: 2ex;
  line-height: 133%;
}

.page .main ul ul {
  margin-bottom: 0;
}

.page .main figure img {
  max-width: 100%;
  display: flex;
  margin: 2ex auto 1ex auto;
}

.page .main figure figcaption {
  font-style: italic;
  text-align: center;
  width: 90%;
  display: flex;
  margin: 0 auto 4ex auto;
}

.page .main .references:before {
  content: "________";
  font-style: normal;
}

.page .main .references {
  margin-top: 3ex;
  font-style: italic;
}

.page .main .quote {
  background: #bbb;
  color: #000;
  padding: 1ex 1em;
  text-decoration: none;
  margin: 1ex 0;
  display: inline-block;
  border-radius: 8px;
  font-weight: bold;
  background: #666666;
  color: #fff;
  font-size: 0.8em;
}

.page .main .source {
  font-style: italic;
  font-weight: normal;
}

.page .main .flexrow  {
  display:flex; 
  flex-direction: row; 
  flex-wrap: wrap; 
  padding: 20px 20px 20px 0px;"
}

.page .main .flexcol1  {
  display: flex; 
  flex-direction: column; 
  flex-basis: 100%; 
  flex: none;
}

.page .main .flexcol2  {
  display: flex; 
  flex-direction: column; 
  flex-basis: 100%; 
  flex: 1;
}


a.button {
  background: #bbb;
  color: #000;
  padding: 1ex 1em;
  text-decoration: none;
  margin: 1ex 0;
  display: inline-block;
  border-radius: 8px;
  font-weight: bold;
}

a.button-primary {
  background: #116ECF;
  color: #fff;
}

a.button-secondary {
  background: #666666;
  color: #fff;
}

@media (max-width: 870px) {
  ul.langnav,
  .logo,
  ul.nav,
  .mainbox-content,
  .mainbox-content > div,
  .mainbox h1,
  .path,
  .page,
  .page .main,
  .page .sidebar {
    width: 512px;
  }
  .mainbox h1 {
    margin: 0 auto;
    text-align: left;
  }
  ul.nav {
    text-align: left;
  }
  .mainbox {
    text-align: center;
  }
  .mainbox-content {
    margin-left: 0;
    min-height: 240px;
    height: auto;
  }
  .logo {
    margin-bottom: 20px;
  }
}


@media (max-width: 512px) {
  ul.langnav,
  .logo,
  ul.nav,
  .mainbox-content,
  .mainbox-content > div,
  .mainbox h1,
  .path,
  .page,
  .page .sidebar,
  .page .main {
    width: 95%;
  }
  .mainbox-image {
    display: none;
  }
  .mainbox-content {
    margin-left: 0;
    min-height: 320px;
    height: auto;
  }
  .mainbox-content h1 {
    margin-left: 0;
  }
}
