@charset "utf-8";

/*===============================================
●画面の横幅が769px以上
===============================================*/
@media screen and (min-width: 769px) {
#pc------------------------------------------- {
}
main .snav ul {
	width: 34.84vw;        /* 476px */
}
main .snav ul li a {
	width: 16.694vw;       /* 228px */
}
main .snav ul li:nth-of-type(1) a {
	background-color: #005DA5;
	color: #fff;
	transition: 0.3s;
}


/* ---------------- broach ---------------- */

#broach {
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#broach .flex2 {
	display: flex;
	justify-content: space-between;
	width: 74.927vw;       /* 1024px */
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	margin-bottom: 5.857vw; /* 80px */
}
#broach .flex2 div {
	width: 32.947vw;       /* 450px */
}
#broach .flex2 div h2 {
	font-size: 1.757vw;    /* 24px */
	line-height: 1.4em;
	margin-bottom: 1.465vw; /* 20px */
}
#broach .flex2 div h2+p {
	line-height: 2em;
}
#broach .flex2 figure {
	width: 35.139vw;       /* 480px */
}
#broach h3 {
	font-size: 1.757vw;    /* 24px */
	color: #0D57A7;
	width: 75.48vw;        /* 1030px */
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#broach h3+.box {
	width: 64.711vw;       /* 884px */
	margin-left: auto;
	margin-right: auto;
	background-image: url("../images/pc/products_broach/fig.png");
	background-size: cover;
	height: 43.196vw;      /* 590px */
	position: relative;
}
#broach h3+.box ol {
	height: 43.196vw;      /* 590px */
}
#broach h3+.box ol li {
	width: 4.393vw;        /* 60px */
	height: 4.393vw;       /* 60px */
	text-align: center;
	line-height: 4.831vw;  /* 66px */
	position: absolute;
}
#broach h3+.box ol li:nth-of-type(1) {
	top: 15.664vw;         /* 214px */
	left: 0;
}
#broach h3+.box ol li:nth-of-type(2) {
	top: 6.955vw;          /* 95px */
	left: 10.617vw;        /* 145px */
}
#broach h3+.box ol li:nth-of-type(3) {
	top: 2.196vw;          /* 30px */
	left: 24.515vw;        /* 335px */
}
#broach h3+.box ol li:nth-of-type(4) {
	bottom: 5.126vw;       /* 70px */
	right: 13.176vw;       /* 180px */
}
#broach h3+.box ol li:nth-of-type(5) {
	bottom: 13.176vw;      /* 180px */
	right: 0;
}
#broach h3+.box ol li a {
	display: block;
	background-color: #0D57A7;
	width: 100%;
	height: 100%;
	color: #fff;
	text-decoration: none;
	font-size: 2.929vw;    /* 40px */
	font-weight: normal;
	border-radius: 100px;
	font-family: "Josefin Sans", sans-serif;
	border: 0.073vw solid #0D57A7; /* 1px */
	transition: 0.3s;
}
#broach h3+.box ol li a:hover {
	background-color: #fff;
	color: #0D57A7;
	border: 0.073vw solid #0D57A7; /* 1px */
	transition: 0.3s;
	box-shadow: 0.22vw 0.22vw 0.22vw rgba(13,87,167,0.75); /* 3px */
}
#broach h4 {
	font-size: 1.757vw;    /* 24px */
	color: rgba(13,87,167,1.00);
	width: 75.48vw;        /* 1030px */
	margin-left: auto;
	margin-right: auto;
}
#broach h4 span.number {
	width: 3.514vw;        /* 48px */
	height: 3.514vw;       /* 48px */
	display: inline-block;
	text-align: center;
	line-height: 3.807vw;  /* 52px */
	color: #fff;
	background-color: #0D57A7;
	border-radius: 100px;
	font-family: "Josefin Sans", sans-serif;
	margin-right: 0.732vw; /* 10px */
}
/*#broach h4.num01.on span {
	background-color: #FF952A;
}
#broach h4.num02.on span {
	background-color: #FF952A;
}
#broach h4.num03.on span {
	background-color: #FF952A;
}
#broach h4.num04.on span {
	background-color: #FF952A;
}
#broach h4.num05.on span {
	background-color: #FF952A;
}*/
#broach .flex {
	display: flex;
	justify-content: space-between;
	margin-top: 1.465vw;   /* 20px */
	margin-bottom: 9.518vw; /* 130px */
	width: 75.48vw;        /* 1030px */
	margin-left: auto;
	margin-right: auto;
}
#broach .flex div.box2 {
	width: 31.985vw;       /* 437px */
	border: 0.073vw solid #0D57A7; /* 1px */
	padding-left: 2.196vw; /* 30px */
	padding-right: 2.196vw; /* 30px */
	padding-top: 1.465vw;  /* 20px */
	padding-bottom: 1.830vw; /* 25px */
	position: relative;
	background-color: #fff;
}
#broach .flex div.box2.num01.on {
	box-shadow: 0.366vw 0.366vw 0.366vw rgba(13,87,167,0.50); /* 5px */
}
#broach .flex div.box2.num02.on {
	box-shadow: 0.366vw 0.366vw 0.366vw rgba(13,87,167,0.50); /* 5px */
}
#broach .flex div.box2.num03.on {
	box-shadow: 0.366vw 0.366vw 0.366vw rgba(13,87,167,0.50); /* 5px */
}
#broach .flex div.box2.num04.on {
	box-shadow: 0.366vw 0.366vw 0.366vw rgba(13,87,167,0.50); /* 5px */
}
#broach .flex div.box2.num05.on {
	box-shadow: 0.366vw 0.366vw 0.366vw rgba(13,87,167,0.50); /* 5px */
}
#broach .flex div h4 {
	position: absolute;
	left: 0;
	top: -4.758vw;         /* -65px */
}
#broach .flex div h5 {
	font-size: 1.318vw;    /* 18px */
	margin-top: 1.098vw;   /* 15px */
	margin-bottom: 1.098vw; /* 15px */
}
#broach .flex div h5+p {
	line-height: 2em;
	min-height: 3.879vw;   /* 53px */
}
#broach .flex div h5+p+p {
	border-top: 0.073vw solid #000; /* 1px */
	margin-top: 1.098vw;   /* 15px */
	padding-top: 1.098vw;  /* 15px */
}
#broach .inner {
	background-color: #CFDEEC;
	padding-top: 5.857vw;  /* 80px */
	padding-bottom: 7.322vw; /* 100px */
	margin-bottom: -8vw; /* -95px */
}
#broach .inner .flex {
	margin-bottom: 0;
}
#broach .inner h3 {
	margin-bottom: 2.196vw; /* 30px */
}

}




