@charset "UTF-8";
/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Normalize monospace sizing:
   en.wikipedia.org/wiki/MediaWiki_talk:Common.css/Archive_11#Teletype_style_fix_for_Chrome */
pre, code, kbd, samp {
  font-family: monospace, sans-serif;
}

pre {
  /* www.pathf.com/blogs/2008/05/formatting-quoted-code-in-blog-posts-css21-white-space-pre-wrap/ */
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
  padding: 15px;
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */
template {
  display: none;
}

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}

.clearfix, .cf {
  zoom: 1;
}
.clearfix:before, .clearfix:after, .cf:before, .cf:after {
  content: "";
  display: table;
}
.clearfix:after, .cf:after {
  clear: both;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.image-replacement,
.ir {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}

/******************************************************************
Site Name:
Author:

Stylesheet: Variables

Here is where we declare all our variables like colors, fonts,
base values, and defaults. We want to make sure this file ONLY
contains variables that way our files don't get all messy.
No one likes a mess.

******************************************************************/
/*********************
COLORS
Need help w/ choosing your colors? Try this site out:
http://0to255.com/
*********************/
/*
Here's a great tutorial on how to
use color variables properly:
http://sachagreif.com/sass-color-variables/
*/
/******************************************************************
Site Name: 
Author: 

Stylesheet: Typography

******************************************************************/
/*
"Web design is 95% typography" — Oliver Reichenstein

When that quote was made in 2006 it was before web fonts, auto-play video,
and animated pop-ups so even if it is 65 or 75% today that is still *most* 
of any web site's design. Understanding some of the basics of typography
(and web typography) will go a long way.

There are lots of web typographic systems out there however many are
overly complex and not intuitive. Thus, we've tried to set some good
defaults that aren't based on confounding mixins here but you may want
to explore web typography further:

https://www.smashingmagazine.com/2009/08/typographic-design-survey-best-practices-from-the-best-blogs/
https://www.smashingmagazine.com/2012/12/css-baseline-the-good-the-bad-and-the-ugly/
http://www.newnet-soft.com/blog/csstypography
http://typecast.com/blog/4-simple-steps-to-vertical-rhythm
https://github.com/StudioThick/megatype
https://sassline.com
http://matejlatin.github.io/Gutenberg/
https://zellwk.com/blog/responsive-typography/
https://github.com/zellwk/typi

Note that most of the typography styles are set in base.scss with
the html, body, and h1–h6 tags so adjust as needed. Set a good baseline
and consider your vertical rhythm.

*/
/*********************
FONT FACE (IN YOUR FACE)
*********************/
/* To embed your own fonts, use this syntax
  and place your fonts inside the
  library/fonts folder. For more information
  on embedding fonts, go to:
  http://www.fontsquirrel.com/
  Be sure to remove the comment brackets.

  Also, you don't have to include a separate name for 
  each font style...just use the same name and
  declare each style separately. See here:
  http://www.newnet-soft.com/blog/csstypography
*/
/*  @font-face {
      font-family: 'Font Name';
      src: url('library/fonts/font-name.eot');
      src: url('library/fonts/font-name.eot?#iefix') format('embedded-opentype'),
             url('library/fonts/font-name.woff') format('woff'),
             url('library/fonts/font-name.ttf') format('truetype'),
             url('library/fonts/font-name.svg#font-name') format('svg');
      font-weight: normal;
      font-style: normal;
  }
*/
/*********************
FONT STACKS
*********************/
/*
 Commented out since WP uses system fonts now but if you can't let go I won't be upset. 
*/
/*
some nice typographical defaults
more here: http://www.newnet-soft.com/blog/csstypography
*/
p {
  -ms-word-wrap: break-word;
  word-break: break-word;
  word-wrap: break-word;
  -webkit-hyphens: none;
  -moz-hyphens: none;
  hyphens: none;
  -webkit-hyphenate-before: 2;
  -webkit-hyphenate-after: 3;
  hyphenate-lines: 3;
}

/******************************************************************
Site Name:
Author:

Stylesheet: Sass Functions

You can do a lot of really cool things in Sass. Functions help you
make repeated actions a lot easier. They are really similar to mixins,
but can be used for so much more.

Anyway, keep them all in here so it's easier to find when you're
looking for one.

For more info on functions, go here:
http://sass-lang.com/documentation/Sass/Script/Functions.html

******************************************************************/
/*********************
COLOR FUNCTIONS
These are helpful when you're working
with shadows and such things. It's essentially
a quicker way to write RGBA.

Example:
box-shadow: 0 0 4px black(0.3);
compiles to:
box-shadow: 0 0 4px rgba(0,0,0,0.3);
*********************/
/*********************
RESPONSIVE HELPER FUNCTION
If you're creating a responsive site, then
you've probably already read
Responsive Web Design: http://www.abookapart.com/products/responsive-web-design

Here's a nice little helper function for calculating
target / context
as mentioned in that book.

Example:
width: cp(650px, 1000px);
or
width: calc-percent(650px, 1000px);
both compile to:
width: 65%;
*********************/
/******************************************************************
Site Name:
Author:

Stylesheet: Mixins Stylesheet

This is where you can take advantage of Sass' great features: Mixins.
I won't go in-depth on how they work exactly,
there are a few articles below that will help do that. What I will
tell you is that this will help speed up simple changes like
changing a color or adding CSS3 techniques gradients.

A WORD OF WARNING: It's very easy to overdo it here. Be careful and
remember less is more.

Helpful:
http://sachagreif.com/useful-sass-mixins/
http://thesassway.com/intermediate/leveraging-sass-mixins-for-cleaner-code
http://web-design-weekly.com/blog/2013/05/12/handy-sass-mixins/

******************************************************************/
/*********************
TRANSITION
*********************/
/*
I totally rewrote this to be cleaner and easier to use.
You'll need to be using Sass 3.2+ for these to work.
Thanks to @anthonyshort for the inspiration on these.
USAGE: @include transition(all 0.2s ease-in-out);
*/
/*********************
CSS3 GRADIENTS
Be careful with these since they can
really slow down your CSS. Don't overdo it.
*********************/
/* @include css-gradient(#dfdfdf,#f8f8f8); */
/*********************
BOX SIZING
*********************/
/* @include box-sizing(border-box); */
/* NOTE: value of "padding-box" is only supported in Gecko. So
probably best not to use it. I mean, were you going to anyway? */
/*--------------------------------------------------
Flexbox SASS mixins
The spec: http://www.w3.org/TR/css3-flexbox
https://gist.github.com/richardtorres314/26b18e12958ba418bb37993fdcbfc1bd

Checkout this Flexbox guide for more info:
https://css-tricks.com/snippets/css/a-guide-to-flexbox/
---------------------------------------------------*/
/*@include flexbox(); */
/******************************************************************
Site Name:
Author:

Stylesheet: Grid Stylesheet

I've seperated the grid so you can swap it out easily. It's
called at the top the style.scss stylesheet.

There are a ton of grid solutions out there. You should definitely
experiment with your own. Here are some recommendations:

http://gridsetapp.com - Love this site. Responsive Grids made easy.
http://susy.oddbird.net/ - Grids using Compass. Very elegant.
http://gridpak.com/ - Create your own responsive grid.
https://github.com/dope/lemonade - Neat lightweight grid.


The grid below is a custom built thingy I modeled a bit after
Gridset. It's VERY basic and probably shouldn't be used on
your client projects. The idea is you learn how to roll your
own grids. It's better in the long run and allows you full control
over your project's layout.

******************************************************************/
.last-col {
  float: right;
  padding-right: 0 !important;
}

/*
Mobile Grid Styles
These are the widths for the mobile grid.
There are four types, but you can add or customize
them however you see fit.
*/
@media (max-width: 767px) {
  .m-all {
    width: 100%;
    padding-right: 0;
  }
  .m-1of2 {
    float: left;
    padding-right: 0.75em;
    width: 50%;
  }
  .m-1of3 {
    float: left;
    padding-right: 0.75em;
    width: 33.33%;
  }
  .m-2of3 {
    float: left;
    padding-right: 0.75em;
    width: 66.66%;
  }
  .m-1of4 {
    float: left;
    padding-right: 0.75em;
    width: 25%;
  }
  .m-3of4 {
    float: left;
    padding-right: 0.75em;
    width: 75%;
  }
}
/* Portrait tablet to landscape */
@media (min-width: 768px) and (max-width: 1029px) {
  .t-all {
    width: 100%;
    padding-right: 0;
  }
  .t-1of2 {
    float: left;
    padding-right: 0.75em;
    width: 50%;
  }
  .t-1of3 {
    float: left;
    padding-right: 0.75em;
    width: 33.33%;
  }
  .t-2of3 {
    float: left;
    padding-right: 0.75em;
    width: 66.66%;
  }
  .t-1of4 {
    float: left;
    padding-right: 0.75em;
    width: 25%;
  }
  .t-3of4 {
    float: left;
    padding-right: 0.75em;
    width: 75%;
  }
  .t-1of5 {
    float: left;
    padding-right: 0.75em;
    width: 20%;
  }
  .t-2of5 {
    float: left;
    padding-right: 0.75em;
    width: 40%;
  }
  .t-3of5 {
    float: left;
    padding-right: 0.75em;
    width: 60%;
  }
  .t-4of5 {
    float: left;
    padding-right: 0.75em;
    width: 80%;
  }
}
/* Landscape to small desktop */
@media (min-width: 1030px) {
  .d-all {
    width: 100%;
    padding-right: 0;
  }
  .d-1of2 {
    float: left;
    padding-right: 0.75em;
    width: 50%;
  }
  .d-1of3 {
    float: left;
    padding-right: 0.75em;
    width: 33.33%;
  }
  .d-2of3 {
    float: left;
    padding-right: 0.75em;
    width: 66.66%;
  }
  .d-1of4 {
    float: left;
    padding-right: 0.75em;
    width: 25%;
  }
  .d-3of4 {
    float: left;
    padding-right: 0.75em;
    width: 75%;
  }
  .d-1of5 {
    float: left;
    padding-right: 0.75em;
    width: 20%;
  }
  .d-2of5 {
    float: left;
    padding-right: 0.75em;
    width: 40%;
  }
  .d-3of5 {
    float: left;
    padding-right: 0.75em;
    width: 60%;
  }
  .d-4of5 {
    float: left;
    padding-right: 0.75em;
    width: 80%;
  }
  .d-1of6 {
    float: left;
    padding-right: 0.75em;
    width: 16.6666666667%;
  }
  .d-1of7 {
    float: left;
    padding-right: 0.75em;
    width: 14.2857142857%;
  }
  .d-2of7 {
    float: left;
    padding-right: 0.75em;
    width: 28.5714286%;
  }
  .d-3of7 {
    float: left;
    padding-right: 0.75em;
    width: 42.8571429%;
  }
  .d-4of7 {
    float: left;
    padding-right: 0.75em;
    width: 57.1428572%;
  }
  .d-5of7 {
    float: left;
    padding-right: 0.75em;
    width: 71.4285715%;
  }
  .d-6of7 {
    float: left;
    padding-right: 0.75em;
    width: 85.7142857%;
  }
  .d-1of8 {
    float: left;
    padding-right: 0.75em;
    width: 12.5%;
  }
  .d-1of9 {
    float: left;
    padding-right: 0.75em;
    width: 11.1111111111%;
  }
  .d-1of10 {
    float: left;
    padding-right: 0.75em;
    width: 10%;
  }
  .d-1of11 {
    float: left;
    padding-right: 0.75em;
    width: 9.0909090909%;
  }
  .d-1of12 {
    float: left;
    padding-right: 0.75em;
    width: 8.33%;
  }
}
/******************************************************************
Site Name:
Author:

Stylesheet: Alert Styles

If you want to use these alerts in your design, you can. If not,
you can just remove this stylesheet.

******************************************************************/
.alert-success, .alert-error, .alert-info, .alert-help {
  margin: 10px;
  padding: 5px 18px;
  border: 1px solid;
}

.alert-help {
  border-color: #e8dc59;
  background: #ebe16f;
}

.alert-info {
  border-color: #bfe4f4;
  background: #d5edf8;
}

.alert-error {
  border-color: #f8cdce;
  background: #fbe3e4;
}

.alert-success {
  border-color: #deeaae;
  background: #e6efc2;
}

/******************************************************************
Site Name:
Author:

Stylesheet: Button Styles

Buttons are a pretty important part of your site's style, so it's
important to have a consistent baseline for them. Use this stylesheet
to create all kinds of buttons.

Helpful Links:
http://galp.in/blog/2011/08/02/the-ui-guide-part-1-buttons/

******************************************************************/
/*********************
BUTTON DEFAULTS
We're gonna use a placeholder selector here
so we can use common styles. We then use this
to load up the defaults in all our buttons.

Here's a quick video to show how it works:
http://www.youtube.com/watch?v=hwdVpKiJzac

*********************/
.purple-btn, .blue-btn, #submit, .comment-reply-link, button {
  display: inline-block;
  position: relative;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS Pゴシック", "MS P Gothic", sans-serif;
  text-decoration: none;
  color: #fff;
  font-size: 21px;
  line-height: 34px;
  font-weight: 700;
  padding: 12px 24px;
  border-radius: 2px;
  border: 0;
  cursor: pointer;
  margin-bottom: 0.5em;
  -webkit-transition: background-color 0.14s ease-in-out;
  transition: background-color 0.14s ease-in-out;
}
.purple-btn:hover, .blue-btn:hover, #submit:hover, .comment-reply-link:hover, button:hover, .purple-btn:focus, .blue-btn:focus, #submit:focus, .comment-reply-link:focus, button:focus {
  color: #fff;
  text-decoration: none;
  outline: none;
}
.purple-btn:active, .blue-btn:active, #submit:active, .comment-reply-link:active, button:active {
  top: 1px;
}

