
/* CSS Document */

/*==================================================

top-contents
=================================================*/


.new-top .photo {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
}
.new-top .photo .pict {
    width: 50%;
}

.new-top .ring-title::before {
    content: " ";
	display: block;
    position: absolute;
    width: 240%;
    padding-top: 240%;
}
.new-top .ring-title span {
    display: block;
    position: absolute;
    width: 260%;
    padding-top: 260%;
    transform-origin: center;
}
.top-image.new-top .txt h1 {
    width: 24%;
    max-width: 444px;
    position: relative;
}
.top-image.new-top .txt .sub {
    width: 24%;
    max-width: 444px;
    text-align: left;
    color: #FFF;
}
.top-image.new-top .txt .sub span {
    display: inline-block;
    text-align: left;
    margin-left: -65%;
}

.top-image.message .txt .sub {
    color: #55a5ff;
}

.prologue {
    position: relative;
    text-align: left;
    background: linear-gradient(90deg, #72b8dc, #5a85e4);
}
.prologue h2 {
    display: inline-block;
    font-size: clamp(1.4rem, 2.4vw, 3rem);
    line-height: 160%;
    text-align: left;
    font-weight: 600;
    background: linear-gradient(90deg, #FFF 0%, #FFF 100%);
    color: transparent;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    padding: 6em 5% 5em;
}
.prologue::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    background-image: url("../../high_school/images/head_bg.png");
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    right: 0;
}
h1.section-title {
    font-family: "Archivo Black", 'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", YuGothicM, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 400;
    text-align: center;
    font-size: clamp(4rem, 7vw, 12rem);
    color: #194fcb;
    line-height: 140%;
    letter-spacing: 0;
}
h1.section-title strong {
    display: inline-block;
    position: relative;
}
h1.section-title strong::before {
    content: " ";
	display: block;
    position: absolute;
    width: 120%;
    height: 100%;
    background-image: url("../../high_school/images/title_effect.png");
    background-position: left top;
    background-repeat: no-repeat;
    background-size: .5em;
    top: 5%;
    left: -10%;
    z-index: 1;
}
h1.section-title span {
    display: block;
    font-weight: 800;
    color: #000;
    font-size: clamp(1.6rem, 2vw, 3rem);
    line-height: 120%;
    text-align: center;
}

.about-bg {
    position: relative;
    background-size: auto auto;
    background-color: rgba(255, 248, 204, 1);
    background-image: repeating-linear-gradient(135deg, transparent, transparent 10px, rgba(255, 246, 190, 1) 10px, rgba(255, 246, 190, 1) 20px );
}
.about {
    width: 100%;
    position: relative;
    padding: 6em 0 6em;
}
.about::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: .2;
    background-image: 
    url("../../high_school/images/bg1.png"),
    url("../../high_school/images/bg3.png"),
    url("../../high_school/images/bg5.png");
    background-position:
    right -12em top,
    left -6em top 40%,
    right 1em top 80%;
    background-repeat: no-repeat;
    background-size: 24em,18em,10em;
    top: 0;
    left: 0;
    z-index: 0;
}

