/** Reset some basic elements */
@import url(http://fonts.googleapis.com/css?family=Open+Sans:700,300,600,800,400);
@import url(http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css);
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font-family: "Open Sans", Helvetica, Arial, sans-serif; font-size: 16px; line-height: 1.5; font-weight: 300; color: #111; background-color: #fdfdfd; -webkit-text-size-adjust: 100%; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-weight: 300; }

/** Links */
a { color: #2a7ae2; text-decoration: none; }
a:visited { color: #1756a9; }
a:hover { color: #111; text-decoration: underline; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }
blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: scroll; }
pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }
@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.wrapper:after, .footer-col-wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.icon > svg { display: inline-block; width: 16px; height: 16px; vertical-align: middle; }
.icon > svg path { fill: #828282; }

/** Site header */
.site-header { border-top: 5px solid #424242; border-bottom: 1px solid #e8e8e8; min-height: 56px; position: relative; }

.site-title { font-size: 26px; line-height: 56px; letter-spacing: -1px; margin-bottom: 0; float: left; }
.site-title, .site-title:visited { color: #424242; }

.site-nav { float: right; line-height: 56px; }
.site-nav .menu-icon { display: none; }
.site-nav .page-link { color: #111; line-height: 1.5; }
.site-nav .page-link:not(:first-child) { margin-left: 20px; }
@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 30px; background-color: #fdfdfd; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; }
  .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; }
  .site-nav .menu-icon > svg { width: 18px; height: 15px; }
  .site-nav .menu-icon > svg path { fill: #424242; }
  .site-nav .trigger { clear: both; display: none; }
  .site-nav:hover .trigger { display: block; padding-bottom: 5px; }
  .site-nav .page-link { display: block; padding: 5px 10px; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; padding: 30px 0; background-color: #353535; color: #fff; text-align: center; font-size: 20px; }

.site-footer a, .site-footer a:visited { color: #fff; vertical-align: middle; }

.site-footer a:hover { color: #2df585; text-decoration: none; vertical-align: middle; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(20% - (30px / 2)); width: calc(20% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(45% - (30px / 2)); width: calc(45% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); }
  .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
@media screen and (max-width: 600px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }
/** Page content */
.page-content { padding: 30px 0; }

.page-heading { font-size: 25px; font-weight: 700; color: #353535; }

.post-list { margin-left: 0; list-style: none; }
.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { font-size: 42px; letter-spacing: -1px; line-height: 1; }
@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }
.post-content h2 { font-size: 32px; }
@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }
.post-content h3 { font-size: 26px; }
@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }
.post-content h4 { font-size: 20px; }
@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Syntax highlighting styles */
.highlight { background: #fff; }
.highlight .c { color: #998; font-style: italic; }
.highlight .err { color: #a61717; background-color: #e3d2d2; }
.highlight .k { font-weight: bold; }
.highlight .o { font-weight: bold; }
.highlight .cm { color: #998; font-style: italic; }
.highlight .cp { color: #999; font-weight: bold; }
.highlight .c1 { color: #998; font-style: italic; }
.highlight .cs { color: #999; font-weight: bold; font-style: italic; }
.highlight .gd { color: #000; background-color: #fdd; }
.highlight .gd .x { color: #000; background-color: #faa; }
.highlight .ge { font-style: italic; }
.highlight .gr { color: #a00; }
.highlight .gh { color: #999; }
.highlight .gi { color: #000; background-color: #dfd; }
.highlight .gi .x { color: #000; background-color: #afa; }
.highlight .go { color: #888; }
.highlight .gp { color: #555; }
.highlight .gs { font-weight: bold; }
.highlight .gu { color: #aaa; }
.highlight .gt { color: #a00; }
.highlight .kc { font-weight: bold; }
.highlight .kd { font-weight: bold; }
.highlight .kp { font-weight: bold; }
.highlight .kr { font-weight: bold; }
.highlight .kt { color: #458; font-weight: bold; }
.highlight .m { color: #099; }
.highlight .s { color: #d14; }
.highlight .na { color: #008080; }
.highlight .nb { color: #0086B3; }
.highlight .nc { color: #458; font-weight: bold; }
.highlight .no { color: #008080; }
.highlight .ni { color: #800080; }
.highlight .ne { color: #900; font-weight: bold; }
.highlight .nf { color: #900; font-weight: bold; }
.highlight .nn { color: #555; }
.highlight .nt { color: #000080; }
.highlight .nv { color: #008080; }
.highlight .ow { font-weight: bold; }
.highlight .w { color: #bbb; }
.highlight .mf { color: #099; }
.highlight .mh { color: #099; }
.highlight .mi { color: #099; }
.highlight .mo { color: #099; }
.highlight .sb { color: #d14; }
.highlight .sc { color: #d14; }
.highlight .sd { color: #d14; }
.highlight .s2 { color: #d14; }
.highlight .se { color: #d14; }
.highlight .sh { color: #d14; }
.highlight .si { color: #d14; }
.highlight .sx { color: #d14; }
.highlight .sr { color: #009926; }
.highlight .s1 { color: #d14; }
.highlight .ss { color: #990073; }
.highlight .bp { color: #999; }
.highlight .vc { color: #008080; }
.highlight .vg { color: #008080; }
.highlight .vi { color: #008080; }
.highlight .il { color: #099; }

body { background: #e9e9e9; }

header { background: url(img/vire_header_bg.png) center center; background-size: cover; height: 568px; color: #f5f5f5; }

header .left-sm-logo { margin: 15px 10px 0 10px; position: absolute; width: 10%; height: 10%; }

header .right-sm-logo { margin: 15px 0 0 12%; position: absolute; width: 7%; height: 7%; }

header nav { float: right; margin: 22px 20px 0 0; font-weight: 600; }

header nav a:last-child { float: right; margin: 4px 11px 0 0; }

header nav a, header nav a:visited { color: #fff; margin-right: 7px; text-decoration: none; }

header nav a:hover { color: #2df585; text-decoration: none; }

header .logo { float: left; position: absolute; left: 20%; top: 170px; width: 260px; overflow: hidden; }

header .logo h2 { position: absolute; font-size: 100px; letter-spacing: 1.5px; font-weight: 800; margin-left: 10px; }

header .logo h2:first-child { font-size: 500px; color: #004d8c; font-weight: 300; margin: -307px 0 0 -14px; opacity: 1; }

header .logo p { text-align: center; margin-top: 120px; font-size: 17px; font-weight: 500; }

.header-btn { height: 30px; position: absolute; top: 400px; left: 50%; margin-left: -115px; }

.header-btn a { text-align: center; border: thin solid #fff; font-weight: 700; font-size: 16px; padding: 14px 14px; text-decoration: none; color: #fff; }

.header-btn a:hover { background-color: #2df585; text-decoration: none; }

header .header-info-text { float: left; margin-top: 425px; font-size: 15px; width: 100%; }

header .header-info-text h3 { text-align: center; font-weight: 500; margin: -2px 0; text-shadow: 1px 1px 8px #444; }

header strong { color: #2df585; }

@media (max-width: 580px) { header .header-info-text h3 { font-size: 15px; }
  header .right-sm-logo { margin: 40px 0 0 20px; position: absolute; width: 7%; height: 7%; } }
@media (max-width: 410px) { header .right-sm-logo, header .left-sm-logo { display: none; }
  header .logo { left: 10%; } }
#leiri { margin-top: 5px; position: relative; overflow: hidden; background-color: #34495e; }

#leiri img { width: 50%; float: left; }

#leiri article { max-width: 42%; float: right; color: #fff; padding: 5% 4%; text-align: center; }

#leiri article h1 { font-size: 30px; text-align: center; font-weight: 600; margin: 30px 0; }

#leiri article p { font-size: 22px; font-weight: 400; }

@media (max-width: 1259px) { #leiri article { padding: 3% 2%; }
  #leiri article h1 { font-size: 25px; padding-top: 6%; }
  #leiri article p { font-size: 18px; } }
@media (max-width: 1034px) { #leiri article h1 { font-size: 150%; padding-top: 4%; }
  #leiri article p { font-size: 100%; } }
@media (max-width: 919px) { #leiri article h1 { font-size: 130%; }
  #leiri article p { font-size: 85%; } }
@media (max-width: 813px) { #leiri article h1 { font-size: 110%; padding-top: 0%; }
  #leiri article p { font-size: 80%; } }
@media (max-width: 739px) { #leiri article { padding-top: 10%; margin: 0; }
  #leiri article h1 { display: none; }
  #leiri article p:last-child { display: none; } }
@media (max-width: 510px) { #leiri img { width: 100%; border-top: thick solid #fff; }
  #leiri article { max-width: 100%; float: left; padding-top: 7%; padding-bottom: 7%; }
  #leiri article p:last-child { display: inline; }
  #leiri article p { font-size: 17px; } }
#ota-yhteytta { background-color: #f6f6f6; text-align: center; padding: 30px 30px; color: #252525; margin-top: 5px; }

.first_contact { float: left; width: 30%; margin: 1.5%; }

.second_contact { float: left; width: 30%; margin: 1.5%; }

.third_contact { float: left; width: 30%; margin: 1.5%; }

.third_contact a { font-weight: 600; }

.first_contact img, .second_contact img, .third_contact img { margin-bottom: 10px; width: 25%; height: 25%; }

@media (max-width: 690px) { .first_contact, .second_contact, .third_contact { width: 96%; } }
#pestit-page-line { margin-bottom: 10px; }

.job-section { border: thin solid #aaa; margin-bottom: 3%; background-color: #fff; }

.job-section div.summary { text-align: center; height: 70px; position: relative; cursor: hand; }

.job-section div.program { background: #2980b9; }

.job-section div.logistics { background: #c0392b; }

.job-section div.boats { background: #34495e; }

.job-section div.celebration { background: #27ae60; }

.job-section h3 { position: absolute; top: 50%; left: 50%; display: inline-block; font-weight: 600; color: #fff; transform: translate(-50%, -50%); }

.job-section p, .job-section ol { padding: 1% 2% 0 2%; font-size: 18px; }

.job-section li { margin: 2% 0; }

.job-section div.summary i { color: #fff; position: absolute; top: 50%; left: 33%; transform: translate(-50%, -50%); }

.job-section div.summary span { left: 75%; top: 50%; position: absolute; transform: translate(-50%, -50%); }

.job-section div.summary span i:first-child { font-size: 60px; position: absolute; left: -26%; transform: translateY(-50%); }

.job-section div.summary i:first-child { left: 25%; font-size: 40px; }

.job-section div.job-contents { display: none; }

ol strong { margin-left: -4%; }

@media (max-width: 531px) { .job-section h3 { display: block; }
  .job-section div.summary i:first-child { left: 13%; }
  .job-section div.summary span { left: 87%; } }
@media (max-width: 400px) { .job-section div.summary i:first-child, .job-section div.summary span { display: none; }
  .job-section div.job-contents { display: inline; } }