/*
An example button.
You can use this example if you want. Just replace all the variables
and it will create a button dependant on those variables.
*/
.blue-btn, #submit, .comment-reply-link, button {
  background-color: #0088cc;
  border-bottom: 6px solid #006da3;
}
.blue-btn:hover, #submit:hover, .comment-reply-link:hover, .blue-btn:focus, #submit:focus, .comment-reply-link:focus, button:hover, button:focus {
  background-color: #007ab8;
}
.blue-btn:active, #submit:active, .comment-reply-link:active, button:active {
  background-color: #0077b3;
}

.purple-btn {
  background-color: #CC0099;
  border-bottom: 6px solid #a3007a;
}
.purple-btn:hover, .purple-btn:focus {
  background-color: #b8008a;
}
.purple-btn:active {
  background-color: #b30086;
}

/******************************************************************
Site Name:
Author:

Stylesheet: Form Styles

We put all the form and button styles in here to setup a consistent
look. If we need to customize them, we can do this in the main
stylesheets and just override them. Easy Peasy.

You're gonna see a few data-uri thingies down there. If you're not
sure what they are, check this link out:
http://css-tricks.com/data-uris/
If you want to create your own, use this helpful link:
http://websemantics.co.uk/online_tools/image_to_data_uri_convertor/

******************************************************************/
/*********************
INPUTS
*********************/
input.with-description {
  margin-bottom: 0;
}

input[type=text],
input[type=password],
input[type=datetime],
input[type=datetime-local],
input[type=date],
input[type=month],
input[type=time],
input[type=week],
input[type=number],
input[type=email],
input[type=url],
input[type=search],
input[type=tel],
input[type=color],
select,
textarea,
.field {
  display: block;
  height: 40px;
  line-height: 1em;
  padding: 0 12px;
  margin-bottom: 14px;
  font-size: 1em;
  color: #3f3f3f;
  border-radius: 3px;
  vertical-align: middle;
  box-shadow: none;
  border: 0;
  width: 100%;
  max-width: 400px;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS Pゴシック", "MS P Gothic", sans-serif;
  background-color: #eaedf2;
  -webkit-transition: background-color 0.24s ease-in-out;
  transition: background-color 0.24s ease-in-out;
}
input[type=text]:focus, input[type=text]:active,
input[type=password]:focus,
input[type=password]:active,
input[type=datetime]:focus,
input[type=datetime]:active,
input[type=datetime-local]:focus,
input[type=datetime-local]:active,
input[type=date]:focus,
input[type=date]:active,
input[type=month]:focus,
input[type=month]:active,
input[type=time]:focus,
input[type=time]:active,
input[type=week]:focus,
input[type=week]:active,
input[type=number]:focus,
input[type=number]:active,
input[type=email]:focus,
input[type=email]:active,
input[type=url]:focus,
input[type=url]:active,
input[type=search]:focus,
input[type=search]:active,
input[type=tel]:focus,
input[type=tel]:active,
input[type=color]:focus,
input[type=color]:active,
select:focus,
select:active,
textarea:focus,
textarea:active,
.field:focus,
.field:active {
  background-color: #f7f8fa;
  outline: none;
}
input[type=text].error, input[type=text].is-invalid,
input[type=password].error,
input[type=password].is-invalid,
input[type=datetime].error,
input[type=datetime].is-invalid,
input[type=datetime-local].error,
input[type=datetime-local].is-invalid,
input[type=date].error,
input[type=date].is-invalid,
input[type=month].error,
input[type=month].is-invalid,
input[type=time].error,
input[type=time].is-invalid,
input[type=week].error,
input[type=week].is-invalid,
input[type=number].error,
input[type=number].is-invalid,
input[type=email].error,
input[type=email].is-invalid,
input[type=url].error,
input[type=url].is-invalid,
input[type=search].error,
input[type=search].is-invalid,
input[type=tel].error,
input[type=tel].is-invalid,
input[type=color].error,
input[type=color].is-invalid,
select.error,
select.is-invalid,
textarea.error,
textarea.is-invalid,
.field.error,
.field.is-invalid {
  color: #fbe3e4;
  border-color: #fbe3e4;
  background-color: #fff;
  background-position: 99% center;
  background-repeat: no-repeat;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo2NDM0NDREQkYwNEIxMUUyOTI4REZGQTEzMzA2MDcyNiIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo2NDM0NDREQ0YwNEIxMUUyOTI4REZGQTEzMzA2MDcyNiI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjQ3ODRGRkE2RjA0QTExRTI5MjhERkZBMTMzMDYwNzI2IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjY0MzQ0NERBRjA0QjExRTI5MjhERkZBMTMzMDYwNzI2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+U8iT5wAAAedJREFUeNqk1U9I02Ecx/HtV3aIFAc1hcRDUoGXRAq0oNLA2CrsEFmHbikZu0iQYIFGYAiegkCpLipBxPpDEBMUzB0EhSG2LhG7hMR2GviPgUTvB57Bw8P3+U23B16HPX8+e/b8nt93wezZSMCnhXETF3AcB5BDCnH8Dq98ExcGHcFn8Ah3cdDni+fxnPDv9oAnTB7CKu6VCFXtChZy56LxUjt+jfuB8toSOth9wd7xWAWhqrUjYR/FRTwWJm+iIPT/w7bQf5ljiZnBg45dtKFX6H+LU8gIY8OEV6vgTkStwXWE8BPTGDHGPqNPz2mCfSOOYkA99TvCt1bhGPL68zMcwmncMuape10jrI+q4BbHi/FLn31S9z2x5tRhTc+1W506ipM+T3oRD4X+8+qtc4SqFvL0z/Fr14S+Szjis8bz9Lvvaq8cwS/wwGfdlqfPSWqTiFlX77o13u9Ym1PBs8JAytpRoy44X9Ft9E/gvbA+rYKn8NcaaMVc8UHgBw4b9/iqUQZ6hOAJFbyDcUflmsEX4a6+wTtHGfhAIUqa1U29Zc2BytouThD8x6xuN5CtMPi2CrXLZkZf/HyZoRFCP7n+QVR4PV7uI/AjGghN7OU/r1ilnqILtfpNC+o6vIFljBKYlhb/F2AAgaBsWR5wRiIAAAAASUVORK5CYII=);
  outline-color: #fbe3e4;
}
input[type=text].success, input[type=text].is-valid,
input[type=password].success,
input[type=password].is-valid,
input[type=datetime].success,
input[type=datetime].is-valid,
input[type=datetime-local].success,
input[type=datetime-local].is-valid,
input[type=date].success,
input[type=date].is-valid,
input[type=month].success,
input[type=month].is-valid,
input[type=time].success,
input[type=time].is-valid,
input[type=week].success,
input[type=week].is-valid,
input[type=number].success,
input[type=number].is-valid,
input[type=email].success,
input[type=email].is-valid,
input[type=url].success,
input[type=url].is-valid,
input[type=search].success,
input[type=search].is-valid,
input[type=tel].success,
input[type=tel].is-valid,
input[type=color].success,
input[type=color].is-valid,
select.success,
select.is-valid,
textarea.success,
textarea.is-valid,
.field.success,
.field.is-valid {
  color: #e6efc2;
  border-color: #e6efc2;
  background-color: #fff;
  background-position: 99% center;
  background-repeat: no-repeat;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo2NDM0NDRERkYwNEIxMUUyOTI4REZGQTEzMzA2MDcyNiIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo2NDM0NDRFMEYwNEIxMUUyOTI4REZGQTEzMzA2MDcyNiI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjY0MzQ0NERERjA0QjExRTI5MjhERkZBMTMzMDYwNzI2IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjY0MzQ0NERFRjA0QjExRTI5MjhERkZBMTMzMDYwNzI2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+7olkTQAAAfhJREFUeNqklU9oE0EUhzdroWjw0tBeWlDxkEaIp55TsCU9VKIgCrHBelA8CQ1Kr1WPbZrQ3gqtQqvGqxpQc2jBk6BIIaAGD4qNCKURpDSKiPi98gLDsJt//uBjsztvfnk7895sIPAw6/joGMThFJyAXn2+A+9gA57/TaY/eU0OeBgfhGm4DiGnsb7DAszxBz/NAdcKjMJLuNWCqagHbsscN5+L+hmH4QkMOe1L5jzFfNA2PgT34ajTuY7AGuZB0/hmh5m+gS0r8xv1zRvg+gGCHZiOwnF4DP3iB3sQkYxPd2C6CWfhB9Xwlus5+K1j4jXuaq3a+gM1H9OPcAa+7q9lPidZJqHbiIm7Wg22rsEI7FrPSzAMX/T+ADyAKSsu7Fr1KplehLvwCs5DvfBf65p+MypqRbO1FXK9utH4/QKuaqYTsG3E3INJv00Q46px3+XxanJ/Ute2/vqP4FKDza2KcdljIKdnhS0xXYULTaqmLMZFn8FFSFtvt6x70ExFCS5oUXspq2ssa7oEl1swFa+CGFdgtkHgPDyDKy02zyxNU6lXRUZb1EuHYayNNs+Yh5B0WQo+/8fpJnNTZFuzz2OpjoQ2QruSOQlMy35fEGmEGMxY9e1brxobw7TkWA1h6xfckUPb+JhGoE/Hpfvew7qUld/H9J8AAwDpw3WYrxcZ3QAAAABJRU5ErkJggg==);
  outline-color: #e6efc2;
}
input[type=text][disabled], input[type=text].is-disabled,
input[type=password][disabled],
input[type=password].is-disabled,
input[type=datetime][disabled],
input[type=datetime].is-disabled,
input[type=datetime-local][disabled],
input[type=datetime-local].is-disabled,
input[type=date][disabled],
input[type=date].is-disabled,
input[type=month][disabled],
input[type=month].is-disabled,
input[type=time][disabled],
input[type=time].is-disabled,
input[type=week][disabled],
input[type=week].is-disabled,
input[type=number][disabled],
input[type=number].is-disabled,
input[type=email][disabled],
input[type=email].is-disabled,
input[type=url][disabled],
input[type=url].is-disabled,
input[type=search][disabled],
input[type=search].is-disabled,
input[type=tel][disabled],
input[type=tel].is-disabled,
input[type=color][disabled],
input[type=color].is-disabled,
select[disabled],
select.is-disabled,
textarea[disabled],
textarea.is-disabled,
.field[disabled],
.field.is-disabled {
  cursor: not-allowed;
  border-color: #cfcfcf;
  opacity: 0.6;
}
input[type=text][disabled]:focus, input[type=text][disabled]:active, input[type=text].is-disabled:focus, input[type=text].is-disabled:active,
input[type=password][disabled]:focus,
input[type=password][disabled]:active,
input[type=password].is-disabled:focus,
input[type=password].is-disabled:active,
input[type=datetime][disabled]:focus,
input[type=datetime][disabled]:active,
input[type=datetime].is-disabled:focus,
input[type=datetime].is-disabled:active,
input[type=datetime-local][disabled]:focus,
input[type=datetime-local][disabled]:active,
input[type=datetime-local].is-disabled:focus,
input[type=datetime-local].is-disabled:active,
input[type=date][disabled]:focus,
input[type=date][disabled]:active,
input[type=date].is-disabled:focus,
input[type=date].is-disabled:active,
input[type=month][disabled]:focus,
input[type=month][disabled]:active,
input[type=month].is-disabled:focus,
input[type=month].is-disabled:active,
input[type=time][disabled]:focus,
input[type=time][disabled]:active,
input[type=time].is-disabled:focus,
input[type=time].is-disabled:active,
input[type=week][disabled]:focus,
input[type=week][disabled]:active,
input[type=week].is-disabled:focus,
input[type=week].is-disabled:active,
input[type=number][disabled]:focus,
input[type=number][disabled]:active,
input[type=number].is-disabled:focus,
input[type=number].is-disabled:active,
input[type=email][disabled]:focus,
input[type=email][disabled]:active,
input[type=email].is-disabled:focus,
input[type=email].is-disabled:active,
input[type=url][disabled]:focus,
input[type=url][disabled]:active,
input[type=url].is-disabled:focus,
input[type=url].is-disabled:active,
input[type=search][disabled]:focus,
input[type=search][disabled]:active,
input[type=search].is-disabled:focus,
input[type=search].is-disabled:active,
input[type=tel][disabled]:focus,
input[type=tel][disabled]:active,
input[type=tel].is-disabled:focus,
input[type=tel].is-disabled:active,
input[type=color][disabled]:focus,
input[type=color][disabled]:active,
input[type=color].is-disabled:focus,
input[type=color].is-disabled:active,
select[disabled]:focus,
select[disabled]:active,
select.is-disabled:focus,
select.is-disabled:active,
textarea[disabled]:focus,
textarea[disabled]:active,
textarea.is-disabled:focus,
textarea.is-disabled:active,
.field[disabled]:focus,
.field[disabled]:active,
.field.is-disabled:focus,
.field.is-disabled:active {
  background-color: #d5edf8;
}

