.highlight {
    background: linear-gradient(transparent 50%, #ffcce4 30%);
	background: #ff0000;
    line-height: 0.8em;
    /*font-size: 25px;*/
    font-weight: bold;
}

#floating_link {
	display: block;
	width: 100%;
	position: fixed;
	right: 16px;
	top: 16px;
	z-index: 9999;
	text-align: right;
	padding: 0 auto;
}
.DXd_logo2 {
	width: 55%;
  	height: auto;
}

#cloud {
	animation: cloud 45s linear infinite;
	background: url(../images/bk_cloud.png);
	background-position-x: 0%;
	background-position-y: 120%;
	background-repeat: repeat-x;
	background-size: 1000px auto;
	height: 680px;
  }

  
  #BackImg2 {
	animation: cloud 20s linear infinite;
	background: url(../images/bk_cloud2.png);
	background-position-x: 0%;
	background-position-y: 120%;
	background-repeat: repeat-x;
	background-size: 1000px auto;
	height: 680px;
  }
  /* 2. keyframeを使って、雲が流れるように。 */
  @keyframes cloud {
	from {
	  background-position-x: 0;
	}
	to {
	  background-position-x: -800px;
	}
  }

/* innerのマージン */
.container.box.style3 {
	padding: 10px 40px 10px 40px;
}
/* TOPICSのレイアウト */
.newsBox {
	font-size: small;
	color: #fff;
	padding: 5px 10px;
	margin-right: 10px;
}
dl{
	margin-bottom: 10px;
}
.color01 {
	background-color: #ba6159;
}
.color02 {
	background-color: #888;
}

.topics dl {
	border-bottom: 1px solid #ccc;
	margin-bottom: 10px;
	}
	
.topics dt {
	margin-right: 55px;
	}

.txt-hide{
	display: none;
	}
	
	button.more {
	width: 500px;
	margin: 70px auto;
	display: block;
	background-color: #666;
	color: #fff;
	padding:10px 15px;
	border: none;
	outline: 0;
	transition: .5s;
	-erbkit-transition: .5s;
	}
	 
	button.more::after {
	content: "もっと見る";
	transition: .2s;
	-erbkit-transition: .2s;
	}
	
	button.more.on-click::after{
	content: "閉じる";
	}
	

	@media screen and (min-width: 768px) {
	.topics dt {
	clear: left;
	float: left;
	width: 10%;
	}
	.topics dd {
	margin-left: 11%;
	}
}
@media screen and (max-width: 768px) {
	.newsBox {
		padding: 3px;
		margin-right: 10px;
	}
button.more {
	width: 100%;
}
	}
#topics.container.box.style3 {
		padding-bottom: 30px;
	}

/* service_listのレイアウト */

.service_list{
    display:flex;
}

.service_text{
	width: 550px;
    margin: 20px;
	text-align: left;
}

.service_pict img{
    width: 350px;
	margin: 20px 0px;
}

@media screen and (max-width: 600px) {
	.service_list {
	  display: block;
	}
	.service_text{
		width:  85%;
		margin: 20px;
		word-break: break-all;
	}
	.service_pict img{
		width: 100%;
		margin: 20px 0px;
		
	}
  }
/* DXdSchoolのレイアウト */
.dxds{
	background-image: url(../images/dxds_back.jpg);
	height: 100%;
	text-align: center;
	padding-top: 30px;
	padding-bottom: 30px;
}
.btn01{
	display: inline-block;
	background: #cd291b; /* 背景色 */
	color: #fff; /* 文字色 */
	padding: 0px 20px; /* 上下の余白、左右の余白 */
	text-decoration: none; /* デフォルトで入るリンクの下線を消す */
	border-radius: 20px; /* 角を丸くする */
	font-size: 0.7rem;
}

/* フォント */
#banner h2{
	margin-top:  20px;
	font-family: '游ゴシック', sans-serif;
	font-weight: 700 ;
	font-size: xx-large !important;
}
@media screen and (max-width: 600px) {
	#banner h2{
		font-size: x-large !important;
	}
}


h3{
	color: #cd291b;
	margin-top: 20px;
	font-family: '游ゴシック bold', sans-serif;
	font-weight: 700;
	font-size: x-large;
}
h4{
	margin-top: 20px;
	font-family: '游ゴシック bold', sans-serif;
	font-weight: 700;
	font-size: x-large;
}
h5{
	margin-top: 20px;
	font-family: '游ゴシック bold', sans-serif;
	font-weight: 700;
	font-size: large;
	text-transform:none;
}

  .MyClass01{
	margin-top: 20px;
	font-size: x-large;
	font-family: '游ゴシック', sans-serif;
	text-transform: none ;
	border-bottom: 1px solid #553922;
	}

	.MyClass02 {
		position: relative;
		padding: 1.5rem 2rem 1.5rem 60px;
		font-size: x-large;
		 
	   }
	   
	.MyClass02 span {
		color: #cd291b;
		 font-family: 'DIN Condensed', sans-serif ;
		 font-size: 40px;
		 font-size: 4rem;
		 position: absolute;
		 left: 0;
		 margin-top: 8px;
	}
	.MyClass03{
		border-left: solid 5px #cd291b;
		padding-left: 20px;
		margin-bottom: 10px;
	}
	.MyClass04{
		border: solid 1px #cd291b;
		padding: 10px;
		margin: 30px;
		background-color: #fff;
	}
	.MyClass05{
		padding: 10px;
		margin: 30px;
		background-color: #fff;
	}

   @media screen and (max-width: 600px) {
		.MyClass02{
			font-size: medium ;
			padding: 1.5rem 2rem 1.5rem 60px;
			}
		.MyClass02 span {
			margin: 15px 0px;
				
		}
		
		.MyClass05{
			padding-bottom: 15px;
			margin: 10px;
		}
	}
		


