/******************************************************************
Theme Name: effector
Theme URI: https://wp-effector.com/effector-demo/
Description: ブログサイト向けのシンプルなWordPressテーマ。
Author: EFFECTOR
Version: 1.0.5
Author URI: https://wp-effector.com
Text Domain:

License: GNU General Public License
License URI: licence.txt
******************************************************************/

article, aside, details, figcaption, figure,
footer, header, hgroup, main, nav, section, summary { display: block; }

audio, canvas, video { display: inline-block; }

audio:not([controls]) {
	display: none;
	height: 0;
}

[hidden], template { display: none; }

html {
	font-family: sans-serif;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}

body { margin: 0; }

a { background: transparent; }

h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

abbr[title] { border-bottom: 1px dotted; }

b, strong, .strong { font-weight: bold; }

dfn, em, .em { font-style: italic; }

hr {
	-moz-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
}

p {
	-webkit-hyphens: auto;
	-epub-hyphens: auto;
	-moz-hyphens: auto;
	hyphens: auto;
}

pre {
	margin: 0;
	white-space: pre-wrap;
}

code, kbd, pre, samp {
	font-family: monospace, serif;
	font-size: 1em;
}

q { quotes: "\201C" "\201D" "\2018" "\2019"; }

q:before, q:after {
	content: "'";
	content: none;
}

small, .small { font-size: 75%; }

sub, sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sup { top: -0.5em; }

sub { bottom: -0.25em; }

dl, menu, ol, ul { margin: 0 0 1.75em; }

dd { margin: 0; }

menu { padding: 0 0 0 40px; }

ol, ul {
	padding: 0;
	list-style-type: none;
}

nav ul, nav ol {
	list-style: none;
	list-style-image: none;
}

img {
	border: 0;
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
}

svg:not(:root) { overflow: hidden; }

figure { margin: 0; }

fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em;
}

legend {
	border: 0;
	padding: 0;
}

button, input, select, textarea {
	font-family: inherit;
	font-size: 100%;
	margin: 0;
}

button, input { line-height: normal; }

button, select { text-transform: none; }

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}

button[disabled],
html input[disabled] { cursor: default; }

input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

input[type="search"] {
	-webkit-appearance: none;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

textarea {
	overflow: auto;
	vertical-align: top;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

* {
	-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;
}

.clearfix, .cf, .comment-respond { zoom: 1; }

.clearfix:before, .clearfix:after,
.cf:before, .cf:after,
.comment-respond:before, .comment-respond:after {
	content: "";
	display: table;
}

.clearfix:after, .cf:after, .comment-respond:after { clear: both; }

p {
	-ms-word-wrap: break-word;
	word-wrap: break-word;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	hyphens: auto;
	-webkit-hyphenate-before: 2;
	-webkit-hyphenate-after: 3;
}

.comment-reply-link, #submit, input[type="submit"] {
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: white;
	background-color: #4593af;
	font-size: .9em;
	font-weight: normal;
	padding: 1em 2em;
	border-radius: 5px;
	border: 0;
	cursor: pointer;
	transition: background-color 0.3s ease-in-out;
}

.comment-reply-link:hover, #submit:hover, input[type="submit"]:hover,
.comment-reply-link:focus, #submit:focus, input[type="submit"]:focus {
	color: #fff;
	background-color: #69b8d5;
	text-decoration: none;
	outline: none;
}

.comment-reply-link:active, #submit:active, input[type="submit"]:active { top: 1px; }

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

/*------------------------------
 Form styles
------------------------------*/
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;
	line-height: 40px;
	height: 42px;
	padding: 0 12px;
	margin-bottom: 10px;
	font-size: 16px;
	border-radius: 0;
	box-shadow: none;
	border: 2px solid #ddd;
	max-width: 97%;
	background-color: #f5f5f5;
	transition: background-color 0.24s ease-in-out, box-shadow 0.24s, background 0.24s;
	-webkit-appearance: none;
	appearance: none;
}

#main input[type="text"],
#main input[type="password"],
#main input[type="datetime"],
#main input[type="datetime-local"],
#main input[type="date"],
#main input[type="month"],
#main input[type="time"],
#main input[type="week"],
#main input[type="number"],
#main input[type="email"],
#main input[type="url"],
#main input[type="tel"],
#main input[type="color"],
#main select,
#main textarea,
#main .field {
	width: 300px;
	margin: 0;
}
#main textarea {
	padding: 2%;
	min-width: 100%;
}
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 {
	outline: none;
	background-color: #fff;
}
input[type="password"] {
	letter-spacing: 0.3em;
}

textarea {
	max-width: 100%;
	min-height: 120px;
	line-height: 1.5em;
}
select {
	-webkit-appearance: none;
	background-image: url(library/images/icon_arrow_select.png);
	background-repeat: no-repeat;
	background-position: 97.5% center;
	background-size: 9px;
}
@media only screen and (max-width: 480px) {
	#main input[type="text"],
	#main input[type="password"],
	#main input[type="datetime"],
	#main input[type="datetime-local"],
	#main input[type="date"],
	#main input[type="month"],
	#main input[type="time"],
	#main input[type="week"],
	#main input[type="number"],
	#main input[type="email"],
	#main input[type="url"],
	#main input[type="tel"],
	#main input[type="color"],
	#main input[type="file"],
	#main select,
	#main textarea,
	#main .field {
		width: 100%;
	}
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	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"],
	#main input[type="file"],
	select,
	textarea,
	.field {
		width: 92%;
		max-width: 92%;
	}
}
fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em;
}
legend {
	border: 0;
	padding: 0;
}
button,
input,
select,
textarea {
	margin: 0;
}
button,
input {
	line-height: normal;
}
button,
select {
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none;
	text-transform: none;
}
select::-ms-expand {
	display: none;
}
select {
}
button,
html input[type="button"],
input[type="reset"] {
	-webkit-appearance: button;
	cursor: pointer;
	font-size: 0.95em;
	padding: 8px 20px;
	background: #666666;
	color: #fff;
	border: 0;
	border-radius: 5px;
}
button[disabled],
html input[disabled] {
	cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}
input[type="search"] {
	-webkit-appearance: none;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
	appearance: none;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}
textarea {
	overflow: auto;
	vertical-align: top;
}

/*------------------------------
 General styles
------------------------------*/
body {
	font-family: "Noto Sans Japanese", "Mplus 1p", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-size: 103%;
	line-height: 1.8;
	color: #434343;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	word-wrap: break-word;
}

a {
	color: #4593af;
	text-decoration: underline;
}

a:hover, a:focus, a:visited:focus {
	color: #69b8d5;
	text-decoration: none;
}

a, a img {
	transition: 0.3s ease-in-out;
}

a:hover img {
	opacity: 0.65;
}

a:link, a:visited:link {
	-webkit-tap-highlight-color: rgba(0,0,0,0.3);
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5 {
	text-rendering: optimizelegibility;
	font-weight: 500;
}

h1 a, .h1 a, h2 a, .h2 a, h3 a, .h3 a, h4 a, .h4 a, h5 a, .h5 a {
	text-decoration: none;
}

h1, .h1 {
	font-size: 1.8em;
	font-weight: bold;
	line-height: 1.333em;
}

h2, .h2 {
	font-size: 1.75em;
	font-weight: bold;
	line-height: 1.4em;
	margin-bottom: 0.375em;
}

h3, .h3 {
	font-size: 1.125em;
	font-weight: bold;
}

h4, .h4 {
	font-size: 1.1em;
	font-weight: 700;
}

h5, .h5 {
	font-size: 1em;
	font-weight: 700;
	line-height: 2.09em;
}

/*------------------------------
 Header
------------------------------*/
.site-header {
	background-color: #20333e;
	position: relative;
	z-index: 3;
}

.site-header.headercenter {
	text-align: center;
}

#inner-header {
	position: relative;
}

#logo {
	padding: 0;
}

#logo h1 {
	height: 51px;
	display: table-cell;
	vertical-align: middle;
	line-height: 1.1;
}

#logo img {
	display: table-cell;
	vertical-align: middle;
}

.site-header.headercenter #logo {
	float :none;
	display: table;
	width: 92%;
	margin: 0 auto;
}

.site-header.headercenter #logo img {
	display: inline;
	margin: 0 auto;
}

#logo .site-title {
	font-weight: bold;
	font-size: 1.7em;
	margin: 0;
	padding: 0;
}

#logo.logo-l .site-title.text {font-size: 2.1em;}
#logo.logo-l .site-title img {max-height: 50px; margin: 10px auto;}
#logo.logo-m .site-title.text {font-size: 1.7em;}
#logo.logo-m .site-title img {max-height: 33px;}
#logo.logo-s .site-title.text {font-size: 1.3em;}
#logo.logo-s .site-title img {max-height: 25px;}

