@charset "UTF-8";



.mb0{margin-bottom: 0;}
.flex{display: flex;flex-wrap: wrap;}
.flex_between{justify-content: space-between;}
.flex_a_center{align-items: center;}


.contents_btm01{margin-bottom: 20px;}
.contents_btm02{margin-bottom: 40px;}
.contents_btm03{margin-bottom: 60px;}


#mainvisual{
	background: #faf5e5;
	height: 28vw;
	max-height: 600px;
	margin-bottom: 30px;
	overflow: hidden;
	position: relative;
}

#mainvisual::after{
	content: "";
	display: block;
	background: url(../images/main_visual.png);
	background-size: cover;
	width: 72vw;
	height: 23.5vw;
	position: absolute;
	top: 50%;
	right: 2%;
	transform: translateY(-50%);
  -webkit- transform: translateY(-50%);
}

#mainvisual .txt_area{
	position: absolute;
	bottom: 1.5vw;
	left: 2vw;
	font-family:"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
#mainvisual .txt_area h1{
    margin-bottom: 1em;
}
#mainvisual .txt_area h1 span{
    background: rgba(203,31,75,0.5);
    color: #fff;
    padding: 0.15em 0.5em;
    font-size: 1.1vw;
}
#mainvisual .txt_area h2{
	font-size:3.5vw;
	color: #4e412d;;
	font-weight: bold;
	margin-bottom: .15em;
	letter-spacing: .25em;
	line-height: 1.2;
}
#mainvisual .txt_area .course,#mainvisual .txt_area .hashtag{
	display: flex;
	flex-wrap: wrap;
}
#mainvisual .txt_area .course{margin-bottom:.75em;}
#mainvisual .txt_area .course li{
	font-size: 1.3vw;
	color: #d64191;
	font-weight: bold;	
	margin: 0 .5em;
	padding: .25em 1em;
	border-radius: 30px;
	border: 3px solid #d64191;
	background: #fff;
}

#mainvisual .txt_area .hashtag li{
	font-size:1.25vw;
	color: #4e412d;
	font-weight: bold;	
	margin: 0 .5em;
}

.campaign_bnr .button-area-two{
	width: 90%;
	max-width: 740px;
	margin: 30px auto;
}


#mainContent h2{font-size: 2.5rem;margin-bottom: 2em; }
#courseArea h3{font-size: 1.5rem;}
.sh2{
	font-size: 1.6rem;
	font-weight: bold;
	margin-bottom: .75em;	
}
.t_1{
	background: #cb1f4b;
	color: #fff !important;
	padding: .25em;
	font-weight: bold;
	text-align: center;
	margin-bottom: 1.5em;		
	font-size: 1.35rem;
}
.txt_under{background: linear-gradient(transparent 60%, yellow 40%);}

span.small{
	font-size: 1rem;
	display: block;
}

#mainContent .mainList{
	width: 48.5%;
	padding: 30px;
}

#mainContent .mainList .imgArea{
	width: 80%;
	margin: 0 auto 20px;
}


#mainContent .box01,#mainContent .box02{
	margin-bottom: 30px;
}

#mainContent .box01,#mainContent p{
	font-size: 1rem;
}



#courseArea .course{padding: 40px 0;}
#courseArea .photoshop{background: #cad4e3;}
#courseArea .illustrator{background: #ffebe3;}
#courseArea .document{background: #e7f9f8;}
#courseArea .parts{background: #e9ffe3;}
#courseArea .aim{background: #fffeed;}




#courseArea .list>li{
	background: #fff;
	padding: 40px;	
}
#courseArea .list>li:not(:last-child){
	margin-bottom: 40px;
}

#courseArea .list>li.study ul,
#courseArea .list>li.results ul{
	display: flex;
	flex-wrap: wrap;
}
#courseArea .list>li.results ul{
	justify-content: space-between;
	margin-bottom: 30px;
}
#courseArea .list>li.study ul li{
	background: #6cc4c4;
	color: #fff;
	padding: .5em 1em;
	margin: .25em;
}
#courseArea .list>li.results ul li{
	width: 48%;
}
#courseArea .list>li.results ul li h5{
	text-align: center;
	font-weight: bold;
	margin-bottom: 1em;
}

