﻿@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Asap:ital,wght@0,500;0,600;0,700;1,500;1,600;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap');

@charset "UTF-8";

/*----------------------
 * 1. GENERAL
 *   1.1  Margin
 *   1.2  Text
 *   1.3  Titles and Subtitles
 *   1.4  Lists
 *   1.5 Other Elements
 *        1.5.1 page top
 *        1.5.2 movie
 *        1.5.3 google map
 *        1.5.4 side oc btn
 * 2. HEADER
 * 3. NAV
 *    3.1. Main Nav (pc)
 *    3.2. Main Nav (sp)
 * 4. CONTENTS
 *    4.1 Swiper
 *    4.2 Cate Title
 *    4.3 Btn
 *    4.4 Career
 *    4.5 Course
 *    4.6 Open Campus
 *    4.7 Summary
 *    4.8 School
 *    4.9 Guidance
 * 5. TOP
 *    5.1 Main Visual
 *    5.2 Reason
 *    5.3 Open campus
 *    5.4 News
 * 6. FOOTER
 * 7. INTERACTIONS
 * 8. 追加 220721 オープンキャンパス 締切時のテキスト追加
 * 9. 追加 230302 アクセスマップ Google mpasの変更
 * 10. 追加 230509 オープンキャンパス 緑追加暫定
 */

/*-------------------------------
 * 1.GENERAL
 * ----------------------------*/
@font-face {
	font-family: 'BrownhillScript';
	src: url('../fonts/BrownhillScript.woff2') format('woff2'),
	        url(../fonts/BrownhillScript.ttf) format('truetype');
}

html {
    font-size: 62.5%;
}
html,
body {
	overflow-x: hidden;
}
body {
    font-family: YakuHanJP, 'Zen Maru Gothic', sans-serif;
    margin: 0;
    padding: 0;
    font-size: 1.4rem;    
    background: #fff !important;
	color: 000;
	line-height: 1.8;
	font-weight: 400;
	letter-spacing: 0;
	overflow: hidden;
}
body#v2-top-page {
    background: #fff !important;
}
@media (max-width: 767px) {
    body {
        line-height: 1.9;
        font-size: 1.4rem;
    }
}
@media (max-width: 320px) {
    body {
        font-size: 1.2rem;
    }
}

a {
    color: #ef628b;
    text-decoration: none;
    cursor: pointer;
}
a:hover {
    color: #ef628b;
    text-decoration: underline;
}
a:focus {
  outline: none !important;
  overflow: hidden;
  text-decoration: none;
}
*:focus {
    outline: none;
}

a[href^="tel:"] {
	cursor: default;
	text-decoration: none;
}
a[href^="tel:"]:hover {
	text-decoration: none;
}
@media (max-width: 767px) {
	a[href^="tel:"] {
		cursor: pointer;
	}
}

small {
    font-size: 80%;
}

ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

strong {
    font-weight: 600;
}

img {
    display: block;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.sp,
.md,
.sp-md,
.sp-md-lg,
.md-lg,
.lg {
	display: none !important;
}
.pc,
.lg-pc {
    display: block !important;
}
@media (max-width: 1199px) {
    .lg,
    .md-lg,
    .sp-md-lg {
        display: block !important;
    }
}
@media (max-width: 991px) {
    .md,
    .sp-md {
        display: block !important;
    }
    .lg-pc {
        display: none !important;
    }
}
@media (max-width: 767px) {
    .sp {
        display: block !important;
    }
    .md-lg,
    .lg,
    .md,
    .pc {
        display: none !important;
    }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* 1.1  Margin
 * ------------------------------*/
.mt00 { margin-top: 0 !important; }
.mt05 { margin-top: 0.5rem !important; }
.mt10 { margin-top: 1rem !important; }
.mt15 { margin-top: 1.5rem !important; }
.mt20 { margin-top: 2rem !important; }
.mt30 { margin-top: 3rem !important; }
.mt40 { margin-top: 4rem !important; }
.mt50 { margin-top: 5rem !important; }
.mt60 { margin-top: 6rem !important; }
.mt70 { margin-top: 7rem !important; }
.mt80 { margin-top: 8rem !important; }

.mb00 { margin-bottom: 0 !important; }
.mb05 { margin-bottom: 0.5rem !important; }
.mb10 { margin-bottom: 1rem !important; }
.mb15 { margin-bottom: 1.5rem !important; }
.mb20 { margin-bottom: 2rem !important; }
.mb30 { margin-bottom: 3rem !important; }
.mb40 { margin-bottom: 4rem !important; }
.mb50 { margin-bottom: 5rem !important; }
.mb60 { margin-bottom: 6rem !important; }
.mb70 { margin-bottom: 7rem !important; }
.mb80 { margin-bottom: 8rem !important; }

.pt00 { padding-top: 0 !important; }
.pt10 { padding-top: 1rem !important; }
.pb00 { padding-bottom: 0 !important; }
.pb10 { padding-bottom: 1rem !important; }

@media (max-width: 767px) {
    .mt00-xs {
        margin-top: 0 !important;
    }
    .mt10-xs {
        margin-top: 1rem !important;
    }
    .mt15-xs {
        margin-top: 1.5rem !important;
    }
    .mt20-xs {
        margin-top: 2rem !important;
    }
    .mt30-xs {
        margin-top: 3rem !important;
    }
    .mt40-xs {
        margin-top: 4rem !important;
    }
    .mt50-xs {
        margin-top: 5rem !important;
    }
    .mt60-xs {
        margin-top: 6rem !important;
    }
    .mt70-xs {
        margin-top: 7rem !important;
    }
    .mt80-xs {
        margin-top: 8rem !important;
    }
    .mb00-xs {
        margin-bottom: 0 !important;
    }
    .mb10-xs {
        margin-bottom: 1rem !important;
    }
    .mb15-xs {
        margin-bottom: 1.5rem !important;
    }
    .mb20-xs {
        margin-bottom: 2rem !important;
    }
    .mb30-xs {
        margin-bottom: 3rem !important;
    }
    .mb40-xs {
        margin-bottom: 4rem !important;
    }
    .mb50-xs {
        margin-bottom: 5rem !important;
    }
    .mb60-xs {
        margin-bottom: 6rem !important;
    }
    .mb70-xs {
        margin-bottom: 7rem !important;
    }
    .mb80-xs {
        margin-bottom: 8rem !important;
    }
    .pt00-xs {
        padding-top: 0 !important;
    }
    .pt10-xs {
        padding-top: 1rem !important;
    }
    .pt20-xs {
        padding-top: 2rem !important;
    }
    .pt30-xs {
        padding-top: 3rem !important;
    }
    .pb00-xs {
        padding-bottom: 0 !important;
    }
    .pb10-xs {
        padding-bottom: 1rem !important;
    }
    .pb20-xs {
        padding-bottom: 2rem !important;
    }
    .pb30-xs {
        padding-bottom: 3rem !important;
    }
}

/* 1.2 Text
 * ------------------------------*/
p {
    margin: 1rem 0;
    /*text-align: justify;
    text-justify: inter-ideograph;*/
}
.line-height235 {
    line-height: 2 !important;
}
.line-height235 {
    line-height: 2.35 !important;
}
.text-left {
    text-align: left !important;
}
.text-center {
    text-align: center !important;
}
.text-right {
    text-align: right !important;
}
@media (max-width: 991px) {
     .text-left-md {
        text-align: left !important;
    }
    .text-center-md {
        text-align: center !important;
    }
    .text-right-md {
        text-align: right !important;
    }
}
@media (max-width: 767px) {
    .line-height2,
    .line-height235 {
        line-height: 1.8 !important;
    }
     .text-left-xs {
        text-align: left !important;
    }
    .text-center-xs {
        text-align: center !important;
    }
    .text-right-xs {
        text-align: right !important;
    }
}

.txt-black,
.txt-black a,
.txt-black a:hover {
    color: #000 !important;
}
.txt-red,
.txt-red a,
.txt-red a:hover {
    color: #dd0000 !important;
}
.txt-pink,
.txt-pink a,
.txt-pink a:hover {
    color: #ef628b !important;
}
.txt-blue,
.txt-blue a,
.txt-blue a:hover {
    color: #1398cc !important;
}
.txt-yellow,
.txt-yellow a,
.txt-yellow a:hover {
    color: #F4A738 !important;
}

a.txt-underline,
.txt-underline {
    text-decoration: underline !important;
}
a.txt-underline:hover {
    text-decoration: none !important;
}

.txt-marker {
    background: linear-gradient(transparent 60%, #ffda2a 60%);
}
.txt-marker.yellow {
    background: linear-gradient(transparent 60%, #ffda2a 60%);
}
.txt-marker.yellow-light {
    background: linear-gradient(transparent 70%, #FFEE9B 70%);
}
.txt-marker.pink {
    background: linear-gradient(transparent 60%, #F69AB3 60%);
}
.txt-marker.blue {
    background: linear-gradient(transparent 60%, #73BFEB 60%);
}

.en {
    font-family: 'Asap', sans-serif !important;
    font-style: italic !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
}

.f10 { font-size: 1rem !important; }
.f11 { font-size: 1.1rem !important; }
.f12 { font-size: 1.2rem !important; }
.f13 { font-size: 1.3rem !important; }
.f14 { font-size: 1.4rem !important; }
.f15 { font-size: 1.5rem !important; }
.f16 { font-size: 1.6rem !important; }
.f17 { font-size: 1.7rem !important; }
.f18 { font-size: 1.8rem !important; }
.f19 { font-size: 1.9rem !important; }
.f20 { font-size: 2rem !important; }
.f21 { font-size: 2.1rem !important; }
.f22 { font-size: 2.2rem !important; }
.f23 { font-size: 2.3rem !important; }
.f24 { font-size: 2.4rem !important; }
.f25 { font-size: 2.5rem !important; }
@media (max-width: 991px) {
    .f18, .f19 {
        font-size: 1.6rem !important;
    }
    .f20, .f21 {
        font-size: 1.7rem !important;
    }
    .f22, .f23 {
        font-size: 1.8rem !important;
    }
    .f24, .f25 {
        font-size: 2rem !important;
    }
}
@media (max-width: 767px) {
    .f13, .f14 {
        font-size: 1.2rem !important;
    }
    .f15, .f16 {
        font-size: 1.3rem !important;
    }
    .f17, .f18 {
        font-size: 1.4rem !important;
    }
    .f19, .f20, .f21 {
        font-size: 1.5rem !important;
    }
    .f22, .f23, .f24, .f25 {
        font-size: 1.6rem !important;
    }
    .f15-xs {
        font-size: 1.5rem !important;
    }
    .f14-xs {
        font-size: 1.4rem !important;
    }
    .f13-xs {
        font-size: 1.3rem !important;
    }
    .f12-xs {
        font-size: 1.2rem !important;
    }
    .f11-xs {
        font-size: 1.1rem !important;
    }
    .f10-xs {
        font-size: 1rem !important;
    }
}

/* 1.3 Titles and Subtitles
 * ------------------------------*/
h1, h2, h3, h4 {
    margin: 0;
    padding: 0;
}

.v2-section-ttl {
    text-align: center;
    font-size: 3.2rem;
    margin: 0 0 3rem;
    position: relative;
    font-weight: 600;
}
.v2-section-ttl.en {
    font-size: 5rem;
}
.v2-section-ttl .v2-icon-sub {
    display: inline-block;
    width: calc(57 / 1280 * 100vw);
    height: calc(50 / 1280 * 100vw);
    background: url(../image/icon/icon-sub.svg) center center no-repeat;
    background-size: contain;
    vertical-align: -40%;
    margin-right: 1rem;
}
.v2-section-ttl.en .v2-icon-sub {
    vertical-align: -10%;
}
.v2-section-ttl .v2-takabi {
    display: inline-block;
    width: calc(220 / 1280 * 100vw);
    margin-left: -0.5rem;
}
.v2-section-ttl .v2-txt {
    display: inline-block;
    vertical-align: -12%;
}
@media (min-width: 1280px) {
    .v2-section-ttl .v2-takabi {
        width: 220px;
    }
    .v2-section-ttl .v2-icon-sub {
        width: 57px;
        height: 50px;
    }
}
@media (max-width: 1199px) {
    .v2-section-ttl .v2-icon-sub {
        vertical-align: -30%;
    }
    .v2-section-ttl.en .v2-icon-sub {
        vertical-align: 0;
    }
}
@media (max-width: 991px) {
    .v2-section-ttl {
        font-size: 2.7rem;
    }
    .v2-section-ttl.en {
        font-size: 4rem;
    }
}
@media (max-width: 767px) {
    .v2-section-ttl {
        font-size: 2rem;
        margin-bottom: 2rem;
    }
    .v2-section-ttl.en {
        font-size: 3rem;
    }
    .v2-section-ttl .v2-takabi {
        width: 110px;
    }
    .v2-section-ttl .v2-icon-sub {
        width: 34px;
        height: 30px;
        vertical-align: -40%;
    }
    .v2-section-ttl.en .v2-icon-sub {
        vertical-align: -8%;
    }
}
@media (max-width: 480px) {
    .v2-section-ttl {
        font-size: 1.8rem;
    }
    .v2-section-ttl.en {
        font-size: 2.8rem;
    }
    .v2-section-ttl .v2-takabi {
        width: 100px;
    }
}

.v2-section-en {
    font-family: BrownhillScript;
    font-size: 12rem;
    text-align: center;
    letter-spacing: 0.05em;
    position: relative;
    margin: -2rem 0 2rem;
}
.v2-section-en::after {
    content:"";
    display: block;
    margin: auto;
    width: 100%;
    height: 20px;
    background: url(../image/line-pink.svg) top center no-repeat;
    background-size: contain;
    position: absolute;
    bottom: 7px;
    left: 0;
    right: 0;
    z-index: -1;
}
.v2-section-en.pink::after {
     background-image: url(../image/line-pink.svg);
}
.v2-section-en.blue::after {
     background-image: url(../image/line-blue.svg);
}
@media (max-width: 991px) {
    .v2-section-en {
        font-size: 10rem;
    }
    .v2-section-en::after {
        width: 60%;
    }
}
@media (max-width: 480px) {
    .v2-section-en {
        font-size: 6.8rem;
        margin-bottom: 1.5rem;
    }
    .v2-section-en::after {
        width: 85%;
        bottom: -5px;
    }
}
@media (max-width: 320px) {
    .v2-section-en {
        font-size: 5.8rem;
    }
}

.v2-section-sub {
    font-size: 2rem;
    text-align: center;
    font-weight: 600;
    margin: 0 0 4rem;
}
@media (max-width: 480px) {
    .v2-section-sub {
        font-size: 1.5rem;
        margin-bottom: 2rem;
    }
}
@media (max-width: 320px) {
    .v2-section-sub {
        font-size: 1.3rem;
    }
}

.v2-sub-bg {
    background: #ef628b;
    color: #fff;
    font-size: 2.4rem;
    text-align: center;
    padding: 1rem 0.5rem 1.2rem;
    letter-spacing: 0.03em;
    margin: 0 0 3rem;
}
.v2-sub-bg.v2-blue {
    background: #1398cc;
}
.v2-sub-line {
    position: relative;
    text-align: center;
    margin: 0 0 3rem;
    font-size: 2.7rem;
    letter-spacing: 0.03em;
}
.v2-sub-line::before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 1px;
  content: '';
  background: #000;
}
.v2-sub-line span {
  position: relative;
  padding: 0 2rem;
  background: #fff;
}
.v2-sub-line .icon-scissors {
    display: inline-block;
    width: 37px;
    margin-right: 1.5rem;
}
.v2-sub-line em {
    font-style: normal;
}
@media (max-width: 991px) {
    .v2-sub-bg {
        font-size: 2rem;
    }
    .v2-sub-line {
        font-size: 2.4rem;
    }
}
@media (max-width: 767px) {
    .v2-sub-bg {
        font-size: 1.5rem;
        padding: 0.7rem 0.5rem;
    }
    .v2-sub-line {
        font-size: 1.7rem;
        margin-bottom: 2rem;
    }
}
@media (max-width: 480px) {
    .v2-sub-line.v2-two-line span {
        display: inline-block;
        padding: 0 0.5rem 0 1rem;
        background: #fff;
    }
    .v2-sub-line .icon-scissors {
        margin-right: 0.5rem;
        width: 25px;
    }
    .v2-sub-line.v2-two-line em {
        display: block;
        top: -3px;
        position: relative;
    }
}
@media (max-width: 360px) {
    .v2-sub-line.v2-two-line::before {
        display: none;
    }
}
@media (max-width: 320px) {
    .v2-sub-line.v2-two-line {
        font-size: 1.5rem;
    }
}

.v2-sub-large  {
    font-size: 3rem;
    text-align: center;
    margin: 3rem 0 2.5rem;
    line-height: 1.8;
}
@media (max-width: 991px) {
    .v2-sub-large  {
        font-size: 2.5rem;
    }
}
@media (max-width: 767px) {
    .v2-sub-large  {
        font-size: 1.8rem;
        margin: 1.5rem 0;
    }
}
@media (max-width: 480px) {
    .v2-sub-large  {
        font-size: 1.6rem;
    }
}

.v2-sub-scissors {
    font-size: 3rem;
    text-align: center;
    margin: 0 0 2rem;
    line-height: 1.8;
    font-weight: 600;
    letter-spacing: 0.08em;
}
.v2-sub-scissors .v2-icon-scissors {
    display: inline-block;
    width: calc(37 / 1280 * 100vw);
    height: calc(50 / 1280 * 100vw);
    background: url(../image/icon/icon-scissors.svg) center center no-repeat;
    background-size: contain;
    vertical-align: -35%;
    margin-right: 1rem;
}
.v2-sub-scissors .v2-icon-scissors.v2-blue {
    background-image: url(../image/icon/icon-scissors-blue.svg)
}
.v2-sub-scissors .v2-icon-scissors.v2-yellow {
    background-image: url(../image/icon/icon-scissors-yellow.svg)
}
@media (max-width: 1199px) {
    .v2-sub-scissors {
        font-size: 2.7rem;
    }
    .v2-sub-scissors .v2-icon-scissors {
        width: 37px;
        height: 50px;
        vertical-align: -25%;
    }
}
@media (max-width: 767px) {
    .v2-sub-scissors {
        font-size: 1.9rem;
        margin-bottom: 1rem;
        letter-spacing: 0.05em;
    }
    .v2-sub-scissors .v2-icon-scissors {
        width: 30px;
        height: 40px;
        vertical-align: -30%;
    }
}

/* 1.4 Lists
 * ------------------------------*/
ul.v2-check-list {
    position: relative;
}
ul.v2-check-list li {
    margin: 0 0 1rem;
    font-size: 1.7rem;
}
ul.v2-check-list li:last-of-type {
    margin-bottom: 0;
}
ul.v2-check-list li {
    background: url(../image/icon/icon-check.svg) 0 6px no-repeat;
    background-size: auto 20px;
    padding-left: 3.5rem;
}
@media (max-width: 767px) {
    ul.v2-check-list li {
        font-size: 1.4rem;
    }
    ul.v2-check-list li {
        background-position: 0 7px;
        background-size: auto 15px;
        padding-left: 2.5rem;
    }
}

/* 1.5 Other Elements
 * ------------------------------*/
/* 1.5.1 page top ------------*/
#v2-pagetop {
    position: fixed;
    bottom: 30px;
    right: 15px;
    width: 44px;
    height: 44px;
    z-index: 10;
    transition: background-color 400ms;
    background: url(../image/pagetop.svg) center center no-repeat;
    background-size: contain;
    text-indent: 100% !important;
	white-space: nowrap;
	overflow: hidden;
	cursor: pointer;
}
#v2-pagetop:hover {
    opacity: 0.8;
    transition: 0.5s;
}
@media (max-width: 767px) {
    #v2-pagetop {
        width: 40px;
        height: 40px;
        bottom: 90px;
    }
}

/* 1.5.2 movie ------------*/
.v2-movie {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}
.v2-movie iframe {
    margin: 0;
    padding: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}

/* 1.5.3 googlemap ------------*/
.v2-googlemap {
    margin: 3.5rem 0 0;
}
.v2-googlemap iframe {
	margin: 0;
	padding: 0;
	height:  calc(396 / 1280 * 100vw);
}
@media (min-width: 1280px) {
    .v2-googlemap iframe {
        height: 396px;
    }
}
@media (max-width: 767px) {
    .v2-googlemap {
	    margin-top: 2rem;
	   }
}
@media (max-width: 480px) {
	.v2-googlemap {
	    margin-top: 2rem;
		position: relative;
		padding-bottom: 75%;
		height: 0;
		overflow: hidden;
	}
	.v2-googlemap iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100% !important;
		height: 100% !important;
	}
}

/* 1.5.4 side oc btn ------------*/
#v2-side-oc-btn {
    width: 60px;
    position: fixed;
    z-index: 10;
    right: 0;
    top: 20%;
}
@media (max-width: 1199px) {
    #v2-side-oc-btn {
        top: 15%;
    }
}
@media (max-width: 991px) {
    #v2-side-oc-btn {
        top: 10%;
    }
}
@media (max-width: 767px) {
    #v2-side-oc-btn {
        display: none;
    }
}

