@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@600&display=swap");

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;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
	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-collapse: collapse;
	border-spacing: 0;
}
img {
	vertical-align: bottom;
}
input[type="text"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-shadow: none;
	border: none;
}
button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-shadow: none;
	border: none;
	cursor: pointer;
	background: none;
	padding: 0;
}


/* -----------------------------------------------------------------------------*/

html {
	overflow-y: scroll;
	font-size: 62.5%;
}

body {
	font-size: 1.4em;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-weight: 500;
	line-height: 1;
	color: #000;
	background-color: #fff;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
}


a {
	color: #000;
	text-decoration: underline;
}
a:hover {
}

a img {
	transition: opacity 0.3s ease-in-out;
}
a:hover img {
	opacity: 0.7;
}
img.nofade {
	opacity: 1 !important;
}


#wrap {
	overflow: hidden;
}

/* SP
-------------------------------------*/
@media screen and (max-width: 768px) {
	#wrap {
		min-width: 0;
	}
}


#responseFlagTab {
	display: none !important;
}

/* PC
-------------------------------------*/
@media screen and (min-width: 769px) {
	#responseFlagPc {
		display: block !important;
	}
	#responseFlagSp {
		display: none !important;
	}
}

/* SP
-------------------------------------*/
@media screen and (max-width: 768px) {
	#responseFlagPc {
		display: none !important;
	}
	#responseFlagSp {
		display: block !important;
	}
}


/*===========================================================================
 #header
===========================================================================*/
#header {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 100;
}
#header a:hover,
#footer a:hover {
	opacity: 1;
}
#header .hdInr {
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	padding: 16px 50px;
	margin: 0 auto;
}
#header .hdInr .hdLogo {
	width: 178px;
}
#header .hdInr .hdLogo a {
	text-decoration: none;
	display: block;
}
#header .hdInr .hdLogo img {
	width: 100%;
	height: auto;
}
#header .hdInr .hdNavWrap .openLogo {
	display: none;
}
#header .hdInr .hdNavWrap .hdNavInr {
	display: flex;
	align-items: center;
	margin-right: -20px;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav {
	position: relative;
	padding: 0 2.5px;
	box-sizing: border-box;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav > a {
	display: block;
	font-family: "Poppins", sans-serif;
	color: #fff;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.05em;
	padding: 5px 18px;
	box-sizing: border-box;
	text-decoration: none;
	background-color: transparent;
	border-radius: 99px;
	transition: color 0.2s ease-in-out,background 0.2s ease-in-out;
}
#header .hdInr .hdNavWrap .hdNavInr.jp .hdNav > a {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover {
	color: #ca0821;
	background-color: #fff;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavBtn {
	position: relative;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavBtn::after {
	content: "";
	display: inline-block;
	background-color: #fff;
	mask: url(../../common/images/icn_arw_right_wt.svg) no-repeat center / contain;
	-webkit-mask: url(../../common/images/icn_arw_right_wt.svg) no-repeat center / contain;
	width: 13px;
	height: 8px;
	margin-left: 11px;
	transform: rotate(90deg);
	transition: transform 0.2s ease-in-out,background-color 0.2s ease-in-out;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi li:not(:first-child) {
	margin-top: 3px;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi a {
	display: block;
	position: relative;
	color: #000;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 1;
	padding: 5px 0 5px 17px;
	text-decoration: none;
	transition: color 0.2s ease-in-out;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi a .textSpace {
	letter-spacing: -0.06em;
}
#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi a:hover {
	color: #cd0600;
	text-decoration: underline;
}

#header.fixedHd {
	background: #fff;
	position: fixed;
	top: 0;
	left: 0;
}
#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav > a {
	color: #000;
}
#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavBtn::after {
	background-color: #c7001a;
}
#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover {
	color: #fff;
	background-color: #ca0821;
}



#header.js-fixed {
	background: #fff;
}
#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav > a {
	color: #000;
}
#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavBtn::after {
	background-color: #c7001a;
}
#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover {
	color: #fff;
	background: #c7001a;
}

