/* ===================================================
   Braintree Bowmen - Main Stylesheet
   Based on the Tempera WordPress theme (v1.8.1)
   Dark theme: bg #111, accent #359325, text #ddd
   =================================================== */

/* --- Google Fonts (loaded via <link> in head.html) --- */
/* Playfair Display for entry headings */

/* --- Web Font Imports via Google Fonts CDN --- */
@import url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@300;400&family=Oswald:wght@300;400&family=Bebas+Neue&family=Open+Sans:wght@300;400&display=swap');

/* --- Elusive / Crycon Icon Font --- */
@font-face {
  font-family: 'elusive';
  src: url('/fonts/elusive.woff') format('woff'),
       url('/fonts/elusive.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}
[class^="crycon-"]:before, [class*=" crycon-"]:before {
  font-family: "elusive";
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  font-variant: normal;
  text-transform: none;
  line-height: inherit;
  margin-left: .2em;
  cursor: inherit;
  font-size: inherit;
}
.crycon-author:before { content: '\e801' }
.crycon-category:before { content: '\e805' }
.crycon-tag:before { content: '\e802' }
.crycon-comment:before { content: '\e800' }
.crycon-date:before { content: '\e82b' }
.crycon-time:before { content: '\e80d' }
.crycon-search:before { content: '\e816' }
.crycon-angle-right:before { content: '\e808' }
.crycon-angle-left:before { content: '\e807' }
.crycon-home:before { content: '\e81f' }
.crycon-homebread:before { content: '\e81f' }
.crycon-menu:before { content: '\e820' }
.crycon-right-dir:before { content: '\e806' }
.crycon-left-dir:before { content: '\e811' }
.crycon-back2top:before { content: '\e812' }
.crycon-quote:before { content: '\e80f' }

/* ===================================================
   CSS Reset
   =================================================== */
html,body,div,span,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,
address,code,del,em,img,ins,q,strike,strong,sub,sup,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%; }
html { -webkit-box-sizing: border-box; box-sizing: border-box; }
*, *::before, *::after { -webkit-box-sizing: inherit; box-sizing: inherit; }
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section { display: block; }
ol,ul { list-style: none; }
blockquote,q { quotes: none; }
table { border-collapse: collapse; border-spacing: 0; }
h1,h2,h3,h4,h5,h6 { clear: both; font-weight: normal; }
#content h1,#content h2,#content h3,#content h4,#content h5,#content h6 { clear: none; }
a img { border: none; }
a:link, a:visited { text-decoration: none; }

/* ===================================================
   Base Typography
   =================================================== */
html { font-size: 15px; line-height: 1.7; }
body {
  font-family: 'Ubuntu', 'Open Sans', sans-serif;
  color: #ddd;
  background-color: #111;
  margin: 0;
}
a { color: #359325; }
a:hover, a:focus { color: #359325; }
h1 { font-size: 2.526em; }
h2 { font-size: 2.202em; }
h3 { font-size: 1.878em; }
h4 { font-size: 1.554em; }
h5 { font-size: 1.23em; }
h6 { font-size: .906em; }
strong { font-weight: bold; }
em, i { font-style: italic; }
pre {
  font-family: "Courier New", Courier, monospace;
  padding: 1.5em;
  overflow: auto;
  white-space: nowrap;
}
code { font-family: Monaco, Consolas, monospace; }
hr { border: 1px solid #070707; clear: both; height: 1px; }
abbr, acronym { border-bottom: 1px dotted #ddd; cursor: help; }

/* ===================================================
   Layout
   =================================================== */
#wrapper { max-width: 100%; margin: 0 auto; }
#header, #main, #topbar-inner { max-width: 1180px; margin: 0 auto; }
#main { clear: both; margin-top: 20px; background-color: #000; }
#forbottom { clear: both; margin: 0 40px; padding: 25px 0; }

/* Two-column layout */
#container { float: none; margin: 0; width: 100%; }
#container.two-columns-right #secondary { width: 280px; float: right; }
#container.two-columns-right #content { width: calc(100% - 290px); float: left; }

#content { margin-bottom: 0; }
.sidey { display: block; float: left; }

/* ===================================================
   Topbar
   =================================================== */
#topbar {
  display: block;
  height: 40px;
  width: 100%;
  background-color: #000;
  border-bottom: 1px solid #282828;
  box-shadow: 3px 0 3px #000;
}
#topbar-inner { display: block; margin: 0 auto; }

/* ===================================================
   Header & Branding
   =================================================== */
#header-full { background: none; }
#header { background: none; max-width: 1180px; margin: 0 auto; }
#masthead { position: relative; }
#branding {
  display: block;
  float: left;
  position: relative;
  clear: both;
  height: 140px;
  padding: 0;
  overflow: hidden;
  width: 100%;
}
#header-container {
  display: block;
  float: none;
  position: relative;
  top: 0;
  width: 100%;
  height: 100%;
}
#header-container > div { margin: 40px 0 0 0; }
#site-title { float: left; font-size: 38px; }
#site-title span a {
  color: #359325;
  font-family: 'Ubuntu', sans-serif;
  text-decoration: none;
  letter-spacing: -0.03em;
  display: block;
  line-height: 1.1;
}
#site-title img { display: block; }
#site-description { color: #ddd; }

/* ===================================================
   Navigation
   =================================================== */
#nav-toggle {
  display: none;
  border: 0;
  background: #359325;
  color: #000;
  padding: 10px 14px;
  cursor: pointer;
  float: right;
}
#nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: #000;
  box-shadow: 0 6px 0 #000, 0 12px 0 #000;
}
#access {
  display: block;
  float: left;
  margin: 0 auto;
  width: 100%;
  line-height: 1.5;
  background-color: #359325;
  color: #000;
}
#access a, #nav-toggle span { color: #000; }
#access a {
  position: relative;
  display: block;
  text-decoration: none;
  font-size: 15px;
  font-family: 'Ubuntu', sans-serif;
  transition: all .3s ease-in-out;
}
#access a > span { display: block; padding: .8em 1em; }
#access > .menu > ul > li > a > span {
  border-right: 1px solid #177507;
  box-shadow: 1px 0 0 #4dab3d;
}
#access a:hover { background-color: #42a032; }
#access ul li.current-menu-item > a,
#access ul li.current_page_item > a,
#access ul li.current-menu-ancestor > a { background-color: #42a032; }