input[type=password] {
  letter-spacing: 0.3em;
}

textarea {
  max-width: 100%;
  min-height: 120px;
  line-height: 1.5em;
}

select {
  -webkit-appearance: none; /* 1 */
  -moz-appearance: none;
  appearance: none;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA8AAAAHCAYAAADXhRcnAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpEOEZCMjYxMEYwNUUxMUUyOTI4REZGQTEzMzA2MDcyNiIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpEOEZCMjYxMUYwNUUxMUUyOTI4REZGQTEzMzA2MDcyNiI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkQ4RkIyNjBFRjA1RTExRTI5MjhERkZBMTMzMDYwNzI2IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkQ4RkIyNjBGRjA1RTExRTI5MjhERkZBMTMzMDYwNzI2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Vxkp9gAAAI9JREFUeNpidHFxucHAwKAOxE+AmJmBMPgLxDJAfJMFSKwD4kqoAClgA+P///8ZXF1dPaCGcBKh6QcQB+3evXs7WDMIAA2QB1I7gFgDj0aQFz2BGh+AOEwwUaDAQyBlCMR7cGjcC5KHaQQBuM3IAOiKTiBVhiTUDdRUhq4Oq2aoAelAahIQ5wM1zsCmBiDAADhYMJXVZ9u9AAAAAElFTkSuQmCC);
  background-repeat: no-repeat;
  background-position: 97.5% center;
}

fieldset {
  border: 1px solid #ccc;
}
fieldset label {
  font-weight: 600;
}
fieldset p {
  margin-bottom: 0;
}

legend {
  padding: 0 0.5em;
}

.radio-buttons {
  margin-top: 0;
}
.radio-buttons li {
  margin-left: 2px;
}
.radio-buttons label {
  font-weight: normal;
}

/*********************
BASE (MOBILE) SIZE
This are the mobile styles. It's what people see on their phones. If
you set a great foundation, you won't need to add too many styles in
the other stylesheets. Remember, keep it light: Speed is Important.
*********************/
/*********************
GENERAL STYLES
*********************/
button.hamburger {
  display: none;
}

html, body {
  height: 100%;
}

html {
  font-size: 16px;
}

body {
  background-color: #fff;
  color: #3f3f3f;
  font-size: 100%;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS Pゴシック", "MS P Gothic", sans-serif;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: flex;
  flex-direction: column;
}

#container {
  flex: 1 0 auto;
}

#footer {
  flex-shrink: 0;
}

a {
  transition: opacity 0.6s ease-in-out, color 0.6s ease-in-out;
}
a:hover, a:focus {
  opacity: 0.6;
  color: #90C31F;
}
a:focus {
  outline: solid;
}

video, img {
  max-width: 100%;
  height: auto;
}

audio, video, img {
  vertical-align: bottom;
}

address {
  font-style: normal;
}

.intro {
  font-weight: 600;
  font-size: 125%;
  line-height: 1.4;
}

.hamburger-inner, .hamburger-inner::after, .hamburger-inner::before {
  background-color: #90C31F;
}

.hamburger span {
  color: #90C31F;
  font-weight: bold;
}

/********************
WORDPRESS BODY CLASSES
style a page via class
********************/
/* for sites that are read right to left (i.e. hebrew) */
/* home page */
/* blog template page */
/* archive page */
/* date archive page */
/* replace the number to the corresponding page number */
/* search page */
/* search result page */
/* no results search page */
/* individual paged search (i.e. body.search-paged-3) */
.error404 .article-header {
  border: 0;
  text-align: center;
}
.error404 .article-header h1 {
  margin-bottom: 0;
}
.error404 .entry-content {
  text-align: center;
}
.error404 .entry-content .hal {
  position: relative;
  margin: 0 auto;
  width: 200px;
  height: auto;
}
.error404 .entry-content .hal .circle:before {
  color: yellow;
}
.error404 .entry-content .hal .circle {
  position: absolute;
  top: 50%;
  left: 50%;
  animation: glow 1.5s linear infinite alternate;
}
.error404 .entry-content .hal img {
  margin-bottom: 0;
}
.error404 .search {
  display: block;
  padding: 1.5em;
  text-align: center;
}
.error404 .search .searchform {
  width: 100%;
}
.error404 .search .searchform input {
  margin: 0 auto;
  margin-bottom: 1em;
  width: 100%;
}

/* 404 page */
/* single post page */
/* individual post page by id (i.e. body.postid-73) */
/* individual paged single (i.e. body.single-paged-3) */
/* attatchment page */
/* individual attatchment page (i.e. body.attachmentid-763) */
/* style mime type pages */
/* author page */
/* user nicename (i.e. body.author-samueladams) */
/* paged author archives (i.e. body.author-paged-4) for page 4 */
/* category page */
/* individual category page (i.e. body.category-6) */
/* replace the number to the corresponding page number */
/* tag page */
/* individual tag page (i.e. body.tag-news) */
/* replace the number to the corresponding page number */
/* custom page template page */
/* individual page template (i.e. body.page-template-contact-php */
/* replace the number to the corresponding page number */
/* parent page template */
/* child page template */
/* replace the number to the corresponding page number */
/* if user is logged in */
/* paged items like search results or archives */
/* individual paged (i.e. body.paged-3) */
/*********************
LAYOUT & GRID STYLES
*********************/
.wrap {
  margin: 0 auto;
  width: 96%;
  max-width: 980px;
}

#inner-header {
  margin: 0 auto;
  padding: 0 5px;
  max-width: 1230px;
}

#inner-content {
  padding-top: 1.5em;
}

/*********************
LINK STYLES
*********************/
a, a:visited {
  color: #3f3f3f;
  text-decoration: underline;
  /* on hover */
  /* on click */
  /* mobile tap color */
}
a:hover, a:focus, a:visited:hover, a:visited:focus {
  color: #00699e;
  text-decoration: none;
}
a:link, a:visited:link {
  /*
  this highlights links on iPhones/iPads.
  so it basically works like the :hover selector
  for mobile devices.
  */
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.3);
}

/******************************************************************
HEADING STYLES
******************************************************************/
/* While there are several frameworks for Sass web typography and
baselines like Sassline, Megatype and Gutenberg, those all seemed
overly complex. What I wanted was simple defaults that looked good
out of the box without a lot of calculations and segmented mixins.

After searching far and wide, I came across this:
http://type-scale.com which we used to get our base sizes.

*/
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  margin: 1.333em 0 0.5em;
  font-weight: bold;
  line-height: 1.2;
  text-rendering: optimizelegibility;
  /*
  if you're going to use webfonts, be sure to check your weights
  http://css-tricks.com/watch-your-font-weight/
  */
  /* removing text decoration from all headline links */
}
h1 a, .h1 a, h2 a, .h2 a, h3 a, .h3 a, h4 a, .h4 a, h5 a, .h5 a, h6 a, .h6 a {
  text-decoration: none;
}

h1, .h1 {
  margin-top: 0;
  margin-bottom: 0.319em;
  font-size: 1.8em;
}

h2, .h2 {
  margin-top: 1.5em;
  font-size: 1.4em;
}

h3, .h3 {
  font-size: 1.3em;
}

h4, .h4 {
  font-size: 1.2em;
}

h5, .h5 {
  font-size: 1.1em;
}

h6, .h6 {
  font-size: 1em;
}

/*********************
LIST STYLES
*********************/
ul, ol {
  -webkit-padding-start: 20px;
}

.list-square {
  margin-bottom: 1.5em;
  list-style-position: outside;
  list-style-type: square;
}

.nostyle {
  margin-left: 0;
  padding-left: 0;
  list-style-type: none;
}

/*********************
HEADER STYLES
*********************/
.header {
  background-color: #fff;
  border-bottom: 3px solid #90C31F;
  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.3);
}

#inner-header {
  position: relative;
}

.site-description {
  background-color: #90C31F;
  font-size: 0.9em;
}
.site-description p {
  margin: 0 auto;
  padding: 5px 0;
}
.site-description p a {
  color: #fff;
  font-weight: bold;
  text-decoration: none;
}

#site-title,
h1#site-title {
  padding-right: 72px;
  margin: 10px 0 10px;
  font-size: 1.4em;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  display: flex;
  justify-content: start;
  align-items: center;
  height: 52px;
  line-height: 1.1;
}
#site-title:before,
h1#site-title:before {
  flex-shrink: 0;
  content: "";
  background: url(../images/handle-icon.svg) no-repeat;
  background-size: cover;
  margin-right: 5px;
  height: 48px;
  width: 48px;
  vertical-align: middle;
  display: inline-block;
  transition: opacity 0.6s ease-in-out;
}
#site-title a,
h1#site-title a {
  color: #111111;
  font-weight: bold;
}
#site-title a span,
h1#site-title a span {
  text-align: left;
  line-height: 1;
}
#site-title a:hover, #site-title afocus,
h1#site-title a:hover,
h1#site-title afocus {
  color: #90C31F;
  opacity: 1;
}
#site-title a:hover:before, #site-title afocus:before,
h1#site-title a:hover:before,
h1#site-title afocus:before {
  opacity: 0.8;
}
#site-title:hover:before, #site-titlefocus:before,
h1#site-title:hover:before,
h1#site-titlefocus:before {
  opacity: 0.7;
}

#banner .header-image {
  display: block;
}

.border-title {
  display: flex;
  font-family: "游ゴシック", "Yu Gothic", YuGothic, "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "MS Pゴシック", "MS P Gothic", sans-serif;
  text-align: center;
  align-items: center;
  justify-content: center;
}
.border-title:after {
  content: "";
  flex-grow: 2;
  border-bottom: 2px solid #90C31F;
}
.border-title:before {
  margin: 0 5px 0 0;
}
.border-title:after {
  margin: 0 0 0 5px;
}

.manabiya .border-title:after {
  border-color: #1e90ff;
}

.info-center .border-title:after {
  border-color: #228b22;
}

#header {
  position: relative;
  height: 75px;
  line-height: 36px;
}

.hamburger {
  position: absolute;
  bottom: 0;
  right: 0;
  height: 72px;
  width: 72px;
}
.hamburger span.text {
  line-height: 0;
  font-size: 0.6em;
  display: block;
  font-weight: bold;
  white-space: nowrap;
  text-align: center;
}