/*-------------------------------
 * 2. HEADER
 * ----------------------------*/
header#v2-header {
    width: 100%;
    height: 70px !important;
    padding: 0 !important;
    margin: 0 !important;
    background-image: none !important;
    -webkit-animation: slideIn 0.6s ease both;
    animation: slideIn 0.6s ease both;
    -webkit-animation-delay: 0.5s;
    animation-delay: 0.5s;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    background: #fff !important;
}
header#v2-header h1 {
    display: none;
}
@media (max-width: 991px) {
    header#v2-header {
        display: none;
    }
}

.v2-header-logo {
    margin: 0;
    padding: 1.4rem 0 0 3rem;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: center;
}
.v2-header-logo div:nth-of-type(1) {
    width: 200px;
    box-sizing: border-box;
}
.v2-header-logo div:nth-of-type(2) {
    width: 200px;
    box-sizing: border-box;
    padding-left: 1rem;
}
@media (max-width: 1199px) {
    .v2-header-logo {
        padding: 1.7rem 0 0 2.5rem;
    }
    .v2-header-logo div:nth-of-type(1) {
        width: 150px;
    }
    .v2-header-logo div:nth-of-type(2) {
        width: 170px;
    }
}
@media (max-width: 991px) {
    .v2-header-logo {
        padding: 1.3rem 0 0 1.2rem;
    }
    .v2-header-logo div:nth-of-type(1) {
        width: 110px;
    }
}
@media (max-width: 360px) {
    .v2-header-logo {
        padding-top: 1.4rem;
    }
    .v2-header-logo div:nth-of-type(1) {
        width: 100px;
    }
}
@media (max-width: 320px) {
    .v2-header-logo {
        padding: 1.5rem 0 0 1rem;
    }
    .v2-header-logo div:nth-of-type(1) {
        width: 90px;
    }
}

.v2-sns {
    width: 310px;
    margin: 0;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: center;
    align-content: center;
    position: absolute;
    top: 16px;
    right: 400px;
}
.v2-sns li {
    padding: 0 1.2rem;
}
.v2-sns li.v2-line img {
    height: 30px;
}
.v2-sns li.v2-youtube img {
    height: 22px;
}
.v2-sns li.v2-instagram img {
    height: 38px;
}
.v2-sns li:hover {
    opacity: 0.7;
    transition: 0.5s;
}
@media (max-width: 1199px) {
    .v2-sns {
        right: 350px;
    }
    .v2-sns li {
        padding: 0 1rem;
    }
}
@media (max-width: 991px) {
    .v2-sns {
        width: 200px;
        top: 10px;
        right: 40px;
    }
    .v2-sns li {
        padding: 0 0.4rem;
    }
    .v2-sns li.v2-line img {
        height: 20px;
    }
    .v2-sns li.v2-youtube img {
        height: 15px;
    }
    .v2-sns li.v2-instagram img {
        height: 30px;
    }
}
@media (max-width: 320px) {
    .v2-sns {
        width: 180px;
        top: 12px;
        right: 37px;
    }        
    .v2-sns li {
        padding: 0 0.3rem;
    }
    .v2-sns li.v2-line img {
        height: 18px;
    }
    .v2-sns li.v2-youtube img {
        height: 14px;
    }
    .v2-sns li.v2-instagram img {
        height: 26px;
    }
}

.v2-header-menu .v2-hmenu {
    width: 350px;
    top: 0;
    right: 0;
}
.v2-hmenu {
    margin: 0;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    position: absolute;
    text-align: center;
}
.v2-hmenu a {
    color: #000;
}
.v2-hmenu a:hover {
    color: #000;
    text-decoration: none;
}
.v2-hmenu li:hover {
    opacity: 0.7;
    transition: 0.5s;
}
.v2-hmenu li {
    width: calc(100% / 3);
    height: 70px;
    box-sizing: border-box;
    padding: 0 0.2rem;
}
.v2-hmenu li .v2-txt {
    display: block;
    font-size: 1.2rem;
    line-height: 1.1;
    font-weight: 500;
    margin-top: 0.7rem;
}
.v2-hmenu li.v2-access {
    background: #FBFBC0;
    padding-top: 0.7rem;
}
.v2-hmenu li.v2-access img {
    width: 25px;
}
.v2-hmenu li.v2-oc {
    background: #BEF2F9;
    padding-top: 0.5rem;
}
.v2-hmenu li.v2-oc img {
    width: 35px;
}
.v2-hmenu li.v2-request {
    background: #FDE0E6;
    padding-top: 1rem;
}
.v2-hmenu li.v2-request img {
    width: 35px;
}
@media (max-width: 991px) {
    .v2-header-menu .v2-hmenu {
        display: none;
    }
}

/*-------------------------------
 * 3. NAV
 * ----------------------------*/
/* 3.1. Main Nav (pc)
 * ------------------------------*/
#v2-main-nav {
    width: 100%;
    height: 70px;
    margin: 0;
    padding: 0;
    background: #fff;
    position: relative;
    box-sizing: border-box;
    padding-top: 1.4rem;
    margin-top: 70px;
}
body#v2-top-page #v2-main-nav {
    top: -70px;
    margin-top: 0;
    margin-bottom: -30px;
}
#v2-main-nav ul.v2-nav-menu {
    margin: 0;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: flex-start;
    align-content: flex-start;
}
#v2-main-nav ul.v2-nav-menu li {
    flex: 1;
    text-align: center;
    font-size: 1.8rem;
    font-weight: 500;
     letter-spacing: 0.08em;
     box-sizing: border-box;
     border-left: 1px solid #000;
}
#v2-main-nav ul.v2-nav-menu li:last-of-type {
    border-right: 1px solid #000;
}
#v2-main-nav ul.v2-nav-menu li a {
    display: block;
    overflow: visible;
    color: #000;
    height: 44px;
    line-height: 41px;
    position: relative;
    box-sizing: border-box;
}
#v2-main-nav ul.v2-nav-menu li a:hover {
    text-decoration: none;
    color: #000;
}
#v2-main-nav ul.v2-nav-menu li a::after {
  content: '';
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  width: 0;
  height: 100%;
  background:rgba(249,197,210,0.7);
  transition: all .5s;
  opacity: 0;
}
#v2-main-nav ul.v2-nav-menu li a:hover::after {
  width: 100%;
  opacity: 1;
}
@media (max-width: 1199px) {
    #v2-main-nav ul.v2-nav-menu li {
        font-size: 1.6rem;
    }
    #v2-main-nav ul.v2-nav-menu li a {
        padding: 0 1.5rem;
    }
}
@media (max-width: 991px) {
    #v2-main-nav {
        display: none !important;
    }
}

@-webkit-keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-100px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-100px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* 3.2. Main Nav (sp)
 * ------------------------------*/
