@charset "utf-8";

/* Contents
 * ****************************
 * campaign ONLY
 * ****************************
 */

div, span, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark {
    font-family: "Noto Sans JP", 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-weight: 400;
}
body {
	color: #242422;
}
a:hover {
	opacity: 1;
}
h2 {
	font-size: 2rem;
}
h3 {
	font-size: 1.5rem;
}
h4 {
	font-size: 1.2rem;
	margin-bottom: 1rem;
	margin-top: 0;
}
p {
	line-height: 2.1rem;
}
br {
	line-height: initial;
}
.red {
	color: #ff8f00!important;
}
.blue {
	color: #61a3d5;
}
div[id^="pos"] {
	padding-top: 0px;
}
.mag_bt100 {
	margin-bottom: 100px;
}
.m_auto {
	margin: auto;
}
.v_top {
	vertical-align: top;
}
.v_middle {
	vertical-align: middle;
}
.v_bottom {
	vertical-align: bottom;
}
.menu_wrap {
	background-image: url("/dokushuzemi/fe/img/menu-back.png");
	box-shadow: 0px 0px 5px rgba(0,0,0,0.4);
}
.menu_pc {
	height: 100px;
	margin-left: 0;
	margin-right: 20px;
}
.menu_pc .col {
	margin-bottom: 0;
	vertical-align: middle;
}
.title-smp {
	display: none;
}
.menu_pc .col.title {
	height: 80px;
	margin: auto auto auto 20px;
	min-width: 360px;
	width: 40%;
}
.menu_pc .col.title .table-cell {
	vertical-align: middle;
}
.menu_pc .col.title .table-cell p {
	font-size: 20px;
	margin: 0;
        white-space: nowrap;
}       
.menu_pc .col span {
	font-size: 20px;
	vertical-align: middle;
}
.menu_pc ul {
	font-size: 0;
	height: 40px;
	text-align: right;
	width: 100%;
}
.menu_pc li {
	display: inline-block;
	font-size: 16px;
	height: auto;
	width: auto;
}
.menu_pc li a {
	background: none;
	border-radius: 0;
	color: #242422;
	line-height: 50px;
	margin: 0 10px;
}
.menu_pc li a:hover {
	border-bottom: solid 3px #22b1dd;
}
.menu_pc a.ptn2 {
	background-color: #3fc9f3!important;
	background-image: none;
	border: none;
	color: #fff;
	padding: 5px 20px;
	transition: .3s;
}
.menu_pc a.ptn2:hover {
	background-color: #22b1dd!important;
}
.menu_pc a.ptn2.document-request {
	background-color: #ffa52e!important;
	background-image: none;
}
.menu_pc a.ptn2.document-request:hover {
	background-color: #e68e1b!important;
	background-image: none;
}
.eye_catch {
	height: 450px;
	background: #EEEEEE;
	position: relative;
        //margin-top:80px;
}
.eye_catch_mask {
	background-color: rgba(255, 255, 255, .70);
	z-index: 1;
	pointer-events: none;
}
.eye_catch_text_block {
	padding: 0px 140px 0;
	text-align: left;
	vertical-align: top;
	z-index: 10;
}
.eye_catch_bottom_block {
	z-index: 10;
        margin-left: 60px;
}
.eye_catch .txt-1 {
	height: 330px;
	margin-top: 80px;
	text-align: left;
	text-shadow: none;
}
.eye_catch .txt-1 .btn-ptn2 {
	margin-top: 50px;
} 
.eye_catch .txt-1 .btn-ptn2 a {
	width: 400px;
} 
.eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.campaign {
	color: #242422;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 2.5rem;
	margin-bottom: 50px;
	text-shadow: none;
}

.eye_catch .txt-1 p.campaign {
	font-size: 1.7rem;
}
.eye_catch .txt-1 p.ttl{
	color: #242422;
	font-size: 2.5rem;
	font-weight: 400;
	text-shadow: none;
}
.eye_catch ul {
	margin: auto;
	margin-left: 50px;
	margin-top: 50px;
	max-width: 600px;
	padding: 0;
	padding-top: 50px;
	position: relative;
}
.eye_catch ul li {
	border-bottom: dashed 2px #242422;
	color: #242422;
	font-size: 1.6rem;
	font-weight: bold; /*好みで太字に*/
	line-height: 1.5;
	list-style-type: none!important;
	margin-bottom: 50px;
	padding: 0.3em 0.5em 0.3em 2em;
}
.eye_catch ul li::before {
	color: #242422;
	content: "✔";
	left : 0.5em; /*左端からのアイコンまでの距離*/
	position: absolute;
}
.table-cell.hayawari {
	background-image: url(/dokushuzemi/fe/img/top-image.png);
	background-position: center;
	background-repeat: no-repeat;
}

.top-image {
        background-image: url(/dokushuzemi/fe/img/top-image.png);
        background-size: 300px auto;
        background-position: right 10% bottom 15%;
        background-repeat: no-repeat;
}

.eye_catch .hayawari .txt-1 {
	padding: 0px 20%;
	vertical-align: middle;
}
.eye_catch .hayawari .txt-1 p {
	background-color: rgba(130, 130, 130, 0.7);
	font-size: 28px;
	line-height: 45px;
	padding: 20px;
	text-align: center;
}
/* .eye_catch .txt-1 .btn-ptn2系スタイルはstyle.cssで一元管理するため削除 */
/* .eye_catch .txt-1 .btn-ptn2 {
	margin-top: 50px;
} 
.eye_catch .txt-1 .btn-ptn2 a {
	width: 400px;
} */ 
/* .eye_catch .txt-1 p系スタイルはstyle.cssで一元管理するため削除 */
/* .eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.campaign {
	color: #333333;
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 2.5rem;
	margin-bottom: 50px;
	text-shadow: none;
}

.eye_catch .txt-1 p.campaign {
	font-size: 1.7rem;
}
.eye_catch .txt-1 p.ttl{
	color: #333333;
	font-size: 2rem;
	font-weight: 400;
	text-shadow: none;
} */
/* .eye_catch ul系スタイルはstyle.cssで一元管理するため削除 */
/* .eye_catch ul {
	margin: auto;
	margin-left: 50px;
	margin-top: 50px;
	max-width: 600px;
	padding: 0;
	padding-top: 50px;
	position: relative;
} */
/* .eye_catch ul li系スタイルはstyle.cssで一元管理するため削除 */
/* .eye_catch ul li {
	border-bottom: dashed 2px #333333;
	color: #333333;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	list-style-type: none!important;
	margin-bottom: 50px;
	padding: 0.3em 0.5em 0.3em 2em;
}
.eye_catch ul li::before {
	color: #333333;
	content: "✔";
	left : 0.5em;
	position: absolute;
} */
.count {
	font-size: 2rem;
	font-weight: bold;
}
.btn a {
	border-radius: 0;
}
.section_0 {
	background-color: #fff;
}
.table, .table-smp {
	display: table;
	width: 100%;
}
.table-cell, .table-cell-smp {
	display: table-cell;
}
.w10 {
	width: 10%;
}
.w20 {
	width: 20%;
}
.w30 {
	width: 30%;
}
.w40 {
	width: 40%;
}
.w50 {
	width: 50%;
}
.w60 {
	width: 60%;
}
.w70 {
	width: 70%;
}
.w80 {
	width: 80%;
}
.w90 {
	width: 90%;
}
.center {
	text-align: center;
	vertical-align: middle;
}
p.current-status {
	font-size: 1.2rem;
}
div[class^="section_"] {
	margin: 0;
	padding: 50px 20px;
}
.section_student {
	background-color: #badfdb;
	color: #777777;
	margin-bottom: 0!important;
	padding: 30px 0;
}
.section_glossary {
	background-color: #eeeeee;
	padding-bottom: 2rem!important;
	margin-bottom: 2rem!important;
}
.section_breadcrumb {
	font-size: .8rem;
	padding: 2rem 1rem;
	color: #9e9e9e!important;
	border: none !important;
}
.section_breadcrumb a, .section_breadcrumb a:hover, .section_breadcrumb a:active, .section_breadcrumb a:visited {
	color: #9e9e9e!important;
	text-decoration: none;
}
.section_breadcrumb.head {
	padding-top: 120px;
}
@media screen and (max-width: 767px){
	.section_breadcrumb.head {
		padding-top: 20px;
	}
}
.section_present {
	background-color: #156082;
	color: #fff;
	padding: 0px 30px!important;
	text-align: center;
}

.section_feature {
	background-color: #fff;
}
.section_feature h3 {
	font-size: 1.2rem;
}
@media screen and (orientation: portrait){
	.section_feature img {
		max-width: 150px;
	}
}

.section_utilization {
	background-color: #156082;
	color: #fff;
	font-weight: bold;
	padding-bottom: 448px!important;
	position: relative;
	margin-bottom: 200px!important;
}
.section_utilization img:last-of-type {
	box-shadow: 0px 1px 2px 2px rgba(0,0,0,0.1);
	left: 0;
	margin: 0 auto;
	max-width: 1024px;
	position: absolute;
	right: 0;
}
@media screen and (orientation: portrait){
	.section_utilization {
		padding-bottom: 50px!important;
	}
	.section_utilization img:last-child {
		width: 90%;
	}
}

.section_curriculum .cmn_width > .table {
	margin: 3rem auto;
}
.section_curriculum .cmn_width > .table .table-cell {
	padding: 1rem;
}
.section_curriculum .cmn_width > .table .table-cell > div {
	box-shadow: 0px 1px 2px 2px rgba(0,0,0,0.1);
	height: 150px;
	padding: 3rem 3rem 2rem;
	position: relative;
	margin-bottom: 2rem;
}
.section_curriculum .cmn_width > .table .table-cell > a {
	border-bottom: 2px solid;
	color: #242422;
	display: block;
	font-size: 1.2rem;
	font-weight: bold;
	padding: .8rem;
	margin-bottom: 3rem;
}
.section_curriculum .cmn_width > .table .table-cell > div > img {
	left: 0;
	margin: 0 auto;
	position: absolute;
	right: 0;
	top: -30px;
	width: 100px;
}
.section_curriculum .cmn_width > .table .table-cell > div > ul {
	margin-bottom: 2rem;
}
.section_curriculum .btn-ptn3 a {
	width: 260px!important;
}
.section_curriculum div[class^="curriculum_"] {
	margin-bottom: 3rem;
}
.section_curriculum div[class^="curriculum_"] .table .table-cell:first-child {
	background: #e7f6ff;
	border-right: solid 5px #fff;
	text-align: center;
}
.section_curriculum div[class^="curriculum_"] .table .table-cell:last-child {
	background: #f5f7f9;
}
.section_curriculum div[class^="curriculum_"] .table .table-cell:last-child p {
	border-bottom: solid 5px #fff;
	margin-bottom: 0;
	padding: 10px 20px;
}
.section_curriculum div[class^="curriculum_"] .table .table-cell:last-child p:last-child {
	border: none;
}
.section_curriculum .btn-ptn4 {
	background-color:#c0e3ff;
}
@media screen and (orientation: portrait){
	.section_curriculum .cmn_width > .table .table-cell > div {
		height: auto;
	}
}

.section_teacher .table {
	margin: 5rem auto;
}
.section_teacher .table .table-cell:first-child {
	padding: 0 3rem;
}
.section_teacher .table .table-cell:first-child img {
	border-radius: 50%;
}
.section_teacher .table .table-cell:last-child {
	padding-left: 2rem;
}
.section_teacher .table .table-cell:last-child p:first-child {
	font-weight: bold;
	margin-bottom: 1.3rem;
}
.section_teacher .table .table-cell:last-child p:first-child span {
	font-size: 1.3rem;
	font-weight: bold;
	margin-right: 1rem;
}
.section_teacher .table .table-cell:last-child p:nth-child(2) {
	color: #797979;
}
.section_teacher .table .table-cell:last-child p:last-child {
	background: #f5f5f5;
	border-radius: 1rem;
	font-size: .8rem;
	line-height: 1.5rem;
	padding: 1rem;
	margin-top: 1rem;
}
@media screen and (orientation: portrait){	
	.section_teacher .table .table-cell:first-child {
		text-align: center;
	}
	.section_teacher .table .table-cell:last-child {
		padding-left: 0;
	}
}

.bg-logo {
	background-color: #f0f0f0;
	display: inline-block;
	padding: 10px 20px;
	width: auto;
}

.section_about {
	background-color: #fff;
}
.border-outer {
	background: #fff;
	border: solid 2px #242422;
	margin: 0 auto;
	padding: 50px;
	width: 80%;
}
.border-inner {
	background: #fff;
	border: solid 1px #242422;
	box-shadow: 0px 0px 0px 10px #fff;
	margin: 0.5em;
	padding: 1em;
}
.border-inner p.align_c {
	margin-bottom: 20px!important;
}

.section_3 {
//	background-color: #cee8f4;
	padding: 50px 0 75px;
}
.section_3 h4 span {
	color: #0ea3d5;
	font-size: 2rem;
	font-weight: bold;
}
.section_3 .performance-header {
    border-bottom: solid 3px #365c96;
    border-top: solid 3px #365c96;
	color: #365c96;
    padding: 0.5em 0;
}
.right_img{
	text-align: right;
}
.section_3 h3:first-child {
	margin-top: 0;
}
.orange-marker {
	background: linear-gradient(transparent 70%, #ffd79c 70%);
}
.section_3 .btn-ptn3 {
	margin: 50px auto 60px;
	min-width: 380px;
	text-align: center;
	width: 50%;
}
.btn-ptn3 a {
	background: #fff;
	box-shadow: 0px 1px 2px 2px rgba(0,0,0,0.1);
	color: #242422;
	padding: 0px 60px;
	transition: .3s;
	width: fit-content;
	width: -moz-fit-content;
}
.btn-ptn3 span {
	font-size: 1.2rem;
}
.btn-ptn3 img {
	margin: 0 0 3px 5px;
	transition: .3s;
}
.exemption-detail {
	background-color: #fff;
	padding: 130px 50px 50px;
	position: relative;
	margin: 50px 0 80px;
	width: 90%;
}
.exemption-detail .ribbon {
	background-color: #ffd79c;
	left: -20px;
	position: absolute;
	top: 50px;
	width: calc(100% + 40px);
}
.exemption-detail .ribbon:before {
	border: none;
	border-bottom: solid 15px transparent;
	border-right: solid 20px #b3a78c;/*折り返し部分*/
	content: '';
	left: 0;
	position: absolute;
	top: 100%;
}
.exemption-detail .ribbon:after {
	border: none;
	border-bottom: solid 15px transparent;
	border-left: solid 20px #b3a78c;/*折り返し部分*/
	content: '';
	position: absolute;
	top: 100%;
	right: 0;
}
.exemption-detail .ribbon h3 {
	margin: 10px;
}
.exemption-detail .table {
	border-bottom: solid 1px #242422;
	padding: 50px 0;
	width: 100%;
}
.exemption-detail .table:last-child {
	border: none;
}
.exemption-detail .detail, .exemption-detail .image {
	width: 50%;
}
.exemption-detail .detail h3 {
	margin-top: 0;
}
.exemption-detail img {
	height: 250px;
	width: auto;
}
.exemption-schedule {
	background-color: #fff;
	padding: 50px;
	position: relative;
	margin-bottom: 80px;
	width: 90%;
}
.exemption-schedule .table {
	padding: 10px;
	max-width: 80%;
}
.exemption-schedule .table .table-cell:first-child{
	border-bottom: solid 2px #242422;
}
.exemption-schedule .table .table-cell:last-child{
	border-bottom: solid 2px #aaaaaa;
}
div[class^="step_"] {
	border-radius: 50%;
	color: #fff;
	height: 230px;
	padding: 5px;
	width: 230px;
}
div[class^="step_"] h2 {
	margin-bottom: 15px;
	margin-top: 30px;
}
.step_1 {
	background-color: rgba(97,163,213,0.6);
}
.step_2 {
	background-color: rgba(97,163,213,0.8);
}
.step_3 {
	background-color: rgba(97,163,213,1.0);
}
.triangle {
	border-bottom: 20px solid transparent;
	border-left: 30px solid #242422;
	border-top: 20px solid transparent;
	height: 0;
	width: 0;
}
.triangle_s {
	border-bottom: 10px solid transparent;
	border-left: 15px solid #242422;
	border-top: 10px solid transparent;
	height: 0;
	width: 0;
}
.past-data {
	text-align: center;
}
.section_3 .cmn_pad {
	margin-bottom: 100px;
}
.section_3 .border-outer {
	box-shadow: 0px 1px 8px 3px rgba(0,0,0,0.1);
	position: relative;
	margin-top: 100px;
}
.section_3 .border-inner {
	padding: 80px 50px 50px;
}
.section_3 .btn-ptn3 a {
	width: 300px;
}
.two-chances {
	background-color: #156082;
	color: #fff;
	font-size: 28px;
	padding: 20px;
	text-align: center;
}
.faq-ttl {
	background-color: #b9e1f9;
	padding: 0.5em 1em;
}
.faq-block dt {
	background-color: #cfedff;
}
.faq-block dd {
	background-color: #f7fcff;
	margin-bottom: 10px;
}
.faq-block p.attention {
    padding-left: 1.2rem;
}
.solid_box {
	border: 2px solid #b9e1f9;
	margin-bottom: 30px;
}
h2.features {
	border-bottom: solid 3px #cee8f4;
	margin: 0px auto 50px;
	position: relative;
}
h2.features span {
	display: inline-block;
	font-size: 1.7rem;
	font-weight: bold;
	position: relative;
}
h2.features::after {
	bottom: -3px;
	border-bottom: solid 3px #ffd79c;
	content: " ";
	display: block;
	position: absolute;
	width: 10%;
}
.feature-box {
	background-color: #fff;
	box-shadow: 0 0 5px 3px rgba(0,0,0,0.1);
	margin: 0 auto 50px;
	padding: 30px 50px;
	width: 90%;
}
.feature-box:last-child {
	margin-bottom: 0;
}
.section_5 .table .table-cell:first-child {
	padding-right: 80px;
}
.section_5 div.align_c {
	width: 85%;
}
.section_5 .btn-ptn2 {
	margin-top: 40px;
}
.section_5 .feature {
    background: #F6F6F6;
    padding: 3rem;
}
.section_5 .feature p {
    margin-top: 1rem;
}
.teacher-box {
	margin: 0 auto 30px;
	padding: 30px 50px;
	width: 90%;
}
h4.heading {
	background: transparent;/*背景透明に*/
	border-left: solid 5px #ffd79c;/*左線*/
	padding: 0em 0.8em;/*上下 左右の余白*/
}
.feature-box p {
	padding-left: 1.2rem;
}
.section_movie .btn-ptn4 a {
	background: #c0e3ff;
	color: #242422;
}
.section_7 .table {
	margin: 0 10px;
	padding: 20px;
}
.stage_1 {
	background-color: rgba(97,163,213,0.2);
}
.stage_2 {
	background-color: rgba(97,163,213,0.4);
}
.stage_3 {
	background-color: rgba(97,163,213,0.6);
}
.attention-box {
	border: solid 2px #848484;
	border-radius: 30px;
	margin: 30px auto 30px;
	padding: 10px 0px;
	position: relative;
}
.attention-box img {
	height: 100px;
	width: 100px;
}
.attention-box p {
	font-size: 1rem;
        margin-top: 0px;
        margin-bottom: 0px;
}
.attention {
	left: 0;
	margin: 0;
	text-indent: -1em;
}
.attention:before {
	content: '※';
}
.section_app .table-cell:first-child {
	vertical-align: middle;
	width: 35%;
}
.section_app .table-cell:first-child p {
	margin-top: 1rem;
	padding: 0;
}
.section_app ol {
	background: #fff;
	border: dashed 2px #0297d7;
	margin-bottom: 1rem;
	margin-left: 1rem;
	padding: 0.5em 0.5em 0.5em 2.2em;
}
.section_app ol li {
	line-height: 1.5;
	padding: 0.5em 0;
}
.section_8 {
	margin-top: 50px!important;
}
.benefits-box {
	background-color: #0063a0;
	margin: 0 auto;
	padding: 50px;
	position: relative;
	width: 90%;
}
.benefits-circle {
	background-color: #fff;
	border-radius: 50%;
	display: inline-block;
	height: 50px;
	margin-right: 10px;
	padding: 5px;
	vertical-align: middle;
	width: 50px;
}
.benefits-box h3 {
	display: inline-block;
	margin-top: 0;
}
.benefits-box h3, .benefits-box p, .benefits-box span {
	color: #fff;
}
.benefits-title {
	margin-bottom: 30px;
}
.benefits-title img {
	height: 62px;
	width: 62px;
}
.benefits-circle h3 {
	color: #0063a0;
	margin-top: 5px;
}
table{
	border-spacing: 0;
	color: #fff;
	width: 100%;
}
table th{
	border-bottom: solid 2px #e8d01f;
	padding: 30px 10px 10px;
	text-align: center;
}
table td{
	border-bottom: solid 2px #dcdbdb;
	padding: 30px 10px 10px 30px;
}
.section_reapp {
	background-color: #b1b1b1;
	padding-bottom: 50px;
	padding-top: 50px;
}
.section_reapp h3, .section_reapp p {
	color: #fff;
}
.section_reapp .btn-ptn3 {
	min-width: 380px;
	width: 50%;
}
.balloon1-top {
	background-color: #fff;
}
.section_reapp .feature-box h3, .section_reapp .feature-box h4, .section_reapp .feature-box p {
	color: #242422;
}
.section_reapp .feature-box .attention-box p {
	font-size: .8rem;
	line-height: 1.5rem;
}
.balloon1-top:before {
	content: none;
}
.price-box {
	background-color: #fff;
	box-shadow: 0 0 5px 2px rgba(0,0,0,0.1);
	height: 420px;
	position: relative;
	margin: 0 auto 50px;
	width: 90%;
}

.price-box .header {
	background-color: #5bbaf4;
	color: #fff;
	padding: 10px 20px;
	text-align: left;
}
.price-box .body {
	color: #242422;
	padding: 30px 20px;
	text-align: center;
}
.price-box .body p {
	margin-bottom: 0;
}
.price-ribbon {
	background: linear-gradient(#fcb942 0%, #ffa300 100%);
	border-radius: 2px 0 0 0;
	color: white;
	display: inline-block;
	font-size: 17px;
	font-weight: bold;
	margin: 0;
	padding: 14px 0;
	position: absolute;
	text-align: center;
	top: -6px;
	right: 15px;
	width: 80px;
	z-index: 2;
}
.price-ribbon:before {
	border: none;
	border-bottom: solid 6px #b57400;
	border-right: solid 6px transparent;
	content: '';
	position: absolute;
	right: -6px;
	top: 0;
}
.price-ribbon:after {
	border-bottom: 20px solid transparent;
	border-left: 40px solid #ffa300;
	border-right: 40px solid #ffa300;
	content: '';
	height: 0;
	left: 0;
	position: absolute;
	top: 99%;
	width: 0;
}
.price-box .header h4 {
	color: #fff!important;
	margin-bottom: 0;
	text-align: left;
}
.price {
	font-size: 2rem;
}
.cancel {
	text-decoration: line-through;
}
div[class^="flowchart_"] {
	color: #fff;
	margin: 0 0 5px;
	padding: 10px 20px;
	text-align: center;
	vertical-align: middle;
}
.flowchart_start, .flowchart_end {
	background-color: #fff;
	border: solid 2px #0063a0;
	color: #0063a0!important;
	font-weight: bold;
}
.flowchart_1 {
	background-color: #0087da;
}
div[class^="flowchart_"] .table {
	margin-top: 10px;
}
.flowchart_1 .table {
	border-top: dashed 2px #fff;
}
div[class^="flowchart_"] .table-cell {
	padding: 20px;
	width: 50%;
}
.flowchart_1 .table-cell:last-child {
	border-left: dashed 2px #fff;
}
.flowchart_2 {
	background-color: #2da6f1;
}
.flowchart_3 {
	background-color: #6dc7ff;
}
.flowchart_end {
	margin-bottom: 30px!important;
}
.triangle_under {
	border-bottom: 12px solid transparent;
	border-left: 18px solid #005d96;
	border-top: 12px solid transparent;
	display: inline-block;
	height: 0;
	margin: 0 auto;
	width: 0;
	-moz-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	-o-transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
}
.btn-ptn4 a {
	background: #fcb942;
	box-shadow: 0px 1px 5px 1px rgba(0,0,0,0.1);
	border: none;
	color: #fff;
	padding: 0px 80px;
	transition: .3s;
	width: auto;
	width: fit-content;
	width: -moz-fit-content;
}
.btn-ptn4 a:hover {
	box-shadow: 0px 3px 8px 3px rgba(0,0,0,0.2);
}
.btn-ptn4 span {
	font-size: 1.2rem;
	font-weight: bold;
}
.btn-ptn5 a {
	background: #eeff00;
	border: none;
	box-shadow: 0px 1px 5px 1px rgba(0,0,0,0.1);
	color: #777777;
	padding: 0px 80px;
	transition: .3s;
	width: auto;
	width: fit-content;
	width: -moz-fit-content;
}
.btn-ptn5 a:hover {
	box-shadow: 0px 3px 8px 3px rgba(0,0,0,0.2);
}
.btn-ptn5 span {
	font-size: 1.4rem;
	font-weight: bold;
}
.fenavi {
	width: 80%;
	margin: auto;
}

.js-animation {
	opacity: 0;
	transform: translateY(40px);
	transition: all 1s;
	visibility: hidden;
}
.js-animation.is-show {
	opacity: 1;
	transform: translateY(0px);
	visibility: visible;
}
.js-animation2 {
	opacity: 0;
	transform: translateX(20px);
	transition: all 1s;
	visibility: hidden;
}
.js-animation2.is-show {
	opacity: 1;
	transform: translateX(0px);
	visibility: visible;
}
.js-animation3 {
	transform: translateY(-20px);
}
.section_13 h3 {
	font-size: 1rem;
	display: inline-block;
	padding: 0 60px;
	position: relative;
}
.section_13 h3:before {
	background-color: #242422;
	content: '';
	display: inline-block;
	height: 1.5px;
	position: absolute;
	top: 50%;
	transform: rotate(60deg);
	width: 60px;
	-webkit-transform: rotate(60deg);
}
.section_13 h3:after {
	background-color: #242422;
	content: '';
	display: inline-block;
	height: 1.5px;
	position: absolute;
	top: 50%;
	transform: rotate(-60deg);
	width: 60px;
	-webkit-transform: rotate(-60deg);
}
.section_13 h3:before {
	left:0;
}
.section_13 h3:after {
	right: 0;
}
.section_AP {
	margin-bottom: 30px!important;
}
.section_AP .attention {
	padding-left: 2rem;
}
.products {
	margin-left: 45px;
	width: 300px;
}
.products img {
	margin: auto; /* it centers any block level element */
}
.products-detail {
	width: 500px;
}
.users-voices {
        max-width:1000px;
}
.users-voices img {
    height: 60px;
    width: 60px;
}
.users-voices-card {
    display: flex;
    margin: 10px;
}
.users-voices-comment {
    background-color: #f5f5f5;
    margin-left: 30px; 
    width: 100%;
    vertical-align: middle;
}
.users-voices-comment p {
    margin: 10px!important;
}

.gray-box {
	background: #f5f5f5;
	border-radius: 1rem;
	margin: auto;
	max-width: 800px;
	padding: 1rem;
}
.performance {
	padding-left: 30px;
}

.section_present img {
        height: auto;
        max-height: 230px;
        width: auto;
}

@media screen and (max-width: 767px){
	.eye_catch .txt-1 p.ttl {
		font-size: 1.4rem;
	}
	.eye_catch ul {
		max-width: 500px;
	}
	.eye_catch .hayawari .txt-1 p {
		font-size: 26px;
	}
        .background-block {
                background-color: rgba(255,255,255,0.7);
        }
        .section_present img {
            width: 100%;
            margin-top: 30px;
        }
}
@media screen and (max-width: 767px){
	.eye_catch {
		height: 580px;
	}
	.eye_catch .txt-1 p.ttl {
		font-size: 1.4rem;
	}
	.eye_catch ul {
		max-width: 450px;
	}
	.eye_catch ul li {
		font-size: 1.2rem;
	}
	.eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.campaign {
		color: #242422;
		font-size: 1.3rem;
		line-height: 2rem;
		text-shadow: none;
		font-weight: 400;
		margin-bottom: 50px;
	}
	.eye_catch .hayawari .txt-1 {
		padding: 0px 10%;
	}
	.eye_catch .hayawari .txt-1 p {
		font-size: 20px;
	}
}
@media screen and (max-width: 767px){
	.eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.campaign {
		font-size: 1.1rem;
		line-height: 1.4rem;
	}
	.btn-ptn4 a {
		padding: 0px 60px;
	}
	.btn-ptn4 span {
		font-size: 1rem;
	}
}
@media screen and (max-width: 767px){

	.eye_catch .txt-1 p.ttl {
		font-size: 1.4rem;
		line-height: 1.8rem;
	}
	.eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.campaign {
		font-size: 1.1rem;
	}
	.btn-ptn4 a {
		padding: 0px 60px;
	}
	.btn-ptn4 span {
		font-size: 1rem;
	}
}
@media screen and (min-width: 767px){
	.view_smp {
		display: none;
	}
	.menu_pc .col a {
		border: none;
	}
	.countmin {
		font-size: 28px;
	}
	.btn-ptn2 a {
		text-align: center;
		font-size: 16px;
		text-decoration: none;
		font-weight: bold;
		position: relative;
	}
	.btn-ptn2 span {
		font-size: 1.4rem;
		font-weight: bold;
		position: relative;
		z-index: 1;
	}
	.btn-ptn2.orange a {
		background-color: #fcb942;
		border: 2px solid #fcb942;
		color: #fcb942;
	}
	.btn-ptn2.blue a {
		background-color: #61a3d5;
		border: 2px solid #61a3d5;
		color: #61a3d5;
	}
	.btn-ptn2.gray a {
		background-color: #5a5a5a;
		border: 1px solid #5a5a5a;
		color: #5a5a5a;
	}
	.btn-ptn2.gray span {
		font-weight: 500;
	}
	.btn-ptn2 a::before,
	.btn-ptn2 a::after {
		content: "";
		display: block;
		background-color: #FFF;
		width: 50%;
		height: 100%;
		position: absolute;
		top: 0;
		transition: .3s;
	}
	.btn-ptn2 a::before {
		left: 0;
	}
	.btn-ptn2 a::after {
		right: 0;
	}
	.btn-ptn2 a:hover:before,
	.btn-ptn2 a:hover:after {
		width: 0;
		background-color: #FFF;
	}
	.btn-ptn2.orange a:hover, .btn-ptn2.blue a:hover, .btn-ptn2.gray a:hover {
		color: #fff;
	}
	.btn-ptn3 a:hover {
		box-shadow: 0px 3px 8px 3px rgba(0,0,0,0.2);
	}
	.btn-ptn3 a:hover img {
		transform: translateY(2px);
	}
	.section_app h3 {
		margin-top: 0;
	}
	.btm-wrap {
		display: none;
	}
}
@media screen and (max-width: 767px){
	html {
		-moz-text-size-adjust:100%;
		-webkit-text-size-adjust:100%;
		-ms-text-size-adjust:100%;
	}
	.menu_wrap {
		position: relative;
		height: 60px!important;
	}
	header .menu_btn {
		width: 190px;
		margin-right: 0;
	}
	header .menu_btn ul li {
		display: inline-block;
	}
	header .menu_btn ul li a {
		background-color: #ffda98;
		color: #fff;
		border: none;
		padding: 5px 20px;
		background-image: linear-gradient(90deg, #007cad 0%, #61a3d5 100%);
	}
	.eye_catch_text_block {
		padding: 0px;
	}
	.eye_catch ul {
		margin-left: 0;
	}
	.table-cell.hayawari {
		background-size: contain;
	}
	.cmn_width {
		padding-left: 0!important;
		padding-right: 0!important;
	}
	.close{
		display: inline-block;
		position: absolute;
		margin: 0 20px 0 7px;
		padding: 0;
		width: 4px;
		top: 10px;
		right: 5px;
		height: 25px;
		background: #156082;
		transform: rotate(45deg);
	}
	.close:before{
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: -10px;
		width: 25px;
		height: 4px;
		margin-top: -2px;
		background: #156082;
	}
	.menu_pc {
		display: none;
	}
	.menu_btn {
		display: block;
		cursor: pointer;
		height: 50px;
		line-height: 50px;
		margin-left: auto;
		margin-right: 20px;
		width: 50px;
		z-index: 10000;
	}
	.title-smp {
		display: inline-block;
		position: absolute;
		width: 40%;
		height: 50px;
		min-width: 100px;
		margin-top: 5px;
		margin-left: 20px;
		z-index: 9999;
	}
	.title-smp span {
		line-height: 50px;
	}
	.menu_smp .col:first-child {
		padding-top: 30px;
		border-top: none;
	}
	.menu_smp {
		background: none;
		box-sizing: border-box;
		display: block;
		padding-top: 50px!important;
	}
	.menu_smp .col {
		background: none;
		padding: 15px 30px 15px 0;
		text-align: right!important;
		text-decoration: none;
		border-bottom: none;
	}
	.menu_smp .col a {
		color: #242422;
		font-weight: bold;
		background: none;
		text-align: right!important;
		text-decoration: none;
		border-bottom: none;
	}

	.menu_smp .offer a {
		background-color: #f00;
		color: #fff;
	}

	html, body {
		font-size: 18px!important;
	}
	h2 {
		font-size: 1.8rem;
	}
	h3 {
		font-size: 1.3rem;
	}
	p {
		line-height: 1.8rem;
	}
	div[class^="section_"] {
		padding: 20px;
		margin: 0;
	}
	.table {
		display: block;
		width: auto;
	}
	.table-cell {
		display: block;
		width: auto;
		margin-bottom: 20px;
	}

	.eye_catch {
		height: 500px;
		min-height: 100px;
		top: 0px;
	}
	.eye_catch .txt-1 {
		position: relative;
		top: 50px;
		padding: 20px 10px;
		margin-top: 0;
		text-align: center;
		height: auto;
	}
	.eye_catch .txt-1 p.nobe {
		font-size: 1.1rem;
		line-height: 1.3rem;
		text-shadow: none;
		font-weight: 500;
		margin-bottom: 1.2em;
	}
	.eye_catch .txt-1 p.campaign {
		font-size: 1.1rem;
		line-height: 1.6rem;
		font-weight: 500;
		margin-bottom: 1.2em;
	}
	.eye_catch .txt-1 p.ttl {
		font-size: 1.2rem;
		font-weight: 500;
		line-height: 2.5rem;
	}
	.eye_catch .txt-1 p.campaign {
		font-size: 1.0rem;
		margin-left: 60px;
	}

	.eye_catch .txt-1 .btn-ptn2 {
		margin-top: 0px;
		margin-left: 60px;
	} 
	.eye_catch .txt-1 .btn-ptn2 a {
		width: 260px;
	}
	.eye_catch ul {
		margin-top: 0px;
		margin-left: 0px;
		padding-top: 0px;
		max-width: 600px;
	}
	p.current-status {
		font-size: 1rem;
	}
	.btn-ptn2 a {
		text-align: center;
		font-size: 14px;
		text-decoration: none;
		font-weight: bold;
	}
	.btn-ptn2.orange a {
		border: solid 2px #fcb942;
		margin-top: 30px;
	}
	.btn-ptn2.blue a {
		border: solid 2px #61a3d5;
		color: #61a3d5;
		margin-top: 30px;
	}
	.btn-ptn2.gray a {
		border: solid 2px #5a5a5a;
	}
	.btn-ptn2 span {
		font-size: 1rem;
		font-weight: bold;
		position: relative;
		z-index: 1;
	}
	.btn-ptn2.orange span {
		color: #fcb942;
	}
	.btn-ptn2.gray span {
		color: #5a5a5a;
	}
	.border-outer {
		width: auto;
	}
	.section_about .border-inner p:last-child {
		margin-bottom: 50px!important;
	}
	.section_about .btn-ptn2 {
		width: 100%;
		margin: 30px auto;
		min-width: 0px;
	}
	.btn-ptn2 a {
		width: 500px;
	}
	.section_3 {
		/*background-color: #cee8f4;*/
		padding: 30px 0 50px;
	}
	.section_3 .btn-ptn3 {
		width: 100%;
		text-align: center;
		margin: 30px auto 50px;
		min-width: 0px;
	}
	.section_3 .table-cell {
		margin-bottom: 0;
	}
	.section_3 .border-outer {
		margin-top: 50px;
		padding: 30px 0;
	}
	.btn-ptn3 a {
		width: 500px;
		padding: 0;
	}
	.btn-ptn3 span {
		font-size: 1rem;
	}
	.exemption-detail {
		width: auto;
		padding: 130px 30px 10px;
		margin: 50px 0;
	}
	.exemption-detail .ribbon {
		top: 30px;
		left: -10px;
		width: calc(100% + 20px);
		background-color: #ffd79c;
	}
	.exemption-detail .ribbon:before {
		border-bottom: solid 8px transparent;
		border-right: solid 10px #b3a78c;/*折り返し部分*/
	}
	.exemption-detail .ribbon:after {
		border-bottom: solid 8px transparent;
		border-left: solid 10px #b3a78c;/*折り返し部分*/
	}
	.exemption-detail .v_middle.view_smp {
		margin-top: 30px;
	}
	.exemption-detail .table {
		padding: 20px 0;
		border-bottom: solid 1px #242422;
	}
	.exemption-detail .detail, .exemption-detail .image {
		width: 100%;
	}
	.exemption-detail .detail h3 {
		font-size: 1.2rem;
	}
	.exemption-detail .detail p {
		text-align: left;
	}
	.exemption-detail .image {
		display: none;
	}
	.exemption-schedule {
		width: auto;
		padding: 30px;
	}
	.exemption-schedule .table {
		max-width: 100%;
		padding: 10px 0;
	}
	.exemption-schedule .table .table-cell:first-child {
		border-bottom: none;
		background: #242422;
		color: #fff;
	}
	.exemption-schedule .table .table-cell:first-child p {
		padding-left: 10px;
	}
	.exemption-schedule .table .table-cell:last-child {
		border-bottom: none;
	}
	.section_3 .cmn_pad {
		margin-bottom: 50px;
	}
	.right_img {
		text-align: center;
	}
	div[class^="step_"] {
		border-radius: 0;
		width: 100%;
		height: auto;
		padding: 15px 0;
		margin-bottom: 0;
	}
	div[class^="step_"] h2 {
		margin-top: 0px;
		margin-bottom: 10px;
	}
	.past-data {
		text-align: left;
	}
	.section_3 .border-inner {
		padding: 10px 20px;
	}
	.section_3 .border-inner h2 {
		font-size: 1.4rem;
		margin-top: 5px;
		margin-bottom: 20px;
		text-align: center;
	}
	.section_3 .border-inner h3 {
		font-size: 1.2rem;
		margin-bottom: 0;
		text-align: center;
	}
	.section_3 .border-inner .attention {
		margin-top: 20px;
	}
	.section_3 .table-smp {
		width: auto;
		margin: auto;
	}
	h2.features {
		position: relative;
		margin: 0px auto 30px;
	}
	h2.features span {
		position: relative;
		font-size: 1.3rem;
		display: inline-block;
	}
	.feature-box {
		width: auto;
		padding: 30px 10px;
		margin-bottom: 30px;
	}
	.feature-box p {
		padding-right: 0.8rem;
		padding-left: 1.2rem;
	}
	h4.heading {
		padding: 0 0 0 0.8em;
		border-bottom: solid 1px #ffd79c;
	}
	.cmn_width .feature-box {
		margin-right: -10px;
		margin-left: -10px;
	}
	.section_5 .cmn_pad, .section_11 .cmn_pad, .section_13 .cmn_pad {
		padding-left: 0px;
		padding-right: 0px;
	}
	.section_5 div.align_c {
		width: 100%;
	}
	.section_5 p {
		margin-bottom: 5px;
	}
	.section_5 .btn-ptn2 {
		margin-top: 0;
	}
	.teacher-box {
		width: auto;
		padding: 0;
	}
	.section_movie .feature-box .table-cell:first-child {
		text-align: center;
	}
	.section_movie .feature-box img {
		width: auto!important;
		max-width: 240px;
	}
	.section_7 .feature-box .table-cell {
		margin-bottom: 0;
	}
	div[class^="stage_"] {
		height: auto;
	}
	.section_7 .table h4 {
		text-align: center;
	}
	.section_7 .attention {
		text-align: left!important;
	}
	.python {
		max-width: 350px;
	}
	.attention-box {
		padding: 30px 50px;
	}
	.attention-box img {
		width: 60px;
		height: 60px;
	}
	.section_app .table-cell:first-child {
		width: auto;
		text-align: center;
	}
	.section_app .table-cell:first-child img {
		max-width: 200px;
	}
	.section_app ol {
		margin: 0 0 1rem;
	}
	.section_8 {
		margin-top: 30px!important;
		margin-bottom: 30px!important;
	}
	.benefits-box {
		width: auto;
		padding: 30px 20px;
	}
	.benefits-title {
		margin-bottom: 0;
	}
	.benefits-title img {
		width: 55px;
		height: 55px;
	}
	.benefits-circle {
		margin-right: 0;
		margin-bottom: 20px;
	}
	.benefits-circle h3 {
		margin-top: 10px;
	}
	.benefits-box p.align_c {
		text-align: left!important;
	}
	table th {
		display: block;
		width: auto;
	}
	table td {
		display: block;
		width: auto;
		border: none;
		padding: 20px 10px;
	}
	.section_reapp {
		padding: 40px 20px!important;
	}
	.section_reapp h3 {
		margin-top: 0;
	}
	.section_reapp .btn-ptn3 {
		width: auto;
		min-width: 0px;
	}
	.section_reapp .cmn_width .feature-box {
		margin-right: -20px;
		margin-left: -20px;
	}
	.section_reapp .w50 {
		width: auto;
	}
	.price-box {
		width: 500px;
                height: auto;
                max-height: 420px;
	}
	.price-box .body {
		padding: 50px 20px 30px;
	}
	h4.faq-ttl {
		font-size: 1rem;
	}
	div[class^="flowchart_"] .table-cell {
		width: auto;
		margin-bottom: 0;
		padding: 10px 20px;
	}
	.flowchart_1 .table-cell:last-child {
		border-left: none;
	}
	.btn-ptn4 span {
		font-size: 1rem;
	}
	.btn-ptn5 a {
		width: 500px;
		text-align: center;
		text-decoration: none;
		font-weight: bold;
		padding: 0;
	}
	.btn-ptn5 span {
		font-size: 1rem;
	}
	.view_pc {
		display: none;
	}
	.view_smp {
		display: block;
	}
	.section_5 .table .table-cell:first-child {
		padding: 0;
	}
	.products {
		width: 200px;
		margin: auto;
	}
	.products-detail {
		width: auto;
	}
        .users-voices {
            max-width: 350px;
        }
        .users-voices img {
            display:none;
            height: 60px;
            width: 60px;
        }
        .users-voices-card {
            display: flex;
            margin: 10px;
        }
        .users-voices-comment {
            background-color: #f5f5f5;
            margin-left: 0px;
        }
        .users-voices-comment p {
            margin: 10px;
        }

	.section_14 div[id^="carriculum_"] .table .table-cell:first-child {
		margin-bottom: 0;
		text-align: left;
	}
	.section_14 .cmn_pad .table .table-cell:first-child p {
		padding: 0 0 0 10px!important;
	}
	.performance {
		padding-right: 0px;
		border-right: none;
		margin-bottom: 30px!important;
		padding-left: 0;
		text-align: center;
	}
	.btm-wrap {
		display: block;
		-webkit-overflow-scrolling: touch;
		z-index: 9998;
		background-color: rgba(0,0,0,.7);
		bottom: 0;
		height: 90px;
		left: 0;
		position: fixed;
		width: 100%;
	}
	.btm-menu {
		bottom: 0;
		display: block;
		height: 90px;
		left: 0;
		margin: 0 auto;
		position: fixed;
		right: 0;
		width: 100%;
		z-index: 9999;
		text-align: center;
	}
	.btm-menu div {
		margin: auto;
	}
	.btm-menu div {
		text-align: center;
		width: 23%;
		display: inline-block;
	}
	.btm-ul {
		position: absolute;
		bottom: 20px;
		left: 0;
		width: 100%!important;
	}
	.btm-menu img, .btm-menu div img {
		height: 60px!important;
		width: auto;
	}
	footer .cmn_width {
		margin-bottom: 80px;
	}
}


@media screen and (max-width: 767px) {
  .eye_catch {
    height: auto !important;
    min-height: 0 !important;
    padding: 24px 0 16px 0;
    //display: flex;
    align-items: flex-start;
  }
  .eye_catch_text_block {
    padding: 0 10px !important;
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
  }
  .eye_catch .txt-1 {
    margin-top: 0 !important;
    top: 0 !important;
    padding: 0 !important;
    width: 100%;
  }
  .eye_catch .txt-1 p.nobe,
  .eye_catch .txt-1 p.ttl {
    margin-bottom: 8px !important;
    margin-top: 0 !important;
    text-align: center !important;
  }
  .eye_catch .hayawari .txt-1 {
    top: 0 !important;
    margin-top: 0 !important;
    padding: 0 !important;
    text-align: center !important;
  }
  .eye_catch_bottom_block {
    margin-top: 12px !important;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-left: 0px;
  }
  .eye_catch_bottom_block .btn-wrapper {
    width: 100%;
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
  }
  .eye_catch_bottom_block .btn {
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
  }
  .eye_catch_bottom_block .btn a {
    width: 100% !important;
    text-align: center;
  }
}

@media screen and (max-width: 767px){
	html, body {
		font-size: 14px!important;
	}
	.eye_catch .hayawari .txt-1 {
		padding: 0;
	}
	.eye_catch .txt-1 p.nobe {
		font-size: 1.2rem;
		line-height: 1.5rem;
	}
	.menu_wrap {
		background: url("/dokushuzemi/fe/img/menu-back-smp.png") no-repeat left top;
		background-size: 100% auto;
	}
	.menu_smp .col:first-child {
		padding-top: 0px;
	}
	.menu_smp .col {
		padding: 5px 30px 0 0;
	}
	.eye_catch {
		height: 500px;
	}
	.eye_catch .table {
		display: block;
	}
	.eye_catch .table-cell {
		display: block;
		width: 100%;
	}
	.eye_catch .table-cell.w30 {
		order: 1;
	}
	.eye_catch .table-cell.w70 {
		order: 2;
	}
	.eye_catch_bottom_block {
		order: 3;
		margin-top: 2rem !important;
	}
	.eye_catch_text_block {
		display: flex;
		flex-direction: column;
		height: 100%;
	}
	.eye_catch_text_block .table {
		display: flex;
		flex-direction: column;
		flex: 1;
	}
	.eye_catch_bottom_block .btn-wrapper {
		flex-direction: column !important;
		align-items: center !important;
		gap: 1rem !important;
	}
	.eye_catch_bottom_block .btn {
		width: 100%;
		max-width: 300px;
		margin: 0 auto;
	}
	.eye_catch_bottom_block .btn a {
		width: 100% !important;
		text-align: center;
	}
	.eye_catch .txt-1 p.nobe, .eye_catch .txt-1 p.ttl, .eye_catch .txt-1 p.campaign, .eye_catch .txt-1 .btn-ptn2 {
		margin-left: 0px;
	}
	.eye_catch .txt-1 {
		top: 30px;
		width: 100%;
		padding: 0;
		margin-top: 0;
	}
	.eye_catch .txt-1 p.ttl {
		font-size: 1.7rem;
		text-align: center;
	}
	.eye_catch .txt-1 p.nobe {
		text-align: center;
		margin-bottom: 20px;
	}
	.eye_catch .txt-1 p.campaign {
		text-align: center;
		font-size: 1.2rem;
		margin-bottom: 10px;
	}
	.btn-ptn2.orange a {
		margin-top: 10px;
	}
	.eye_catch ul li {
		margin-bottom: 10px;
		font-size: 1.0rem;
	}
	.eye_catch ul {
		max-width: 320px;
		margin: auto;
	}
	.btn-ptn5 a {
		width: 260px;
	}
	.section_about {
		text-align: left;
	}
	.section_about p:last-child {
		margin-bottom: 20px!important;
	}
	.section_about h3 {
		font-weight: bold;
	}
	.btn-ptn2 a {
		width: 260px;
	}
	.border-outer {
		padding: 0;
		margin: auto;
		background: #fff;
		border: none;
		width: 100%;
	}
	.border-inner {
		padding: 0;
		margin: 0;
		background: #fff;
		box-shadow: none;
		border: none;
	}
	.btn-ptn3 a {
		width: 260px;
	}
	.section_3 .cmn_pad {
		margin-bottom: 50px;
	}
	.section_3 h4 span {
		color: #0ea3d5;
		font-size: 1.5rem;
		font-weight: bold;
	}
	div[class^="step_"] {
		border-radius: 0;
		width: 100%;
		height: auto;
		padding: 15px 0;
		margin-bottom: 0;
	}
	div[class^="step_"] h2 {
		margin-top: 0px;
		margin-bottom: 10px;
	}
	.past-data {
		text-align: left;
	}
	.section_3 .border-inner {
		padding: 10px 20px;
	}
	.section_3 .border-inner h2 {
		text-align: left;
	}
	.section_3 .border-inner h3 {
		text-align: left;
	}
	.section_3 .border-inner .attention {
		margin-top: 20px;
	}
	h2.features {
		text-align: left;
	}
	h2.features span {
		font-weight: bold;
		margin: 0;
		padding: 0;
		background: none;
	}
	h2.features::after {
		width: 20%;
	}
	.feature-box {
		width: auto;
		padding: 30px 10px;
	}
	.feature-box p {
		padding-right: 0.8rem;
		padding-left: 1.2rem;
	}
	h4.heading {
		padding: 0 0 0 0.8em;
		border-bottom: solid 1px #ffd79c;
	}
	.cmn_width .feature-box {
		margin-right: -20px;
		margin-left: -20px;
	}
	.section_5 .cmn_pad, .section_11 .cmn_pad, .section_13 .cmn_pad {
		padding-left: 0px;
		padding-right: 0px;
	}
	.section_5 div.align_c {
		width: 100%;
	}
	.section_5 p {
		margin-bottom: 5px;
	}
	.section_5 .btn-ptn2 {
		margin-top: 0;
	}
	.teacher-box {
		width: auto;
		padding: 0;
	}
	.section_movie .feature-box img {
		width: auto!important;
	}
	.section_7 h4.align_c {
		font-size: 1rem;
		text-align: left!important;
	}
	.section_7 .feature-box .table-cell {
		margin-bottom: 0;
	}
	div[class^="stage_"] {
		height: auto;
	}
	.section_7 .attention {
		text-align: left!important;
	}
	.attention-box {
		padding: 20px;
	}
	.attention-box img {
		width: 60px;
		height: 60px;
	}
	.benefits-box {
		width: auto;
		padding: 30px 10px;
	}
	.benefits-title {
		margin-bottom: 0;
	}
	.benefits-circle {
		margin-right: 0;
		margin-bottom: 20px;
	}
	.benefits-circle h3 {
		margin-top: 10px;
	}
	.benefits-box p.align_c {
		text-align: left!important;
	}
	table th {
		display: block;
		width: auto;
	}
	table td {
		display: block;
		width: auto;
		border: none;
		padding: 20px 10px;
	}
	.section_reapp {
		padding: 30px 20px;
	}
	.section_reapp h3 {
		margin-top: 0;
	}
	.section_reapp .btn-ptn3 {
		width: auto;
		min-width: 0px;
	}
	.section_reapp .cmn_width .feature-box {
		margin-right: -20px;
		margin-left: -20px;
	}
	.price-box {
		width: auto;
	}
	.price-box .header, .price-box .header h4 {
		text-align: left!important;
	}
	.price-box .body {
		padding: 50px 20px 30px;
	}
	h4.faq-ttl {
		font-size: 1rem;
	}
	div[class^="flowchart_"] .table-cell {
		width: auto;
		margin-bottom: 0;
		padding: 10px 20px;
	}
	.flowchart_1 .table-cell:last-child {
		border-left: none;
	}
	.btn-ptn4 a {
		width: 260px!important;
		padding: 0!important;
	}
	.btn-ptn4 span {
		font-size: 1rem;
	}
	.section_AP .table-cell:last-child {
		width: auto;
	}
	.section_3 .btn-ptn3 a {
		width: 260px;
	}
}
@media screen and (max-width: 767px){
	.two-chances {
		font-size: 1.3rem;
	}
	.section_5 .feature {
		padding: 1rem;
	}
	.eye_catch {
		height: 450px;
	}
	.eye_catch_bottom_block .btn {
		max-width: 280px;
	}
}
@media screen and (max-width: 767px){
	.two-chances {
		font-size: 16px;
		padding: 10px;
	}
	.section_3 .border-outer h3 {
		font-size: 1rem;
	}
	.eye_catch {
		height: 400px;
	}
	.eye_catch_bottom_block .btn {
		max-width: 260px;
	}
	.eye_catch .txt-1 p.nobe {
		font-size: 1.1rem;
		line-height: 1.4rem;
	}
}
/* .eye_catch系メディアクエリはstyle.cssで一元管理するため削除 */
/* @media screen and (max-width: 370px){
	.eye_catch {
		height: 400px;
	}
} */
@media screen and (min-width: 767px){
	.menu_wrap {
		background-color: #fff;
	}
}

@media screen and (max-width: 767px){
	.section_reapp .price-box {
		width: 250px;
	}
	.section_reapp .price-box .body {
		padding: 30px 20px;
	}
	.btm-menu img, .btm-menu div img {
		height: 53px!important;
	}
}

/* --- ボタン反応強制 --- */
.eye_catch_mask {
  pointer-events: none !important;
  z-index: 1 !important;
}
.eye_catch_text_block {
  position: relative;
  z-index: 10 !important;
}
/* --- ここまで --- */


/* --- section-cta（リンクブロック）用スタイル --- */
.cta-buttons {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  max-width: 800px;
  margin: 0 auto;
}

.cta-button-wrapper {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.cta-button-wrapper .btn {
  min-width: 180px;
  text-align: center;
}

.cta-desc {
  margin: 0;
  color: #242422;
  font-size: 1.2rem;
  font-weight: bold;
  display: flex;
  align-items: center;
}

@media screen and (min-width: 767px) {
  .cta-buttons {
    flex-direction: column;
  }
  .cta-button-wrapper {
    flex-direction: row;
  }
  .cta-desc {
    font-size: 1rem;
    font-weight: bold;
  }
}

@media screen and (max-width: 767px) {
  .cta-button-wrapper {
    flex-direction: column;
    align-items: flex-start;
  }
  .cta-button-wrapper .btn {
    width: 100%;
  }
  .cta-desc {
    display: block;
    align-items: initial;
  }
}

.btn-outline {
  background-color: #fff !important;
  color: #242422 !important;
  border: 2px solid #242422 !important;
  transition: background-color 0.3s, color 0.3s;
}
.cta-button {
  border: 2px solid #242422 !important;
  font-size: 1.25rem !important;
}
.btn-outline:hover {
  background-color: #242422 !important;
  color: #fff !important;
}

.cta-button-wrapper .btn {
  width: 300px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .cta-button-wrapper .btn {
    width: 100%;
  }

  .cta-button {
    font-size: 1rem !important;
  }
}


/* --- section-cta（リンクブロック）用レイアウト調整 --- */
.cta-buttons {
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
    max-width: 900px;
    margin: 0 auto;
    background: none;
}

.cta-button-wrapper {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1.5rem;
    flex-wrap: nowrap;
    background: none;
}

.cta-button-wrapper .btn.cta-button {
    min-width: 340px;
    max-width: 100%;
    height: 56px;
    font-size: 1.4rem;
    font-weight: bold;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.10);
    border: 3px solid #222;
    transition: background 0.3s, color 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cta-button-wrapper .btn.cta-button.cta-button-480 {
    min-width: 480px;
}

.cta-button-wrapper .btn.cta-button {
    background: #21A6A1 !important;
    color: #fff !important;
}

.cta-button-wrapper .btn.cta-button.cta-button-blue {
    background: #3FC9F3 !important;
    color: #fff !important;
}

.cta-button-wrapper .btn.cta-button.cta-button-orange {
    background: #FCB942 !important;
    color: #FFF !important;
}

.cta-button-wrapper .btn.btn-outline.cta-button {
    background: #fff !important;
    color: #222 !important;
    border: 3px solid #222 !important;
}

.cta-button-wrapper .btn.cta-button:hover {
    background: #36ADD4 !important;
    color: #fff !important;
}

.cta-button-wrapper .btn.cta-button.cta-button-blue:hover {
    background: #36ADD4 !important;
    color: #FFF !important;
}

.cta-button-wrapper .btn.cta-button.cta-button-orange:hover {
    background: #E0A734 !important;
    color: #FFF !important;
}

.cta-button-wrapper .btn.btn-outline.cta-button:hover {
    background: #242422 !important;
    color: #fff !important;
}

.cta-desc {
    margin: 0;
    margin-left: 0;
    font-size: 1.2rem;
    color: #222;
    font-weight: bold;
    text-align: left;
    min-width: 320px;
}

@media screen and (max-width: 767px) {
    .cta-buttons {
        max-width: 100%;
        padding: 0 1rem;
    }
    .cta-button-wrapper {
        gap: 1.2rem;
    }
    .cta-button-wrapper .btn.cta-button {
        min-width: 0;
        width: 95vw;
        max-width: 100%;
        font-size: 1.1rem;
        height: 48px;
        margin-left: auto;
        margin-right: auto;
    }
    .cta-button-wrapper {
        padding-left: 0;
        padding-right: 0;
    }
    .cta-desc {
        font-size: 1rem;
        min-width: 0;
    }
    .cta-button-wrapper .btn.cta-button.cta-button-480 {
        min-width: 0px;
    }
}

@media screen and (max-width: 767px) {
    .cta-button-wrapper {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }
    .cta-button-wrapper .btn.cta-button {
        margin-bottom: 0.5rem;
    }
    .cta-desc {
        margin-left: 0;
        text-align: left;
        margin-bottom: 1.5rem;
    }
}

.section-cta {
    background-color: #156082;
}

.cta-desc {
    color:#fff;
}
.section_11 .cta-button-wrapper .btn.cta-button {
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
}

.required::after {
  content: " *";
  color: red;
  vertical-align: middle;
}

@media screen and (min-width:767px){
    .section_present p {
        font-size: 1.0rem;
        text-align: left;
        margin-left: 60px;
        padding-top: 20px;
    }
}

@media screen and (min-width: 767px) {
    .section-course-tabs .container {
      /*max-width: 1200px;*/  /* 例: 1200pxにする（お好みで調整） */
      width: 80%;
      margin: 0 auto;
    }
    .course-tabs {
        display: flex;
        justify-content: center;
        margin-bottom: 2rem;
    }
    .course-tabs-document {
        display:flex;
        justify-content:center; 
    }
    .course-tabs-document p {
        margin-right:30px; 
    }
}

@media screen and (max-width: 767px) {
    .section-course-tabs .container {
      /*max-width: 1200px;*/  /* 例: 1200pxにする（お好みで調整） */
      width: 95%;
      margin: 0 auto;
    }
    .course-tabs {
        display:flex;
        justify-content:center;
        margin-bottom: 2rem;
    }
    .course-tabs-document {
    }
    .course-tabs-document p {
    }
    .course-tabs.table {
        display: block;
    }
    .course-tabs.table-cell {
        display: block
    }
}

.tab-button {
  flex: 1;
  padding: 1rem;
  border: none;
  font-weight: bold;
  font-size: 1.1rem;
  background-color: #f0f0f0;
  cursor: pointer;
  border-top: 3px solid #999;
  transition: background 0.3s;
}

.tab-button.active {
  background-color: #c6f0ef;
  border-top-color: #21A6C1;
}
.course-content {
  display: none;
  text-align: left;
}

.course-content.active {
  display: block;
}

.course-a-detail {
  text-align: left;
  /*padding: 2rem;*/
  /*background-color: #f9f9f9;*/
  border-radius: .5rem;
}

.course-a-detail .strong {
  font-weight: bold;
  font-size: 1.2rem;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
  color: #242422;
}

.course-a-detail .feature-list {
  list-style-type: disc;
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

.course-a-detail .caption {
  font-size: 0.9rem;
  font-weight: bold;
  color: #666;
  margin-top: 0.5rem;
}

.icon-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}

.icon-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 1rem;
  color: #242422;
  font-weight: bold;
}

.icon-item img {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}

.course-price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap; 
  gap: 1rem;
  margin-top: 2rem;
}

.course-price-row .price-text {
  flex: 1;
}

.course-price-row .price-button {
  flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .course-price-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .course-price-row .price-button {
    width: 100%;
  }
}

.course-price-row .price-text {
  flex: 1;
}

.course-price-row .price-button {
  flex-shrink: 0;
}

@media screen and (max-width: 767px) {
  .course-price-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .course-price-row .price-button {
    width: 100%;
  }
}

.course-tabs-gray {
    background-color: #f5f5f5;
}