.headercenter #logo .site-title img { margin: 10px auto; }
.headercenter #logo.logo-l .site-title.text {font-size: 2.2em;}
.headercenter #logo.logo-l .site-title img { max-height: 60px; }
.headercenter #logo.logo-m .site-title.text {font-size: 1.8em;}
.headercenter #logo.logo-m .site-title img { max-height: 38px; }
.headercenter #logo.logo-s .site-title.text {font-size: 1.4em;}
.headercenter #logo.logo-s .site-title img { max-height: 30px; }

#logo a {
	color: #fff;
	width: 100%;

	text-align: center;
	text-decoration: none;
}

.site-description {
	padding: 0.5em 0 0;
	font-size: 12px;
	color: #fff;
}
.site-description.desc-s {font-size: 0.6em;}
.site-description.desc-m {font-size: 0.75em;}
.site-description.desc-l {font-size: 0.9em;}

/*------------------------------
 Navigation
------------------------------*/
.nav {
	border-bottom: 0;
	margin: 0;
	float: right;
	position: relative;
	top: 0;
	transition: all 0.3s;
}

.nav li a {
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 0.5em;
	position: relative;
}

.nav li a span {
	display: block;
	text-align: center;
	width: 100%;
}

.nav li li {
	font-size: 14px;
	text-align: left;
}

.nav li li span { display: none; }

.nav li ul.sub-menu li a {
	padding-left: 30px;
	font-weight: normal;
}

.nav-btn {
	color: inherit;
	width: auto;
	padding: 0.8em 0.6em;
	border: none;
	background: none;
	font-size: 0.8em;
	text-align: center;
	float: right;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.3s;
}

.nav-btn::before {
	font-size: 2em;
	font-family: 'fontawesome';
	content: '\f0c9';
	width: 100%;
	line-height: 1.15em;
	display: block;
}

.nav-btn .text {
	font-size: 0.85em;
	display: none;
}

.nav-btn.search-btn::before {
	content: '\f002';
}

.headercenter .nav-btn {
	float: none;
	position: absolute;
	right: 0;
	top: 0;
}

.headercenter .nav-btn.menu-btn {
	left: 0;
	right: auto;
}

.fixed-btn {
	position: fixed;
	opacity: 0;
	top: -100px;
	left: 15px;
	z-index: 10;
}

.fixed-btn a {
	background: rgba(0,0,0,0.75);
	color: rgba(255,255,255,0.8);
	font-size: 1.3em;
	text-align: center;
	line-height: 50px;
	width: 50px;
	height: 50px;
	padding: 0;
	display: block;
	border-radius: 5px;
}

.fixed-btn a:hover {
	background: rgba(255,255,255,0.8);
	color: rgba(0,0,0,0.7);
}

.admin-bar .fixed-btn { margin-top: 32px; }

@media screen and (max-width: 782px) {
	.admin-bar .fixed-btn { margin-top: 46px; }
}

/*------------------------------
 Searchform
------------------------------*/
.searchform {
	position: relative;
}

.searchform input {
	min-width: 92.811%;
	max-width: 92.811%;
	padding: 0 3%;
	margin: 0;
	height: 52px;
	line-height: 52px;
}

.searchform button {
	position: absolute;
	top: 0;
	right: 3%;
	border: 0;
	background: none;
	display: block;
	height: auto;
	padding: 0;
	font-size: 1.4em;
	line-height: 54px;
	color: #232f3e;
	opacity: 0.4;
}

/*------------------------------
 Top cover
------------------------------*/
#top-cover {
	color: #fff;
	width: 100%;
	text-align: center;
	margin-bottom: 0;
	position: relative;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

#top-cover .wrap {
	display: block;
	padding: 13% 2% 12%;
	position: relative;
	z-index: 1;
}

#top-cover .top-cover-wrapper {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	padding: 0;
}

#top-cover .top-cover-inner {
	max-width: 800px;
	margin: auto;
}

#top-cover .header-eyecatch { margin-bottom: 1em; }

#top-cover .header-eyecatch img { max-width: 60%; }

#top-cover.textright .top-cover-inner,
#top-cover.textleft .top-cover-inner { max-width: 500px; }

#top-cover.textright .top-cover-inner {margin-right: 0;}
#top-cover.textleft .top-cover-inner {margin-left: 0;}

#top-cover .txt-main {
	font-size: 3em;
	font-weight: bold;
	margin: 0;
	line-height: 1;
}

#top-cover .txt-sub {
	font-size: 1.1em;
	line-height: 1.7;
	font-weight: bold;
	margin: 1em 0 0;
}

#top-cover .btn {
	margin: 2.5em 0 0;
}

#top-cover .btn a:link,
#top-cover .btn a:visited {
	color: #fff;
	font-size: 1em;
	font-weight: bold;
	width: 300px;
	max-width: 90%;
	background: #4593af;
	border: none;
	box-shadow: none;
	position: relative;
	text-align: center;
	opacity: 0.9;
}

#top-cover .btn a:hover {
	opacity: 0.8;
}

#top-cover::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	background: rgba(0,0,0,0.4);
}

#top-cover.layer-wh::after { background: rgba(255,255,255,0.4); }
#top-cover.layer-bl::after { background: rgba(0,0,0,0.4); }
#top-cover.layer-dt::after {
	background-image: url(library/images/bg_layer01.png);
	background-color: rgba(0,0,0,0.1);
	background-repeat: repeat;
	opacity: 0.4;
}
#top-cover.layernone::after { content: none; }

#top-cover-img {
	text-align: center;
}

#top-cover a.btn-scroll {
	padding-top: 70px;
	position: absolute;
	bottom: 30px;
	left: 0;
	right: 0;
	z-index: 2;
	width: 100px;
	margin: auto;
	display: inline-block;
	color: rgba(221,221,221,0.75);
	font-size: 0.7em;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-decoration: none;
	text-transform: uppercase;
	transition: opacity 0.3s;
}

#top-cover a.btn-scroll span {
	position: absolute;
	top: 0;
	left: 50%;
	width: 20px;
	height: 20px;
	margin-left: -10px;
	border-left: 1px solid rgba(221,221,221,0.75);
	border-bottom: 1px solid rgba(221,221,221,0.75);
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	-webkit-animation: sdb 1.5s infinite;
	animation: sdb 1.5s infinite;
	box-sizing: border-box;
}