/*********************
NAVIGATION STYLES
*********************/
/* Where did the nav menu go?
Navigation styles for mobile are now in 767down.scss
if you need them.

We almost always use the Responsive Menu plugin:
https://wordpress.org/plugins/responsive-menu/ for mobile
menus but those selectors are there if you need them.

For your main navigation, styles are in 768up.scss.
*/
.header-nav {
  display: none;
}

#chapter-navigation {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: #1e90ff;
  box-shadow: 0 -1px 1px 0 rgba(0, 0, 0, 0.4);
}
#chapter-navigation ul {
  letter-spacing: -0.4em;
  padding: 0;
  margin: 0 auto;
  list-style: none;
}
#chapter-navigation ul li {
  vertical-align: bottom;
  height: 64px;
  letter-spacing: normal;
  display: inline-block;
  width: calc(50% - 36px);
  font-size: 1.2em;
}
#chapter-navigation ul li a {
  padding: 5px;
  line-height: 1.1;
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
  justify-content: center;
  align-items: start;
}
#chapter-navigation ul li a span.text {
  display: none;
}
#chapter-navigation ul li.prev {
  padding-right: 10px;
}
#chapter-navigation ul li.prev a {
  align-items: start;
  background: url(../images/arrow-left.svg) center left 5px no-repeat;
  background-size: 32px 32px;
  padding-left: 42px;
}
#chapter-navigation ul li.next {
  padding-left: 10px;
}
#chapter-navigation ul li.next a {
  align-items: flex-end;
  background: url(../images/arrow-right.svg) center right 5px no-repeat;
  background-size: 32px 32px;
  padding-right: 42px;
}
#chapter-navigation ul li.home {
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;
  width: 72px;
  font-size: 0.6em;
  font-weight: bold;
}
#chapter-navigation ul li.home a {
  align-items: center;
}
#chapter-navigation ul li.home a span {
  display: block;
}
#chapter-navigation ul li.home a:before {
  content: "";
  background: url(../images/car-icon.svg) no-repeat;
  background-size: cover;
  display: block;
  width: 48px;
  height: 48px;
}

.page-template-archive-johokan #chapter-navigation,
.page-template-page-johokan #chapter-navigation {
  z-index: 99999;
  background-color: #228b22;
}

/*********************
POSTS & CONTENT STYLES
*********************/
div.info-category,
article {
  padding-bottom: 0.5em;
  background-color: #fff;
}
div.info-category header,
article header {
  padding: 0.5em;
  border-bottom: 1px solid #f8f9fa;
}
div.info-category footer,
article footer {
  padding: 0.5em 0;
  border-top: 1px solid #f8f9fa;
}

/* end .hentry */
.content-area h2 {
  margin: 0.5em 0;
  font-size: 1.8em;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}
.content-area h2:before {
  content: "";
  background: url(../images/learning-icon.svg) no-repeat;
  background-size: cover;
  display: block;
  width: 48px;
  height: 48px;
}
.content-area.info-center h2:before {
  background-image: url(../images/reading-icon.svg);
}
.content-area .lead {
  margin-bottom: 1em;
  font-size: 1.1em;
}

