@charset "utf-8";

#mainArea .mainImgBox .textBox .left p.text {
	margin: 4px auto 0;
}


.contentsBox {
	margin: 100px auto 0;
}
.contentsBox .ques {
	width: 880px;
	margin: 30px auto 0;
	font-size: 20px;
	font-weight: bold;
	text-align: left;
	line-height: 1.7;
	position: relative;
	/*text-indent: 56px;*/
}
/*.contentsBox .ques::before {
	content: '';
	position: absolute;
	top: 15px;
	left: 0;
	width: 54px;
	height: 1px;
	background: #151515;
}*/


.contentsBox .ans {
	width: 880px;
	margin: 25px auto 50px;
	font-size: 20px;
	font-weight: 500;
	text-align: left;
	line-height: 1.9;
}

.contentsBox .ans + .ans {
  margin-top: 40px;
}

.contentsBox .ans_note {
	font-size: 17px;
	line-height: 1.5;
	color: #858585;
}

.contentsBox .ans span {
	color: #858585;
}
.contentsBox .imgBox {
	width: 880px;
	margin: 30px auto 0;
	position: relative;
}

.contentsBox .imgBox2 {
	width: 440px;
	margin: 30px 10px 30px 30px;
	position: relative;
	float: left;
}


.contentsBox .imgBox p.cap,
.contentsBox .imgBox2 p.cap {
	font-size: 15px;
	text-align: left;
	line-height: 1.5;
	margin: 0px 0 5px 0;
	font-weight: normal;
	color: #858585;
}
#snsComments.contentsBox .imgBox {
	padding: 0 0 29px 0;
}
.contentsBox .choosePoint {
	width: 880px;
	margin: 25px auto 0;
	text-align: left;
}

.contentsBox .choosePoint .boxInner{
	padding: 30px 30px;
	border: 1px solid #858585;
	background: #fff;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.9;
}

.contentsBox .choosePoint span {
font-size: 15px;
	text-align: left;
	line-height: 1.5;
	font-weight: normal;
}

.contentsBox .choosePoint p {
font-size: 20px;
	font-weight: bold;
	text-align: left;
	line-height: 1.7;
	margin: 0 0 0 0;
	display: block;
}

.contentsBox p {
font-size: 20px;
	font-weight: bold;
	text-align: left;
	line-height: 1.7;
	margin: 40px 0 10px 0;
}

.contentsBox .textLink img,
#mainArea .point{
	position: relative;
	top:7px;
}

#mainArea .contentsBox .ans .point{
	top:11px;
}

#mainArea .contentsBox .ans_note .point{
	top:5px;
}


.contentsBox .textLink img,
#mainArea .point{
	position: relative;
	top:7px;
}

.contentsBox .point2{
	position: relative;
	top:3px;
}

.contentsBox .textLink{
	margin: 20px 0;
}


.contentsBox .note {
	width: 880px;
	margin: 25px auto 0;
	font-size: 15px;
	text-align: left;
	line-height: 1.5;
}


.contentsBox a:hover{
	color:#FF3300 !important;
	text-decoration:underline;
}

.contentsBox h4 {
width: 880px;
	margin: 50px auto 10px;
	font-size: 22px;
	font-weight: bold;
	text-align: left;
	line-height: 1.7;
	position: relative;
	display: block;
    font-feature-settings: "palt";
    -webkit-font-feature-settings: "palt";
}

.contentsBox .inBox {
	width: 630px;
	display: inline-block;
	vertical-align: top;
	-webkit-transition:opacity 0.3s;
	-moz-transition:opacity 0.3s;
	-ms-transition:opacity 0.3s;
	-o-transition:opacity 0.3s;
	transition:opacity 0.3s;
	margin: 35px 0 0;
}
.contentsBox .inBox + .inBox {
	margin: 35px 0 0 40px;
}
/*
.contentsBox .inBox:hover {
	opacity: 0.5;
}
*/
.contentsBox .inBox a {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none;
}
.contentsBox .inBox h5.title {
	height: 40px;
	line-height: 40px;
	text-align: center;
    background: #000;
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	padding: 0 0 0 20px;
}
.ie .contentsBox .inBox h5.title {
	line-height: 44px;
}
.contentsBox .inBox .imgArea {
	position: relative;
	margin: 0 auto 0;
	padding: 25px 0 43px 0;
	background: #fff;
}
.contentsBox .inBox .imgArea a {
	display: block;
	width: 100%;
	height: 100%;
	transition: opacity 0.3s linear;
}
.contentsBox .inBox .imgArea a:hover {
	opacity: 0.7;
}
.contentsBox .inBox .imgArea .link {
	position: absolute;
	bottom: 13px;
	right: 13px;
	font-size: 15px;
	font-weight: 500;
}
.contentsBox .inBox .imgArea a:hover .link {
	text-decoration: underline;
}
.contentsBox .inBox .imgArea a > div {
	/*display: inline-block;*/
	vertical-align: top;
}
.contentsBox .inBox .imgArea div.text {
	margin: 10px 0 0 0;
	text-align: center;
    font-size: 17px;
}