@-webkit-keyframes sdb {
	0% {
		-webkit-transform: rotate(-45deg) translate(0, 0);
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
	100% {
		-webkit-transform: rotate(-45deg) translate(-20px, 20px);
		opacity: 0;
	}
}
@keyframes sdb {
	0% {
		transform: rotate(-45deg) translate(0, 0);
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
	100% {
		transform: rotate(-45deg) translate(-20px, 20px);
		opacity: 0;
	}
}

/*------------------------------
 Breadcrumb
------------------------------*/
.breadcrumb {
	font-size: 13px;
	margin: 0;
	padding: 10px 0;
}

.breadcrumb ul { margin: 0; }

.breadcrumb li:first-child { margin-left: 0; }

.single .breadcrumb li:last-child { display: none; }

.breadcrumb li { float: left; }

.breadcrumb li:after {
	font-family: "FontAwesome";
	content: "\f105";
	color: #bbb;
	padding: 0 0.75em;
}

.single .breadcrumb li:nth-last-child(2):after,
.breadcrumb li:last-child:after { display: none; }

.breadcrumb li a {
	opacity: 0.6;
	text-decoration: none;
}

/*------------------------------
 Post list
------------------------------*/
.post-list {
	font-size: 0.85em;
	position: relative;
}

.post-list.sticky {}

.post-list a {
	background-color: transparent;
	display: block;
	padding: 20px 0;
	text-decoration: none;
	color: #333;
	border-top: 1px solid rgba(204,204,204,0.5);
	position: relative;
}

.post-list a:hover,
.post-list a:focus { color: #999; }

.post-list .post-thumbnail {
	width: 36.5%;
	position: relative;
	float: left;
	margin-right: 2%;
}

.post-list .post-thumbnail .new {
	position: absolute;
	top: -7px;
	left: -7px;
	background: #317790;
	padding: 0.5em 1em;
	font-size: 1em;
	font-weight: bold;
	color: #fff;
	text-align: center;
	z-index: 1;
}

.post-list .eyecatch {
	width: 100%;
	overflow: hidden;
	position: relative;
}

.post-list .eyecatch img {
	margin: 0;
	width: 100%;
}

.post-list .entry-content {
	padding: 0;
	overflow: hidden;
}

.post-list .entry-header { margin-bottom: 0.5em; }

.post-list .entry-header .entry-meta { margin: 0 0 0.5em; }

.post-list .entry-content .entry-description { opacity: 0.7; }

.post-list .entry-content .entry-title {
	font-size: 1.4em;
	margin: 0 0 0.5em;
}

.post-list .entry-content p {
	margin-bottom: 0;
	line-height: 1.8;
}

/* post-list-simple */
.post-list-simple .post-list-inner {
	border-bottom: 1px solid rgba(204,204,204,0.5);
}

.post-list-simple .post-list:first-child a { border-top: 1px solid rgba(204,204,204,0.5); }

/* post-list-block */
.post-list-block .post-list-inner {
	margin-left: -2%;
	margin-right: -2%;
}

.post-list-block .post-list-inner { letter-spacing: -0.5em; }

.post-list-block .post-list {
	width: 46%;
	margin: 0 2% 4%;
	display: inline-block;
	vertical-align: top;
	letter-spacing:normal;
}

.post-list-block .post-list a {
	padding: 0 0 4%;
	min-width: 100%;
}

.post-list-block .post-list .post-thumbnail {
	width: auto;
	float: none;
	margin: 0;
}

.post-list-block .post-list .eyecatch {
	text-align: center;
	max-height: 300px;
	margin-top: -1px;
}

.post-list-block .post-list .entry-content .entry-title { margin: 0.8em 0; }

.search-no-results .post-list-block { margin: 0 0 2em; }

/*------------------------------
 Pagenation
------------------------------*/
.pagination,
.page-links,
.wp-prev-next { margin: 2em 0; }

.pagination,
.page-links { text-align: center; }

.pagination ul,
.page-links ul {
	display: block;
	text-align: center;
	margin:0;
	padding: 0;
	clear: both;
	white-space: nowrap;
}

.pagination:empty,
.wp-prev-next:empty,
.pagination ul:empty,
.page-links ul:empty,
.search-no-results .pagination { display: none; }

.pagination li,
.page-links li {
	padding:0 !important;
	display: inline-block;
}

.pagination ul li,
.entry-content .page-links ul li { margin: 0 0.1px; }

.entry-content .page-links li::before { content: none; }

.pagination a,
.pagination span,
.page-links a,
.page-links ul > li > span {
	margin: 0;
	padding: 12px 14px;
	text-decoration: none;
	line-height: 1;
	font-size: 1em;
	font-weight: bold;
	color: #4593af;
	border: 2px solid #4593af;
	display: inline-block;
}

.pagination span.dots,
.page-links ul > li > span.dots {
	background: none !important;
	padding-left: 11px;
	padding-right: 11px;
}

.pagination a:hover, .pagination a:focus, .pagination span:hover, .pagination span:focus,
.page-links a:hover, .page-links a:focus {
	background-color: #4593af;
	color: #fff;
}

.pagination .current,
.page-links ul > li > span {
	cursor: default;
	background: #5c6b80;
	color: #fff;
}

.pagination .current:focus,
.pagination .dots:hover, .pagination .dots:focus {
	background-color: #5c6b80;
	color: #fff;
}

.wp-prev-next .prev-link { float: left; }
.wp-prev-next .next-link { float: right; }

/*------------------------------
 Archive
------------------------------*/
.archive-title {
	font-size: 1.5em;
	margin: 0 0 1em;
	line-height: 1.4;
}

.archive-title span {
	display: block;
	margin: 0 auto 5px;
	font-size: 11px;
	font-weight: bold;
	letter-spacing: 0.1em;
}

.taxonomy-description {
	margin: 0 0 1.5em;
	padding-top: 0;
}

.archive-title .author-icon img {
	margin: 0 0 15px;
	border: 4px solid #fff;
	border-radius: 50%;
	box-shadow: 0 0 6px rgba(0,0,0,0.16);
}

/*------------------------------
 Post & Page
------------------------------*/
.page #main article {
	margin-bottom: 20px
}

.single-title,
.page-title,
.entry-title {
	font-size: 1.8em;
	font-weight: bold;
	margin: 0 0 0.75em;
}

.entry-header { margin-bottom: 1em; }

.entry-header .categories {
	display: inline-block;
	margin: 0;
}

.entry-header .categories li,
.entry-header .tags li {
	float: left;
	margin: 0 5px 5px 0;
	padding: 0.6em 0.8em;
	background: #fff;
	line-height: 1.2;
	display: block;
	font-size: 0.8em;
	font-weight: bold;
}

.entry-header .categories li::before,
.entry-header .tags li::before {
	content: none;
}

.entry-header .entry-meta .updated::before {
	font-family: "fontawesome";
	margin-right: 0.2em;
	position: relative;
}

.entry-header .entry-meta .updated.undo { margin-left: 0.5em; }

.entry-header .entry-meta .updated.undo::before { content: "\f1da"; }

.entry-header .entry-meta .author {
	margin: 0 1em 0 0;
	position: relative;
	display: inline-block;
}

.entry-header .entry-meta .author a {
	color: #242424;
	text-decoration: none;
}

.entry-header .entry-meta .author .avatar {
	position: relative;
	margin-right: 0.5em;
	margin-bottom: 0;
	border-radius: 45px;
	vertical-align: middle;
	opacity: 1;
}

.entry-header .entry-meta {
	font-size: 0.9em;
	margin: 0 0 1em;
}

.entry-header .eyecatch {
	text-align: center;
	overflow: hidden;
	position: relative;
}

.entry-header .eyecatch img {
	margin: 0;
	height: auto;
}

.page .eyecatch_custom #main header.entry-header,
.single .eyecatch_custom #main header.entry-header {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	text-align: center;
	position: relative;
	text-shadow: 0 0 8px rgba(0,0,0,0.5);
}

.page .eyecatch_custom #main header.entry-header::after,
.single .eyecatch_custom #main header.entry-header::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.65);
	opacity: 0.6;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.eyecatch_custom #main .entry-header-inner {
	color: #fff;
	padding: 17% 5% 12%;
	position: relative;
	z-index: 2;
}

.eyecatch_custom #main .entry-header-inner a { color: #fff; }

.eyecatch_custom #main header.entry-header .categories { display: inline-block; }

.eyecatch_custom #main header.entry-header .categories li,
.eyecatch_custom #main header.entry-header .tags li {
	background: none;
	color: #fff;
	border: 1px solid rgba(255,255,255,1);
	box-shadow: 0 0 8px rgba(0,0,0,0.3);
	margin: 0 3px 5px;
}

.eyecatch_custom #main header.entry-header .tags li { border-color: transparent; }

.entry-content h2 {
	font-size: 1.6em;
	position: relative;
	padding: 0.7em 0;
	border-bottom: 2px solid #434343;
	margin: 1em 0 1em;
	clear: both;
}

.entry-content h2.fukidashi::before {
	content: "";
	border: 10px solid transparent;
	border-top: 10px solid #fff;
	position: absolute;
	left: 2em;
	bottom: -19px;
	z-index: 2;
}

.entry-content h2.fukidashi::after {
	content: "";
	border: 10px solid transparent;
	border-top: 10px solid #434343;
	position: absolute;
	left: 2em;
	bottom: -22px;
}

.entry-content h2.centerline {
	text-align: center;
	border: none;
	padding: 1em 0;
}

.entry-content h2.centerline::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -1em;
	content: "";
	width: 2em;
	border-top: 2px solid;
}

.entry-content h3 {
	font-size: 1.3em;
	position: relative;
	padding: 0.7em 1em;
	background: #317790;
	color: #fff;
	border-radius: 3px;
}

.entry-content h3.fukidashi::after {
	content: "";
	border: 11px solid transparent;
	border-top: 11px solid #317790;
	position: absolute;
	left: 2em;
	bottom: -22px;
}

.entry-content h4 {
	font-size: 1.2em;
	padding: 0 0 0 1em;
	position: relative;
}

.entry-content h4::before {
	content: "";
	position: absolute;
	top: 5px;
	left: 0;
	display: block;
	width: 4px;
	height: 80%;
	background: #434343;
	border-radius: 20px;
}

.entry-content h5 { font-size: 1.1em; }

.entry-content h6 { font-size: 1em; }

.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	margin: 2em 0 1em;
}

.entry-content p {
	line-height: 2.0;
	margin: 0 0 1.75em;
}

.entry-content table {
	font-size: 0.9em;
	min-width: 100%;
	border: 1px solid #ddd;
	margin-bottom: 1.5em;
}