.about .inner {
    width: 90%;
    max-width: 1300px;
    position: relative;
    background-color: #FFF;
    border: 5px solid #000;
    background-image: url("../../high_school/images/about_corner.png");
    background-position: left 35px bottom 35px;
    background-repeat: no-repeat;
    background-size: 10%;
    border-radius: 60px;
    margin: 0 auto;
    padding: 5em 0 8em;
    z-index: 3;
}
.about .inner .item {
    width: 83%;
    position: relative;
    margin: 0 auto;
    padding-top: 5em;
}
.about .inner .item .txt {
    position: relative;
    z-index: 2;
}
.about .inner .item .photo {
    width: 38%;
    position: absolute;
    top: 5%;
    right: -3%;
    z-index: 1;
}
.about .inner .item .photo img {
    width: 100%;
	max-width: 100%;
	height: auto;
}
.about .inner .item h2 {
    width: 63%;
    max-width: 666px;
    font-weight: 700;
    font-size: clamp(2rem, 3vw, 5rem);
    letter-spacing: 0;
}
.about .inner .item h2 strong {
    font-weight: 600;
    font-size: clamp(2.8rem, 5vw, 7rem);
    color: #ffb000;
    line-height: 160%;
    letter-spacing: 0;
}
.about .inner .item h2 span {
    font-size: clamp(2.8rem, 5vw, 7rem);
}
.about .inner .item dl {
    margin-top: 3em;
}
.about .inner .item dl dt {
    width: 60%;
    max-width: 460px;
    position: relative;
    cursor: pointer;
    font-size: clamp(1.6rem, 2vw, 2.4rem);
    text-align: center;
    background-color: #194fcb;
    border: 4px solid #194fcb;
    color: #FFF;
    border-radius: 60px;
    padding: 1em 1em;
    
    transition: all 0.3s;
}
dl.slide > dt::after {
    content: " ";
	display: block;
    position: absolute;
    width: 38px;
    height: 38px;
    background-image: url("../../high_school/images/plus.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    top: 50%;
	right: 20px;
	transform: translate(0, -50%);
    z-index: 1;
}
dl.slide dt.addbg {
    color: #194fcb!important;
    background-color: #FFF!important;
}
dl.slide dt.addbg::after {
    background-image: url("../../high_school/images/plus_b.png")!important;
}
@media (hover: hover) {
    dl.slide > dt:hover {
        color: #5a85e4!important;
        background-color: #FFF!important;
    }
    dl.slide > dt:hover::after {
        background-image: url("../../high_school/images/plus_hover.png");
    }
}

.about .inner .item dl dd {
    padding: 3em 0 0;
}
.about .inner .item .icon {
    width: 100%;
    max-width: 1250px;
    margin: 5em auto 0;
}

.job-info {
    width: 100%;
    position: relative;
    /*background-image: url("../../images/circle_normal.gif");
    background-position: left -12em top;
    background-repeat: no-repeat;
    background-size: 36em;*/
}
.job-info::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: .2;
    background-image: 
    url("../../high_school/images/bg4.png"),
    url("../../high_school/images/bg1.png"),
    url("../../high_school/images/bg5.png");
    background-position:
    left -12em top,
    right -6em top 40%,
    left 1em top 90%;
    background-repeat: no-repeat;
    background-size: 24em,18em,10em;
    top: 0;
    left: 0;
    z-index: 0;
}
.job-info .inner {
    width: 90%;
    max-width: 1300px;
    position: relative;
    margin: 0 auto;
}
.job-info .inner::before {
    content: " ";
	display: block;
    position: absolute;
    pointer-events: none;
    width: 10%;
    height: 15%;
    background-image: url("../../high_school/images/s_icon1.png");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    top: 45%;
    right: 3%;
	transform: translate(0, -50%);
    z-index: 1;
}
.job-info .inner::after {
    content: " ";
	display: block;
    position: absolute;
    pointer-events: none;
    width: 20%;
    height: 25%;
    background-image: url("../../high_school/images/l_icon1.png");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    left: 0;
    bottom: 0;
	transform: translate(-5%, 20%);
    z-index: 1;
}
.job-info .inner .txt {
    width: 100%;
    text-align: center;
}
.job-info .inner .switch {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    margin: 4em auto 0;
}
.job-info .inner .switch li {
    width: 33.2%;
    cursor: pointer;
    position: relative;
    color: #AAA;
    text-align: center;
    font-size: clamp(1.8rem, 2.8vw, 3rem);
    line-height: 160%;
    background-color: #FFF;
    background-image: url("../../high_school/images/tab_b.png");
    background-position: left 2em center;
    background-repeat: no-repeat;
    background-size: 10%;
    border-radius: 10px 10px 0 0;
    padding: .8em 1em;
}
.job-info .inner .switch li.active {
    color: #FFF;
    border: 5px solid #000;
    border-bottom: none;
    background-image: url("../../high_school/images/tab.png");
    background-color: #194fcb;
}
.job-info .inner .switch li.active::after {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 10px;
    background-color: #194fcb;
    left: 0;
    bottom: -6px;
    z-index: 1;
}
.job-info .inner .item {
    border: 5px solid #000;
    background-color: #194fcb;
    border-radius: 0 0 20px 20px;
    padding: 5em;
}
.job-info .inner .item p {
    width: 90%;
    position: relative;
    text-align: left;
    margin: 0 auto;
    padding: 1em 0;
}
.job-info .inner .item p.fukidashi {
    width: 90%;
    position: relative;
    border-radius: 100px;
    background-color: #FFF;
    margin: 60px auto 0;
    padding: 2em 5em;
}
.job-info .inner .item p.fukidashi::before {
    content: " ";
	display: block;
    position: absolute;
    width: 40px;
    height: 35px;
    background-color: #FFF;
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    top: 0;
	left: 50%;
	transform: translate(-50%, -97%);
    z-index: 1;
}

