@charset "utf-8";
/***************************************************
information
  filename : app_user.css;
***************************************************/
:root {
  --app-basic-txt: #333;
  --app-main-txt: #E9551C;
  --app-main-c-txt: #4CCFCA;
  --app-glnv-txt: #000;
  --app-sbnv-txt: #7DB9FC;
  --app-copy-txt: #fff;
  --app-bg-cr: #F2F2F2;
  --app-main-cr: #171717;
  --app-main-cr-c: #e60012;
  --app-header-cr: #fff;
  --app-footer-cr: #222222;
  --app-glnv-cr: #fff;
  --app-sbnv-cr: #fff;
  --app-copy-cr: #171717;
}
/***************************************************
共通（※高岡追加）
***************************************************/
a:hover{
text-decoration:none;
}
.articleBox p{
   padding:0px;
   margin:20px 0;
}
.articleBox h2{
  margin:80px 0 32px;
}
/***************************************************
ボタンパーツ（※高岡追加）
***************************************************/
/* デフォルトボタン1 */
.buttonBox{
	text-align: center;
	margin:16px auto;
  }
  button,.buttonBox a{
	font-size:16px;
	background:var(--app-main-c-txt);
	color:#fff;
	border:none;
	width:360px;
	padding:16px 8px;
	border-radius: 4px;
	box-shadow: 0 2px 20px rgba(0,0,0,0.08);
	transition:0.4s ease;
  }
  .buttonBox a{
	display: block;
	margin:auto;
  }
  button:hover{
	transform:scale(0.99);
	box-shadow: none;
	transition:0.2s ease;
  }

  @media screen and (max-width:767px){
	button,.buttonBox a{
	  width:320px;
	}
  }
  @media screen and (max-width:440px){
	button,.buttonBox a{
	  width:71%;
	font-size:14px;
	padding:12px 8px;
	}
  }

/* デフォルトボタン2 */
button.line,.buttonBox a.line{
	color: var(--app-main-txt);
	padding:14px 8px;
	background:none;
	border:2px solid var(--app-main-txt);
	box-shadow: none;
  }
  button.line:hover{
	color:#fff;
	background:var(--app-main-txt);
	transform:scale(1);
  }

/* 強調ボタン中 */
button.main,.buttonBox a.main{
	background:var(--app-main-c-txt);
  }

/* 強調ボタン大 */
button.mainBig,.buttonBox a.mainBig{
	font-size:18px;
	width:480px;
	background:var(--app-main-cr-c);
  }

  @media screen and (max-width:650px){
	button.mainBig,.buttonBox a.mainBig{
	  width:85%;
	}
  }
  @media screen and (max-width:540px){
	button.mainBig,.buttonBox a.mainBig{
	  width:90%;
	}
}


/***************************************************
記事パーツ（※高岡追加）
***************************************************/
/************　囲みBOX　***********/
.borderBox{
    border: 1px solid var(--app-main-brd-a);
    margin:16px 0;
    padding:8px 32px;
}
/* 強調色 */
.borderBox.strong-color,.borderBox.brdClr2{
    border: 1px solid var(--app-main-txt);
}