.entry-content table caption {
	margin: 0 0 7px;
	font-size: 0.75em;
	color: #9fa6b4;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.entry-content tr { border-bottom: 1px solid #ddd; }

.entry-content td {
	padding: 1em;
	border-right: 1px solid #ddd;
}

.entry-content td:last-child { border-right: 0; }

.entry-content th {
	padding: 1em;
	background-color: rgba(245,245,245,0.4);
	border-bottom: 1px solid #ddd;
	border-right: 1px solid #ddd;
}

.entry-content th:last-child { border-right: 0; }

.entry-content blockquote {
	font-size: 0.9em;
	padding: 5% 4% 2%;
	margin: 2.5em 0 3em;
	position: relative;
	border: 1px solid #ddd;
}

.entry-content blockquote::before,
.entry-content blockquote::after {
	font-family: 'FontAwesome';
	font-size: 1.3em;
	position: absolute;
	width: 1em;
	height: 1em;
	display: block;
	padding: 0.3em;
	line-height: 1;
	text-align: center;
	background: #fff;
}

.entry-content blockquote::before {
	content: "\f10d";
	left: -0.4em;
	top: -0.6em;
}

.entry-content blockquote::after {
	content: "\f10e";
	right: -0.4em;
	bottom: -0.7em;
}

.entry-content blockquote h1,
.entry-content blockquote h2,
.entry-content blockquote h3,
.entry-content blockquote h4 { margin-top: 0 !important; }

.entry-content dt {
	font-weight: bold;
	margin-bottom: 0.5em;
}

.entry-content dd {
	margin-left: 0;
	font-size: 0.9em;
	margin-bottom: 1.5em;
}

.entry-content ul li {
	position: relative;
	padding-left: 1.2em;
	margin: 1em 0;
	line-height: 1.8;
}

.entry-content ul li::before {
	font-family: "fontawesome";
	content: "\f111";
	display: block;
	position: absolute;
	left: 0.2em;
	top: .05em;
	-webkit-transform: scale(0.6);
	transform: scale(0.6);
}

.entry-content ul li ul li::before { content: "\f10c"; }

.entry-content ul li ul li ul li::before {
	content: "■";
	-webkit-transform: scale(0.5);
	transform: scale(0.5);
	opacity: 0.4;
}

.entry-content ol { counter-reset: number; }

.entry-content ol li {
	list-style: none;
	position: relative;
	padding-left: 1.6em;
	margin: 1em 0;
}

.entry-content ol > li::before {
	counter-increment: number;
	content: counter(number);
	color: #fff;
	background: #434343;
	width: 1.3em;
	height: 1.3em;
	font-size: 0.9em;
	font-weight: bold;
	display: block;
	text-align: center;
	line-height: 1.3em;
	border-radius: 50%;
	position: absolute;
	left: 0.1em;
	top: 0.3em;
}

.entry-content li ol li::before {
	background: none;
	border: 2px solid;
	color: #434343;
	-webkit-transform: scale(0.8);
	transform: scale(0.8);
	top: 0.2em;
}

.entry-content li li ol li::before {
	content: counter(number) ".";
	border: none;
	-webkit-transform: scale(1.0);
	transform: scale(1.0);
	top: 0.3em;
}

.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 .alignleft,
.entry-content img.alignleft,
.widget .alignleft,
.widget img.alignleft {
	margin-right: 1.5em;
	float: left;
}

.entry-content .alignright,
.entry-content img.alignright,
.widget .alignright,
.widget img.alignright {
	margin-left: 1.5em;
	float: right;
}

.entry-content .aligncenter,
.entry-content img.aligncenter,
.widget .aligncenter,
.widget img.aligncenter {
	margin-right: auto;
	margin-left: auto;
	display: block;
	clear: both;
}

.entry-content pre {
	background: #434343;
	color: #f8f8f8;
	font-size: 0.9em;
	padding: 1.5em;
	margin: 0 0 1.75em;
}

iframe { max-width: 100%; }

iframe.wp-embedded-content { width: 100%; }

.gallery { margin: 0.5em auto 2em !important; }

.gallery dl { margin:0 !important; }

.gallery dl img {
	margin-bottom:0;
	border: none !important;
	padding: 1px;
}

.gallery dd.gallery-caption {
	font-size: 0.85em;
}

.wp-caption {
	max-width: 100%;
	margin-bottom: 1.5em;
}

.wp-caption img {
	max-width: 100%;
	margin-bottom: 0;
	width: 100%;
}

.wp-caption p.wp-caption-text {
	background: #f2f2f2;
	font-size: 0.85em;
	padding: 0.5em;
	text-align: center;
}

.entry-footer .categories,
.entry-footer .tags {
	display: inline-block;
	vertical-align: top;
	margin-bottom: 0.5em;
}

.entry-footer .categories li,
.entry-footer .tags li {
	float: left;
}

.entry-footer .categories a,
.entry-footer .tags a {
	padding: 0.4em 0.8em;
    margin: 0 0.4em 0.4em 0;
	display: inline-block;
	font-size: 0.8em;
	font-weight: bold;
	color: #777;
	border: 2px solid #4593af;
	text-decoration: none;
}

.entry-footer .tags a {
	background: rgba(204,204,204,0.2);
	border-color: transparent;
}

.entry-footer .categories a::before,
.entry-footer .tags a::before {
	font-family: "fontawesome";
	content: "\f02b";
	margin-right: 0.2em;
}

.entry-footer .categories a::before {
	content: "\f07b";
}

.entry-footer .categories a:hover,
.entry-footer .tags a:hover {
	background: #4593af;
	color: #fff;
}

.entry-footer { margin: 1.5em 0; }

/*------------------------------
 Comment
------------------------------*/
#comments-title {
	font-size: 1.2em;
	padding: 0.75em 0;
	margin: 0;
}

#comments-title::before {
	font-family: "fontawesome";
    content: "\f27a";
    font-weight: normal;
    margin-right: 0.2em;
    font-size: 150%;
	display: inline-block;
	-webkit-transform: scale(-1,1);
	transform: scale(-1,1);
}

.commentlist {
	margin: 0;
	list-style-type: none;
}

.comment {
	position: relative;
	clear: both;
	overflow: hidden;
	padding: 1em;
	border-bottom: 1px solid #f8f8f8;
}

.comment .comment-author {
	padding: 1em;
	border: 0;
}

.comment .vcard { margin-left: 2em; }

.comment .comment-metadata time {
	font-size: 0.85em;
}

.comment .vcard .avatar {
	position: absolute;
	left: 1em;
	border-radius: 50%;
}

.comment:last-child { margin-bottom: 0; }

.comment .children { margin: 0; }

.comment[class*=depth-] { margin-top: 1.1em; }

.comment.depth-1 {
	margin-left: 0;
	margin-top: 0;
}

.comment:not(.depth-1) {
	margin-top: 0;
	margin-left: 0;
	padding: 1em;
}

.comment.odd,
.comment.bypostauthor.odd { background: #fff; }

.comment.even,
.comment.bypostauthor.even { background: #f8f8f8; }

.comment-content p {
	margin: 0.5em 0 1.75em;
	line-height: 1.8;
}

.comment-reply-link {
	font-size: 0.9em;
	float: right;
	padding: 0.5em 1em;
}

.comment-edit-link {
	font-style: italic;
	margin: 0 7px;
	text-decoration: none;
	font-size: 0.9em;
}

.comment-respond { padding: 1em 0; }

#reply-title {
	font-size: 1.2em;
	margin: 0;
}

#reply-title::before {
	font-family: "fontawesome";
	content: "\f044";
	font-weight: normal;
	margin-right: 0.2em;
	font-size: 150%;
	vertical-align: middle;
}

.logged-in-as {
  color: #999;
  font-style: italic;
  margin: 0;
}

.comment-form label {
	display: inline-block;
	margin-bottom: 0.5em;
}

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

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

#submit {
	font-size: 1em;
	margin-top: 1em;
}

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

#allowed_tags { margin: 1.5em 10px 0.7335em 0; }

.nocomments { margin: 0 20px 1.1em; }

/*------------------------------
 Post navigation
------------------------------*/
.post-nav {
	padding: 0;
	border-radius: 10px;
}

.post-nav .navigation { max-height: 97px; }

.post-nav .post-nav-list {
	width: 50%;
	float: left;
	margin: 0;
	word-break: break-all;
}

.post-nav .prev.post-nav-list a {
	margin-right: 1px;
	border-radius: 10px 0 0 10px;
}

.post-nav .next.post-nav-list a { border-radius: 0 10px 10px 0; }

.post-nav .post-nav-list dt {
	width: 25%;
	margin: 15px 3.5%;
	display: block;
	float: left;
}

.post-nav .post-nav-list dd {
	display: inline-block;
	width: 57%;
	max-height: 67px;
	margin: 15px 3.5% 15px 0;
	padding: 0;
	overflow: hidden;
	vertical-align: top;
	line-height: 160%;
}

