
body {
	max-width: 480px;
	min-width: 380px;
	-webkit-text-size-adjust: 100%;
}

h2.subtitle {
	font-size: 24px;
}

h3.subtitle {
	font-size: 20px;
	text-align: justify;
}

h3.copy {
	font-size: 20px;
	padding: 10px 0 15px 0;
}

.df {
	display: none;
}

.sp {
	display: inline;
}

div.sp {
	display: block;
}

img.spwideimg {
	height: auto;
	width: 100%;
}

span.img-left,
span.img-right {
	display: block;
	float: none;
	margin: 0;
	padding-bottom: 10px;
	text-align: center;
}

p.spjustify {
	text-align: justify;
}

a.link-btn,
div.page span.next a,
div.page a.next {
	background-position: right 15px center;
	line-height: 1.5em;
	margin: 5px 0;
	padding: 12px 35px 12px 30px;
}

a.link-btn:hover,
div.page span.next a:hover,
div.page a.next:hover {
	background-position: right 10px center;
}

a.link-btn-prev,
div.page span.prev a,
div.page a.prev {
	background-position: left 15px center;
	line-height: 1.5em;
	margin: 5px 0;
	padding: 10px 30px 10px 35px;
}

a.link-btn-prev:hover,
div.page span.prev a:hover,
div.page a.prev:hover {
	background-position: left 10px center;
}

/***********************************************************************/

ul.photos li img {
	height: auto;
	max-width: 100%;
}

table.list-table th {
	display: block;
	padding: 10px;
	width: auto;
}

table.list-table td {
	border: none;
	display: block;
	padding: 10px 15px 20px 15px;
}

/***********************************************************************/

table.form-table tr {
	display: block;
	position: relative;
}

table.form-table th {
	border: none;
	display: block;
	padding: 10px 20px;
	text-align: left;
	width: auto;
}

table.form-table td {
	border: none;
	clear: both;
	display: block;
	line-height: 1.5em;
	margin-bottom: 15px;
	padding: 10px 20px;
}

table.form-table td.m {
	background-color: #102a52;
	border: none;
	display: block;
	float: right;
	height: 30px;
	padding: 2px;
	position: absolute;
	right: 10px;
	top: 5px;
	width: 30px;
}

table.form-table td.m span {
	display: table-cell;
	font-size: 12px;
	line-height: 1em;
	vertical-align: middle;
}

table.form-table td input.size500,
table.form-table td input.size400,
table.form-table td input.size300,
table.form-table td input.size200,
table.form-table td textarea {
	width: 95%;
}

table.form-table td table th,
table.form-table td table td {
	display: table-cell;
}

input.submit {
	display: block;
	font-size: 20px;
	margin: 0 auto;
	padding: 20px 0;
	width: 90%;
}

body#form p.error {
	padding: 30px 20px;
}

body#form table.form-table th {
	padding: 8px 20px;
}

body#form table.form-table td {
	padding: 10px 20px 20px 20px;
}

/***********************************************************************/

ul.news-list {
	width: auto;
}

ul.news-list li a {
	background-position: right 30px center;
	display: block;
	padding: 14px 60px 14px 40px;
}

ul.news-list li a span.date {
	display: block;
	font-size: 14px;
	padding: 0 0 5px 0;
}

div.page a.next {
	display: inline;
	padding: 8px 50px 8px 30px;
}

div.page a.prev {
	display: inline;
	padding: 8px 30px 8px 50px;
}

body#single h1 {
	background-image: none;
	font-size: 22px;
	line-height: 1.5em;
	padding-top: 20px;
}

body#single div.body {
	padding: 0 0 20px 0;
	width: auto;
}

body#single div.body h2 {
	font-size: 120%;
}

body#single div.body figure {
	height: auto;
	margin: 10px 0;
	padding: 0;
	width: auto;
}

body#single div.body figure img {
	height: auto;
	width: 100%;
}

body#single div.body figure figcaption {
	font-size: 14px;
	line-height: 1.5em;
}

/***********************************************************************/

#header {
	padding-top: 10px;
	width: 100%;
}	

#header-logo {
	margin-left: 20px;
}

#header-logo img {
	width: 170px;
}

#hamburger {
	background-color: #102a52;
	background-color: rgba(16, 42, 82, .6);
	border-radius: 50%;
	display: block;
	height: 50px;
	position: absolute;
	right: 5px;
	top: 5px;
	width: 50px;
	z-index: 999;
}

#hamburger:hover {
	cursor: pointer;
	opacity: .7;
}

#hamburger span,
#hamburger span:before,
#hamburger span:after {
	background-color: white;
	display: block;
	height: 3px;
	position: absolute;
	transition-duration: .3s;
	transition-property: transform;
	width: 34px;
}

#hamburger span {
	left: 8px;
	top: 50%;
}

#hamburger span:before {
	content: "";
	transform: translateY( -10px ) rotate( 0deg );
}