#v2-main-nav-sp {
    display: none;
}
@media (max-width: 991px) {
    #v2-main-nav-sp {
        display: block;
        width: 100%;
        height: 50px;
        margin: 0;
        padding: 0;
        position: fixed;
        top: 0;
        left: 0;
        background: #fff;
        -webkit-animation: slideIn 0.6s ease both;
        animation: slideIn 0.6s ease both;
        -webkit-animation-delay: 0.5s;
        animation-delay: 0.5s;
        z-index: 1000;
    }
    #v2-main-nav-sp.active {
        z-index: 100;
        width: 100%;
        height: 100%;
        display: block;
        background-color: rgba(255, 255, 255, 1);
        position: fixed;
        top: 0;
        left: 0;
    }
    #v2-main-nav-sp nav ul {
        display: none;
    }
    #v2-main-nav-sp nav ul.active {
        width: 100vw;
        height: 100vh;
        margin: -6rem auto 0;
        padding: 0;
        text-align: center;
        display: flex;
        flex-flow: row wrap;
        justify-content: center;
        align-items: center;
        align-content: center;
    }
    #v2-main-nav-sp nav ul li {
        width: 100%;
        opacity: 0;
    }
    #v2-main-nav-sp.active nav ul li {
        -webkit-animation: slideIn 1s 0s 1 forwards;
        animation: slideIn 1s 0s 1 forwards;
    }
    #v2-main-nav-sp.active nav ul li:nth-of-type(1) {
        -webkit-animation-delay: 0.1s;
        animation-delay: 0.1s;
    }
    #v2-main-nav-sp.active nav ul li:nth-of-type(2) {
        -webkit-animation-delay: 0.2s;
        animation-delay: 0.2s;
    }
    #v2-main-nav-sp.active nav ul li:nth-of-type(3) {
        -webkit-animation-delay: 0.3s;
        animation-delay: 0.3s;
    }
    #v2-main-nav-sp.active nav ul li:nth-of-type(4) {
        -webkit-animation-delay: 0.4s;
        animation-delay: 0.4s;
    }
    #v2-main-nav-sp.active nav ul li:nth-of-type(5) {
        -webkit-animation-delay: 0.5s;
        animation-delay: 0.5s;
    }
    #v2-main-nav-sp nav ul li a {
        transition-duration: 0.5s;
        color: #000;
        font-size: 3rem;
        line-height: 3.5;
        width: 100%;
        display: block;
        font-weight: 500;
    }
    #v2-main-nav-sp nav ul li a:hover {
        background-color: rgba(249, 169, 187, 0.95);
        text-decoration: none;
    }    
    #v2-main-nav-sp .v2-nav-toggle {
        width: 35px;
        height: 35px;
        display: block;
        position: fixed;
        right: 15px;
        top: 0;
        cursor: pointer;
        z-index: 200;
        background: inherit;
        text-align: center;
    }
    #v2-main-nav-sp .v2-nav-toggle span {
        display: block;
        position: absolute;
    }
    #v2-main-nav-sp .v2-nav-toggle .line {
        width: 35px;
        border-bottom: solid 2px #000;
        -webkit-transition: .35s ease-in-out;
        -moz-transition: .35s ease-in-out;
        transition: .35s ease-in-out;
        right: 0;
    }
    #v2-main-nav-sp .v2-nav-toggle .line:nth-child(1) {
        top: 14px;
    }
    #v2-main-nav-sp .v2-nav-toggle .line:nth-child(2) {
        top: 23px;
        width: 27px;
    }
    #v2-main-nav-sp .v2-nav-toggle .line:nth-child(3) {
        top: 32px;
        width: 19px;
    }
    #v2-main-nav-sp .v2-nav-toggle.active {
        border: none;
        background: none;
        top: 10px;
    }
    #v2-main-nav-sp .v2-nav-toggle.active .line:nth-child(1) {
        top: 15px;
        width: 30px;
        -webkit-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        transform: rotate(-45deg);
        border-color: #000;
    }
    #v2-main-nav-sp .v2-nav-toggle.active .line:nth-child(3) {
        top: 15px;
        width: 30px;
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        transform: rotate(45deg);
        border-color: #000;
    }
    #v2-main-nav-sp .v2-nav-toggle.active .line:nth-child(2) {
        display: none;
    }
}
@media screen and (orientation:landscape) and (max-width: 896px) {
    #v2-main-nav-sp nav ul.active {
        margin-top: -4.5rem;
    }
    #v2-main-nav-sp nav ul li a {
        line-height: 2.5;
        font-size: 2rem;
    }
}
@media (max-width: 767px) {
    #v2-main-nav-sp nav ul li a {
        line-height: 2.5;
        font-size: 2rem;
    }
}
@media (max-width: 575px) {
    #v2-main-nav-sp nav ul li a {
        font-size: 1.7rem;
    }
}
@media (max-width: 480px) {
    #v2-main-nav-sp nav ul li a {
        line-height: 3;
        font-size: 2.2rem;
    }
    #v2-main-nav-sp nav ul.active {
        margin-top: -8rem;
    }
}
@media (max-width: 360px) {
    #v2-main-nav-sp nav ul.active {
        margin-top: -7rem;
    }
}
@media (max-width: 320px) {
    #v2-main-nav-sp nav ul li a {
        font-size: 2rem;
    }
}

/*-------------------------------
 * 4. CONTENTS
 * ----------------------------*/
main {
    margin: 0;
    padding: 0;
    top: 0;
    background: #fff !important;
}
body#v2-top-page main {
    background: #fff !important;
}
.v2-section-wrap {
    margin: 0;
    padding: 4rem 0;
}
@media (max-width: 767px) {
    .v2-section-wrap {
        padding: 4rem 0 0;
    }
}

.v2-inner {
    max-width: 800px;
    margin: 0 auto 4rem;
}
.v2-inner.wide {
    max-width: 900px;
}
@media (max-width: 1199px) {
    .v2-inner.wide {
        max-width: 100%;
    }
}
@media (max-width: 767px) {
    .v2-inner {
        margin-bottom: 2rem;
    }
}

.v2-box {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: stretch;
    margin: 0;
}
.v2-box.v2-center {
    justify-content: center;
}
.v2-box .v2-col-three {
    width: 31.5%;
    box-sizing: border-box;
    position: relative;
}
.v2-box .v2-col-two {
    width: 48.5%;
    box-sizing: border-box;
    position: relative;
}
@media (max-width: 767px) {
    .v2-box .order1 {
        order:1;
    }
    .v2-box .order2 {
        order: 2;
    }
    .v2-box .order3 {
        order: 3;
    }
    .v2-box .v2-col-three,
    .v2-box .v2-col-two {
       width: 100%;
       margin-bottom: 1.5rem;
    }
    .v2-box .v2-col-three:last-of-type,
    .v2-box .v2-col-two:last-of-type {
       margin-bottom: 0;
    }
}

.v2-gray-box {
    background: #f9f9f9;
    padding: 2.5rem 4rem;
    margin: 0;
}
@media (max-width: 767px) {
    .v2-gray-box {
        padding:1.52rem;
    }
}

.v2-txt-read {
    text-align: center;
    font-size: 2rem;
    line-height: 2;
    font-weight: 400;
    margin: 0;
}
@media (max-width: 767px) {
    .v2-txt-read {
        font-size: 1.4rem;
    }
}

/* 4.1 Swiper
 * ------------------------------*/
.swiper-wrapper {
    z-index: 0 !important;
}
.swiper-slide {
    box-sizing: border-box;
    position: relative;
}
.swiper-button-prev:focus,
.swiper-button-next:focus {
  outline: none;
  overflow: hidden;
  text-decoration: none;
}
.swiper-button-prev,
.swiper-button-next {
    top: 62%;
    transform: translateY(-62%);
    width: 40px;
    height: 40px;
    background-size: contain;
    z-index: 30;
}
.swiper-button-prev {
    background-image: url(../image/arrow-prev.svg) !important;
    left: 20px;
}
.swiper-button-next {
    background-image: url(../image/arrow-next.svg) !important;
    right: 20px;
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
    opacity: 0.6;
    transition: 0.5s;
}
.swiper-button-prev:focus,
.swiper-button-next:focus {
  outline: none;
  overflow: hidden;
  text-decoration: none;
}
.swiper-custom-parent {
    position: relative;
}
@media (max-width: 991px) {
    .swiper-button-prev,
    .swiper-button-next {
        top: 68%;
        transform: translateY(-68%);
        width: 30px;
        height: 30px;
    }
    .swiper-button-prev {
        left: 10px;
    }
    .swiper-button-next {
        right: 10px;
    }
}
@media (max-width: 767px) {
    .swiper-custom-parent .swiper-button-prev {
        left: 10px;
    }
    .swiper-custom-parent  .swiper-button-next {
        right: 10px;
    }
}
@media (max-width: 480px) {
    .swiper-button-prev,
    .swiper-button-next {
        top: 70%;
        transform: translateY(-70%);
    }
}

/*----- TOP main visual ---*/
.swiper-main .slide-img {
    width: 100vw;
    height: 100vh;
    background-size: cover;
    background-position: 50% 70px;
    background-repeat: no-repeat;
}
.swiper-main .swiper-slide-active .slide-img,
.swiper-main .swiper-slide-duplicate-active .slide-img,
.swiper-main .swiper-slide-prev .slide-img {
    -webkit-animation: ToZoom 10s linear 0s 1 normal both;
    animation: ToZoom 10s linear 0s 1 normal both;
}
.swiper-main .slide-img.v2-main01,
.swiper-main .slide-img.v2-main02,
.swiper-main .slide-img.v2-main03 {
    background-position: 100% 70px;
}
@media screen and (orientation:landscape) and (max-width: 1024px) {
    .swiper-main .slide-img.v2-main01 {
        background-position: 80% 70px;
    }
    .swiper-main .slide-img.v2-main03 {
        background-position: 90% 70px;
    }
}
@media screen and (orientation:portrait) and (max-width: 1024px) {
    .swiper-main .slide-img {
        height: 800px;
    }
    .swiper-main .slide-img.v2-main01 {
        background-position: 70% 70px;
    }
    .swiper-main .slide-img.v2-main03 {
        background-position: 90% 70px;
    }
}
@media (max-width: 991px) {
    .swiper-main .slide-img {
        height: 600px;
       background-position: 50% 50px;
    }
    .swiper-main .slide-img.v2-main01 {
        background-position: 70% 50px;
    }
    .swiper-main .slide-img.v2-main02 {
        background-position: 100% 50px;
    }
    .swiper-main .slide-img.v2-main03 {
        background-position: 90% 50px;
    }
}
@media screen and (orientation:landscape) and (max-width: 896px) {
    .swiper-main .slide-img {
        height: 500px;
    }
}
@media (max-width: 480px) {
    .swiper-main .slide-img {
        height: 320px;
    }
    .swiper-main .slide-img.v2-main01 {
        background-position: 100% 50px;
    }
    .swiper-main .slide-img.v2-main02 {
        background-position: 96% 50px;
    }
    .swiper-main .slide-img.v2-main04 {
        background-position: 45% 50px;
    }
    .swiper-main .slide-img.v2-main05 {
        background-position: 59% 50px;
    }
    .swiper-main .swiper-slide-active .slide-img,
    .swiper-main .swiper-slide-duplicate-active .slide-img,
    .swiper-main .swiper-slide-prev .slide-img {
        -webkit-animation: ToZoom_sp 10s linear 0s 1 normal both;
        animation: ToZoom_sp 10s linear 0s 1 normal both;
    }
}
@media (max-width: 360px) {
    .swiper-main .slide-img {
        height: 310px;
    }
}
@media (max-width: 320px) {
    .swiper-main .slide-img {
        height: 270px;
    }
}

@-webkit-keyframes ToZoom {
    0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
@keyframes ToZoom {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
@-webkit-keyframes ToZoom_sp {
    0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}
@keyframes ToZoom_sp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.1);
  }
}

/*----- TOP youtube ---*/
.swiper-movie .slide-img iframe {
    width: 100%;
    height: 320px;
}
.swiper-movie .swiper-button-prev,
.swiper-movie .swiper-button-next {
    top: 57%;
    transform: translateY(-57%);
}
@media (max-width: 1199px) {
    .swiper-movie .slide-img iframe {
        height: calc(320 / 1200 * 100vw);
    }
}
@media (max-width: 991px) {
    .swiper-movie .swiper-button-prev,
    .swiper-movie .swiper-button-next {
        top: 60%;
        transform: translateY(-60%);
    }
}
@media (max-width: 767px) {
    .swiper-movie .slide-img {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
    }
    .swiper-movie .slide-img iframe {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        left: 0;
        width: 100% !important;
        height: 100% !important;
    }
}
@media (max-width: 480px) {
    .swiper-movie .swiper-button-prev,
    .swiper-movie .swiper-button-next {
        top: 63%;
        transform: translateY(-63%);
    }
}

/*----- TOP twitter / youtubeと高さ合わせる ---*/
.twitter-timeline {
    height: 340px !important;
}
@media (max-width: 1199px) {
    .twitter-timeline {
        height: calc(340 / 1200 * 100vw) !important;
    }
}
@media (max-width: 480px) {
    .twitter-timeline {
        height: 250px !important;
    }
}

/*----- TOP instagram ---*/
.swiper-instagram .slide-img {
    width: 100%;
    height: 220px;
}
.swiper-instagram .slide-img .v2-imagearea {
    width: auto;
    height: 220px;
    object-fit: cover;
}
@media (max-width: 1199px) {
    .swiper-instagram .slide-img,
    .swiper-instagram .slide-img .v2-imagearea {
        height: calc(220 / 1200 * 100vw);
    }
}
@media (max-width: 767px) {
    .swiper-instagram .slide-img,
    .swiper-instagram .slide-img .v2-imagearea {
        height: 200px;
    }
}
@media (max-width: 480px) {
    .swiper-instagram .slide-img,
    .swiper-instagram .slide-img .v2-imagearea {
        height: 130px;
    }
}

/*----- TOP blog ---*/
.swiper-blog .slide-img {
    position: relative;
    width: 100%;
    height: 220px;
}
.swiper-blog .slide-img .v2-imagearea {
    width: auto;
    height: 220px;
    object-fit: cover;
}
.swiper-blog .slide-img a {
    color: #fff;
}
.swiper-blog .slide-img a:hover {
    color: #fff;
    text-decoration: none;
}
.swiper-blog .slide-img .v2-txt-box {
    position: absolute;
    width: 150px;
    height: 52px;
    right: 10px;
    bottom: 10px;
    margin: 0;
    background: rgba(248, 124, 153, 0.8);
    box-sizing: border-box;
    z-index: 10;
    font-size: 1.3rem;
    padding: 0.5rem 0.8rem;
    line-height: 1.5;
}
.swiper-blog .slide-img .v2-txt-box .v2-day {
    display: block;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.05em;
    font-size: 1.2rem;
}
.swiper-blog .slide-img .v2-txt-box .v2-txt {
    display: block;
    overflow: hidden;
    line-height: 25px;
    height: 25px;
    text-align: justify;
    text-justify: inter-ideograph;
}
@supports (-webkit-line-clamp: 2) {
    .swiper-blog .slide-img .v2-txt-box .v2-txt {
        display: -webkit-box;
        overflow: hidden;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
    }
}
@media (max-width: 1199px) {
    .swiper-blog .slide-img,
    .swiper-blog .slide-img .v2-imagearea {
        height: calc(220 / 1200 * 100vw);
    }
}
@media (max-width: 767px) {
    .swiper-blog .slide-img,
    .swiper-blog .slide-img .v2-imagearea {
        height: 200px;
    }
}
@media (max-width: 991px) {
    .swiper-blog .slide-img .v2-txt-box {
        width: 120px;
        height: 38px;
        right: 6px;
        bottom: 6px;
        font-size: 1.2rem;
        line-height: 0.8;
    }
    .swiper-blog .slide-img .v2-txt-box .v2-day {
        font-size: 1.1rem;
    }
}
@media (max-width: 480px) {
    .swiper-blog .slide-img,
    .swiper-blog .slide-img .v2-imagearea {
        height: 130px;
    }
    .swiper-blog .slide-img .v2-txt-box {
        width: 100px;
        font-size: 1.1rem;
        line-height: 0.7;
        padding-top: 0.65rem;
    }
}

/*----- TOP Open Campus ---*/
#v2-tp-oc-slider {
    padding-top: 1rem;
    padding-bottom: 1rem;
}
#v2-tp-oc-slider .v2-movie {
    margin-top: 4rem;
}
@media (max-width: 991px) {
    #v2-tp-oc-slider {
        padding-bottom: 0;
    }
}
@media (max-width: 767px) {
    #v2-tp-oc-slider {
        padding-top: 3rem;
    }
    #v2-tp-oc-slider .v2-movie {
        margin-top: 2.5rem;
        margin-bottom: -1.5rem;
    }
}