/* Spinner */
.spinner {
	width: 36px;
	height: 36px;
	border: 5px solid #fff;
	border-bottom-color: transparent;
	border-radius: 50%;
	display: inline-block;
	box-sizing: border-box;
	animation: rotation 1s linear infinite;
}

@keyframes rotation {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}


/* PC
----------------------------------*/
@media screen and (max-width: 1015px) {
	#header .hdInr {
		padding: 16px 20px;
	}
}
@media screen and (max-width: 1080px) {
	#header .hdInr .hdLogo a {
		margin-left: 0;
	}
	#header .hdInr .hdNavWrap .hdNavInr {
		margin-right: 0;
	}
}

/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
	.spBtn {
		display: none;
	}

	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi {
		display: block !important;
		height: auto !important;
		position: absolute;
		top: 22px;
		left: 50%;
		padding-top: 12px;
		transform: translateX(-50%);
		transition: all 0.3s ease-in-out;
		transition-property: visibility, opacity;
		visibility: hidden;
		opacity: 0;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChiInr {
		min-width: 160px;
		box-sizing: border-box;
		padding: 15px 30px 14px;
		border-radius: 10px;
		border: 2px solid #CA0921;
		background-color: #fff;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi a::before {
		content: '▶︎';
		position: absolute;
		top: 5px;
		left: 0;
		font-weight: bold;
		font-size: 1rem;
		letter-spacing: 0.23em;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover > a {
		color: #ca0821;
		background-color: #fff;
	}
	#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover > a,
	#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover > a {
		color: #fff;
		background: #c7001a;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover .hdNavBtn::after {
		background-color: #c7001a;
		transform: rotate(270deg);
	}
	#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover .hdNavBtn::after,
	#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover .hdNavBtn::after {
		background: #fff;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav.js-flexWrap:hover .hdNavChi {
		visibility: visible;
		opacity: 1;
	}
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
	#header {
	}
	#header .hdInr {
		max-width: 100%;
		padding: calc(17 / 428 * 100vw) calc(20 / 428 * 100vw);
	}
	#header .hdInr .hdLogo {
		width: calc(170 / 428 * 100vw);
	}
	#header .hdInr .hdLogo a {
		margin-left: 0;
	}
	#header .hdInr .hdNavWrap {
		display: block;
		width: 100%;
		position: absolute;
		top: 0;
		left: 0;
		transform: translateX(-100%);
		transition: all 0.3s ease-out;
	}
	#header .hdInr .hdNavWrap .openLogo {
		display: block;
		width: calc(170 / 428 * 100vw);
		position: absolute;
		top: calc(22 / 428 * 100vw);
		left: calc(20 / 428 * 100vw);
		z-index: 2;
	}
	#header .hdInr .hdNavWrap .openLogo img {
		width: 100%;
		height: auto;
	}
	#header .hdInr .hdNavWrap .hdNavInr {
		display: block;
		margin-right: 0;
		box-sizing: border-box;
		padding: calc(122 / 428 * 100vw) calc(20 / 428 * 100vw) calc(146 / 428 * 100vw);
		background: #fff;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav {
		padding: 0;
		position: relative;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav::after {
		content: " ";
		width: calc(100% - (20 / 428 * 100vw));
		height: 1px;
		background: #ccc;
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav:last-of-type {
		margin-right: 0;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav:last-of-type::after {
		content: none;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav > a {
		color: #c7001a;
		font-size: calc(26 / 428 * 100vw);
		letter-spacing: 0;
		padding: calc(27 / 428 * 100vw) calc(20 / 428 * 100vw)  calc(20 / 428 * 100vw);
		border-radius: 0;
		transition: all 0.3s ease-out;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover {
		opacity: 1;
	}

	#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav > a,
	#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav > a {
		color: #c7001a;
	}
	#header.js-fixed .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover,
	#header.fixedHd .hdInr .hdNavWrap .hdNavInr .hdNav > a:hover {
		color: #c7001a;
		background-color: #fff;
	}

	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavBtn::after {
		background-color: #c7001a;
		position: absolute;
		top: 50%;
		right: calc(28 / 428 * 100vw);
		width: calc(24 / 428 * 100vw);
		height: calc(14 / 428 * 100vw);
		margin-left: 0;
		transform: translateY(calc(50% - 10 / 428 * 100vw)) rotate(90deg);
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav.js-open .hdNavBtn::after {
		transform: translateY(calc(50% - 12 / 428 * 100vw)) rotate(270deg);
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi {
		display: none;
		height: 0;
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChiInr {
		padding: 0 0 calc(23 / 428 * 100vw);
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi li:not(:first-child) {
		margin-top: calc(10 / 428 * 100vw);
	}
	#header .hdInr .hdNavWrap .hdNavInr .hdNav .hdNavChi a {
		font-size: calc(16 / 428 * 100vw);
		padding: calc(10 / 428 * 100vw) calc(20 / 428 * 100vw);
		text-align: left;
		transition: color 0.2s ease-in-out;
	}



	.spBtn {
		display: block;
		width: calc(50 / 428 * 100vw);
		height: calc(50 / 428 * 100vw);
		margin-right: calc((5 / 428 * 100vw) * -1);
		position: relative;
		z-index: 2;
	}
	.spBtn .btnBar {
		height: 100%;
		background: #fff;
		border-radius: 100%;
		position: relative;
		cursor: pointer;
	}
	.spBtn .btnBar::before,
	.spBtn .btnBar::after {
		content: " ";
	}
	.spBtn .btnBar .bar,
	.spBtn .btnBar::before,
	.spBtn .btnBar::after {
		width: calc(25 / 428 * 100vw);
		height: calc(2 / 428 * 100vw);
		background: #c7001a;
		border-radius: 40px;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%,-50%) rotate(0);
		transition: all 0.3s ease-out;
	}
	.spBtn .btnBar::before {
		margin-top: calc((7 / 428 * 100vw) * -1);
	}
	.spBtn .btnBar::after {
		margin-top: calc(7 / 428 * 100vw);
	}


	#header .hdInr.js-open .hdNavWrap {
		transform: translateX(0);
	}

	.js-open .spBtn .btnBar .bar,
	.js-open .spBtn .btnBar::before {
		margin-top: 0;
		transform: translate(-50%,-50%) rotate(45deg);
	}
	.js-open .spBtn .btnBar::after {
		margin-top: 0;
		transform: translate(-50%,-50%) rotate(-45deg);
	}

	.recruit .spBtn .btnBar {
		background: none;
	}
	.recruit .spBtn .btnBar .bar,
	.recruit .spBtn .btnBar::before,
	.recruit .spBtn .btnBar::after {
		background: #fff;
	}
	.recruit .js-fixed .spBtn .btnBar .bar,
	.recruit .js-fixed .spBtn .btnBar::before,
	.recruit .js-fixed .spBtn .btnBar::after,
	.recruit .js-open .spBtn .btnBar .bar,
	.recruit .js-open .spBtn .btnBar::before,
	.recruit .js-open .spBtn .btnBar::after {
		background: #c7001a;
	}
}



	/*===========================================================================
 #footer
===========================================================================*/
	#footer {
		padding: 40px 20px 20px;
		box-sizing: border-box;
	}
	#footer .ftInr {
		max-width: 1000px;
		padding-right: 50px;
		box-sizing: border-box;
		margin: 0 auto;
		background-color: #fff;
	}
	#footer .ftInr .ftCts {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
	}
	#footer .ftInr .ftCts .ftLogo {
		width: 236px;
	}
	#footer .ftInr .ftCts .ftLogo a {
		display: block;
		text-decoration: none;
	}
	#footer .ftInr .ftCts .ftLogo a img {
		width: 100%;
		height: auto;
	}
	#footer .ftInr .ftCts .ftInfo {
		display: flex;
		align-items: center;
		height: 64px;
	}
	#footer .ftInr .ftCts .ftInfo .infoWrap {
		color: #000;
		font-weight: 400;
		line-height: 1.5;
	}
	#footer .ftInr .ftCts .ftInfo .infoWrap .infoAddress {
	}
	#footer .ftInr .ftCts .ftInfo .infoOther {
		display: flex;
		flex-direction: column;
		justify-content: space-around;
		height: 100%;
		padding-left: 45px;
		margin-left: 40px;
		box-sizing: border-box;
		border-left: 1px solid #000;
	}
	#footer .ftInr .ftCts .ftInfo .infoOther .other {
	}
	#footer .ftInr .ftCts .ftInfo .infoOther .other a {
		box-sizing: border-box;
		padding: 10px 0;
		color: #000;
		font-weight: 400;
		line-height: 1;
		text-decoration: none;
	}
	#footer .ftInr .ftCts .ftInfo .infoOther .other a:hover {
		text-decoration: underline;
	}
	#footer .ftInr .copyright {
		margin-top: 65px;
		text-align: center;
		color: #454545;
		font-weight: 400;
		line-height: 1.5;
	}
	/* SP
----------------------------------*/
	@media screen and (max-width: 768px) {
		#footer {
			padding: calc(34 / 428 * 100vw) calc(20 / 428 * 100vw) calc(15 / 428 * 100vw);
		}
		#footer .ftInr {
			max-width: 100%;
			padding-right: 0;
		}
		#footer .ftInr .ftCts {
			display: block;
		}
		#footer .ftInr .ftCts .ftLogo {
			width: calc(255 / 428 * 100vw);
			margin: 0 auto;
		}
		#footer .ftInr .ftCts .ftLogo a {
		}
		#footer .ftInr .ftCts .ftLogo a img {
		}
		#footer .ftInr .ftCts .ftInfo {
			height: auto;
			margin-top: calc(40 / 428 * 100vw);
			display: block;
		}
		#footer .ftInr .ftCts .ftInfo .infoWrap {
			font-size: calc(14 / 428 * 100vw);
			line-height: 1.8;
		}
		#footer .ftInr .ftCts .ftInfo .infoWrap .infoAddress {
		}
		#footer .ftInr .ftCts .ftInfo .infoOther {
			display: block;
			margin-top: calc(20 / 428 * 100vw);
			padding-left: 0;
			margin-left: 0;
			border-left: 0;
		}
		#footer .ftInr .ftCts .ftInfo .infoOther .other {
		}
		#footer .ftInr .ftCts .ftInfo .infoOther .other + .other {
			margin-top: calc(5 / 428 * 100vw);
		}
		#footer .ftInr .ftCts .ftInfo .infoOther .other a {
			font-size: calc(14 / 428 * 100vw);
			line-height: 1.8;
		}
		#footer .ftInr .ftCts .ftInfo .infoOther .other a:hover {
			text-decoration: underline;
		}
		#footer .ftInr .copyright {
			margin-top: calc(30 / 428 * 100vw);
			font-size: calc(12 / 428 * 100vw);
		}
	}




	/*===========================================================================
 Common use utility （cm-）
===========================================================================*/
	/* PC
-------------------------------------*/
	@media screen and (min-width: 769px) {
		.cm-spOnly {
			display: none !important;
		}
	}

	/* SP
-------------------------------------*/
	@media screen and (max-width: 768px) {
		.cm-pcOnly {
			display: none !important;
		}
	}

    @media screen and (min-width: 950px){
		.cm-narrowOnly {
			display: none !important;
		}
	}


	.cm-ctsWid {
		max-width: 910px;
		margin: 0 auto;
	}
	.cm-ctsIdt {
		padding: 0 25px;
		box-sizing: border-box;
	}

	/* SP
----------------------------------*/
	@media screen and (max-width: 768px) {
		.cm-ctsWid {
			max-width: none;
		}
		.cm-ctsIdt {
			padding: 0 calc(20 / 428 * 100vw);
		}
	}


	.md-modal {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		/* z-index: 1000; */
		z-index: 0;
		opacity: 0;
		display: none;
		transition: height 0.3s ease-in-out;
	}
	.md-modal .modalOl {
		position: absolute;
		top: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
		background-color: rgba(0 0 0 / 80%);
		transition: height 0.3s ease-in-out;
	}
	.md-modal .modalInr {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		padding: 30px;
		box-sizing: border-box;
		position: relative;
	}
	.md-modal .modalInr .modalCts {
		z-index: 100;
		max-width: 1000px;
		width: 100%;
		height: 100%;
		max-height: 480px;
		background-color: #fff;
		border-radius: 10px;
		padding: 50px 75px;
		box-sizing: border-box;
		position: relative;
		overflow: hidden;
	}
	.md-modal .modalInr .modalCloseBtn {
		position: absolute;
		top: 15px;
		right: 15px;
		width: 50px;
		height: 50px;
		background: url(../../common/images/modal_close.png) no-repeat center center;
		background-size: 16px auto;
		cursor: pointer;
		z-index: 1000;
	}
	.md-modal .modalInr .modalCts  .modalCtsArea {
		height: 100%;
	}
	.md-modal .modalInr .modalCts  .modalCtsArea .memberCts {
		display: flex;
		align-items: center;
		height: 100%;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberImg {
		width: 286px;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberImg img {
		width: 100%;
		height: auto;
		object-fit: contain;
		border-radius:50%;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc {
		padding-left: 45px;
		box-sizing: border-box;
		flex: 1;
	}
	
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead {
		color: #c7001a;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead .cat {
		font-size: 1.8rem;
		line-height: 1.5;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead .name {
		font-size: 3rem;
		font-weight: bold;
		line-height: 2;
	}
	.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .desc {
		margin-top: 25px;
		font-size: 1.8rem;
		line-height: 1.8;
	}

	/* SP
----------------------------------*/
	@media screen and (max-width: 768px) {
		.md-modal {
		}
		.md-modal .modalOl {
			background-color: rgba(0 0 0 / 90%);
		}
		.md-modal .modalInr {
			padding: calc(20 / 375 * 100vw);
		}
		.md-modal .modalInr .modalCloseBtn {
			position: absolute;
			top: calc(10 / 375 * 100vw);
			right: calc(10 / 375 * 100vw);
			width: calc(30 / 375 * 100vw);
			height: calc(30 / 375 * 100vw);
		}
		.md-modal .modalInr .modalCts {
			max-width: 100%;
			height: auto;
			max-height: 100%;
			padding: calc(45 / 428 * 100vw) calc(16 / 428 * 100vw);
		}
		.md-modal .modalInr .modalCloseBtn {
			top: calc(20 / 428 * 100vw);
			right: calc(20 / 428 * 100vw);
			width: calc(30 / 428 * 100vw);
			height: calc(30 / 428 * 100vw);
			background-size: calc(30 / 428 * 100vw) auto;
		}

		.md-modal .modalInr .modalCts .modalCtsArea .memberCts {
			display: block;
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberImg {
			width: calc(200 / 428 * 100vw);
			margin: 0 calc(10 / 428 * 100vw) 0 0;
			float: left;
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc {
			margin-top: calc(20 / 428 * 100vw);
			padding-left: 0;
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead {
			padding-top: calc(56 / 428 * 100vw);
			color: #c7001a
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead .cat {
			font-size: calc(18 / 428 * 100vw);
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .descHead .name {
			font-size: calc(28 / 428 * 100vw);
			line-height: 1.7;
		}
		.md-modal .modalInr .modalCts .modalCtsArea .memberCts .memberDesc .desc {
			clear: left;
			margin-top: 0;
			padding-top: calc(25 / 428 * 100vw);
			font-size: calc(14 / 428 * 100vw);
		}
	}









	.secContact {
		background-color: #ca0821;
	}
	.secContact .secInr {
		padding: 55px 0 65px;
		box-sizing: border-box;
		color: #fff;
		text-align: center;
	}
	.secContact .secInr .secTtl {
		font-size: 6rem;
		font-weight: 600;
		line-height: 1.5;
		font-family: "Poppins", sans-serif;
		letter-spacing: 0.05em;
	}
	.secContact .secInr .secCts {
		margin-top: 50px;
	}
	.secContact .secInr .secCts .btnBlock {
	}
	.secContact .secInr .secCts .btnBlock + .btnBlock {
		margin-top: 70px;
	}
	.secContact .secInr .secCts .btnBlock .blockTtl {
		font-size: 2rem;
		font-weight: bold;
		line-height: 1.5;
		letter-spacing: 0.05em;
	}
	.secContact .secInr .secCts .btnBlock .blockCts {
		margin-top: 30px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .btn {
		padding: 0 25px;
		box-sizing: border-box;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .btn a {
		min-width: 300px;
		color: #c7001a;
		font-size: 1.8rem;
		font-weight: bold;
		line-height: 1;
		padding: 20px 10px;
		box-sizing: border-box;
		background-color: #fff;
		border-radius: 99px;
		display: block;
		text-decoration: none;
		transition: all 0.3s ease-in-out;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .btn a:hover {
		opacity: 0.8;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .btn a .icn {
		padding-left: 40px;
		box-sizing: border-box;
		position: relative;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .btn a .icn::before {
		content: " ";
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 100% auto;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
	}
	.secContact .secInr .secCts .btnBlock .blockCts .icn-tw a .icn,
	.secContact .secInr .secCts .btnBlock .blockCts .icn-note a .icn {
		padding-left: 30px;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .icn-mail a .icn::before {
		background-image: url(/common/images/icn_mail.svg);
		width: 29px;
		height: 21px;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .icn-tw a .icn::before {
		background-image: url(/common/images/icn_x.svg);
		width: 40px;
		height: 25px;
		margin-left: -5px;
	}
	.secContact .secInr .secCts .btnBlock .blockCts .icn-note a .icn::before {
		background-image: url(/common/images/icn_note.svg);
		width: 20px;
		height: 23px;
	}

	/* SP
----------------------------------*/
	@media screen and (max-width: 768px) {
		.secContact {
		}
		.secContact .secInr {
			padding: calc(40 / 428 * 100vw) 0 calc(50 / 428 * 100vw);
		}
		.secContact .secInr .secTtl {
			font-size: calc(38 / 428 * 100vw);
		}
		.secContact .secInr .secCts {
			margin-top: calc(35 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock {
		}
		.secContact .secInr .secCts .btnBlock + .btnBlock {
			margin-top: calc(40 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockTtl {
			font-size: calc(16 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts {
			margin-top: calc(15 / 428 * 100vw);
			display: block;
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn {
			padding: 0;
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn + .btn {
			margin-top: calc(25 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn a {
			min-width: 0;
			margin: 0 auto;
			width: calc(270 / 428 * 100vw);
			font-size: calc(15 / 428 * 100vw);
			padding: calc(15 / 428 * 100vw) calc(5 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn a:hover {
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn a .icn {
			padding-left: calc(35 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts .btn a .icn::before {
		}
		.secContact .secInr .secCts .btnBlock .blockCts .icn-tw a .icn,
		.secContact .secInr .secCts .btnBlock .blockCts .icn-note a .icn {
			padding-left: calc(30  / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts .icn-mail a .icn::before {
			width: calc(28 / 428 * 100vw);
			height: calc(21 / 428 * 100vw);
		}
		.secContact .secInr .secCts .btnBlock .blockCts .icn-tw a .icn::before {
			width: calc(40 / 428 * 100vw);
			height: calc(21 / 428 * 100vw);
			margin-left: -5px;
		}
		.secContact .secInr .secCts .btnBlock .blockCts .icn-note a .icn::before {
			width: calc(20 / 428 * 100vw);
			height: calc(23 / 428 * 100vw);
		}
	}
}
