﻿@charset 'UTF-8';
/* ------------------------------ */
/* YAKULT						 */
/* ------------------------------ */
/* build by gulp				  */
/* ------------------------------ */
/* [Core] */
/* ------------------------------ */
/* Reset */
/* ------------------------------ */
/* Eric Meyer's Reset CSS v2.0 (http://meyerweb.com/eric/tools/css/reset/) */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font: inherit;
	font-style: normal;
	font-size: 100%;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

body {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

table {
	border-spacing: 0;
	border-collapse: collapse;
}

/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: baseline;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

[hidden],
template {
	display: none;
}

a {
	background: transparent;
}

a:active,
a:hover {
	outline: 0;
}

sub,
sup {
	position: relative;
	vertical-align: baseline;
	font-size: 75%;
	line-height: 0;
}

sup {
	top: -.5em;
}

sub {
	bottom: -.25em;
}

button,
input,
optgroup,
select,
textarea {
	margin: 0;
	color: inherit;
	font: inherit;
}

button {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

button,
html input[type='button'],
input[type='reset'],
input[type='submit'] {
	cursor: pointer;

	-webkit-appearance: button;
}

button[disabled],
html input[disabled] {
	cursor: default;
}

input[type='checkbox'],
input[type='radio'] {
	box-sizing: border-box;
	padding: 0;
}

input[type='search'] {
	box-sizing: content-box;

	-webkit-appearance: textfield;
}

textarea {
	overflow: auto;
}

/* ------------------------------ */
/* Init */
/* ------------------------------ */
html {
	overflow-y: scroll;
	font-size: 62.5%;
}
@media only screen and (max-width: 640px) {
	html {
		-webkit-text-size-adjust: 100%;
		-moz-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
		text-size-adjust: 100%;
	}
}

body {
	background: #fdf5f4;
	color: #333641;
	word-wrap: break-word;
	word-break: break-all;
	font-size: 1.6rem;
	font-family: 'Karla', 'Noto Sans JP', sans-serif;
	line-height: 1.5;
}
@media only screen and (max-width: 640px) {
	body {
		font-size: 2.4rem;
	}
}
@media print, screen and (min-width: 641px) {
	body {
		min-width: 1120px;
	}
}

html,
body {
	height: 100%;
	min-height: 100%;
}

a {
	text-decoration: underline;
}

a:link,
a:visited {
	color: #333641;
}

a:hover,
a:active {
	color: #333641;
	text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: normal;
	line-height: 1.3;
}

*,
*:before,
*:after {
	box-sizing: border-box;
	max-height: 99999px;
	background: transparent;
	word-break: normal;
}

img {
	vertical-align: bottom;
}

img.fluidImg {
	width: 100%;
	height: auto;
}

strong {
	font-weight: bold;
}

::-webkit-input-placeholder {
	color: #c9c9c9;
}

::-moz-placeholder {
	color: #c9c9c9;
}

/* [Layout] */
/* ------------------------------ */
/* Global Header */
/* ------------------------------ */
.siteHeader {
	position: relative;
	z-index: 110;
	padding: 32px 0 10px;
	background-color: #ffffff;
}
@media print, screen and (min-width: 641px) {
	.siteHeader {
		padding: 22px 0 86px;
	}
	.pageHome .siteHeader {
		padding: 22px 0;
	}
}
.siteHeader .ttl {
	text-align: center;
	font-size: 0;
}
@media print, screen and (min-width: 641px) {
	.siteHeader .ttl {
		width: 1120px;
		margin: 0 auto;
	}
}
.siteHeader .ttl a {
	transition: opacity .2s ease-in-out;
}
.siteHeader .ttl a:hover {
	text-decoration: none;
	opacity: .7;
}
@media print, screen and (min-width: 641px) {
	.siteHeader .ttl a img {
		height: 34px;
	}
}
@media only screen and (max-width: 640px) {
	.siteHeader .ttl a {
		display: inline-block;
	}
	.siteHeader .ttl a img {
		width: 247px;
		height: 49px;
	}
}
.siteHeader .logo {
	position: absolute;
	top: 26px;
	left: 18px;
	font-size: 0;
}
@media only screen and (max-width: 640px) {
	.siteHeader .logo {
		top: 32px;
	}
}
.siteHeader .logo a {
	transition: opacity .2s ease-in-out;
}
.siteHeader .logo a:hover {
	text-decoration: none;
	opacity: .7;
}
.siteHeader.isActive .headerNav .spMenu a {
	border: none;
	background: #d3d3d4;
	box-shadow: inset 0 0 3px rgba(0, 0, 0, .23);
}
.siteHeader.isActive .headerNav .spMenu span {
	top: 37px;
	left: 27px;
	width: 28px;
	height: 2px;
	background: #535353;
}
.siteHeader.isActive .headerNav .spMenu span:nth-of-type(1) {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.siteHeader.isActive .headerNav .spMenu span:nth-of-type(2) {
	opacity: 0;
}
.siteHeader.isActive .headerNav .spMenu span:nth-of-type(3) {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

@media print, screen and (min-width: 641px) {
	.headerNav {
		position: absolute;
		top: 78px;
		left: 0;
		width: 100%;
		padding-bottom: 0;
		background: #e60039;
		background: linear-gradient(to bottom, #e60039 0%, #e60039 64px, #ffffff 64px, #ffffff 100%);
		box-shadow: 0 0 0 rgba(0, 0, 0, 0);
		text-align: center;
		font-size: 1.4rem;
		transition: box-shadow .8s ease;
	}
	.headerNav .spMenu,
	.headerNav .spTit {
		display: none;
	}
	.headerNav ol {
		display: flex;
		overflow: hidden;
		width: 1120px;
		width: 1036px;
		margin: 0 auto;
		padding: 0 0 5px;

		justify-content: space-between;
	}
	.headerNav ol:after {
		display: block;
		clear: both;
		overflow: hidden;
		content: '';
	}
	.headerNav ol > li {
		position: relative;
		overflow: hidden;
		width: 24.5%;
		line-height: 2.2;
	}
	.headerNav ol > li:last-child {
		width: 26.5%;
	}
	.headerNav ol > li:first-child:before,
	.headerNav ol > li:after {
		position: absolute;
		top: 64px;
		right: 0;
		display: block;
		width: 1px;
		height: calc(100% - 64px);
		border-top: 25px solid #ffffff;
		border-bottom: 32px solid #ffffff;
		background-color: rgba(83, 85, 93, .5);
		content: '';
	}
	.headerNav ol > li:first-child:before {
		right: auto;
		left: 0;
	}
	.headerNav ol > li p {
		position: relative;
		z-index: 0;
		display: block;
		padding: 2px 0 0;
		color: #ffffff;
		font-weight: bold;
		font-size: 1.6rem;
		font-family: 'Karla', sans-serif;
		transition: color 2s ease;
	}
	.headerNav ol > li p:before {
		position: absolute;
		top: -1px;
		left: 50%;
		z-index: -1;
		display: block;
		width: 64px;
		height: 33px;
		margin-left: -32px;
		background: url(/shared/img/bg_header_01.png) center 0 no-repeat;
		background: url(/shared/img/bg_header_01.svg) center 0 no-repeat;
		background-size: 64px 33px;
		content: '';
		transition: all .5s ease-in-out;
		-webkit-transform: scale(0);
		transform: scale(0);
		-webkit-transform-origin: 50% 0;
		transform-origin: 50% 0;
	}
	.headerNav ol > li p strong {
		position: relative;
		display: block;
		margin-top: -8px;
		color: rgba(255, 255, 255, .5);
		font-size: 1.4rem;
		font-family: 'Karla', 'Noto Sans JP', sans-serif;
	}
	.headerNav ol > li a {
		color: rgba(83, 85, 93, .5);
		letter-spacing: -.05em;
		transition: all .5s ease-in-out;
	}
	.headerNav ol > li:hover {
		top: -6px;
		transition: all .5s ease-in-out;
	}
	.headerNav ol > li.current,
	.headerNav ol > li:hover {
		top: 0;
	}
	.headerNav ol > li.current p:before,
	.headerNav ol > li:hover p:before {
		-webkit-transform: scale(1);
		transform: scale(1);
	}
	.headerNav ol > li.current p,
	.headerNav ol > li:hover.isMoveEnd p {
		color: #e60039;
	}
	.headerNav ol > li.current p strong,
	.headerNav ol > li:hover.isMoveEnd p strong {
		color: #ffffff;
	}
	.headerNav ol > li.current a,
	.headerNav ol > li:hover.isMoveEnd a {
		color: #53555d;
	}
	.headerNav:hover {
		box-shadow: 0 20px 20px rgba(0, 0, 0, .16);
	}
	.headerNav:hover .headerNavChild {
		max-height: 1000px;
		transition: all .8s ease-out;
	}
}

@media only screen and (max-width: 640px) {
	.headerNav {
		margin-top: 20px;
	}
	.headerNav ol {
		position: absolute;
		top: 92px;
		left: 0;
		z-index: 50;
		overflow: hidden;
		width: 100%;
		max-height: 0;
		background: #fdf5f4;
		color: #ffffff;
		transition: all .5s ease-in-out;
	}
	.headerNav ol p {
		padding: 2.66667vw 0;
		background: #e60039;
		text-align: center;
		font-weight: bold;
		font-size: 0;
	}
	.headerNav ol p strong {
		font-size: 2.1rem;
	}
	.headerNav ol ul {
		display: flex;
		flex-direction: column;
		margin: -.8rem 0 0 -1.7rem;
		padding: 2.5rem;
	}
	.headerNav ol ul:after {
		display: block;
		clear: both;
		overflow: hidden;
		content: '';
	}
	.headerNav ol ul li {
		margin: .9rem 0 0 1.8rem;
		font-size: 2.4rem;
	}
	.headerNav ol ul li a {
		display: block;
		padding: 1rem;
	}
	.isActive .headerNav ol {
		max-height: 2000px;
	}
	.headerNav .spMenu {
		position: absolute;
		top: 52px;
		right: 25px;
		z-index: 100;
		transition: all .3s ease-in-out;
	}
	.headerNav .spMenu a {
		display: block;
		width: 81px;
		height: 81px;
		border-radius: 50%;
		background: #e60039;
		transition: all .3s ease-in-out;
	}
	.headerNav .spMenu span {
		position: absolute;
		top: 32px;
		left: 30px;
		display: block;
		width: 22px;
		height: 3px;
		background: #ffffff;
		transition: all .3s ease-in-out;
	}
	.headerNav .spMenu span:nth-of-type(2) {
		top: 39px;
	}
	.headerNav .spMenu span:nth-of-type(3) {
		top: 46px;
	}
	.headerNav .spTit {
		position: relative;
		z-index: 0;
		padding: 10px 0 16px;
		background-color: #e60039;
		color: #e60039;
		text-align: center;
		font-weight: bold;
		font-size: 3.2rem;
	}
	.pageHome .headerNav .spTit {
		display: none;
	}
}
@media only screen and (max-width: 640px) and (max-device-width: 480px) {
	.headerNav .spTit {
		padding-top: 10px;
	}
}

@media only screen and (max-width: 640px) {
	.pageHome .headerNav .spTit {
		display: none;
	}
	.headerNav .spTit span {
		position: absolute;
		top: -2px;
		left: 50%;
		z-index: -1;
		display: block;
		width: 160px;
		height: 80px;
		margin-left: -80px;
		background: url(/shared/img/bg_header_01.png) center 0 no-repeat;
		background: url(/shared/img/bg_header_01.svg) center 0 no-repeat;
		background-size: 120px auto;
		content: '';
	}
	.headerNav .spTit strong {
		display: block;
		color: #ffffff;
		font-size: 2.4rem;
	}
	.headerNav .spTit.isMove:before {
		-webkit-transform: scale(1);
		transform: scale(1);
	}
	.headerNav .spTit.isMoveEnd strong {
		color: #ffffff;
	}
}

@media print, screen and (min-width: 641px) {
	.headerNav .headerNavChild {
		overflow: hidden;
		max-height: 0;
		line-height: 1.4;
		transition: all .2s ease-out;
	}
	.headerNav .headerNavChild ul {
		padding: 17px 0 61px;
	}
	.headerNav .headerNavChild ul li {
		margin-top: 11px;
	}
}

/* Global Footer */
/* ------------------------------ */
.siteFooter {
	position: relative;
	background-color: #ffffff;
	box-shadow: 0 0 40px rgba(0, 0, 0, .08);
	color: #53555d;
}
@media only screen and (max-width: 640px) {
	.siteFooter {
		box-shadow: 0 0 3.5rem rgba(0, 0, 0, .16);
	}
}
.siteFooter .inner {
	padding: 10.3rem 0 3.5rem;
}
@media print, screen and (min-width: 641px) {
	.siteFooter .inner {
		width: 1120px;
		margin: 0 auto;
		padding: 60px 0;
	}
}
.siteFooter h1 {
	position: relative;
	z-index: 1;
	margin-bottom: 40px;
	text-align: center;
	font-size: 2.4rem;
	font-family: 'Karla', sans-serif;
}
@media only screen and (max-width: 640px) {
	.siteFooter h1 {
		display: none;
	}
}
.siteFooter .footerSocial {
	display: flex;
	margin-top: 80px;
	text-align: center;
	letter-spacing: -.40em;

	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 640px) {
	.siteFooter .footerSocial {
		margin-top: 0;
	}
}
.siteFooter .footerSocial li {
	display: block;
	margin: 0 32px;
}
@media print, screen and (min-width: 641px) {
	.siteFooter .footerSocial li {
		margin: 0 12px;
	}
}
.siteFooter .footerSocial li a {
	transition: opacity .2s ease-in-out;
}
.siteFooter .footerSocial li a:hover {
	text-decoration: none;
	opacity: .7;
}
@media print, screen and (min-width: 641px) {
	.siteFooter .footerSocial li a img {
		width: 24px;
		height: 24px;
	}
}
@media only screen and (max-width: 640px) {
	.siteFooter .footerSocial li a img {
		width: 4.1rem;
		height: 4.1rem;
	}
}
.siteFooter .copyright {
	margin-top: 10.3rem;
	text-align: center;
	font-weight: 300;
	font-size: 2.1rem;
	font-family: 'Karla', sans-serif;
}
@media print, screen and (min-width: 641px) {
	.siteFooter .copyright {
		margin-top: 20px;
		font-size: 1.2rem;
	}
}
@media only screen and (max-width: 640px) {
	.siteFooter .copyright {
		line-height: 1.2;
	}
}
.siteFooter .pagetop {
	position: fixed;
	right: 2.9rem;
	bottom: 2.9rem;
	z-index: 100;
	transition: -webkit-transform .3s ease;
	transition: transform .3s ease;
	transition: transform .3s ease, -webkit-transform .3s ease;
	-webkit-transform: translate3d(0, 15rem, 0);
	transform: translate3d(0, 15rem, 0);
}
.is-pagetop-active .siteFooter .pagetop {
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 640px) {
	.siteFooter .pagetop {
		transition: bottom .2s ease;
	}
}
@media print, screen and (min-width: 641px) {
	.siteFooter .pagetop {
		right: 60px;
		bottom: 60px;
	}
}
.siteFooter .pagetop a {
	display: block;
	overflow: hidden;
	width: 8.2rem;
	height: 8.2rem;
	background: #dddddd url(/shared/img/ico_arrow_up.svg) no-repeat 50% 50%;
	background-size: 2.4rem auto;
	text-indent: 200%;
	white-space: nowrap;
	transition: opacity .2s ease-in-out;
}
.siteFooter .pagetop a:hover {
	text-decoration: none;
	opacity: .7;
}
@media print, screen and (min-width: 641px) {
	.siteFooter .pagetop a {
		width: 48px;
		height: 48px;
		background-size: 14px auto;
	}
}

.footerNav {
	display: flex;
	width: 100%;
	border-left: 1px solid #c3c4c6;
	text-align: center;
	letter-spacing: -.40em;
	font-size: 1.4rem;
	justify-content: space-between;
}
@media only screen and (max-width: 640px) {
	.footerNav {
		display: none;
	}
}
.footerNav > li {
	display: block;
	width: 24.5%;
	padding: 1px 0 40px;
	border-right: 1px solid #c3c4c6;
}
.footerNav > li:last-child {
	width: 26.5%;
}
.footerNav > li a {
	color: #333641;
}
.footerNav > li p {
	display: block;
	margin-top: 20px;
	letter-spacing: normal;
	font-weight: bold;
}
.footerNav ul {
	display: inline-block;
	margin-top: 11px;
	vertical-align: top;
	letter-spacing: normal;
	line-height: 1.4;
}
.footerNav ul li {
	margin-top: 9px;
}

/* Layout Base */
/* ------------------------------ */
.fixed {
	overflow: hidden;
	height: 1260px;
}

.container {
	position: relative;
}

main {
	position: relative;
	display: block;
	padding-bottom: 17.1rem;
	line-height: 1.8;
}
@media print, screen and (min-width: 641px) {
	main {
		width: 100%;
		padding-bottom: 100px;
	}
}
@media print, screen and (min-width: 641px) {
	.pageHome main {
		padding: 65px 0 0;
	}
}

.mainInner {
	padding: 28px;
	background: #ffffff;
	box-shadow: 0 1.8rem 5.2rem rgba(0, 0, 0, .08);
}
.mainInner.isNobg {
	padding: 0 28px;
	background: none;
	box-shadow: none;
}
@media print, screen and (min-width: 641px) {
	.mainInner {
		width: 1120px;
		margin: 0 auto;
		padding: 40px;
		border-radius: 3px;
		box-shadow: 0 20px 20px rgba(0, 0, 0, .08);
	}
	.mainInner.isNobg {
		padding: 0;
	}
}

.headerLang {
	position: absolute;
	top: 27px;
	right: 20px;
}
@media only screen and (max-width: 640px) {
	.headerLang {
		top: 5px;
	}
}
.headerLang li {
	display: inline-block;
	margin-left: 5px;
}
.headerLang li a {
	display: inline-block;
	padding: 4px 0;
	border: 1px solid #dddddd;
	border-radius: 2px;
	background: #ffffff;
	text-align: center;
	text-decoration: none;
}
@media only screen and (max-width: 640px) {
	.headerLang li a {
		width: 80px;
		font-size: 1.6rem;
	}
}
@media print, screen and (min-width: 641px) {
	.headerLang li a {
		width: 60px;
		font-size: 1rem;
	}
	.headerLang li a:hover {
		opacity: .7;
	}
}

.headerLang li.en a {
	color: #e60039;
}

.headerLang li.jp a {
	color: #e60039;
}

.htmlEn .headerLang li.en a {
	color: #e60039;
}

.htmlEn .headerLang li.jp a {
	color: #e60039;
}

.blockFeaturelLead {
	position: relative;
	width: 1120px;
	margin: 0 auto 75px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead {
		width: 100%;
	}
}
.blockFeaturelLead .unitHeader {
	margin: 0 10px;
}
.blockFeaturelLead .unitBody {
	position: relative;
	padding: 40px;
	background: #ffffff;
}
.blockFeaturelLead .unitBody .featureNav {
	margin: 38px 0 -1px;
	padding-bottom: 30px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .unitBody .featureNav {
		display: none;
	}
}
.blockFeaturelLead .featureNav {
	position: relative;
	margin: 0 10px;
	padding: 0 30px;
	background: #53555d;
	color: #ffffff;
	font-size: 1.4rem;
	line-height: 1.2;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav {
		margin: 0 20px;
	}
}
.blockFeaturelLead .featureNav p {
	padding: 18px 0 15px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav p {
		text-align: center;
		font-size: 2.6rem;
	}
}
.blockFeaturelLead .featureNav hr {
	position: absolute;
	top: 48px;
	right: 0;
	left: 0;
	width: calc(100% - 60px);
	height: 1px;
	margin: 0 auto -1px;
	padding: 0;
	border: 0;
	background: #87888e;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav hr {
		display: none;
	}
}
.blockFeaturelLead .featureNav .btn {
	position: absolute;
	top: 12px;
	right: 16px;
	display: block;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background: #c9c9c9;
	box-shadow: 0 0 2px rgba(0, 0, 0, .23);
	transition: all .5s ease;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .btn {
		top: 3px;
		width: 56px;
		height: 56px;
	}
}
.blockFeaturelLead .featureNav .btn.isActive {
	border: 1px solid #c9c9c9;
	background: #53555d;
}
.blockFeaturelLead .featureNav .btn.isActive + .navWrap.isHidden {
	overflow: visible;
	padding-top: 15px;
	padding-bottom: 30px;
	max-height: 9999px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .btn.isActive + .navWrap.isHidden {
		max-height: 9999px;
	}
}
.blockFeaturelLead .featureNav .btn.isActive span {
	top: 12px;
	left: 5px;
	width: 15px;
	height: 2px;
	background: #ffffff;
}
.blockFeaturelLead .featureNav .btn.isActive span:nth-of-type(1) {
	top: 11px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.blockFeaturelLead .featureNav .btn.isActive span:nth-of-type(2) {
	opacity: 0;
}
.blockFeaturelLead .featureNav .btn.isActive span:nth-of-type(3) {
	top: 8px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .btn.isActive span {
		top: 20px;
		left: 15px;
		width: 24px;
		height: 4px;
	}
	.blockFeaturelLead .featureNav .btn.isActive span:nth-of-type(1) {
		top: 24px;
	}
	.blockFeaturelLead .featureNav .btn.isActive span:nth-of-type(3) {
		top: 17px;
	}
}
.blockFeaturelLead .featureNav .btn span {
	position: relative;
	top: 10px;
	left: 7px;
	display: block;
	width: 12px;
	height: 1px;
	background: #565b6d;
}
.blockFeaturelLead .featureNav .btn span:nth-of-type(2) {
	top: 12px;
}
.blockFeaturelLead .featureNav .btn span:nth-of-type(3) {
	top: 14px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .btn span {
		top: 21px;
		left: 19px;
		width: 17px;
		height: 2px;
	}
	.blockFeaturelLead .featureNav .btn span:nth-of-type(2) {
		top: 25px;
	}
	.blockFeaturelLead .featureNav .btn span:nth-of-type(3) {
		top: 29px;
	}
}
.blockFeaturelLead .featureNav .navWrap {
	position: relative;
	top: 1px;
	display: block;
	width: 100%;
	padding-top: 15px;
	max-height: 9999px;
	transition: max-height .5s ease-in-out;
}
.blockFeaturelLead .featureNav .navWrap .navWrapInner {
	-webkit-column-count: 2;
	-moz-column-count: 2;
	column-count: 2;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .navWrap .navWrapInner {
		-webkit-column-count: 1;
		-moz-column-count: 1;
		column-count: 1;
	}
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .navWrap {
		display: block;
		-webkit-column-count: 1;
		-moz-column-count: 1;
		column-count: 1;
	}
	.blockFeaturelLead .featureNav .navWrap dl {
		width: 100%;
		margin: 0;
	}
}
.blockFeaturelLead .featureNav .navWrap:before {
	position: absolute;
	top: 0;
	left: 50%;
	display: block;
	width: 1px;
	height: 100%;
	background: #87888e;
	content: '';
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .navWrap:before {
		display: none;
	}
}
.blockFeaturelLead .featureNav .navWrap:after {
	display: none;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .navWrap:after {
		display: none;
	}
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav .navWrap {
		max-height: 9999px;
	}
}
.blockFeaturelLead .featureNav .navWrap.isHidden {
	overflow: hidden;
	padding-top: 0;
	padding-bottom: 0;
	max-height: 0;
	transition: max-height .5s ease-in-out;
}
.blockFeaturelLead .featureNav dl {
	position: relative;
	width: 100%;
	margin: 0 0 10px;
	padding: 15px 0 5px 10px;
}
.blockFeaturelLead .featureNav dl:first-child {
	padding-top: 0;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav dl {
		border: 0;
		font-size: 2.2rem;
		-webkit-column-count: 1;
		-moz-column-count: 1;
		column-count: 1;
	}
	.blockFeaturelLead .featureNav dl:last-child {
		padding-bottom: 30px;
	}
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav dt {
		margin-top: 10px;
	}
}
.blockFeaturelLead .featureNav dd {
	margin-top: 10px;
	margin-left: 15px;
}
@media only screen and (max-width: 640px) {
	.blockFeaturelLead .featureNav dd {
		margin-top: 20px;
	}
}
.blockFeaturelLead .featureNav dd a {
	color: #ffffff;
	text-decoration: none;
}
.blockFeaturelLead .featureNav dd a:hover {
	text-decoration: underline;
	opacity: .7;
}

/* [Module] */
/* ------------------------------ */
/* ------------------------------ */
/* Module */
/* ------------------------------ */
@media only screen and (max-width: 640px) {
	br.mbnone {
		display: none;
	}
}

@media print, screen and (min-width: 641px) {
	br.pcnone {
		display: none;
	}
}

.mainInner i {
	font-style: italic;
}

@media only screen and (max-width: 640px) {
	.pchiddenMbnone {
		display: none;
	}
}

@media print, screen and (min-width: 641px) {
	.pchiddenMbnone {
		visibility: hidden;
	}
}

/* Heading */
/* ------------------------------ */
.modHeading0 {
	margin-bottom: 15px;
	padding-bottom: 10px;
	border-bottom: 3px solid #000000;
	text-align: left;
	font-weight: 600;
	font-size: 3rem;
}

.modHeading1 {
	margin-bottom: 14px;
	text-align: center;
	font-weight: bold;
	font-size: 5.2rem;
	line-height: 1.3;
}
.modHeading1:only-child {
	margin-bottom: 0;
}
@media print, screen and (min-width: 641px) {
	.modHeading1 {
		margin-bottom: 28px;
		font-size: 3.2rem;
	}
	.modHeading1:only-child {
		margin-bottom: 0;
	}
}

.mainInner.isNobg .modHeading1 {
	color: #333641;
}

.modHeading2,
.pageBacteriaDetail section h2 {
	margin-bottom: 15px;
	padding-bottom: 5px;
	border-bottom: 1px solid #707070;
	font-weight: 600;
	font-size: 3.2rem;
}
@media print, screen and (min-width: 641px) {
	.modHeading2,
	.pageBacteriaDetail section h2 {
		font-size: 2.4rem;
	}
}

.modHeading3 {
	overflow: hidden;
	margin-bottom: 23px;
	font-weight: bold;
}
@media print, screen and (min-width: 641px) {
	.modHeading3 {
		font-size: 2.4rem;
	}
}
.modHeading3.line {
	display: table;
	width: 100%;
	white-space: nowrap;
}
.modHeading3.line:after {
	position: relative;
	top: 0;
	right: -18px;
	display: table-cell;
	width: 100%;
	border-top: 1px solid #707070;
	content: '';
	-webkit-transform: translateY(40%);
	transform: translateY(40%);
}

.modHeading4 {
	margin: 42px 0 15px;
	text-align: center;
}
@media print, screen and (min-width: 641px) {
	.modHeading4 {
		margin: 0 0 8px;
	}
}
.modHeading4 dt {
	display: inline-block;
	margin-bottom: 15px;
	border-bottom: 1px solid #fdf5f4;
	font-weight: bold;
	font-size: 3.2rem;
	line-height: 1.2;
}
@media print, screen and (min-width: 641px) {
	.modHeading4 dt {
		margin-bottom: 7px;
		font-size: 2.1rem;
	}
}
.modHeading4 dd {
	text-align: center;
	font-size: 2.2rem;
	line-height: 1.58;
}
@media print, screen and (min-width: 641px) {
	.modHeading4 dd {
		font-size: 1.2rem;
	}
}

.modHeading5 {
	margin-bottom: 9px;
	font-weight: bold;
	font-size: 2.8rem;
	line-height: 1.31;
}
@media print, screen and (min-width: 641px) {
	.modHeading5 {
		font-size: 2.2rem;
	}
}

.modHeadingMission1 {
	padding-top: 11px;
	font-size: 2.1rem;
}
@media print, screen and (min-width: 641px) {
	.modHeadingMission1 {
		font-size: 1.2rem;
	}
}
.modHeadingMission1:after {
	display: block;
	width: 40px;
	height: 4px;
	margin: 33px auto 0;
	background: #ffffff;
	content: '';
}
@media print, screen and (min-width: 641px) {
	.modHeadingMission1:after {
		width: 30px;
		height: 2px;
	}
}
.modHeadingMission1 strong {
	display: block;
	margin-top: 5px;
	font-size: 0;
}
@media only screen and (max-width: 640px) {
	.modHeadingMission1 strong {
		padding-bottom: 14px;
		background: url(/shared/img/ttl_mission_01_sp.png) no-repeat center top;
		background-size: auto 14px;
	}
}
@media only screen and (max-width: 640px) {
	.modHeadingMission1 strong img {
		display: none;
	}
}

.modHeadingMission2 {
	margin-top: 33px;
	text-shadow: 0 0 5px rgba(0, 0, 0, .75);
	font-size: 4.0rem;
	line-height: 1.35;
}
@media print, screen and (min-width: 641px) {
	.modHeadingMission2 {
		font-size: 4.8rem;
	}
}

.modHeadingTop {
	padding: 33px 0;
	text-align: center;
	font-weight: bold;
	font-size: 0;
}
@media print, screen and (min-width: 641px) {
	.modHeadingTop {
		padding: 31px 0 28px;
	}
}

/* pageHeader */
/* ------------------------------ */
.modPageHeader {
	padding: 60px 28px 50px;
	text-align: center;
}
@media only screen and (max-width: 640px) {
	.modPageHeader {
		transition: padding .1s ease-in;
	}
	.modPageHeader.isShort {
		padding-top: 25px;
		padding-bottom: 18px;
	}
	.modPageHeader.isShort .modHeading1 {
		-webkit-transform: rotateX(360deg);
		transform: rotateX(360deg);
	}
	.modPageHeader.isShort .modLead {
		display: none;
	}
}
@media only screen and (max-width: 640px) {
	.modPageHeader .modHeading1 {
		transition: -webkit-transform .5s ease-in-out;
		transition: transform .5s ease-in-out;
		transition: transform .5s ease-in-out, -webkit-transform .5s ease-in-out;
	}
}
.modPageHeader .modLead {
	font-size: 2.8rem;
}
@media print, screen and (min-width: 641px) {
	.modPageHeader .modLead {
		margin-top: 24px;
		font-size: 1.4rem;
		line-height: 1.85;
	}
}
.modPageHeader .modLead p {
	position: relative;
	margin-top: 24px;
}
.modPageHeader .modLead p strong {
	font-size: 125%;
}

.mainInner + .mainInner .modPageHeader {
	padding: 48px 28px 46px;
}

/* text */
/* ------------------------------ */
.modP {
	margin-top: .75em;
}

.modList,
.pageBacteriaDetail section ul {
	margin: .75em 0;
}
.modList li,
.pageBacteriaDetail section ul li {
	position: relative;
	margin: 0 0 8px;
	padding-left: 20px;
	line-height: 1.3;
}
.modList li:before,
.pageBacteriaDetail section ul li:before {
	position: absolute;
	top: 2px;
	left: 0;
	content: '・';
	font-weight: bold;
}
.modList li:last-child,
.pageBacteriaDetail section ul li:last-child {
	margin-bottom: 0;
}

.modTxt .modHeading4,
.modTxt p,
.modTxt ul {
	margin-top: 31px;
}

.modTxt .modHeading4 + p,
.modTxt .modHeading4 + ul {
	margin-top: 0;
}

.modTxt .box {
	margin-top: 19px;
	padding: 10px 17px;
	border-radius: 3px;
	background-color: #fdf5f4;
	color: #ffffff;
}
.modTxt .box dt {
	font-weight: bold;
}

.modTxt em,
.modTxt i {
	font-style: italic;
}

.modTxt .summary dt {
	margin-bottom: 0;
}
@media print, screen and (min-width: 641px) {
	.modTxt .summary dt {
		float: left;
		width: 8em;
		margin-bottom: .5em;
	}
}

.modTxt .summary dd {
	margin: 0 0 .5em 0;
}
.modTxt .summary dd:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
.modTxt .summary dd.note {
	position: relative;
	top: -1em;
	margin-bottom: -1em;
	font-size: 1.3rem;
}

[class*='modHeading'] + .modTxt .modHeading4:first-child,
[class*='modHeading'] + .modTxt p:first-child,
[class*='modHeading'] + .modTxt ul:first-child {
	margin-top: 0;
}

/* notes */
.modNotes {
	margin-bottom: 60px;
	padding: 14px 18px;
	border: 1px solid #e5e5e5;
	background-color: #efefef;
	font-size: 2rem;
	line-height: 1.9;
}
@media print, screen and (min-width: 641px) {
	.modNotes {
		margin-top: 40px;
		font-size: 1.2rem;
	}
}
.modNotes dt {
	font-weight: bold;
}
@media print, screen and (min-width: 641px) {
	.modNotes dt {
		display: inline-block;
		padding-right: 1em;
	}
}
.modNotes dd {
	display: inline;
}
.modNotes.bgWhite {
	padding: 0;
	border: none;
	background-color: #ffffff;
}
.modNotes.dispBlock dt,
.modNotes.dispBlock dd {
	display: block;
}

/* breadcrumbs */
/* ------------------------------ */
@media only screen and (max-width: 640px) {
	.modBreadcrumbs {
		display: none;
	}
}

.modBreadcrumbs .inner {
	border-bottom: 1px solid #5c5e67;
}
@media print, screen and (min-width: 641px) {
	.modBreadcrumbs .inner {
		width: 1120px;
		margin: 0 auto;
		padding: 26px 6px 7px;
		font-size: 1.3rem;
	}
}

.modBreadcrumbs ul:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}

.modBreadcrumbs ul li {
	float: left;
}
.modBreadcrumbs ul li + li:before {
	display: inline-block;
	margin: 0 .6em 0 .4em;
	content: '\003e';
}
.modBreadcrumbs ul li a {
	text-decoration: none;
}
.modBreadcrumbs ul li a:hover,
.modBreadcrumbs ul li a:active {
	text-decoration: underline;
}
.modBreadcrumbs ul li em {
	font-weight: bold;
}

/* section */
/* ------------------------------ */
.modSection,
.pageBacteriaDetail section {
	margin-bottom: 80px;
}
@media print, screen and (min-width: 641px) {
	.modSection,
	.pageBacteriaDetail section {
		margin-bottom: 48px;
		line-height: 1.81;
	}
}
.modSection.modHomeSection,
.pageBacteriaDetail section.modHomeSection {
	margin-bottom: 34px;
}
@media print, screen and (min-width: 641px) {
	.modSection.modHomeSection,
	.pageBacteriaDetail section.modHomeSection {
		margin-bottom: 52px;
	}
}
.modSection a,
.pageBacteriaDetail section a {
	color: #283cc8;
	text-decoration: none;
	transition: all .3s ease;
}
.modSection a:hover,
.pageBacteriaDetail section a:hover {
	text-decoration: underline;
	opacity: .7;
}
.modSection a > em,
.pageBacteriaDetail section a > em {
	color: #e60039;
	text-decoration: underline;
}
.modSection.column,
.pageBacteriaDetail section.column {
	background: #e5e5e5;
}
@media print, screen and (min-width: 641px) {
	.modSection.column,
	.pageBacteriaDetail section.column {
		padding: 40px;
	}
	.modSection.column .modGrid2 .grid,
	.pageBacteriaDetail section.column .modGrid2 .grid {
		width: 465px;
	}
}
@media only screen and (max-width: 640px) {
	.modSection.column,
	.pageBacteriaDetail section.column {
		padding: 40px 20px;
	}
}

.mainInner.isNobg .modSection:last-child,
.mainInner.isNobg .pageBacteriaDetail section:last-child,
.pageBacteriaDetail .mainInner.isNobg section:last-child {
	margin-bottom: 0;
}

/* pager */
/* ------------------------------ */
.modPager {
	overflow: hidden;
	margin: 20px 0 0;
}
.modPager .fa {
	color: #666666;
}
.modPager p {
	position: relative;
}
@media print, screen and (min-width: 641px) {
	.modPager p {
		width: 50%;
	}
}
@media only screen and (max-width: 640px) {
	.modPager p {
		font-size: 2.2rem;
	}
}
.modPager p.prev {
	padding-left: 25px;
}
@media print, screen and (min-width: 641px) {
	.modPager p.prev {
		float: left;
	}
}
.modPager p.prev:before {
	position: absolute;
	top: 2px;
	left: 0;
	color: #888888;
	content: '\f053';
	font-family: 'FontAwesome';
}
.modPager p.next {
	padding-right: 25px;
}
@media print, screen and (min-width: 641px) {
	.modPager p.next {
		float: right;
		text-align: right;
	}
}
@media only screen and (max-width: 640px) {
	.modPager p.next {
		margin-bottom: 10px;
	}
}
.modPager p.next:after {
	position: absolute;
	top: 2px;
	right: 0;
	color: #888888;
	content: '\f054';
	font-family: 'FontAwesome';
}
.modPager a {
	color: #e60039;
}

/* KeyVisual */
/* ------------------------------ */
.modKeyVisual img {
	width: 100%;
	height: auto;
}

/* modSocial */
/* ------------------------------ */
.modSocial {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.modSocial {
		display: none;
	}
}
.modSocial:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
.modSocial .modSectionLink {
	position: relative;
	top: 8px;
	float: right;
	padding-right: 1px;
	line-height: 1;
}
.modSocial .modSectionLink li {
	display: inline-block;
	overflow: hidden;
	height: 20px;
	margin-left: 10px;
	vertical-align: middle;
	line-height: 1;
}
.modSocial .modSectionLink li span,
.modSocial .modSectionLink li iframe {
	vertical-align: top !important;
}
.pageDictionaryIndex .modSocial {
	top: -10px;
}
@media print, screen and (min-width: 641px) {
	.pageDictionaryDetail .modSocial {
		top: -60px;
	}
}
@media print, screen and (min-width: 641px) {
	.modSocial + .modTxt *:first-child {
		margin-top: 0;
	}
}

/* grid */
/* ------------------------------ */
[class*='modGrid']:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}

[class*='modGrid'] .grid img {
	height: auto;
	max-width: 100%;
}

@media print, screen and (min-width: 641px) {
	[class*='modGrid'] .grid {
		float: left;
	}
}

@media print, screen and (min-width: 641px) {
	.modGrid2 {
		position: relative;
		margin-right: -15px;
		margin-left: -15px;
	}
	.modGrid2 .grid {
		width: 505px;
		margin: 0 15px;
	}
}

.modGrid2 .grid .modTxt:first-child *:first-child {
	margin-top: 0;
}

.modGrid3 {
	position: relative;
}
@media print, screen and (min-width: 641px) {
	.modGrid3 {
		position: relative;
		margin-right: -15px;
		margin-left: -15px;
	}
	.modGrid3 .grid {
		width: 353px;
		margin-right: 15px;
		margin-left: 15px;
	}
}

@media print, screen and (min-width: 641px) {
	.mainInner .modPhotoPos.even > .grid:nth-child(odd) {
		float: right;
	}
}

.modGrid4 .grid {
	float: left;
	width: 287px;
}
.modGrid4 .grid.grid2 {
	width: 100%;
}
@media print, screen and (min-width: 641px) {
	.modGrid4 .grid.grid2 {
		width: 505px;
		margin-right: 30px;
	}
}
.modGrid4 .grid.grid2 ~ .grid {
	margin-right: 10px;
}
@media print, screen and (min-width: 641px) {
	.modGrid4 .grid.grid2 ~ .grid {
		margin-right: 29px;
	}
}
@media print, screen and (min-width: 641px) {
	.modGrid4 .grid.grid2 ~ .grid .modFigure {
		margin-top: 0;
	}
}
.modGrid4 .grid.grid2 ~ .grid:last-child {
	margin-right: 0;
}
@media print, screen and (min-width: 641px) {
	.modGrid4 .grid.grid2 ~ .grid:last-child {
		margin-right: 0;
	}
}
@media only screen and (max-width: 640px) {
	.modGrid4 .grid {
		margin-right: 10px;
	}
	.modGrid4 .grid:nth-child(2n) {
		margin-right: 0;
	}
}
@media print, screen and (min-width: 641px) {
	.modGrid4 .grid {
		width: 238px;
		margin-right: 29px;
	}
	.modGrid4 .grid:nth-child(4n) {
		margin-right: 0;
		margin-left: 1px;
	}
	.modGrid4 .grid.grid2 .modFigure figcaption {
		margin-right: -267px;
	}
}

.modFigure {
	margin: 20px 0 0;
}
.modFigure img {
	width: 100%;
	height: auto;
}
@media print, screen and (min-width: 641px) {
	.modFigure img {
		width: auto;
	}
}
@media print, screen and (min-width: 641px) {
	.modFigure {
		margin-top: 15px;
	}
}
.modFigure figcaption {
	margin: 10px 0 0;
	font-size: 2.0rem;
	line-height: 1.6;
}
.modFigure figcaption em {
	font-style: italic;
}
@media print, screen and (min-width: 641px) {
	.modFigure figcaption {
		margin-top: 7px;
		font-size: 1.2rem;
	}
}
@media print, screen and (min-width: 641px) {
	.modGrid2.modPhotoPos > .grid:nth-child(-n+2) > .modFigure {
		margin-top: 0;
	}
}

/* chart */
/* ------------------------------ */
.modChartCaption {
	position: relative;
	width: 95%;
	margin: 0 0 0 auto;
	padding: 0 0 1.3em 0;
	text-align: right;
	font-size: 1.9rem;
	line-height: 1.3;
}
@media print, screen and (min-width: 641px) {
	.modChartCaption {
		width: 97%;
		font-size: 1.2rem;
	}
}
.modChartCaption .pv {
	position: absolute;
	top: 1.7em;
	right: 97%;
	text-align: left;
	-webkit-transform: rotate(-90deg);
	transform: rotate(-90deg);
}
.modChartCaption .ago {
	position: absolute;
	bottom: 0;
	left: 0;
	text-align: left;
}
.modChartCaption .today {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 8em;
	margin: 0 0 0 auto;
	text-align: right;
}

/* btn */
/* ------------------------------ */
[class*='modBtn'] {
	margin-top: 27px;
}
[class*='modBtn'].modBtn1 {
	position: relative;
	overflow: hidden;
}
[class*='modBtn'].modBtn1 a {
	position: relative;
	z-index: 1;
	padding: 13px 0 12px 37px;
}
[class*='modBtn'].modBtn1 a:before {
	position: absolute;
	top: 50%;
	left: 100%;
	z-index: 0;
	margin-top: -47px;
	border: 47px solid transparent;
	border-left: 30px solid #53555d;
	content: '';
}
[class*='modBtn'].modBtn2 {
	position: relative;
	z-index: 0;
	margin-top: 20px;
	text-align: right;
}
@media print, screen and (min-width: 641px) {
	[class*='modBtn'].modBtn2 {
		font-size: 1.4rem;
	}
}
[class*='modBtn'].modBtn2 a {
	position: relative;
	display: inline-block;
	padding: 10px 30px;
	border-radius: 30px;
}
@media print, screen and (min-width: 641px) {
	[class*='modBtn'].modBtn2 a {
		padding: 6px 20px 5px;
		border-radius: 20px;
	}
}
[class*='modBtn'] a {
	background-color: #53555d;
	color: #ffffff;
	text-decoration: none;
	transition: opacity .2s ease-in-out;
}
[class*='modBtn'] a:hover {
	text-decoration: none;
	opacity: .7;
}
[class*='modBtn'] a:visited {
	color: #ffffff;
}

/* recommendLink */
/* ------------------------------ */
.modRecommendLink {
	position: relative;
	overflow: hidden;
	margin-top: 20px;
	border: 1px solid #e5e5e5;
	border-radius: 3px;
	background-color: #e5e5e5;
}
.modRecommendLink:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
@media print, screen and (min-width: 641px) {
	.modRecommendLink {
		margin-top: 20px;
	}
	.modRecommendLink dd {
		font-size: 1.4rem;
	}
	.modRecommendLink:before {
		position: absolute;
		top: 50%;
		left: -1px;
		z-index: 0;
		margin-top: -200px;
		border: 200px solid transparent;
		border-left: 150px solid #53555d;
		content: '';
	}
}
@media only screen and (max-width: 640px) {
	.modRecommendLink dl {
		padding: 0 9px 9px 0;
	}
	.modRecommendLink dl:after {
		display: block;
		clear: both;
		overflow: hidden;
		content: '';
	}
}
.modRecommendLink dt {
	position: relative;
	z-index: 0;
	overflow: hidden;
	box-sizing: content-box;
	width: 6em;
	padding: 12px 23px 13px 13px;
	color: #ffffff;
}
@media only screen and (max-width: 640px) {
	.modRecommendLink dt {
		top: 9px;
		float: left;
	}
	.modRecommendLink dt:before {
		position: absolute;
		top: 50%;
		left: 0;
		z-index: -1;
		margin-top: -300px;
		border: 300px solid transparent;
		border-left: 180px solid #53555d;
		content: '';
	}
}
@media print, screen and (min-width: 641px) {
	.modRecommendLink dt {
		z-index: 1;
		display: table-cell;
		padding: 0 0 0 18px;
		vertical-align: middle;
	}
}
.modRecommendLink dd {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.modRecommendLink dd {
		margin-top: -9px;
	}
}
@media print, screen and (min-width: 641px) {
	.modRecommendLink dd {
		z-index: 1;
		display: table-cell;
		padding: 0 0 9px 40px;
	}
}
.modRecommendLink dd ul:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
.modRecommendLink dd ul li {
	float: left;
	margin: 18px 0 0 9px;
}
@media print, screen and (min-width: 641px) {
	.modRecommendLink dd ul li {
		margin: 9px 0 0 12px;
	}
}
.modRecommendLink dd a {
	display: block;
	padding: 3px 8px;
	border: 1px solid #d3d3d4;
	border-radius: 3px;
	background-color: #ffffff;
	text-decoration: none;
	font-weight: bold;
	transition: opacity .2s ease-in-out;
}
.modRecommendLink dd a:hover {
	text-decoration: none;
	opacity: .7;
}

/* localNav�亥▼蠎ｷ逕ｨ隱槭□縺代〒菴ｿ逕ｨ縺吶ｋ�� */
/* ------------------------------ */
.modLocalNav {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 100;
	border-radius: 3px 3px 0 0;
	background: #53555d;
	box-shadow: 0 0 5px rgba(0, 0, 0, .13);
	color: #ffffff;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav {
		position: relative;
		top: auto;
		right: auto;
		left: auto;
		z-index: 0;
		width: 1100px;
		width: 1120px;
		margin: 0 auto;
		margin: 0 auto;
		padding: 14px 20px 0;
		line-height: 1.86;
	}
	.modLocalNav:before {
		position: absolute;
		top: 30px;
		left: 555px;
		width: 0;
		height: calc(100% - 63px);
		border-left: 1px solid rgba(255, 255, 255, .3);
		content: '';
	}
}
.modLocalNav p.btn {
	position: absolute;
	top: 5px;
	right: 38px;
	z-index: 2;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav p.btn {
		top: 12px;
		right: 16px;
	}
}
.modLocalNav p.btn a {
	display: block;
	width: 54px;
	height: 54px;
	border: 1px solid #c9c9c9;
	border-radius: 50%;
	background: #c9c9c9;
	box-shadow: 3px 0 3px rgba(0, 0, 0, .4);
	transition: all .3s ease-in-out;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav p.btn a {
		width: 26px;
		height: 26px;
		box-shadow: 0 0 2px rgba(0, 0, 0, .23);
	}
}
.modLocalNav p.btn span {
	position: absolute;
	top: 21px;
	left: 18px;
	display: block;
	width: 18px;
	height: 2px;
	background: #565b6d;
	transition: all .3s ease-in-out;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav p.btn span {
		top: 10px;
		left: 7px;
		width: 12px;
		height: 1px;
	}
}
.modLocalNav p.btn span:nth-of-type(2) {
	top: 26px;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav p.btn span:nth-of-type(2) {
		top: 13px;
	}
}
.modLocalNav p.btn span:nth-of-type(3) {
	top: 31px;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav p.btn span:nth-of-type(3) {
		top: 16px;
	}
}
.modLocalNav .modLocalNavHeading {
	padding: 60px 0 14px;
	text-align: center;
	font-size: 2.8rem;
	line-height: 1.3;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav .modLocalNavHeading {
		position: relative;
		z-index: 1;
		margin: -14px -20px 0;
		padding: 14px 20px 13px;
		background: #53555d;
		text-align: left;
		font-size: 1.5rem;
		cursor: pointer;
	}
	.modLocalNav .modLocalNavHeading em {
		display: inline-block;
		width: 0;
		padding-left: 0;
		min-width: 8.8em;
		transition: all .3s ease-in-out;
	}
	.modLocalNav .modLocalNavHeading span {
		display: inline-block;
		overflow: hidden;
		width: 1.5em;
		vertical-align: middle;
		text-align: center;
	}
}
.modLocalNav > .inner {
	transition: all .3s ease-in-out;
}
@media only screen and (max-width: 640px) {
	.modLocalNav > .inner {
		overflow: hidden;
		padding: 0 28px;
		max-height: 0;
		transition: none !important;
	}
	.modLocalNav > .inner:before {
		position: relative;
		display: block;
		height: 56px;
		margin: 0 -28px;
		background: #fdf5f4;
		content: '';
	}
}
.modLocalNav > .inner .inner {
	font-size: 2.0rem;
}
.modLocalNav > .inner .inner a {
	color: #ffffff;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav > .inner .inner a {
		text-decoration: none;
	}
	.modLocalNav > .inner .inner a:hover {
		text-decoration: underline;
	}
}
@media print, screen and (min-width: 641px) {
	.modLocalNav > .inner .inner {
		overflow: hidden;
		max-height: 0;
		transition: all .3s ease-in-out;
	}
}
@media only screen and (max-width: 640px) {
	.modLocalNav .modLocalNavIndex {
		padding-top: 16px;
	}
}
@media print, screen and (min-width: 641px) {
	.modLocalNav .modLocalNavIndex {
		display: none;
	}
}
.modLocalNav .modLocalNavIndex ul {
	position: relative;
	margin-left: -30px;
}
.modLocalNav .modLocalNavIndex ul:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
.modLocalNav .modLocalNavIndex ul li {
	float: left;
	margin: 10px 0 0 30px;
}
.modLocalNav dl:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
@media only screen and (max-width: 640px) {
	.modLocalNav dl {
		position: relative;
		overflow: hidden;
		margin-left: -30px;
		zoom: 1;
	}
}
@media print, screen and (min-width: 641px) {
	.modLocalNav dl {
		padding: 16px 0 5px 1px;
		border-top: 1px solid rgba(255, 255, 255, .3);
		font-size: 1.4rem;
		-webkit-column-count: 4;
		-moz-column-count: 4;
		column-count: 4;
		-webkit-column-gap: 0;
		-moz-column-gap: 0;
		column-gap: 0;
	}
	.modLocalNav dl:before,
	.modLocalNav dl:after {
		position: absolute;
		top: 30px;
		left: 290px;
		width: 0;
		height: calc(100% - 63px);
		border-left: 1px solid rgba(255, 255, 255, .3);
		content: '';
	}
	.modLocalNav dl:after {
		right: 290px;
		left: auto;
	}
}
@media only screen and (max-width: 640px) {
	.modLocalNav dl dt {
		float: none;
		clear: both;
		margin-left: 30px;
		padding-top: 40px;
	}
}
@media print, screen and (min-width: 641px) {
	.modLocalNav dl dt {
		padding-left: 20px;
		font-size: 1.2rem;
		line-height: 2.5;
	}
}
.modLocalNav dl dd {
	float: left;
	margin: 10px 0 0 30px;
	font-weight: bold;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav dl dd {
		float: none;
		margin: 0;
		padding-left: 20px;
	}
}
.modLocalNav.isActive {
	padding-bottom: 25px;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav.isActive {
		padding-bottom: 0;
	}
	.modLocalNav.isActive .modLocalNavHeading em {
		padding-left: 0;
	}
	.modLocalNav.isActive .modLocalNavSwitch {
		display: block;
	}
}
.modLocalNav.isActive > .inner {
	padding-bottom: 33px;
}
@media only screen and (max-width: 640px) {
	.modLocalNav.isActive > .inner {
		max-height: 10000px;
		transition: all .1s ease-in;
	}
	.modLocalNav.isActive > .inner:before {
		display: none;
	}
}
@media print, screen and (min-width: 641px) {
	.modLocalNav.isActive > .inner .inner {
		max-height: 5000px;
	}
}
.modLocalNav.isActive p.btn a {
	background: #53555d;
}
.modLocalNav.isActive p.btn span {
	top: 24px;
	left: 16px;
	width: 23px;
	height: 5px;
	background: #ffffff;
}
@media print, screen and (min-width: 641px) {
	.modLocalNav.isActive p.btn span {
		top: 12px;
		left: 6px;
		width: 15px;
		height: 2px;
	}
}
.modLocalNav.isActive p.btn span:nth-of-type(1) {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.modLocalNav.isActive p.btn span:nth-of-type(2) {
	opacity: 0;
}
.modLocalNav.isActive p.btn span:nth-of-type(3) {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

/* modHistory */
/* ------------------------------ */
.modHistoryData {
	border-bottom: 1px solid #000000;
}
.modHistoryData .unit {
	display: flex;
	width: 100%;
	padding: 20px 0;
	border-top: 1px solid #000000;

	align-items: center;
}
@media only screen and (max-width: 640px) {
	.modHistoryData .unit {
		display: block;
	}
	.modHistoryData .unit:after {
		display: block;
		clear: both;
		overflow: hidden;
		content: '';
	}
}
.modHistoryData .year {
	width: 130px;

	order: 1;
}
@media only screen and (max-width: 640px) {
	.modHistoryData .year {
		float: left;
		width: 100px;
	}
}
.modHistoryData .year span {
	display: block;
	width: 4em;
	height: 4em;
	border-radius: 50%;
	background-color: #5c6277;
	color: #ffffff;
	vertical-align: middle;
	text-align: center;
	font-size: 2.4rem;
	line-height: 4em;
}
.modHistoryData .year span.period {
	position: relative;
	padding-top: .5em;
	line-height: 1.5;
}
.modHistoryData .year span.period:after {
	position: absolute;
	top: 30px;
	right: -2px;
	left: 0;
	display: inline-block;
	color: #ffffff;
	content: '-';
	font-family: Arial;
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
}
@media only screen and (max-width: 640px) {
	.modHistoryData .year span.period:after {
		top: 22px;
		right: -6px;
		font-size: 30px;
	}
}
@media only screen and (max-width: 640px) {
	.modHistoryData .year span {
		font-size: 2.2rem;
	}
}
.modHistoryData ul {
	order: 2;
	flex: 1;
}
@media only screen and (max-width: 640px) {
	.modHistoryData ul {
		margin-left: 110px;
	}
}
.modHistoryData ul li {
	position: relative;
	width: 100%;
	margin-bottom: 8px;
	padding-left: 25px;
	font-weight: bold;
	font-size: 1.8rem;
	line-height: 1.4;
}
.modHistoryData ul li em {
	font-style: italic;
}
@media only screen and (max-width: 640px) {
	.modHistoryData ul li {
		font-weight: normal;
		font-size: 2.2rem;
	}
}
.modHistoryData ul li:before {
	position: absolute;
	top: 0;
	left: 3px;
	color: #999999;
	content: '・';
	font-weight: bold;
}
.modHistoryData ul li:last-child {
	margin-bottom: 0;
}
.modHistoryData .photo {
	width: 200px;
	text-align: right;

	order: 3;
}
@media only screen and (max-width: 640px) {
	.modHistoryData .photo {
		float: right;
		margin: 0 0 10px 20px;
		text-align: center;
	}
}

/* google map */
/* ------------------------------ */
.modMap {
	position: relative;
	padding-bottom: 56%;
}
@media only screen and (max-width: 640px) {
	.modMap {
		margin-top: 15px;
	}
}
.modMap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* table */
/* ------------------------------ */
.modTblA {
	margin-top: 13px;
}
@media only screen and (max-width: 640px) {
	.modTblA {
		overflow: hidden;
	}
	.modTblA .inner {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}
.modTblA table {
	width: 100%;
	border-right: 1px solid #707070;
	border-bottom: 1px solid #707070;
	table-layout: fixed;
}
@media only screen and (max-width: 640px) {
	.modTblA table {
		width: 1000px;
	}
}
.modTblA th,
.modTblA td {
	width: 25%;
	border-top: 1px solid #707070;
	border-left: 1px solid #707070;
	text-align: left;
}
.modTblA thead th {
	padding: 15px 10px 13px;
	background: #f2f2f2;
	vertical-align: middle;
	line-height: 1.5;
}
.modTblA tbody th,
.modTblA td {
	padding: 6px 10px 5px;
}
.modTblA th + td,
.modTblA th:nth-child(2) {
	background: #f2f2f2;
	text-align: center;
	font-size: 2.0rem;
}
@media print, screen and (min-width: 641px) {
	.modTblA th + td,
	.modTblA th:nth-child(2) {
		font-size: 1.3rem;
	}
}
.modTblA em {
	font-style: italic;
}

.modTblB table {
	width: 100%;
	border-right: 1px solid #707070;
	border-bottom: 1px solid #707070;
	table-layout: fixed;
}
.modTblB table th {
	width: calc(3em + 20px);
	text-align: left;
	white-space: nowrap;
	font-size: 2.0rem;
}
@media print, screen and (min-width: 641px) {
	.modTblB table th {
		width: 61px;
		font-size: 1.3rem;
	}
}
.modTblB table th,
.modTblB table td {
	padding: 6px 10px 5px;
	border-top: 1px solid #d3d3d4;
	border-left: 1px solid #d3d3d4;
}
.modTblB table tr:nth-child(even) th,
.modTblB table tr:nth-child(even) td {
	background-color: #f2f2f2;
}

/* modRank */
/* ------------------------------ */
.modRank {
	margin-top: 13px;
}
.modRank ol {
	border-right: 1px solid #707070;
	border-bottom: 1px solid #707070;
}
@media print, screen and (min-width: 641px) {
	.modRank ol {
		-webkit-column-count: 2;
		-moz-column-count: 2;
		column-count: 2;
		-webkit-column-gap: 0;
		-moz-column-gap: 0;
		column-gap: 0;
	}
}
.modRank ol li {
	border-top: 1px solid #707070;
	border-left: 1px solid #707070;
}
.modRank ol li dt {
	display: table-cell;
	width: 3.5em;
	padding: 6px 0 5px;
	border-right: 1px solid #707070;
	background: #f2f2f2;
	text-align: center;
	white-space: nowrap;
	font-size: 2.0rem;
}
@media print, screen and (min-width: 641px) {
	.modRank ol li dt {
		font-size: 1.3rem;
	}
}
.modRank ol li dd {
	display: table-cell;
	padding: 6px 10px 5px;
}
.modRank .modInterested {
	display: flex;
	flex-direction: column;
	width: 100%;
}
.modRank .modInterested li {
	box-sizing: border-box;
	width: 100%;
	padding: 6px 10px 5px;
	border: 1px solid #707070;
	border-bottom: none;
}
.modRank .modInterested li:last-of-type {
	border-bottom: 1px solid #707070;
}
@media print, screen and (min-width: 641px) {
	.modRank .modInterested li {
		width: 50%;
	}
}

/* modRelated */
/* ------------------------------ */
@media only screen and (max-width: 640px) {
	.modRelated {
		margin-top: 80px;
	}
}

.modRelated ul a {
	color: #e60039;
	text-decoration: underline;
}

/* modSummary */
/* ------------------------------ */
.modSummary {
	position: relative;
	margin-top: 19px;
}
.modSummary + .modSummary {
	margin-top: 30px;
}
.modSummary .flagNew {
	z-index: 1;
	box-sizing: border-box;
	width: 60px;
	padding: 5px 10px;
	background: #e60039;
	color: #ffffff;
	text-align: center;
	font-size: 1.2rem;
	line-height: 1;
}
.modSummary a.pdf {
	color: #e60039;
	text-decoration: underline;
}
.modSummary table {
	width: 100%;
	border-right: 1px solid #d3d3d4;
	border-bottom: 1px solid #d3d3d4;
}
@media only screen and (max-width: 640px) {
	.modSummary table {
		border: 1px solid #d3d3d4;
	}
}
.modSummary table tr:first-child {
	font-weight: bold;
}
.modSummary table th {
	width: 92px;
	text-align: left;
	white-space: nowrap;
	font-size: 2.0rem;
}
@media print, screen and (min-width: 641px) {
	.modSummary table th {
		font-size: 1.3rem;
	}
}
@media only screen and (max-width: 640px) {
	.modSummary table th {
		width: 100%;
		background-color: #e5e5e5;
	}
}
.modSummary table th,
.modSummary table td {
	padding: 6px 10px 5px;
	border-top: 1px solid #d3d3d4;
	border-left: 1px solid #d3d3d4;
}
@media only screen and (max-width: 640px) {
	.modSummary table th,
	.modSummary table td {
		display: block;
		border: none;
	}
}
@media print, screen and (min-width: 641px) {
	.modSummary table tr:nth-child(even) th,
	.modSummary table tr:nth-child(even) td {
		background-color: #f2f2f2;
	}
}
.modSummary table td {
	width: 428px;
}
@media only screen and (max-width: 640px) {
	.modSummary table td {
		width: 100%;
		min-height: 2em;
		background-color: #ffffff;
	}
}

/* modSearch */
/* ------------------------------ */
.modSearch .blockSearch1 {
	font-size: 1.4rem;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 {
		text-align: center;
		font-size: 2.4rem;
	}
}
.modSearch .blockSearch1 .unitTxt {
	display: table-cell;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .unitTxt {
		display: block;
		margin-bottom: 20px;
	}
}
.modSearch .blockSearch1 .unitTxt input {
	width: 712px;
	height: 40px;
	padding: 0 10px;
	border: 2px solid #e5e5e5;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .unitTxt input {
		width: 100%;
		height: 60px;
		border-radius: 0;
		box-shadow: none;
		-webkit-appearance: none;
	}
}
.modSearch .blockSearch1 .unitSelect {
	display: table-cell;
	height: 40px;
	vertical-align: middle;
	font-size: 0;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .unitSelect {
		position: relative;
		position: relative;
		display: block;
		height: auto;
		margin-bottom: 20px;
		font-size: 2.4rem;
	}
	.modSearch .blockSearch1 .unitSelect:before {
		position: absolute;
		top: 50%;
		right: 10px;
		margin-top: -6px;
		border-width: 20px 10px 0 10px;
		border-style: solid;
		border-color: #000000 transparent transparent transparent;
		content: '';
	}
	.modSearch .blockSearch1 .unitSelect:after {
		position: absolute;
		top: 0;
		right: 0;
		width: 42px;
		height: 100%;
		border-left: 1px solid #e5e5e5;
		content: '';
	}
}
.modSearch .blockSearch1 .unitSelect select {
	width: 100%;
	height: 60px;
	padding: 0 14px;
	border: 2px solid #e5e5e5;
	border-radius: 0;
	-webkit-appearance: none;
}
@media print, screen and (min-width: 641px) {
	.modSearch .blockSearch1 .unitSelect select {
		display: none;
	}
}
.modSearch .blockSearch1 .unitSelect .sod_select {
	display: table;
	width: 100%;
	height: 60px;
	padding: 0;
	border: 2px solid #e5e5e5;
	box-shadow: none;
	vertical-align: middle;
	font-weight: bold;
	font-size: 2.0rem;
}
@media print, screen and (min-width: 641px) {
	.modSearch .blockSearch1 .unitSelect .sod_select {
		display: block;
		width: 122px;
		height: 40px;
		font-size: 1.4rem;
	}
}
.modSearch .blockSearch1 .unitSelect .sod_select.open {
	color: #333641;
}
.modSearch .blockSearch1 .unitSelect .sod_select .sod_label {
	display: table-cell;
	width: 118px;
	height: 36px;
	padding: 0 14px;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .unitSelect .sod_select .sod_label {
		font-size: 2.4rem;
	}
}
.modSearch .blockSearch1 .unitSelect .sod_select:before {
	position: absolute;
	top: 50%;
	right: 5px;
	margin-top: -3px;
	border-width: 10px 5px 0 5px;
	border-style: solid;
	border-color: #000000 transparent transparent transparent;
	content: '';
}
.modSearch .blockSearch1 .unitSelect .sod_select:after {
	position: absolute;
	top: 0;
	right: 0;
	width: 21px;
	height: 100%;
	border-left: 1px solid #e5e5e5;
	content: '';
}
.modSearch .blockSearch1 .unitSelect .sod_select .sod_list_wrapper {
	width: 122px;
	margin: 0 0 0 -2px;
	border: 2px solid #e5e5e5;
	font-weight: bold;
}
.modSearch .blockSearch1 .unitSelect .sod_select .sod_list_wrapper:after {
	position: absolute;
	top: 0;
	right: 20px;
	display: block;
	width: 1px;
	height: 100%;
	background: #e5e5e5;
	content: '';
}
.modSearch .blockSearch1 .unitSelect .sod_select .sod_list_wrapper .sod_option {
	padding: 5px 15px;
}
.modSearch .blockSearch1 .unitSelect .sod_select .sod_list_wrapper .sod_option.selected:before {
	display: none;
}
.modSearch .blockSearch1 .btnSearch {
	display: table-cell;
	padding-left: 30px;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .btnSearch {
		display: inline-block;
		padding-left: 0;
	}
}
.modSearch .blockSearch1 .btnSearch input {
	display: table-cell;
	width: 144px;
	height: 40px;
	padding: 0;
	border: 2px solid #e5e5e5;
	border-radius: 3px;
	background: #5c6277;
	color: #ffffff;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .btnSearch input {
		height: 60px;
	}
}
.modSearch .blockSearch1 .btnSearch input:hover {
	transition: opacity .2s ease-in-out;
}
.modSearch .blockSearch1 .btnSearch input:hover:hover {
	text-decoration: none;
	opacity: .7;
}
.modSearch .blockSearch1 .btnClear {
	display: table-cell;
	padding-left: 10px;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .btnClear {
		display: inline-block;
	}
}
.modSearch .blockSearch1 .btnClear a {
	display: table-cell;
	width: 143px;
	height: 40px;
	border: 2px solid #e5e5e5;
	border-radius: 3px;
	vertical-align: middle;
	text-align: center;
	text-decoration: none;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch1 .btnClear a {
		height: 60px;
	}
}
.modSearch .blockSearch1 .btnClear a:before {
	display: inline-block;
	margin-right: 6px;
	content: '\00d7';
}
.modSearch .blockSearch1 .btnClear a:hover {
	transition: opacity .2s ease-in-out;
}
.modSearch .blockSearch1 .btnClear a:hover:hover {
	text-decoration: none;
	opacity: .7;
}

.modSearch .blockSearch2 {
	display: table;
	margin-top: 4px;
	font-size: 1.4rem;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 {
		display: block;
		font-size: 2.4rem;
	}
}
.modSearch .blockSearch2 dl {
	display: table-row;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl {
		display: block;
	}
}
.modSearch .blockSearch2 dl dt {
	display: table-cell;
	width: 184px;
	padding-top: 13px;
	vertical-align: top;
	font-weight: bold;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl dt {
		display: block;
		width: 100%;
		font-size: 2.4rem;
	}
}
.modSearch .blockSearch2 dl dd {
	display: table-cell;
	padding-top: 13px;
	vertical-align: top;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl dd {
		display: block;
	}
}
.modSearch .blockSearch2 dl dd ul {
	margin-top: -3px;
}
.modSearch .blockSearch2 dl dd ul:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
.modSearch .blockSearch2 dl dd ul li {
	position: relative;
	float: left;
	overflow: hidden;
	margin: 3px 21px 0 0;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl dd ul li {
		float: none;
	}
}
.modSearch .blockSearch2 dl dd ul li input {
	position: absolute;
	left: -100px;
}
.modSearch .blockSearch2 dl dd ul li input[type=radio] + label:before {
	background-image: url(/shared/img/bg_radio_01.png);
}
.modSearch .blockSearch2 dl dd ul li input:checked + label:before {
	background-position: left top;
}
.modSearch .blockSearch2 dl dd ul li label {
	display: block;
	cursor: pointer;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl dd ul li label {
		display: inline-block;
	}
}
.modSearch .blockSearch2 dl dd ul li label:before {
	position: relative;
	top: -2px;
	display: inline-block;
	width: 19px;
	height: 19px;
	margin-right: 3px;
	background: url(/shared/img/bg_checkbox_01.png) no-repeat -19px top;
	background-size: auto 19px;
	content: '';
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSearch .blockSearch2 dl dd ul li label:before {
		top: -3px;
		width: 38px;
		height: 38px;
		margin-right: 6px;
		background-position: -38px top;
		background-size: auto 38px;
	}
}

/* modPanel */
/* ------------------------------ */
.grid.modPanel {
	position: relative;
	overflow: hidden;
	margin-top: 28px;
	padding: 20px 0 111px;
	border-radius: 3px;
	background: #ffffff;
	background-clip: padding-box;
	transition: opacity .3s ease-in;
}
@media only screen and (max-width: 640px) {
	.grid.modPanel {
		width: 100%;
	}
	.grid.modPanel:first-child {
		margin-top: 0;
	}
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel {
		margin-top: 30px;
		padding-bottom: 68px;
	}
	.grid.modPanel:nth-child(-n+3) {
		margin-top: 0;
	}
	.grid.modPanel:hover {
		opacity: .9;
		cursor: pointer;
	}
	.grid.modPanel:not(.isActive):hover .btnReadmore a:after {
		-webkit-animation: readmore .4s ease-in-out;
		animation: readmore .4s ease-in-out;
	}
}
.grid.modPanel.isNew:before {
	position: absolute;
	top: -48px;
	right: -244px;
	z-index: 1;
	box-sizing: border-box;
	width: 276px;
	height: 276px;
	padding-top: 236px;
	background: #e60039;
	color: #ffffff;
	content: 'NEW';
	text-align: center;
	font-size: 2.0rem;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transform-origin: right top;
	transform-origin: right top;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel.isNew:before {
		top: -24px;
		right: -122px;
		-webkit-transform: rotate(45deg) scale(.5, .5);
		transform: rotate(45deg) scale(.5, .5);
	}
}
.grid.modPanel.isActive {
	box-shadow: inset 0 -9px 3px -3px #575b66;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel.isActive:hover .btnReadmore a:after {
		-webkit-animation: readmore2 .4s ease-in-out;
		animation: readmore2 .4s ease-in-out;
	}
}
.grid.modPanel.isActive .modDigest {
	max-height: 0;
}
.grid.modPanel.isActive .modTxt {
	max-height: 9999px;
}
.grid.modPanel.isActive .btnReadmore:before {
	height: 46px;
	background-color: #999999;
}
@media only screen and (max-width: 640px) {
	.grid.modPanel.isActive .btnReadmore:before {
		top: 2px;
		height: 68px;
	}
}
.grid.modPanel.isActive .btnReadmore a {
	background: #575b66;
	color: #ffffff;
}
.grid.modPanel.isActive .btnReadmore a:after {
	background-image: url(/shared/img/icon_readmore_01_on.png);
	opacity: 1;
	-webkit-transform: rotate(-90deg);
	transform: rotate(-90deg);
}
.grid.modPanel.isActive .btnReadmore a:before {
	content: '繝壹�繧ｸ縺ｸ';
}
.grid.modPanel .modFigure {
	position: relative;
	overflow: hidden;
	margin: 0 20px 20px;
	background: #ffffff;
	text-align: center;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel .modFigure {
		width: 313px;
	}
}
.grid.modPanel .modFigure img {
	width: auto;
	height: auto;
	max-width: 100%;
}
@media only screen and (max-width: 640px) {
	.grid.modPanel .modFigure img {
		width: 100%;
	}
}
.grid.modPanel .blockPanel {
	padding: 0 33px;
}
.grid.modPanel .modDigest,
.grid.modPanel .modTxt {
	overflow: hidden;
	line-height: 1.67;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel .modDigest,
	.grid.modPanel .modTxt {
		font-size: 1.5rem;
	}
}
.grid.modPanel .modDigest p,
.grid.modPanel .modTxt p {
	margin-top: 31px;
}
.grid.modPanel .modDigest p:first-child,
.grid.modPanel .modTxt p:first-child {
	margin-top: 0;
}
.grid.modPanel .modDigest {
	max-height: 9999px;
}
.grid.modPanel .modTxt {
	max-height: 0;
}
.grid.modPanel .btnReadmore {
	position: absolute;
	bottom: 0;
	left: 0;
	display: table;
	width: 100%;
}
.grid.modPanel .btnReadmore:before {
	position: absolute;
	top: 0;
	right: 70px;
	z-index: 2;
	width: 2px;
	height: 100px;
	background: #dfdfdf;
	content: '';
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel .btnReadmore:before {
		top: 1px;
		right: 45px;
		width: 1px;
	}
}
.grid.modPanel .btnReadmore a {
	display: table-cell;
	height: 70px;
	padding-right: 70px;
	border-top: 2px solid #dfdfdf;
	background: rgba(87, 91, 102, .1);
	color: #666666;
	vertical-align: middle;
	text-align: center;
	text-decoration: none;
	font-weight: bold;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel .btnReadmore a {
		height: 43px;
		padding-right: 46px;
		border-width: 1px;
	}
}
.grid.modPanel .btnReadmore a:after {
	position: absolute;
	top: 50%;
	right: 26px;
	display: inline-block;
	width: 18px;
	height: 21px;
	margin-top: -10px;
	background: url(/shared/img/icon_readmore_01.png) no-repeat center bottom;
	background-size: 18px 24px;
	content: '';
	opacity: .5;
}
@media print, screen and (min-width: 641px) {
	.grid.modPanel .btnReadmore a:after {
		right: 16px;
		width: 13px;
		height: 15px;
		margin-top: -7px;
		background-size: 13px auto;
	}
}
.grid.modPanel .btnReadmore a:before {
	content: '繧ゅ▲縺ｨ隕九ｋ';
}

.iphone .grid.modPanel .btnReadmore,
.safari .grid.modPanel .btnReadmore {
	left: -3px;
	width: calc(100% + 3px);
}

@-webkit-keyframes readmore {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	20% {
		-webkit-transform: translateY(2px);
		transform: translateY(2px);
	}
	50% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	70% {
		-webkit-transform: translateY(2px);
		transform: translateY(2px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@keyframes readmore {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	20% {
		-webkit-transform: translateY(2px);
		transform: translateY(2px);
	}
	50% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	70% {
		-webkit-transform: translateY(2px);
		transform: translateY(2px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@-webkit-keyframes readmore2 {
	0% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
	20% {
		-webkit-transform: translateX(2px) rotate(-90deg);
		transform: translateX(2px) rotate(-90deg);
	}
	50% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
	70% {
		-webkit-transform: translateX(2px) rotate(-90deg);
		transform: translateX(2px) rotate(-90deg);
	}
	100% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
}

@keyframes readmore2 {
	0% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
	20% {
		-webkit-transform: translateX(2px) rotate(-90deg);
		transform: translateX(2px) rotate(-90deg);
	}
	50% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
	70% {
		-webkit-transform: translateX(2px) rotate(-90deg);
		transform: translateX(2px) rotate(-90deg);
	}
	100% {
		-webkit-transform: translateX(0) rotate(-90deg);
		transform: translateX(0) rotate(-90deg);
	}
}

/* modTxtMincho */
/* ------------------------------ */
.modTxtMincho {
	position: relative;
	margin-top: -44px;
	color: #ffffff;
	text-align: center;
	font-size: 3.0rem;
	font-family: 'Noto Serif JP', serif;
	line-height: 1.58;
}
@media print, screen and (min-width: 641px) {
	.modTxtMincho {
		font-size: 2.4rem;
	}
}
.modTxtMincho p {
	margin-top: 1.62em;
}

/* modSidebar */
/* ------------------------------ */
.modSidebar {
	position: fixed;
	top: 185px;
	left: 50%;
	z-index: 100;
	width: 212px;
	margin-left: -609px;
	background: #fdf5f4;
}
@media only screen and (max-width: 640px) {
	.modSidebar {
		display: none;
	}
}
.modSidebar .ttl {
	padding: 16px 0 9px;
	border: 1px solid #5c5e67;
	color: #ffffff;
	text-align: center;
	font-size: 1.347rem;
}
.modSidebar .ttl strong {
	display: block;
	margin-bottom: 5px;
	font-size: 0;
}
.modSidebar .nav {
	font-size: 1.4rem;
}
.modSidebar .nav li {
	border: 1px solid #5c5e67;
	border-top: none;
}
.modSidebar .nav li a {
	display: block;
	padding: 12px 20px 13px;
	background: rgba(31, 33, 40, .4);
	color: #ffffff;
	text-decoration: none;
}
.modSidebar .nav li a:hover {
	transition: opacity .2s ease-in-out;
}
.modSidebar .nav li a:hover:hover {
	text-decoration: none;
	opacity: .7;
}
.modSidebar .nav li.current {
	border: none;
}
.modSidebar .nav li.current a {
	background: #ffffff;
	color: #e60039;
}

/* modPresentation */
/* ------------------------------ */
.modPresentation dl:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}

.modPresentation dl + p {
	margin-top: 0;
}

.modPresentation dt {
	float: left;
	width: 7em;
	margin: 0 0 31px;
}
.modPresentation dt:last-of-type {
	margin-bottom: 0;
}
@media only screen and (max-width: 640px) {
	.modPresentation dt {
		float: none;
		width: auto;
		margin-bottom: 0;
	}
}

.modPresentation dd {
	margin: 0 0 31px 7em;
}
.modPresentation dd:last-of-type {
	margin-bottom: 0;
}
@media only screen and (max-width: 640px) {
	.modPresentation dd {
		margin: 0 0 31px;
	}
	.modPresentation dd:last-of-type {
		overflow: hidden;
		height: 0;
	}
}

/* modHomePanels */
/* ------------------------------ */
.pageBacteriaDetail .modFigure {
	margin-bottom: 20px;
}

/* modBanner */
/* ------------------------------ */
.modBanner {
	width: 1120px;
	margin: 50px auto 0;
	padding: 0 40px;
}
@media only screen and (max-width: 640px) {
	.modBanner {
		width: 100%;
		padding: 0 28px;
	}
}
.modBanner img {
	overflow: hidden;
}
.modBanner img.pc {
	border-radius: 60px;
	box-shadow: 0 20px 20px rgba(0, 0, 0, .08);
}
.modBanner img.sp {
	display: none;
	width: 100%;
	border-radius: 4.26667vw;
	box-shadow: 0 2.66667vw 8vw rgba(0, 0, 0, .08);
}
@media only screen and (max-width: 640px) {
	.modBanner img.pc {
		display: none;
	}
	.modBanner img.sp {
		display: block;
	}
}

/* 2021-12 繝ｪ繝九Η繝ｼ繧｢繝ｫ縺ｫ繧医ｋ霑ｽ蜉�繝｢繧ｸ繝･繝ｼ繝ｫ */
/* modNewsList */
/* ------------------------------ */
.modNewsList {
	display: block;
	margin: 1.8rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modNewsList {
		margin: 60px 0 0;
	}
}
.modNewsList li {
	display: block;
	margin: 5.2rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modNewsList li {
		margin: 20px 0 0;
	}
}
.modNewsList li a {
	display: block;
	text-decoration: none;
	transition: opacity .2s ease-in-out;
}
.modNewsList li a:hover {
	text-decoration: none;
	opacity: .5;
}
@media print, screen and (min-width: 641px) {
	.modNewsList li a {
		display: flex;
		align-items: flex-start;
	}
}
.modNewsList li time {
	display: block;
	color: #46b1d2;
	font-weight: bold;
	font-size: 3.1rem;
	line-height: 1.4;
}
@media print, screen and (min-width: 641px) {
	.modNewsList li time {
		width: 115px;
		font-size: 18px;
	}
}
.modNewsList li p {
	margin: 3.5rem 0 0;
	font-weight: bold;
	font-size: 2.8rem;
	line-height: 1.5;
}
@media print, screen and (min-width: 641px) {
	.modNewsList li p {
		margin: 0;
		font-size: 16px;

		flex: 1;
	}
}

.modContentsList {
	display: flex;
	flex-direction: column;
	margin: 3.5rem 0 0;

	align-items: center;
}
@media print, screen and (min-width: 641px) {
	.modContentsList {
		flex-direction: row;
		margin: 30px 0 0 -60px;
		padding: 0 20px;

		flex-wrap: wrap;
		align-items: flex-start;
	}
}
.modContentsList li {
	display: block;
	margin: 10.3rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modContentsList li {
		width: calc(33.33333% - 60px);
		margin: 50px 0 0 60px;
	}
}
.modContentsList a {
	display: block;
	text-decoration: none;
	transition: opacity .2s ease-in-out;
}
.modContentsList a:hover {
	text-decoration: none;
	opacity: .7;
}
.modContentsListImage {
	position: relative;
	z-index: 0;
	width: 54.7rem;
	height: 54.7rem;
}
@media print, screen and (min-width: 641px) {
	.modContentsListImage {
		width: 100%;
		height: 320px;
	}
}
.modContentsListImage img {
	overflow: hidden;
	width: 100%;
	height: 100%;
	border: 1.8rem solid #ffffff;
	border-radius: 50%;
	box-shadow: 0 1.8rem 5.2rem rgba(0, 0, 0, .08);
	font-family: 'object-fit: cover;';

	-o-object-fit: cover;
	object-fit: cover;
}
@media print, screen and (min-width: 641px) {
	.modContentsListImage img {
		border-width: 10px;
		border-radius: 50%;
		box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
	}
}
.modContentsListImage figcaption {
	position: absolute;
	bottom: 5.2rem;
	left: 50%;
	z-index: 1;
	display: flex;
	height: 7.6rem;
	padding: 0 5.2rem;
	border-radius: 3.8rem;
	background: #ffffff;
	color: #46b1d2;
	white-space: nowrap;
	font-weight: bold;
	font-size: 2.8rem;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	justify-content: center;
	align-items: center;
}
@media print, screen and (min-width: 641px) {
	.modContentsListImage figcaption {
		bottom: 30px;
		height: 44px;
		padding: 0 30px;
		border-radius: 22px;
		font-size: 16px;
	}
}
.modContentsListText {
	display: block;
	margin: 5.2rem 0;
	color: #53555d;
	text-align: center;
	font-size: 2.8rem;
}
@media print, screen and (min-width: 641px) {
	.modContentsListText {
		margin: 32px 0 0;
		font-weight: bold;
		font-size: 16px;
	}
}

.modAboutList {
	display: flex;
	flex-direction: column;
	margin: 8.6rem 0 0;

	align-items: center;
}
@media print, screen and (min-width: 641px) {
	.modAboutList {
		flex-direction: row;
		margin: 30px 0 0 -80px;
		padding: 0 80px;

		flex-wrap: wrap;
		align-items: flex-start;
	}
}
.modAboutList li {
	display: block;
	margin: 5.2rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modAboutList li {
		display: flex;
		width: calc(33.33333% - 80px);
		margin: 50px 0 0 80px;
		max-width: 266px;
		justify-content: center;
	}
}
.modAboutList a {
	display: block;
	text-decoration: none;
	transition: opacity .2s ease-in-out;
}
.modAboutList a:hover {
	text-decoration: none;
	opacity: .7;
}
.modAboutListImage {
	position: relative;
	z-index: 0;
	overflow: hidden;
	width: 45.4rem;
	height: 68.3rem;
	border: 1.8rem solid #ffffff;
	border-radius: 4.1rem;
	box-shadow: 0 1.8rem 5.2rem rgba(0, 0, 0, .08);
}
@media print, screen and (min-width: 641px) {
	.modAboutListImage {
		border-width: 10px;
		border-radius: 24px;
		box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
	}
}
@media print, screen and (min-width: 641px) {
	.modAboutListImage {
		width: 100%;
		height: 400px;
	}
}
.modAboutListImage img {
	width: 100%;
	height: 100%;
	font-family: 'object-fit: cover;';

	-o-object-fit: cover;
	object-fit: cover;
}
.modAboutListImage figcaption {
	position: absolute;
	bottom: 5.2rem;
	left: 50%;
	z-index: 1;
	display: flex;
	height: 7.6rem;
	padding: 0 5.2rem;
	border-radius: 3.8rem;
	background: #ffffff;
	color: #46b1d2;
	white-space: nowrap;
	font-weight: bold;
	font-size: 2.8rem;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	justify-content: center;
	align-items: center;
}
@media print, screen and (min-width: 641px) {
	.modAboutListImage figcaption {
		bottom: 25px;
		height: 44px;
		padding: 0 30px;
		border-radius: 22px;
		font-size: 16px;
	}
}

/* [Pages] */
/* ------------------------------ */
/* home */
/* ------------------------------ */
/* modHomePanels */
/* ------------------------------ */
.blockHomeSection {
	padding: 17.1rem 3.5rem;
}
@media print, screen and (min-width: 641px) {
	.blockHomeSection {
		padding: 100px 28px;
	}
}
.blockHomeSection:first-child {
	padding-top: 3.5rem;
}
@media print, screen and (min-width: 641px) {
	.blockHomeSection:first-child {
		padding-top: 40px;
	}
}
.blockHomeSection:nth-child(2n + 1) {
	background-color: #e9f5fc;
}
.blockHomeSection:nth-child(2n) {
	background-color: #fbecea;
}
.blockHomeSectionInner {
	margin: 0 auto;
	max-width: 1120px;
}
#news .blockHomeSectionInner {
	max-width: 1260px;
}
.blockHomeSectionColumn {
	margin: 60px auto 0;
	max-width: 1120px;
}
#news .blockHomeSectionColumn {
	max-width: 1080px;
}
@media print, screen and (min-width: 641px) {
	.blockHomeSectionColumn.column-2-1 {
		display: flex;
	}
	.blockHomeSectionColumn.column-2-1 .blockHomeSectionColumnInner *:first-child {
		margin-top: 0 !important;
	}
	.blockHomeSectionColumn.column-2-1 .blockHomeSectionColumnInner:first-child {
		flex: 1;
	}
	.blockHomeSectionColumn.column-2-1 .blockHomeSectionColumnInner:last-child {
		width: 330px;
		margin: 0 0 0 40px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockHomeSection .modNewsList {
		margin: 30px 0 0;
	}
}

.modHomeKv {
	position: relative;
	z-index: 0;
	display: block;
	transition: opacity .2s ease-in-out;
}
.modHomeKv:hover {
	text-decoration: none;
	opacity: .7;
}
.modHomeKvImage {
	display: block;
	max-width: 100%;
}
.modHomeKvImage img {
	overflow: hidden;
	width: 100%;
	border: 1.8rem solid #ffffff;
	border-radius: 4.1rem;
	box-shadow: 0 1.8rem 5.2rem rgba(0, 0, 0, .08);
}
@media print, screen and (min-width: 641px) {
	.modHomeKvImage img {
		border-width: 10px;
		border-radius: 24px;
		box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
	}
}
.modHomeKvImage figcaption {
	position: absolute;
	bottom: 5.2rem;
	left: 50%;
	z-index: 5;
	display: flex;
	width: 50.9rem;
	height: 7.6rem;
	border-radius: 3.8rem;
	background-color: #ffffff;
	color: #46b1d2 !important;
	text-decoration: none;
	font-weight: bold;
	font-size: 2.8rem;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	justify-content: center;
	align-items: center;
}
@media print, screen and (min-width: 641px) {
	.modHomeKvImage figcaption {
		bottom: 40px;
		width: 298px;
		height: 58px;
		font-size: 1.6rem;
	}
}

.modHomeHeading {
	text-align: center;
	font-weight: bold;
	font-size: 3.8rem;
	line-height: 1.36364;
}
@media print, screen and (min-width: 641px) {
	.modHomeHeading {
		font-size: 22px;
	}
}
.modHomeHeading span {
	display: block;
	margin: 1.4rem 0 0;
	color: #f47454;
	font-size: 3.1rem;
	font-family: 'Karla', sans-serif;
}
@media print, screen and (min-width: 641px) {
	.modHomeHeading span {
		margin: 8px 0 0;
		font-size: 18px;
	}
}
#news .modHomeHeading {
	margin-top: 6.9rem;
}
@media print, screen and (min-width: 641px) {
	#news .modHomeHeading {
		display: flex;
		margin-top: 60px;

		align-items: center;
	}
	#news .modHomeHeading span {
		display: inline-block;
		margin: 0 0 0 8px;
	}
}

.modHomeSlide {
	overflow: hidden;
	margin: 6.9rem 0 0;
	border-radius: 2.8rem;
}
@media print, screen and (min-width: 641px) {
	.modHomeSlide {
		margin: 0;
		border-radius: 16px;
	}
}
.modHomeSlide .swiper-wrapper {
	height: 27.4rem;
}
@media print, screen and (min-width: 641px) {
	.modHomeSlide .swiper-wrapper {
		height: 160px;
	}
}
.modHomeSlide .swiper-slide {
	height: 100%;
}
.modHomeSlide .swiper-slide a {
	display: block;
	height: 100%;
}
@media print, screen and (min-width: 641px) {
	.modHomeSlide .swiper-slide a {
		transition: opacity .2s ease-in-out;
	}
	.modHomeSlide .swiper-slide a:hover {
		text-decoration: none;
		opacity: .7;
	}
}
.modHomeSlide img {
	display: block;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.modHomeSlidePagination {
	display: flex;
	margin: 1.8rem 0 0;

	justify-content: center;
}
@media print, screen and (min-width: 641px) {
	.modHomeSlidePagination {
		margin: 10px 0 0;
	}
}
.modHomeSlidePagination .swiper-pagination-bullet {
	display: block;
	width: 1.4rem;
	height: 1.4rem;
	margin: 0 .9rem;
	border-radius: 1.4rem;
	background-color: rgba(83, 85, 93, .5);
	transition: background-color .3s ease;
}
@media print, screen and (min-width: 641px) {
	.modHomeSlidePagination .swiper-pagination-bullet {
		width: 8px;
		height: 8px;
		margin: 0 5px;
		border-radius: 8px;
		cursor: pointer;
	}
}
.modHomeSlidePagination .swiper-pagination-bullet-active {
	background-color: #53555d;
}

.modHomeBannerList {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.8rem;
}
@media print, screen and (min-width: 641px) {
	.modHomeBannerList {
		gap: 10px;
	}
}
.modHomeBannerList a {
	display: block;
	width: 50.4rem;
	aspect-ratio: 32 / 10;
}
@media print, screen and (min-width: 641px) {
	.modHomeBannerList a {
		width: 320px;
		transition: opacity .2s ease-in-out;
	}
	.modHomeBannerList a:hover {
		text-decoration: none;
		opacity: .7;
	}
}
.modHomeBannerList a img {
	max-width: 100%;
	box-shadow: 0 1.8rem 5.2rem rgba(0, 0, 0, .04);
}
@media print, screen and (min-width: 641px) {
	.modHomeBannerList a img {
		box-shadow: 0 10px 30px rgba(0, 0, 0, .04);
	}
}

/* Backteria Nav */
/* ------------------------------ */
.blockBacteriaNav {
	position: relative;
	margin: 0 auto;
	max-width: 1100px;
	background: #53555d;
	color: #ffffff;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav {
		padding: 0 20px;
	}
}
.blockBacteriaNav a {
	color: #ffffff;
}
.blockBacteriaNav .btn {
	position: absolute;
	z-index: 20;
	display: block;
	border: 1px solid #c9c9c9;
	border-radius: 50%;
	background: #c9c9c9;
	box-shadow: 0 0 2px rgba(0, 0, 0, .23);
	transition: opacity .2s ease-in-out;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn {
		top: -9em;
		right: 40px;
		width: 56px;
		height: 56px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn {
		top: 10px;
		right: 20px;
		width: 26px;
		height: 26px;
	}
}
.mainInner .blockBacteriaNav .btn {
	display: none;
}
.blockBacteriaNav .btn:hover {
	opacity: .7;
}
.blockBacteriaNav .btn span {
	position: absolute;
	display: block;
	background: #565b6d;
	transition: all .2s ease-in-out;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn span {
		top: 20px;
		left: 14px;
		width: 24px;
		height: 2px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn span {
		top: 9px;
		left: 6px;
		width: 12px;
		height: 1px;
	}
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn span:nth-of-type(2) {
		top: 26px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn span:nth-of-type(2) {
		top: 12px;
	}
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn span:nth-of-type(3) {
		top: 32px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn span:nth-of-type(3) {
		top: 15px;
	}
}
.blockBacteriaNav .btn.isActive {
	background: #53555d;
}
.blockBacteriaNav .btn.isActive span {
	background: #ffffff;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn.isActive span {
		left: 16px;
		width: 23px;
		height: 4px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn.isActive span {
		left: 4px;
		width: 16px;
		height: 2px;
	}
}
.blockBacteriaNav .btn.isActive span:nth-of-type(1) {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn.isActive span:nth-of-type(1) {
		top: 25px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn.isActive span:nth-of-type(1) {
		top: 11px;
	}
}
.blockBacteriaNav .btn.isActive span:nth-of-type(2) {
	opacity: 0;
}
.blockBacteriaNav .btn.isActive span:nth-of-type(3) {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .btn.isActive span:nth-of-type(3) {
		top: 25px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .btn.isActive span:nth-of-type(3) {
		top: 12px;
	}
}
.blockBacteriaNav .navHeader {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navHeader {
		display: none;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navHeader {
		padding: 14px 20px 13px;
		line-height: 1.2;
	}
}
.blockBacteriaNav .navSwitch {
	display: flex;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navSwitch {
		position: relative;
		top: 100px;
		z-index: 10;
		width: 100%;
		justify-content: center;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navSwitch {
		position: absolute;
		top: 10px;
		right: 55px;
	}
	.mainInner .blockBacteriaNav .navSwitch {
		right: 15px;
	}
}
.blockBacteriaNav .navSwitch li {
	margin: 0 5px;
}
.blockBacteriaNav .navSwitch a {
	display: inline-block;
	width: 6em;
	border: 1px solid rgba(255, 255, 255, .3);
	border-radius: 3px;
	background: #53555d;
	color: #ffffff;
	text-align: center;
	text-decoration: none;
	line-height: 1;
	transition: opacity .2s ease-in-out;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navSwitch a {
		padding: 10px 0;
		font-size: 2rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navSwitch a {
		padding: 4px 0;
		font-size: 1rem;
	}
	.blockBacteriaNav .navSwitch a:hover {
		text-decoration: none !important;
		opacity: .7;
	}
}
.blockBacteriaNav .navSwitch a.isActive {
	background: #333641;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody {
		padding: 30px 0;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody {
		display: flex;
		margin: 0 20px;
		border-top: 1px solid rgba(255, 255, 255, .3);
	}
	.blockBacteriaNav .navBody:after {
		display: block;
		clear: both;
		overflow: hidden;
		content: '';
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody a {
		text-decoration: none;
	}
	.blockBacteriaNav .navBody a:hover {
		text-decoration: underline;
	}
}
.blockBacteriaNav .navBody .contentsList {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList {
		font-size: 2.2rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList {
		font-size: 1.5rem;
	}
}
.blockBacteriaNav .navBody .contentsList .spHeading {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList .spHeading strong {
		display: block;
		text-align: center;
		font-weight: normal;
		font-size: 2.8rem;
	}
	.blockBacteriaNav .navBody .contentsList .spHeading span {
		position: absolute;
		top: 3px;
		right: 5px;
		display: inline-block;
		font-size: 2rem;
	}
	.blockBacteriaNav .navBody .contentsList .spHeading span a {
		display: inline-block;
		padding: 2px;
		border: 1px solid #ffffff;
		text-decoration: none;
		font-size: 1.8rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList .spHeading {
		display: none;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList {
		float: left;
		width: 25%;
		padding: 16px 20px 16px 0;
		font-size: 1.5rem;
	}
	.blockBacteriaNav .navBody .contentsList:after {
		position: absolute;
		top: 0;
		right: 0;
		display: block;
		width: 1px;
		height: 100%;
		background: rgba(255, 255, 255, .3);
		content: '';
	}
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList > ul {
		padding-top: 20px;
	}
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList > ul > li {
		margin: 0 0 5px;
		padding: 0 0 0 20px;
		background: url(/shared/img/ico_agenda_01.png) no-repeat 0 14px;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList > ul > li {
		margin: 0 0 10px;
		padding: 0 0 0 20px;
		background: url(/shared/img/ico_agenda_01.png) no-repeat 0 6px;
	}
}
.blockBacteriaNav .navBody .contentsList > ul > li.cate {
	padding-left: 0;
	background-image: none;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul {
		margin-top: 5px;
		margin-bottom: 15px;
		padding-left: 20px;
		font-size: 2.0rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul {
		margin-top: 5px;
		margin-bottom: 15px;
		padding-left: 20px;
		font-size: 1.3rem;
	}
}
.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul li {
	position: relative;
	margin-bottom: 10px;
	line-height: 1.3;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul li {
		display: inline-block;
		margin-right: 1.5em;
	}
}
.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul li:before {
	position: absolute;
	top: 0;
	left: -15px;
	content: '\003e';
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul li:before {
		font-size: 2rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .contentsList > ul > li.cate > ul li:before {
		font-size: 1rem;
	}
}
.blockBacteriaNav .navBody .titleListWrapper {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .titleListWrapper {
		font-size: 2rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .titleListWrapper {
		float: left;
		width: 75%;
		font-size: 1.2rem;
	}
}
.blockBacteriaNav .navBody .titleListWrapper .spHeading {
	position: relative;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .titleListWrapper .spHeading {
		margin-bottom: 90px;
		font-size: 2.0rem;
	}
	.blockBacteriaNav .navBody .titleListWrapper .spHeading strong {
		display: block;
		text-align: center;
		font-weight: normal;
		font-size: 2.8rem;
	}
	.blockBacteriaNav .navBody .titleListWrapper .spHeading span {
		position: absolute;
		top: 3px;
		right: 5px;
		display: inline-block;
		font-size: 2rem;
	}
	.blockBacteriaNav .navBody .titleListWrapper .spHeading span a {
		display: inline-block;
		padding: 2px 5px;
		border: 1px solid #ffffff;
		text-decoration: none;
		font-size: 1.8rem;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .titleListWrapper .spHeading {
		display: none;
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .titleListWrapper:before {
		position: absolute;
		top: 0;
		left: 33.3%;
		display: block;
		width: 1px;
		height: 100%;
		background: rgba(255, 255, 255, .3);
		content: '';
	}
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .titleListWrapper:after {
		position: absolute;
		top: 0;
		left: 66.6%;
		display: block;
		width: 1px;
		height: 100%;
		background: rgba(255, 255, 255, .3);
		content: '';
	}
}
.blockBacteriaNav .navBody .titleList {
	display: none;
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav .navBody .titleList {
		padding: 16px 0 16px 10px;
		-webkit-column-count: 3;
		-moz-column-count: 3;
		column-count: 3;
	}
}
.blockBacteriaNav .navBody .titleList.isActive {
	display: block;
}
.blockBacteriaNav .navBody .titleList dt {
	margin-bottom: 5px;
}
.blockBacteriaNav .navBody .titleList dd,
.blockBacteriaNav .navBody .titleList li {
	margin-bottom: 5px;
}
@media only screen and (max-width: 640px) {
	.blockBacteriaNav .navBody .titleList dd,
	.blockBacteriaNav .navBody .titleList li {
		display: inline-block;
		margin-right: 1em;
	}
}

.blockBacteriaNav.category .navWrapper {
	padding: 10px 0 20px;
}
@media print, screen and (min-width: 641px) {
	.blockBacteriaNav.category .navWrapper .categoryHeading {
		margin: 0 20px;
		padding: 5px 0 10px;
		font-size: 1.5rem;
	}
}

@media only screen and (max-width: 640px) {
	.blockBacteriaNav.category .navSwitch {
		top: 0;
		margin-bottom: 20px;
	}
}

.blockBacteriaNav.category .navBody .titleListWrapper {
	float: none;
	width: 100%;
}

@media only screen and (max-width: 640px) {
	.modPageHeader + .blockBacteriaNav .navWrapper {
		overflow: hidden;
		max-height: 0;
		transition: max-height 1s ease;
	}
}

@media only screen and (max-width: 640px) {
	.modPageHeader + .blockBacteriaNav.isOpen .navWrapper {
		overflow: visible;
		max-height: 9999px;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav .navBody {
		overflow: hidden;
		max-height: 0;
		transition: max-height .7s ease-in-out;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav .navSwitch {
		visibility: hidden;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav .navHeader span {
		transition: all .3s ease;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav.isOpen .navBody {
		overflow: visible;
		max-height: 9999px;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav.isOpen .navSwitch {
		visibility: visible;
	}
}

@media print, screen and (min-width: 641px) {
	.modPageHeader + .blockBacteriaNav.isOpen .navHeader span.separate {
		display: none;
	}
	.modPageHeader + .blockBacteriaNav.isOpen .navHeader span.index {
		padding-left: 7.8em;
	}
}

@media print, screen and (min-width: 641px) {
	.mainInner .blockBacteriaNav .navHeader span {
		display: inline-block;
	}
	.mainInner .blockBacteriaNav .navHeader .separate {
		display: none;
	}
	.mainInner .blockBacteriaNav .navHeader .index {
		display: inline-block;
		padding-left: 7.4em;
	}
}

@media print, screen and (min-width: 641px) {
	.pageBacteriaDetail #blockBacteriaInterests {
		height: 280px;
	}
}

@media only screen and (max-width: 640px) {
	.pageBacteriaDetail #blockBacteriaInterests .modChartCaption {
		width: 100%;
	}
}

.pageBacteriaDetail #blockBacteriaInterests .modChartCaption .ago {
	bottom: -1em;
}

.pageBacteriaDetail .modGrid2.modPhotoPos.even {
	margin-bottom: 24px;
}

.pageBacteriaDetail section p {
	margin: 1em 0;
}

.pageBacteriaDetail section i {
	font-style: italic;
}

.pageBacteriaDetail .tbl table {
	width: 100%;
	table-layout: fixed;
	line-height: 1.4;
}

.pageBacteriaDetail .tbl th {
	width: 150px;
	padding: 10px 12px;
	border: 1px solid #c9c9c9;
	background: #f6f6f6;
	vertical-align: middle;
	text-align: left;
}

.pageBacteriaDetail .tbl td {
	padding: 10px 12px;
	border: 1px solid #c9c9c9;
	vertical-align: middle;
	word-wrap: break-word;
}

.pageBacteriaDetail .tbl em,
.pageBacteriaDetail .tbl i {
	font-weight: normal;
	font-style: italic;
}

@media print, screen and (min-width: 641px) {
	.pageBacteriaDetail .modRecommendLink {
		margin-top: 20px;
	}
}

/* Dictionary */
/* ------------------------------ */
.pageDictionaryIndex .modRecommendLink {
	margin-bottom: 53px;
}
@media print, screen and (min-width: 641px) {
	.pageDictionaryIndex .modRecommendLink {
		margin-bottom: 0;
	}
}

.pageDictionaryIndex .modChart {
	margin-bottom: 20px;
}
@media print, screen and (min-width: 641px) {
	.pageDictionaryIndex .modChart .modGrid2 .grid {
		height: auto !important;
	}
}
@media only screen and (max-width: 640px) {
	.pageDictionaryIndex .modChart .modGrid2 .modTxt {
		margin-bottom: 21px;
	}
}
.pageDictionaryIndex .modChart .modGrid2 .modTxt p {
	margin: 0;
}
.pageDictionaryIndex .modChart .modGrid2 .modTxt p strong {
	margin: 0 1em 0 0;
}

.pageDictionaryIndex .modLocalNav {
	width: 100%;
}
.pageDictionaryIndex .modLocalNav .btn {
	display: none;
}
@media only screen and (max-width: 640px) {
	.pageDictionaryIndex .modLocalNav {
		position: relative;
	}
}
.pageDictionaryIndex .modLocalNav:before {
	left: 520px;
}
.pageDictionaryIndex .modLocalNav .modLocalNavHeading {
	cursor: default;
}
.pageDictionaryIndex .modLocalNav dl:before {
	left: 270px;
}
.pageDictionaryIndex .modLocalNav dl:after {
	right: 270px;
}

@media print, screen and (min-width: 641px) {
	.pageDictionaryIndex #blockDictionaryInterests {
		min-height: 264px;
	}
}

.pageDictionaryDetail .mainInner .modLocalNav {
	width: 100%;
}
.pageDictionaryDetail .mainInner .modLocalNav .btn {
	display: none;
}
@media print, screen and (min-width: 641px) {
	.pageDictionaryDetail .mainInner .modLocalNav {
		margin-bottom: 0;
	}
}
@media only screen and (max-width: 640px) {
	.pageDictionaryDetail .mainInner .modLocalNav {
		position: relative;
		margin-bottom: 48px;
	}
}
.pageDictionaryDetail .mainInner .modLocalNav:before {
	left: 520px;
}
.pageDictionaryDetail .mainInner .modLocalNav .modLocalNavHeading {
	cursor: default;
}
.pageDictionaryDetail .mainInner .modLocalNav dl:before {
	left: 270px;
}
.pageDictionaryDetail .mainInner .modLocalNav dl:after {
	right: 270px;
}

.pageDictionaryDetail .btnReadmore a:hover {
	opacity: 1;
}

@media print, screen and (min-width: 641px) {
	.pageDictionaryDetail .modRecommendLink {
		margin: 40px 0;
	}
}

@media only screen and (max-width: 640px) {
	.pageDictionaryDetail .modRecommendLink {
		margin-bottom: 80px;
	}
}

.pageDictionaryDetail .modTxt {
	overflow: hidden;
}
.pageDictionaryDetail .modTxt p {
	margin: 0 0 1em;
}
@media print, screen and (min-width: 641px) {
	.pageDictionaryDetail .modTxt .image {
		float: right;
	}
}
@media only screen and (max-width: 640px) {
	.pageDictionaryDetail .modTxt .image {
		overflow: hidden;
	}
}
.pageDictionaryDetail .modTxt .image figure {
	float: left;
	margin: 0 0 20px 20px;
}
.pageDictionaryDetail .modTxt .image figcaption {
	font-size: 1.2rem;
}

@media print, screen and (min-width: 641px) {
	.pageFeatureDetail .modRecommendLink {
		margin: 40px 0 70px;
	}
}

@media only screen and (max-width: 640px) {
	#mayCart2 {
		width: 584px !important;
		height: auto;
	}
}

/* About */
/* ------------------------------ */
.blockAboutHistory {
	margin-top: 52px;
}
.blockAboutHistory .modHeading2,
.blockAboutHistory .pageBacteriaDetail section h2,
.pageBacteriaDetail section .blockAboutHistory h2 {
	border: none;
}
.blockAboutHistory .modLinkMore {
	margin-top: 20px;
	font-size: 2rem;
}

/* mission */
/* ------------------------------ */
@media only screen and (max-width: 640px) {
	.contMission .modPageHeader {
		margin-bottom: 0;
	}
}

.contMission .modPageHeader .modHeading1 {
	position: relative;
	margin: 0 auto 50px;
	padding-bottom: 25px;
	background: url(../img/ttl_mission_01.png) no-repeat 50% 100%;
	font-size: 1.2rem;
}
@media only screen and (max-width: 640px) {
	.contMission .modPageHeader .modHeading1 {
		padding-top: 11px;
		font-size: 2.1rem;
	}
}
.contMission .modPageHeader .modHeading1:after {
	position: absolute;
	right: 0;
	bottom: -30px;
	left: 0;
	display: block;
	width: 40px;
	height: 4px;
	margin: 0 auto;
	background: #ffffff;
	content: '';
}
@media print, screen and (min-width: 641px) {
	.contMission .modPageHeader .modHeading1:after {
		width: 30px;
		height: 2px;
	}
}

.contMission .modPageHeader .modLead {
	margin-top: 33px;
	text-shadow: 0 0 5px rgba(0, 0, 0, .75);
	font-size: 4.8rem;
	line-height: 1.35;
}
@media only screen and (max-width: 640px) {
	.contMission .modPageHeader .modLead {
		margin-top: 50px;
		font-size: 4.0rem;
	}
}

.contMission .mainInner {
	position: relative;
	margin-top: -44px;
	background: transparent;
	color: #ffffff;
	text-align: center;
	font-size: 3.0rem;
	font-family: 'Calibri Light', 'Calibri', '貂ｸ譏取悃', YuMincho, '繝偵Λ繧ｮ繝取�譛� ProN W3', 'Hiragino Mincho ProN', 'HG譏取悃E', '�ｭ�ｳ �ｰ譏取悃', '�ｭ�ｳ 譏取悃', serif;
	line-height: 1.58;
}
.contMission .mainInner p {
	margin: 1.5em 0;
	font-size: 2.4rem;
}
.contMission .mainInner p:first-child {
	margin-top: 0;
}
@media only screen and (max-width: 640px) {
	.contMission .mainInner {
		font-size: 1.6rem;
	}
}

/* special */
/* ------------------------------ */
/* pageThesis */
/* ------------------------------ */
.pageThesis .modPager {
	margin: 2em 0;
	text-align: center;
}
@media only screen and (max-width: 640px) {
	.pageThesis .modPager {
		margin: 1em 0;
	}
}
.pageThesis .modPager .wrapBtn:after {
	display: block;
	clear: both;
	overflow: hidden;
	content: '';
}
@media print, screen and (min-width: 641px) {
	.pageThesis .modPager .wrapBtn {
		margin-top: -27px;
	}
}
.pageThesis .modPager .wrapBtn .modBtn2 {
	margin: 0;
}
@media only screen and (max-width: 640px) {
	.pageThesis .modPager .wrapBtn .modBtn2 {
		font-size: 1.8rem;
	}
}
.pageThesis .modPager .wrapBtn .modBtn2.prev {
	float: left;
	text-align: left;
}
.pageThesis .modPager .wrapBtn .modBtn2.next {
	float: right;
}

.pageThesis a.pdf {
	color: #e60039;
}

/* news sp */
/* ------------------------------ */
.pageNewsDetail .mainInner {
	padding-top: 40px;
	padding-bottom: 70px;
}
@media print, screen and (min-width: 641px) {
	.pageNewsDetail .mainInner {
		width: 720px;
		margin: 0 auto;
	}
}

@media only screen and (max-width: 640px) {
	.pageNewsDetail .modPageHeader {
		padding: 20px 0;
	}
}

.pageNewsDetail .modHeading2,
.pageNewsDetail .pageBacteriaDetail section h2,
.pageBacteriaDetail section .pageNewsDetail h2 {
	margin-bottom: 30px;
	border-bottom: 0;
}

.pageNewsDetail .figure {
	margin-bottom: 30px;
	text-align: center;
}
@media print, screen and (min-width: 641px) {
	.pageNewsDetail .figure img {
		width: 640px;
		height: auto;
	}
}
@media only screen and (max-width: 640px) {
	.pageNewsDetail .figure img {
		width: 100%;
		height: auto;
	}
}

.pageNewsDetail .entryBody {
	margin: 0 0 20px;
}
.pageNewsDetail .entryBody p {
	margin-bottom: .75em;
}

.pageNewsDetail .more {
	margin: 0 0 20px;
	padding: 0 20px;
	text-align: right;
	font-size: 2.6rem;
}
.pageNewsDetail .more a {
	color: #e60039;
}

.pageNewsDetail .modRecommendLink {
	margin-top: 80px;
}

.modSectionWord p {
	margin: 0 0 1em;
}

.modSectionWord table {
	width: 100%;
	border: 1px solid #c9c9c9;
}
@media only screen and (max-width: 640px) {
	.modSectionWord table {
		display: block;
		border: 0;
	}
}

@media only screen and (max-width: 640px) {
	.modSectionWord tbody {
		display: block;
		width: 100%;
	}
}

@media only screen and (max-width: 640px) {
	.modSectionWord tr {
		display: block;
		width: 100%;
	}
}

.modSectionWord th {
	width: 12em;
	padding: 5px;
	border: 1px solid #c9c9c9;
	border-right: 0;
	background-color: #f6f6f6;
	vertical-align: middle;
}
@media only screen and (max-width: 640px) {
	.modSectionWord th {
		display: block;
		width: 100%;
		border-right: 1px solid #c9c9c9;
	}
}

.modSectionWord td {
	padding: 5px 10px 5px 30px;
}
@media only screen and (max-width: 640px) {
	.modSectionWord td {
		display: block;
		width: 100%;
		padding: 10px 20px;
		border: 1px solid #c9c9c9;
		border-top: 0;
	}
}
.modSectionWord td li {
	display: inline-block;
	margin-right: 1em;
}
@media only screen and (max-width: 640px) {
	.modSectionWord td li {
		display: block;
		margin-right: 0;
	}
}

.modSectionWord:last-child {
	margin-bottom: 6em;
}

/* Movie */
/* ------------------------------ */
.modMovieBanner a {
	display: block;
	transition: opacity .2s ease-in-out;
}
.modMovieBanner a:hover {
	text-decoration: none;
	opacity: .7;
}

.modMovieBanner picture {
	max-width: 100%;
}
.modMovieBanner picture img {
	width: 100%;
}

@media print, screen and (min-width: 641px) {
	.modMovieList {
		display: flex;
		margin: 0 0 0 -32px;

		flex-wrap: wrap;
	}
}

.modMovieList li {
	margin: 8.6rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modMovieList li {
		width: calc(50% - 32px);
		margin: 50px 0 0 32px;
	}
	.modMovieList li:first-child {
		width: 100%;
		margin: 50px 0 0 32px;
	}
}

.modMovieWrapper {
	width: 100%;
	aspect-ratio: 16 / 9;
}
.ie .modMovieWrapper {
	position: relative;
	height: 0;
	padding-top: 56.25%;
}
.modMovieWrapper iframe {
	width: 100%;
	height: 100%;
}
.ie .modMovieWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.modMovieText {
	margin: 4.1rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modMovieText {
		margin: 24px 0 0;
	}
}
.modMovieText p {
	margin: 5.2rem 0 0;
}
@media print, screen and (min-width: 641px) {
	.modMovieText p {
		margin: 30px 0 0;
	}
}