.swiper-opencampus .slide-img .v2-imagearea {
    width: auto;
    height: 250px;
    object-fit: cover;
}
.swiper-opencampus .slide-img a {
    color: #000;
}
.swiper-opencampus .slide-img a:hover {
    color: #000;
    text-decoration: none;
}
.swiper-opencampus .slide-img .v2-day {
    display: block;
    width: 100%;
    height: 40px;
    background: #f87c99;
    box-sizing: border-box;
    text-align: center;
    font-size: 2.7rem;
    font-weight: 600;
    color: #fff;
    font-family: 'Asap', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    line-height: 1;
    padding-top: 0.6rem;
    border-top-left-radius: 10px;
}
.swiper-opencampus .slide-img .v2-day.v2-blue {
    background: #1398cc;
}
.swiper-opencampus .slide-img .v2-day span {
    display: inline-block;
    font-size: 1.5rem;
    vertical-align: 15%;
}
.swiper-opencampus .slide-img .v2-txt-box {
    margin: 0;
    padding: 1.5rem;
    border-bottom-right-radius: 10px;
    background:rgba(237,231,224,0.4);
}
.swiper-opencampus .slide-img .v2-txt-box .v2-sub {
    font-size: 1.7rem;
    text-align: center;
    margin: 0 0 0.6rem;
    color: #ef628b;
}
.swiper-opencampus .slide-img .v2-txt-box .v2-sub.v2-blue {
    color: #1398cc;
}
.swiper-opencampus .slide-img .v2-txt-box .v2-txt {
    display: block;
    overflow: hidden;
    line-height: 25px;
    height: 50px;
    text-align: justify;
    text-justify: inter-ideograph;
    margin: 0;
}
@supports (-webkit-line-clamp: 2) {
    .swiper-blog .slide-img .v2-txt-box .v2-txt {
        display: -webkit-box;
        overflow: hidden;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
    }
}
@media (max-width: 1199px) {
    .swiper-opencampus .slide-img .v2-imagearea {
        height: calc(250 / 1200 * 100vw);
    }
}
@media (max-width: 991px) {
    .swiper-opencampus .slide-img .v2-imagearea {
        height: 200px;
    }
}
@media (max-width: 767px) {
    .swiper-opencampus .slide-img .v2-imagearea {
        height: 350px;
    }
}
@media (max-width: 480px) {
    .swiper-opencampus .slide-img .v2-imagearea {
        height: 200px;
    }
    .swiper-opencampus .slide-img .v2-day {
        font-size: 2rem;
        height: 30px;
        padding-top: 0.5rem;
    }
    .swiper-opencampus .slide-img .v2-day span {
        vertical-align: 10%;
        font-size: 1.4rem;
    }
    .swiper-opencampus .slide-img .v2-txt-box {
        padding: 1.2rem;
    }
    .swiper-opencampus .slide-img .v2-txt-box .v2-sub {
        font-size: 1.6rem;
    }
}

.swiper-opencampus .swiper-button-prev,
.swiper-opencampus .swiper-button-next {
    top: 47%;
    transform: translateY(-47%);
}

/*----- COURSE pickup (sp only) ---*/
.swiper-pickup {
    margin-bottom: 4rem;
}
.swiper-pickup .slide-img .v2-img-area {
    position: relative;
}
.swiper-pickup .slide-img .v2-txt-area {
    font-size: 1.3rem !important;
    padding: 0.8rem 1rem 1rem !important;
    line-height: 1.7 !important;
    background: #f9f9f9 !important;
    text-align: justify !important;
    text-justify: inter-ideograph !important;
}
.swiper-pickup .slide-img .v2-label {
    bottom: 10px !important;
    right: 10px !important;
    padding: 0.3rem 0.8rem 0.5rem !important;
    font-size: 1.2rem !important;
    line-height: 1 !important;
}
.swiper-pickup .swiper-button-prev,
.swiper-pickup .swiper-button-next {
    top: 45%;
    transform: translateY(-45%);
}
.swiper-pickup .swiper-button-prev {
    background-image: url(../image/arrow-prev-blue.svg) !important;
}
.swiper-pickup .swiper-button-next {
    background-image: url(../image/arrow-next-blue.svg) !important;
}
@media (max-width: 320px) {
    .swiper-pickup .slide-img .v2-txt-area {
        font-size: 1.2rem !important;
    }
}

/*----- COURSE manabi (sp only) ---*/
.swiper-manabi {
    margin-top: -1rem;
    margin-bottom: 3rem;
}
.swiper-manabi .slide-img .v2-img-area {
    position: relative;
}
.swiper-manabi .slide-img .v2-label {
    bottom: 10px !important;
    right: 10px !important;
    padding: 0.3rem 0.8rem 0.5rem !important;
    font-size: 1.2rem !important;
    line-height: 1 !important;
}
.swiper-manabi .swiper-button-prev,
.swiper-manabi .swiper-button-next {
    top: 60%;
    transform: translateY(-60%);
}

/* 4.2 Cate Title
 * ------------------------------*/
#v2-cate-ttl {
    text-align: center;
    margin: 1rem auto 4rem;
}
#v2-cate-ttl .v2-ttl {
    font-size: 2.8rem;
    letter-spacing: 0.08em;
}
#v2-cate-ttl .v2-ttl span {
    display: block;
    font-size: 10rem;
    color: #F8B1C4;
    font-family: 'Asap', sans-serif !important;
    font-style: italic !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
    position: relative;
    margin-bottom: 4rem;
}
#v2-cate-ttl .v2-ttl span::after {
    content: "";
    position: absolute;
    bottom: -18px;
    left: 0;
    right: 0;
    margin: auto;
    width: 190px;
    height: 4px;
    background: #F8B1C4;
}
@media (max-width: 1199px) {
    #v2-cate-ttl .v2-ttl {
        font-size: 2.5rem;
    }
    #v2-cate-ttl .v2-ttl span {
        font-size: 8rem;
    }
    #v2-cate-ttl .v2-ttl span::after {
        width: 150px;
    }
}
@media (max-width: 991px) {
    #v2-cate-ttl {
        margin: 6rem auto 3rem;
    }
    #v2-cate-ttl .v2-ttl {
        font-size: 2.2rem;
    }
    #v2-cate-ttl .v2-ttl span {
        font-size: 6rem;
    }
    #v2-cate-ttl .v2-ttl span::after {
        width: 120px;
    }
}
@media (max-width: 767px) {
    #v2-cate-ttl.v2-renewal-page {
        margin-bottom: 0;
    }
    #v2-cate-ttl .v2-ttl {
        font-size: 1.8rem;
    }
    #v2-cate-ttl .v2-ttl span {
        font-size: 4.5rem;
        margin-bottom: 2.5rem;
    }
    #v2-cate-ttl .v2-ttl span::after {
        width: 80px;
        bottom: -12px;
        height: 3px;
    }
}

/* 4.3 Btn
 * ------------------------------*/
.v2-btn-wrap {
    padding: 0 0 2rem;
}
.v2-btn-wrap .v2-btn-list {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: flex-start;
    align-content: flex-start;
    gap: 0 30px;
}
.v2-btn-wrap .v2-btn-list li {
    flex: 1;
}
@media (max-width: 991px) {
    .v2-btn-wrap .v2-btn-list {
        gap: 0 20px;
    }
}
@media (max-width: 767px) {
    .v2-btn-wrap {
        padding: 1rem 0;
    }
    .v2-btn-wrap .v2-btn-list {
        display: block;
        gap: 0;
    }
    .v2-btn-wrap .v2-btn-list li {
        width: 100%;
        margin: -1rem 0 0;
    }
    .v2-btn-wrap .v2-btn-list li:nth-of-type(1) {
        margin-top: 0;
    }
}

.v2-btn {
    display: block;
    max-width: 400px;
    padding: 1.3rem 0.5rem 1.6rem;
    border: 2px solid #ef628b;
    color: #ef628b;
    font-size: 2rem;
    text-align: center;
    font-weight: 600;
    box-sizing: border-box;
    margin: 2rem auto 4rem;
    line-height: 1.5;
}
.v2-btn:focus {
    color: #ef628b;
}
.v2-btn-wrap .v2-btn-list.v2-col-three li .v2-btn {
    max-width: 400px;
}
.v2-btn-wrap .v2-btn-list.v2-col-two li .v2-btn {
    max-width: 600px;
}
.v2-btn.small {
    max-width: 120px;
    padding: 0.2rem 1.5rem 0.5rem;
    position: absolute;
    top: 10px;
    right: 0;
    margin: 0;
    font-size: 1.5rem;
}
.v2-btn i {
    display: inline-block;
    margin-right: 1rem;
}
.v2-btn.small i {
    margin-right: 0.7rem;
    vertical-align: -5%;
}
.v2-btn:hover {
    text-decoration: none;
    color: #fff;
    background: #ef628b;
    transition: 0.5s;
}
.v2-btn.v2-blue {
    border-color: #1398cc;
    color: #1398cc;
}
.v2-btn.v2-blue:hover {
    background: #1398cc;
    color: #fff;
}
.v2-btn.v2-blue:focus {
    color: #1398cc;
}
.v2-btn.v2-yellow {
    border-color: #f9b84e;
    color: #f9b84e;
}
.v2-btn.v2-yellow:hover {
    background: #f9b84e;
    color: #fff;
}
.v2-btn.v2-yellow:focus {
    color: #f9b84e;
}
@media (max-width: 991px) {
    .v2-btn {
        font-size: 1.6rem;
    }
    .v2-btn.small {
        font-size: 1.3rem;
        padding: 0.1rem 1rem 0.4rem;
        top: 8px;
    }
}
@media (max-width: 767px) {
    .v2-btn {
        max-width: 100% !important;
        padding: 1.1rem 0.5rem 1.2rem;
        margin-bottom: 3rem;
    }
    .v2-btn.small {
        font-size: 1.3rem;
        padding: 0.1rem 1rem 0.3rem;
        top: 2px;
    }
    .v2-btn.small i {
        margin-right: 0.5rem;
    }
}
@media (max-width: 320px) {
    .v2-btn {
        font-size: 1.4rem;
    }
    .v2-btn.small {
        font-size: 1.2rem;
        padding: 0.2rem 0.7rem 0.3rem;
    }
}

/* 4.4 Career
 * ------------------------------*/
.v2-career-wrap .v2-reason .v2-col-three {
    padding-bottom: 0.5rem;
}
.v2-career-wrap .v2-reason .v2-sub {
    text-align: center;
    letter-spacing: 0;
    font-size: 2.4rem;
    height: auto;
    padding-bottom: 1.5rem;
}
.v2-career-wrap .v2-reason .v2-sub::before {
    bottom: 0;
}
.v2-career-wrap .v2-reason .v2-txt {
    text-align: center;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.7;
}
@media (max-width: 991px) {
    .v2-career-wrap .v2-reason .v2-sub {
        font-size: 2rem;
    }
    .v2-career-wrap .v2-reason .v2-txt {
        font-size: 1.5rem;
    }
    .v2-career-wrap .v2-reason .v2-col-three:hover {
        opacity: 1;
    }
}