.contentsBox .inBox .imgArea * {
    color: #151515;
}
.contentsBox .inBox .imgArea div.text ul.list li {
	font-size: 14px;
	font-weight: 500;
	line-height: 1.1;
	margin: 0 0 5px;
}
.contentsBox .inBox .imgArea div.text ul.list span.mini {
	font-size: 11px;
}
.contentsBox .inBox p.note {
	margin: 5px auto 0;
	text-align: right;
	font-size: 15px;
	letter-spacing: -0.01em;
}

.movieBox {
	margin: 80px 0 0 0;
}
.movieBox .sub {
	width: 880px;
	margin: 50px auto 0;
	font-size: 20px;
	font-weight: bold;
	text-align: left;
	line-height: 1.7;
	position: relative;
}

.movieBox .youtubeBox {
	width: 880px;
	margin: 30px auto 0;
}

.movieBox .youtubeBox .youtubeContents {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.movieBox .youtubeBox .youtubeContents iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.movieBox p {
  width: 880px;
  text-align: left;
  margin: 0 auto;
  font-size: 90%;
  font-weight: normal;
}

.contentsBox .ques ol,
.contentsBox .ans ul{
  margin: 30px 0 30px 60px;
}

.contentsBox .ans ul li{
  list-style-type: disc;
}

.contentsBox .ques ol,
.contentsBox .ans ul{
  margin: 30px 0 30px 60px;
}

.contentsBox .ques ol li,
.contentsBox .ans ul li{
  line-height: 1.7;
}

.under #photo_contents .mainImgBox .textBox .right p a {
  color: #000099;
}
.under #photo_contents .mainImgBox .textBox .right p a:visited {
  color: #005AB4;
}
.contentsBox .voices {
  width: 880px;
  margin: 30px auto 0;
  font-size: 20px;
  text-align: left;
  line-height: 1.7;
  position: relative;
}
.contentsBox .voices dt {
  font-weight: bold;
  margin-bottom: 20px;
}
.contentsBox .voices dd {
  clear: both;
  margin-bottom: 40px;
 }
.contentsBox .voices dd img {
  display: block;
  float: right;
  margin: 0 0 20px 20px;
 }
.contentsBox .imgBox-floatL {
width: 350px;
margin: 30px 40px 30px 0;
margin-left: 40px;
float: left;
}
.contentsBox .imgBox-floatR {
width: 350px;
margin: 30px 40px 30px 0;
margin-left: 40px;
float: right;
}
.contentsBox .imgBox2 p {
font-size: 17px;
line-height: 1.5;
color: #858585;
font-weight: normal;
margin: 25px 0 0;
}

.contentsInner .box p.text {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: -0.07em;
    text-align: left;
}




/** talk **/
.talkWrap {
margin: 60px 0;
}

.talkRight,
.talkLeft {
margin-bottom: 20px;
}

/* 回り込み解除 */
.talkRight:after,.talkRight:before,
.talkLeft:after,.talkLeft:before{
clear: both;
content: "";
display: block;
}

/* 左画像 */
.talkLeft img {
margin-left: 4px;
margin-top: -10px;
float: left;
width: 110px;
height: 140px; 
object-fit: cover; 
object-position: 0 0;
font-family: 'object-fit: cover; object-position: top left;';
}

/* 左テキスト */
.talkLeft p {
position: relative;
margin: 0 0 0 120px;
padding: 10px 20px;
border: 3px solid #c3d600;
background-color: #fff;
border-radius: 8px;
font-weight: normal;
font-size: 18px;
}

.talkLeft p b,
.talkRight p b {
font-size: 22px;
}

/* 左三角形 */
.talkLeft p:before {
position: absolute;
content: '';
border: 10px solid transparent;
border-right: 10px solid #c3d600;
top: 15px;
left: -20px;
}

.talkLeft p:after {
position: absolute;
content: '';
border: 10px solid transparent;
border-right: 10px solid #fff;
top: 15px;
left: -16px;
}