/* 組織構成のレイアウト */
.member dl {
	border-bottom: 1px solid #ccc;
	margin-bottom: 10px;
	}
	
	.member dt {
	margin-right: 55px;
	}
	
	@media screen and (min-width: 768px) {
	.member dt {
	clear: left;
	float: left;
	width: 10%;
	}
	.member dd {
	margin-left: 11%;
	}
	}
#member.container.box.style {
		padding-bottom: 30px;
	}
/*お問い合わせのレイアウト */
.style4 {
	text-align: center;
}
.submit {
	padding: 5px 150px;
}
@media screen and (max-width: 768px) {
	.submit {
		padding: 12px;
	}
}

	/*ページ全体のレスポンシブ対応 */


	.br-sp {
		display: none;
		}
		
		@media screen and (max-width: 1080px) {		
		.br-sp {
			display:block;
		}
	}
		
	.br-pc {
		display:block;
		}
		
		@media screen and (max-width: 1080px) {		
		.br-pc {
			display: none;
		}
	}

	@media screen and (max-width: 600px) {
		.DXd_logo2{
			width: 75%;
    		height: auto;
			}
			ul.menu li:first-child {
				margin-top: 1em;
			}
		}
	
/* セミナーアーカイブBox */
.DXd_logo3 {
	width: 30%;
  	height: auto;
}
@media screen and (max-width: 840px){
.DXd_logo3 {
    width: 60%;
}
.btn01 {
    padding: 12px;
    border-radius: 24px;
}
}

#header_ds {
	display: block;
	margin-top: 10px;
	margin-bottom: 1em;
	padding-top: 30px;
	text-align: center;
	padding: 1em 0;
}
header img{
	width:60%;
	text-align: center;
}

.box_ds {
	position: relative;
	margin-top: 9em;
	margin-bottom: 0;
}
/*
	.box_ds:after {
		content: '';
		display: block;
		position: absolute;
		top: -9em;
		left: 50%;
		height: 9em;
		border-left: solid 1px #553922;
	}

	.box_ds:before {
		content: '';
		display: block;
		width: 90px;
		height: 66px;
		position: absolute;
		left: 50%;
		top: -4.5em;
		margin-left: -45px;
		margin-top: -33px;
		background: url("images/arrow.svg") no-repeat;
	}

	.box_ds :last-child {
		margin-bottom: 0;
	}
*/
	.box_ds.style1 {
		background: var(--main-color-01);
		padding: 3em;
	}

		.box_ds.style1 .image {
			display: block;
			position: absolute;
			top: 0;
			width: 50%;
			height: 100%;
			background: #152E33;
			overflow: hidden;
		}

			.box_ds.style1 .image img {
				position: absolute;
				top: 0;
				height: 100%;
				width: auto;
			}

		.box_ds.style1 .inner > :last-child {
			margin: 0;
		}

		.box_ds.style1.right .image {
			left: 0;
		}

			.box_ds.style1.right .image img {
				right: 0;
			}

		.box_ds.style1.right .inner {
			margin-left: 50%;
			padding-left: 3em;
		}

		.box_ds.style1.left .image {
			right: 0;
		}

			.box_ds.style1.left .image img {
				left: 0;
			}

		.box_ds.style1.left .inner {
			margin-right: 50%;
			padding-right: 3em;
		}

	.box_ds.style2 {
		text-align: center;
	}

		.box_ds.style2 header {
			display: inline-block;
			background: var(--main-color-01);
			padding: 2em 3em 2em 3em;
			margin: 0;
		}

			.box_ds.style2 header p {
				padding: 0;
			}

		.box_ds.style2 .inner {
			position: relative;
			padding: 40px 0 0px 0;
		}
/*
			.box_ds.style2 .inner:after {
				content: '';
				display: block;
				position: absolute;
				top: 0;
				left: 50%;
				height: 100%;
				border-left: solid 1px var(--main-color-01);
			}
*/
			.box_ds.style2 .inner .row {
				position: relative;
			}
/*
				.box_ds.style2 .inner .row:before {
					content: '';
					display: block;
					position: absolute;
					top: 50%;
					left: 20px;
					width: calc(100% - 40px);
					border-bottom: solid 1px var(--main-color-01);
				}
*/
			.box_ds.style2 .inner .image {
				position: relative;
				z-index: 1;
				padding: 20px;
			}

	.box_ds.style3 {
		background: #f2f2f2;
		padding: 0.8em;
		font-size: 0.8em;
		text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
	}

		.box_ds.style3 header {
			background: #E6E6E6;
			text-align: center;
		}

	
/* innerのマージン */
.container.box_ds.style3 {
	padding: 10px 40px 10px 40px;
}