#courseArea h4{
	text-align: center;
}

#courseArea .list>li .qualification h5{
	background: #426089;
	color: #fff;
	font-size: 1.5rem;
	padding: .5em;
	margin-bottom: 2em;
	text-align: center;
	position: relative;
}
#courseArea .list>li .qualification h5::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 20px 20px 0 20px;
	border-color: #426089 transparent transparent transparent;
	position: absolute;
	bottom: -15px;
	right: 0;
	left: 0;
	margin: auto;
}
#courseArea .list>li .qualification .box{
	border: 1px solid #ccc;
}
#courseArea .list>li .qualification h6{
	text-align: center;
	background: #fffaac;
	padding: .5em;
	font-size: 1.35rem;
	font-weight: bold;
}
#courseArea .list>li .qualification p{
	padding: 30px;
	background: #fff;
}

#courseArea h3 .txts{
	display: block;
	background: #fff;
	color: #cb1f4b;
	padding: .25em 1em;
	font-size: 1.125rem;
}

#courseArea .list>li .txt01{
	margin-bottom: 20px;
}
#courseArea .list>li p{
	line-height: 1.8;
}
#courseArea .list>li .caption{
	margin-bottom: 30px;
}
#courseArea .list>li .caption li{
	font-size: .875rem;
	text-indent: -1em;
	margin-left: 1em;
}

#courseArea .results .img_area{
	width: 80%;
	margin: auto;
}

#courseArea .list>li .skil{
	width: 80%;
	margin:40px auto 0;
}
#courseArea .list>li .skil li{
	width: 25%;
	background: #ff77a9;
	padding: 20px 10px;
	color: #fff;
}
#courseArea .list>li .skil li:not(:last-child){border-right: 1px solid #fff;}
#courseArea .list>li .skil li figure{
	display: block;
	margin: auto;
	text-align: center;
}
#courseArea .list>li .skil li figure figcaption{
	font-size: 1.25rem;
}

#courseArea .list>li .skil li figure img{
	margin-bottom: 10px;
	height: 45px;
}


#voiceArea .box01 .img_area{
	width: 50%;
}
#voiceArea .box01 .txt_area{
	width: 40%;
}
#voiceArea .box01 li:first-child{
	margin-bottom: 4em;
	position: relative;
}

#voiceArea .box01 li:first-child::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 30px 0 30px;
	border-color: #FFD455 transparent transparent transparent;
	position: absolute;
	bottom: -3em;
	right: 0;
	left: 0;
	margin: auto;
}


#voiceArea .box01 li dt{
	color: #fff;
	text-align: center;
	padding: .25em;
	font-size: 1.25rem;
	font-weight: bold;
}

#voiceArea .box01 li:first-child dt{background: #a00000;}
#voiceArea .box01 li:last-child dt{background: #005F9A;}

#voiceArea .box01 li dd{
	background: #fffbd7;
	font-weight: bold;
	text-align: center;
	padding: 1em;
}
#voiceArea .box02 ul{
	width: 85%;
	margin: auto;
}
#voiceArea .box02 ul li:not(:last-child){
	margin-bottom: 30px;
}
#voiceArea .box02 li dt{
	width: 34%;
	background: #5f96c2;
	color: #fff;
	font-weight: bold;
	text-align: center;
	padding: 1em;
	display: flex;
	align-items: center;
	justify-content: center;
}
#voiceArea .box02 li dd{
	width: 60%;
	background: #ff77a9;
	color: #fff;
	font-weight: bold;
	padding: 1em 2em;
	position: relative;
}
#voiceArea .box02 li dd::before{
	content: "";
	position: absolute;
	top: 50%;
	left: -18px;
	transform: translateY(-50%);
	-webkit- transform: translateY(-50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 29px 25px 0;
	border-color: transparent #ff77a9 transparent transparent;
}

#voiceArea .box03 .img_area{
	width: 80%;
	margin: auto;
}






@media (max-width: 999px){

#mainvisual{
	height: 30vw;
}

#mainvisual::after{
	top: 42%;
	width: 73vw;
    height: 24vw;
    right: 1%;
}

#mainvisual .txt_area{
	left:1%;
	bottom: 1.5vw;
}