/* 右画像 */
.talkRight img {
margin-right: 4px;
margin-top: -10px;
float: right;
width: 110px;
height: 140px; 
object-fit: cover; 
object-position: 0 0;
font-family: 'object-fit: cover; object-position: top left;';
}

/* 右テキスト */
.talkRight p {
position: relative;
margin: 0 120px 0 0;
padding: 10px 20px;
border: 3px solid #fce033;
background-color: #fff;
border-radius: 8px;
font-weight: normal;
font-size: 18px;
}

/* 右三角形 */
.talkRight p:before {
position: absolute;
content: '';
border: 10px solid transparent;
border-left: 10px solid #fce033;
top: 15px;
right: -20px;
}

.talkRight p:after {
position: absolute;
content: '';
border: 10px solid transparent;
border-left: 10px solid #fff;
top: 15px;
right: -16px;
}


/****/
.ribbon {
  display: inline-block;
  position: relative;
  height: 60px;
  text-align: center;
  box-sizing: border-box;
  margin-bottom: 80px;
}

.ribbon:before {/*左側のリボン端*/
  content: '';
  position: absolute;
  width: 4px;
  bottom: -10px;
  left: -45px;
  z-index: 0;
  border: 28px solid #2b87ec;
  border-left-color: transparent;/*山形に切り抜き*/
}

.ribbon:after {/*右側のリボン端*/
  content: '';
  position: absolute;
  width: 4px;
  bottom: -10px;
  right: -45px;
  z-index: 0;
  border: 28px solid #2b87ec;
  border-right-color: transparent;/*山形に切り抜き*/
}

.ribbon h3 {
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 0 20px;
  line-height: 60px;
  font-size: 24px;
  color: #FFF;
  background: #096bec;/*真ん中の背景色*/
  width: 800px;
  z-index: 1;
}

.ribbon h3:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-right: solid 15px #165091;/*左の折り返し部分*/
}

.ribbon h3:after {
  position: absolute;
  content: '';
  top: 100%;
  right: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-left: solid 15px #165091;/*右の折り返し部分*/
}


/****/

.titleArea .balloon {
  position: relative;
  display: inline-block;
  margin: 0 10px 0 0;
  padding: 4px 15px;
  font-size: 16px;
  background: #fff;
  border-radius: 6px;
  color: #0081dc;
  font-weight: bold;  
}

.titleArea .balloon:before {
  content: "";
  position: absolute;
  top: 70%;
  left: 100%;
  margin-top: -15px;
  border: 8px solid transparent;
  border-left: 8px solid #fff;
}


.mainImg {
padding-top:20px
}

.profileWrap {
display: flex;
width: 880px;
margin: 0 auto;
justify-content: space-between;
}

.profileWrap li {
width: 425px;
}

.profileWrap li:first-child .txt-wrap {
float: right;
}

.profileWrap li:nth-child(2) .txt-wrap {
float: left;
}

.profileWrap li:first-child img {
float: left;
}

.profileWrap li:nth-child(2) img {
float: right;
}

.profileWrap li .txt-wrap {
width: 285px;
}

.profileWrap li .name {
font-size: 20px;
margin: 0 0 10px;
}

.profileWrap li .name span {
font-size: 16px;
}

.profileWrap li .txt {
font-weight: normal;
font-size: 16px;
margin: 0;
}

.profileWrap li img {
width: 120px;
height: 260px;
object-fit: cover;
object-position: 0 0;
font-family: 'object-fit: cover; object-position: top left;';
flex-shrink: 0
}

.column01 {
border: 1px solid #999;
background: #fff;
padding: 20px;
margin: 40px 0 0 0;
}

.column01 h3 {
  position: relative;
  display: inline-block;
  padding: 0 65px;
  text-align: center;
  font-size: 20px;
  margin-bottom: 20px;
}

.column01 h3:before,
.column01 h3:after {
  position: absolute;
  top: calc(50% - 3px);
  width: 50px;
  height: 6px;
  content: '';
  border-top: solid 2px #000;
  border-bottom: solid 2px #000;
}

.column01 h3:before {
  left: 0;
}

.column01 h3:after {
  right: 0;
}

.column01 div{
overflow: hidden;
}

.column01 p {
margin: 0;
font-weight: normal;
font-size: 17px;
}

.column01 img {
float: left;
width: 250px;
margin: 0 20px 0 0;
}

.column02 {
border-top: 4px double #999;
padding: 40px;
margin: 40px 0 0 0;
display: flex;
align-items: flex-start;
}