.v2-career-wrap .v2-box.v2-flow .v2-col-three {
    width: 43%;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: stretch;
    align-content: stretch;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three.v2-year01 {
    border: 2px solid #ef628b;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three.v2-year02 {
    border: 2px solid #58b1e8;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three .v2-year-sub {
    width: 10%;
    color: #fff;
    background: #ef628b;
    font-size: 2.7rem;
    text-align: center;
    font-weight: 600;
    line-height: 1.4;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    box-sizing: border-box;
    padding-bottom: 2rem;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three.v2-year02 .v2-year-sub {
    background: #58b1e8;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three .v2-year-txt {
    width: 70%;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 1rem 0;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three.arrow-right {
    width: 8%;
}
.v2-career-wrap .v2-box.v2-flow .v2-col-three.arrow-down {
    display: none;
}
.v2-career-wrap .v2-arrow {
    width: 90px;
    margin: 2rem auto;
}
@media (max-width: 767px) {
    .v2-career-wrap .v2-box.v2-flow .v2-col-three {
        width: 100%;
    }
    .v2-career-wrap .v2-box.v2-flow .v2-col-three .v2-year-sub {
        font-size: 2rem;
    }
    .v2-career-wrap .v2-box.v2-flow .v2-col-three .v2-year-txt {
        width: 85%;
        padding: 0;
    }
    .v2-career-wrap .v2-box.v2-flow .v2-col-three.arrow-right {
        display: none;
    }
    .v2-career-wrap .v2-box.v2-flow .v2-col-three.arrow-down {
        display: block;
        width: 100%;
    }
    .v2-career-wrap .v2-box.v2-flow .v2-col-three.arrow-down img {
        width: 40px;
    }
    .v2-career-wrap .v2-arrow {
        width: 60px;
    }
}

.v2-career-wrap .v2-box.v2-flow dl {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: center;
    margin: 0;
    padding: 1rem;
    border-bottom: 1px dashed #000;
}
.v2-career-wrap .v2-box.v2-flow dl:last-of-type {
    border-bottom: none;
}
.v2-career-wrap .v2-box.v2-flow dl dt {
    width: 20%;
    font-size: 1.6rem;
    box-sizing: border-box;
    font-weight: 400;
}
.v2-career-wrap .v2-box.v2-flow dl dd {
    width: 80%;
    font-size: 1.5rem;
    line-height: 1.7;
    box-sizing: border-box;
}
@media (max-width: 767px) {
    .v2-career-wrap .v2-box.v2-flow dl dt {
        font-size: 1.4rem;
    }
    .v2-career-wrap .v2-box.v2-flow dl dd {
        font-size: 1.4rem;
    }
}

.v2-career-wrap .v2-after-box {
    max-width: 600px;
    margin: 0 auto;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: center;
    font-size: 1.6rem;
}
.v2-career-wrap .v2-after-box .v2-sub {
    width: 20%;
    box-sizing: border-box;
    background: #ffc964;
    color: #fff;
    font-weight: 600;
    font-size: 2.6rem;
    text-align: center;
    padding-bottom: 0.2rem;
    letter-spacing: 0.05em;
}
.v2-career-wrap .v2-after-box .v2-txt {
    width: 75%;
    box-sizing: border-box;
}
.v2-career-wrap .v2-after-box .v2-txt p {
    display: inline-block;
    border-bottom: 1px solid #000;
    padding-bottom: 1rem;
}
@media (max-width: 767px) {
    .v2-career-wrap .v2-after-box {
        font-size: 1.5rem;
    }
    .v2-career-wrap .v2-after-box .v2-sub {
        width: 100px;
        font-size: 2rem;
        margin: 0 auto;
        padding-top: 0.2rem;
        padding-bottom: 0;
    }
    .v2-career-wrap .v2-after-box .v2-txt {
        width: 100%;
        text-align: center;
    }
}

/* 4.5 Course
 * ------------------------------*/
.v2-course-wrap dl.v2-course-ttl {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: center;
}
.v2-course-wrap dl.v2-course-ttl dt {
    width: 10%;
}
.v2-course-wrap dl.v2-course-ttl dd {
    width: 87%;
    font-size: 2rem;
    line-height: 2;
}
.v2-course-wrap dl.v2-course-ttl.wide dt {
    width: 22%;
}
.v2-course-wrap dl.v2-course-ttl.wide dd {
    width: 75%;
}
.v2-course-wrap dl.v2-course-ttl.wide dd .v2-sub-manabi {
    line-height: 1.6;
    margin: 0;
}
@media (max-width: 991px) {
    .v2-course-wrap dl.v2-course-ttl dd {
        font-size: 1.8rem;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dt {
        width: 30%;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dd {
        width: 67%;
    }
}
@media (max-width: 480px) {
    .v2-course-wrap dl.v2-course-ttl {
        align-items: flex-start;
        align-content: flex-start;
        margin-bottom: -2rem;
    }
    .v2-course-wrap dl.v2-course-ttl dt {
        width: 19%;
        padding-top: 0.5rem;
    }
    .v2-course-wrap dl.v2-course-ttl dd {
        width: 77%;
        font-size: 1.4rem;
        line-height: 1.8;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dt {
        width: 100%;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dt img {
        width: 55%;
        margin: -0.5rem auto 1rem;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dd {
        width: 100%;
    }
    .v2-course-wrap dl.v2-course-ttl.wide dd .v2-sub-manabi {
        text-align: center;
        line-height: 1.9;
    }
}
@media (max-width: 360px) {
    .v2-course-wrap dl.v2-course-ttl dd {
        font-size: 1.3rem;
    }
}

.v2-course-wrap .v2-course-top-box .v2-col-two {
    width: 50%;
}
.v2-course-wrap .v2-course-top-box .v2-col-two.waku {
    border: 10px solid #FEE8ED;
    padding: 3rem 2rem;
    text-align: center;
}
.v2-course-wrap .v2-course-top-box .v2-label {
    width: 70%;
    margin: 0 auto 2.7rem;
}
.v2-course-wrap .v2-course-top-box .v2-sub {
    font-size: 2.7rem;
    margin: 0 0 2rem;
}
.v2-course-wrap .v2-course-top-box .v2-txt {
    font-size: 1.7rem;
    line-height: 2;
    margin: 0;
}
@media (max-width: 1199px) {
    .v2-course-wrap .v2-course-top-box .v2-col-two.waku {
        padding: 2rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-sub {
        font-size: 2.5rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-txt {
        font-size: 1.6rem;
        line-height: 1.8;
    }
}
@media (max-width: 991px) {
    .v2-course-wrap .v2-course-top-box .v2-label {
        margin-bottom: 1.5rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-sub {
        font-size: 1.8rem;
        margin-bottom: 1rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-txt {
        font-size: 1.4rem;
    }
}
@media (max-width: 767px) {
    .v2-course-wrap .v2-course-top-box .v2-col-two {
        width: 100%;
        margin: 0;
    }
    .v2-course-wrap .v2-course-top-box .v2-col-two.order1 {
        order: 1;
        margin-top: 2rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-col-two.order2 {
        order: 2;
    }
}
@media (max-width: 480px) {
    .v2-course-wrap .v2-course-top-box .v2-label {
        width: 75%;
        margin-bottom: 2rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-sub {
        margin-bottom: 1.5rem;
    }
}
@media (max-width: 360px) {
    .v2-course-wrap .v2-course-top-box .v2-txt {
        font-size: 1.3rem;
    }
}
@media (max-width: 320px) {
    .v2-course-wrap .v2-course-top-box .v2-col-two.waku {
        padding: 1.5rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-sub {
        font-size: 1.5rem;
    }
    .v2-course-wrap .v2-course-top-box .v2-txt {
        font-size: 1.2rem;
    }
}

.v2-course-wrap .v2-icon-list {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: flex-start;
    align-content: center;
    gap: 20px 30px;
}
.v2-course-wrap .v2-icon-list li {
    width: calc(100% / 6 - 30px );
    box-sizing: border-box;
}
.v2-course-wrap .v2-icon-list li p {
    font-size: 1.6rem;
    text-align: center;
    line-height: 1.7;
}
@media (max-width: 991px) {
    .v2-course-wrap .v2-icon-list {
        gap: 20px 20px;
    }
    .v2-course-wrap .v2-icon-list li {
        width: calc(100% / 6 - 20px );
    }
}
@media (max-width: 767px) {
    .v2-course-wrap .v2-icon-list {
        gap: 10px 10px;
        margin-top: 4.5rem;
    }
    .v2-course-wrap .v2-icon-list li {
        width: calc(100% / 4 - 8px );
    }
    .v2-course-wrap .v2-icon-list li p {
        font-size: 1.4rem;
        line-height: 1.5;
    }
}
@media (max-width: 480px) {
    .v2-course-wrap .v2-icon-list li p {
        font-size: 1.2rem;
    }
}
@media (max-width: 360px) {
    .v2-course-wrap .v2-icon-list li p {
        font-size: 1.1rem;
    }
}
@media (max-width: 320px) {
    .v2-course-wrap .v2-icon-list li p {
        font-size: 1rem;
    }
}

.v2-course-wrap .v2-course-box {
    align-items: stretch
    align-content: stretch;
}
.v2-course-wrap .v2-course-box .v2-col-two {
    background: #f9f9f9;
    margin-bottom: 4rem;
}
.v2-course-wrap .v2-course-box .v2-img-area {
    position: relative;
}
.v2-course-wrap .v2-course-box .v2-label {
    display: inline-block;
    position: absolute;
    bottom: 15px;
    right: 15px;
    background: rgba(19, 152, 204, 0.4);
    color: #fff;
    padding: 0 1rem 0.2rem;
    font-weight: 600;
}
.v2-course-wrap .v2-course-box .v2-label.blue {
    background: rgba(19, 152, 204, 0.5);
}
.v2-course-wrap .v2-course-box .v2-label.pink {
    background: rgba(248, 124, 153, 0.5);
}
.v2-course-wrap .v2-course-box .v2-txt-area {
    text-align: center;
    font-size: 1.5rem;
    padding: 1rem 1rem 1.3rem;
}
@media (max-width: 991px) {
    .v2-course-wrap .v2-course-box .v2-txt-area {
        text-align: left;
    }
}

.v2-course-wrap .v2-sub-manabi {
    font-size: 2rem;
    line-height: 1.8;
    margin: 2rem 0;
}
.v2-course-wrap .v2-sub-manabi  span {
    font-size: 130%;
}
.v2-course-debut-box .v2-sub-manabi {
    text-align: center;
}
@media (max-width: 991px) {
    .v2-course-wrap .v2-sub-manabi {
        font-size: 1.7rem;
    }
    .v2-course-debut-box .v2-sub-manabi {
        text-align: left;
    }
}
@media (max-width: 480px) {
    .v2-course-wrap .v2-sub-manabi {
        font-size: 1.5rem;
        margin: 1rem 0 0 0.5rem;
    }
    .v2-course-debut-box .v2-sub-manabi {
        text-align: center;
    }
}
@media (max-width: 360px) {
    .v2-course-wrap .v2-sub-manabi {
        font-size: 1.4rem;
    }
}
@media (max-width: 320px) {
    .v2-course-wrap .v2-sub-manabi {
        font-size: 1.3rem;
        letter-spacing: -0.01em;
    }
}

.v2-course-wrap .v2-course-debut-box {
    margin-top: 5rem;
}
.v2-course-wrap .v2-course-debut-box .v2-col-two.v2-img-area {
    width: 21%;
}
.v2-course-wrap .v2-course-debut-box .v2-col-two.v2-txt-area {
    width: 77%;
}
.v2-course-wrap .v2-course-debut-box .v2-img-debut {
    margin: -3rem 2rem 0 0;
}
@media (max-width: 991px) {
    .v2-course-wrap .v2-course-debut-box .v2-img-debut {
        margin: -1rem 1rem 0 0;
    }
}
@media (max-width: 767px) {
    .v2-course-wrap .v2-course-point {
        margin: -1rem auto;
    }
}
@media (max-width: 480px) {
    .v2-course-wrap .v2-course-debut-box {
        margin-top: 1.5rem;
    }
    .v2-course-wrap .v2-course-debut-box .v2-img-debut {
        margin: 0;
    }
    .v2-course-wrap .v2-course-debut-box .v2-col-two.v2-img-area {
        width: 31%;
    }
    .v2-course-wrap .v2-course-debut-box .v2-col-two.v2-txt-area {
        width: 68%;
    }
}

/* 4.6 Open Campus
 * ------------------------------*/
.v2-oc-wrap.v2-ichiran {
    padding-top: 0;
    padding-bottom: 4rem;
}
.v2-oc-wrap {
    padding-bottom: 0;
}
@media (max-width: 767px) {
    .v2-oc-wrap.v2-ichiran {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
}

.v2-oc-wrap .v2-oc-box {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
    border: 15px solid #FDE0E6;
    position: relative;
    margin-top: 3rem;
}
.v2-oc-wrap .v2-oc-box.v2-blue {
    border-color: #BEF2F9;
}
.v2-oc-wrap .v2-oc-box.v2-yellow {
    border-color: #faeebd;
}
.v2-oc-wrap .v2-oc-box .v2-col {
    padding: 1.5rem;
}
.v2-oc-wrap .v2-oc-box .v2-col.v2-img-area {
    width: 42%;
    padding-right: 0;
    box-sizing: border-box;
}
.v2-oc-wrap .v2-oc-box .v2-col.v2-txt-area {
    width: 56%;
    box-sizing: border-box;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-box {
        border-width: 10px;
    }
    .v2-oc-wrap .v2-oc-box .v2-col {
        padding: 1rem;
    }
}
@media (max-width: 767px) {
    .v2-oc-wrap .v2-oc-box {
        margin-top: 2rem;
    }
}
@media (max-width: 575px) {
    .v2-oc-wrap .v2-oc-box {
        padding: 1rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-col {
        width: 100% !important;
        padding: 0 !important;
    }
    .v2-oc-wrap.v2-ichiran .v2-oc-box .v2-col.v2-img-area {
        margin-top: 2.3rem;
    }
}

.v2-oc-wrap .v2-oc-box .v2-sub {
    width: 56%;
    background: #ef628b;
    color: #fff;
    position: absolute;
    top: -15px;
    right: -15px;
    box-sizing: border-box;
    text-align: center;
    font-size: 2.2rem;
    letter-spacing: 0;
    padding: 0.7rem 1rem 1rem 1rem;
}
.v2-oc-wrap .v2-oc-box.v2-blue .v2-sub {
    background: #1398cc;
}
.v2-oc-wrap .v2-oc-box.v2-yellow .v2-sub {
    background: #f9b84e;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        font-size: 1.8rem;
        padding-bottom: 0.8rem;
        top: -10px;
        right: -10px;
    }
}
@media (max-width: 575px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        width: 104%;
        font-size: 1.6rem;
        padding-top: 0.8rem;
    }
}
@media (max-width: 480px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        width: 105.5%;
    }
}
@media (max-width: 390px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        width: 106%;
    }
}
@media (max-width: 360px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        width: 106.5%;
    }
}
@media (max-width: 320px) {
    .v2-oc-wrap .v2-oc-box .v2-sub {
        width: 107%;
    }
}

.v2-oc-wrap .v2-oc-box .v2-txt-box {
    margin-top: 1.3rem;
}
.v2-oc-wrap .v2-oc-box .v2-txt {
    font-size: 1.6rem;
}
.v2-oc-wrap .v2-oc-box .v2-txt p {
    margin: 0 !important;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-box .v2-txt-box {
        margin-top: 0.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-txt {
        font-size: 1.5rem;
    }
}
@media (max-width: 575px) {
    .v2-oc-wrap .v2-oc-box .v2-txt-box {
        margin-top: 0;
    }
    .v2-oc-wrap .v2-oc-box .v2-txt {
        font-size: 1.4rem;
    }
}
@media (max-width: 320px) {
    .v2-oc-wrap .v2-oc-box .v2-txt {
        font-size: 1.3rem;
    }
}

.v2-oc-wrap .v2-oc-box .v2-day-time {
    margin-bottom: -2rem;
}
.v2-oc-wrap .v2-oc-box .v2-day-time .v2-day {
    display: inline-block;
    margin-right: 2rem;
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 5.8rem;
}
.v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day {
    font-size: 3.5rem;
    margin-right: 0.7rem;
    margin-top: 0.7rem;
}
.v2-oc-wrap .v2-oc-box .v2-day-time .v2-day span {
    display: inline-block;
    font-family: 'Zen Maru Gothic', sans-serif;
    font-size: 2.2rem;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #ef628b;
    color: #fff;
    margin-left: 0.7rem;
    text-align: center;
    line-height: 1;
    padding-top: 0.5rem;
    box-sizing: border-box;
    vertical-align: 55%;
}
.v2-oc-wrap .v2-oc-box.v2-blue .v2-day-time .v2-day span {
    background: #1398cc;
}
.v2-oc-wrap .v2-oc-box.v2-yellow .v2-day-time .v2-day span {
    background: #f9b84e;
}
.v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day span {
    font-size: 1.6rem;
    width: 26px;
    height: 26px;
    vertical-align: 45%;
    margin-left: 0.5rem;
    padding-top: 0.3rem;
}
.v2-oc-wrap .v2-oc-box .v2-day-time .v2-time {
    display: inline-block;
    font-size: 2.6rem;
    font-weight: 600;
    vertical-align: 30%;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day {
        font-size: 4.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day span {
        width: 30px;
        height: 30px;
        font-size: 1.8rem;
        vertical-align: 45%;
        padding-top: 0.4rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-time {
        font-size: 2.2rem;
        vertical-align: 15%;
    }
}
@media (max-width: 575px) {
    .v2-oc-wrap .v2-oc-box .v2-day-time {
        text-align: center;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day {
        margin-right: 1.5rem;
        font-size: 4rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time.v2-small {
        margin-bottom: -0.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day {
        font-size: 3.1rem;
        margin-top: 0.5rem;
        margin-bottom: 0.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day span {
        width: 28px;
        height: 28px;
        font-size: 1.6rem;
        vertical-align: 55%;
        padding-top: 0.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day span {
        font-size: 1.4rem;
        width: 22px;
        height: 22px;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-time {
        font-size: 2rem;
        vertical-align: 22%;
    }
}
@media (max-width: 320px) {
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day {
        margin-right: 1rem;
        font-size: 3.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day {
        font-size: 2.5rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-day span {
        width: 25px;
        height: 25px;
        font-size: 1.4rem;
        vertical-align: 50%;
        padding-top: 0.4rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time.v2-small .v2-day span {
        font-size: 1.3rem;
        width: 20px;
        height: 20px;
        padding-top: 0.2rem;
    }
    .v2-oc-wrap .v2-oc-box .v2-day-time .v2-time {
        font-size: 1.7rem;
        vertical-align: 18%;
    }
}

.v2-oc-wrap .v2-oc-box .v2-btn {
    max-width: 100%;
    margin: 3rem auto 0;
}
.v2-oc-wrap .v2-oc-box.v2-blue .v2-btn {
    border-color: #1398cc;
    color: #1398cc;
}
.v2-oc-wrap .v2-oc-box.v2-blue .v2-btn:hover {
    background: #1398cc;
    color: #fff;
}
.v2-oc-wrap .v2-oc-box.v2-yellow .v2-btn {
    border-color: #f9b84e;
    color: #f9b84e;
}
.v2-oc-wrap .v2-oc-box.v2-yellow .v2-btn:hover {
    background: #f9b84e;
    color: #fff;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-box .v2-btn {
        margin-top: 2rem;
    }
}

.v2-oc-wrap .v2-oc-dl {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
    margin: 1rem 0;
}
.v2-oc-wrap .v2-oc-dl.v2-online {
    margin: 2rem 0 3rem;
}
.v2-oc-wrap .v2-oc-dl.v2-online .v2-day-time {
    margin-top: -1rem;
}
.v2-oc-wrap .v2-oc-dl dt {
    width: 17%;
    box-sizing: border-box;
}
.v2-oc-wrap .v2-oc-dl dd {
    width: 79%;
    box-sizing: border-box;
    font-size: 1.6rem;
    line-height: 1.8;
}
.v2-oc-wrap .v2-oc-dl.v2-online dd {
    font-size: 3rem;
    line-height: 1;
    font-weight: 600;
}
.v2-oc-wrap .v2-oc-dl dt span {
    display: block;
    background: #F491AE;
    color: #fff;
    font-size: 1.6rem;
    text-align: center;
    font-weight: 500;
    line-height: 1;
    padding: 0.6rem 0.5rem 0.8rem;
}
.v2-oc-wrap .v2-blue .v2-oc-dl dt span {
    background: #5AB7DB;
}
.v2-oc-wrap .v2-yellow .v2-oc-dl dt span {
    background: #f9b84e;
}
.v2-oc-wrap .v2-oc-dl .v2-sub-dl {
    font-weight: 600;
    font-size: 2.6rem;
    margin: 0 0 0.8rem;
}
@media (max-width: 991px) {
    .v2-oc-wrap .v2-oc-dl.v2-online dd.v2-time {
        font-size: 2.6rem;
    }
    .v2-oc-wrap .v2-oc-dl dt {
        width: 22%;
    }
    .v2-oc-wrap .v2-oc-dl dd {
        width: 74%;
        font-size: 1.4rem;
    }
    .v2-oc-wrap .v2-oc-dl dt span {
        font-size: 1.4rem;
    }
    .v2-oc-wrap .v2-oc-dl .v2-sub-dl {
        font-size: 2.2rem;
    }
}
@media (max-width: 767px) {
    .v2-oc-wrap .v2-oc-dl {
        margin: 1.5rem 0;
    }
    .v2-oc-wrap .v2-oc-dl.v2-online {
        margin: 2rem 0;
    }
    .v2-oc-wrap .v2-oc-dl.v2-online .v2-day-time {
        text-align: left;
        margin-top: -0.5rem;
    }
    .v2-oc-wrap .v2-oc-dl dt {
        width: 25%;
    }
    .v2-oc-wrap .v2-oc-dl dd {
        width: 71%;
    }
    .v2-oc-wrap .v2-oc-dl.v2-online dd {
        font-size: 2.4rem;
    }
    .v2-oc-wrap .v2-oc-dl dt span {
        padding-top: 0.8rem;
        padding-bottom: 0.7rem;
    }
    .v2-oc-wrap .v2-oc-dl .v2-sub-dl {
        font-size: 2rem;
    }
}
@media (max-width: 320px) {
    .v2-oc-wrap .v2-oc-dl dt {
        width: 26%;
    }
    .v2-oc-wrap .v2-oc-dl dd {
        width: 71%;
        font-size: 1.3rem;
    }
    .v2-oc-wrap .v2-oc-dl.v2-online dd {
        font-size: 2.2rem;
    }
    .v2-oc-wrap .v2-oc-dl dt span {
        font-size: 1.2rem;
    }
    .v2-oc-wrap .v2-oc-dl .v2-sub-dl {
        font-size: 1.7rem;
    }
}

/*----- 220723 追加 -----*/
.v2-oc-sub-bg {
    background: #5AB7DB;
    margin-bottom: 0;
    color: #fff;
    font-size: 2.4rem;
    text-align: center;
    padding: 1rem 0.5rem 1.2rem;
    letter-spacing: 0.03em;
    position: relative;
    z-index: 1;
}
.v2-oc-sub-bg + .v2-oc-box {
    margin-top: -1.5rem;
}
@media (max-width: 767px) {
    .v2-oc-sub-bg {
        font-size: 1.6rem;
    }
    .v2-oc-sub-bg + .v2-oc-box {
        margin-top: -1rem;
    }
}

/*----- online flow -----*/
.v2-oc-wrap .v2-box.v2-flow {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: stretch;
    margin: 0;
}
.v2-oc-wrap .v2-box.v2-flow .v2-col-three {
    width: 43%;
    background: #f9f9f9;
}
.v2-oc-wrap .v2-box.v2-flow .v2-col-three.v2-wide {
    width: 100%;
    margin-bottom: 4rem;
}
.v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-right {
    width: 8%;
    background: transparent;
    position: relative;
}
.v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-right img {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-down {
    display: none;
    background: transparent;
}
.v2-oc-wrap .v2-arrow {
    width: 90px;
    margin: 2rem auto;
}
@media (max-width: 767px) {
    .v2-oc-wrap .v2-box.v2-flow {
        margin-bottom: -3rem;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-col-three {
        width: 100%;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-right {
        display: none;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-down {
        display: block;
        width: 100%;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-col-three.arrow-down img {
        width: 40px;
    }
    .v2-oc-wrap .v2-arrow {
        width: 60px;
        margin-top: 5rem;
    }
}

.v2-oc-wrap .v2-box.v2-flow .v2-sub {
    width: 100%;
    background: #ef628b;
    color: #fff;
    font-weight: 500;
    font-size: 2rem;
    text-align: center;
    padding: 0.8rem 0.5rem;
}
.v2-oc-wrap .v2-box.v2-flow .v2-sub span {
    display: inline-block;
    margin-right: 2rem;
    font-family: 'Asap', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    font-size: 2.3rem;
    vertical-align: -5%;
}
.v2-oc-wrap .v2-box.v2-flow .v2-txt {
    padding: 0 2rem 1rem;
}
@media (max-width: 767px) {
    .v2-oc-wrap .v2-box.v2-flow .v2-sub {
        font-size: 1.5rem;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-sub span {
        font-size: 1.7rem;
        margin-right: 1rem;
    }
    .v2-oc-wrap .v2-box.v2-flow .v2-txt {
        padding: 0.2rem 1.5rem 1rem;
    }
}

.v2-oc-wrap .v2-box.v2-flow .v2-app {
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
    align-content: center;
    margin: 1.5rem 0 1rem;
    gap: 0 5px;
}
.v2-oc-wrap .v2-box.v2-flow .v2-app a {
    display: block;
}
.v2-oc-wrap .v2-box.v2-flow .v2-app a.v2-apple {
    flex-grow: 1;
}
.v2-oc-wrap .v2-box.v2-flow .v2-app a.v2-google {
    flex-grow: 2;
}
.v2-oc-wrap .v2-box.v2-flow .v2-app a img {
    height: 65px;
}
@media (max-width: 1280px) {
    .v2-oc-wrap .v2-box.v2-flow .v2-app a img {
        height: calc(60 / 1280 * 100vw);
    }
}
@media (max-width: 767px) {
    .v2-oc-wrap .v2-box.v2-flow .v2-app a img {
        height: 50px;
    }
}
@media (max-width: 360px) {
    .v2-oc-wrap .v2-box.v2-flow .v2-app a img {
        height: 45px;
    }
}
@media (max-width: 320px) {
    .v2-oc-wrap .v2-box.v2-flow .v2-app a img {
        height: 40px;
    }
}

/* 4.7 Summary
 * ------------------------------*/
.v2-summary-wrap .v2-subsub {
    color: #ef628b;
    font-size: 2.4rem;
    margin: 4rem 0 2rem;
}
.v2-summary-wrap .v2-dl {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    align-content: flex-start;
    margin: 0 0 1.5rem;
    padding: 0 0 1.5rem;
    border-bottom: 1px solid #ccc;
}
.v2-summary-wrap .v2-dl + .v2-sub-bg {
    margin-top: 7rem;
}
.v2-summary-wrap .v2-dl dt {
    width: 55%;
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1.8;
}
.v2-summary-wrap .v2-dl dd {
    width: 40%;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.8;
}
.v2-summary-wrap .v2-dl .v2-btn {
    margin: 0 auto;
    padding: 0.6rem 0.5rem 0.8rem;
    font-size: 1.8rem;
}
@media (max-width: 991px) {
    .v2-summary-wrap .v2-subsub {
        font-size: 2rem;
    }
}
@media (max-width: 767px) {
    .v2-summary-wrap {
        margin-top: 3rem;
        margin-bottom: 4rem;
    }
    .v2-summary-wrap .v2-sub-bg {
        margin-bottom: 1rem;
        font-size: 1.7rem;
        padding: 0.7rem 0.5rem 0.9rem;
    }
    .v2-summary-wrap .v2-subsub {
        font-size: 1.8rem;
        text-align: center;
        margin: 3rem 0 1.5rem;
    }
    .v2-summary-wrap .v2-dl {
        margin-bottom: 1rem;
        padding-bottom: 1.2rem;
    }
    .v2-summary-wrap .v2-dl + .v2-sub-bg {
        margin-top: 4rem;
    }
    .v2-summary-wrap .v2-dl dt {
        width: 100%;
        font-size: 1.5rem;
        text-align: center;
        padding-bottom: 0.7rem;
    }
    .v2-summary-wrap .v2-dl dd {
        width: 100%;
        font-size: 1.4rem;
    }
    .v2-summary-wrap .v2-dl .v2-btn {
        font-size: 1.5rem;
        padding: 0.6rem 0.5rem;
    }
}

/* 4.8 School
 * ------------------------------*/
.v2-school-wrap .v2-sub-txt {
    font-size: 2rem;
    line-height: 1.8;
    text-align: center;
    font-weight: 400;
    margin: 0 0 4rem;
}
.v2-school-wrap .v2-sub-txt strong {
    display: inline-block;
    margin-top: -1.2rem;
    margin-left: 0.5rem;
    vertical-align: -5%;
}
.v2-school-wrap .v2-sub-txt .v2-num {
    display: inline-block;
    font-size: 4rem;
}
.v2-school-wrap .v2-sub-txt .v2-per {
    display: inline-block;
    font-size: 2.5rem;
    margin-left: 0.5rem;
    vertical-align: 5%;
}
.v2-school-wrap .v2-comment {
    width: 49%;
    margin: 4.5rem auto 3rem;
}
.v2-school-wrap .v2-btn {
    padding: 1rem 0.5rem 1.3rem;
    margin: 3rem auto 0;
}
@media (max-width: 991px) {
    .v2-school-wrap .v2-sub-txt {
        font-size: 1.8rem;
    }
    .v2-school-wrap .v2-sub-txt .v2-num {
        font-size: 3.5rem;
    }
    .v2-school-wrap .v2-sub-txt .v2-per {
        font-size: 2rem;
    }
    .v2-school-wrap .v2-btn {
        margin-top: 2rem;
    }
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-btn {
        padding: 1rem 0.5rem 1.1rem;
    }
    .v2-school-wrap .v2-comment {
        width: 95%;
        margin: 0.5rem  auto 2rem;
    }
}
@media (max-width: 480px) {
    .v2-school-wrap .v2-sub-txt {
        font-size: 1.4rem;
        margin-bottom: 1rem;
    }
    .v2-school-wrap .v2-sub-txt strong {
        margin-top: -0.9rem;
        margin-bottom: -0.5rem;
    }
    .v2-school-wrap .v2-sub-txt .v2-num {
        font-size: 2.6rem;
    }
    .v2-school-wrap .v2-sub-txt .v2-per {
        font-size: 1.5rem;
    }
}
@media (max-width: 320px) {
    .v2-school-wrap .v2-sub-txt {
        font-size: 1.3rem;
    }
}

.v2-school-wrap .v2-school-top-box .v2-col-two {
    width: 50%;
}
.v2-school-wrap .v2-school-top-box .v2-col-two.waku {
    border: 10px solid #CCF5FB;
    padding: 3rem;
}
.v2-school-wrap .v2-school-top-box .v2-label {
    width: 60%;
    margin: 0 auto 2rem;
}
.v2-school-wrap .v2-school-top-box .v2-txt {
    font-size: 1.7rem;
    line-height: 2;
    margin: 0;
}
.v2-school-wrap .v2-school-top-box .img-area img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media (max-width: 1199px) {
    .v2-school-wrap .v2-school-top-box .v2-col-two.waku {
        padding: 2rem;
    }
    .v2-school-wrap .v2-school-top-box .v2-txt {
        font-size: 1.6rem;
        line-height: 1.8;
    }
}
@media (max-width: 991px) {
    .v2-school-wrap .v2-school-top-box .v2-label {
        margin-bottom: 1.5rem;
    }
    .v2-school-wrap .v2-school-top-box .v2-txt {
        font-size: 1.4rem;
    }
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-school-top-box .v2-col-two {
        width: 100%;
        margin: 0;
    }
    .v2-school-wrap .v2-school-top-box .v2-col-two.order1 {
        order: 1;
        margin-top: 2rem;
    }
    .v2-school-wrap .v2-school-top-box .v2-col-two.order2 {
        order: 2;
    }
    .v2-school-wrap .v2-school-top-box .img-area img {
        height: auto;
    }
}
@media (max-width: 480px) {
    .v2-school-wrap .v2-school-top-box .v2-label {
        width: 65%;
    }
}
@media (max-width: 360px) {
    .v2-school-wrap .v2-school-top-box .v2-txt {
        font-size: 1.3rem;
    }
}
@media (max-width: 320px) {
    .v2-school-wrap .v2-school-top-box .v2-col-two.waku {
        padding: 1.5rem;
    }
    .v2-school-wrap .v2-school-top-box .v2-txt {
        font-size: 1.2rem;
    }
}

.v2-school-wrap .v2-school-box + .v2-school-box {
    margin-top: 4rem;
}
.v2-school-wrap .v2-school-box .v2-sub-bg {
    margin: 0;
}
.v2-school-wrap .v2-school-box .v2-col-two {
    background: #f9f9f9;
    box-shadow: 1px 0px 5px rgba(0,0,0,0.15);
}
.v2-school-wrap .v2-school-box .v2-txt-box {
    padding: 3rem 3rem 11rem;
}
.v2-school-wrap .v2-school-box .v2-txt-box.v2-pb-none {
    padding-bottom: 1rem;
}
.v2-school-wrap .v2-school-box .v2-txt {
    line-height: 2;
    margin-top: 1.3rem;
}
.v2-school-wrap .v2-school-box .v2-btn {
    width: 400px;
    position: absolute;
    bottom: 35px;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
}
@media (max-width: 1199px) {
    .v2-school-wrap .v2-school-box .v2-txt-box {
        padding: 2rem 2rem 10rem;
    }
    .v2-school-wrap .v2-school-top-box .v2-txt {
        line-height: 1.8;
    }
    .v2-school-wrap .v2-school-box .v2-btn {
        width: 88%;
        bottom: 25px;
    }
}
@media (max-width: 991px) {
    .v2-school-wrap .v2-school-box .v2-txt-box {
        padding: 2rem 2rem 9rem;
    }
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-school-box + .v2-school-box {
        margin-top: 0;
    }
    .v2-school-wrap .v2-school-box .v2-col-two {
        margin-bottom: 2.5rem;
    }
    .v2-school-wrap .v2-school-box .v2-txt-box {
        padding: 2rem;
    }
    .v2-school-wrap .v2-school-box .v2-txt {
        margin-top: 1rem;
    }
    .v2-school-wrap .v2-school-box .v2-btn {
        position: relative;
        width: 100%;
        top: 0;
        margin: 1.5rem auto 0;
    }
}

.v2-school-wrap .v2-school-ichiran-box {
    margin: 8rem 0;
}
.v2-school-wrap .v2-school-ichiran-box .v2-col-two {
    background: #CCF5FB;
    padding: 2.5rem 3rem 11rem;
}
.v2-school-wrap .v2-school-ichiran-box .v2-sub {
    height: calc(45 / 1280 * 100vw);
    box-sizing: border-box;
    position: relative;
    margin: 0 0 2rem;
    text-align: center;
    font-size: 2.4rem;
}
.v2-school-wrap .v2-school-ichiran-box .v2-sub::before {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  content: '';
  background: url(../image/line.svg) left center no-repeat;
  background-size: cover;
}
.v2-school-wrap .v2-school-ichiran-box .v2-txt {
    line-height: 2;
    margin-top: 1.3rem;
}
.v2-school-wrap .v2-school-ichiran-box .v2-btn {
    width: 400px;
    position: absolute;
    bottom: 35px;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    border-color: #1398cc;
    color: #fff;
    background: #1398cc;
}
.v2-school-wrap .v2-school-ichiran-box .v2-btn:hover {
    background: transparent;
    color: #1398cc;
}
@media (max-width: 1199px) {
    .v2-school-wrap .v2-school-ichiran-box .v2-col-two {
        padding: 2rem 2rem 10rem;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-btn {
        width: 88%;
        bottom: 25px;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-sub {
        height: calc(57 / 1199 * 100vw);
    }
}
@media (max-width: 991px) {
    .v2-school-wrap .v2-school-ichiran-box {
        margin: 6rem 0;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-sub {
        font-size: 2rem;
    }
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-school-ichiran-box {
        margin: 4rem 0;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-col-two {
        margin-bottom: 2rem;
        padding: 1.5rem 2rem 2rem;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-btn {
        position: relative;
        width: 100%;
        top: 0;
        margin: 1.5rem auto 0;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-sub {
        height: 35px;
        font-size: 1.7rem;
        margin-bottom: 1.5rem;
    }
    .v2-school-wrap .v2-school-ichiran-box .v2-txt {
        margin-top: 1rem;
    }
}

/*----- principle (timelineはv1のcssにあり) -----*/
.v2-school-wrap .v2-img-shingi {
    width: 35%;
    margin: 4rem auto 5.5rem;
}
.v2-school-wrap .v2-icon-shingi {
    display: none;
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-img-shingi {
        width: 60%;
        margin: 2rem auto 3rem;
    }
    .v2-school-wrap .v2-icon-shingi {
        display: block;
        position: absolute;
        top: -10px;
        left: -10px;
        width: 50px;
        height: 50px;
    }
}

.v2-school-wrap .v2-message-box .v2-img-area {
    width: 35%;
}
.v2-school-wrap .v2-message-box .v2-txt-area {
    width: 61%;
}
.v2-school-wrap .v2-message-box .v2-txt {
    font-size: 1.5rem;
    line-height: 2;
}
.v2-school-wrap .v2-message-box .v2-txt-message {
    margin: 2rem 3rem 0 0;
    text-align: right;
    font-size: 1.6rem;
    line-height: 2;
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-message-box .v2-img-area,
    .v2-school-wrap .v2-message-box .v2-txt-area {
        width: 100%;
    }
    .v2-school-wrap .v2-message-box .v2-img-area img {
        width: 60%;
    }
    .v2-school-wrap .v2-message-box .v2-txt {
        font-size: 1.4rem;
        line-height: 1.8;
        margin-top: 0;
    }
    .v2-school-wrap .v2-message-box .v2-txt-message {
        font-size: 1.5rem;
        margin: 1rem 0 0 0;
        line-height: 1.8;
    }
}

/*----- facilities -----*/
.v2-school-wrap .v2-school-gaikan {
    width: 80%;
    margin: 4rem auto 5rem;
}
@media (max-width: 767px) {
    .v2-school-wrap .v2-school-gaikan {
        width: 100%;
        margin: 2rem auto 3rem;
    }
}

/* 4.9 Guidance
 * ------------------------------*/
.v2-guidance-wrap {
    padding: 1rem 0 7rem;
}
.v2-guidance-wrap .v2-ttl-box,
.v2-guidance-wrap .v2-step-box {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}
.v2-guidance-wrap .v2-ttl-box .v2-col:nth-of-type(1),
.v2-guidance-wrap .v2-step-box .v2-col:nth-of-type(1) {
    width: 13%;
    box-sizing: border-box;
}
.v2-guidance-wrap .v2-ttl-box .v2-col:nth-of-type(2),
.v2-guidance-wrap .v2-step-box .v2-col:nth-of-type(2) {
    width: 85%;
    box-sizing: border-box;
}
.v2-guidance-wrap .v2-step-box .v2-col:nth-of-type(2) {
    background: #FEE8ED;
    padding: 1rem;
}
.v2-guidance-wrap .v2-step-box.v2-blue .v2-col:nth-of-type(2) {
    background: linear-gradient(90deg,#CCF5FB 0%,#CCF5FB 50%,#FDE4BA 50%,#FDE4BA 100%);
}
.v2-guidance-wrap .v2-step-box .v2-col .v2-wbox {
    background: #fff;
    padding: 1.5rem 2rem;
}
.v2-guidance-wrap .v2-step-box .v2-col  .v2-wbox-box {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}
.v2-guidance-wrap .v2-step-box .v2-col  .v2-wbox-box .v2-wbox-col {
    width: 48%;
    box-sizing: border-box;
}
.v2-guidance-wrap .v2-step-box {
    text-align: center;
    font-size: 1.7rem;
}
.v2-guidance-wrap .v2-step-box .v2-sub {
    color: #ef628b;
    font-weight: 500;
    font-size: 2.6rem;
    margin: 0 0 1rem;
}
.v2-guidance-wrap .v2-step-box.v2-blue .v2-sub {
    color: #1398cc;
}
.v2-guidance-wrap .v2-step-box .v2-txt {
    margin: 0;
}
.v2-guidance-wrap .v2-step-box .v2-sup {
    display: inline-block;
    font-size: 1.4rem;
}
.v2-guidance-wrap .v2-step-box .v2-sub-waku {
    font-size: 2rem;
    color: #ef628b;
    border: 3px solid #ef628b;
    padding: 0.7rem 0.5rem;
    margin: 1rem 0;
}
.v2-guidance-wrap .v2-step-box .v2-sub-waku.v2-blue {
    color: #1398cc;
    border-color: #1398cc;
}
.v2-guidance-wrap .v2-step-box .v2-sub-waku.v2-yellow {
    color: #F4A738;
    border-color: #F4A738;
}
.v2-guidance-wrap .v2-step-box .v2-list {
    margin: 1rem 0 0;
    text-align: left;
}
.v2-guidance-wrap .v2-step-box .v2-list li {
    text-indent: -1.2em;
    padding-left: 1.2em;
}
.v2-guidance-wrap .v2-arrow {
    position: relative;
}
.v2-guidance-wrap .v2-arrow img {
    width: 26%;
    margin: 1rem auto;
    text-align: center;
    padding-left: 17%;
}
.v2-guidance-wrap .v2-point {
    display: block;
    text-align: left;
    font-size: 1.6rem;
    padding-left: 17%;
    margin: -4rem 0 1rem;
}
.v2-guidance-wrap .v2-point img {
    display: block;
    width: 90px;
    text-align: left;
    padding-left: 0;
    margin: 0 0 0.5rem;
}
@media (max-width: 991px) {
    .v2-guidance-wrap {
        padding-bottom: 0;
    }
    .v2-guidance-wrap .v2-box .v2-col-two {
        width: 100%;
       margin-bottom: 7rem;
    }
    .v2-guidance-wrap .v2-step-box {
        font-size: 1.9rem;
    }
    .v2-guidance-wrap .v2-arrow img {
        width: 24%;
    }
    .v2-guidance-wrap .v2-point img {
        width: 90px;
    }
}
@media (max-width: 767px) {
    .v2-guidance-wrap .v2-box .v2-col-two {
       margin: 2rem 0;
    }
    .v2-guidance-wrap .v2-step-box .v2-col:nth-of-type(2) {
        padding: 0.5rem;
    }
    .v2-guidance-wrap .v2-step-box .v2-col:nth-of-type(2) .v2-wbox {
        padding: 1rem;
    }
    .v2-guidance-wrap .v2-step-box .v2-col  .v2-wbox-box .v2-wbox-col {
        width: 49%;
    }
    .v2-guidance-wrap .v2-step-box {
        font-size: 1.4rem;
    }
    .v2-guidance-wrap .v2-step-box .v2-sub {
        font-size: 2rem;
    }
    .v2-guidance-wrap .v2-step-box .v2-sup {
        font-size: 1.2rem;
        line-height: 1.6;
    }
    .v2-guidance-wrap .v2-step-box .v2-sub-waku {
        font-size: 1.6rem;
        border-width: 2px;
        padding: 0.5rem;
        margin-top: 0.5rem;
    }
    .v2-guidance-wrap .v2-arrow img {
        width: 26%;
        margin: 0.5rem auto;
    }
    .v2-guidance-wrap .v2-point {
        font-size: 1.3rem;
        line-height: 1.7;
        margin: -30px 0 0.5rem;
    }
    .v2-guidance-wrap .v2-point img {
        width: 65px;
        margin: 0 0 0.5rem;
    }
}
@media (max-width: 360px) {
    .v2-guidance-wrap .v2-step-box .v2-txt {
        font-size: 1.3rem;
    }
    .v2-guidance-wrap .v2-point {
        font-size: 1.2rem;
    }
}

.v2-guidance-wrap .v2-btn {
    max-width: 100%;
    color: #fff;
    margin: 1.2rem auto 0.5rem;
    font-size: 1.7rem;
    background: #ef628b;
    padding: 0.8rem 0.5rem 1rem;
}
.v2-guidance-wrap .v2-btn:focus {
    color: #fff !important;
}
.v2-guidance-wrap .v2-btn:hover {
    color: #ef628b;
    background: #fff !important;
}
.v2-guidance-wrap .v2-btn.v2-blue {
    background: #1398cc;
}
.v2-guidance-wrap .v2-btn.v2-blue:hover {
    color: #1398cc;
}
.v2-guidance-wrap .v2-btn.v2-yellow {
    background: #F4A738;
}
.v2-guidance-wrap .v2-btn.v2-yellow:hover {
    color: #F4A738;
}
@media (max-width: 1199px) {
    .v2-guidance-wrap .v2-btn {
        font-size: 1.5rem;
    }
}
@media (max-width: 991px) {
    .v2-guidance-wrap .v2-btn {
        font-size: 1.7rem;
    }
}
@media (max-width: 767px) {
    .v2-guidance-wrap .v2-btn {
        font-size: 1.3rem;
        padding: 0.8rem 0;
        margin: 0.8rem 0 0;
    }
    .v2-guidance-wrap .v2-btn i {
        margin-right: 0.3rem;
    }
}

/*-------------------------------
 * 5. TOP
 * ----------------------------*/
/* 5.1 Main Visual
 * ------------------------------*/
#v2-main-visual {
    width: 100vw;
    height:100vh;
    margin: 0;
    -webkit-animation: fadeIn 2s ease both;
    animation: fadeIn 2s ease both;
    -webkit-animation-delay: 0.5s;
    animation-delay: 0.5s;
    position: relative;
}
#v2-main-visual .v2-main-sub {
    position: absolute;
    z-index: 1;
    margin: 0;
    top: 14%;
    font-family: BrownhillScript;
    font-size: 7vw;
    transform: rotate(-8deg);
    -webkit-transform: rotate(-8deg);
    text-shadow: 0px 1px 2px #fff;
}
#v2-main-visual .v2-main01 .v2-main-sub {
    left: 4%;
}
#v2-main-visual .v2-main-pict {
    width: 350px;
    position: absolute;
    left: 5%;
    bottom: 12%;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: flex-start;
    align-content: flex-start;
}
#v2-main-visual .v2-main-pict .v2-main-pict-oc {
    width: 190px;
}
#v2-main-visual .v2-main-pict .v2-main-pict-girl {
    width: 110px;
}
@media screen and (orientation:portrait) and (max-width: 1024px) {
    #v2-main-visual {
        height: 800px;
    }
}
@media (max-width: 991px) {
    #v2-main-visual {
        height: 600px;
    }
    #v2-main-visual .v2-main-sub {
        font-size: 8vw;
        font-weight: 500;
    }
    #v2-main-visual .v2-main-pict {
        bottom: 7%;
    }
    #v2-main-visual .v2-main-pict .v2-main-pict-girl {
        display: none;
    }
}
@media (max-width: 767px) {
    #v2-main-visual .v2-main-sub {
        top: 13%;
        font-size: 6.5vw;
    }
    #v2-main-visual .v2-main01 .v2-main-sub {
        left: 4%;
    }
    #v2-main-visual .v2-main-pict {
        bottom: 45%;
    }
    #v2-main-visual .v2-main-pict .v2-main-pict-oc {
        width: 120px;
    }
}
@media (max-width: 480px) {
    #v2-main-visual {
        height: 320px;
    }
    #v2-main-visual .v2-main-sub {
        top: 72%;
        font-size: 8vw;
    }
    #v2-main-visual .v2-main01 .v2-main-sub {
        left: 40%;
    }
    #v2-main-visual .v2-main-pict {
        bottom: 8%;
        left: 2%;
    }
    #v2-main-visual .v2-main-pict .v2-main-pict-oc {
        width: 110px;
    }
}
@media (max-width: 360px) {
    #v2-main-visual {
        height: 310px;
    }
}
@media (max-width: 320px) {
    #v2-main-visual {
        height: 270px;
    }
    #v2-main-visual .v2-main-pict {
        bottom: 44%;
    }
    #v2-main-visual .v2-main-pict .v2-main-pict-oc {
        width: 100px;
    }
}

/* 5.2 Reason
 * ------------------------------*/
#v2-tp-reason .v2-section-ttl {
    margin-bottom: 4rem;
}
.v2-reason .v2-col-three {
    padding: 2rem 2.5rem 4.5rem;
}
.v2-reason .v2-reason01 {
    background: #FBD7DF;
}
.v2-reason .v2-reason02 {
    background: #ACEDFA;
}
.v2-reason .v2-reason03 {
    background: #FAEAAD;
}
.v2-reason .v2-sub {
    height: calc(50 / 1280 * 100vw);
    box-sizing: border-box;
    position: relative;
    margin: 0 0 2rem;
}
.v2-reason .v2-sub::before {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  content: '';
  background: url(../image/line.svg) left center no-repeat;
  background-size: cover;
}
.v2-reason .v2-reason01 .v2-sub img {
    width: 90%;
}
.v2-reason .v2-reason02 .v2-sub img {
    width: 70%;
}
.v2-reason .v2-reason03 .v2-sub img {
    width: 95%;
}
.v2-reason .v2-reason03 .v2-sub {
    padding-top: 0.5rem;
}
.v2-reason .v2-icon-check {
    width: calc(130 / 1280 * 100vw);
    position: absolute;
    right: 25px;
    bottom: 12px;
    margin: 0;
}
.v2-reason .v2-imagearea {
   height:  calc(250 / 1280 * 100vw);
}
@media (min-width: 1280px) {
    .v2-reason .v2-sub {
        height: 50px;
    }
    .v2-reason .v2-icon-check {
        width: 130px;
    }
    .v2-reason .v2-imagearea {
        height: 250px;
    }
}
@media (max-width: 1199px) {
    .v2-reason .v2-sub {
        margin-bottom: 1.5rem;
    }
    #v2-tp-reason .v2-section-ttl {
        margin-bottom: 3rem;
    }
    .v2-reason .v2-col-three {
        padding: 1.5rem 2rem 3.5rem;
    }
}
@media (max-width: 991px) {
    .v2-reason .v2-sub {
        margin-bottom: 1rem;
    }
    .v2-reason .v2-reason01 .v2-sub img {
        width: 100%;
    }
    .v2-reason .v2-reason02 .v2-sub img {
        width: 80%;
    }
    .v2-reason .v2-reason03 .v2-sub img {
        width: 100%;
    }
    .v2-reason .v2-reason03 .v2-sub {
        padding-top: 0.3rem;
    }
}
@media (max-width: 767px) {
    #v2-tp-reason .v2-section-ttl {
        margin-bottom: 2rem;
    }
    .v2-reason .v2-col-three {
        padding: 0;
        background: none !important;
    }
    .v2-reason .v2-col-three:hover {
        opacity: 0.75;
        transition: 0.5s;
    }
}

/* 5.3 Open campus
 * ------------------------------*/
#v2-tp-oc {
    padding-bottom: 2rem;
}
#v2-tp-oc .v2-section-ttl {
    margin-bottom: 1rem;
}
.v2-oc a {
    color: #000;
}
.v2-oc a:hover {
    color: #000;
    text-decoration: none;
}
.v2-oc .v2-col-three {
    background: url(../image/waku-square-pc.svg) center center no-repeat;
    background-size: contain;
    padding: 2.8rem 0.8rem 3rem;
}
.v2-oc .v2-imagearea {
    height:  320px;
    border-radius: 20px;
}
@media (max-width: 1199px) {
    .v2-oc .v2-imagearea {
        height: 270px;
    }
}
@media (max-width: 991px) {
    .v2-oc .v2-imagearea {
        height: 200px;
    }
}
@media (max-width: 767px) {
    #v2-tp-oc {
        padding-bottom: 0;
    }
    #v2-tp-oc .v2-section-ttl {
        margin-bottom: 2rem;
    }
    .v2-oc .v2-col-three {
       background: none;
       padding: 0;
    }
    .v2-oc .v2-col-three:hover {
        opacity: 0.75;
        transition: 0.5s;
    }
}

.v2-oc .v2-sub {
    width: 96%;
    font-size: 1.8rem;
    text-align: center;
    font-weight: 600;
    padding: 2rem 0.5rem;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 29px;
    margin: auto;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
}
.v2-oc .v2-oc01 .v2-sub {
    background: rgba(249, 197, 210, 0.8);
}
.v2-oc .v2-oc02 .v2-sub {
    background: rgba(135, 228, 249, 0.7);
}
.v2-oc .v2-oc03 .v2-sub {
    background: rgba(247, 226, 137, 0.8);
}
@media (min-width: 1280px) {
    .v2-oc .v2-sub {
        bottom: 29px;
    }
}
@media (max-width: 1199px) {
    .v2-oc .v2-sub {
        font-size: 1.6rem;
    }
}
@media (max-width: 991px) {
    .v2-oc .v2-sub {
        font-size: 1.4rem;
    }
}

/* 5.4 News
 * ------------------------------*/
#v2-tp-news .v2-news-box {
    margin: 0;
    height: 340px;
    overflow-x: hidden;
    overflow-y: scroll;
}
.v2-news-box::-webkit-scrollbar {
    width: 5px;
}
.v2-news-box::-webkit-scrollbar-track {
    -webkit-border-radius: 10px;
    border-radius: 10px;
}
.v2-news-box::-webkit-scrollbar-thumb {
    -webkit-border-radius: 10px;
    border-radius: 10px;
    background: #F9A9BB;
}
@media (max-width: 767px) {
    #v2-tp-news .v2-news-box {
        height: 310px;
    }
    .v2-news-box::-webkit-scrollbar {
        width: 3px;
    }
}

.v2-news-box ul {
    padding-right: 1.5rem;
}
.v2-news-box ul li {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: flex-start;
    align-content: flex-start;
    padding: 2rem 0;
    border-bottom: 1px solid #c9caca;
    line-height: 1.8;
}
.v2-news-box ul li:first-of-type {
    border-top: 1px solid #c9caca;
}
.v2-news-box ul li a {
    display: block;
    color: #000;
    text-decoration: none;
}
.v2-news-box ul li a:hover {
    text-decoration: none;
    color: #999;
    transition: 0.5s;
}
.v2-news-box ul li .v2-day {
    width: 90px;
    color: #777777;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.05em;
    font-weight: 400;
    font-size: 1.3rem;
}
.v2-news-box ul li .v2-icon {
    width: 130px;
}
.v2-news-box ul li .v2-icon span {
    display: inline-block;
    width: 130px;
    height: 21px;
    font-size: 1.2rem;
    color: #fff;
    text-align: center;
    box-sizing: border-box;
    line-height: 1;
    padding-top: 0.35rem;
    background: #f87c99;
}
.v2-news-box ul li .v2-txt {
    box-sizing: border-box;
    padding-left: 1.8rem;
}
@media (max-width: 991px) {
    .v2-news-box ul li {
        padding: 1.5rem 0;
    }
}
@media (max-width: 767px) {
    .v2-news-box ul {
        padding-right: 1rem;
    }
    .v2-news-box ul li {
        padding: 1rem 0;
    }
    .v2-news-box ul li .v2-day {
        width: 85px;
    }
    .v2-news-box ul li .v2-txt {
        display: block;
        width: 100%;
        padding-top: 0.5rem;
        padding-left: 0;
    }
}

/*-------------------------------
 * 6. FOOTER
 * ----------------------------*/
footer#v2-footer {
    margin: 4rem 0 0;
    padding: 3rem 0 2rem;
    background: #f87c99;
    color: #fff;
}
footer#v2-footer a {
    color: #fff;
}
footer#v2-footer a:hover {
    color: #fff;
}
footer#v2-footer #v2-copy {
    font-size: 1.2rem;
    text-align: center;
}
@media (max-width: 767px) {
    footer#v2-footer {
        margin-top: 5rem;
        padding: 2rem 0 9rem;
    }
    footer#v2-footer #v2-copy {
        font-size: 1rem;
    }
}

