/*
Theme Name: yokocho
Version: 1.0.0
*/
@charset "UTF-8";

/*--------------------------------------------------------------
	CSS Reset
	COMMON
	HEADER
	NAVIGATION HEADER
	NAVIGATION MOBILE
	FOOTER
	SIDE MENU
	FRONT PAGE
	人気ランキングTOP25 PAGE
	発売日カレンダー PAGE
	作品一覧 PAGE
	SINGLE PAGE
	CONTACT PAGE
	404 PAGE
----------------------------------------------------------------------------- */

/* -------------------------------------------------------------------------- */
/*	CSS Reset
/* -------------------------------------------------------------------------- */
html,
body {
	border: none;
	margin: 0;
	padding: 0;
}
h1, h2, h3, h4, h5, h6, p,
blockquote, address, big,
cite, code, em, font, img, small,
strike, sub, sup, li, ol, ul,
fieldset, form, label, legend, button,
table, caption, tr, th, td {
	border: none;
	font-size: inherit;
	font-weight: normal;
	line-height: inherit;
	margin: 0;
	padding: 0;
	text-align: inherit;
}
a {
	text-decoration:none; 
}
ul, li {
	list-style: none;
}
blockquote::before,
blockquote::after {
	content: "";
}
textarea {
	resize: none;
}
:focus {
	outline: none;
}

/* -------------------------------------------------------------------------- */
/*	COMMON
/* -------------------------------------------------------------------------- */
html {
	height: 100%;
	font-size: 62.5%;
}
body {
	font-size: 1.4rem;
	font-family: "Helvetica", Arial, sans-serif;
	line-height: 1.8;
	background-color: rgba(0, 0, 0, 0.9);
	color: #fff;
	word-wrap: break-word;
	overflow-y: scroll;
	position: relative;

}
h1, h2, h3, h4, h5, h6 {
	font-weight: 700;
}
h1 {
	font-size: 2.2rem;
}
h2 {
	font-size: 2rem;
}
h3 {
	font-size: 1.8rem;
}
h4, h5, h6 {
	font-size: 1.6rem;
}
a {
	color: #fff;
	transition: all 0.4s;
}
a:hover {
	filter: opacity(0.8);
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
input, 
select, 
textarea, 
::placeholder {
	font-family: inherit;
	border: none;
	border-radius: unset;
	-webkit-appearance: none;
}
textarea {
	display: block;
}
#body-wrapper {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
}
#page {
	display: flex;
	flex-flow: column;
	width: 100%;
	min-height: 100vh;
	box-sizing: border-box;
}
#site-content {
	flex: 1;
	display: flex;
	z-index: 1;
	padding-top: 80px;
}
.main-content {
	flex: 1;
	padding: 30px 40px 60px;
}
.page-content {
	margin: 0 20px 50px;
}
.content-body {
	margin-bottom: 40px;
}
.section {
	position: relative;
	padding: 70px 100px;
}
.page-title {
	font-size: 2.8rem;
	line-height: 1.4;
	border-top: 1px solid #333;
	border-bottom: 1px solid #333;
	margin-bottom: 40px;
	padding: 40px 0;
}
.title {
	font-size: 1.2rem;
}
.content-header {
	margin-bottom: 70px;
}
.content-header-menu {
	display: flex;
	justify-content: center;
}
.content-header-link {
	display: flex;
	flex-direction: column;
	text-align: center;
	width: auto;
	margin: 0 14px;
	padding-top: 3px;
}
.breadcrumbs {
	line-height: 1.6;
	margin-bottom: 30px;
}
span.breadcrumb_last {
	color: #777;
}
.content-list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px 30px;
	border-bottom: 1px solid #333;
	margin-bottom: 40px;
	padding-bottom: 40px;
}
.post-item {
	width: calc((100% / 3) - 20px);
	box-sizing: border-box;
}
.post-item-img-wrapper img {
	object-fit: cover;
	aspect-ratio: 16 / 9;
	border-radius: 3px;
	max-width: 100%!important;
	max-height: 100%!important;
}
.post-item-title {
	font-size: 1.4rem;
	line-height: 1.5;
	margin: 0.5em 0;
}
.post-date {
	color: #777;
}
.main-content .searchform {
	padding-bottom: 40px;
}
body:not(.search) .main-content .searchform {
	display: none;
}
body.home .main-content .searchform {
	padding-top: 15px;
}
.searchform > div {
	display: flex;
}
.searchform input[type="text"] {
	color: #ddd;
	border-radius: 3px 0 0 3px;
}
.searchform input[type="submit"] {
	background-color: #999;
	border-radius: 0 3px 3px 0;
	width: 100px;
}
.searchform input[type="submit"]:hover {
	filter: brightness(1.1);
}
@media screen and (max-width: 960px) {
	body {
		font-size: 1.4rem;
	}
	a {
		transition: none;
	}
	.page-content {
		margin: 0 20px;
	}
	.section {
		padding: 50px 20px 60px;
	}
	.header-image {
		height: 200px;
		margin-left: 0;
	}
	#site-content {
		padding-top: 70px;
	}
	.main-content {
		padding: 15px 0 60px;
	}
	.page-title {
		font-size: 2.5rem;
	}
	.content-list {
		gap: 30px 20px;
	}
	.post-item {
		width: calc(50% - 10px);
	}
	body:not(.search) .main-content .searchform {
		display: block;
	}
}