.info-center-contents,
.manabiya-contents {
  padding: 1em 0 2em;
  margin: 0 auto 2em;
  background-color: #bad8e6;
}
.info-center-contents .content-loop,
.manabiya-contents .content-loop {
  position: relative;
  width: 98%;
  margin: 0 1% 10px;
  border-radius: 10px;
  padding: 0;
}
.info-center-contents .content-loop.mail .text-wrapper,
.manabiya-contents .content-loop.mail .text-wrapper {
  padding-bottom: 35px;
}
.info-center-contents .content-loop a,
.manabiya-contents .content-loop a {
  border: 2px solid #1e90ff;
  border-radius: 10px;
  text-decoration: none;
  width: 100%;
  display: flex;
  position: relative;
  min-height: 100px;
  transition: border-color 0.6s ease-in-out;
}
.info-center-contents .content-loop a span.num,
.manabiya-contents .content-loop a span.num {
  font-weight: bold;
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  margin-right: 10px;
  padding: 5px;
  color: #fff;
  font-size: 1.2em;
  margin: 0 3px;
}
.info-center-contents .content-loop a .thumbnail,
.manabiya-contents .content-loop a .thumbnail {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100px;
  border-radius: 8px 0 0 8px;
  background-color: #1e90ff;
  float: left;
}
.info-center-contents .content-loop a .thumbnail img,
.manabiya-contents .content-loop a .thumbnail img {
  max-width: 60%;
  margin-left: auto;
  margin-right: auto;
}
.info-center-contents .content-loop a .thumbnail .inner,
.manabiya-contents .content-loop a .thumbnail .inner {
  color: #fff;
  font-size: 2em;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
.info-center-contents .content-loop a .thumbnail:before,
.manabiya-contents .content-loop a .thumbnail:before {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.info-center-contents .content-loop a header, .info-center-contents .content-loop a .entry-header,
.manabiya-contents .content-loop a header,
.manabiya-contents .content-loop a .entry-header {
  padding-bottom: 0;
}
.info-center-contents .content-loop a header h3, .info-center-contents .content-loop a header .h3, .info-center-contents .content-loop a .entry-header h3, .info-center-contents .content-loop a .entry-header .h3,
.manabiya-contents .content-loop a header h3,
.manabiya-contents .content-loop a header .h3,
.manabiya-contents .content-loop a .entry-header h3,
.manabiya-contents .content-loop a .entry-header .h3 {
  font-size: 1em;
  margin: 0;
}
.info-center-contents .content-loop a .text-wrapper,
.manabiya-contents .content-loop a .text-wrapper {
  padding-left: 100px;
  position: relative;
  width: 100%;
}
.info-center-contents .content-loop a .archive-description,
.manabiya-contents .content-loop a .archive-description {
  padding: 0.5em;
}
.info-center-contents .content-loop a .archive-description,
.info-center-contents .content-loop a .entry-content,
.manabiya-contents .content-loop a .archive-description,
.manabiya-contents .content-loop a .entry-content {
  padding-top: 0;
  min-height: 36px;
}
.info-center-contents .content-loop a .archive-description p:not(.news),
.info-center-contents .content-loop a .entry-content p:not(.news),
.manabiya-contents .content-loop a .archive-description p:not(.news),
.manabiya-contents .content-loop a .entry-content p:not(.news) {
  min-height: 45px;
}
.info-center-contents .content-loop a p:not(.content-info-tabs-now-printing),
.manabiya-contents .content-loop a p:not(.content-info-tabs-now-printing) {
  font-size: 13px;
  margin: 0;
  line-height: 15px;
}
.info-center-contents .content-loop a div.info,
.info-center-contents .content-loop a p.info,
.manabiya-contents .content-loop a div.info,
.manabiya-contents .content-loop a p.info {
  font-size: 13px;
  margin: 0;
  line-height: 15px;
  height: 28px !important;
  margin: 0;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  position: relative;
  border-radius: 0 8px 8px 0;
  transition: border-color 0.3s ease-in-out;
  border-top: 2px solid #1e90ff;
  border-right: 2px solid #1e90ff;
}
.info-center-contents .content-loop a div.info:before,
.info-center-contents .content-loop a p.info:before,
.manabiya-contents .content-loop a div.info:before,
.manabiya-contents .content-loop a p.info:before {
  z-index: 100;
  border-radius: 0 50% 50% 0;
  content: url(../images/infomark-blue.svg);
  display: inline-block;
  width: 18px;
  padding: 5px;
  top: 0;
  left: 0;
  bottom: 0;
  vertical-align: middle;
  background-color: #1e90ff;
  position: absolute;
  transition: background-color 0.3s ease-in-out;
}
.info-center-contents .content-loop a div.info p, .info-center-contents .content-loop a div.info li,
.info-center-contents .content-loop a p.info p,
.info-center-contents .content-loop a p.info li,
.manabiya-contents .content-loop a div.info p,
.manabiya-contents .content-loop a div.info li,
.manabiya-contents .content-loop a p.info p,
.manabiya-contents .content-loop a p.info li {
  padding: 5px 5px 5px 33px;
}
.info-center-contents .content-loop a div.info span,
.info-center-contents .content-loop a p.info span,
.manabiya-contents .content-loop a div.info span,
.manabiya-contents .content-loop a p.info span {
  font-weight: bold;
}
.info-center-contents .content-loop a div.info span.label,
.info-center-contents .content-loop a p.info span.label,
.manabiya-contents .content-loop a div.info span.label,
.manabiya-contents .content-loop a p.info span.label {
  color: #fff;
  background-color: #1e90ff;
}
.info-center-contents .content-loop a div.info span.date,
.info-center-contents .content-loop a p.info span.date,
.manabiya-contents .content-loop a div.info span.date,
.manabiya-contents .content-loop a p.info span.date {
  white-space: nowrap;
  line-height: 18px;
  color: #1e90ff;
}
.info-center-contents .content-loop a div.info span.text,
.info-center-contents .content-loop a p.info span.text,
.manabiya-contents .content-loop a div.info span.text,
.manabiya-contents .content-loop a p.info span.text {
  color: #808080;
  padding: 5px;
}
.info-center-contents .content-loop a div.info.ticker-content ol, .info-center-contents .content-loop a div.info.ticker-content ul,
.manabiya-contents .content-loop a div.info.ticker-content ol,
.manabiya-contents .content-loop a div.info.ticker-content ul {
  margin: 0;
  padding: 0;
  height: 28px !important;
  line-height: 18px !important;
}
.info-center-contents .content-loop a div.info.ticker-content li,
.manabiya-contents .content-loop a div.info.ticker-content li {
  font-size: 12px !important;
  height: 28px !important;
}
.info-center-contents .content-loop a *,
.manabiya-contents .content-loop a * {
  transition: color 0.3s ease-in-out, background-color 0.3s ease-in-out;
}
.info-center-contents .content-loop a:hover, .info-center-contents .content-loop a:focus,
.manabiya-contents .content-loop a:hover,
.manabiya-contents .content-loop a:focus {
  border-color: #90C31F;
  opacity: 1;
}
.info-center-contents .content-loop a:hover *, .info-center-contents .content-loop a:focus *,
.manabiya-contents .content-loop a:hover *,
.manabiya-contents .content-loop a:focus * {
  color: #90C31F;
}
.info-center-contents .content-loop a:hover .thumbnail, .info-center-contents .content-loop a:focus .thumbnail,
.manabiya-contents .content-loop a:hover .thumbnail,
.manabiya-contents .content-loop a:focus .thumbnail {
  background-color: #90C31F;
}
.info-center-contents .content-loop a:hover div.info,
.info-center-contents .content-loop a:hover p.info, .info-center-contents .content-loop a:focus div.info,
.info-center-contents .content-loop a:focus p.info,
.manabiya-contents .content-loop a:hover div.info,
.manabiya-contents .content-loop a:hover p.info,
.manabiya-contents .content-loop a:focus div.info,
.manabiya-contents .content-loop a:focus p.info {
  border-color: #90C31F;
}
.info-center-contents .content-loop a:hover div.info span.date, .info-center-contents .content-loop a:hover div.info span.text,
.info-center-contents .content-loop a:hover p.info span.date,
.info-center-contents .content-loop a:hover p.info span.text, .info-center-contents .content-loop a:focus div.info span.date, .info-center-contents .content-loop a:focus div.info span.text,
.info-center-contents .content-loop a:focus p.info span.date,
.info-center-contents .content-loop a:focus p.info span.text,
.manabiya-contents .content-loop a:hover div.info span.date,
.manabiya-contents .content-loop a:hover div.info span.text,
.manabiya-contents .content-loop a:hover p.info span.date,
.manabiya-contents .content-loop a:hover p.info span.text,
.manabiya-contents .content-loop a:focus div.info span.date,
.manabiya-contents .content-loop a:focus div.info span.text,
.manabiya-contents .content-loop a:focus p.info span.date,
.manabiya-contents .content-loop a:focus p.info span.text {
  color: #90C31F;
}
.info-center-contents .content-loop a:hover div.info:before,
.info-center-contents .content-loop a:hover p.info:before, .info-center-contents .content-loop a:focus div.info:before,
.info-center-contents .content-loop a:focus p.info:before,
.manabiya-contents .content-loop a:hover div.info:before,
.manabiya-contents .content-loop a:hover p.info:before,
.manabiya-contents .content-loop a:focus div.info:before,
.manabiya-contents .content-loop a:focus p.info:before {
  background-color: #90C31F;
}
.info-center-contents .content-loop span.no-link,
.manabiya-contents .content-loop span.no-link {
  position: relative;
  color: #808080;
}
.info-center-contents .content-loop span.no-link span.ch,
.manabiya-contents .content-loop span.no-link span.ch {
  background-color: #808080;
}
.info-center-contents .content-loop span.no-link span.now-printing,
.manabiya-contents .content-loop span.no-link span.now-printing {
  display: block;
}
.info-center-contents .content-loop.now-printing a,
.manabiya-contents .content-loop.now-printing a {
  color: #808080;
  border-color: #808080;
}
.info-center-contents .content-loop.now-printing a .thumbnail,
.manabiya-contents .content-loop.now-printing a .thumbnail {
  background-color: #808080;
}
.info-center-contents .content-loop.now-printing a:hover, .info-center-contents .content-loop.now-printing a:focus,
.manabiya-contents .content-loop.now-printing a:hover,
.manabiya-contents .content-loop.now-printing a:focus {
  color: #1e90ff;
  border-color: #1e90ff;
}
.info-center-contents .content-loop.now-printing a:hover .thumbnail, .info-center-contents .content-loop.now-printing a:focus .thumbnail,
.manabiya-contents .content-loop.now-printing a:hover .thumbnail,
.manabiya-contents .content-loop.now-printing a:focus .thumbnail {
  background-color: #1e90ff;
}
.info-center-contents .content-loop.now-printing a:hover *:not(.num), .info-center-contents .content-loop.now-printing a:focus *:not(.num),
.manabiya-contents .content-loop.now-printing a:hover *:not(.num),
.manabiya-contents .content-loop.now-printing a:focus *:not(.num) {
  color: #1e90ff;
}
.info-center-contents .content-loop.now-printing a:hover p.content-info-tabs-now-printing, .info-center-contents .content-loop.now-printing a:focus p.content-info-tabs-now-printing,
.manabiya-contents .content-loop.now-printing a:hover p.content-info-tabs-now-printing,
.manabiya-contents .content-loop.now-printing a:focus p.content-info-tabs-now-printing {
  color: #fff;
}

.info-center-contents {
  background-color: #60c060;
}
.info-center-contents .content-loop {
  position: relative;
}
.info-center-contents .content-loop.mail .text-wrapper {
  padding-bottom: 35px;
}
.info-center-contents .content-loop a {
  border-color: #228b22;
}
.info-center-contents .content-loop a .thumbnail {
  background-color: #228b22;
}
.info-center-contents .content-loop a div.info,
.info-center-contents .content-loop a p.info {
  border-top: 2px solid #228b22;
  border-right: 2px solid #228b22;
  border-color: #228b22;
}
.info-center-contents .content-loop a div.info span.date, .info-center-contents .content-loop a div.info span.text,
.info-center-contents .content-loop a p.info span.date,
.info-center-contents .content-loop a p.info span.text {
  color: #228b22;
}
.info-center-contents .content-loop a div.info:before,
.info-center-contents .content-loop a p.info:before {
  background-color: #228b22;
}
.info-center-contents .content-loop div.mail {
  position: absolute;
  bottom: 0;
  right: 0;
}
.info-center-contents .content-loop div.mail a {
  border: 0;
  border-radius: 0 0 8px 0;
}
.info-center-contents .content-loop div.mail p {
  display: flex;
  margin: 0;
  text-align: right;
  font-size: 14px;
  padding: 0;
  font-weight: bold;
}
.info-center-contents .content-loop div.mail a {
  transition: background-color 0.3s ease-in-out;
  background-color: #228b22;
  padding: 8px 15px;
  min-height: inherit;
  display: flex;
  align-items: center;
  color: #fff;
}
.info-center-contents .content-loop div.mail a:before {
  content: url(../images/mail-icon.svg);
  width: 18px;
  line-height: 21px;
  height: 21px;
  margin-right: 3px;
  display: inline-block;
}
.info-center-contents .content-loop div.mail a:hover, .info-center-contents .content-loop div.mail a:focus {
  background-color: #90C31F;
}
.info-center-contents .content-loop.now-printing a:hover, .info-center-contents .content-loop.now-printing a:focus {
  color: #228b22;
  border-color: #228b22;
}
.info-center-contents .content-loop.now-printing a:hover .thumbnail, .info-center-contents .content-loop.now-printing a:focus .thumbnail {
  background-color: #228b22;
}
.info-center-contents .content-loop.now-printing a:hover *:not(.num), .info-center-contents .content-loop.now-printing a:focus *:not(.num) {
  color: #228b22;
}

.latest-info-list {
  height: 161px;
  margin: 20px auto 0;
  width: 100%;
  border: 3px solid #1e90ff;
  background-color: #1e90ff;
  border-radius: 8px;
  position: relative;
}
.latest-info-list:before {
  content: "";
  display: inline-block;
  position: absolute;
  top: -3px;
  left: -3px;
  bottom: -3px;
  width: 40px;
  height: 161px;
  background: #1e90ff url(../images/infomark-blue.svg) no-repeat center center;
  background-size: 26px 26px;
  border-radius: 8px 0 0 8px;
}
.latest-info-list .inner-wrapper {
  height: 155px;
  overflow: auto;
  padding: 5px 0 5px 42px;
  background-color: #fff;
  border-radius: 0 8px 8px 0;
}
.latest-info-list ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
.latest-info-list li {
  margin: 0 0 5px 0;
  font-size: 0.9em;
}
.latest-info-list li, .latest-info-list li a {
  display: block;
  font-weight: bold;
  text-decoration: none;
  color: #323944;
}
.latest-info-list li .date, .latest-info-list li a .date {
  color: #1e90ff;
}
.latest-info-list li.double a {
  display: inline;
}
.latest-info-list li .num {
  background-color: #1e90ff;
  color: #fff;
  padding: 2px 5px;
  border-radius: 2px;
}
.latest-info-list li .title {
  display: block;
}
.latest-info-list.info-center {
  border-color: #228b22;
  background-color: #228b22;
}
.latest-info-list.info-center:before {
  background-color: #228b22;
}
.latest-info-list.info-center li .num, .latest-info-list.info-center li a .num {
  background-color: #228b22;
}
.latest-info-list.info-center li .date, .latest-info-list.info-center li a .date {
  color: #228b22;
}
.latest-info-list.info-center li:before, .latest-info-list.info-center li a:before {
  color: #228b22;
}
.latest-info-list.info-center li a:hover, .latest-info-list.info-center li a:focus {
  color: #228b22;
}

.mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail {
  background-color: #1e90ff;
}

.info-center-contents .mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail {
  background-color: #228b22;
}

p.content-info-tabs-now-printing,
ol.content-info-tabs {
  margin: 0;
  padding: 0 8px 0 0;
  display: flex;
  align-items: center;
  height: 30px;
  background-color: #1e90ff;
  border-top: 2px solid #1e90ff;
  border-radius: 0 0 8px 0;
}

p.content-info-tabs-now-printing,
ol.content-info-tabs li {
  list-style: none;
  font-weight: bold;
  height: 30px;
  border: 1px solid #1e90ff;
  background-color: #fff;
  text-align: center;
  color: #808080;
  padding: 0;
}
p.content-info-tabs-now-printing span,
ol.content-info-tabs li span {
  display: block;
  border: 1px solid #fff;
  height: 28px;
  line-height: 28px;
}
p.content-info-tabs-now-printing.uploaded,
ol.content-info-tabs li.uploaded {
  color: #fff;
  background-color: #1e90ff;
}

ol.content-info-tabs li {
  width: 16.666667%;
}

p.content-info-tabs-now-printing {
  color: #fff;
  background-color: #808080;
  border-color: #808080;
  padding: 0 1em;
}

.manabiya-contents .content-loop:not(.now-printing) a:hover ol.content-info-tabs {
  background-color: #90C31F;
  border-color: #90C31F;
}
.manabiya-contents .content-loop:not(.now-printing) a:hover ol.content-info-tabs li {
  border-color: #90C31F;
  color: #808080;
}
.manabiya-contents .content-loop:not(.now-printing) a:hover ol.content-info-tabs li.uploaded * {
  background-color: #90C31F;
  color: #fff !important;
}

.now-printing ol.content-info-tabs {
  border-color: #808080;
  background-color: #808080;
}
.now-printing ol.content-info-tabs li {
  border-color: #808080;
}
.now-printing:hover p.content-info-tabs-now-printing,
.now-printing:hover ol.content-info-tabs, .now-printing:focus p.content-info-tabs-now-printing,
.now-printing:focus ol.content-info-tabs {
  border-color: #1e90ff;
  background-color: #1e90ff;
  color: #fff;
}
.now-printing:hover ol.content-info-tabs li, .now-printing:focus ol.content-info-tabs li {
  border-color: #1e90ff;
}

.in-content-nav-wrapper {
  margin: 0 auto;
  background-color: #1e90ff;
  border: 3px solid #1e90ff;
}
.in-content-nav-wrapper .wrap {
  max-width: 840px;
  width: 100%;
}
.in-content-nav-wrapper p {
  position: relative;
  z-index: 3;
  border-bottom: 0;
  margin: 0 1px 10px;
  background-color: #fff;
  border-radius: 0;
  padding: 0.5em;
  color: #1e90ff;
  font-weight: bold;
  font-size: 1em;
}
.in-content-nav-wrapper ol {
  background-color: #1e90ff;
  padding: 0;
  margin: 10px 0 0;
  list-style: none;
  display: flex;
  justify-content: space-evenly;
}
.in-content-nav-wrapper ol li {
  flex-grow: 1;
  display: block;
  position: relative;
  margin: 0 1px 0;
  border-bottom: 2px solid #1e90ff;
  border-radius: 3px 3px 0 0;
  background-color: #fff;
}
.in-content-nav-wrapper ol li:not(.current) {
  z-index: 1;
}
.in-content-nav-wrapper ol li:not(.current) a {
  color: #808080;
  transition: color 0.6s ease-in-out;
}
.in-content-nav-wrapper ol li:not(.current) a:hover {
  opacity: 1;
  color: #1e90ff;
}
.in-content-nav-wrapper ol li.current {
  z-index: 4;
  border-bottom: 2px solid #fff;
  background-color: #fff;
}
.in-content-nav-wrapper ol li.current a {
  color: #1e90ff;
}
.in-content-nav-wrapper ol li:before {
  display: block;
  padding-top: 80%;
  content: "";
  width: 100%;
}
.in-content-nav-wrapper ol li a {
  font-size: 1.2em;
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  font-weight: bold;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: -1px;
}

.mail-wrap p {
  width: 72%;
  max-width: 320px;
  margin: 40px auto;
  font-weight: bold;
  color: #228b22;
  border-radius: 8px;
  border: 3px solid #fff;
  background-color: #90C31F;
  position: relative;
}
.mail-wrap p strong {
  font-size: 1.2em;
}
.mail-wrap p a {
  background-color: #fff;
  border-radius: 0 6px 6px 0;
  display: block;
  text-decoration: none;
  padding: 10px;
  margin-left: 80px;
  text-align: left;
}
.mail-wrap p a:before {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 50px;
  height: 48px;
  padding: 11px 15px;
  content: url(../images/mail-icon.svg);
  margin-right: 3px;
  display: inline-block;
}

.archive-title,
.single-title,
.page-title,
.entry-title {
  margin: 0;
  padding-bottom: 3px;
}

.page-title {
  border-bottom: 3px solid #90C31F;
}

/* want to style individual post classes? Booya! */
/* post by id (i.e. post-3) */
/* general post style */
/* general article on a page style */
/* general style on an attatchment */
/* sticky post style */
/* hentry class */
/* style by category (i.e. category-videos) */
/* style by tag (i.e. tag-news) */
/* post meta */
.byline {
  margin: 0;
  color: #9fa6b4;
  font-style: normal;
}
/* entry content */
.entry-header h2, .entry-header h3.content-style-header, .entry-header h3.sub-title,
.entry-content h2,
.entry-content h3.content-style-header,
.entry-content h3.sub-title {
  position: relative;
  padding-bottom: 3px;
}
.entry-header h2:after, .entry-header h3.content-style-header:after, .entry-header h3.sub-title:after,
.entry-content h2:after,
.entry-content h3.content-style-header:after,
.entry-content h3.sub-title:after {
  content: "";
  display: block;
  width: 100%;
  padding: 5px 0;
  border-bottom: 2px solid #90C31F;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

.entry-content {
  padding: 0.5em;
  /*
  image alignment on a screen this size may be
  a bit difficult. It's set to start aligning
  and floating images at the next breakpoint,
  but it's up to you. Feel free to change it up.
  */
}
.entry-content figure {
  margin: 0 0 10px;
}
.entry-content figure iframe {
  max-width: 100%;
}
.entry-content figure figcaption {
  font-size: 0.9em;
  margin: 3px 0 10px;
  padding: 0 5px;
}
.entry-content figure.video-block video {
  border: 1px solid #ddd;
}
.entry-content .video-block-embed-youtube .video-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
  height: 0;
  overflow: hidden;
}
.entry-content .video-block-embed-youtube .video-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.entry-content p {
  margin: 0 0 1em;
}
.entry-content table {
  margin-bottom: 1.5em;
  width: 100%;
  border: 1px solid #eaedf2;
}
.entry-content table caption {
  margin: 0 0 7px;
  color: #9fa6b4;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 0.75em;
}
.entry-content tr {
  border-bottom: 1px solid #eaedf2;
}
.entry-content tr:nth-child(even) {
  background-color: #f8f9fa;
}
.entry-content td {
  padding: 7px;
  border-right: 1px solid #eaedf2;
}
.entry-content td:last-child {
  border-right: 0;
}
.entry-content th {
  border-right: 1px solid #eaedf2;
  border-bottom: 1px solid #eaedf2;
  background-color: #f8f9fa;
}
.entry-content th:last-child {
  border-right: 0;
}
.entry-content blockquote p {
  margin: 0 0 1em;
  padding: 0 0 0 0.75em;
  border-left: 3px solid #0088cc;
  color: #808080;
  font-size: 0.88em;
  line-height: 1.3;
}
.entry-content dd {
  margin-bottom: 1.5em;
  margin-left: 0;
  color: #787878;
  font-size: 0.9em;
}
.entry-content img {
  margin: 0 0 1.5em 0;
  max-width: 100%;
  height: auto;
}
.entry-content .size-auto,
.entry-content .size-full,
.entry-content .size-large,
.entry-content .size-medium,
.entry-content .size-thumbnail {
  max-width: 100%;
  height: auto;
}
.entry-content pre {
  overflow-x: auto;
  margin: 0 0 1.5em;
  padding: 1.5em;
  background: #fdf6e3;
  color: #586e75;
  white-space: pre;
  font-size: 14px;
  font-family: monaco, Monaco, Consolas, "Lucida Console", monospace;
}
.entry-content code {
  font-size: 14px;
  font-family: monaco, Monaco, Consolas, "Lucida Console", monospace;
}

/* end .entry-content */
.wp-caption {
  margin-bottom: 1.5em;
  padding: 5px;
  max-width: 100%;
  background: #eee;
  /* images inside wp-caption */
}
.wp-caption img {
  margin-bottom: 0;
  max-width: 100%;
  width: 100%;
}
.wp-caption p.wp-caption-text {
  margin: 4px 0 7px;
  text-align: center;
  font-size: 0.85em;
}

/* end .wp-caption */
/* image gallery styles */
/* end .gallery */
/* gallery caption styles */
.tags {
  margin: 0;
}

body.parent-pageid-2 .entry-content h2:before {
  content: "";
  background: url(../images/film-icon.svg) no-repeat;
  background-size: contain;
  width: 1.2em;
  height: 1.2em;
  display: inline-block;
  vertical-align: bottom;
  margin-right: 3px;
}

/******************************************************************
SCREEN READER STYLES
******************************************************************/
/* Text meant only for screen readers. */
.screen-reader-text {
  position: absolute !important;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  width: 1px;
  height: 1px;
  white-space: nowrap;
}

.screen-reader-text:focus {
  top: 5px;
  left: 5px;
  z-index: 100000; /* Above WP toolbar. */
  display: block;
  clip: auto !important;
  padding: 15px 23px 14px;
  width: auto;
  height: auto;
  border-radius: 3px;
  background-color: #f1f1f1;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  color: #21759b;
  text-decoration: none;
  font-weight: bold;
  font-size: 0.875rem;
  font-size: 14px;
  line-height: normal;
}

/******************************************************************
PAGE NAVI STYLES
******************************************************************/
.pagination,
.wp-prev-next {
  margin: 1.5em 0;
}

.pagination {
  text-align: center;
}
.pagination ul {
  display: inline-block;
  clear: both;
  padding: 0;
  border-radius: 3px;
  background-color: #fff;
  white-space: nowrap;
}
.pagination li {
  display: inline;
  float: left;
  overflow: hidden;
  margin: 0;
  padding: 0;
  border-right: 1px solid #eaedf2;
}
.pagination a, .pagination span {
  display: block;
  margin: 0;
  padding: 0;
  padding: 0.75em;
  min-width: 1em;
  color: #0088cc;
  text-decoration: none;
  font-weight: normal;
  font-size: 1em;
  line-height: 1em;
}
.pagination a:hover, .pagination a:focus, .pagination span:hover, .pagination span:focus {
  background-color: #004466;
  color: #fff;
}
.pagination .current {
  color: #3f3f3f;
  cursor: default;
}
.pagination .current:hover, .pagination .current:focus {
  background-color: #fff;
  color: #3f3f3f;
}

/* end .bones_page_navi */
/* fallback previous & next links */
.wp-prev-next .prev-link {
  float: left;
}
.wp-prev-next .next-link {
  float: right;
}

/* end .wp-prev-next */
/******************************************************************
COMMENT STYLES
******************************************************************/
/* h3 comment title */
#comments-title {
  margin: 0;
  padding: 0.75em;
  border-top: 1px solid #f8f9fa;
  /* number of comments span */
}
.commentlist {
  margin: 0;
  list-style-type: none;
}

.comment {
  position: relative;
  clear: both;
  overflow: hidden;
  padding: 1.5em;
  border-bottom: 1px solid #f8f9fa;
  /* vcard */
  /* end .commentlist .vcard */
  /* end children */
  /* general comment classes */
}
.comment .comment-author {
  padding: 7px;
  border: 0;
}
.comment .vcard {
  margin-left: 50px;
}
.comment .vcard cite.fn {
  font-weight: 700;
  font-style: normal;
}
.comment .vcard time {
  display: block;
  font-style: italic;
  font-size: 0.9em;
}
.comment .vcard time a {
  color: #9fa6b4;
  text-decoration: none;
}
.comment .vcard time a:hover {
  text-decoration: underline;
}
.comment .vcard .avatar {
  position: absolute;
  left: 16px;
  border-radius: 50%;
}
.comment:last-child {
  margin-bottom: 0;
}
.comment .children {
  margin: 0;
  /* variations */
  /* change number for different depth */
}
.comment[class*=depth-] {
  margin-top: 1.1em;
}
.comment.depth-1 {
  margin-top: 0;
  margin-left: 0;
}
.comment:not(.depth-1) {
  margin-top: 0;
  margin-left: 7px;
  padding: 7px;
}
.comment.odd {
  background-color: #fff;
}
.comment.even {
  background: #f8f9fa;
}
/* comment meta */
/* comment content */
.comment_content p {
  margin: 0.7335em 0 1.5em;
  font-size: 1em;
  line-height: 1.5em;
}

/* end .commentlist .comment_content */
/* comment reply link */
.comment-reply-link {
  float: right;
  font-size: 0.9em;
} /* end .commentlist .comment-reply-link */
/* edit comment link */
.comment-edit-link {
  margin: 0 7px;
  text-decoration: none;
  font-style: italic;
  font-size: 0.9em;
}

/******************************************************************
COMMENT FORM STYLES
******************************************************************/
.comment-respond {
  padding: 1.5em;
  border-top: 1px solid #f8f9fa;
}

#reply-title {
  margin: 0;
}