.post-nav .post-nav-list dd.nothumb {
	width: 85%;
	margin: 15px 3.5%;
}

.post-nav a {
	display: block;
	font-size: 0.8em;
	text-decoration: none;
	background: rgba(238,238,238,0.6);
	color: #666;
}

.post-nav-list a:hover { background: #fff; }

.post-nav a .eyecatch {
	vertical-align: middle;
	text-align:center;
	position: relative;
	width: 100%;
	max-height: 67px;
	overflow: hidden;
}

.post-nav a .eyecatch img {
	width: 100%;
}

.post-nav .prev .backnumber-link-icon {
	float: left;
	border-radius: 10px 0 0 10px;
}

.post-nav .next .backnumber-link-icon {
	float: right;
	border-radius: 0 10px 10px 0;
}

.post-nav a .backnumber-link-icon {
	z-index: 2;
	color: #fff;
	width: 7.5%;
	height: 97px;
	background: #444;
	display: block;
	transition-duration: 0.3s;
	transition-timing-function: ease-in-out;
}

.post-nav-list a:hover .backnumber-link-icon {
	background: #999;
}

.post-nav-list a .backnumber-link-icon i {
	font-size: 2em;
	position: relative;
	top: 35.353535%;
	left: 33.333333%;
}

/*------------------------------
 Widget
------------------------------*/
.widget {
	margin-bottom: 3em;
	font-size: 0.9em;
}

.post-widget.upper .widget,
.post-widget.under .widget{
	margin: 1.5em 0;
}

.top-widget.upper .widget,
.top-widget.under .widget{
	margin-bottom: 30px;
}

.widget ul { margin: 0; }

.widget ul li { line-height: 1.6; }

.widget a {
	text-decoration: none;
}

.widget select {
	font-size: 16px;
	margin-top: 1em;
	width: 100%;
	max-width: 100%;
}

.widget.widget_categories label,
.widget.widget_archive label { display: none; }

.widgettitle {
	background: #20333e;
	color: #fff;
	padding: 15px;
	margin-top: 0;
	margin-bottom: 0.9em;
	border-radius: 3px;
}

.widget.widget_tag_cloud .widgettitle,
.widget.widget_categories .widgettitle,
.widget.widget_recent_entries .widgettitle,
.widget.widget_nav_menu .widgettitle,
.widget.widget_pages .widgettitle,
.widget.widget_archive .widgettitle,
.widget.widget_mycategoryorder .widgettitle,
.widget.popular-posts .widgettitle,
.widget.widget_recent_comments .widgettitle { margin-bottom: 0; }

.widget.widget_categories ul,
.widget.widget_recent_entries ul,
.widget.widget_nav_menu ul,
.widget.widget_pages ul,
.widget.widget_archive ul,
.widget.widget_mycategoryorder ul,
.remodal-g-nav ul { margin-top: 0; }

.widget.widget_categories ul li,
.widget.widget_recent_entries li,
.widget.widget_nav_menu li,
.widget.widget_pages li,
.widget.widget_archive li,
.widget.widget_mycategoryorder li,
.remodal-g-nav li,
.category-list ul li {
	border-bottom: 1px solid rgba(204,204,204,0.4);
	margin: 0;
	padding: 0;
	position: relative;
}

.category-list ul li::before { content: none !important; }

.widget.widget_categories li a,
.widget.widget_recent_entries li a,
.widget.widget_nav_menu li a,
.widget.widget_pages li a,
.widget.widget_archive li a,
.widget.widget_mycategoryorder li a,
.remodal-g-nav li a,
.category-list li a {
	display: block;
	padding: 1em 1.5em 1em 0.25em;
	margin: 0;
	position: relative;
	text-decoration: none;
}

.widget.widget_categories li a::after,
.widget.widget_recent_entries li a::after,
.widget.widget_nav_menu li a::after,
.widget.widget_pages li a::after,
.widget.widget_archive li a::after,
.widget.widget_mycategoryorder li a::after,
.remodal-g-nav li a::after,
.category-list li a::after {
	font-family: "fontawesome";
	content: "\f054";
	position: absolute;
	right: 0.2em;
	font-size: 1.2em;
	color: #ccc;
	top: 50%;
	margin-top: -0.7em;
	transition: 0.3s ease-in-out;
}

.widget li a .count {
	border-radius: 3px;
	background: rgba(119,119,119,0.2);
	font-size: 0.9em;
	color: #777;
	padding: 0 0.5em;
	margin-left: 0.3em;
}

/* List (2nd level) */
.widget.widget_nav_menu li ul,
.widget.widget_pages li ul,
.widget.widget_categories li ul,
.remodal-g-nav li ul,
.category-list li ul {
	padding: 0;
	margin: 0;
	border-top: 1px solid rgba(204,204,204,0.4);
}
.widget.widget_nav_menu li ul a,
.widget.widget_pages li ul a,
.widget.widget_categories li ul a,
.remodal-g-nav li ul a,
.category-list li ul a { padding-left: 1em; }

.widget.widget_nav_menu li ul a::before,
.widget.widget_pages li ul a::before,
.widget.widget_categories li ul a::before,
.remodal-g-nav li ul a::before,
.category-list li ul a::before {
	font-family: "fontawesome";
	content: "\f0da";
	display: inline-block;
    margin-right: 5px;
	opacity: 0.25;
}

.widget.widget_nav_menu li ul a::after,
.widget.widget_pages li ul a::after,
.widget.widget_categories li ul a::after,
.remodal-g-nav li ul a::after,
.category-list li ul a::after { content: none; }

.widget.widget_nav_menu li ul li:last-child,
.widget.widget_pages li ul li:last-child,
.widget.widget_categories li ul li:last-child,
.remodal-g-nav li ul li:last-child,
.category-list li ul li:last-child { border: none; }

.widget.widget_nav_menu li ul li .btn-accordion,
.widget.widget_pages li ul li .btn-accordion,
.widget.widget_categories li ul li .btn-accordion,
.remodal-g-nav li ul li .btn-accordion {
	border-color: #69b8d5;
	color: #69b8d5;
}

/* List (3rd level) */
.widget.widget_nav_menu li ul ul a,
.widget.widget_pages li ul ul a,
.widget.widget_categories li ul ul a,
.remodal-g-nav li ul ul a,
.category-list li ul ul a { padding-left: 2em; }

.widget.widget_nav_menu li ul ul a::before,
.widget.widget_pages li ul ul a::before,
.widget.widget_categories li ul ul a::before,
.remodal-g-nav li ul ul a::before,
.category-list li ul ul a::before { content: '− '; }

/* List (4th level) */
.widget.widget_nav_menu li ul ul ul a,
.widget.widget_pages li ul ul ul a,
.widget.widget_categories li ul ul ul a,
.remodal-g-nav li ul ul ul a,
.category-list li ul ul ul a { padding-left: 3em; }

/* Accordion menu */
.widget li.accordion-wrap > a::after,
.remodal li.accordion-wrap > a::after { content: none; }

.btn-accordion {
	display: table;
	font-size: 1.1em;
	width: 2em;
	height: 2em;
	border-radius: 3px;
	text-align: center;
	position: absolute;
	top: 0.7em;
	right: 0;
	color: #4593af;
	border: 2px solid #4593af;
	cursor: pointer;
	transition: 0.3s ease-in-out;
}

.btn-accordion::before {
	font-family: "fontawesome";
	font-weight: bold;
	content: "\f107";
	display: inline-block;
}

.btn-accordion.active { opacity: 0.5; }

.btn-accordion.active::before {
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}

/* Comments */
.widget.widget_recent_comments ul { margin-top:0; }

.widget.widget_recent_comments li {
	border-bottom: 1px solid rgba(204,204,204,0.4);
	padding: 1em 1.5em 1em 0.25em;
	margin: 0;
}

/* Calendar */
.widget.widget_calendar table {
	width: 100%;
	text-align: center;
}

/* Tag cloud */
.widget.widget_tag_cloud .tagcloud { margin-top: 1em; }

.widget.widget_tag_cloud a {
	padding: 0.25em 0.8em 0.25em 1.9em;
	margin: 0 0.1em 0.4em 0;
	display:inline-block;
	font-size: 12px !important;
	color: #434343;
	background: rgba(119,119,119,0.15);
	border-radius: 1em;
	position: relative;
}

.widget.widget_tag_cloud a::before {
	font-family: "fontawesome";
	content: "\f02b";
	position: absolute;
	top: auto;
	left: 0.8em;
	font-size: 1em;
}

.widget.widget_tag_cloud a:hover {
	background: rgba(0,0,0,0.5);
	color: #fff;
}

/* Navigation menu */
.widget.widget_nav_menu li a span,
.remodal-g-nav li a span { display: none; }

/* Recent entries */
.widget.widget_recent_entries li .eyecatch {
	width: 100px;
	max-width: 100px;
	float: left;
	margin-right: 15px;
}

.widget.widget_recent_entries li span.date {
	padding: 0 0.2em;
	display: block;
	opacity: 0.6;
}

.widget.widget_recent_entries li a { overflow: hidden; }

.widget.widget_new_img_post li span.title {
	padding: 0 0 0 115px;
	display: block;
}

.widget.widget_new_img_post li span.date {
	padding: 0 0 0 117px;
}

/*------------------------------
 Footer
------------------------------*/
#page-top {
	position: fixed;
	right: 15px;
	z-index: 2;
}