#access .menu { display: block; }
#access ul { list-style: none; padding: 0; margin: 0; }
#access ul li {
  position: relative;
  display: block;
  float: left;
  white-space: nowrap;
}

/* Dropdown submenu */
#access ul ul {
  position: absolute;
  clear: both;
  z-index: 260;
  margin-left: 0;
  visibility: hidden;
  opacity: 0;
  max-height: 0;
  transform: translateY(50px);
  transition: .25s all ease-in;
  background-color: #ccc;
}
#access ul li:hover > ul,
#access ul li.menu-hover > ul {
  visibility: visible;
  opacity: 1;
  max-height: 1000px;
  transform: translateY(0);
}
#access > .menu > ul > li > ul:before {
  display: inline-block;
  content: "";
  position: absolute;
  left: 10px;
  top: -6px;
  border-bottom: 6px solid #ccc;
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
}
#access ul ul li {
  display: table;
  position: relative;
  float: left;
  clear: both;
  margin: 0;
  width: 100%;
  border-top: 1px solid #dadada;
  border-bottom: 1px solid #c1c1c1;
  background-color: #ccc;
}
#access ul ul li a { color: #000; }
#access ul ul li a:hover { background: #dadada; }
#access ul ul a, #access ul ul ul a { display: table; float: none; min-width: 150px; width: 100%; }