.comment-form-comment {
  margin: 1.5em 0 0.75em;
}

.form-allowed-tags {
  padding: 1.5em;
  background-color: #f8f9fa;
  font-size: 0.9em;
}

/* comment submit button */
#submit {
  float: right;
  font-size: 1em;
}

/* comment form title */
#comment-form-title {
  margin: 0 0 1.1em;
}

/* cancel comment reply link */
/* logged in comments */
/* allowed tags */
#allowed_tags {
  margin: 1.5em 10px 0.7335em 0;
}

/* no comments */
.nocomments {
  margin: 0 20px 1.1em;
}

/*********************
SIDEBARS & ASIDES
*********************/
.widget ul li {
  /* deep nesting */
}
.no-widgets {
  margin-bottom: 1.5em;
  padding: 1.5em;
  border-radius: 2px;
  background-color: #fff;
}

/*********************
FOOTER STYLES
*********************/
#footer-bg {
  clear: both;
  background: url(../images/footer.png) bottom center no-repeat;
  background-size: contain;
  height: 100px;
}

#footer {
  clear: both;
}
#footer .inner-wrapper {
  padding: 20px 0;
  text-align: center;
  background-color: #90c31f;
  color: #fff;
}
#footer .inner-wrapper p {
  margin: 5px 0;
}

/* end .footer-links */
.page-template .page-title {
  text-align: center;
  border-color: #1e90ff;
}
.page-template .entry-header,
.page-template .entry-content {
  max-width: 840px;
  margin-left: auto;
  margin-right: auto;
}
.page-template .entry-header h2:after, .page-template .entry-header h3.sub-title,
.page-template .entry-content h2:after,
.page-template .entry-content h3.sub-title {
  border-color: #1e90ff;
}
.page-template.page-template-archive-johokan .page-title, .page-template.page-template-page-johokan .page-title {
  border-color: #228b22;
}
.page-template.page-template-archive-johokan .entry-header h2:after, .page-template.page-template-archive-johokan .entry-header h3:after,
.page-template.page-template-archive-johokan .entry-content h2:after,
.page-template.page-template-archive-johokan .entry-content h3:after, .page-template.page-template-page-johokan .entry-header h2:after, .page-template.page-template-page-johokan .entry-header h3:after,
.page-template.page-template-page-johokan .entry-content h2:after,
.page-template.page-template-page-johokan .entry-content h3:after {
  border-color: #228b22;
}
.page-template .block-group .entry-content img,
.page-template .block-group .block-group__inner-container img {
  margin-bottom: 0;
}
.page-template .block-group .entry-content p,
.page-template .block-group .block-group__inner-container p {
  margin: 0;
}
.page-template .block-group .entry-content p.now-printing,
.page-template .block-group .block-group__inner-container p.now-printing {
  position: relative;
  background-color: #808080;
}
.page-template .block-group .entry-content p.now-printing:before,
.page-template .block-group .block-group__inner-container p.now-printing:before {
  display: block;
  content: "";
  padding-bottom: 56.25%;
  width: 100%;
}
.page-template .block-group .entry-content p.now-printing span.text,
.page-template .block-group .block-group__inner-container p.now-printing span.text {
  color: #fff;
  font-size: 3em;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  vertical-align: middle;
  justify-content: center;
  align-items: center;
}
.page-template .block-group .entry-content p.cm-link,
.page-template .block-group .block-group__inner-container p.cm-link {
  font-weight: bold;
  margin-top: 2em;
}
.page-template .block-group .entry-content div.excerpt,
.page-template .block-group .block-group__inner-container div.excerpt {
  padding: 5px;
  font-weight: bold;
}
.page-template .block-group .entry-content div.excerpt p.readmore,
.page-template .block-group .block-group__inner-container div.excerpt p.readmore {
  margin: 20px 0 0;
  text-align: right;
}
.page-template .block-group .entry-content div.excerpt p.readmore a,
.page-template .block-group .block-group__inner-container div.excerpt p.readmore a {
  border: 2px solid #90C31F;
  background-color: #90C31F;
  color: #fff;
  font-weight: bold;
  padding: 5px 15px 5px 2em;
  border-radius: 20px 0 0 20px;
  text-decoration: none;
  transition: color 0.6s ease-in-out, background-color 0.6s ease-in-out;
}
.page-template .block-group .entry-content div.excerpt p.readmore a:hover, .page-template .block-group .entry-content div.excerpt p.readmore a:focus,
.page-template .block-group .block-group__inner-container div.excerpt p.readmore a:hover,
.page-template .block-group .block-group__inner-container div.excerpt p.readmore a:focus {
  background-color: #fff;
  color: #90C31F;
  opacity: 1;
}
.page-template #footer {
  min-height: 264px;
  margin-bottom: 0;
}
.page-template #footer .inner-wrapper {
  padding-bottom: calc(100vh - 480px);
}

.category-no-posts,
.category-description {
  max-width: 840px;
  margin: 20px auto;
}

.category-description {
  border: 2px solid #228b22;
  border-radius: 8px;
  padding: 1em 2em;
}
.category-description p {
  margin: 0;
  font-size: 1.2em;
  font-weight: bold;
  color: #228b22;
}

.category-no-posts {
  font-size: 1.1em;
  text-align: center;
}

body.page-template-archive-johokan {
  position: relative;
}

body.page-template-archive-johokan.video-open {
  height: 100%;
  overflow: hidden;
}

span.new-icon {
  background-color: #ff0000;
  color: #fff;
  font-weight: bold;
  border-radius: 3px;
  padding: 3px 5px;
  font-size: 0.8em;
  vertical-align: center;
}

.page-template-archive-johokan .entry-content {
  display: flex;
  flex-direction: column-reverse;
}
.page-template-archive-johokan .entry-content .video-content-wrapper p.excerpt {
  font-weight: bold;
}
.page-template-archive-johokan .entry-content .video-content-wrapper figure a {
  position: relative;
  display: block;
  overflow: hidden;
}
.page-template-archive-johokan .entry-content .video-content-wrapper figure a:after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  background: url("../images/play-icon.png") center center no-repeat;
  background-size: 84px 84px;
  justify-content: center;
  align-items: center;
}