/* -------------------------------------------------------------------------- */
/*	HEADER
/* -------------------------------------------------------------------------- */
.header-top {
	position: fixed;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: 80px;
	padding: 0 20px;
	box-sizing: border-box;
	background-color: #fa2198;
}
.header-left {
	display: flex;
	align-items: center;
	width: 480px;
}
.header-right {
	display: flex;
	flex: 1;
	justify-content: end;
	align-items: center;
}
.site-logo-link {
	line-height: 1;
}
.site-logo-link:hover {
	filter: none;
}
.site-logo {
	width: 150px;
	max-width: 100%;
	height: auto;
}
.logo-sp {
	position: fixed;
	display: flex;
	align-items: center;
	line-height: 1em;
	width: 100%;
	height: 60px;
	background-color: #fa2198;
	padding: 0 80px 0 20px;
	z-index: 2;
}
.logo-sp a:hover {
	filter: none;
}
.left-menu-btn {
	display: flex;
	align-items: center;
	height: 30px;
	margin-left: 15px;
	cursor: pointer;
}
.header-left .left-menu-btn {
	display: none;
}
.left-menu-ul span {
	display: inline-block;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	vertical-align: middle;
	margin: 0 3px;
	background-color: #fff;
}
.header .searchform {
	margin-left: 30px;
	width: 220px;
}
.header .searchform input {
	font-size: 1.3rem;
	padding: 7px 10px;
	color: #fff;
	background-color: #ff68bb;
	height: 30px;
}
.header .searchform input[type="submit"] {
	text-indent: -9999px;
	width: 30px;
	height: 30px;
	border: none;
	background-color: #ff68bb;
	background-image: url('assets/img/icon-loupe.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: 15px;
	cursor: pointer;
}
.header .searchform input[type="submit"]:hover {
	background-color: #ff68bb;
	filter: none;
}
.header .nav-sp .searchform {
	width: 100%;
	box-sizing: border-box;
	margin-left: 0;
	padding: 25px 30px 5px;
}
.header .nav-sp .searchform input {
	font-size: 1.8rem;
	height: 40px;
}
.header .nav-sp .searchform input[type="submit"] {
	width: 40px;
	height: 40px;
}
@media screen and (max-width: 960px) {
	.site-logo {
		width: 130px;
	}
	.left-menu-btn {
		margin-left: 10px;
	}
}

/* -------------------------------------------------------------------------- */
/*	NAVIGATION HEADER
/* -------------------------------------------------------------------------- */
.menu {
	display: flex;
	font-size: 1.4rem;
}
.header-nav .menu {
	flex-wrap: wrap;
	justify-content: end;
}
.header-nav .menu-item {
	margin-left: 20px;
}
.header-nav .menu-item a {
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.7;
	transition: all 0.4s;
}
.menu-item-has-children {
	position: relative;
}
.menu-item-has-children > a:hover {
	cursor: pointer;
}
.menu-item-has-children > a {
	padding-right: 12px;
}
.menu-item-has-children > a::before {
	position: absolute;
	bottom: 7px;
	content: "";
	right: 1px;
	width: 5px;
	height: 5px;
	border-top: 1px solid #1a1d7a;
	border-right: 1px solid #1a1d7a;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}
.sub-menu {
	position: absolute;
	width: max-content;
	text-align: center;
	left: 50%;
	margin: auto;
	padding: 5px 15px 15px;
	transform: translateX(-50%);
	-webkit- transform: translateX(-50%);
	visibility: hidden;
	background-color: #fff;
	opacity: 0;
	top: 50%;
	transition: all .3s;
}

/* -------------------------------------------------------------------------- */
/*	NAVIGATION MOBILE
/* -------------------------------------------------------------------------- */
.header-sp {
	display: none;
}
.header-main {
	width: 100%;
	z-index: 2;
}
.mobile-nav {
	margin-top: 30px;
	text-align: center;
}
.mobile-nav .menu {
	flex-direction: column;
	border-top: 1px solid #999;
	font-size: 1.7rem;
	line-height: 2;
}
.mobile-nav .menu-item {
	border-bottom: 1px solid #999;
}
html.fixed body {
	overflow: hidden;
}
.drawer {
	position: fixed;
	top: 0;
	right: 0;
	z-index:999;
}
.navbar_toggle {
	padding: 23px 18px;
	cursor:pointer;
}
.navbar_toggle_icon {
	position: relative;
	display: block;
	height: 2px;
	width: 25px;
	background: #fff;
	-webkit-transition: ease .5s;
	transition: ease .5s;
}
.navbar_toggle:not(.open) .navbar_toggle_icon {
	background: #fff;
}
.navbar_toggle_icon:nth-child(1) {
	top: 0;
}
.navbar_toggle_icon:nth-child(2) {
	margin: 5px 0;
	opacity: 1;
}
.navbar_toggle_icon:nth-child(3) {
	top: 0;
}
.navbar_toggle.open .navbar_toggle_icon:nth-child(1) {
	top: 7px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.navbar_toggle.open .navbar_toggle_icon:nth-child(2) {
	opacity: 0;
}
.navbar_toggle.open .navbar_toggle_icon:nth-child(3) {
	top: -7px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.nav-sp{
	-webkit-transition: ease .6s;
	transition: ease .4s;
	position: fixed;
	top: 58px;
	left: 0;
	right: 0;
	bottom: 0;
	box-sizing: border-box;
	background-color: #fa2198;
	z-index: -1;
	transform: translateX(101%);
}
.nav-sp a {
	display: block;
	font-weight: 700;
	color: #fff;
	padding: 10px 0;
}
.nav-sp a:hover {
	filter: none;
}
.header-sp-logo {
	display: flex;
	align-items: center;
	line-height: 1em;
	height: 60px;
	margin: 0 80px 0 20px;
}
.nav-sp.open {
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	z-index: 888;
	transform: translateX(0);
}
@media screen and (max-width: 960px) {
	.header-main {
		display: none!important;
	}
	.header-sp {
		display: flex;
	}
}

/* -------------------------------------------------------------------------- */
/*	FOOTER
/* -------------------------------------------------------------------------- */
.footer {
	background-color: #fa2198;
	padding: 60px 20px 30px;
}
.footer a {
	font-size: 1.4rem;
	font-weight: 700;

}
.footer-link {
	display: flex;
	font-size: 1.3rem;
	margin-bottom: 50px;
}
.footer-link-item {
	flex: 1;
	text-align: center;
	padding: 0 20px;
	margin: 0;
	box-sizing: border-box;
}
.footer-link-item-title {
	font-size: 1.6rem;
	font-weight: 700;
	border-bottom: 1px solid #999;
	padding-bottom: 15px;
}
.footer-link-item .menu {
	flex-wrap: wrap;
	flex-direction: column;
	font-size: inherit;
}
.footer-link-item .menu li {
	border-bottom: 1px solid #999;
}
.footer-link-item .menu li a {
	display: block;
	color: #ccc;
	padding: 15px 20px;
}
.footer-credits {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid #aaa;
	padding-top: 30px;
}
.nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	font-size: 1.6rem;
	font-weight: 700;
}
.page-numbers {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #333;
	line-height: 1;
	width: 50px;
	height: 50px;
	border-radius: 3px;
	margin: 6px;
}
.page-numbers.current {
	background-color: #686868;
}
.go-to-top {
	display: none;
	position: fixed;
	bottom: 20px;
	right: 20px;
	line-height: 0;
	z-index: 10;
}
.go-to-top a {
	display: inline-block;
	width: 40px;
	height: 40px;
	background-color: #444;
	border-radius: 3px;
}
.go-to-top a:hover {
	filter: none;
	background-color: #666;
}
.arrow {
	position: relative;
}
.arrow::after {
	content: '';
	display: block;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
}
.arrow-right::after {
	position: absolute;
	top: 18px;
	right: 15px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.grecaptcha-badge {
	display: none;
}
@media screen and (max-width: 960px) {
	.page-numbers {
		width: 35px;
		height: 35px;
	}
	.footer {
		padding: 20px;
	}
	.footer-link {
		flex-direction: column;
	}
	.footer-link-item {
		padding: 0;
	}
	.footer-link-item-title {
		margin-top: 50px;
	}
	.footer-credits {
		margin: 0 -20px 10px;
	}
	.footer-copyright {
		text-align: center;
		width: 100%;
	}
}

/* -------------------------------------------------------------------------- */
/*	SIDE MENU
/* -------------------------------------------------------------------------- */
.side-menu-left {
	width: 200px;
	box-sizing: border-box;
	background-color: #000;
	padding: 30px 20px 60px;
}
.side-menu-right {
	width: 300px;
	box-sizing: border-box;
	background-color: #000;
	padding: 30px 20px 60px;
}
.side-menu-item {
	margin-bottom: 40px;
}
.side-menu-list {
	margin-top: 10px;
}
.side-menu-list li {
	display: inline-block;
	margin: 0 10px 13px 0;
}
.side-menu-list li a {
	font-size: 1.2rem;
	font-weight: 700;
	color: #333;
	background-color: #eee;
	border-radius: 3px;
	padding: 6px 10px;
}
.side-menu-right-title {
	font-size: 1.8rem;
	text-align: center;
	margin-bottom: 15px;
}
.side-menu-right-item .content-list {
	gap: 25px 30px;
	border: none;
	margin-bottom: 20px;
	padding-bottom: 0;
}
.side-menu-right-item .post-item {
	width: 100%;
}
.side-menu-right-footer {
	text-align: center;
	border-bottom: 1px solid #333;
	margin-bottom: 30px;
	padding-bottom: 30px;
}
.side-link-more-btn {
	background-color: #fa2198;
	color: #fff;
	border-radius: 3px;
	padding: 5px 8px;
}
@media screen and (max-width: 1279px) {
	.side-menu-left {
		transition: ease .4s;
		position: fixed;
		overflow-y: scroll;
		scrollbar-width: none;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		padding-top: 110px;
		border-right: 1px solid #333;
		z-index: 10;
		transform: translateX(-101%);
	}
	.side-menu-left.open {
		transform: translateX(0);
	}
	.header-left .left-menu-btn {
		display: flex;
	}
	#site-content {
		flex-direction: column;
	}
	.side-menu-right {
		width: 100%;
	}
	.side-menu-right-item .post-item {
		width: calc((100% / 3) - 20px);
	}
}
@media screen and (max-width: 960px) {
	.side-menu-left {
		padding-top: 85px;;
	}
}
@media screen and (max-width: 767px) {
	.side-menu-right-item .post-item {
		width: 100%;
	}
}

/* -------------------------------------------------------------------------- */
/*	FRONT PAGE
/* -------------------------------------------------------------------------- */
.home .side-menu-right {
	display: none;
}
.front-list-block {
	margin-bottom: 70px;
}
.front-list-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid #333;
	color: #888;
	width: 100%;
	margin-bottom: 30px;
	padding-bottom: 10px;
}
.front-title {
	font-size: 2.4rem;
}
.front-list-button {
	display: flex;
}
.slider-btn, 
.link-more-btn {
	color: #666;
	background: #333;
	border-radius: 3px;
}
.slider-btn {
	font-weight: 700;
	margin: 0 5px;
	padding: 2px 7px;
	transition: all 0.4s;
}
.slider-btn[disabled] {
	opacity: 0.4;
}
.slider-btn:not([disabled]) {
	cursor: pointer;
}
.slider-btn:not([disabled]):hover {
	color: #fff;
}
.link-more-btn {
	margin-left: 10px;
	padding: 2px 5px;
}
.link-more-btn:hover {
	filter: none;
	color: #fff;
}
.slider-item.post-item {
	width: calc(25% - 23px);
}
@media screen and (max-width: 960px) {
	.front-list-header {
		flex-direction: column;
	}
	.front-title {
		margin-right: auto;
		padding-bottom: 5px;
	}
	.front-list-button {
		margin-left: auto;
	}
	.slider-item.post-item {
		width: calc(50% - 10px);
	}
}

/* -------------------------------------------------------------------------- */
/*	人気ランキングTOP25 PAGE
/* -------------------------------------------------------------------------- */
.tab-buttons {
	display: flex;
	gap: 10px;
	margin-bottom: 30px;
}
.tab-button {
	flex-grow: 1;
	padding: 15px;
	text-align: center;
	color: #999;
	background-color: #333;
	cursor: pointer;
	transition: all 0.3s;
	outline: none;
	font-size: 1.6rem;
}
.tab-button:hover {
	filter: brightness(1.5);
}
.tab-button.active:hover {
	filter: none;
}
.tab-button.active {
	color: #fff;
	font-weight: bold;
	background-color: #888;
}
.tab-content {
	padding: 20px;
	background-color: #fff;
}
.tab-container .tab-pane {
	display: none;
}
.tab-container .tab-pane.active {
	display: block;
}
.wpp-li {
	border-bottom: 1px solid #333;
	margin-bottom: 20px;
	padding-bottom: 20px;
	position: relative;
	counter-increment: cnt;
}
.wpp-li::before {
	content: counter(cnt);
	position: absolute;
	top: -4px;
	left: -4px;
	font-weight: 700;
	line-height: 1;
	background: #fa2198;
	border-radius: 5px;
	padding: 7px 10px;
}
.wpp-link {
	display: flex;
}
.wpp-link:hover {
	filter: none;
}
.wpp-tn {
	width: 50%;
	max-width: 300px;
}
.wpp-tn img {
	object-fit: cover;
	aspect-ratio: 16 / 9;
	border-radius: 3px;
}
.wpp-data {
	flex: 1;
	margin-left: 15px;
	transition: all 0.4s;
}
.wpp-data:hover {
	filter: opacity(0.8);
}
.wpp-title {
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 5px;
}
.wpp-view {
	color: #777;
	font-size: 1.9rem;
}
@media screen and (max-width: 767px) {
	.wpp-link {
		flex-direction: column;
	}
	.wpp-tn {
		width: 100%;
		max-width: 100%;
	}
	.wpp-data {
		margin-top: 15px;
		margin-left: 0;
	}
	.wpp-title {
		font-size: 1.6rem;
	}
	.wpp-view {
		font-size: 1.4rem;
	}
}

/* -------------------------------------------------------------------------- */
/*	発売日カレンダー PAGE
/* -------------------------------------------------------------------------- */
.index-month-list {
	display: flex;
	gap: 5px;
	width: 100%;
	margin: 7px 0 20px;
}
.index-month-item {
	flex: 1;
	box-sizing: border-box;
}
.index-month-item a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	color: #333;
	line-height: 1.3;
	background-color: #eee;
	border-radius: 3px;
	text-align: center;
	padding: 8px 5px;
	box-sizing: border-box;
}
.release-search-index-result {
	margin-top: 60px;
}
.title-year {
	margin-top: 35px;
}
.title-year-month-wrapper {
	background-color: #fff;
	border-radius: 3px;
	margin-top: 5px;
	padding: 5px 5px 5px 8px;
}
.title-year-month {
	font-size: 2rem;
	font-weight: 700;
	color: #333;
	border-left: #cccc solid 6px;
	padding-left: 0.5em;
}
.month-list {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 24px 0;
}
.month-list-item {
	display: flex;
	width: calc(25% - 15px);
}
.month-list-item a {
	display: flex;
	flex-direction: column;
	color: #222;
	font-size: 1.3rem;
	background-color: #eee;
	border-radius: 3px;
	width: 100%;
	padding: 10px;
}
.month-list-item-img {
	margin-bottom: 1em;
}
.month-list-item-img img {
	object-fit: cover;
	aspect-ratio: 16 / 9;
	border-radius: 3px;
}
.month-list-item-title {
	font-weight: 700;
	line-height: 1.5;
	padding-bottom: 6px;
}
.month-list-item-date {
	font-size: 1.2rem;
	text-align: right;
	margin-top: auto;
}
@media screen and (max-width: 1535px) {
	.month-list-item {
		width: calc(50% - 10px);
	}
}

/* -------------------------------------------------------------------------- */
/*	作品一覧 PAGE
/* -------------------------------------------------------------------------- */
.initial-search-index {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 8px;
}
.search-index-item {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	width: calc(50% - 4px);
}
.search-index-button {
	width: calc(20% - 4px);
	box-sizing: border-box;
}
.span_kana, 
.link_kana {
	display: flex;
	justify-content: center;
	width: 100%;
	border-radius: 3px;
	text-align: center;
	line-height: 2.5;
}
.span_kana {
	color: #777;
	background-color: #333;
}
.link_kana {
	color: #333;
	background-color: #eee;
}
.work-list-kana-title {
	border-bottom: 2px solid;
	margin-bottom: 15px;
	padding-top: 40px;
}
.work-list-kana {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.work-list-kana-item {
	display: flex;
	width: calc((100% / 3) - 4px);
}
.work-list-kana-item a {
	display: flex;
	align-items: center;
	width: 100%;
	border: 1px solid;
	border-radius: 3px;
	padding: 5px 8px;
}
@media screen and (max-width: 960px) {
	.work-list-kana {
		flex-direction: column;
	}
	.work-list-kana-item {
		width: 100%;
	}
}

/* -------------------------------------------------------------------------- */
/*	SINGLE PAGE
/* -------------------------------------------------------------------------- */
.post-title {
	font-size: 2.8rem;
	line-height: 1.5;
	margin-top: 1em;
}
.content-single .single-meta {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	border-top: 1px solid #333;
	border-bottom: 1px solid #333;
	line-height: 2.5;
	margin: 20px 0;
	padding: 15px 0;
}
.content-single .single-meta-row {
	display: flex;
	flex-wrap: wrap;
}
.content-single .post-date {
	margin-right: 15px;
}
.post-categories, 
.post-categories li {
	display: inline;
}
.post-categories {
	margin-right: 15px;
}
.btn-download {
	color: #666;
	background: #333;
	border-radius: 3px;
	padding: 4px 8px;
}
.btn-download:hover {
	color: #fff;
	filter: none;
}
.article {
	margin: 20px 0 40px;
}
.article p {
	margin-bottom: 0.8em;
}
.video-content {
	width: 100%;
}
.wp-video {
	width: 100% !important;
	min-width: 100% !important;
	aspect-ratio: 16 / 9 !important;
	opacity: 0;
	animation: cutIn 0.01s forwards;
	animation-delay: 0.3s;
}
@keyframes cutIn {
	to {
		opacity: 1;
	}
}
.mejs-video {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 16 / 9 !important;
}
.mejs-controls {
	bottom: -1px !important;
}
.video-meta {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 10px 0;
	background-color: #323232;
	padding: 10px;
	position: relative;
	z-index: 2;
}
.content-body .pld-like-dislike-wrap {
	display: none;
}
.pld-count-wrap {
	display: none;
}
.pld-like-dislike-wrap {
	display: flex;
	margin-bottom: 0;
}
a.pld-like-dislike-trigger {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}
.pld-common-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 35px;
	font-size: 1.8rem;
	background-color: #666;
	border-radius: 3px;
}
.video-meta-item {
	display: flex;
	gap: 10px;
}
.post-nav-button {
	display: flex;
	background-color: #666;
	height: 35px;
	align-items: center;
	justify-content: center;
	border-radius: 3px;
	font-size: 1.4rem;
	font-weight: 700;
	padding: 0 8px;
}
.post-nav-button[disabled] {
	opacity: 0.4;
}
.video-like {
	text-align: right;
	color: #777;
	line-height: 1.5;
	margin-top: 8px;
}
.like-percentage {
	display: flex;
	justify-content: end;
	align-items: center;
	font-size: 2.7rem;
	font-weight: 700;
}
.like-percentage i {
	font-size: 0.9em;
	padding: 0 8px 4px 0;
}
.work-info-title {
	line-height: 1.5;
	border-left: 3px solid #777;
	margin-bottom: 8px;
	padding-left: 0.7em;
}
.work-info-table {
	border-collapse: collapse;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #777;
	margin: 5px 0 30px;
}
.work-info-table th {
	box-sizing: border-box;
	padding: 4px 15px 4px 0;
	color: #fa2198;
	width: 80px;
}
.work-info-table td {
	box-sizing: border-box;
	padding: 4px 0 4px 0;
}
.tag-list {
	font-size: 1.5rem;
}
.tag-list a {
	color: #777;
}
.crp_related {
	margin-top: 50px;
}
.crp_related h2 {
	margin-bottom: 15px;
}
.crp_title {
	display: block;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1.5;
	margin: -0.2em 0 0.5em;
}
.crp_date {
	color: #777;
}
@media screen and (max-width: 960px) {
	.post-title {
		font-size: 2rem;
	}
}

/* -------------------------------------------------------------------------- */
/*	CONTACT PAGE
/* -------------------------------------------------------------------------- */
.wpcf7, input, textarea {
	font-size: 1.6rem;
	color: #9a9a9a;
}
input, textarea {
	width: 100%;
	box-sizing: border-box;
	border-radius: 3px;
	background-color: #3c3c3c;
	padding: 12px 15px;
}
input[type="checkbox"] {
	width: 13px;
	height: 13px;
	padding: 5px;
	margin: 0 5px 0 0;
	-webkit-appearance: auto;
}
input[type="submit"] {
	width: 100px;
	font-weight: 700;
	color: #fff;
	cursor: pointer;
	transition: 0.4s;
}
input[type="submit"]:not(:disabled):hover {
	background-color: #999;
}
.wpcf7-list-item {
	margin: 0;
}
.div_wpcf7 {
	margin-bottom: 1em;
}
.wpcf7-not-valid-tip {
	margin-top: 5px;
}
.wpcf7-response-output {
	margin: 2em 0 !important;
}

/* -------------------------------------------------------------------------- */
/*	404 PAGE
/* -------------------------------------------------------------------------- */
.page-not-found {
	text-align: center;
	width: 100%;
	padding: 100px 0;
}