#hamburger span:after {
	content: "";
	transform: translateY( 10px ) rotate( 0deg );
}

#hamburger.open span {
	background: transparent !important;
}

#hamburger.open span:before {
	transform: rotate( 45deg ) !important;
}

#hamburger.open span:after {
	transform: rotate( -45deg ) !important;
}

nav#globalnav {
	background-color: white;
	display: none;
	margin-right: 0;
	padding: 0;
	position: absolute;
	top: 55px;
	width: 100%;
	z-index: 5;
}

nav#globalnav ul {
	display: block;
	padding-bottom: 0;
}

nav#globalnav ul li {
	border-left: none;
	display: block;
	text-align: center;
}

nav#globalnav ul li {
	border-bottom: 1px solid #102a52;
	padding: 0;
}

nav#globalnav ul li a {
	background: white url(images/link_btn_black.svg) no-repeat right 20px center;
	background-size: 6px;
	color: black;
	display: block;
	padding: 15px 26px;
}

nav#globalnav ul li a:hover {
	background-position: right 15px center;
	opacity: .6;
	transition: all .3s;
}

#title {
	height: 120px;
	position: relative;
	width: auto;
}

#title h1 {
	background-color: #e0e3eb;
	bottom: -20px;
	font-size: 30px;
	padding: 5px 0 5px 20px;
	position: absolute;
	text-indent: 10px;
	width: 90%;
}

#title h1:after {
	bottom: 8px;
	left: 20px;
	margin-left: 0;
	position: absolute;
	width: calc(100% - 30px);
}

#title h1 em {
	font-size: 14px;
	padding-top: 10px;
}

#title-s {
	padding-top: 20px;
	width: auto;
}

#title-s a {
	font-size: 24px;
}

div.main,
div.main-s,
div.main-c,
div.spmain {
	padding: 0 20px;
	width: auto;
}

footer {
	background-color: #efefef;
}

#fcontact {
	padding: 20px;
}

#fcontact-text {
	padding-left: 0;
	width: auto;
}

#fcontact-text h2 {
	position: static;
}

p#fcontact-tel {
	flex-wrap: wrap;
	justify-content: center;
	position: relative;
}

p#fcontact-mail {
	position: relative;
}

p#fcontact-tel img,
p#fcontact-mail a img {
	height: auto;
	left: 28px;
	padding: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

p#fcontact-tel img {
	width: 32px;
}

p#fcontact-mail a img {
	width: 30px;
}

p#fcontact-tel span {
	padding: 0;
	text-align: center;
	width: 100%;
}

p#fcontact-tel a {
	font-size: 28px;
	padding: 10px 0;
	text-decoration: none;
}

p#fcontact-mail a {
	background-position: right 32px center;
	display: block;
	padding: 30px;
	text-align: center;
}

p#fcontact-tel em {
	font-size: 12px;
}

#footer {
	display: block;
	padding: 50px 0 20px 0;
	text-align: center;
	width: auto;
}

#footer-address {
	padding: 0 20px;
	width: auto;
}

#footer-address h3 {
	text-align: center;
}

#footer-address h3 a img {
	height: auto;
	width: 250px;
}

#footer-address p {
	font-size: 14px;
	text-align: center;
}

#footer-address p a {
	color: white;
	text-decoration: none;
}

#footer-address address {
	font-size: 14px;
}

a#footer-sotec img {
	margin: 20px 0 50px 0;
}

nav#footernav {
	display: block;
	padding: 0;
}

nav#footernav ul {
	display: block;
	padding: 0;
	width: auto;
}

nav#footernav ul:first-child {
	border-bottom: none;
	padding-right: 0;
	width: 100%;
}

nav#footernav ul li {
	border: none;
	border-bottom: 1px solid #102a52;
	display: block;
	padding: 0;
}

nav#footernav ul li a {
	background: white url(images/link_btn_black.svg) no-repeat right 20px center;
	background-size: 6px;
	color: black;
	display: block;
	font-size: 14px;
	padding: 13px 26px;
	text-align: center;
}

nav#footernav ul li a:hover {
	background-position: right 15px center;
}

nav#footernav ul li a:after {
	display: none;
}

nav#footernav ul li ul {
	display: block;
	margin: 0;
	padding: 0;
}

nav#footernav ul li ul li,
nav#footernav ul li ul li:last-child {
	border-top: 1px solid #84b698;
	display: block;
}

nav#footernav ul li ul li a {
	padding: 7px 0;
}

nav#footernav ul li ul li a::before {
	content: "";
	margin-right: 0;
}

nav#footernav ul li ul li a {
	background-image: none;
}

p#copyright {
	background-color: #071325;
	font-size: 11px;
	line-height: 1.5em;
	margin-top: 30px;
	padding: 15px;
	text-align: justify;
	width: auto;
}

#pagetop {
	right: 10px;
}