/* Search in nav */
#access li.menu-main-search { float: right; }
li.menu-main-search .searchform input[type="search"] {
  color: #000;
  background-color: #4dab3d;
  border-left-color: #177507;
  border-top: 0;
  border-bottom: 0;
  border-right: 0;
  border-left: 1px solid #177507;
  border-radius: 0;
  padding: .8em 1em;
  font-size: 15px;
  height: auto;
  line-height: inherit;
}
li.menu-main-search .searchform { display: block; height: auto; position: relative; overflow: hidden; }
.searchsubmit {
  display: block;
  position: absolute;
  right: 0;
  font-family: 'elusive', sans-serif;
  font-size: 17px;
  border: none;
  height: 100%;
  vertical-align: middle;
  background: none;
  box-shadow: none;
  opacity: .5;
  cursor: pointer;
  color: #000;
}
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

/* ===================================================
   Content Area
   =================================================== */
.entry-title, .entry-title a { color: #eee; font-family: 'Bebas Neue', sans-serif; font-size: 34px; font-weight: normal; line-height: 1.3; padding: 0; margin: 0; word-wrap: break-word; }
.entry-title a:hover { color: #fff; }
#content h1.entry-title, #content h2.entry-title { font-family: 'Bebas Neue', sans-serif; font-size: 34px; }
.entry-content h1, .entry-content h2, .entry-content h3,
.entry-content h4, .entry-content h5, .entry-content h6 {
  color: #eee;
  font-family: 'Playfair Display', Georgia, serif;
  line-height: 1.5em;
  margin: 20px 0 0;
}
.widget-title, .widget-title a { font-family: 'Bebas Neue', sans-serif; font-size: 18px; color: #ddd; }
.entry-content, .entry-summary { clear: both; padding-top: 8px; word-wrap: break-word; }
.entry-content p, .entry-content ul, .entry-content ol, .entry-content pre { margin-bottom: 1em; }
.entry-content ul { margin-left: 1.5em; }
.entry-content ul > li { list-style-type: circle; }
.entry-content ol > li { text-indent: 0; }
.entry-meta {
  display: block;
  clear: both;
  overflow: hidden;
  font-size: .9em;
  color: #359325;
  margin-bottom: 1em;
}
.entry-meta span { display: block; float: left; margin-right: 12px; line-height: 2; }
.entry-meta span a, .comments-link a { color: #359325; }
.entry-meta .crycon-metas:before { color: #359325; }
.entry-featured-image { margin-bottom: 20px; }
.entry-featured-image img { max-width: 100%; height: auto; border: 1px solid #222; }

/* Tables */
.entry-content table { border: 1px solid #070707; margin: 0 0 24px; text-align: left; width: 100%; }
.entry-content tr th, .entry-content thead th { color: #eee; padding: 9px 24px; }
.entry-content tr td, .entry-content tr th { border-top: 1px solid #070707; padding: 6px 24px; }
.entry-content tr.even td { background-color: #111 !important; }

/* Code */
.entry-content pre { border: 1px solid #070707; border-bottom: 1px solid #359325; background: none; padding: 10px; }
.entry-content code { background-color: #111; }
.entry-content blockquote { border-top: 1px solid #111; border-bottom: 1px solid #111; padding: 30px 30px 30px 80px; font-size: 1.1em; font-style: italic; }

/* Input fields */
input[type="text"], input[type="password"], input[type="email"],
input[type="search"], textarea, select {
  background-color: #111;
  border: 1px solid #070707;
  color: #ddd;
  padding: 10px 15px;
  font-family: inherit;
  border-radius: 4px;
}
input[type="submit"], input[type="reset"], .button {
  background-color: #359325;
  color: #000;
  border: 1px solid #359325;
  padding: .75em 1.5em;
  cursor: pointer;
  border-radius: 4px;
}
input[type="submit"]:hover { background-color: #42a032; }

/* ===================================================
   Sidebar
   =================================================== */
.sidey .widget-container { color: #ddd; background-color: #000; padding: 5px; margin: 0 0 20px; }
.sidey .widget-title { color: #ddd; background-color: #090909; border-bottom: 1px solid #000; padding: 5px 5px 5px 10px; margin-bottom: 12px; border-radius: 4px; }
.widget-container > ul > li { display: block; float: none; margin-bottom: 10px; }
.widget-area a:link, .widget-area a:visited { text-decoration: none; word-wrap: break-word; color: #ddd; }
.widget-area a:hover { color: #359325; }
.searchform { display: block; height: auto; position: relative; overflow: hidden; }
.searchform input[type="search"] { display: block; float: left; padding: 0 30px 0 10px; height: 50px; width: 100%; border-radius: 4px; background-color: #111; border-color: #070707; color: #eee; }

/* ===================================================
   Breadcrumbs
   =================================================== */
.breadcrumbs { display: block; margin-bottom: 20px; font-size: .9em; color: #359325; }
.breadcrumbs a { color: #359325; }
.breadcrumbs .current { color: #ddd; }
.breadcrumbs i { margin: 0 4px; font-size: .8em; }

/* ===================================================
   Pagination
   =================================================== */
.pagination { display: table; float: none; margin: 20px auto; text-align: center; clear: both; border: 1px solid #070707; }
.pagination span, .pagination a {
  display: block;
  float: left;
  padding: .75em 1.5em;
  text-decoration: none;
  background: #111;
  border-left: 1px solid #000;
  border-right: 1px solid #212121;
  color: #ddd;
}
.pagination a:hover { background: #191919; }
.pagination .current { background: #191919; }

/* Continue reading link */
a.continue-reading-link {
  display: inline-block;
  padding: 9px 8px 8px 15px;
  border-bottom: 1px solid #359325;
  margin-top: 3px;
  font-size: .9em;
  clear: both;
  border-radius: 4px;
  background: #359325;
  color: #000;
}
a.continue-reading-link:hover { border-bottom-color: #359325; }

/* ===================================================
   Author Info
   =================================================== */
#author-info, #entry-author-info, #content .page-title {
  border-left: 3px solid #359325;
  background: #111;
  padding: 15px;
}

/* ===================================================
   Homepage - Frontpage
   =================================================== */
#frontpage { display: block; }

/* Slider */
.slider-wrapper { display: block; float: none; clear: both; margin: 0 auto 40px; }
.frontpage-slider { position: relative; width: 100%; overflow: hidden; background: #000; }
.frontpage-slider .slide { display: none; position: relative; }
.frontpage-slider .slide.active { display: block; }
.frontpage-slider .slide img { width: 100%; height: auto; display: block; }
.nivo-html-caption {
  position: absolute;
  right: 60px;
  bottom: 60px;
  width: 43%;
  padding: 20px;
  background: rgba(0,0,0,.8);
  border-radius: 4px;
  pointer-events: none;
}
.nivo-html-caption h2 {
  margin-bottom: 10px;
  font-size: 1.6em;
  line-height: 1.3;
  padding: 0 0 10px;
  border-bottom: 1px solid #444;
  font-weight: normal;
  text-align: right;
  color: #eee;
  font-family: 'Playfair Display', Georgia, serif;
}
.slide-text { text-align: right; font-size: 1em; line-height: 1.4; color: #ddd; }
.slider-shadow { height: 10px; background: linear-gradient(to bottom, rgba(0,0,0,.3), transparent); }

/* After-slider / welcome section */
#pp-afterslider { margin: 0 40px; padding-top: 15px; }
#front-text1 h2 {
  display: block;
  float: none;
  margin: 0 auto;
  text-align: center;
  font-size: 2.2em;
  line-height: 1.4em;
  clear: both;
  font-weight: bold;
  font-family: 'Playfair Display', Georgia, serif;
  color: #eee;
}
#front-text1 { display: block; float: none; padding: 0 100px 30px; }
#front-text3 { padding: 15px 0; margin-bottom: 3em; font-size: 1.1em; }

/* 3-column section */
#front-columns {
  display: block;
  width: auto;
  float: none;
  overflow: hidden;
  margin: 40px 0;
}
#front-columns > div {
  display: block;
  float: left;
  height: auto;
  margin-right: 5%;
  margin-bottom: 30px;
  width: 30%;
}
#front-columns > div:last-child { margin-right: 0; }
.pp-columns3 > div { width: 29%; }
.column-image { width: 100%; display: block; overflow: hidden; position: relative; }
.column-image img { width: 100%; display: block; }
.column-image-inside {
  width: 100%;
  height: 100%;
  position: absolute;
  background: rgba(0,0,0,.7);
  z-index: 250;
  left: -100%;
  transition: all .3s ease-out;
}
.column-text {
  position: absolute;
  top: 50%;
  left: 100%;
  color: #ddd;
  font-size: .85em;
  line-height: 1.5;
  padding: 10px 20px;
  width: 100%;
  z-index: 251;
  transform: translate(0, -65%);
  transition: all .3s ease-out;
}
.column-image:hover .column-image-inside,
.column-image:hover .column-text { left: 0; }
.columnmore {
  display: block;
  position: absolute;
  bottom: -50px;
  margin: 0 auto;
  clear: both;
  width: 100%;
  font-size: .85em;
  text-align: center;
  z-index: 251;
  transition: all .3s ease-out;
}
.column-image:hover .columnmore { bottom: 30px; }
.columnmore a { background: #359325; border-radius: 2px; padding: 8px 22px; color: #000; }
.column-header-image {
  font-size: 1.4em;
  margin-bottom: 10px;
  line-height: 1.5;
  font-family: 'Playfair Display', Georgia, serif;
  color: #eee;
}
.clickable-column { text-decoration: none; }

/* ===================================================
   Post list
   =================================================== */
article.post, article.hentry { display: block; overflow: hidden; margin: 0; padding: 0; margin-bottom: 3em; }
.post-thumbnail img { max-width: 100%; height: auto; margin-bottom: 15px; }
.entry-summary { margin-bottom: 10px; }
.sticky .entry-header { border-bottom: 2px solid #359325; }

/* Magazine layout (2-col on list pages) */
.magazine-layout #content article.post { float: left; width: 48%; padding: 0 0 10px; }
.magazine-layout #content article:nth-of-type(2n+1) { clear: both; margin-right: 4%; }

/* ===================================================
   Footer
   =================================================== */
#footer {
  color: #ddd;
  background-color: #111;
  clear: both;
  width: 100%;
  margin-top: 20px;
}
#colophon { margin: 0 30px; overflow: hidden; }
#footer-widget-area { overflow: hidden; margin: 20px 0 10px; }
.footerone .widget-area { float: left; width: 100%; }
#footer .widget-container { color: #ddd; background-color: #000; padding: 5px; margin: 0 0 20px; }
#footer .widget-title { color: #ddd; background-color: #090909; border-bottom: 1px solid #000; padding: 5px 5px 5px 10px; margin-bottom: 12px; border-radius: 4px; }
#footer a { transition: color .2s; color: #ddd; }
#footer a:hover { text-decoration: underline; }
.textwidget .columnsContainer { position: relative; }
.textwidget .leftColumn { display: inline-block; width: 48%; vertical-align: top; padding-right: 2%; }
.textwidget .rightColumn { display: inline-block; width: 48%; vertical-align: top; }
.textwidget .leftColumn h2, .textwidget .rightColumn h2 { font-size: 1.2em; margin-bottom: .5em; color: #eee; }
.textwidget .leftColumn h3, .textwidget .rightColumn h3 { font-size: 1em; margin: .5em 0 .2em; color: #aaa; }
.textwidget iframe { display: block; margin-top: 10px; }

#footer2 {
  display: block;
  padding: 20px 0 5px;
  overflow: visible;
  margin-bottom: 20px;
  background-color: #000;
  color: #ddd;
}
#footer2:after { content: ""; display: table; clear: both; }
#footer2 a { text-decoration: none; color: #ddd; }
#footer2 a:hover { text-decoration: underline; }

/* Social icons */
.socials { position: relative; float: right; overflow: hidden; margin-right: 10px; height: 30px; }
.socials a {
  display: block;
  float: left;
  position: relative;
  overflow: hidden;
  height: 34px;
  padding: 4px 12px;
  margin-right: 5px;
  border-radius: 50px;
  background-color: #3873c2;
  color: #fff;
  line-height: 26px;
  font-size: .85em;
}

/* Back to top */
#toTop {
  display: block;
  position: fixed;
  width: auto;
  height: auto;
  bottom: 40px;
  left: 1330px;
  font-size: 12px;
  padding: 10px 14px;
  opacity: 0;
  z-index: 251;
  cursor: pointer;
  border-radius: 0 4px 4px 0;
  background: #000;
  color: #ddd;
  transition: all .3s ease-in-out;
}
#toTop:hover { opacity: 1 !important; }
#toTop:hover .crycon-back2top:before { color: #359325; }
/* Show after scroll */
#toTop.visible { opacity: .7; }

/* ===================================================
   Images
   =================================================== */
.entry-content img { max-width: 100%; height: auto; }
.alignleft, img.alignleft, .alignleft img { float: left; margin-right: 24px; margin-top: 4px; }
.alignright, img.alignright, .alignright img { float: right; margin-left: 24px; margin-top: 4px; }
.aligncenter, img.aligncenter, .aligncenter img { clear: both; margin-left: auto; margin-right: auto; }
img.aligncenter { display: block; }
.wp-caption { margin-bottom: 20px; text-align: center; max-width: 100%; }
.wp-caption img { width: 100%; }
.wp-element-caption, .wp-caption-text { font-size: .9em; font-style: italic; text-align: center; color: #aaa; }
figure { margin: 0 0 1em; }

/* ===================================================
   Responsive / Mobile
   =================================================== */
@media screen and (max-width: 768px) {
  #forbottom { margin: 0 15px; }
  #colophon { margin: 0 15px; }
  #pp-afterslider { margin: 0 15px; }
  #front-text1 { padding: 0 20px 20px; }

  #container.two-columns-right #content { width: 100%; float: none; }
  #container.two-columns-right #secondary { width: 100%; float: none; clear: both; }

  #front-columns > div { width: 100%; float: none; margin-right: 0; }

  #nav-toggle { display: block; }
  #access { display: none; }
  #access.nav-open { display: block; }
  #access ul li { float: none; }
  #access ul ul { position: static; visibility: visible; opacity: 1; max-height: none; transform: none; }
  #access ul ul li { width: 100%; }

  .nivo-html-caption { right: 10px; bottom: 10px; width: 80%; }

  .textwidget .leftColumn, .textwidget .rightColumn { display: block; width: 100%; padding: 0; margin-bottom: 20px; }

  #toTop { left: auto; right: 0; border-radius: 4px 0 0 4px; }
}

@media (max-width: 1225px) {
  #footer2 #toTop {
    position: relative;
    margin: 0 auto;
    bottom: 0;
    display: block;
    width: 45px;
    border-radius: 4px 4px 0 0;
    opacity: 1;
  }
}

/* ===================================================
   Sticky/featured posts
   =================================================== */
article.sticky .entry-header { border-bottom: 2px solid #359325; }
span.entry-format { display: inline; float: left; padding: 0 3px; margin-right: 5px; border-radius: 100px; width: 2em; height: 2em; line-height: 2; text-align: center; color: #000; background-color: #359325; }

/* ===================================================
   Box-sizing global
   =================================================== */
*, *:before, *:after { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }
