@charset "utf-8";

/* -----------------------------
	.intro-area
-------------------------------- */
.intro-area {
	position: relative;
	padding: 60px 0;
	margin: 100px 0 0;
}

.intro-area::before {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	right: 10%;
	width: 0;
	height: 100%;
	background: var(--palegreen);
	transition: all 4s;
    z-index: -1;
}

.intro-area.sideAppear.active::before {
	width: 60%;
}

@media screen and (min-width: 769px) and (max-width: 1600px ) {
	.intro-area.sideAppear.active::before {
		right: 0;
		min-width: 500px;
	}
}

.intro-area .inner {
	width: calc( 100% - calc( ( 100% - 1200px ) / 2 ) );
	margin-right: calc( ( 100% - 1200px ) / 2 );
	display: flex;
	justify-content:flex-end;
	align-items: center;
	gap: 5%;
}

.intro-area .txt-wrap {
	width: 46%;
	min-width: 600px;
    position: relative;
    z-index: 1;
}

.intro-area .txt-wrap .basic-txt + .basic-txt {
    margin-top: 10px;
}

.intro-area .movie-wrap {
	position: relative;
	width: 54%;
	min-width: 500px;
}

.intro-area .movie-wrap .thumb {
	width: 100%;
}

.intro-area .movie-wrap .thumb img {
	width: 100%;
	object-fit: cover;
}

.intro-area .movie-wrap .movie-btn {
	width: 100%;
	height: 100%;
	cursor: pointer;
	position: absolute;
	top: 0;
	left: 0;
}

.intro-area .movie-wrap .movie-btn img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

@media screen and (max-width: 768px){
	.intro-area {
		padding: 30px 0;
		margin: 0;
	}
	
	.intro-area::before {
		bottom: 0;
		right: 0;
		width: 70%;
		height: 200px;
	}
	
	.intro-area::after {
		font-size: 7.4rem;
		font-weight: 500;
		top: -60px;
	}
	
	.intro-area .inner {
		width: 100%;
		margin-left: 0;
		flex-wrap: wrap;
		gap: 0;
		padding: 0 20px;
	}
	
	.intro-area .movie-wrap {
		width: 100%;
		min-width: initial;
		order: 2;
		margin: 20px 0 0;
	}
	
	.intro-area .movie-wrap .movie-btn img {
		aspect-ratio: 1/1;
		width: 110px;
	}
	
	.intro-area .txt-wrap {
		display: contents;
	}
	
	.intro-area .catch-l {
		order: 1;
		font-size: 2.3rem;
		width: 100%;
		text-align: center;
		letter-spacing: -.1rem;
		font-feature-settings: initial;
	}
	
	.intro-area .basic-txt {
		order: 3;
	}
}


/* -----------------------------
	course-detail-area
-------------------------------- */
.course-detail-area {
	padding: 100px 0 0;
    counter-reset: counter;
}

.course-detail-area .ttl-block {
	text-align: center;
}

.course-detail-area .anchor-list {
	display: flex;
	justify-content: center;
	gap: 10px;
}

.course-detail-area .anchor-list li {
	width: calc( ( 100% - 50px ) / 6 );
}

.course-detail-area .anchor-list li a {
	display: block;
	position: relative;
	bottom: 0;
	box-shadow: 0 0 20px rgba(0,0,0,.1);
}

.course-detail-area .anchor-list li a:hover {
	box-shadow: none;
	bottom: -10px;
	opacity: .8;
}

.course-detail-area .anchor-list li .anchor-img {
	width: 100%;
	height: 120px;
}

.course-detail-area .anchor-list li .anchor-img img {
	width: 100%;
	height: 120px;
	object-fit: cover;
}

.course-detail-area .anchor-list li .anchor-txt {
	padding: 15px 10px 5px;
	line-height: 1.4;
	text-align: center;
	font-weight: bold;
	background: var(--palegreen);
	position: relative;
	font-size: 1.3rem;
	font-feature-settings: "palt";
}

.course-detail-area .anchor-list li .anchor-txt::after {
	content: "\f107";
	display: inline-block;
	position: relative;
	font-size: 1.3rem;
	color: var(--green);
	width: 100%;
	text-align: center;
}

.course-detail-area .course-block {
	margin: 100px 0 0;
	/*background: #F5FCFC;*/
	padding: 0 0 100px;
	position: relative;
}

.course-detail-area .course-block::before {
	content: "";
	display: block;
	position: absolute;
	top: 100px;
	height: calc( 100% - 100px );
	width: 90%;
	min-width: 1400px;
	background: #F5FCFC;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
}

.course-detail-area .course-block.support::before {
	background: #FAFCF5;
}

.course-detail-area .course-block .bg-ttl-wrap {
	width: 100%;
	display: flex;
	align-items: flex-start;
	margin: 0 0 60px;
}

.course-detail-area .course-block .ttl-wrap {
	padding-top: 180px;
	padding-left: calc( ( 100% - 1200px ) / 2 );
	width: 54%;
}

.course-detail-area .course-block .price-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--green);
    width: 580px;
    margin-top: 40px;
    font-weight: bold;
    font-family: var(--mincho);
}

.course-detail-area .course-block .price-wrap .price {
    font-size: 1.7rem;
}

.course-detail-area .course-block .price-wrap .price-num .large {
    font-size: 4.0rem;
    line-height: 1;
}

/*カッコつき数字リスト*/
.course-detail-area .num-list {
	font-size: 1.6rem;
	margin: 20px 0 0;
	/*counter-reset: counter;*/
}

.course-detail-area .num-list li {
	line-height: 1.7;
	position: relative;
	padding-left: 25px;
}

.course-detail-area .num-list li::before {
	counter-increment: counter 1;
	content:  counter(counter) ".";
	font-family: var(--basefont);
	font-weight: 400;
	position: absolute;
	left: 0;
	top: 0;
}

.course-detail-area .num-list li + li {
	margin: 10px 0 0;
}

.course-detail-area .course-block .bg-wrap {
	width: 46%;
	height: 540px;
}

.course-detail-area .course-block .bg-wrap img {
	width: 100%;
	height: 540px;
	object-fit: cover;
}

.course-detail-area .course-block .inner {
	position: relative;
}

.course-detail-area .course-block .en {
	font-size: 12rem;
	font-family: var(--en);
	color: #DCF3F4;
	line-height: 1;
	position: absolute;
	top: 0;
	left: calc( calc( (100% - 1200px ) / 2 ) - 30px );
	margin-left: -40px;
}

.course-detail-area .course-block.support .en {
	color: #F4F0DC;
}

.course-detail-area .course-block .course-ttl {
	font-size: 4.2rem;
	font-family: var(--mincho);
	line-height: 1.6;
	/*margin: 50px 0 0;*/
    margin: 0 0 40px;
}

.course-detail-area .course-block .catch {
	font-size: 2.8rem;
	font-family: var(--mincho);
	line-height: 1.6;
	margin: 20px 0 20px;
}

.course-detail-area .course-block .basic-txt {
	max-width: 580px;
	/*min-height: 200px;*/
}

.course-detail-area .course-block .h5-ttl {
	font-size: 2.4rem;
	font-family: var(--mincho);
	padding: 0 0 10px;
	border-bottom: 1px solid var(--green);
	line-height: 1.6;
	margin: 60px 0 30px;
}

.course-detail-area .course-block.support .h5-ttl {
	border-bottom: 1px solid #E8D784;
}

.course-detail-area .course-block .h5-ttl span {
	position: relative;
	display: inline-block;
}

.course-detail-area .course-block .h5-ttl span::before {
	content: "";
	display: inline-block;
	position: absolute;
	right: -20px;
	top: 3px;
	width: 0;
	height: 0;
	border-style: solid;
	border-right: 7px solid transparent;
	border-left: 7px solid transparent;
	border-top: 14px solid #E8D784;
	border-bottom: 0;
	transform: rotate(30deg);
}

.course-detail-area .course-block .h5-ttl span::after {
	content: "";
	display: inline-block;
	position: absolute;
	right: -25px;
	top: 16px;
	width: 0;
	height: 0;
	border-style: solid;
	border-right: 5px solid transparent;
	border-left: 5px solid transparent;
	border-top: 10px solid var(--green);
	border-bottom: 0;
	transform: rotate(90deg);
}

.course-detail-area .course-block .square-list {
	display: flex;
	justify-content: flex-start;
	gap: 20px;
	flex-wrap: wrap;
}

.course-detail-area .course-block .square-list li {
	padding-left: 20px;
	position: relative;
	font-size: 1.6rem;
	line-height: 1.5;
}

.course-detail-area .course-block .square-list li::before {
	content: "◆";
	display: inline-block;
	position: absolute;
	top: 1px;
	left: 0;
	font-size: 1.6rem;
	color: var(--green);
	line-height: 1.2;
}

.course-detail-area .course-block .check-list {
	display: flex;
	justify-content: flex-start;
	gap: 20px;
	flex-wrap: wrap;
}

.course-detail-area .course-block .check-list li {
	padding-left: 23px;
	position: relative;
	font-size: 1.7rem;
	line-height: 1.5;
	font-weight: bold;
}

.course-detail-area .course-block .check-list li::before {
	content: "\f14a";
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	font-weight: 400;
	font-size: 2.0rem;
	color: var(--green);
	line-height: 1.2;
}

.course-detail-area .course-block .icon-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 20px;
}

.course-detail-area .course-block .icon-list li {
	width: calc( ( 100% - 40px ) / 3 );
	padding: 30px 15px;
	text-align: center;
	background: #fff;
	box-shadow: 0 0 30px rgba(221,245,245,1);
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

.course-detail-area .course-block .icon-list  .icon-wrap {
	/*width: 100px;
	height: 100px;
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--palegreen);
	border-radius: 50px;*/
}

.course-detail-area .course-block .icon-list li .icon-txt {
	font-size: 1.6rem;
	margin: 20px 0 0;
	font-weight: bold;
	width: 100%;
}

.course-detail-area .course-block .voice-list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 30px;
}

.course-detail-area .course-block .voice-list li {
	padding: 30px;
	width: calc( ( 100% - 30px ) / 2 );
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 30px;
	background: #fff;
	box-shadow: 0 0 30px rgba(221,245,245,1);
}

#support .voice-list li {
	box-shadow: 0 0 30px rgba(207,157,67,.1);
}

.course-detail-area .course-block .voice-list li .voice-img {
	width: 100px;
	height: 100px;
}

.course-detail-area .course-block .voice-list li .voice-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.course-detail-area .course-block .voice-list li .voice-txt {
	width: calc( 100% - 130px );
}

.course-detail-area .course-block .voice-list li .voice-name {
	font-weight: bold;
}

.course-detail-area .seminar-box {
	width: 100%;
	display: block;
}

.course-detail-area .seminar-box + .seminar-box {
	margin: 40px 0 0;
}

.course-detail-area .seminar-box a {
	display: flex;
	padding: 40px;
	width: 100%;
	gap: 40px;
	position: relative;
	border: 1px solid #fff;
	right: 0;
	background: #fff;
	box-shadow: 0 0 30px rgba(221,245,245,1);
}

.course-detail-area .seminar-box .img-wrap {
	width: 380px;
	height: 260px;
}

.course-detail-area .seminar-box .img-wrap img {
	object-fit: cover;
	width: 100%;
	height: 260px;
}

.course-detail-area .seminar-box .txt-wrap {
	width: calc( 100% - ( 380px + 40px ) );
}

.course-detail-area .seminar-box .arrow {
	position: absolute;
	bottom: 40px;
	right: 40px;
	content: "";
	display: inline-block;
	width: 60px;
	height: 1px;
	background: #bbb;
	transition: all .4s;
}

.course-detail-area .seminar-box .arrow::before {
	content: "";
	display: inline-block;
	position: absolute;
	right: 0;
	top: -4px;
	width: 10px;
	height: 1px;
	background: #bbb;
	transition: all .4s;
	transform: rotate(45deg);
}

.course-detail-area .seminar-box .tag-list {
	display: flex;
	gap: 5px;
	flex-wrap: wrap;
}

.course-detail-area .seminar-box .tag-list li {
	font-size: 1.4rem;
	line-height: 1.3;
	padding: 5px 10px;
	color: var(--green);
	border: 1px solid var(--green);
	font-weight: bold;
}

.course-detail-area .seminar-box .seminar-ttl {
	font-size: 2.0rem;
	font-weight: bold;
	background: var(--palegreen);
	line-height: 1.6;
	padding: 10px 20px;
	margin: 20px 0 0;
}

.course-detail-area .seminar-box .seminar-table {
	margin: 20px 0 0;
}

.course-detail-area .seminar-box .seminar-table th {
	width: 22%;
	vertical-align: text-top;
	padding: 7px 0;
	line-height: 1.5;
	font-weight: 500;
}

.course-detail-area .seminar-box .seminar-table th i {
	color: var(--green);
	display: inline-block;
	min-width: 20px;
}

.course-detail-area .seminar-box .seminar-table td {
	width: 78%;
	padding: 7px 0;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 500;
}

.course-detail-area .seminar-box .seminar-table tr:first-child td {
	font-size: 2.1rem;
	line-height: 1;
}

.course-detail-area .service-list {
	display: flex;
	gap: 30px;
	justify-content: space-between;
}

.course-detail-area .service-list li {
	width: calc( ( 100% - 60px ) / 3 );
	background: #fff;
	box-shadow: 0 0 30px rgba(244,240,220,1);
}

.course-detail-area .service-list li .service-name {
	width: 100%;
	padding: 15px;
	line-height: 1.5;
	font-size: 1.8rem;
	font-weight: bold;
	background: var(--green);
	color: #fff;
	text-align: center;
	height: 60px;
}
.course-detail-area .service-list li .txt-wrap {
	padding: 10px 20px;
	text-align: center;
	justify-content: center;
	align-items: center;
	align-content: center;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	height: calc( 100% - 60px );
}

.course-detail-area .service-list li .type-wrap {
	padding: 20px 0;
	width: 100%;
	position: relative;
}

.course-detail-area .service-list li .type-wrap + .type-wrap {
	border-top: 1px solid var(--green);
}

.course-detail-area .service-list li .type {
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.5;
	margin: 0 0 5px;
}

.course-detail-area .service-list li .cost {
	font-weight: bold;
}

.course-detail-area .service-list li .cost.green {
	color: var(--green);
}

.course-detail-area .service-list li .cost .num {
	color: var(--green);
	font-weight: bold;
	font-size: 3.0rem;
	display: inline-block;
	margin: 0 3px 0 0;
	line-height: 1;
}

.course-detail-area .service-list li .type-wrap .circle {
	position: absolute;
	width: 70px;
	height: 70px;
	background: #E18F7E;
	color: #fff;
	font-weight: bold;
	line-height: 1.3;
	font-size: 1.2rem;
	text-align: center;
	border-radius: 35px;
	display: flex;
	justify-content: center;
	align-items: center;
	top: 50%;
	transform: translateY(-50%);
	right: 10px;
}

.course-detail-area .list-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	--main: #00A5CD;
	gap: 30px;
}

.course-detail-area .list-box {
	width: calc( ( 100% - 30px ) / 2 );
}

.course-detail-area .list-box:nth-child(2) {
	--main: #CF9D43;
}

.course-detail-area .list-box:nth-child(3) {
	--main: var(--green);
}

.course-detail-area .list-box.full {
	width: 100%;
}

.course-detail-area .list-box .list-ttl {
	color: #fff;
	background: var(--main);
	padding: 15px 20px;
	width: 100%;
	text-align: center;
	font-size: 2.1rem;
	font-weight: bold;
	line-height: 1.5;
	position: relative;
	z-index: 1;
}

.course-detail-area .list-box .table-list {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	justify-content: space-between;
	background: #fff;
	padding: 20px 0;
	box-shadow: 0 0 30px rgba(221,245,245,1);
}

.course-detail-area .list-box .table-list li {
	width: calc( 100% / 3 );
	text-align: center;
	padding: 20px 20px;
	position: relative;
	z-index: 1;
}

.course-detail-area .list-box .table-list li:nth-child(2)::before,
.course-detail-area .list-box .table-list li:nth-child(3)::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	background: #ccc;
	width: 1px;
	height: 70%;
}

.course-detail-area .list-box .table-list .curriculum {
	width: 100%;
}

.course-detail-area .list-box .table-list .list-name {
	font-size: 1.8rem;
	line-height: 1.6;
}

.course-detail-area .list-box .table-list p {
	font-weight: bold;
}

.course-detail-area .list-box .table-list .accent {
	color: var(--main);
	font-size: 3.0rem;
}

.course-detail-area .list-box .table-list .accent02 {
	color: var(--main);
	font-size: 2.1rem;
}

.course-detail-area .list-box .table-list .curriculum .list-name {
	position: relative;
	margin: 0 0 10px;
	z-index: 1;
}

.course-detail-area .list-box .table-list .curriculum .list-name span {
	background: #fff;
	display: inline-block;
	z-index: 3;
	position: relative;
	padding: 0 20px;
}

.course-detail-area .list-box .table-list .curriculum .list-name::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 12px;
	width: 100%;
	height: 1px;
	left: 0;
	background: var(--main);
}

#support .list-wrap .list-box:first-child {
	width: 700px;
}

#support .list-box:first-child .table-list li {
	width: 50%;
}

#support .list-wrap .list-box:nth-child(2) {
	width: 470px;
}

#support .list-box .table-list {
	box-shadow: 0 0 30px rgba(207,157,67,.1);
}

#support .list-wrap .list-box:nth-child(3) .table-list li {
	width: calc( 510px / 3 );
	padding: 20px 15px;
}

#support .list-wrap .list-box:nth-child(3) .table-list li:last-child {
	width: calc( 100% - 510px );
	line-height: 2.0;
	font-weight: 500;
	text-align: left;
	padding: 20px 30px;
}

#support .list-wrap .list-box:nth-child(3) .table-list li:nth-child(4)::before {
	content: "";
    display: inline-block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    background: #ccc;
    width: 1px;
    height: 70%;
}

#support .list-box .circle {
	position: absolute;
	right: 35px;
	top: 15%;
	background: #E18F7E;
	color: #fff;
	font-size: 1.2rem;
	text-align: center;
	line-height: 1.2;
	font-weight: bold;
	width: 70px;
	height: 70px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 35px;
} 

#support .list-box .table-list li.full {
	width: 100%;
}



/*ホバーエフェクトPCのみ*/
@media screen and (min-width: 769px){
	.course-detail-area .seminar-box a:hover {
		border: 1px solid var(--green);
		right: -15px;
		opacity: .8;
	}
	
	.course-detail-area .seminar-box a:hover .arrow,
	.course-detail-area .seminar-box a:hover .arrow::before {
		background: var(--green);
	}
	
}

@media screen and (max-width: 768px){
	.course-detail-area {
		padding: 40px 0 0;
	}
	
	.course-detail-area .ttl-block .en {
		font-size: 3.4rem;
		letter-spacing: .2rem;
	}
	
	.course-detail-area .anchor-list {
		flex-wrap: wrap;
	}
	
	.course-detail-area .anchor-list li {
		width: calc( ( 100% - 10px ) / 2 );
	}
	
	.course-detail-area .anchor-list li .anchor-img {
		width: 100%;
		height: 20vw;
	}
	
	.course-detail-area .anchor-list li .anchor-img img {
		width: 100%;
		height: 100%;
	}
	
	.course-detail-area .anchor-list li .anchor-txt {
		padding: 12px 5px 5px;
		line-height: 1.4;
		text-align: center;
		font-weight: bold;
		background: var(--palegreen);
		position: relative;
		font-size: 1.4rem;
		font-feature-settings: "palt";
	}
	
	.course-detail-area .course-block {
		margin: 40px 0 0;
		padding: 0 0 50px;
	}
	
	.course-detail-area .course-block::before {
		top: 50px;
		height: calc( 100% - 50px );
		width: 100%;
		min-width: initial;
	}
	
	.course-detail-area .course-block .en {
		/*margin-left: -10px;
		margin-top: -30px;*/
		font-size: 10rem;
		letter-spacing: .3rem;
		white-space: nowrap;
		z-index: 1;
        top: 48vw;
        left: 20px;
        margin-left: 0;
	}
    
    .course-detail-area .course-block.support .en {
        font-size: 7.0rem;
        top: 54vw;
    }
	
	.course-detail-area .course-block .bg-ttl-wrap {
		flex-wrap: wrap;
		margin: 0 0 30px;
	}
	
	.course-detail-area .course-block .ttl-wrap {
		padding: 60px 20px 0;
		width: 100%;
		order: 2;
	}
	
	.course-detail-area .course-block .bg-wrap {
		width: 94%;
		height: 50vw;
		top: -50px;
		order: 1;
	}
	
	.course-detail-area .course-block .bg-wrap img {
		width: 100%;
		height: 50vw;
	}
	
	.course-detail-area .course-block .course-ttl {
		font-size: 2.6rem;
		z-index: 2;
		position: relative;
		/*margin: 10px 0 0;*/
        margin: 0 0 30px;
	}
	
	.course-detail-area .course-block .catch {
		font-size: 2.0rem;
		margin: 10px 0 15px;
		font-feature-settings: initial;
		letter-spacing: 0;
	}
	
	.course-detail-area .course-block .basic-txt {
		min-height: initial;
	}

	.course-detail-area .course-block .h5-ttl {
		font-size: 1.9rem;
		margin: 30px 0 20px;
		letter-spacing: 0;
	}
    
    .course-detail-area .course-block .price-wrap {
        width: 100%;
        margin-top: 20px;
    }
    
    .course-detail-area .course-block .price-wrap .price-num .large {
        font-size: 3.0rem;
        line-height: 1;
    }
	
	.course-detail-area .course-block .check-list {
		gap: 15px;
	}
	
	.course-detail-area .course-block .check-list li {
		font-size: 1.6rem;
	}
	
	.course-detail-area .course-block .check-list li::before {
		font-size: 1.8rem;
		top: 1px;
	}
    
    .course-detail-area .num-list {
		margin: 15px 0 0;
	}
	
	.course-detail-area .course-block .square-list {
		gap: 15px;
	}
	
	.course-detail-area .course-block .icon-list {
		flex-wrap: wrap;
		gap: 10px;
	}
	
	.course-detail-area .course-block .icon-list li {
		width: 100%;
		padding: 20px 15px;
	}
	
	.course-detail-area .course-block .icon-list  .icon-wrap {
		width: 50px;
	}
	
	.course-detail-area .course-block .icon-list  .icon-wrap img {
		width: 100%;
		object-fit: cover;
	}
	
	.course-detail-area .course-block .icon-list li .icon-txt {
		font-size: 1.5rem;
		margin: 0;
		width: calc( 100% - 50px );
		text-align: left;
		padding-left: 20px;
	}
	
	.course-detail-area .course-block .voice-list {
		gap: 20px;
	}
	
	.course-detail-area .course-block .voice-list li {
		padding: 20px;
		width: 100%;
		gap: 10px 20px;
		align-items: flex-start;
		justify-content: center;
		flex-wrap: wrap;
	}

	.course-detail-area .course-block .voice-list li .voice-img {
		width: 80px;
		height: 80px;
	}
	
	.course-detail-area .course-block .voice-list li .voice-name {
		text-align: center;
		width: 100%;
		display: inline-block;
	}
	
	.course-detail-area .course-block .voice-list li .voice-txt {
		width: 100%;
	}
	
	.course-detail-area .seminar-box + .seminar-box {
		margin: 0;
	}
	
	.course-detail-area .sp-wrap {
		width: 100%;
		overflow-x: scroll;
	}
	
	.course-detail-area .seminar-block {
		width: fit-content;
		display: flex;
		gap: 20px;
		padding: 0 0 20px;
	}
	
	.course-detail-area .seminar-box {
		width: auto;
		width: 340px;
		
	}
	
	.course-detail-area .seminar-box a {
		padding: 20px;
		gap: 15px;
		flex-wrap: wrap;
	}
	
	.course-detail-area .seminar-box .img-wrap {
		width: 100%;
		max-height: initial;
		height: 40vw;
	}
	
	.course-detail-area .seminar-box .img-wrap img {
		height: 100%;
	}
	
	.course-detail-area .seminar-box .txt-wrap {
		width: 100%;
	}
	
	.course-detail-area .seminar-box .seminar-ttl {
		font-size: 1.8rem;
		margin: 15px 0 0;
		padding: 10px 15px;
	}
	
	.course-detail-area .seminar-box .tag-list li {
		font-size: 1.3rem;
		padding: 4px 8px;
	}
	
	.course-detail-area .seminar-box .seminar-table {
		margin: 15px 0 0;
	}
	
	.course-detail-area .seminar-box .seminar-table th {
		width: 100%;
		padding: 5px 0;
		display: block;
		border-bottom: 1px solid var(--green);
		text-align: left;
	}
	
	.course-detail-area .seminar-box .seminar-table td {
		width: 100%;
		padding: 8px 0 10px;
		display: block;
		font-size: 1.5rem;
	}
	
	.course-detail-area .seminar-box .seminar-table tr:first-child td {
		font-size: 1.7rem;
		line-height: 1.5;
	}
	
	.course-detail-area .seminar-box .arrow {
		bottom: 20px;
		right: 20px;
		width: 40px;
	}
	
	.course-detail-area .seminar-box .arrow::before {
		top: -3px;
		width: 8px;
	}
	
	.course-detail-area .service-list {
		gap: 20px;
		flex-wrap: wrap;
	}
	
	.course-detail-area .service-list li {
		width: 100%;
	}
	
	.course-detail-area .service-list li .service-name {
		padding: 12px;
		font-size: 2.0rem;
		height: initial;
	}
	
	.course-detail-area .service-list li .txt-wrap {
		padding: 10px 20px;
		height: initial;
	}
	
	.course-detail-area .service-list li .type {
		font-size: 1.8rem;
	}
	
	.course-detail-area .service-list li .cost {
		font-size: 1.5rem;
	}
	
	.course-detail-area .service-list li .cost .num {
		font-size: 2.8rem;
	}
	
	.course-detail-area .service-list li .type-wrap .circle {
		right: 0;
	}
	
	.course-detail-area .list-wrap {
		flex-wrap: wrap;
		width: 100%;
		margin: 30px 0 0;
		gap: 20px;
	}
	
	.course-detail-area .list-box {
		width: 100%;
	}
	
	#support .list-box .circle {
		width: initial;
		height: initial;
		right: initial;
		top: initial;
		font-size: 1.4rem;
		border-radius: 0;
		line-height: 1.8;
		padding: 0 15px;
		border-radius: 20px;
		display: inline-block;
		white-space: nowrap;
		position: relative;
	}
	
	#support .list-wrap .list-box:nth-child(3) .table-list li {
		width: calc( 100% / 3 );
		padding: 20px 0;
	}
	
	#support .list-wrap .list-box:nth-child(3) .table-list li:last-child {
		width: 100%;
		padding: 0 20px 30px;
	}
	
	#support .list-wrap .list-box:nth-child(3) .table-list li:nth-child(4)::before {
		display: none;
	}

	.course-detail-area .list-box .list-ttl {
		padding: 10px 10px;
		font-size: 1.7rem;
		font-feature-settings: "palt";
		letter-spacing: 0;
	}
	
	.course-detail-area .list-box .table-list {
		padding: 0;
	}
	
	.course-detail-area .list-box .table-list li {
		padding: 20px 5px;
	}
	
	.course-detail-area .list-box .table-list .list-name {
		font-size: 1.6rem;
	}
	
	.course-detail-area .list-box .table-list .accent {
		font-size: 1.8rem;
		letter-spacing: 0;
	}
	
	.course-detail-area .list-box .table-list p {
		font-size: 1.3rem;
	}
	
	.course-detail-area .list-box .table-list .curriculum {
		padding: 0 10px 20px;
	}

}

/* -----------------------------
	service-area
-------------------------------- */
.service-area {
	padding: 100px 0;
	background: #ccc;
}

@media screen and (max-width: 768px){
	
}

/* -----------------------------
	discount-area
-------------------------------- */
.discount-area {
    padding: 80px 0 0;
}

.discount-area .discount-block {
    padding: 60px 0;
    border-top: 2px solid var(--green);
    border-bottom: 2px solid var(--green);
    display: flex;
    flex-wrap: wrap;
    gap: 40px 60px;
    text-align: center;
    justify-content: center;
}

.discount-area .block-ttl {
    font-family: var(--mincho);
    font-size: 4.0rem;
    /*margin-bottom: 20px;*/
}

.discount-area .block-ttl .min {
    background: var(--green);
    color: #fff;
    font-size: 2.1rem;
    font-weight: bold;
    font-family: var(--mincho);
    display: inline-block;
    padding: 10px 20px;
    margin: 0 0 20px;
    border-radius: 30px;
}

.discount-area .discount-box {
    --main: var(--green);
    width: calc( ( 100% - 60px ) / 2 );
    border: 1px solid var(--main);
}

.discount-area .discount-box.complate {
    --main: #CF9D43;
}

.discount-area .discount-box .box-ttl {
    background: var(--main);
    color: #fff;
    padding: 15px;
    text-align: center;
    font-size:2.4rem;
    font-family: var(--mincho);
    line-height: 1.5;
    font-weight: bold;
}

.discount-area .discount-box .price-wrap {
    padding: 30px;
    position: relative;
}

.discount-area .discount-box .price {
    font-family: var(--mincho);
    line-height: 1.3;
    font-size: 2.4rem;
    position: relative;
}

.discount-area .discount-box .price .large {
    font-size: 4.0rem;
    color: var(--red);
}

.discount-area .discount-box .arrow {
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-top: 20px solid var(--main);
    border-bottom: 0;
    margin: 15px auto;
}

.discount-area .discount-box .fukidashi {
    position: absolute;
    right: 50px;
    bottom: 30px;
    background: var(--red);
    color: #fff;
    width: 90px;
    height: 90px;
    color: #fff;
    /*font-family: var(--mincho);*/
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1.3;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 45px;
}

.discount-area .discount-box .fukidashi::before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-bottom: 17px solid var(--red);
    border-top: 0;
    transform: rotate(237deg);
    position: absolute;
    left: -7px;
    bottom: 12px;
}

@media screen and (max-width: 768px){
	.discount-area {
        padding: 40px 0 0;
    }
    
    .discount-area .discount-block {
        padding: 30px 0;
        gap: 30px;
    }
    
    .discount-area .block-ttl {
        font-size: 2.8rem;
        line-height: 1.6;
    }
    
    .discount-area .block-ttl .min {
        font-size: 1.6rem;
        padding: 8px 20px 5px;
        margin: 0 0 10px;
    }
    
    .discount-area .basic-txt {
        text-align: left;
    }
    
    .discount-area .discount-box {
        width: 100%;
    }
    
    .discount-area .discount-box .box-ttl {
        padding: 10px;
        font-size: 2.0rem;
    }
    
    .discount-area .discount-box .price-wrap {
        padding: 20px;
    }
    
    .discount-area .discount-box .price {
        font-size: 1.8rem;
        display: inline-block;
    }
    
    .discount-area .discount-box .price .large {
        font-size: 3.6rem;
    }
    
    .discount-area .discount-box .arrow {
        border-right: 10px solid transparent;
        border-left: 10px solid transparent;
        border-top: 12px solid var(--main);
        margin: 10px auto;
    }
    
    .discount-area .discount-box .fukidashi {
        right: -54%;
        bottom: 60px;
        width: 70px;
        height: 70px;
        font-size: 1.3rem;
        border-radius: 45px;
    }
}

/* -----------------------------
	faq-area
-------------------------------- */
.faq-area {
	padding: 100px 0;
	background: #eee;
}

@media screen and (max-width: 768px){
	
}


/* -----------------------------
	〇〇〇
-------------------------------- */

@media screen and (max-width: 768px){
	
}