.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper {
  letter-spacing: normal;
  display: inline-block;
  vertical-align: top;
  width: 100%;
  padding: 0 2% 2%;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper .inner {
  display: flex;
  flex-direction: column;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper h2, .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper h3 {
  order: 2;
  font-size: 0.9rem;
  line-height: 1.2;
  margin: 0 0 10px;
  padding-bottom: 8px;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper h2:after, .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper h3:after {
  padding: 0;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper figure {
  order: 1;
  height: 100%;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper p.excerpt {
  font-size: 0.9em;
  order: 3;
}
.page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper img {
  margin: 0;
  vertical-align: center;
}

.page-template-archive-johokan.list-style .entry-content {
  row-gap: 2rem;
  align-items: flex-start;
}
.page-template-archive-johokan.list-style .entry-content h2, .page-template-archive-johokan.list-style .entry-content h3.sub-title {
  margin: 0;
  font-size: 1.3em;
}
.page-template-archive-johokan.list-style .entry-content p.excerpt {
  margin-top: 5px;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper {
  position: relative;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper img {
  margin: 0;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper:after {
  content: "";
  background-color: #ccc;
  margin: 2rem auto 0;
  width: 100%;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  display: block;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper .inner {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  column-gap: 1rem;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper .inner .text-wrapper {
  flex: 1 0;
}
.page-template-archive-johokan.list-style .entry-content .video-content-wrapper .inner figure {
  margin: 0;
  flex: 0 0;
  flex-basis: 180px;
}
.page-template-archive-johokan.list-style .entry-content .has-sub-content:after {
  content: "";
  background-color: #ccc;
  margin: 2rem auto 0;
  width: 100%;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  display: block;
}
.page-template-archive-johokan.list-style .entry-content .has-sub-content .video-content-wrapper {
  margin-bottom: 2rem;
}
.page-template-archive-johokan.list-style .entry-content .has-sub-content .video-content-wrapper:after {
  content: none;
}
.page-template-archive-johokan.list-style .entry-content .has-sub-content section.video-content-wrapper {
  padding-left: 1.5rem;
}

.page-template-archive-johokan.content-style .entry-content {
  flex-direction: column-reverse;
  row-gap: 1rem;
  align-items: flex-start;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  column-gap: 1rem;
  row-gap: 1rem;
  padding-bottom: 0;
  align-items: flex-start;
  flex-wrap: nowrap;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper img {
  margin: 0;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header {
  width: 100%;
  margin: 0;
  flex: 0 0 100%;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header a {
  display: block;
  padding: 1.25rem;
  border: 3px solid #90C31F;
  background-color: rgba(144, 195, 31, 0.9);
  color: #3f3f3f;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header a:hover, .page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header a:active, .page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header a:focus {
  opacity: 1;
  outline: 0;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header:after {
  display: none;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper .sections-wrapper {
  width: 100%;
  display: flex;
  flex-direction: row-reverse;
  row-gap: 1.5rem;
  flex-wrap: wrap-reverse;
  overflow: hidden;
  opacity: 0;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper.opened h2.article-header {
  margin: 0;
  flex: 0 0 36%;
  transition: 0.5s flex-basis ease-in-out;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper.opened .sections-wrapper {
  transition: 1.2s max-height ease-in-out, 0.3s flex-basis ease-in-out, 0.3s opacity ease-in-out 0.6s;
  max-height: 4000px;
  opacity: 1;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper.opened .click-annotation {
  display: none;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper:not(.opened) h2.article-header {
  transition: 0.6s flex-basis ease-in-out 0.2s;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper:not(.opened) h2.article-header a {
  background-color: #ccc;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper:not(.opened) .sections-wrapper {
  transition: 0.6s max-height ease-in-out, 0.6s flex-basis ease-in-out 0.2s, 0.2s opacity ease-in-out;
  flex: 0 0 0;
  max-height: 0;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper .video-content-wrapper {
  padding-top: 2%;
  transition: background-color 0.9s ease-in-out 1.4s;
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper .video-content-wrapper.current {
  background: rgba(144, 195, 31, 0.5);
}
.page-template-archive-johokan.content-style .entry-content article.contents-wrapper span.new-icon {
  margin-bottom: 8px;
}

#video-player-container {
  position: fixed;
  overflow: hidden;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 9999999999;
  margin: 0;
  display: none;
  padding: 30px;
}
#video-player-container video {
  width: 100%;
  max-height: 100%;
  max-width: 1200px;
}
#video-player-container.open {
  display: flex;
  justify-content: center;
  align-items: center;
}
#video-player-container button.hamburger {
  display: inline-block;
  position: absolute;
  top: 0;
  right: 0;
}
#video-player-container button.hamburger.is-active .hamburger-inner, #video-player-container button.hamburger.is-active .hamburger-inner::after, #video-player-container button.hamburger.is-active .hamburger-inner::before {
  background-color: #fff;
}
#video-player-container button.hamburger:hover, #video-player-container button.hamburger:focus, #video-player-container button.hamburger:active {
  background: 0;
}
#video-player-container button.hamburger:focus {
  outline: 1px solid;
}
#video-player-container button.hamburger .hamburger-box {
  margin-bottom: 5px;
}
#video-player-container button.hamburger span.text {
  font-size: 0.8em;
  font-weight: bold;
  color: #fff;
}

span.text-underline {
  text-decoration: underline;
}

p.info-annotate {
  width: 90%;
  margin: 0 auto 20px;
  font-size: 0.9em;
  text-align: right;
}

#video-thumbnails-wrapper ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
#video-thumbnails-wrapper li {
  display: inline-block;
  vertical-align: top;
  width: 46%;
  margin: 0 auto 2%;
}
#video-thumbnails-wrapper li a {
  text-decoration: none;
}
#video-thumbnails-wrapper .portlet {
  display: flex;
}
#video-thumbnails-wrapper .portlet h3 {
  font-size: 1em;
  font-style: normal;
}
#video-thumbnails-wrapper .portlet p {
  font-size: 0.8em;
}

.page-now-printing {
  font-weight: bold;
  font-size: 1.4em;
  text-align: center;
}

/*********************
LARGER MOBILE DEVICES
This is for devices like the Galaxy Note or something that's
larger than an iPhone but smaller than a tablet. Let's call them
tweeners.
*********************/
@media only screen and (min-width: 481px) {
  /******************************************************************
  Site Name:
  Author:

  Stylesheet: 481px and Up Stylesheet

  This stylesheet is loaded for larger devices. It's set to
  481px because at 480px it would load on a landscaped iPhone.
  This isn't ideal because then you would be loading all those
  extra styles on that same mobile connection.

  A word of warning. This size COULD be a larger mobile device,
  so you still want to keep it pretty light and simply expand
  upon your base.scss styles.

  ******************************************************************/
  /*
  IMPORTANT NOTE ABOUT SASS 3.3 & UP
  You can't use @extend within media queries
  anymore, so just be aware that if you drop
  them in here, they won't work.
  */
  br.sp {
    display: none;
  }
  .content-area h2 {
    font-size: 2em;
  }
  .info-center-contents .content-loop.mail .text-wrapper,
.manabiya-contents .content-loop.mail .text-wrapper {
    padding-bottom: 0;
  }
  .info-center-contents .content-loop a,
.manabiya-contents .content-loop a {
    min-height: 125px;
  }
  .info-center-contents .content-loop a .thumbnail,
.manabiya-contents .content-loop a .thumbnail {
    width: 125px;
  }
  .info-center-contents .content-loop a header h3, .info-center-contents .content-loop a header .h3, .info-center-contents .content-loop a .entry-header h3, .info-center-contents .content-loop a .entry-header .h3,
.manabiya-contents .content-loop a header h3,
.manabiya-contents .content-loop a header .h3,
.manabiya-contents .content-loop a .entry-header h3,
.manabiya-contents .content-loop a .entry-header .h3 {
    font-size: 1.2em;
  }
  .info-center-contents .content-loop a .text-wrapper,
.manabiya-contents .content-loop a .text-wrapper {
    padding-left: 125px;
  }
  .info-center-contents .content-loop a .archive-description,
.info-center-contents .content-loop a .entry-content,
.manabiya-contents .content-loop a .archive-description,
.manabiya-contents .content-loop a .entry-content {
    padding-top: 0;
    min-height: 36px;
  }
  .info-center-contents .content-loop a .archive-description p:not(.news),
.info-center-contents .content-loop a .entry-content p:not(.news),
.manabiya-contents .content-loop a .archive-description p:not(.news),
.manabiya-contents .content-loop a .entry-content p:not(.news) {
    font-size: 1em;
    line-height: 1.1em;
    min-height: 5.5em;
  }
  .in-content-nav-wrapper {
    border-width: 5px;
  }
  .in-content-nav-wrapper p {
    font-size: 1.2em;
  }
  .in-content-nav-wrapper ol li {
    border-radius: 5px 5px 0 0;
  }
  .in-content-nav-wrapper ol li:before {
    padding-top: 70%;
  }
  .in-content-nav-wrapper ol li a {
    font-size: 1.4em;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content {
    flex-direction: row;
    flex-wrap: wrap-reverse;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper {
    flex: 0 0 50%;
  }
  /*********************
  NAVIGATION STYLES
  *********************/
  /* .menu is clearfixed inside mixins.scss */
  .menu {
    /* end .menu ul */
  }
  .menu ul {
    /* end .menu ul li */
    /* highlight current page */
    /* end current highlighters */
  }
  .menu ul li {
    /*
    plan your menus and drop-downs wisely.
    */
  }
  .menu ul li a {
    /*
    you can use hover styles here even though this size
    has the possibility of being a mobile device.
    */
  }
  /* end .menu */
  /*********************
  POSTS & CONTENT STYLES
  *********************/
  /* entry content */
  .entry-content {
    /* at this larger size, we can start to align images */
  }
  .entry-content .alignleft, .entry-content img.alignleft {
    margin-right: 1.5em;
    display: inline;
    float: left;
    margin-top: 11px;
  }
  .entry-content .alignright, .entry-content img.alignright {
    margin-left: 1.5em;
    display: inline;
    float: right;
    margin-top: 11px;
  }
  .entry-content .aligncenter, .entry-content img.aligncenter {
    margin-right: auto;
    margin-left: auto;
    display: block;
    clear: both;
    margin-top: 11px;
  }
  /* end .entry-content */
  /*********************
  FOOTER STYLES
  *********************/
  /*
  check your menus here. do they look good?
  do they need tweaking?
  */
  /* end .footer-links */
}
@media only screen and (min-width: 641px) {
  #header {
    height: 86px;
    line-height: 43px;
  }
  .hamburger {
    bottom: 7px;
  }
  #site-title,
h1#site-title {
    font-size: 1.8em;
    height: 65px;
  }
  #site-title:before,
h1#site-title:before {
    width: 60px;
    height: 60px;
  }
  .content-area h2 {
    font-size: 2.4em;
  }
  .latest-info-list {
    width: 90%;
  }
  .in-content-nav-wrapper ol li:before {
    padding-top: 50%;
  }
  #chapter-navigation ul li a span.text {
    display: inline;
  }
  .block-group .block-group__inner-container {
    display: flex;
  }
  .block-group .block-group__inner-container figure, .block-group .block-group__inner-container p.now-printing, .block-group .block-group__inner-container .excerpt {
    flex-basis: 50%;
  }
  .page-template .block-group .entry-content div.excerpt,
.page-template .block-group .block-group__inner-container div.excerpt {
    padding: 0 0 0 8%;
  }
  .page-template .block-group .entry-content p.cm-link,
.page-template .block-group .block-group__inner-container p.cm-link {
    margin-top: 6em;
  }
  .page-template-archive-johokan.list-style .entry-content .video-content-wrapper .inner figure {
    flex-basis: 240px;
  }
  .page-template-archive-johokan.content-style .entry-content article.contents-wrapper h2.article-header a {
    background: #90C31F;
  }
}
/*********************
BELOW TABLET
This is for everything that's below an iPad including mobile
phones. This way we can keep mobile styles separate and not
compete with the base styles.
*********************/
@media only screen and (max-width: 767px) {
  /******************************************************************
  Site Name: 
  Author:

  Stylesheet: Below Tablet

  This stylesheet will show on devices smaller than an iPad or tablet.
  Use this to add styles that will *only* show on mobile.

  I find it easier to do it this way than to have to override base styles.

  ******************************************************************/
  /*********************
  NAVIGATION STYLES
  *********************/
  .nav {
    border-bottom: 0;
    margin: 0;
    list-style-type: none;
    padding: 0;
    /* end .menu li */
    /* highlight current page */
    /* end current highlighters */
  }
  .nav li {
    /* 
    Are you really going to use drop-down menus for mobile?
    Probably not. We almost always use the Responsive Menu
    plugin: https://wordpress.org/plugins/responsive-menu/
    */
  }
  .nav li a {
    display: block;
    color: #fff;
    text-decoration: none;
    padding: 0.75em;
  }
  .nav li ul.sub-menu li a,
.nav li ul.children li a {
    padding-left: 30px;
  }
  /* end .nav */
}
/*********************
TABLET & SMALLER LAPTOPS
This is the average viewing window. So Desktops, Laptops, and
in general anyone not viewing on a mobile device. Here's where
you can add resource intensive styles.
*********************/
@media only screen and (min-width: 768px) {
  /******************************************************************
  Site Name:
  Author:

  Stylesheet: Tablet & Small Desktop Stylesheet

  This stylesheet will be used for tablets and larger devices
  like desktops. The grid starts working here and you can get
  busy with more stylings.

  ******************************************************************/
  /*********************
  GENERAL STYLES
  *********************/
  /*********************
  LAYOUT & GRID STYLES
  *********************/
  .wrap {
    max-width: 980px;
  }
  .info-center-contents .wrap,
.manabiya-contents .wrap {
    max-width: 840px;
  }
  .info-center-contents .content-loop a,
.manabiya-contents .content-loop a {
    min-height: 150px;
  }
  .info-center-contents .content-loop a .thumbnail,
.manabiya-contents .content-loop a .thumbnail {
    width: 150px;
  }
  .info-center-contents .content-loop a header h3, .info-center-contents .content-loop a header .h3, .info-center-contents .content-loop a .entry-header h3, .info-center-contents .content-loop a .entry-header .h3,
.manabiya-contents .content-loop a header h3,
.manabiya-contents .content-loop a header .h3,
.manabiya-contents .content-loop a .entry-header h3,
.manabiya-contents .content-loop a .entry-header .h3 {
    font-size: 1.6em;
  }
  .info-center-contents .content-loop a .text-wrapper,
.manabiya-contents .content-loop a .text-wrapper {
    padding-left: 150px;
  }
  .info-center-contents .content-loop a .archive-description,
.info-center-contents .content-loop a .entry-content,
.manabiya-contents .content-loop a .archive-description,
.manabiya-contents .content-loop a .entry-content {
    padding-top: 0;
  }
  .info-center-contents .content-loop a .archive-description p:not(.news),
.info-center-contents .content-loop a .entry-content p:not(.news),
.manabiya-contents .content-loop a .archive-description p:not(.news),
.manabiya-contents .content-loop a .entry-content p:not(.news) {
    font-size: 1.1em;
    line-height: 1.2em;
    min-height: 4.8em;
  }
  /*********************
  HEADER STYLES
  *********************/
  #site-title,
h1#site-title {
    font-size: 2.4em;
  }
  #logo {
    position: relative;
    top: 3px;
    display: inline-block;
    margin-right: 1.5em;
    padding: 1em 0;
    width: 300px;
  }
  #logo img {
    display: block;
  }
  /*********************
  NAVIGATION STYLES
  *********************/
  .nav {
    margin: 0;
    padding: 0;
    border: 0;
    list-style-type: none;
    /* end .menu ul li */
    /* highlight current page */
    /* end current highlighters */
  }
  .nav ul {
    margin-top: 0;
    background: #323944;
  }
  .nav li {
    position: relative;
    float: left;
    list-style: none;
    /*
    plan your menus and drop-downs wisely.
    */
    /* showing sub-menus */
  }
  .nav li a {
    display: block;
    padding: 0.75em;
    border-bottom: 0;
    color: #fff;
    text-decoration: none;
    /*
    you can use hover styles here even though this size
    has the possibility of being a mobile device.
    */
  }
  .nav li a:hover, .nav li a:focus {
    color: #fff;
    text-decoration: underline;
  }
  .nav li ul.sub-menu,
.nav li ul.children {
    position: absolute;
    z-index: 8999;
    visibility: hidden;
    margin-top: 0;
    border: 1px solid #ccc;
    border-top: 0;
    /* highlight sub-menu current page */
  }
  .nav li ul.sub-menu li,
.nav li ul.children li {
    /*
    if you need to go deeper, go nuts
    just remember deeper menus suck
    for usability. k, bai.
    */
  }
  .nav li ul.sub-menu li a,
.nav li ul.children li a {
    display: block;
    padding-left: 10px;
    width: 180px;
    border-right: 0;
    border-bottom: 1px solid #ccc;
  }
  .nav li ul.sub-menu li:last-child a,
.nav li ul.children li:last-child a {
    border-bottom: 0;
  }
  .nav li ul.sub-menu li ul,
.nav li ul.children li ul {
    top: 0;
    left: 100%;
  }
  .nav li:hover > ul {
    top: auto;
    visibility: visible;
  }
  /* end .nav */
  /********************
  WORDPRESS BODY CLASSES
  style a page via class
  ********************/
  /*
  We like having these classes for use in iPad and larger devices
  so we've copied them here.
  */
  /* for sites that are read right to left (i.e. hebrew) */
  /* home page */
  /* blog template page */
  /* archive page */
  /* date archive page */
  /* replace the number to the corresponding page number */
  /* search page */
  /* search result page */
  /* no results search page */
  /* individual paged search (i.e. body.search-paged-3) */
  .error404 .search {
    display: flex;
    justify-content: center;
  }
  .error404 .search .searchform {
    width: 45%;
    margin: 0;
  }
  /* 404 page */
  /* single post page */
  /* individual post page by id (i.e. body.postid-73) */
  /* individual paged single (i.e. body.single-paged-3) */
  /* attatchment page */
  /* individual attatchment page (i.e. body.attachmentid-763) */
  /* style mime type pages */
  /* author page */
  /* user nicename (i.e. body.author-samueladams) */
  /* paged author archives (i.e. body.author-paged-4) for page 4 */
  /* category page */
  /* individual category page (i.e. body.category-6) */
  /* replace the number to the corresponding page number */
  /* tag page */
  /* individual tag page (i.e. body.tag-news) */
  /* replace the number to the corresponding page number */
  /* custom page template page */
  /* individual page template (i.e. body.page-template-contact-php */
  /* replace the number to the corresponding page number */
  /* parent page template */
  /* child page template */
  /* replace the number to the corresponding page number */
  /* if user is logged in */
  /* paged items like search results or archives */
  /* individual paged (i.e. body.paged-3) */
  /*********************
  SIDEBARS & ASIDES
  *********************/
  .sidebar {
    margin-top: 2.2em;
  }
  .widgettitle {
    margin-bottom: 0.75em;
    border-bottom: 2px solid #444;
  }
  .widget {
    margin: 2.2em 0;
    padding: 0 10px;
  }
  .widget ul li {
    margin-bottom: 0.75em;
    /* deep nesting */
  }
  .widget ul li ul {
    margin-top: 0.75em;
    padding-left: 1em;
  }
  /* links widget */
  /* meta widget */
  /* pages widget */
  /* recent-posts widget */
  /* archives widget */
  /* tag-cloud widget */
  /* calendar widget */
  /* category widget */
  /* recent-comments widget */
  /* search widget */
  /* text widget */
  /*********************
  FOOTER STYLES
  *********************/
  /*
  you'll probably need to do quite a bit
  of overriding here if you styled them for
  mobile. Make sure to double check these!
  */
  .footer-links ul li {
    /*
    be careful with the depth of your menus.
    it's very rare to have multi-depth menus in
    the footer.
    */
  }
  /* end .footer-links */
}
/*********************
DESKTOP
This is the average viewing window. So Desktops, Laptops, and
in general anyone not viewing on a mobile device. Here's where
you can add resource intensive styles.
*********************/
@media only screen and (min-width: 1030px) {
  /******************************************************************
  Site Name:
  Author:

  Stylesheet: Desktop Stylsheet

  This is the desktop size. It's larger than an iPad so it will only
  be seen on the Desktop.

  ******************************************************************/
  .category-description {
    padding-top: 0.75em;
    padding-bottom: 0.75em;
    margin-top: 10px;
    margin-bottom: 10px;
  }
  .category-description p {
    font-size: 1rem;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper {
    flex-basis: 33.33333%;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper h2 {
    line-height: 1.1rem;
    min-height: calc(2.2rem + 3px);
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper figure {
    text-align: center;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .video-content-wrapper figure a:after {
    background-size: 72px 72px;
  }
  .page-template-archive-johokan:not(.list-style) .entry-content .content-num4 .video-content-wrapper:first-child {
    margin-right: 66.666666%;
  }
}
/*********************
LARGE VIEWING SIZE
This is for the larger monitors and possibly full screen viewers.
*********************/
@media only screen and (min-width: 1240px) {
  /******************************************************************
  Site Name: 
  Author: 

  Stylesheet: Super Large Monitor Stylesheet

  You can add some advanced styles here if you like. This kicks in
  on larger screens like the 4K or 5K iMac.

  ******************************************************************/
}
/*********************
PRINT STYLESHEET
Feel free to customize this. Remember to add things that won't make
sense to print at the bottom. Things like nav, ads, and forms should
be set to display none.
*********************/
@media print {
  /******************************************************************
  Site Name:
  Author:

  Stylesheet: Print Stylesheet

  This is the print stylesheet. There's probably not a lot
  of reasons to edit this stylesheet. If you want to
  though, go for it.

  ******************************************************************/
  * {
    background: transparent !important;
    color: black !important;
    text-shadow: none !important;
    filter: none !important;
    -ms-filter: none !important;
  }
  a, a:visited {
    color: #444 !important;
    text-decoration: underline;
  }
  a:after, a:visited:after {
    content: " (" attr(href) ")";
  }
  a abbr[title]:after, a:visited abbr[title]:after {
    content: " (" attr(title) ")";
  }
  .ir a:after,
a[href^="javascript:"]:after,
a[href^="#"]:after {
    content: "";
  }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group;
  }
  tr, img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  @page {
    margin: 0.5cm;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
h3 {
    page-break-after: avoid;
  }
  .sidebar,
.page-navigation,
.wp-prev-next,
.respond-form,
nav {
    display: none;
  }
}
/*# sourceMappingURL=./style.css.map */

/*# sourceMappingURL=style.css.map */