#page-top a {
	background: rgba(0,0,0,0.75);
	color: rgba(255,255,255,0.8);
	font-size: 18px;
	text-align: center;
	text-decoration: none;
	line-height: 50px;
	width: 50px;
	height: 50px;
	display: block;
	border-radius: 5px;
}

#page-top a:hover {
	background: rgba(255,255,255,0.8);
	color: rgba(0,0,0,0.7);
}

#footer-top {
	background: #232f3e;
	color: #fff;
}

#footer-top li { border-bottom: 1px solid rgba(204,204,204,0.25); }

.site-footer {
	clear: both;
	background: #131a22;
	color: #ddd;
}

.footer-links ul {
	padding: 0;
	margin: 1em 0 0.5em;
}

.footer-links ul li {
	display: inline-block;
	font-size: 0.75em;
	margin: 0 1.5em 0.5em 0;
	border-radius: 3px;
}

.footer-links ul li a {
	color: #f8f9fa;
	text-decoration: none;
	display: block;
	opacity: 0.75;
}

.footer-links ul li a:hover {
	opacity: 1;
}

.follow-box,
.cta-area,
.post-nav,
.author-area,
.pickup-area {
	margin: 10px 0 30px;
}

/*------------------------------
 Article footer
------------------------------*/
/* SNS button */
.share-area { margin: 1em 0; }

.share-area .sns ul { margin: 0 -3px; }

.eyecatch + .share-upper .sns ul,
.share-bottom .sns ul { text-align: center; }

.share-area .sns li {
	display: inline-block;
	margin: 4px 3px;
}

.share-area .sns li a {
	font-size: 1.3em;
	color: #fff;
	width: 70px;
	height: 60px;
	text-align: center;
	position: relative;
	font-family: "fontawesome";
	content: "\f144";
	display: block;
	border-radius: 5px;
	text-decoration: none;
	text-shadow: none;
}

.share-area .sns li a:hover { background: none; }

.share-area .sns li a .text {
	font-size: 12px;
	font-weight: bold;
	display: inline-block;
	position: absolute;
	bottom: 5px;
	left: 0;
	width: 100%;
}

.share-area .sns li .fa {
	position: relative;
	top: -6px;
	line-height: 60px;
}

.share-area .sns .fa-hatebu {
	font-size: 90%;
	font-weight: bold;
}

.sns .twitter a { background: #55acee; }
.sns .twitter a:hover { color: #55acee; }

.sns .facebook a { background: #3b5998; }
.sns .facebook a:hover { color: #3b5998; }

.sns .googleplus a { background: #dd4b39; }
.sns .googleplus a:hover { color: #dd4b39; }

.sns .line a { background: #25af00; }
.sns .line a:hover { color: #25af00; }

.sns .hatebu a { background: #00a4de; }
.sns .hatebu a:hover { color: #00a4de; }

.sns .pocket a { background: #e5364e; }
.sns .pocket a:hover { color: #e5364e; }

/* Follow box */
.follow-box {
	background: rgba(34,34,34,1.0);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	min-width: 100%;
	text-align: center;
}

.follow-box::after {
	background: rgba(34,34,34,1.0);
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0.75;
}

.follow-box .follow-inner {
	position: relative;
	padding: 5% 2% 7%;
	color: #fff;
	text-align: center;
	z-index: 1;
}

.follow-box .h-title {
	font-size: 2.0em;
	font-weight: bold;
	text-transform: uppercase;
	text-align: center;
	margin: 0.5em 0;
	opacity: 0.75;
}

.follow-box .h-title::before {
	font-family: "fontawesome";
	font-weight: normal;
	content: "\f1e0";
	margin-right: 0.2em;
}

.follow-box .follow-title::before {
	content: "\f0fe";
}

.follow-box .follow-inner p {
	font-size: 0.8em;
	font-weight: bold;
	line-height: 1.6;
	margin: 0 0 1em;
	opacity: 0.75;
}

.follow-box .follow-inner a:hover { color: #fff; }

.follow-box .social-fun .facebook-like,
.follow-box .social-fun .twitter-like {
	margin: 0 3px;
	display: inline-block;
}

.follow-box .social-fun .facebook-like { vertical-align: top; }

/* CTA */
.cta-area { background: #f3f3f3; }

.cta-inner {
	padding: 3em 3em 1.5em;
	font-size: 1em;
}

.cta-inner .ctatitle {
	font-size: 1.4em;
	text-align: center;
	margin: 0 0 1.5em;
}

.cta-inner .alignleft, .cta-inner img.alignleft,
.cta-inner .alignright, .cta-inner img.alignright { max-width: 50%; }

.cta-inner .widget {
	font-size: 1em;
	line-height: 2.0;
}

/* Author profile */
.author-area .profile-box {
	text-align: center;
	border: 2px solid #ddd;
	padding: 5%;
}

.author-area .author-avatar,
.author-area .author-description {
	display: table-cell;
	vertical-align: middle;
}

.author-area .author-avatar {
	padding-right: 3%;
	vertical-align: top;
}

.author-area .author-avatar img {
	width: 100%;
	margin: 0 auto;
	border-radius: 50%;
	/*border: 2px solid #fff;
	box-shadow: 0 0 6px rgba(0,0,0,0.16);*/
}

.author-area .author-name {
	font-size: 1.2em;
	margin: 0 0 1em;
}

.author-area .author-name a {
	font-weight: bold;
	text-decoration: none;
}

.author-area .author-name span {
	display: block;
	font-size: 13px;
	font-weight: normal;
	color: #777;
	margin-bottom: 0.5em;
}

.author-area .author-description {
	font-size: 0.9em;
	text-align: left;
}

.author-area .author-acount ul {
	text-align: center;
	margin: 1.5em 0 0;
}

.author-area .author-acount li {
	display: inline-block;
	margin: 0 0.3em;
}

.author-area .author-acount a {
	color: initial;
	display: block;
	text-decoration: none;
}

.author-area .author-acount a span { display: none; }

.author-area .author-acount li a::before {
	font-size: 1.2em;
	background-color: #444;
	width: 2em;
	height: 2em;
	line-height: 2em;
	position: relative;
	margin: 0.2em auto;
	color: #fff;
	font-family: "fontawesome";
	content: "\f144";
	display: block;
	border-radius: 50%;
	transition: 0.3s ease-in-out;
}

.author-area .author-acount li a:hover::before {
	background-color: #f5f5f5;
	color: #444;
}

.author-area .author-acount li.author-twitter a::before {content: "\f099";}
.author-area .author-acount li.author-facebook a::before {content: "\f09a";}
.author-area .author-acount li.author-instagram a::before {content: "\f16d";}
.author-area .author-acount li.author-tumblr a::before {content: "\f173";}

/* Pickup article */
.pickup-area-inner {
	background: rgba(238,238,238,0.6);
	padding: 4% 4% 0;
}

.pickup-area .h-title {
	text-align: center;
	text-transform: uppercase;
	margin: 0 0 1.5em;
	padding: 0 0 0.5em;
	position: relative;
}

.pickup-area .h-title::after {
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -0.9em;
	content: "";
	width: 1.8em;
	border-top: 1px solid;
}

.pickup-post-list .entry-content .entry-title {
	font-size: 1.1em;
	line-height: 1.8;
}

.pickup-post-list .entry-content .entry-time {
	opacity: 0.6;
}

.pickup-post-list .cat-label {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0.5em 1.2em;
	background: #222;
	color: #fff;
	letter-spacing: 0.1em;
	font-size: 0.85em;
	font-weight: bold;
	opacity: 0.9;
	z-index: 1;
}

.pickup-post-list .cat-label:empty:before {
	content: "PICK UP";
}

/* Related article */
.related-area .h-title {
	font-size: 1.2em;
	font-weight: bold;
	line-height: 1.2;
	letter-spacing: 1px;
	position: relative;
	padding: 0 0 0 1em;
	margin: 2em 0;
}

.related-area .h-title::before {
	content: "";
	position: absolute;
	top: 2px;
	left: 0;
	display: block;
	width: 4px;
	height: 100%;
	background: #222;
	border-radius: 20px;
}

.related-area .post-list { font-size: 0.85em; }

.related-area .post-list .entry-content p { font-weight: bold; }

.related-area .post-list .eyecatch img { margin: 0; }

.related-area .post-list a { padding: 10px 0; }

.related-area .post-list .entry-time { opacity: 0.5; }

.related-area .post-list .entry-content { padding-bottom: 0; }

.related-area .post-list-simple .post-thumbnail {
	width: 15%;
	position: static;
}

.related-area .post-list-simple .eyecatch {
	max-height: 80px;
	position: static;
}

.related-area .post-list-block .post-list-inner {
	margin-left: -1%;
	margin-right: -1%;
}

.related-area .post-list-block .post-list {
	width: 23%;
	margin: 0 1% 30px;
}

.related-area .post-list-block .post-list a { padding: 0; }

.related-area .post-list-block .post-list .post-thumbnail { margin: 0; }

.related-area .post-list-block .eyecatch { max-height: 125px; }

.related-area .post-list-block .entry-content p { margin-top: 0.5em; }

/*------------------------------
 Layout & Responsive styles
------------------------------*/
.wrap {
	width: 92%;
	margin: 0 auto;
}

.home.blog #inner-content {
	margin-top: 30px;
}

@media only screen and (min-width: 980px) {
	#inner-content {
		display: table;
		margin-top: 20px;
		margin-bottom: 40px;
	}

	.content-area {
		width: 100%;
		margin-right: -380px;
		float: left;
	}

	#main {
		margin-right: 380px;
		max-width: 800px;
	}

	.error404 #main {
		margin-bottom: 2em;
	}

	#secondary {
		width: 336px;
		float: right;
	}

	.site-footer .inner,
	#footer-top .inner {
		padding: 0 35px;
	}

	#footer-top .inner {
		padding-right: 20px;
	}

	#content.lp {
		padding: 40px 0 80px;
	}

	.lp #inner-content {
		background: #fff;
		overflow: hidden;
		margin-top: 0;
		border: 1px solid #eee;
		border-radius: 5px;
		box-shadow: 0 0 30px rgba(204,204,204,0.25);
	}

	.lp .entry-header { margin-bottom: 0; }
	
	.lp #main {
		width: 800px;
		padding: 30px 0;
		margin-left: auto;
		margin-right: auto;
		float: none;
	}

	.home .onecolumn .content-area,
	.home .onecolumn #main,
	.archive .onecolumn .content-area,
	.archive .onecolumn #main,
	.search .onecolumn .content-area,
	.search .onecolumn #main,
	.single .onecolumn .content-area,
	.single .onecolumn #main,
	.page .onecolumn .content-area,
	.page .onecolumn #main,
	.error404 .onecolumn #main {
		max-width: 800px;
		float: none;
		margin-left: auto;
		margin-right: auto;
	}

	.home .onecolumn .content-area,
	.home .onecolumn #main,
	.archive .onecolumn .content-area,
	.archive .onecolumn #main,
	.search .onecolumn .content-area,
	.search .onecolumn #main {
		max-width: none;
	}

	.page .eyecatch_custom #inner-content.onecolumn,
	.single .eyecatch_custom #inner-content.onecolumn {
		margin-top: 0;
		padding: 0;
	}

	.page .eyecatch_custom #inner-content.onecolumn,
	.single .eyecatch_custom #inner-content.onecolumn,
	.page .eyecatch_custom .onecolumn .content-area,
	.single .eyecatch_custom .onecolumn .content-area,
	.page .eyecatch_custom .onecolumn #main,
	.single .eyecatch_custom .onecolumn #main {
		max-width: initial;
		width: 100%;
		float: none;
		margin-left: auto;
		margin-right: auto;
	}

	.eyecatch_custom #main .entry-header-inner,
	.eyecatch_custom .onecolumn .share-area,
	.page .eyecatch_custom .onecolumn .entry-content,
	.single .eyecatch_custom .onecolumn .entry-content,
	.eyecatch_custom .onecolumn .entry-footer,
	.eyecatch_custom .onecolumn .cta-area,
	.eyecatch_custom .onecolumn .post-widget,
	.eyecatch_custom .onecolumn .top-widget{
		max-width: 800px;
		margin-left: auto;
		margin-right: auto;
	}

	.eyecatch_custom .onecolumn #main .entry-header-inner {
		padding: 10% 0 8%;
	}

	.eyecatch_custom .onecolumn #main .entry-header-inner .entry-title {
		font-size: 2.2em;
	}

	.onecolumn .top-post-list.post-list-block .post-list-inner {
		margin-left: -1%;
		margin-right: -1%;
	}

	.onecolumn .top-post-list.post-list-block .post-list {
		width: 31.333%;
		margin: 0 1% 2%;
	}

	.onecolumn .post-list-simple .post-list {
		font-size: 0.95em;		
	}

	#g-nav .nav > li > a {
		padding: 0.8em 1.2em;
	}
	
	#top-cover.heightfull .txt-main {
		font-size: 4em;
	}

}

@media only screen and (max-width: 979px) {
	#main {
		padding: 0;
		float: none;
	}
	
	.page .eyecatch_custom .onecolumn #main header.entry-header,
	.single .eyecatch_custom .onecolumn #main header.entry-header {
		margin-left: -4.35%;
		margin-right: -4.35%;
	}

}

@media only screen and (min-width: 768px) {
	#container {
		overflow: hidden;
	}

	#logo {
		float: left;
	}

	.site-header.headercenter #g-nav {
		float: none;
	}

	#g-nav,
	#g-nav .nav {
		display: inline-block;
	}

	#g-nav {
		margin: 0;
		float: right;
		position: relative;
	}

	#g-nav .nav {
		margin: 0;
		border: 0;
	}

	#g-nav .nav > li {
		float: left;
		position: relative;
		font-size: 0.8em;
		font-weight: bold;
		text-align: center;
	}

	#g-nav .nav > li::after {
		content: "";
		display: block;
		margin: 0 auto;
		position: absolute;
		right: 0;
		left: 0;
		bottom: 3px;
		width: 75%;
		height: 3px;
		background: #33bad3;
		-webkit-transform: translateY(-3px);
		transform: translateY(-3px);
		opacity: 0;
		transition: 0.3s ease-in-out;
	}

	#g-nav .nav > li:hover::after {
		-webkit-transform: translateY(0px);
		transform: translateY(0px);
		opacity: 1;
	}

	#g-nav .nav > li > a {
		padding-right: 1em;
		padding-left: 1em;
	}

	#g-nav .nav ul {
		background: #222;
		margin-top: 0;
	}

	#g-nav .nav li ul {
		border-radius: 0 0 5px 5px;
	}

	#g-nav .nav li ul li ul {
		border-radius: 0;
	}

	#g-nav .nav li a {
		border-bottom: 0;
	}

	#g-nav .nav > li a span {
		font-size: 0.7em;
		font-weight: normal;
		letter-spacing: 0.1em;
		opacity: 0.6;
	}

	.nav li ul.sub-menu {
		position: absolute;
		z-index: 100;
		top: 100%;
		left: 0;
		margin: 0;
		visibility: hidden;
		opacity: 0;
		-webkit-transition: 0.3s ease-in-out;
		transition: 0.3s ease-in-out;
	}

	.nav li:hover ul.sub-menu {
		visibility: visible;
		opacity: 1;
	}

	.nav li ul.sub-menu li {
		position: relative;
		background: rgba(0,0,0,0.2);
	}

	.nav li ul.sub-menu li:last-child {
		border-radius: 0 0 5px 5px;
	}

	.nav li ul.sub-menu li a {
		display: block;
		min-width: 260px;
		padding: 1em;
		border-bottom: 1px solid rgba(119,119,119,0.3);
		opacity: 0.75;
	}

	.nav li ul.sub-menu li:last-child a {
		border-bottom: 0;
	}

	.nav li ul.sub-menu li a:hover {
		opacity: 1;
	}
	
	/* Grandchild */
	#g-nav .nav li ul.sub-menu li ul {
		top: 0;
		left: 100%;	
		visibility: hidden;
		opacity: 0;
	}

	#g-nav .nav li ul.sub-menu li:hover ul {
		visibility: visible;
		opacity: 1;
	}

	.sidebar {
		font-size: 95%;
	}

    .widget ul li {
		margin-bottom: 0.75em;
	}

	.widget ul li ul {
		margin-top: 0.75em;
		padding-left: 1em;
	}

	#footer-top .footer-inner {
		margin-left: -2%;
		margin-right: -2%;
	}

	#footer-top .footer-col {
		width: 46%;
		float: left;
		margin: 3em 2%;
		vertical-align: top;
	}

	#inner-footer nav {
		float: left;
	}

	.site-footer .copyright {
		font-size: 0.8em;
		padding: 0.6em 0;
		float: right;
	}

	.site-footer .copyright a {
		color: inherit;
		text-decoration: none;
	}

	.author-area .h-title,
	.related-area .h-title {
		text-align: left;
	}

	.author-area .h-title span,
	.related-area .h-title span {
		display: inline;
		margin-right: 0.5em;
	}

}