.column02 h4 {
width: inherit;
font-size: 20px;
font-weight: normal;
margin: 0 0 10px;
display: block;
}

.column02 h4 span {
font-size: 17px;
}
.column02 p {
margin: 0;
font-weight: normal;
font-size: 17px;
line-height: 1.5;
}

.column02 img {
width: 250px;
margin: 0 20px 0 0;
flex-shrink: 0;
}

.contentsBox p.caption02 {
color: #858585;
font-size: 17px;
line-height: 1.5;
margin: 16px auto 0;
font-weight: normal;
}

.col02 {
display: flex;
margin-top: 40px;
align-items: center;
flex-wrap: wrap;
}

.col02 dt {
flex-basis: 550px;
margin: 0 20px 20px 0;
}


.col02 dd {
width: 310px;
font-size: 17px;
text-align: left;
margin-bottom: 20px;
color: #858585;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";

}

.col02.step dd {
color: #000;
}

.col02 dt img {
width: 100%;
}

.col02 dt img:nth-of-type(2) {
margin-top: 10px;
}

.col02 dd span {
display: inline-block;
font-size: 14px;
line-height: 24px;
width: 24px;
border-radius: 12px;
background: #f00;
color: #fff;
text-align: center;
font-weight: bold;
white-space:nowrap;
letter-spacing: -0.1em;
font-family: Arial, Helvetica, "sans-serif";
text-indent:-2px;
margin-right:10px;
}

.col02 dd p {
font-size: 17px;
font-weight: normal;
margin: 0 0 10px 0;
padding-left: 34px;
text-indent: -34px;
line-height: 1.5;
}

.col02 .fb100 {
flex-basis: 100%;
margin-right: 0;
}

.titleArea {
padding: 0 20px;
}

.titleArea {
padding: 1rem;
position: relative;
color: #fff;
background: -webkit-linear-gradient(135deg,#008aeb 47%,#0081dc 0,#0081dc 70%,#008aeb 0,#008aeb 70%,#0081dc 0);
background: linear-gradient(-45deg,#008aeb 47%,#0081dc 0,#0081dc 70%,#008aeb 0,#008aeb 70%,#0081dc 0);
background-size: 20px 20px;
}


.titleArea p.subTitle {
margin: 0 0 5px;
display: inline-block;
padding: 5px 15px;
font-size: 18px;
}

.titleArea h1 {
font-size: 24px;
margin-bottom: 10px;
}

.titleCourse {
font-size: 24px;
padding: 1rem;
position: relative;
color: #fff;
background: -webkit-linear-gradient(135deg,#008aeb 47%,#0081dc 0,#0081dc 70%,#008aeb 0,#008aeb 70%,#0081dc 0);
background: linear-gradient(-45deg,#008aeb 47%,#0081dc 0,#0081dc 70%,#008aeb 0,#008aeb 70%,#0081dc 0);
background-size: 20px 20px;
}

.titleCourse span {
font-size: 20px;
font-weight: normal;
}

.columnNext {
text-align: left;
margin: 60px 40px;
display: flex;
border-radius: 6px;
border: 2px solid #c3d600;
padding: 10px;
background: #fff;
}

.columnNext .subTitle {
border-radius: 6px;
display: inline-block;
font-size: 22px;
background: #c3d600;
padding: 10px;
color: #fff;
font-weight: bold;
flex-basis: 100px;
text-align: center;
margin-right: 20px;
}

@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, .columnNext .subTitle {min-width:65px;}
}

.columnNext .main {
background: #fff;
font-size: 18px;
}

.columnNext .main h3 {
font-size: 20px;
}

#mainArea .contentsTitle {
background: -webkit-linear-gradient(135deg,#edf3b2 25%,#fef7cb 0,#fef7cb 50%,#edf3b2 0,#edf3b2 75%,#fef7cb 0);
background: linear-gradient(-45deg,#edf3b2 25%,#fef7cb 0,#fef7cb 50%,#edf3b2 0,#edf3b2 75%,#fef7cb 0);
background-size: 8px 8px;
border:1px solid #c3d600;
}

.boxCol02 {
display: flex;
justify-content: space-between;
margin: 40px 0;
}

.boxCol02 li{
width: 420px;
}


.boxCol02 li img {
width: 100%;
}


#mainArea .pageLink a, #mainArea .contentsTitle {
height: inherit;
line-height: inherit;
padding: 20px 0 20px 40px;
}

.contentsBox a,
.contentsBox a:visited {
	color: #005AB4 !important;
}