/*===============================================
●画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:768px){
	
/*===============================================
●sp-tablet
===============================================*/
#sptablet------------------------------------------- {
}
main .snav ul li:nth-of-type(1) a {
	background-color: #005DA5;
	color: #fff;
	transition: 0.3s;
}




#broach {
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#broach .flex2 {
	margin-left: 5vw;
	margin-right: 5vw;
	text-align: left;
	margin-bottom: 15vw;
}
#broach .flex2 div {
}
#broach .flex2 div h2 {
	font-size: 5.5vw;
	line-height: 1.4em;
	margin-bottom: 5vw;
}
#broach .flex2 div h2+p {
	line-height: 2em;
}
#broach .flex2 figure {
	margin-top: 5vw;
}
#broach h3 {
	font-size: 5vw;
	color: #0D57A7;
	margin-left: 5vw;
	margin-right: auto;
	text-align: left;
}
#broach h3+.box {
	margin-left: auto;
	margin-right: auto;
	background-image: url("../images/pc/products_broach/fig.png");
	background-size: contain;
	background-repeat: no-repeat;
	height: 65vw;
	position: relative;
	margin-bottom: 10vw;
	margin-top: 5vw;
}
#broach h3+.box ol {
	height: 65vw;
}
#broach h3+.box ol li {
	width: 10vw;
	height: 10vw;
	text-align: center;
	line-height: 11.5vw;
	position: absolute;
}
#broach h3+.box ol li:nth-of-type(1) {
	top: 22vw;
	left: 1vw;
}
#broach h3+.box ol li:nth-of-type(2) {
	top: 8.5vw;
	left: 15vw;
}
#broach h3+.box ol li:nth-of-type(3) {
	top: 3vw;
	left: 34.5vw;
}
#broach h3+.box ol li:nth-of-type(4) {
	bottom: 8.5vw;
	right: 20vw;
}
#broach h3+.box ol li:nth-of-type(5) {
	bottom: 20vw;
	right: 2vw;
}
#broach h3+.box ol li a {
	display: block;
	background-color: #0D57A7;
	width: 100%;
	height: 100%;
	color: #fff;
	text-decoration: none;
	font-size: 5vw;
	font-weight: normal;
	border-radius: 100px;
	font-family: "Josefin Sans", sans-serif;
	border: 1px solid #0D57A7;
	transition: 0.3s;
}
#broach h3+.box ol li a:hover {
	background-color: #fff;
	color: #0D57A7;
	border: 1px solid #0D57A7;
	transition: 0.3s;
	box-shadow: 3px 3px 3px rgba(13,87,167,0.75);
}
#broach h4 {
	font-size: 5vw;
	color: rgba(13,87,167,1.00);
	margin-left: 5vw;
	margin-right: 5vw;
}
#broach h4 span.number {
	width: 10vw;
	height: 10vw;
	display: inline-block;
	text-align: center;
	line-height: 11vw;
	color: #fff;
	background-color: #0D57A7;
	border-radius: 100px;
	font-family: "Josefin Sans", sans-serif;
	margin-right: 2vw;
}
#broach h4 span.number+span {
	width: 80vw;
}
/*#broach h4.num01.on span {
	background-color: #FF952A;
}
#broach h4.num02.on span {
	background-color: #FF952A;
}
#broach h4.num03.on span {
	background-color: #FF952A;
}
#broach h4.num04.on span {
	background-color: #FF952A;
}
#broach h4.num05.on span {
	background-color: #FF952A;
}*/
#broach .flex {
	margin-top: 3vw;
	margin-left: 5vw;
	margin-right: 5vw;
}
#broach .flex div.box2 {
	border: 1px solid #0D57A7;
	padding-left: 5vw;
	padding-right: 5vw;
	padding-top: 4vw;
	padding-bottom: 4vw;
	position: relative;
	background-color: #fff;
	margin-bottom: 30vw;
}
#broach .flex div.box2.num01.on {
	box-shadow: 5px 5px 5px rgba(13,87,167,0.50);
}
#broach .flex div.box2.num02.on {
	box-shadow: 5px 5px 5px rgba(13,87,167,0.50);
}
#broach .flex div.box2.num03.on {
	box-shadow: 5px 5px 5px rgba(13,87,167,0.50);
}
#broach .flex div.box2.num04.on {
	box-shadow: 5px 5px 5px rgba(13,87,167,0.50);
}
#broach .flex div.box2.num05.on {
	box-shadow: 5px 5px 5px rgba(13,87,167,0.50);
}
#broach h4+.flex {
	margin-bottom: 30vw;
}
#broach h4+.flex div.box2 {
	margin-bottom: 8vw;
}
#broach .flex div h4 {
	position: absolute;
	left: -5vw;
	top: -13vw;
}
#broach .flex div h5 {
	font-size: 5vw;
	margin-top: 3vw;
	margin-bottom: 2vw;
}
#broach .flex div h5+p {
	line-height: 1.8em;
}
#broach .flex div h5+p+p {
	border-top: 1px solid #000;
	margin-top: 4vw;
	padding-top: 4vw;
}
#broach .inner {
	background-color: #CFDEEC;
	padding-top: 10vw;
	padding-bottom: 10vw;
	margin-bottom: -20vw;
}
#broach .inner .flex {
	margin-bottom: 0px;
}
#broach .inner .flex div.box2 {
	margin-bottom: 8vw;
}
#broach .inner h3 {
	margin-bottom: 5vw;
}
}



/*===============================================
●画面の横幅が400pxまで
===============================================*/
@media screen and (max-width:400px){
/*===============================================
●sp400
===============================================*/
#sp400------------------------------------------- {
}
}



/*===============================================
●画面の横幅が320pxまで
===============================================*/
@media screen and (max-width:320px){
/*===============================================
●sp320
===============================================*/
#sp320------------------------------------------- {
}
}



/*===============================================
●画面の横幅が481pxから768pxまで
===============================================*/
@media screen and (min-width:481px) and (max-width:768px) {
/*===============================================
●tablet
===============================================*/
#tab------------------------------------------- {
}
}