@media only screen and (max-width: 767px) {
	#logo {
		float: none;
		display: table;
		width: 75% !important;
		margin: 0 auto;
	}

	#logo h1 {
		height: auto;
		text-align: center; 
	}
	
	#logo img {
		margin: 0 auto !important;
	}

	body {
		position: relative;
		left: 0;
		overflow-x: hidden;
	}

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

	.site-header .nav-btn {
		position: absolute;
		top: 0;
		bottom: 0;
		left: 2%;
		margin: auto;
	}

	.site-header .nav-btn.search-btn {
		left: auto;
		right: 2%;
	}

	.g-nav,
	.g-nav-sp {
		position: relative;
	}

	#g-nav .menu {
		padding: 0 10px 8px;
		font-size: .7em;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
	}

	#g-nav .menu > ul {
		width: 100%;
		margin: 0;
		display: table;
		overflow-x: scroll;
		white-space: nowrap;
		float: none;
		position: inherit;
	}

	#g-nav .menu ul ul {
		display: none;
	}

	#g-nav .menu li {
		display: table-cell;
		padding-right: 1.5em;
	}

	#g-nav .nav li a {
		color: #fff;
		font-weight: bold;
		text-align: center;
		padding: .25em 0;
		border-bottom: 3px solid rgba(119,119,119,.4);
	}

	#g-nav .nav li a span {
		display: none;
	}

	.g-nav-sp .fadeInRight {
		animation-duration: 1s;
		animation-fill-mode: both;
		animation-delay: 0.5s;
		animation-timing-function: ease-in-out;
		animation-name: fadeInRight;
	}

	@keyframes fadeInRight {
		from { opacity: 0; transform: translate3d(100%, 0, 0); }
		to { opacity: 1; transform: translate3d(0, 0, 0); }
	}

	@keyframes fadeInRight {
		0% { opacity: 0; transform: translateX(80px); }
		100% { opacity: 1; transform: translateX(0); }
	}

	#top-cover .txt-main { font-size: 2.5em; }
	
	#top-cover .txt-sub { font-size: 1em; }
	
	#top-cover .btn { margin-top: 1.5em; }

	#footer-top .footer-col {
		padding: 3em 2% 0;
	}

	#footer-top .footer-col:last-child {
		padding-top: 0;
	}

	.search-no-results .post-list-simple {
		margin: 0 0 2em;
	}

	.post-list .post-thumbnail {
		width: 40%;
	}

	/* YouTube embed */
	.youtube-container {
		position: relative;
		width: 100%;
		padding-top: 56.25%;
	}

	.youtube-container iframe {
		position: absolute;
		top: 0;
		right: 0;
		width: 100% !important;
		height: 100% !important;
	}

	.widget {
		margin-bottom: 2em;
	}
}

@media only screen and (max-width: 480px) {
	#inner-content {
		width: auto;
		overflow: hidden;
		padding: 0 4%;
		margin: 0 0 20px;
	}
	
	.home.blog #inner-content {
		margin-top: 20px;
	}

	.site-description {
		text-align: center;
	}

	#top-cover {
		padding: 7% 0;
	}

	#top-cover .txt-main {
		font-size: 2.2em;
	}

	#top-cover .txt-sub {
		font-size: 0.8em;
	}

	#top-cover .btn-wrap a {
		font-size: 0.8em;
	}

	.post-list .entry-content .entry-title {
		font-size: 1.0em;
	}

	.post-list-simple .post-list-inner {
		margin-left: -4.35%;
		margin-right: -4.35%;
	}

	.post-list-simple .post-list a {
		padding: 10px 7% 10px 10px;
	}

	.post-list-simple .post-list::after {
		font-family: "fontawesome";
		content: '\f054';
		position: absolute;
		right: 1.5%;
		font-size: 1.4em;
		line-height: 1.0;
		top: 50%;
		margin-top: -0.5em;
		opacity: 0.25;
	}
	
	.top-post-list .entry-header .categories li {
		font-size: 0.6em;
	}

	.entry-header .entry-meta .author {
		display: block;
		margin-right: 0;
		margin-bottom: 0.5em;
	}

	.post-list .post-thumbnail .new {
		font-size: 0.75em;
		top: 0;
		left: 0;
	}

	.entry-content h2,
	.post-nav,
	.post-nav .prev .backnumber-link-icon,
	.post-nav .next .backnumber-link-icon,
	.cta-area {
		border-radius: 0;
	}

	.post-nav .prev.post-nav-list a {
		margin: 0 0 1px;
	}

	.pickup-post-list .cat-label {
		font-size: 0.7em;
	}
	
	.related-area .post-list .entry-content {
		font-size: 0.9em;
	}

	.related-area .post-list-simple .post-thumbnail {
		width: 30%;
	}
	
	.related-area .post-list-block .post-list-inner {
		margin-left: -2%;
		margin-right: -2%;
	}

	.related-area .post-list-block .post-list {
		width: 46%;
		margin: 0 2% 30px;
	}

	.related-area .post-list-block .eyecatch {
		max-height: 110px;
	}

	.author-area .author-avatar {
		width: 32%;
		display: block;
		margin: 0 auto;
		padding: 0;
	}

	.author-area .author-name {
		text-align: center;
		margin-top: 0.5em;
	}

	#inner-footer {
		padding: 0;
	}

	#inner-footer.wrap {
		width: 100%;
	}

	.footer-links ul {
		margin: 0;
		border-top: 1px solid rgba(119,119,119,0.2);
	}

	.footer-links ul li {
		margin: 0;
		display: block;
		border-bottom: 1px solid rgba(119,119,119,0.2);
	}

	.footer-links ul li a {
		padding: 0.8em 2em 0.8em 0.8em;
		border: none;
		border-radius: 0;
		position: relative;
	}

	.footer-links ul li a::after {
		font-family: "fontawesome";
		content: '\f054';
		position: absolute;
		right: .8em;
		font-size: 1.2em;
		top: 50%;
		margin-top: -0.8em;
		color: rgba(119,119,119,0.2);
	}

	#inner-footer .copyright {
		margin: 1em;
		font-size: 0.75em;
		text-align: center;
	}
	
	.single-title, .page-title, .entry-title {
		font-size: 1.4em;
	}
	
	.entry-header .entry-meta {
		font-size: 80%;
	}

	.entry-content h2 {
		font-size: 1.4em;
	}
	
	.entry-content h3 {
		padding: 0.7em 0.5em;
		font-size: 1.2em;
	}

	.page .eyecatch_custom #main header.entry-header,
	.single .eyecatch_custom #main header.entry-header,
	.entry-header .eyecatch,
	.cta-area,
	.follow-box,
	.post-nav,
	.pickup-area {
		margin-left:  -4.35%;
		margin-right: -4.35%;
	}

	.post-nav .navigation {
		max-height: none;
	}

	.post-nav .post-nav-list {
		width: 100%;
		float: none;
	}

	.post-nav .prev.post-nav-list a,
	.post-nav .next.post-nav-list a {
		border-radius: 0;
	}

	.post-nav a .backnumber-link-icon {
		width: 22px;
		height: 22px;
		text-align: center;
	}

	.post-nav-list a .backnumber-link-icon i {
		position: static;
		font-size: 1.5em;
		line-height: 22px;
	}

	.remodal-g-nav {
		margin-top: 0;
	}

	.remodal-g-nav li a {
		text-decoration: none;
	}

	.share-area .sns ul {
		margin: 0 -2px;
	}

	.share-area .sns li {
		margin: 4px 2px;
	}
	
	.share-area .sns li a {
		width: 52px;
		height: 52px;
	}
	
	.share-area .sns li .fa {
		top: -10px;
	}
	
	.share-area .sns li a .text {
		font-size: 10px;
	}

}

@media only screen and (min-width: 1240px) {
	.wrap {
		width: 1180px;
	}
	
	#g-nav .nav > li {
		font-size: 0.9em;
	}
}