#mainvisual .txt_area h1 span{font-size: 1.4vw;margin-bottom: 0.75em;}
#mainvisual .txt_area h2{font-size: 3.8vw;}
#mainvisual .txt_area .course li{font-size: 1.5vw;margin: 0 0.25em;}
#mainvisual .txt_area .hashtag li{font-size: 1.5vw;}

}

@media (max-width:899px){
	#mainvisual .inner::after{width: 68vw;height: 22vw;top: 45%;}
	
}

@media (max-width: 799px){

#mainvisual::after{
	width: 70vw;
    height: 22.5vw;
}

#mainvisual .txt_area h1 span{font-size: 1.5vw;}
#mainvisual .txt_area h1{margin-bottom: 0.25em;}

#mainContent h2{font-size: 1.5rem;}
.sh2{font-size: 1.5rem;}
.t_1{font-size: 1.35rem;}
#courseArea h3{font-size: 1.35rem;}
#courseArea .list>li .qualification h5{font-size: 1.35rem;}
#courseArea .list>li .qualification h6{font-size: 1.25rem;}
#mainvisual .txt_area .course{margin-bottom: 0.5em;}


#mainContent .mainList{
	width: 100%;
	padding: 25px;
}
#mainContent .box01,#mainContent .box02,#mainContent .box03{
	margin-bottom: 30px;
}

#courseArea .results .img_area{
	width: 100%;
}

#courseArea .list>li .skil{
	width: 100%;
}


}



@media (max-width: 599px){

#mainvisual{
	height: 78vw;
}
#mainvisual::after{
	background: url(../images/main_visual_smt.png);
	background-size: cover;
	width: 62vw;
	height: 29.5vw;
	position: absolute;
	top: initial;
	right: 0;
	bottom: -12vw;
}
#mainvisual .txt_area{
	top: -4vw;
	left: 2%;
	transform: translateY(10%);
	-webkit- transform: translateY(10%);
}
#mainvisual .txt_area h1 span{font-size: 3vw;padding: 0.25em 0.5em;}
#mainvisual .txt_area h1{margin-bottom: 0.5em;}
#mainvisual .txt_area h2{font-size: 7.5vw;}
#mainvisual .txt_area .course li{font-size: 3vw;}
#mainvisual .txt_area .hashtag li{
	width: 100%;
	font-size:3vw;
	color: #4e412d;
	font-weight: bold;	
	margin: 0 .5em;
}

.campaign_bnr .button-area-two{
	margin: 20px auto;
}
.campaign_bnr ul.button-area-two li{
	width: 90%;
}
.campaign_bnr ul.button-area-two li:first-child{
	margin-bottom: 20px;
}

#mainContent h2{font-size: 1.35rem;}
.sh2{font-size: 1.35rem;}
.t_1{font-size: 1.25rem;margin-bottom: 1.5em;}
#courseArea h3{font-size: 1.25rem;}

#courseArea .list>li .qualification h5{font-size: 1.25rem;}
#courseArea .list>li .qualification h6{font-size: 1.15rem;}

#mainContent .imgArea{width: 80%;margin: 0 auto 20px;}
#mainContent .txtArea{width: 100%;}


#courseArea .list>li{
	margin-bottom: 25px;
	padding: 25px;	
}
#courseArea h3 .txts{
	font-size: 1rem;
}


#courseArea .list>li .skil li{
	width: 50%;
}
#courseArea .list>li .skil li:nth-of-type(2){border-right: none;}
#courseArea .list>li .skil li:nth-of-type(-n+2){border-bottom: 1px solid #fff;}



#voiceArea .box01 .img_area{
	width: 80%;
	margin: 0 auto 30px;
}
#voiceArea .box01 .txt_area{
	width: 100%;
}

#voiceArea .box02 li dt,#voiceArea .box02 li dd{
	width: 100%;
}

#voiceArea .box02 li dd::before{
	display: none;
}
#voiceArea .box02 ul li:not(:last-child){
	position: relative;
	margin-bottom: 4em;
}
#voiceArea .box02 ul li:not(:last-child)::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 30px 0 30px;
	border-color: #89D3FD transparent transparent transparent;
	position: absolute;
	bottom: -3em;
	right: 0;
	left: 0;
	margin: auto;	
}



}