.job-info .inner .item .movie {
	width: 80%;
    background-color: rgba(0, 0, 0, 1);
    margin: 0 auto;
}
.job-info .inner .item .movie video {
	display: block;
	outline: none;
	margin: 0 auto;
}

.interview {
    width: 100%;
    position: relative;
    /*background-image: url("../../images/circle_normal.gif");
    background-position: right -12em top;
    background-repeat: no-repeat;
    background-size: 36em;*/
    padding: 6em 0;
}
.interview::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: .2;
    background-image: 
    url("../../high_school/images/bg1.png"),
    url("../../high_school/images/bg3.png"),
    url("../../high_school/images/bg5.png");
    background-position:
    right -12em top,
    left -6em top 40%,
    right 1em top 80%;
    background-repeat: no-repeat;
    background-size: 24em,18em,10em;
    top: 0;
    left: 0;
    z-index: 0;
}
.interview .inner {
    width: 90%;
    max-width: 1200px;
    position: relative;
    background-image: url("../../high_school/images/about_corner.png");
    background-position: left 35px bottom 35px;
    background-repeat: no-repeat;
    background-size: 10%;
    margin: 0 auto;
}
.interview .inner::before {
    content: " ";
	display: block;
    position: absolute;
    pointer-events: none;
    width: 20%;
    height: 20%;
    background-image: url("../../high_school/images/s_icon2.png");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    top: 0;
    right: 0;
	transform: translate(0, -10%);
    z-index: 1;
}
.interview .inner .movie {
    width: 70%;
    background-color: rgba(0, 0, 0, 1);
    margin: 4em auto 0;
}

.education {
    width: 100%;
    position: relative;
    /*background-image: url("../../images/circle_normal.gif");
    background-position: left -12em top;
    background-repeat: no-repeat;
    background-size: 36em;*/
}
.education::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: .2;
    background-image: 
    url("../../high_school/images/bg4.png"),
    url("../../high_school/images/bg1.png"),
    url("../../high_school/images/bg5.png");
    background-position:
    left -10em top,
    right -6em top 40%,
    left 1em top 90%;
    background-repeat: no-repeat;
    background-size: 24em,18em,10em;
    top: 0;
    left: 0;
    z-index: 0;
}
.education .inner {
    width: 90%;
    max-width: 1400px;
    position: relative;
    margin: 0 auto;
}
.education .inner::before {
    content: " ";
	display: block;
    position: absolute;
    pointer-events: none;
    width: 20%;
    height: 20%;
    background-image: url("../../high_school/images/s_icon3.png");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    top: 0;
    left: 0;
	transform: translate(-20%, -10%);
    z-index: 1;
}
.education .inner dl {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center; 
    overflow: hidden;
    background-color: #fff;
    border: 5px solid #000;
    border-radius: 40px;
    margin-top: 4em;
    padding: 2em 6em;
}
.education .inner dl dt {
    width: 20%;
    display: none;
}
.education .inner dl dd {
    width: 100%;
    padding-left: 0;
}
.education .inner dl dd h2 {
    width: 100%;
    max-width: 480px;
    color: #FFF;
    text-align: center;
    font-size: clamp(1.6rem, 2vw, 2.4rem);
    background-color: #194fcb;
    border-radius: 60px;
    margin: 0 auto .8em;
    padding: .6em 1.2em;
}

.reason {
    width: 100%;
    position: relative;
    /*background-image: url("../../images/circle_normal.gif");
    background-position: right -12em top;
    background-repeat: no-repeat;
    background-size: 36em;*/
    padding: 4em 0 0;
}
.reason::before {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: .2;
    background-image: 
    url("../../high_school/images/bg1.png"),
    url("../../high_school/images/bg3.png"),
    url("../../high_school/images/bg5.png");
    background-position:
    right -12em top,
    left -6em top 40%,
    right 1em top 80%;
    background-repeat: no-repeat;
    background-size: 24em,18em,10em;
    top: 0;
    left: 0;
    z-index: 0;
}
.reason .inner {
    width: 90%;
    max-width: 1400px;
    position: relative;
    margin: 0 auto;
}
.reason .inner::before {
    content: " ";
	display: block;
    position: absolute;
    pointer-events: none;
    width: 11%;
    height: 20%;
    background-image: url("../../high_school/images/s_icon4.png");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    top: 0;
    right: 0;
	transform: translate(-25%, 6%);
    z-index: 1;
}
.reason .inner ul {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    margin-top: 3em;
}
.reason .inner ul li {
    width: 32%;
    overflow: hidden;
    border: 5px solid #000;
    background-color: #fff;
    margin-top: 2em;
    border-radius: 20px;
}
.reason .inner ul li dd {
    padding: 1.5em 2em 2em;
}
.reason .inner ul li dd h2 {
    color: #FFF;
    text-align: center;
    font-size: clamp(1.6rem, 2vw, 2.4rem);
    background-color: #ffa200;
    border-radius: 60px;
    padding: .3em 1em;
    margin-bottom: .5em;
}
.reason .inner ul li dd p.size-l {
    max-width: 283px;
    text-align: center;
    font-size: clamp(1.8rem, 2.4vw, 3rem);
    line-height: 160%;
    margin: 1.5em auto 0;
}
.reason .inner ul li dd p.size-l strong {
    font-size: clamp(1.8rem, 5vw, 10rem);
    font-weight: 600;
}

.top-etc {
    width: 100%;
    position: relative;
    /*background-image: url("../../images/circle_normal.gif");
    background-position: left -12em top;
    background-repeat: no-repeat;
    background-size: 36em;*/
    padding: 6em 0 0;
}
.top-etc .inner {
    width: 90%;
    max-width: 1400px;
    position: relative;
    margin: 0 auto;
}
.top-etc .inner > dl:nth-of-type(1) {
    margin-bottom: 5em;
}
.top-etc .inner > dl > dt {
    width: 100%;
    position: relative;
    cursor: pointer;
    font-size: clamp(1.6rem, 2vw, 2.4rem);
    text-align: center;
    background-color: #194fcb;
    border: 5px solid #194fcb;
    color: #FFF;
    border-radius: 60px;
    padding: 1em 1em;
    
    transition: all 0.3s;
}
.top-etc .inner > dl > dd > p.info {
    text-align: center;
    margin: 2em 0;
}
.top-etc .inner > dl > dd .benefit {
    width: 100%;
    display: table;
    border: 5px solid #000;
    overflow: hidden;
    margin-top: 1.5em;
    border-radius: 20px;
}
.top-etc .inner > dl > dd > dl:nth-of-type(1) {
    margin-top: 4em;
}
.top-etc .inner > dl > dd .benefit dt {
    width: 33%;
    display: table-cell;
    color: #FFF;
    font-size: clamp(1.8rem, 2vw, 3rem);
    line-height: 160%;
    vertical-align: middle;
    background-color: #194fcb;
    padding: 2em;
}
.top-etc .inner > dl > dd .benefit dd {
    display: table-cell;
    vertical-align: top;
    background-color: #FFF;
    padding: 2em 1em 2em 3em;
}
.top-etc .inner > dl > dd .benefit dd ul {
    width: 48%;
    display: inline-block;
    vertical-align: top;
}
.top-etc .inner > dl > dd .benefit dd ul li {
    position: relative;
    padding-right: 1em;
}
.top-etc .inner > dl > dd .benefit dd ul li::before {
    content: "■";
	display: block;
    width: 1em;
    height: 1em;
    position: absolute;
    color: #2654ab;
    top: 0;
    left: -1em;
    z-index: 1;
}
.top-etc .inner .recruit-data table:nth-of-type(1) {
    margin-bottom: 4em;
}