.archiveArea.archiveIndex .conDetailArea .articleBox .lineBox p {
    position: static;
    padding-top: 16px;
}
/* アイコンボタンボックス */
.icon_buttonBox a{
    background:#fff;
    border-radius:8px;
    display:block;
    padding:24px 72px;
    position:relative;
    color:#333;
    font-weight:bold;
    z-index:1;
}
.icon_buttonBox a:before{
    position:absolute;
    content:'';
    background:var(--app-main-c-txt);
    width:50px;
    height:50px;
    border-radius: 6px;
    top:50%;
    left:10px;
    transform:translateY(-50%);
    z-index:1;
}
/* 素材ダウンロードアイコン */
.icon_buttonBox a.icon_buttonBox_download:after{
    position:absolute;
    content:'';
    background:url(https://img.dogapon-course.com/course/icon/icon_buttonBox_download.svg)no-repeat;
    background-size: contain;
    width:30px;
    height:30px;
    top:50%;
    left:20px;
    transform:translateY(-50%);
    z-index:99;
}
/* 自由課題アイコン */
.icon_buttonBox a.icon_buttonBox_freetask:before{
    background:#977FFC;
}
.icon_buttonBox a.icon_buttonBox_freetask:after{
    position:absolute;
    content:'';
    background:url(https://img.dogapon-course.com/course/icon/icon_buttonBox_freetask.svg)no-repeat;
    background-size: contain;
    width:30px;
    height:30px;
    top:50%;
    left:20px;
    transform:translateY(-50%);
    z-index:99;
}

/************　見出し　***********/
.midashi1{
    text-align: center;
    background:#F8F8F8;
    border-top:1px solid #ddd;
    border-bottom:1px solid #ddd;
    position:relative;
    margin:80px 0 40px;
}
.midashiTtl{
    background:#333333;
    color:#fff;
    display:inline-block;
    padding:4px 32px;
    border-radius: 40px;
    position:absolute;
    top:-16px;
    left:50%;
    transform:translateX(-50%);
}
.midashi1 p{
    color:var(--app-main-txt);
    font-size:20px;
    line-height: 1.75;
}
.midashiTxt{
   padding-top:8px;
}
@media screen and (max-width:540px) {
    .midashi1{
        padding:12px 0 1px;
        margin:60px 0 30px;
    }
    .midashi1 p{
        font-size:18px;
    }

}

/************　文字装飾　***********/
p.style1{
    color:var(--app-main-txt);
}

/************　見出し　***********/
/* 見出しスタイル１ */
h2.style1{
    position: relative;
    z-index:1;
    font-size: 32px;
}
h2.style1:after{
    position: absolute;
    content: "";
    right: -40px;
    width: 100%;
    height: 0.5em;
    right: 0;
    bottom: -2px;
    background: #ddd;
    z-index: -1;
}
/* 見出しスタイル２ */
h2.style2,h2.mainT,h3.mainT{
    position: relative;
    padding-left:16px;
    margin-left:8px;
}
h2.style2:before,h2.mainT:before,h3.mainT:before{
    position: absolute;
    content: "";
    background: var(--app-main-c-txt);
    width: 10px;
    height: 10px;
    left: 0;
    top: 50%;
    transform:translateY(-50%);
}

/************　動画埋め込み　***********/
.articleBox .innvideo {
   padding-top: 56.25% !important;
   margin:16px 0px;
}
/************　囲みBOX　***********/
.baseBox,.lineBox,.listBox{
	padding:16px 24px;
　margin:16px 0px !important;
}
.box__title p{
	color:var(--app-main-txt);
	font-weight:bold;
}
/* 囲みBOX1 */
.baseBox{
	background:var(--app-main-brd-a);
	margin:16px 0px;
}
/* 囲みBOX2 */
.lineBox{
	border:1px solid var(--app-main-brd);
	margin:16px 0px;
}
/* 囲みBOX3 */
.gray{
	border:1px solid var(--app-main-brd);
}
.gray p{
	color:var(--app-main-brd);
}
/************　強調BOX　***********/
.pointBox{
	background:#f8f8f8;
	padding-bottom:8px;
	margin:16px auto;
}
.pointBox p{
  width:95%;
  margin:16px auto;
}
.pointBox .box__title{
  background:var(--app-main-txt);
	padding:8px;
}
.pointBox .box__title p{
	color:#fff;
	font-weight:bold;
	text-align: center;
	margin:0px;
}
.pointBox .box__title.icon{
  background:#333;
	/* background:var(--app-main-cr-c); */
	text-align: center;
}
.box__title.icon p{
	display:inline-block;
	position:relative;
  width:auto;
}
.box__title.icon p:before{
	position:absolute;
	content:'';
	width:15px;
	height:9px;
	border-left:3px solid #fff;
	border-bottom:3px solid #fff;
	top:22%;
	left:-22px;
	transform:rotate(-45deg);
}
/* 強調BOX1 */

/* 強調BOX2 */

/************　リストBOX　***********/
/* リストBOX1 */
.listBox ul li{
	padding-left:20px;
	position:relative;
  list-style: none;
}
.listBox ul li:before{
	position:absolute;
	content:'';
	background:var(--app-main-txt);
	width:4px;
	height:4px;
	border-radius: 50%;
	top:50%;
	left:0;
	transform:translateY(-50%);
}
/* リストBOX2 */
.listBox ol{
	counter-reset: item;
  	list-style-type: none;
	position:relative;
}
.listBox ol li:before{
	counter-increment: item;
 	content: counter(item)'. ';
	color:var(--app-main-txt);
	font-weight:bold;
}
/* リストBOX3 */
ol.countType2 li:before{
	color:#fff;
	font-size:80%;
	background:var(--app-main-txt);
	content: counter(item)'';
	padding:5.5px 7.6px 5px;
	margin-right:6px;
	border-radius: 50%;
}
/************ 強調テキスト　***********/

/* 強調テキスト1 */
.pointText{
	margin:16px auto;
}
.pointText p.check{
	padding-left:20px;
	margin-top:4px;
	margin-bottom:4px;
	font-size:105%;
	font-weight:bold;
	position:relative;
}
.pointText p.check:before{
	position:absolute;
	content:'';
	width:24px;
	height:14px;
	border-left:4px solid var(--app-main-cr-c);
	border-bottom:4px solid var(--app-main-cr-c);
	top:50%;
	left:-16px;
	transform:translateY(-70%)rotate(-45deg);
}
/* 強調テキスト2 */
.pointText p.check.sub:before{
	border-left:4px solid var(--app-main-c-txt);
	border-bottom:4px solid var(--app-main-c-txt);
}
@media screen and (max-width:540px){
	.pointText p.check:before{
		width:22px;
		height:12px;
		left:-12px;
	}
}
/************ 見出し装飾　***********/
/* タグタイトル */
.tagTitle {
	display:flex;
	align-items: center;
	padding:0px;
	margin:40px 48px 24px;
}
.tagTitle .tagTitle__mark{
	background:var(--app-main-txt);
	color:#fff;
	font-size:95%;
	padding:3px 12px 2px;
	margin-right:12px;
}
.tagTitle__mark.strong{
	background:var(--app-main-cr-c);
}
.tagTitle h3,.tagTitle h4{
	margin:0;
	border:none;
	background:none;
	text-align: left;
	color:var(--app-glnv-txt);
}
/************ ふきだしテキスト　***********/
/* ふきだしテキスト左 */
.serifBox{
	display:flex;
	align-items: center;
}
.serifBox__img img{
	width:96px;
	height:96px;
	border-radius: 50%;
	border:2px solid var(--app-gray-brd);
}
.serifBox__text p{
	min-width: 400px;
	padding:20px 32px;
	background:var(--app-gray-bg);
	border-radius: 8px;
	margin:0 0 0 20px;
	position:relative;
}
.serifBox__text p:before{
	position:absolute;
	content:'';
	border-style: solid;
	border-width: 10px 10px 10px 0;
	border-color: transparent var(--app-gray-bg) transparent transparent;
	left:-10px;
	top:50%;
	transform:translateY(-50%);
}
/* ふきだしテキスト右 */
.serif-right.serifBox{
	flex-direction:row-reverse ;
}
.serif-right .serifBox__text p{
	margin:0 20px 0 0;
}
.serif-right .serifBox__text p:before{
	border-width: 10px 0 10px 10px;
	border-color: transparent transparent transparent var(--app-gray-bg);
	left:auto;
	right:-10px;
}
@media screen and (max-width:540px){
	/* .serifBox{
		align-items: flex-start;
	} */
	.serifBox__img img{
		width:72px;
		height:72px;
	}
	.contents .serifBox__text p{
		margin:12px;
	}
	.serifBox__text p{
		min-width: auto;
		width:95%;
		padding:16px 20px;
	}
}
/************ 関連BOX　***********/
/* 関連BOX1 */
.kanrenBox{
	display:flex;
}
.kanrenBox__img {
	margin:0 16px;
}
.kanrenBox__text {
	margin:0 16px 0 0;
}
.kanrenBox__text--tag{
	display:inline-block;
	background:var(--app-main-cr);
	color:#fff;
	font-size:85%;
	padding:2px 8px 1px;
}
.kanrenBox__text--title{
	font-size:18px;
	font-weight:bold;
	color:var(--app-glnv-txt);
	padding:8px 0 4px;
	border-bottom: 1px solid var(--app-gray-brd);
}
.kanrenBox__text--detail{
	color:var(--app-gray-txt);
	padding:8px 0;
	font-size:90%;
}
/* 関連BOX2 */
.lineBox.strong{
	border:1px solid var(--app-main-cr-c);
}
.kanrenBox.strong .kanrenBox__text--tag{
	background:var(--app-main-cr-c);
}
/* 関連BOX3 */
/************ アイコンBOX　***********/

/* アイコンBOX */
/************ 動画埋込BOX　***********/

/* 動画埋込BOX */

/************　画像BOX　***********/

/* 画像中サイズ */
/* 画像大サイズ */
.imgBox img{
	width:100%;
	margin:16px auto;
}
/* 画像横並び２列 */
.imgBox_col2{
	display:flex;
}
.imgBox_col2 .imgBox__item{
	width:50%;
	padding:4px;
}
@media screen and (max-width:767px){
	.imgBox img{
		height:100%;
	}
	.imgBox_col2{
		display:block;
	}
	.imgBox_col2 .imgBox__item{
		width:100%;
	}
}
/************　質問BOX　***********/

/* 質問BOX1 */
.qaBox__title{
	position: relative;
	padding-left: 12px;
	border-left: none;
	margin-bottom: 0px;
}
.qaBox__title:before{
	position: absolute;
	content: "Q";
	color: #fff;
	background: var(--app-main-cr-c);
	border-radius: 50%;
	padding: 8px 15.5px;
	top: 50%;
	left: 0px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	font-size: 16px;
}
.qaBox__title p{
	font-size: 18px;
}
.qaBox__text{
	position: relative;
	padding-left: 12px;
  }
  .qaBox__text:before {
	position: absolute;
	content: "A";
	color: #fff;
	background: var(--app-main-cr);
	border-radius: 50%;
	padding: 8px 15.5px;
	top: 10px;
	left: 0px;
	font-weight: bold;
  }

/***************************************************
記事内テキスト装飾パーツ
***************************************************/
/************　本文パーツ　***********/
/* マーカー（メイン） */
.mck{
	color:var(--app-main-txt);
}
/* マーカー（サブ） */
.mck_sub{
  color:var(--app-main-txt);
	border-bottom: 1px dashed var(--app-main-txt);
  padding-bottom: 5px;
}
/* アンダーライン */
.uline{
	color:var(--app-main-c-txt);
	border-bottom: 1px dashed var(--app-main-c-txt);
  padding-bottom: 5px;
}
/* アンダーライン ２*/
.uline2{
	border-bottom: 1px dashed var(--mainTxt-txt);
  padding-bottom: 5px;
}
/* p 補足 */

@media screen and (max-width:540px){
	.uline{
		padding-bottom: 3px;
	}
}
/************　タイトルパーツ　***********/
/* サブタイトル */
.subT{
	color:var(--app-main-cr);
	padding-bottom:4px;
	border-bottom:2px solid #acacac;
}
/* 会社概要 */
.company{
	padding:16px 48px 0px;
}
.company dl {
	display: flex;
	border-bottom: 1px solid #DDDDDD;
	padding: 20px 0px 20px 0px;
  }
  @media screen and (max-width:540px) {
	.company{
		padding:16px 24px 0px;
	}
	.company dl {
	  font-size: 14px;
	}
  }
  .company dl:last-child {
	border-bottom: none;
  }
  .company dt {
	width: 20%;
  }
  @media screen and (max-width:540px) {
	.company dt {
	  width: 27%;
	}
  }
  .company dd {
	width: 80%;
	padding-left: 16px;
  }
  @media screen and (max-width:540px) {
	.company dd {
	  padding-left: 12px;
	  width: 73%;
	}
}
.rmd_det,.rmd_det #wrapper{
background:#f2f2f2;
}