@media (max-width: 499px){

#mainvisual .txt_area{top: -5vw;}
#mainvisual .txt_area h2{font-size: 8vw;}
#mainvisual .txt_area .course li{font-size: 4vw;padding: 0.15em 0.75em;}
#mainvisual .txt_area .hashtag li{margin: 0 0.5em 0 0;font-size: 3.5vw;}

#mainContent .mainList, #courseArea .list>li, #courseArea .list>li .qualification p{padding: 15px;}

#voiceArea .box02 li dd{padding: 1em;}

}






@media (max-width: 320px){
#mainvisual .txt_area .course li{font-size: 3.5vw;}


}


#mainContent .sh2{
	line-height: 1.4;
	margin-bottom: 0.5em;
	font-size: 1.4rem;
}
.txt_s, #mainContent p.txt_s{
    font-size: 75%;
}
#mainContent p.txt_s{
	margin-top: 0.5em;
}
.txt_ind{
	padding-left: 1em;
    text-indent: -1em;
}
.mainList h4 small{
	font-size: 50%;
	font-weight: normal;
	margin-left: 0.25em;
}


.pc_no{
	display:none;
}

@media (max-width: 1399px){
	#mainContent .sh2{font-size: 1.6vw;}

}

@media (max-width: 1099px){
	#mainContent .sh2{font-size:2vw;}

}

@media (max-width: 799px){
	#mainContent .sh2{font-size:3vw;}

}

@media (max-width: 699px){
	.pc_no{display:block;}
	.smt_no{display:none;}
}

@media (max-width: 499px){
	#mainContent .sh2{font-size:1.15rem;}

}



/* 221227追記（コース追加） */