footer#v2-footer .v2-footer-menu01 {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: flex-start;
}
footer#v2-footer .v2-footer-menu01 .v2-sub {
    margin: 0 0 0.8rem;
    padding-bottom: 0.8rem;
    font-size: 1.5rem;
    border-bottom: 1px solid #fff;
}
footer#v2-footer .v2-footer-menu01 ul {
    width: 17%;
    margin: 0;
    padding: 0;
}
footer#v2-footer .v2-footer-menu01 ul li {
    margin: 0;
    padding: 0;
    line-height: 1.8;
    font-size: 1.4rem;
}
@media (max-width: 767px) {
    footer#v2-footer .v2-footer-menu01 .v2-sub {
        font-size: 1.3rem;
    }
    footer#v2-footer .v2-footer-menu01 ul {
        width: 46%;
        margin-bottom: 2rem;
    }
    footer#v2-footer .v2-footer-menu01 ul li {
        font-size: 1.2rem;
    }
}

footer#v2-footer .v2-footer-menu02 ul {
    width: 100%;
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
    align-items: flex-start;
    align-content: flex-start;
    margin: 4rem 0 3rem;
    padding: 0;
}
footer#v2-footer .v2-footer-menu02 ul li {
    margin: 0;
    padding: 0;
    line-height: 1.8;
    font-size: 1.4rem;
    display: block;
}
footer#v2-footer .v2-footer-menu02 ul li::after {
    content: " | ";
    padding: 0 2.5rem;
}
footer#v2-footer .v2-footer-menu02 ul li:last-of-type::after {
    content: "";
}
@media (max-width: 991px) {
    footer#v2-footer .v2-footer-menu02 ul li {
        margin: 0 1.5rem;
    }
    footer#v2-footer .v2-footer-menu02 ul li::after {
        content: "";
    }
}
@media (max-width: 767px) {
    footer#v2-footer .v2-footer-menu02 ul li {
        font-size: 1.2rem;
    }
}

footer#v2-footer .v2-footer-add {
    display: none;
}
@media (max-width: 767px) {
    footer#v2-footer .v2-footer-add {
        display: block;
        text-align: center;
        margin: 2rem auto 3rem;
    }
    footer#v2-footer .v2-footer-add .v2-footer-logo {
        width: 200px;
        margin: 0 auto;
    }
}
@media (max-width: 320px) {
    footer#v2-footer .v2-footer-add .v2-footer-logo {
        width: 180px;
    }
}

.v2-foooter-hmenu {
    display: none;
}
@media (max-width: 991px) {
    .v2-foooter-hmenu {
        display: block;
        -webkit-animation: fadeIn 0.6s ease both;
        animation: fadeIn 0.6s ease both;
        -webkit-animation-delay: 0.8s;
        animation-delay: 0.8s;
    }
    .v2-foooter-hmenu .v2-hmenu {
        width: 100%;
        position: fixed;
        bottom: 0;
        left: 0;
        border-top: 3px solid #fff;
    }
    .v2-foooter-hmenu .v2-hmenu li {
        height: 66px;
    }
    .v2-foooter-hmenu .v2-hmenu li .v2-txt {
        font-size: 1.1rem;
        margin-top: 0.8rem;
    }
    .v2-foooter-hmenu .v2-hmenu li.v2-access img {
        width: 22px;
    }
    .v2-foooter-hmenu .v2-hmenu li.v2-oc {
        padding-top: 1rem;
    }
    .v2-foooter-hmenu .v2-hmenu li.v2-oc img {
        width: 37px;
    }
    .v2-foooter-hmenu .v2-hmenu li.v2-request {
        padding-top: 0.8rem;
    }
    .v2-foooter-hmenu .v2-hmenu li.v2-request img {
        width: 32px;
    }
}

/*-------------------------------
 * 7. INTERACTIONS
 * ----------------------------*/
.opacity:hover {
  opacity: 0.75;
  transition: 0.7s;
}

a:hover .v2-imagearea-content > img {
    -ms-transform: scale(1.05);
    transform: scale(1.05);
}
.v2-imagearea {
    width: 100%;
    position: relative;
    display: block;
    overflow: hidden;
}
.v2-imagearea:before {
    content: "";
    display: block;
    padding-top: 66.667%;
}
.v2-imagearea-content {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    display: block;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    align-content: flex-start;
}
.v2-imagearea-content > img {
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
    object-position: 50% 50%;
    transition: transform 600ms cubic-bezier(0.39, 0.575, 0.565, 1);
    overflow: hidden !important;
}

/*--------- keyframes --------- */
@-webkit-keyframes fadeIn {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
@keyframes fadeIn {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@-webkit-keyframes fadeOut {
    0% {
        opacity: 1;
    }
    30% {
        opacity: 0;
    }
}
@keyframes fadeOut {
    0% {
        opacity: 1;
    }
    30% {
        opacity: 0;
    }
}

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }
  30% {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }
  30% {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
}

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes pulse {
  0% {
    transform: scale3d(1, 1, 1);
  }
  50%{
    transform: scale3d(1.02, 1.02, 1.02);
  }
  100% {
    transform: scale3d(1, 1, 1);
  }
}
@keyframes pulse {
  0% {
    transform: scale3d(1, 1, 1);
  }
  50%{
    transform: scale3d(1.02, 1.02, 1.02);
  }
  100% {
    transform: scale3d(1, 1, 1);
  }
}

/*-------------------------------
 * 8. 追加 220721 オープンキャンパス 締切時のテキスト追加 
 * ----------------------------*/
.text-note {
    color: #ef628b;
    font-size: 2rem;
    text-align: center;
}
@media (max-width: 991px) {
    .text-note {
        font-size: 1.6rem;
    }
}

/*-------------------------------
 * 9. 追加 230302 アクセスマップ Google mpasの変更
 * ----------------------------*/
.new-google-maps iframe {
    width: 100%;
    max-width: 100%;
    height: 450px;
}
@media (max-width: 767px) {
    .new-google-maps iframe {
        height: 200px;
    }
}

/*-------------------------------
 * 10. 追加 230509 オープンキャンパス 緑追加暫定
 * ----------------------------*/
.v2-oc-wrap .v2-oc-box.v3-green {
    border-color: #e5f2ed;
}
.v2-oc-wrap .v2-oc-box.v3-green .v2-sub {
    background: #7FDEB7;
}
.v2-oc-wrap .v2-oc-box.v3-green .v2-day-time .v2-day span {
    background: #7FDEB7;
}
.v2-oc-wrap .v2-oc-box.v3-green .v2-btn {
    border-color: #7FDEB7;
    color: #7FDEB7;
}
.v2-oc-wrap .v2-oc-box.v3-green .v2-btn:hover {
    background-color: #7FDEB7;
    color: #fff;
}