@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;
}

.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 h5 {
margin: 0 auto 0;
width: 880px;
text-align: center;
font-size: 24px;
font-weight: bold;
margin-bottom: 20px;
border: 1px solid #000;
box-sizing: border-box;
padding: 10px;
background: #fff;
}

.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;
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 #71b1ff;
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 #71b1ff;
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 #ffbb83;
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 #ffbb83;
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 img {
margin-bottom: 20px;
}

.column01 p {
margin: 0;
font-weight: normal;
font-size: 17px;
}

.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.caption01 {
font-size: 17px;
font-weight: normal;
text-align: left;
margin:16px 0 40px;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
}

.contentsBox p.caption02 {
color: #858585;
font-size: 17px;
line-height: 1.5;
margin: 16px auto 0;
font-weight: normal;
}

.contentsBox p.reg-caption {
color: #858585;
font-size: 15px;
line-height: 1.5;
margin: 5px auto 0;
font-weight: normal;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";

}

.col02 {
display: flex;
margin: 40px 0;
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;
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
}

.col01.step dd,
.col02.step dd {
color: #000;
}

.col02 dt img {
width: 100%;
}

.col02 dt img:nth-of-type(2) {
margin-top: 10px;
}

.col01 dd span,
.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;
}

.col01 dd p,
.col02 dd p {
font-size: 17px;
font-weight: normal;
margin: 0 0 10px 0;
padding-left: 34px;
text-indent: -34px;
line-height: 1.5;
word-break: break-word;
}

.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 #71b1ff;
padding: 10px;
background: #fff;
}

.columnNext .subTitle {
border-radius: 6px;
display: inline-block;
font-size: 22px;
background: #71b1ff;
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,#fee6e0 25%,#f8e2d1 0,#f8e2d1 50%,#fee6e0 0,#fee6e0 75%,#f8e2d1 0);
background: linear-gradient(-45deg,#fee6e0 25%,#f8e2d1 0,#f8e2d1 50%,#fee6e0 0,#fee6e0 75%,#f8e2d1 0);
background-size: 8px 8px;
border:1px solid #ffbf71;
}

.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
}

table.spec {
width: 880px;
margin: 39px auto 0;
text-align: left;
border-width:1px 0 0 0;
}

table.spec,
table.spec th,
table.spec td{ border:1px solid #858585; }

table.spec tr th,
table.spec tr td {
border-width:0 1px 1px 1px;
}

table.spec tr th {
background: #000;
padding: 0 20px;
height: 60px;
line-height: 60px;
color: #fff;
font-size: 18px;
font-weight: bold;
text-align: left;
text-align: center;
}

table.spec tr td {
padding: 0 20px;
height: 80px;
background: #fff;
font-size: 20px;
position: relative;
word-break: break-all;
text-align: center;
}

table.spec tr td:first-child {
background: #dedede;
font-size: 18px;
position: relative;
word-break: break-all;
text-align: center;
width: 40%;
}

table.spec caption {
margin: 0 auto 0;
width: 880px;
height: 50px;
text-align: center;
background: #000;
font-size: 24px;
font-weight: bold;
line-height: 50px;
color: #fff;
margin-bottom: 20px;
}

dl.col01 {
margin-top: 40px;
}

dl.col01 dt p {
text-align: left;
}

dl.col01 dd {
text-align: left;
margin: 25px auto 50px;
font-size: 17px;
/*color: #858585;*/
font-feature-settings: "palt";
-webkit-font-feature-settings: "palt";
}

dl.col01 dt img {
width: 100%;
}

.mb20 {
margin-bottom: 20px;
}

.float-l {
float: left;
margin: 0 20px 0 0;
}

.float-r {
float: right;
margin: 0 0 0 20px;
}

ul.copyright {
margin: 54px auto 0 52px;
width: 880px;
text-align: left;
}

ul.copyright li {
font-size: 15px;
font-weight: 500;
line-height: 1.4;
}

.column01 .col02 dt {
flex-basis: 360px;
}

.column01 .col02 dt:last-of-type,
.column01 .col02 dt:last-of-type img{
margin-bottom: 0;
}

.column01 .col02{
margin-bottom: 20px;
}

.column01 .col02 dd{
width: 458px;
}

dl#get_adobe {
margin: 54px auto 0 52px;
width: 880px;
box-sizing: border-box;
text-align: left;
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -o-flex;
display: flex;
padding: 15px;
border: solid 1px #ccc;
}

dl#get_adobe dd{
margin-left: 40px;
font-size: 15px;
font-weight: 500;
line-height: 1.4;
}

.contentsInner a img {
-moz-transition: opacity 0.25s ease;
-o-transition: opacity 0.25s ease;
-webkit-transition: opacity 0.25s ease;
transition: opacity 0.25s ease;
}

.contentsInner a img:hover {
opacity: 0.7;
}

.under #photo_contents .contentsBox a,
.under #photo_contents .contentsBox a:visited {
color: #005AB4;
}

.under #photo_contents .contentsBox a:hover {
text-decoration: none;
color: #ff3300;
border-bottom: #ff3300 1px solid;
}