.course.retouch { background: #dff6ff;}
.course.design { background: #ffe9f5;}
.results h5.txt_center { text-align: center; font-weight: bold; margin-bottom: 1em;}
#courseArea .list>li.results .carousel { display: block; width: 100%; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; text-align: center;}
#courseArea .list>li.results .carousel > li { width: auto; max-width: calc( 95% - 2em ); display: inline-block; margin-right: 2em; vertical-align: top; padding-bottom: 1em;}
.course.design .list_dot { column-count: 2; column-gap: 3em;}
.course.design .list_dot li { padding-left: 1em; position: relative; margin-bottom: 0.5em;}
.course.design .list_dot li::before { content: "・"; position: absolute; left: 0; top: 0;}
#courseArea h5.txt_bold{font-weight: bold;margin: 1em 0 0.25em;font-size:105%;color:#cb1f4b;}
.notes li{padding-left: 1em;text-indent: -1em;}
@media (max-width: 499px){
	.course.design .list_dot { column-count: unset;}
}


/* -----アコーディオン----- */
/*ボックス全体*/
.accbox {
    max-width: 100%;/*最大幅*/
    margin-bottom: 50px;
}

/*ラベル*/
.accbox label {
    display: block;
    /*margin: 1.5px 0;*/
    cursor :pointer;
    transition: all 0.5s;
    position: relative;
}

/*アイコンを表示*/
.accbox label:before {
    content: "\f13a";
    font-family:"FontAwesome";
    font-weight: 900;
    position: absolute;
    right: 1.5%;
    top: 0;
    bottom: 0;
    color: #fff;
    font-size: 1.5em;
    height: 21px;
    margin: auto;
    line-height: 1;
}

/*チェックは隠す*/
.accbox input {
    display: none;
}

/*中身を非表示にしておく*/
.accbox .accshow {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.cssacc:checked + label + .accshow {
    height: auto;
    padding: 0;
    opacity: 1;
}

.accbox .accshow p {
    margin: 5px 10px;
    text-align: justify;
	text-justify: inter-ideograph;
}

/*アイコンを入れ替える*/
.cssacc:checked + label:before {
    content:"\f139";
}


@media (max-width:599px) {
	.item_ttl{padding:10px 38px 10px 10px;font-size: 16px;line-height: 1.4;}
}


@media (max-width:399px) {
	.item_ttl{font-size: 15px;padding-right: 25px;}
	.item_ttl span{font-size:90%;}
	.accbox label:before {font-size: 1.2em;}
}


/* -----アコーディオン　ここまで----- */











	.ytbox{max-width: 560px;margin: 30px auto;}
	.ytbox > div{position: relative; padding-bottom: 56.25%;}
	.ytbox iframe {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
	.ytarea{margin-top: 30px;}
	.ytarea h3 {margin-bottom: 30px;font-size: 2.5rem;font-weight: 500;text-align: center;}
	.ytarea h3 .txt_s {font-size: 75%;}
	.ytarea h3 .bold {font-weight: bold;}
	@media (max-width: 799px){
		.ytarea h3 {font-size: 5.5vw;}
	}
	@media (max-width: 499px){
		.ytarea h3 {font-size: 7vw;}
	}
	.call{margin-top: 50px;}
	.call dt{font-weight: normal;max-width: 360px;margin: 0 auto 15px;padding: 0.25em;color: #fff;line-height: 1.5;background: #e96da9;border-radius: 30px;}
	.call dd a:before{width: 0.6em;height: 0.75em;bottom: 0.15em;left:0.25em;}
	.call dd a{padding-left: 1em;}
	.call dd:last-of-type{margin-top: 5px;}
	@media (max-width: 499px){
		.call{margin-top:30px;}
	}
	
	:target:before { height: 120px; margin: -120px 0 0; content:""; display:block; }


#mainvisual::after { background: url(../images/main_visual_231226.png) no-repeat center center; background-size: cover; height: 100%; right: 0; width: 80vw; transform: none; top: 0;}
@media(max-width: 599px) {
	#mainvisual::after { background: url(../images/main_visual_231226_smt.png) no-repeat center center; background-size: cover; top: unset; bottom: 0; width: 70vw; height: 28vw;}
}
#courseArea .adff .list>li.results ul li{width: 100%;margin: 0 auto;max-width: 600px;}
#courseArea .adff .list>li.results ul li p{text-align: center;margin-top: 1em}
#courseArea .adff{background: #e9ffe3;}
#courseArea .parts{background: #FFF4E2;}

/* 新しいセクションの基本設定（既存セクションに合わせた余白など） */
#sctn_review_carousel {
    padding: 60px 0; /* PC版の上下の余白 */
    background: #f7f7f7; /* 必要に応じて背景色を設定 */
}

/* カルーセルコンテナの最大幅と中央寄せ */
#sctn_review_carousel .inner {
    max-width: 1000px; /* 他のセクションの幅に合わせるか、画像幅に合わせて調整 */
    margin-left: auto;
    margin-right: auto;
    padding: 0 20px; /* 左右の余白（特にスマホ用） */
}

/* カルーセル化するリスト（Slick適用前は初期化） */
.review__carousel_list {
    list-style: none;
    padding: 0;
    margin-top: 40px; /* 見出しとの間に余白 */
    width: 70%; 
    margin-left: auto;
    margin-right: auto;
}

/* カルーセル内の画像（元の比率 650x474 を維持しつつレスポンシブ対応） */
.review__carousel_list .carousel_img {
    width: 100%;
    height: auto;
    display: block; /* 画像下の余白を削除 */
}

/* Slickドットインジケーターのスタイル調整（前回のLPと統一） */
#sctn_review_carousel .slick-dots {
    bottom: -40px; /* ドットの位置を調整 */
}

#sctn_review_carousel .slick-dots li button:before {
    font-size: 12px;
    color: #008080; /* ドットの色をテーマカラーに合わせる（例） */
    opacity: 0.5;
}

#sctn_review_carousel .slick-dots li.slick-active button:before {
    color: #008080; /* アクティブ時のドットの色 */
    opacity: 1;
}

/* --- レスポンシブ対応 (例: スマートフォン向け) --- */
@media screen and (max-width: 768px) {
    #sctn_review_carousel {
        padding: 30px 0; /* スマホ版の上下の余白を減らす */
    }

    /* .secttl のスマホ用調整があればここに記述 */
}

/* --- レスポンシブ対応 (スマートフォン向け) --- */
@media screen and (max-width: 768px) {
    /* スマホ表示では幅を90%にする、または100%にして中央寄せを解除する */
    .review__carousel_list {
        width: 90%; 
        /* margin: 0 auto; はPCの設定が引き継がれます */
    }
}