.parent-link {
    width: 100%;
    background: linear-gradient(90deg, #72b8dc, #5a85e4);
}
.parent-link::after {
    content: " ";
	display: block;
    position: absolute;
    width: 50%;
    height: 100%;
    background-image: url("../../high_school/images/mv_sp.jpg");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    top: 0;
    right: 0;
    z-index: 1;
}
.parent-link dl {
    width: 90%;
    max-width: 1400px;
    position: relative;
    display: flex;
    flex-flow: row-reverse wrap;
    overflow: hidden;
    margin: 6em auto 0;
    z-index: 2;
}
.parent-link dt {
    width: 50%;
}
.parent-link dt img {
    width: 100%;
	max-width: 100%;
	height: auto;
    opacity: 0;
}
.parent-link dd {
    width: 50%;
    text-align: center;
    
    padding: 5%;
}
.parent-link dd h1 {
    color: #FFF;
    font-size: clamp(3rem, 6vw, 8rem);
    line-height: 160%;
    letter-spacing: 0;
}
.parent-link dd h1 span {
    display: block;
    font-size: clamp(1.6rem, 2vw, 3rem);
    line-height: 160%;
}
.parent-link dd .button {
    max-width: 380px;
    margin: 1.5em auto 0;
}

.parent-message {
    position: relative;
    padding: 5em 0 0;
}
.parent-message::before {
    content: " ";
	display: block;
    position: absolute;
    opacity: .8;
    width: 100%;
    height: 100%;
    background-image: url("../../images/circle_normal.gif"),url("../../images/circle_normal.gif");
    background-position: left -12em top,right -10em bottom;
    background-repeat: no-repeat;
    background-size: 32em,24em;
    top: 0;
    left: 0;
    z-index: 1;
}
.parent-message section {
    width: 90%;
    max-width: 1200px;
    position: relative;
    margin: 0 auto 3em;
    z-index: 2;
}
.parent-message section:nth-last-of-type(1) {
    margin: 0 auto;
}
.parent-message section h1 {
    color: #2654ab;
}
.parent-message section p {
    margin-top: 1em;
}

@media only screen and (min-width:1px) and (max-width: 960px) {
    
    .reason .inner ul li {
        width: 48%;
        max-width: 450px;
        border-width: 4px;
        overflow: hidden;
        margin-top: 2em;
        border-radius: 20px;
    }
    
}
@media only screen and (min-width:1px) and (max-width: 768px) {
	
    
    .prologue h2 {
        text-align: left;
        padding: 3em 5%;
    }
    .about {
        width: 100%;
        padding: 3em 0;
    }
    .about .inner {
        border: 4px solid #000;
        background-position: left -2% bottom 2%;
        background-size: 15%;
        border-radius: 20px;
        margin: 0 auto;
        padding: 3em 0 3em;
    }

    .about .inner .item {
        width: 85%;
        position: relative;
        margin: 0 auto;
        padding-top: 2em;
    }
    .about .inner .item .photo {
        width: 60%;
        position: relative;
        top: 0;
        right: 0;
        margin: 0 auto 2em;
        z-index: 1;
    }
    .about .inner .item h2 {
        width: 98%;
        text-align: center;
        letter-spacing: 0;
    }
    .about .inner .item dl {
        margin-top: 2em;
    }
    .about .inner .item dl dt {
        width: 100%;
        border: 2px solid #194fcb;
        margin: 0 auto;
    }
    
    dl.slide > dt::after {
        width: 30px;
        height: 30px;
    }
    dl.slide dt.addbg::after {
        background-image: url("../../high_school/images/plus_b.png")!important;
    }

    .about .inner .item dl dd {
        padding: 2em 0 0;
    }
    .about .inner .item .icon {
        width: 100%;
        max-width: 1250px;
        margin: 2em auto 0;
    }

    .job-info {
        width: 100%;
        position: relative;
        margin: 0 auto;
    }
    .job-info .inner {
        width: 90%;
        max-width: 1400px;
        position: relative;
        margin: 0 auto;
    }
    .job-info .inner::after {
        content: " ";
        display: block;
        position: absolute;
        pointer-events: none;
        width: 20%;
        height: 25%;
        left: -5%;
        bottom: -2%;
        transform: translate(-5%, 35%);

        z-index: 1;
    }
    .job-info .inner::before {
        content: " ";
        display: block;
        position: absolute;
        pointer-events: none;
        width: 10%;
        height: 15%;
        top: 30%;
        right: 3%;
        transform: translate(0, -30%);
        z-index: 2;
    }
    .job-info .inner .txt {
        width: 100%;
        text-align: center;
    }
    .job-info .inner .switch {
        margin: 2em auto 0;
    }
    .job-info .inner .switch li {
        width: 33%;
        cursor: pointer;
        font-size: clamp(1.8rem, 2.8vw, 3rem);
        background-position: left .5em center;
        background-size: 16%;
        line-height: 160%;
        border-radius: 10px 10px 0 0;
        padding: .8em 5%;
    }
    .job-info .inner .switch li.active {
        color: #FFF;
        border: 4px solid #000;
        border-bottom: none;
    }
    .job-info .inner .item {
        border: 4px solid #000;
        padding: 3em 5% 3em;
    }
    .job-info .inner .item p.fukidashi {
        width: 100%;
        max-width: 480px;
        text-align: left;
        border-radius: 20px;
        margin: 8% auto 0;
        padding: 2em 2em;
    }
    .job-info .inner .item p.fukidashi br {
        display: none;
    }
    .job-info .inner .item p.fukidashi::before {
        content: " ";
        display: block;
        position: absolute;
        width: 20px;
        height: 15px;
        z-index: 1;
    }

    .job-info .inner .item .movie {
        width: 100%;
        background-color: rgba(0, 0, 0, 1);
    }
    .job-info .inner .item .movie video {
        display: block;
        outline: none;
        margin: 0 auto;
    }

    .interview {
        width: 100%;
        background-size: 24em;
        padding: 3em 0;
    }
    .interview .inner {
        background-size: 12%;
        margin: 0 auto;
    }
    .interview .inner::before {
        transform: translate(25%, 8%);
        z-index: 1;
    }
    .interview .inner .movie {
        width: 100%;
        margin-top: 2em;
    }

    .education {
        width: 100%;
        position: relative;
        background-position: left -12em top;
        background-repeat: no-repeat;
        background-size: 24em;
    }
    .education .inner {
        width: 90%;
        max-width: 1400px;
        position: relative;
        margin: 0 auto;
    }
    .education .inner::before {
        width: 30%;
        height: 30%;
        top: 0;
        left: 0;
        transform: translate(-25%, 8%);
        z-index: 1;
    }
    .education .inner dl {
        width: 100%;
        flex-direction: column;
        overflow: hidden;
        background-color: #fff;
        border-width: 4px;
        border-radius: 20px;
        margin-top: 2em;
        padding: 2em 2em;
    }
    .education .inner dl dt {
        width: 80%;
        max-width: 180px;
    }
    .education .inner dl dd {
        flex: 1;
        margin-top: 0;
        padding-left: 0;
    }
    .education .inner dl dd h2 {
        text-align: center;
    }

    .reason {
        width: 100%;
        position: relative;
        background-position: right -12em top;
        background-repeat: no-repeat;
        background-size: 24em;
        padding: 3em 0 0;
    }
    .reason::after {
        transform: translate(5%, -40%);

        z-index: 1;
    }
    
    .reason .inner {
        width: 90%;
        max-width: 1400px;
        position: relative;
        margin: 0 auto;
    }
    .reason .inner::before {
        content: " ";
        display: block;
        position: absolute;
        pointer-events: none;
        width: 18%;
        height: 20%;
        top: 0;
        right: 0;
        transform: translate(0, 0);
        z-index: 1;
    }
    .reason .inner ul {
        margin-top: 0;
    }
    
    .reason .inner ul li dd {
        padding: 1.5em 2em 2em;
    }
    .reason .inner ul li dd h2 {
        text-align: center;
        margin-bottom: .6em;
    }
    .reason .inner ul li dd p.size-l {
        text-align: center;
        font-size: clamp(1.8rem, 3vw, 3rem);
        line-height: 160%;
        margin-top: 1.5em;
    }
    .reason .inner ul li dd p.size-l strong {
        font-size: 300%;
        font-weight: 600;
    }

    .top-etc {
        width: 100%;
        position: relative;
        background-position: left -12em top;
        background-repeat: no-repeat;
        background-size: 24em;
        padding: 3em 0 0;
    }
    .top-etc .inner {
        width: 90%;
        max-width: 1400px;
        position: relative;
        margin: 0 auto;
    }
    .top-etc .inner > dl:nth-of-type(1) {
        margin-bottom: 3em;
    }
    .top-etc .inner > dl > dt {
        width: 100%;
        color: #FFF;
        border-width: 4px;
        border-radius: 60px;
        padding: 1em 1em;

        transition: all 0.3s;
    }
    .top-etc .inner > dl > dd > p.info {
        text-align: center;
        margin: 2em 0;
    }
    .top-etc .inner > dl > dd .benefit {
        width: 100%;
        display: block;
        border-width: 4px;
        overflow: hidden;
        margin-top: 1.5em;
        border-radius: 20px;
    }
    .top-etc .inner > dl > dd > dl:nth-of-type(1) {
        margin-top: 3em;
    }
    .top-etc .inner > dl > dd .benefit dt {
        width: 100%;
        display: block;
        font-size: clamp(1.8rem, 2vw, 3rem);
        line-height: 160%;
        vertical-align: middle;
        padding: 1.5em;
    }
    .top-etc .inner > dl > dd .benefit dt br {
        display: none;
    }
    .top-etc .inner > dl > dd .benefit dd {
        width: 100%;
        display: block;
        vertical-align: top;
        background-color: #FFF;
        padding: 2em 3em;
    }
    .top-etc .inner > dl > dd .benefit dd ul {
        width: 100%;
        display: block;
        vertical-align: top;
    }
    .top-etc .inner > dl > dd .benefit dd ul li {
        position: relative;
        padding-right: 1em;
    }
    .top-etc .inner > dl > dd .benefit dd ul li::before {
        content: "■";
        display: block;
        width: 1em;
        height: 1em;
        position: absolute;
        top: 0;
        left: -1em;
        z-index: 1;
    }
    .top-etc .inner .recruit-data table:nth-of-type(1) {
        margin-bottom: 4em;
    }
    
    .parent-link::after {
        display: none;
    }
    .parent-link dl {
        width: 100%;
        max-width: 1400px;
        flex-direction: column;
        overflow: hidden;
        border-radius: 0;
        margin: 3em auto 0;
    }
    .parent-link dt {
        width: 100%;
    }
    .parent-link dt img {
        opacity: 1;
    }
    .parent-link dd {
        width: 100%;
        text-align: center;
        background: linear-gradient(90deg, #72b8dc, #5a85e4);
        padding: 2em 1em 3em;
    }
    .parent-link dd h1 {
        color: #FFF;
        font-size: clamp(3rem, 6vw, 8rem);
        line-height: 160%;
        letter-spacing: 0;
    }
    .parent-link dd h1 span {
        display: block;
        font-size: clamp(1.6rem, 2vw, 3rem);
        line-height: 160%;
    }
    .parent-link dd .button {
        max-width: 380px;
        margin: 1.5em auto 0;
    }

}

@media only screen and (min-width:1px) and (max-width: 568px) {
	
    .reason .inner ul {
        flex-direction: column;
        align-items: center; 
        margin-top: 0;
    }
    .reason .inner ul li {
        width: 100%;
    }

}
	
@media only screen and (min-width:1px) and (max-width: 480px) {
	

}

