/*  CSS document  */
@CHARSET "UTF-8";

@import url('https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,300i,400,600&display=swap&subset=latin-ext');

body, header, div, ul, li, p, h1, h2, h3, h4, h5, figure {padding:0;margin:0;font-size:15pt;font-weight:300;font-family: 'Source Sans Pro', sans-serif, Arial, Helvetica}
header, nav, section, footer {width: 100%;max-width:640px;height:auto;margin:0px auto;background-color:#ffffff;}
body {background-color:#ffffff;}

body * {
	box-sizing: border-box;
}

a,
h1 a,
h2 a,
a:visited,
h1 a:visited,
h2 a:visited {
	color: #000;
	text-decoration: none;
}

.bottom_25 {
	padding-bottom: 25px!important;
}
.bottom_50 {
	padding-bottom: 50px!important;
}
.bottom_75 {
	padding-bottom: 75px!important;
}
.bottom_100 {
	padding-bottom: 100px!important;
}
.do_bottom_10 {
   margin-bottom: 10px!important;
}
.do_bottom_25 {
	margin-bottom: 25px!important;
}
.do_bottom_50 {
	margin-bottom: 50px!important;
} 
.do_bottom_75 {
	margin-bottom: 75px!important;
} 
.do_bottom_100 {
	margin-bottom: 100px!important;
} 

.width_50 {
	width: 50%!important;
}

.to_left {
	float:left;
}

a.button_more { 
	box-sizing: border-box;
   padding: 10px 50px 10px 20px;
   margin: 50px 0;
   display: block;
   color: #fff;
   float: right;
   clear: both;
   font-weight: 300!important;
   font-style: inherit!important;
   text-transform: uppercase;
   cursor: pointer;
	background: url('../images/bulletin/button_more.svg') #cc3333 100% 50% no-repeat;
}

.border-top {
   border-top: 1px dotted #cdcdcd;
   padding-top: 40px;
}

.border-bottom {
   border-bottom: 1px dotted #cdcdcd;
   padding-bottom: 40px;
}

.position-static {
	position: static !important;
}

.text-center {
	text-align: center !important;
}

figure h1 + .box-button {
	margin-top: 0;
}

.box-button {
	display: flex;
	justify-content: center;
	margin-top: 20px;
}

.box-button > a {
   background-color: #e31f23;
   color: #ffffff;
   padding: 10px;
   text-decoration: none;
   border: 1px solid #e31f23;
   transition: .3s;
}

.box-button > a:hover {
   background-color: #ffffff;
   color: #e31f23;
}


/* clearing */
div.clear {
	width: 100%;
	height: 1px;
	content: '';
	clear: both;
}
/* ----------------- */

header {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	margin: 10px auto;
}

header img.logo {
	width: 100%;
	max-width: 140px;
	min-width: 100px;
	display: block;
}
header > p > strong {
	display: inline-block;
	text-transform: uppercase;
	font-weight: normal;
	font-size: 110%;
}
header > span {
	display: block;
	padding: 25px 10px 25px 25px;
	letter-spacing: 2px;
	text-align: right;
	vertical-align: middle;
	border-left: 1px dotted silver;
}

section main h2 {
	font-size: 20pt;
	padding-top: 15px;
	margin-bottom: 30px;
}

section main h3 {
	font-size: 16pt;
}

section > figure {
	position: relative;
}
section > figure img.main {
	width: 100%;
}
section > figure img.h1,
section > figure h1 {
	position: absolute;
}
section > figure.catalogue {
	/*margin-top: 60px;*/
	padding: 40px 60px 60px;
	/*border-top: 1px dotted #cdcdcd;*/
	position: relative;		
}
section > figure.catalogue h2 {
	font-size: 16pt;
	margin-bottom: 30px;
}
section > figure.catalogue img {
	width: 75%;
}
section > figure.catalogue img.free {
   position: absolute;
   right: 7%;
   bottom: 10px;
   width: 40%;
}
section > figure.catalogue a.order {
	position: absolute;
	right: 13%;
	bottom: -13%;
	font-weight: 600;
	text-transform: uppercase;
	display: block;
	text-align: center;
}

section > ul,
main > ul,
main > ul > li > ul,
footer > ul {
	list-style-type: none;
	display: flex;
}
main > ul {
	flex-direction: column;
}
main > ul > li {
	padding: 35px 0 0 0;
}
main > ul > li > ul {
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: left;
	align-items: center;
}
main > ul > li > ul > li {
	align-self: flex-start;
}
main > ul > li > ul > li:nth-child(2n+1) {
	padding: 15px;
}
main > ul > li > ul > li:nth-child(2n) {
	width: 100%;
	padding: 0 20px;
}
main > ul > li > ul > li > p {
	padding-top: 0;
}
main > ul > li > ul > li > a {
	float: right;
	text-decoration: none;
	font-style: italic;
}
main > ul > li > ul > li > a:after {
	content: ' ...';
}

footer {
	padding-top: 60px;
	padding-bottom: 15px;
	margin-top: 90px;
	border-top: 1px dotted #cdcdcd;
}
footer > ul.social {
	width: 80%;
	margin: 0 auto 30px auto;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-around;
	align-items: center;
}
footer > ul.social > li > h2 {
	text-align: center;
}
footer > ul.social > li > a {
	margin-right: 10px;
}
footer > ul.social > li.separator {
	padding: 0 10px;
}
footer > ul.social > li.separator > span {
	width: 1px;
	height: 30px;
	display: block;
	border-right: 1px solid #cdcdcd;
}

footer > ul.company {
	width: 95%;
	margin: 0 auto 30px auto;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
}
footer > p,
footer > ul.company p {
	text-align: center;
}

footer > ul.showof {
	width: 100%;
	margin: 0 auto 30px auto;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}
footer > ul.showof > li > img {
	max-height: 60px;
}
footer > p {
	font-size: 12pt;
}


#page header {
	justify-content: flex-start;
}

#page nav {
	padding: 20px 20px 40px 20px;
	text-transform: uppercase;
	font-size: 12pt;
}

#page section {
	padding: 0 20px;
}

#page section h1,
#page section h2 {
	font-size: 24pt;
	font-weight: 400;
	padding: 25px 0 20px 0;
}
#page section h2 {
	font-size: 20pt;
}

#page section p {
	font-size: 16pt;
	line-height: 22pt;
	padding: 5px 0 15px 0;
}
#page section p.perex {
	color: #005ec5;
}

#page section main img {
	width: 100%;
}

#page section a.back {
	display: block;
	margin: 30px 0 50px 0;
	float: left;
   font-style: normal;
   color: #0b6ec7;
}   

#page section.register {
	margin-top: 30px;
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-around;
	align-items: flex-start;
}
#page section.register p {
	font-size: 12pt;
	line-height: 15pt;
	padding: 0 0 0 10px;
}
#page section.register p a {
	font-weight: 600;
}
#page section.register img {
	width: 8%;
	margin-top: 3px;
}
