@charset "UTF-8";
/* CSS Document */

img.sp,br.br { display: none; }

.News .ttl,.Blog .ttl,.oc .ttl { background: var(--main-bg-color-alpha); height: 300px; display: flex; align-items: center; padding-left: 85px; position: relative; }
.News .ttl h1,.Blog .ttl h1,.oc .ttl h1 { font-size: 1.250em; font-weight: 400; color: var(--font-color); position: relative; z-index: 1; border-left: 4px solid var(--font-color); padding-left: 15px; letter-spacing: 0.1em; }
.News .ttl h1 strong,.Blog .ttl h1 strong,.oc .ttl h1 strong { font-size: 2.813rem; display: inline-block; margin-bottom: 15px; }

.topicpath { display: flex; justify-content: flex-start; font-size: 0.875em; margin-top: 10px; }
.topicpath li + li::before { content: "＞"; display: inline-block; margin: 0 5px; }

.wp-pagenavi,.pagenavi { width: 100%; display: flex; justify-content: center; align-items: center; margin: 110px 0 0 0; font-size: 1.250rem; }
.wp-pagenavi .current { color: #FFF; background: var(--main-bg-color); display: flex; justify-content: center; align-items: center; width: 60px; height: 60px; text-align: center; position: relative; border: 1px solid var(--main-bg-color); border-left: none; }
.wp-pagenavi .page,.wp-pagenavi .list,.wp-pagenavi .extend { display: flex; justify-content: center; align-items: center; text-align: center; color: var(--main-bg-color); text-decoration: none; width: 60px; height: 60px; border: 1px solid var(--main-bg-color); border-left: none; }
.wp-pagenavi .nextpostslink,.wp-pagenavi .previouspostslink { display: flex; justify-content: center; align-items: center; color: var(--main-bg-color); width: 60px; height: 60px; border: 1px solid var(--main-bg-color); border-left: none; }

.wp-pagenavi *:first-child,.pagenavi li:first-child { border-left: 1px solid var(--main-bg-color); }
.pagenavi li { color: #FFF; display: flex; justify-content: center; align-items: center; width: 150px; height: 60px; text-align: center; position: relative; border: 1px solid var(--main-bg-color); border-left: none; color: var(--main-bg-color); font-size: 1.500rem; color: #9e9e9f; }
.pagenavi li a { color: var(--main-bg-color); }
.pagenavi li.top { font-size: 0.938rem; }

/*ショート動画検証*/
/*1動画ver*/
.youtube-shorts-wrapper { position: relative; width: 100%; max-width: 300px; aspect-ratio: 9 / 16; margin: 0 auto 80px; overflow: hidden; border-radius: 10px; }
.youtube-shorts-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }
.youtube-shorts-wrapper .youtube { position :initial; }

/* ---------------------------------------------------
News
-------------------------------------------------- */
#News,#Blog { max-width: 1700px; width: 100%; }
#News .inner,#Blog .inner { max-width: 1200px; width: 90%; margin: 0 auto; }

#News dl { display: flex; justify-content: flex-start; flex-wrap: wrap; font-size: 1.250rem; border-top: 1px solid #251e1c; margin-top: 70px; }
#News dl dt { width: 5em; text-align: center; position: relative; border-bottom: 1px solid #251e1c; padding: 25px 1.5em; }
#News dl dt::after { content: ""; display: inline-block; width: 1px; height: 60%; background: #251e1c; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; }
#News dl dd { width: calc(100% - 8em); padding: 25px 1.5em; border-bottom: 1px solid #251e1c; box-sizing: border-box; }

#News article { margin-top: 70px; }
#News article p { font-size: 1.125rem; margin: 30px 15px 0 15px; width: calc(100% - 30px); line-height: 1.8em; }
#News article .date { font-size: 1.250rem; line-height: 1; color: #9e9e9f; margin: 0; padding: 0 15px; }
#News article h2 { font-size: 1.875em; border-bottom: 1px solid #251e1c; padding: 15px; }
#News article .img { margin: 30px 15px 0 15px; width: calc(100% - 30px); box-sizing: border-box; padding-top: 57.9%; overflow: hidden; position: relative; }
#News article .img img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; height: auto; }
#News article .img + p { margin-top: 50px; }


/* ---------------------------------------------------
Blog
-------------------------------------------------- */
.Blog .List { display: flex; justify-content: flex-start; align-items: flex-start; flex-wrap: wrap; }
.Blog .List .column { width: 32%; margin-top: 65px; margin-left: 2%; position: relative; }
.Blog .List .column:nth-child(3n+1) { margin-left: 0; }
.Blog .List .column a { display: block; }
.Blog .List p { line-height: 1.5em; }
.Blog .List .date { font-size: 0.875em; color: #9e9e9f; margin-top: 5px; }
.Blog .List .cat { display: inline-block; position: absolute; top: 0; background: var(--main-bg-color); color: #FFF; font-size: 0.938rem; font-weight: 600; padding: 0 1em; top: 10px; }
.Blog .List .sttl { font-size: 1.000rem; font-weight: 600; margin-top: 5px; }
.Blog .List .sttl + p { font-size: 0.938rem; margin-top: 5px; }
.Blog .List .img { overflow: hidden; width: 100%; position: relative; padding-top: 60.76%; }
.Blog .List .img img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; height: auto; }

.Blog #Nav { display: flex; justify-content: space-between; width: 650px; margin: 100px auto 0 auto; }
.Blog #Nav > div { overflow: hidden; width: 300px; text-align: center; position: relative; border: 1px solid var(--main-bg-color); border-radius: 5px; background: var(--main-bg-color-alpha); }
.Blog #Nav > div select { width: 100%; cursor: pointer; text-indent: 0.01px; text-overflow: ellipsis; border: none; outline: none; background: transparent; background-image: none; box-shadow: none; -webkit-appearance: none; appearance: none; font-size: 1.125em; padding: 10px 1em 10px 1em; color: var(--font-color); }
.Blog #Nav > div select::-ms-expand { display: none; }
.Blog #Nav > div::before { content: ""; -webkit-mask: url(../images/arrow.svg); mask: url(../images/arrow.svg); -webkit-mask-size: 100% auto; mask-size: 100% auto; background-color: var(--font-color); /*background: url(../images/arrow.svg) var(--main-bg-color-alpha); background-size: 100% auto;*/ display: block; position: absolute; width: 30px; height: 30px; pointer-events: none; right: 8px; top: 0; bottom: 0; margin: auto; }
.Blog hr { width: calc(100% - 30px); margin: 100px auto 0 auto; background: #251e1c; color: none; border: none; height: 1px; }

#Blog article { margin-top: 70px; }
#Blog article p { font-size: 1.125rem; margin: 30px 15px 0 15px; width: calc(100% - 30px); line-height: 1.8em; }
#Blog article .date { font-size: 1.250rem; line-height: 1; color: #9e9e9f; margin: 0; padding: 0 15px; }
#Blog article .date span { display: inline-block; background: var(--main-bg-color); color: #FFF; font-size: 0.938rem; padding: 5px 0.5em; margin-right: 20px; }
#Blog article h2 { font-size: 1.875em; border-bottom: 1px solid #251e1c; padding: 15px; }
#Blog article .wp-block-group { margin-top: 40px; padding: 0 15px; }
#Blog h2 + figure { margin-top: 30px; }

.youtube { position: relative; width: 100%; padding-top: 56.25%; }
.youtube iframe{ position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }


/* ---------------------------------------------------
Open Cumpus
-------------------------------------------------- */
.Opencumpus { max-width: 1700px; width: 100%; }
.Opencumpus h1 { max-width: 535px; width: 63%; margin: 110px auto 0 auto; }
.Opencumpus h1 span { max-width: 265px; width: 25%; display: block; margin: 25px auto 0 auto; }
.Opencumpus #Mainvisual { width: 85%; aspect-ratio:31 / 18; position: relative; background-image: url(../../images/opencampus/main_img.jpg); background-repeat: no-repeat; background-size: cover; background-position: center top; box-sizing: border-box; margin: 45px auto 0 auto; }
.Opencumpus #Mainvisual::after { content: ""; position: absolute; max-width: 224px; width: 24%; padding-top: 100%; background: url(../../images/opencampus/img_reserve.png) no-repeat; background-size: 100% auto; right: 2%; top: 95%; z-index: 1; }
.Opencumpus #Mainvisual p { font-size: 1.750em; color: #2587b4; position: absolute; top: -2.5em; right: 9%; width: 45px; writing-mode: vertical-lr; background: rgba(255, 255, 255, .8); display: flex; justify-content: center; align-items: center; }

.Opencumpus #Lead,.Opencumpus #List { max-width: 1700px; width: 100%; }
.Opencumpus #Lead .inner,.Opencumpus #List .inner { max-width: 1000px; width: 90%; margin: 0 auto; }
.Opencumpus #Lead p { color: #4c4948; margin: 20px auto 0 auto; width: 85%; padding-right: 24%; box-sizing: border-box; }
.Opencumpus #Lead p.ttl { font-size: 1.500rem; margin-top: 40px; }
.Opencumpus #Lead p.ttl + p { font-size: 0.938rem; line-height: 2em; }
.Opencumpus #Lead .bg { background: var(--main-bg-color-alpha); margin-top: 20%; padding: 20px 0 10% 0; box-sizing: border-box; position: relative; }
.Opencumpus #Lead .bg .img { margin: -15% auto 0 auto; width: 90%; }
.Opencumpus #Lead .btn { width: 100%; margin: 5% auto 0 auto; position: relative; z-index: 1; }
.Opencumpus #Lead .btn a { width: 100%; height: 200px; padding-left: 4%; box-sizing: border-box; background: url(../../images/opencampus/img_schedule02.jpg) no-repeat right #FFF; background-size: auto 100%; font-size: 1.250em; letter-spacing: 0.2em; display: flex; flex-direction: column; justify-content: center; font-weight: 600; position: relative; }
.Opencumpus #Lead .btn a::before { content: ""; display: block; width: 100%; height: 100%; position: absolute; background: #BDA8A5; z-index: -1; right: -5px; bottom: -5px; }
.Opencumpus #Lead .btn a strong { font-size: 2.250em; display: block; color: #BDA8A5; margin-bottom: 10px; }
.Opencumpus #Lead .btn a strong::before { content: ""; display: block; width: 50%; height: 1px; background: #251e1c; margin: 10px 0 15px -2%; }

.Opencumpus #List .inner { display: flex; justify-content: space-between; flex-wrap: wrap; box-sizing: border-box; margin-top: -3.5%; position: relative; z-index: 1; }
.Opencumpus #List h2 { font-family: var(--sub-font); font-size: 2.813em; color: var(--sub-bg-color); letter-spacing: 0.1em; width: 366px; margin-left: 3.5%; }
.Opencumpus #List .btn { display: flex; justify-content: flex-end; width: calc(96.5% - 366px); }
.Opencumpus #List .btn li { width: 255px; height: 80px; line-height: 1.5em; font-weight: 600; }
.Opencumpus #List .btn li a { display: flex; justify-content: center; align-items: center; flex-direction: column; color: #FFF; height: 100%; letter-spacing: 0.1em; }
.Opencumpus #List .btn li:first-child a { background: var(--main-bg-color); }
.Opencumpus #List .btn li:last-child a { background: var(--sub-bg-color); text-align: center; }
.Opencumpus #List .btn li a strong { font-size: 1.125em; }
.Opencumpus #List .btn li a strong::before { content: ""; display: inline-block; background: url(../../images/opencampus/ic_tel.svg); width: 16px; height: 12px; background-size: 100% auto; margin-right: 5px; }
.Opencumpus #List .date { font-family: var(--sub-font); font-size: clamp(3.438rem, 1rem + 4.06vw, 4.25rem); letter-spacing: -0.06em; max-width: 950px; width: 100%; margin: 0 auto; display: flex; justify-content: flex-start; flex-wrap: wrap; }
.Opencumpus #List .date li { margin: 40px 1.5% 0 1.5%; width: 17%; }
.Opencumpus #List .date li span.m { width: 35%; display: block; }
.Opencumpus #List .date li span.d { width: 35%; display: block; }
.Opencumpus #List .date li span.s { width: 17%; display: block; text-align: center; }
.Opencumpus #List .date li span.week { display: block; width: 13%; box-sizing: border-box; }
.Opencumpus #List .date li span.week img { margin: 7px 0 0 7px; display: block; }
.Opencumpus #List .date li a { display: flex; justify-content: center; border-bottom: 1px solid var(--main-bg-color); color: var(--sub-font-color); width: 100%; padding: 0 0 5px; box-sizing: border-box; }
.Opencumpus #List .date li.blue a { color: #B0CED5; border-color: #B0CED5; }
.Opencumpus #List .date li.end a { color: #dcdcdc; border-color: #dcdcdc; }
.Opencumpus #List .list { max-width: 950px; width: 100%; margin: 35px auto 0 auto; color: var(--main-font-color); line-height: 1.5em; font-size: 0.875em; }
.Opencumpus #List p { font-size: 1.563rem; text-align: center; width: 100%; margin-top: 35px; }

.Opencumpus #Schedule { max-width: 1700px; width: 100%; background: var(--main-bg-color-alpha); }
.Opencumpus #Schedule .inner { max-width: 1100px; width: 90%; margin: 9% auto 0 auto; padding: 70px 0 150px 0; box-sizing: border-box; }
.Opencumpus #Schedule h2 { font-family: var(--sub-font); font-size: 3.875em; color: var(--sub-bg-color); text-align: center; width: 410px; margin: 0 auto; position: relative; letter-spacing: 0.1em; }
.Opencumpus #Schedule h2::before { content: ""; display: block; width: 442px; height: 180px; -webkit-mask-image: url(../../images/opencampus/bg_logo.svg); mask: url(../../images/opencampus/bg_logo.svg); -webkit-mask-size: 100% auto; mask-size: 100% auto; background-color: var(--main-bg-color); position: absolute; top: -15px; }
.Opencumpus #Schedule .box + h2 { margin-top: 60px; }
.Opencumpus #Schedule .box { max-width: 1100px; width: 100%; min-height: 170px; display: flex; justify-content: space-between; align-items: stretch; margin: 50px auto 0 auto; position: relative; }
.Opencumpus #Schedule .box:not(.end):first-of-type { border: 1px solid #ccc; }
.Opencumpus #Schedule h2 + .box { margin-top: 25px; }
.Opencumpus #Schedule .end::before { content: "イベント終了"; display: block; width: 280px; height: 60px; border: 4px solid #9A6996; box-sizing: border-box; z-index: 1; position: absolute; display: flex; justify-content: center; align-items: center; background: #FFF; color: #9A6996; font-size: 2.500rem; transform: rotate(-15deg); left: 0; right: 0; bottom: 0; top: 0; margin: auto; }
.Opencumpus #Schedule .date { font-family: var(--sub-font); color: #FFF; font-size: 3.438em; text-align: center; width: 150px; background: var(--main-bg-color);  display: flex; flex-direction: column; align-items: center; justify-content: center; letter-spacing: -0.05em; }
.Opencumpus #Schedule .date span { display: block; width: 100%; font-size: 1.500rem; border-top: 1px solid #FFF; padding-top: 10px; letter-spacing: 0; margin-top: 10px; }
.Opencumpus #Schedule .blue { background: #B0CED5; }
.Opencumpus #Schedule .txt { width: calc(100% - 460px); padding: 15px; box-sizing: border-box; background: #FFF; display: flex; flex-direction: column; justify-content: center; position: relative; }
.Opencumpus #Schedule .txt .ttl { font-weight: 600; font-size: 1.563em; line-height: 1.3em; }
.Opencumpus #Schedule .txt .time { color: var(--main-bg-color); font-size: 0.875em; margin-top: 2.5%; font-weight: 600; }
.Opencumpus #Schedule .txt .time + p { font-size: 0.875em; line-height: 1.5em; margin-top: 2.5%; }
.Opencumpus #Schedule .img { width: 235px; height: auto; overflow: hidden; position: relative; background: #CCC; }
.Opencumpus #Schedule .img img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: auto; max-width: initial; height: 100%; }
.Opencumpus #Schedule .btn { width: 75px; }
.Opencumpus #Schedule .btn a { display: flex; justify-content: center; align-items: center; width: 100%; height: 50%; font-size: 0.750em; letter-spacing: -0.1em; background: var(--main-bg-color); color: #FFF; text-align: center; line-height: 1.3em; }
.Opencumpus #Schedule .btn a.fb { background: var(--sub-bg-color); flex-direction: column; }
.Opencumpus #Schedule .btn a.fb img { width: 23px; height: auto; margin-top: 3px; }

.Opencumpus + footer { margin-top: 0; }

.oc .app { background: var(--main-bg-color); width: 250px; }
.oc .app a {  color: #FFF; font-size: 0.938rem; }


/* ---------------------------------------------------
Qualification
-------------------------------------------------- */
.Qualification #Mainvisual h1 { font-weight: 400; height: 300px; display: flex; flex-wrap: wrap; flex-direction: column; justify-content: center; align-items: center; }
.Qualification #Mainvisual picture { display: block; }
.Qualification #Mainvisual h1::before { content: attr(data-en); font-size: 2.125rem; color: var(--sub-font-color); letter-spacing: 0.1em; margin-bottom: 15px; }
.Qualification .inner { max-width: 1200px; width: 90%; margin: auto; box-sizing: border-box; }
.Qualification #Mainvisual p { font-size: 1.500em; margin-top: 50px; line-height: 1.5em; }

#Pass { margin-top: 50px; }
#Pass h2,#License h2,#Employment h2 , #Supporters_salon h2 , #Internship h2 { font-size: 1.500em; color: var(--sub-font-color); border-left: 5px solid var(--sub-font-color); padding: 5px 15px; }
#Pass p , #Supporters_salon .flex .box p , #Internship p { font-size: 0.938em; margin-top: 15px; line-height: 2.0em; }
#Pass .img { margin-top: 35px; position: relative; }
#Pass .img::before { content: ""; display: inline-block; width: 338px; height: 138px; background: url(../../images/bg_logo.svg); position: absolute; right: 0; top: -138px; z-index: -1; }
#Supporters_salon .supporters_salon_img02 { max-width: 850px; width: 100%; margin: 20px auto; display: block; }
#Supporters_salon .supporters_salon_img03 { max-width: 700px; width: 100%; display: block; margin: 0 auto 80px; }
#Supporters_salon .supporters_salon_img04 { max-width: 900px; width: 90%; display: block; margin: 20px auto; }
#Supporters_salon .flex { display: flex; justify-content: space-between; }
#Supporters_salon .flex .box { width: calc(92% / 3); margin-bottom: 50px; }
#Supporters_salon .flex .box h3 { font-size: 20px; margin-bottom: 15px; line-height: 1.4; color: var(--sub-font-color); border-bottom: 1px solid #e5e5e5; padding-bottom: 10px; }
#Internship h4 { font-size: 20px; line-height: 1.4em; margin-bottom: 10px; }
#Internship .internship_contents { margin-top: 30px; }
#Internship .internship_flex { display: flex; justify-content: space-between }
#Internship .internship_box { width: calc(95%/ 5); }
#Internship .internship_box p.chusyaku { font-size: 13px; }

#License h2,#Employment h2 , #Supporters_salon h2 , #Internship h2 { margin-top: 100px; }
#License h3 { font-size: 1.125rem; margin-top: 50px; }
#License .flex + h3 { margin-top: 100px; }
#License h2 + p , #Supporters_salon h2 + p { font-size: 0.938em; margin-top: 15px; line-height: 2.0em; }
#License dl { border: 1px solid var(--sub-font-color); margin-top: 70px; padding: 25px; display: flex; justify-content: space-between;  }
#License dl dt { font-size: 1.000em; text-align: center; width: 330px; color: var(--sub-font-color); border-right: 1px solid var(--sub-font-color); display: flex; align-items: center; justify-content: center; }
#License dl dd { width: calc(100% - 330px); padding: 0 50px; font-size: 0.938em; line-height: 1.5em; box-sizing: border-box; }

.Qualification .flex { display: flex; justify-content: space-between; flex-wrap: wrap; align-items: flex-start; }
.Qualification .flex .column { width: 47%; margin-top: 60px; display: flex; flex-direction: column; justify-content: space-between; }
.Qualification .flex .column:first-child,.Qualification .flex .column:nth-child(2) { margin-top: 20px; }
.Qualification .flex .column h4 { font-size: 1.500em; line-height: 1.4em; }
.Qualification .flex .column p { font-size: 0.938em; line-height: 2.0em; margin-top: 15px; }
.Qualification .flex .column .img { margin-top: 20px; }
.Qualification .flex .column .txt { border: 1px solid var(--sub-font-color); margin-top: auto; padding: 20px 40px; box-sizing: border-box; margin-top: 30px; }
.Qualification .flex .column .txt .ttl { margin: 0; font-size: 1.000rem; color: var(--sub-font-color); }
.Qualification .flex .column .txt .ttl + p { margin-top: 10px; }

#Employment p { margin-top: 25px; font-size: 0.938em; line-height: 2.00em; }

/* ---------------------------------------------------
Society
-------------------------------------------------- */
.Society section { margin-bottom: 80px; }
.Society section p { font-size: 0.938em; line-height: 2.0em; margin-top: 15px; }
.Society #Mainvisual h1 { font-weight: 400; height: 300px; display: flex; flex-wrap: wrap; flex-direction: column; justify-content: center; align-items: center; }
.Society #Mainvisual picture { display: block; }
.Society #Mainvisual h1::before { content: attr(data-en); font-size: clamp(1.5rem, 1.25rem + 1.25vw, 2.5rem); color: var(--sub-font-color); letter-spacing: 0.1em; margin-bottom: 15px; }
.Society .inner { max-width: 1200px; width: 90%; margin: auto; box-sizing: border-box; }
.Society #Mainvisual p { font-size: 1.500em; margin-top: 50px; line-height: 1.5em; }
.Society h2 { font-size: 1.500em; line-height: 1.3; color: var(--sub-font-color); border-left: 5px solid var(--sub-font-color); padding: 5px 15px; margin-bottom: 20px; }
.Society h2.obi { background: var(--sub-font-color); color: #fff; font-size: clamp(1.125rem, 1.031rem + 0.47vw, 1.5rem); padding: 10px 20px; line-height: 1.3; box-sizing: border-box; margin-bottom: 10px; }
.Society h3.line { border-bottom: solid 3px #a3bdca; position: relative; padding-bottom: 15px; font-size: 1.400em; line-height: 1.3; }
.Society h3.line:after { position: absolute; content: " "; display: block; border-bottom: solid 3px #38718d; bottom: -3px; width: 20%; }

.Society .flex { display: flex; justify-content: space-between; }
.Society #Intro { margin-top: 50px; }
.Society .flex .column { width: 48%; }
.Society .flex .column span.red { color: #e06f4f; font-weight: 700; }
.Society #Taisyo .flex { margin: 40px 0; }
.Society #Taisyo .hayami h3.tenchi_line { color: var(--main-font-color); padding: 0.5em 0; border-top: solid 1px var(--main-font-color); border-bottom: solid 1px var(--main-font-color); text-align: center; font-size: clamp(1.25rem, 1.094rem + 0.78vw, 1.875rem); width: min(750px , 100%); margin: 0 auto 40px; }
.Society #Taisyo .hayami .hayamihyo { width: min(750px , 100%); margin: 0 auto; }
.Society #Flow h3.flow_ttl { background: #4c4948; color: #fff; display: inline-block; padding: 15px 20px; font-size: clamp(1.125rem, 1.047rem + 0.39vw, 1.438rem); margin: 40px 0 20px; }
.Society #Flow .step_num { color: #e18469; border-radius: 50px; border: 1px solid #e18469; background: #fff; display: flex; align-items: center; justify-content: center; width: 85px; height: 85px; margin-right: 20px; }
.Society #Flow p.step_ttl { font-size: clamp(1.125rem, 1.063rem + 0.31vw, 1.375rem); font-weight: 700; }
.Society #Flow .flow_box p.txt { width: calc(100% - 300px); }
.Society #Flow .flow_box { border-bottom: 1px solid #e18469; margin-bottom: 30px; position: relative; }
.Society #Flow .flow_box::after { content: ''; width: 0; height: 0; border-style: solid; border-right: 23px solid transparent; border-left: 23px solid transparent; border-top: 20px solid #e18469; border-bottom: 0; position: absolute; right: 0; left: 0; margin: auto; }
.Society #Flow .wrapper { display: flex; align-items: center; padding-bottom: 20px; justify-content: space-between; }
.Society #Flow .flex_ttl { display: flex; align-items: center; margin-right: 20px; width: 280px; }
.Society #Flow p { margin-top: 0; }
.Society #Flow .flow_container { width: min(800px , 100%); margin: 0 auto; }
.Society #Kyuhukin .link_btn { text-align: center; }
.Society #Kyuhukin .link_btn a { color: #fff; padding: 20px 30px; text-align: center; background: #666666; display: inline-block; border-radius: 50px; width: min(450px , 100%); margin-top: 50px; line-height: 1.4; box-sizing: border-box; }
.Society #Kyuhukin .link_btn a:hover { opacity: .5; }
.Society #Kyuhukin .link_btn a img { width: min(15px, 100%); margin-left: 10px; vertical-align: -1px; }
.Society p { font-size: 0.938em; margin-top: 15px; line-height: 2.0em; }


/* ---------------------------------------------------
Recruit
-------------------------------------------------- */
.Recruit section { margin-top: 50px; }
.Recruit section p { font-size: 0.938em; line-height: 2.0em; margin-top: 15px; }
.Recruit #Mainvisual h1 { font-weight: 400; height: 300px; display: flex; flex-wrap: wrap; flex-direction: column; justify-content: center; align-items: center; }
.Recruit #Mainvisual picture { display: block; }
.Recruit #Mainvisual h1::before { content: attr(data-en); font-size: clamp(1.5rem, 1.25rem + 1.25vw, 2.5rem); color: var(--sub-font-color); letter-spacing: 0.1em; margin-bottom: 15px; }
.Recruit .inner { max-width: 1200px; width: 90%; margin: auto; box-sizing: border-box; }
.Recruit #Mainvisual p { font-size: 1.500em; margin-top: 50px; line-height: 1.5em; }
.Recruit h2 { font-size: 1.500em; line-height: 1.3; color: var(--sub-font-color); border-left: 5px solid var(--sub-font-color); padding: 5px 15px; margin-bottom: 20px; }
.Recruit .anchor_link ul li::before { content: ''; display: inline-block; background:url("../../images/recruit/link_arrow.png")no-repeat; width: 15px; height: 15px; background-size: contain; margin-right: 5px; vertical-align: -1px; }
.Recruit .anchor_link ul li { font-size: 18px; font-weight: 500; line-height: 1.3; text-indent: -1.3em; padding-left: 1.2em; }
.Recruit .anchor_link ul li:not(:last-child) { margin-bottom: 10px; }
.Recruit section dl.detail { display: flex; flex-wrap: wrap; margin-bottom: 50px; font-size: 0.938em; line-height: 2.0em; }
.Recruit section dl.detail ul li::before { content: '・'; display: inline-block; font-size: 14px; }
.Recruit section dl.detail dt { width: 10em; padding: 20px 0; border-bottom: 1px solid #CAC9C9; }
.Recruit section dl.detail dd { width: calc(100% - 10em); padding: 20px 0; border-bottom: 1px solid #CAC9C9; }
.Recruit h3.obi { background: #38718d; color: #fff; font-size: clamp(1.125rem, 1.031rem + 0.47vw, 1.5rem); padding: 10px 20px; line-height: 1.3; box-sizing: border-box; margin-bottom: 10px; }
.Recruit .link_btn { text-align: center; }
.Recruit .link_btn a { color: #fff; padding: 20px 30px; text-align: center; background: #966E50; display: inline-block; border-radius: 50px; width: min(280px , 100%); margin-top: 50px; line-height: 1.4; box-sizing: border-box; }
.Recruit .link_btn a:hover { opacity: .5; }


/* ---------------------------------------------------
Offer
-------------------------------------------------- */
.Offer { max-width: 1700px; width: 100%; }
.Offer h1 { font-size: 1.500em; text-align: center; color: var(--sub-font-color); }
.Offer h1 strong { background: #FFF; padding: 0 1em; }
.Offer p { font-size: 0.938em; line-height: 2.0em; }
.Offer h1 + p { text-align: center; margin-top: 25px; }

.contact { background: #EEEEEF; margin: 55px auto 0 auto; padding: 40px; box-sizing: border-box; display: flex; justify-content: center; align-items: center; }
.contact dt { background: var(--sub-font-color); color: #FFF; width: 110px; height: 110px; display: flex; justify-content: center; align-items: center; font-size: 1.000em; }
.contact dd { width: 550px; text-align: center; color: var(--sub-font-color);; }
.contact dd span { font-size: 1.250rem; }
.contact dd strong { font-family: var(--sub-font); font-style: normal; font-weight: 300; font-size: 4.000rem; display: inline-block; margin-top: 5px; }
.contact dd a { color: var(--sub-font-color); }

#Protector { padding-top: 50px; }
#Protector .flex { display: flex; justify-content: space-between; flex-wrap: wrap; counter-reset: number 0; margin: auto; }
#Protector .flex > .img { width: 39.5%; margin-top: 50px; }
#Protector .flex .txt { width: 56.5%; margin: 75px 0 25px 0; display: flex; flex-direction: column; justify-content: center; }
#Protector .flex .txt h2 { border-left: 7px solid var(--sub-font-color); padding: 0 25px; font-size: 1.500em; line-height: 1.3em; color: var(--sub-font-color); height: 100px; display: flex; align-items: center; }
#Protector .flex .txt h2::after { counter-increment: number 1; content: "0"counter(number); font-family: var(--sub-font); font-style: normal; font-weight: 300; font-size: 7.688rem; color: #EEEEEF; line-height: 0.6em; margin-left: auto; }
#Protector .flex .txt p { font-size: 0.938em; line-height: 2.0em; margin-top: 20px; }
#Protector .flex .txt .img { display: none; }

#Teacher { padding-top: 170px; }
#Teacher .flex { display: flex; justify-content: space-between; flex-wrap: wrap; }
#Teacher .flex .column { width: 31.5%; margin-top: 50px; }
#Teacher .flex .column h2 { color: #FFF; background: var(--sub-bg-color); text-align: center; font-size: 1.125em; border-radius: 6px; padding: 15px; }
#Teacher .flex .column p { font-size: 0.938em; margin-top: 20px; }

#Company { padding-top: 170px; }
#Company p { font-size: 0.938rem; line-height: 2.0em; }
#Company .btn { margin: 4% auto 0 auto; }
#Company .btn a { background: var(--sub-font-color); display: flex; width: 100%; height: 60px; justify-content: center; align-items: center; color: #FFF; border-radius: 10px; }

#Graduate { padding-top: 170px; }
#Graduate h2 { border-bottom: 1px solid #000; font-size: 1.500em; margin-top: 100px; padding: 0 10px 10px 10px; }
#Graduate h2 + p { margin-top: 15px; font-size: 0.938rem; line-height: 2.0em; }
#Graduate table { border-collapse: collapse; margin-top: 30px; width: 100%; font-size: 0.938em; text-align: center; border-top: 1px solid #000; }
#Graduate table th { background: #f7f7f7; width: 34%; padding: 20px 0; box-sizing: border-box; border-bottom: 1px solid #000; }
#Graduate table td { border-left: 1px solid #000; border-bottom: 1px solid #000; padding: 40px 0; width: 33%; box-sizing: border-box; }
#Graduate table tr:first-child td { padding: 20px 0; }
#Graduate table + p { text-align: right; font-size: 1.125rem; }
#Graduate p.pad { padding: 0 10px; }
#Graduate p + p { margin-top: 30px; }
#Graduate p.sp { display: none; }

/* ---------------------------------------------------
Request
-------------------------------------------------- */
.Request,.Privacy,#Pass,#Employment,#License,.Offer,.error { max-width: 1700px; width: 100%; box-sizing: border-box; }
.Request .inner,.Privacy .inner,#Pass .inner,#License .inner,#Employment .inner,.Offer .inner,.error .inner { max-width: 1100px; width: 90%; margin: auto; box-sizing: border-box; }
.Request h1,.Privacy h1,.error h1 { color: var(--sub-font-color); font-size: 1.500rem; text-align: center; font-weight: 400; margin-top: 50px; }
.Request h1 + p { font-size: 0.938em; font-weight: 500; margin-top: 20px; line-height: 1.5em; text-align: center; }
.Request .btn { margin-top: 70px; display: flex; justify-content: space-between; }
.Request .btn a { background: var(--sub-font-color); display: flex; width: 100%; height: 60px; justify-content: center; align-items: center; color: #FFF; border-radius: 10px; }
.Request .btn a.w100 { width: 100%; }
.Request dl { display: flex; justify-content: flex-start; flex-wrap: wrap; margin-top: 85px; font-size: 1.125em; line-height: 1.3em; }
.Request dl dt { width: calc(7.5em + 50px); position: relative; padding: 40px calc(2em + 25px) 40px 25px; box-sizing: border-box; border-top: 1px solid #000; display: flex; align-items: flex-start; justify-content: center; flex-wrap: wrap; }
.Request dl dt::after { content: ""; padding: 40px 0; display: flex; align-items: flex-start; justify-content: center; width: 2em; position: absolute; right: 25px; top: 0; bottom: 0; margin: auto; font-size: 1.00rem; }
.Request dl dt.required::after { content: "必須"; color: var(--sub-font-color); }
.Request dl dt div { content: "必須"; color: var(--sub-font-color); display: inline-block; padding: 40px 0; display: flex; align-items: flex-start; justify-content: center; width: 2em; position: absolute; right: 25px; top: 0; bottom: 0; margin: auto; font-size: 1.00rem; }
.Request dl dd { width: calc(95% - calc(7.5em + 50px)); border-top: 1px solid #000; padding: 40px 25px; box-sizing: border-box; display: flex; justify-content: flex-start; align-items: center; flex-wrap: wrap; position: relative; }
.Request dl dd label { font-size: 1.250rem; }
.Request dl dd p { font-size: 0.875rem; text-align: right; margin-left: auto; }
.Request dl dd p.pink { color: var(--sub-font-color); position: absolute; bottom: 10px; right: 25px; } 
.Request dl dd span { font-size: 1.250rem; }
.Request .name1,.Request .kana,.Request .inquiry { display: block; width: 100%; }
.Request dl dd.wrap { flex-flow: column; justify-content: flex-start; align-items: flex-start; text-align: left; }
.Request dl dd.wrap .select { margin-top: 10px; }
.Request dl dd.wrap .flex { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; }
.Request dl dd.wrap .flex .select { margin-top: 0px; }
.Request dl dd.wrap .flex > div { display: flex; align-items: center; }
.Request dl dd.wrap .select + div { margin-top: 20px; }
.Request dl dd.wrap .flex .select + div { margin-top: 0; }

.Request textarea { background: #e6e6e6; border: none; width: 100%; padding: 10px; font-size: 1.250rem; box-sizing: border-box; }
.Request input[type="text"],.Request input[type="email"] { background: #e6e6e6; border: none; padding: 10px; font-size: 1.250rem; box-sizing: border-box; }
.Request input[type="checkbox"],.Request input[type="radio"] { display: none; }
.Request input[type="checkbox"] + span,.Request input[type="radio"] + span { position: relative; display: block; }
.Request input[type="checkbox"] + span::before,.Request input[type="radio"] + span::before { content: ""; display: inline-block; border: 1px solid #251e1c; width: 15px; height: 15px; box-sizing: border-box; background: #FFF; z-index: 1; vertical-align: 0.05em; margin-right: 5px; }
.Request input[type="checkbox"]:checked + span::after,.Request input[type="radio"]:checked + span::after { content: ""; display: inline-block; width: 12px; height: 9px; background: url(../images/ic_check.svg) no-repeat center; position: absolute; z-index: 3; left: 2px; top: 0; bottom: 0; margin: auto; }
.Request .select { overflow: hidden; text-align: center; position: relative; background: #e6e6e6; }
.Request .select select { cursor: pointer; text-overflow: ellipsis; border: none; outline: none; background: transparent; background-image: none; box-shadow: none; -webkit-appearance: none; appearance: none; padding: 8px 50px 8px 8px; box-sizing: border-box; font-size: 1.250rem; }
.Request .select select::-ms-expand { display: none; }
.Request .select::before { position: absolute; content: ""; display: block; top: 0; bottom: 0; margin: auto; right: 13px; width: 12px; height: 22px; background: url(../images/ic_arrow.svg) no-repeat; pointer-events: none; z-index: 2; transform: rotate(90deg); background-size: 100% auto; }
.Request .select::after { position: absolute; background: #b4b4b4; top: 0; bottom: 0; right: 0; width: 38px; height: 100%; padding: 0; content: ""; display: block; pointer-events: none; }

.highschool > div,.address > div,.other_box { width: 100%; display: flex; align-items: center; font-size: 1.250rem; margin-left: 30px; }
.other_box { width: 100%; display: flex; align-items: center; margin-left: 0; }
.highschool span.w4 { display: inline-block; width: 4em; }
.highschool > div input,.Request .highschool .select { width: calc(100% - 4em); }
.Request .highschool .select select,.Request .address > div .select select { width: 100%; }
.highschool > div + div,.address > div + div,.pref + div { margin-top: 15px!important; }
.highschool > div:nth-child(2) { margin-top: 0; }
.address .w7 { display: inline-block; width: 7.5em; }
.Request .w5 { display: inline-block; width: 5em; }
.address .addr2,.address .addr3,.Request .address .select,.address .hogo_addr2,.address .hogo_addr3 { width: calc(100% - 7.5em); }
.Request .school,.Request .school_gakka,.Request .other,.highschool .school_req { width: calc(100% - 4em);}
.address .addr2 input,.address .addr3 input,.address .hogo_addr2 input,.address .hogo_addr3 input,.highschool .school input,.highschool .school_gakka input,.Request .other input,.highschool .school_req input { width: 100%; }
.Request .address .select { width: 7.5em; }
.Request .w100 { width: 100%; }
.Request .question,.Request .pr1,.Request .pr2,.hogo_name,.hogo_kana { width: 100%; display: block; }
.Request .birthday { /*font-size: 1.500rem;*/ letter-spacing: -0.1em; }
.Request .birthday + dd {display: flex; }
.Request .birthday + dd div,.Request .graduation_date + dd div { margin-left: 5px; }

.Request form .btn { display: flex; justify-content: space-around; flex-wrap: wrap; }
.Request form .btn input { background: var(--sub-font-color); display: flex; width: 47%; height: 60px; justify-content: center; align-items: center; color: #FFF; border-radius: 10px; border: none; font-size: initial; cursor: pointer; }
.Request form .btn br { display: none; }
.Request form .btn span { display: block; width: 100%; background-repeat: no-repeat; background-position: center; margin-top: 20px; }

.wpcf7 span.wpcf7-not-valid-tip { display: none; }
.wpcf7 .wpcf7-not-valid { background: #ffeaf0!important; }

.wpcf7-response-output { padding: 20px!important; border-radius: 4px; text-align: center; font-size: 1.250rem; color: #eb6d94!important; background-color: #ffeaf0!important; border: 1px solid #ffeaf0!important; }

.wpcf7-response-output br,.wpcf7-response-output a,.wpcf7-response-output span,.wpcf7-response-output i { display: none; }


/* ---------------------------------------------------
Privacy
-------------------------------------------------- */
.Privacy dl { margin-top: -30px; }
.Privacy dl dt { background: var(--sub-font-color); color: #FFF; font-size: 1.375rem; margin-top: 90px; padding: 10px 20px; font-weight: 500; line-height: 1.3em; }
.Privacy dl dd { margin: 20px 20px 0 20px; font-size: 0.938em; line-height: 2.00em; }
.Privacy dl dd ul { margin-left: 1em; }
.Privacy dl dd ul li { text-indent: -1em; margin-left: 1em; margin-top: 20px; }
.Privacy dl dd ul li + li { margin-top: 10px; }
.Privacy dl dd ul li::before,.Privacy dl dd p::before { content: "●"; }
.Privacy dl dd p { text-indent: -1em; margin-left: 2em; margin-top: 20px; display: block; }
.Privacy dl dd svg { fill: #000; width: 15px; height: auto; }
.Privacy .inner > p { font-size: 0.938em; font-weight: 400; display: table; margin-left: auto; margin-top: 60px; line-height: 1.8em; }
.Privacy .inner > p span { display: inline-block; margin-left: 1em; }

/* ---------------------------------------------------
404
-------------------------------------------------- */
.error { text-align: center; }
.error h1 { font-family: din-condensed, sans-serif; font-size: 5em; }
.error h1 + p { margin-top: 20px; }
.error p + p { margin-top: 30px; line-height: 1.8em; }
.error p + p br.sp { display: none; }

.error .btn { border-radius: 10px; margin: 60px auto 0 auto; }
.error .btn a { display: block; max-width: 400px; width: 90%; background: var(--main-bg-color); display: block; height: 80px; color: #FFF; font-size: 1.500em; display: flex; align-items: center; justify-content: center; font-weight: 600; margin: 0 auto; }


@media screen and (max-width:960px) {
	#Contents { margin-top: 50px; }
	
	.News .ttl,.Blog .ttl,.oc .ttl { height: 108px; padding-left: 5%; align-items: flex-start; padding-top: 15px; box-sizing: border-box; }
	.News .ttl::after,.Blog .ttl::after,.oc .ttl::after { font-size: 4.500rem; padding-right: 5%; line-height: 0.66; }
	.News .ttl h1,.Blog .ttl h1,.oc .ttl h1 { font-size: 0.875rem; }
	.News .ttl h1 strong,.Blog .ttl h1 strong,.oc .ttl h1 strong { font-size: 1.438rem; display: inline-block; margin-bottom: 10px; }
	
	.wp-pagenavi,.pagenavi { font-size: 0.938rem; margin-top: 60px; }
	.wp-pagenavi .current { width: 40px; height: 40px; }
	.wp-pagenavi .page,.wp-pagenavi .list,.wp-pagenavi .extend { width: 40px; height: 40px; }
	.wp-pagenavi .nextpostslink,.wp-pagenavi .previouspostslink { width: 40px; height: 40px; }
	
/* ---------------------------------------------------
News
-------------------------------------------------- */
	#News dl { font-size: 0.938rem; }
	
	#News article { margin-top: 70px; }
	#News article p { font-size: 0.938rem; }
	#News article .date { font-size: 0.938rem; }
	#News article h2 { font-size: 1.250rem; padding-top: 10px; }
	
/* ---------------------------------------------------
Blog
-------------------------------------------------- */
	.Blog .List { justify-content: space-between; }
	.Blog .List .column { width: 47%; margin-left: 0; }
	
	.Blog #Nav { max-width: 600px; width: 100%; margin: 70px auto 0 auto; }
	.Blog #Nav > div { width: 48%; }
	.Blog hr { margin: 50px auto 0 auto; }
	
	#Blog article p { font-size: 0.938rem; }
	#Blog article .date { font-size: 0.938rem; }
	#Blog article .date span { font-size: 0.750rem; }
	#Blog article h2 { font-size: 1.250rem; padding-top: 10px; }
	

/* ---------------------------------------------------
Open Cumpus
-------------------------------------------------- */
	.Opencumpus #Mainvisual { width: 100%; }

	.Opencumpus #Lead .btn a { height: 150px; font-size: 0.938rem; }
	.Opencumpus #Lead .btn a strong { font-size: 1.688rem; }
	.Opencumpus #Lead .btn a strong::before { width: 46%; }
	
	.Opencumpus #List h2 { width: 35%; margin-left: 0; }
	.Opencumpus #List .btn { width: 60%; }
	.Opencumpus #List .date { font-size: clamp(2.25rem, -0.25rem + 6.67vw, 3.75rem); }
	.Opencumpus #List .date li span.week img { margin: 4px 0 0 4px; }
	.Opencumpus #List p { font-size: 1.250rem; }
	
	.Opencumpus #Schedule .date { width: 130px; font-size: 2.813rem; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; letter-spacing: -0.05em; }
	.Opencumpus #Schedule .date span { display: block; width: 100%; font-size: 1.250rem; border-top: 1px solid #FFF; padding-top: 10px; letter-spacing: 0; }
	.Opencumpus #Schedule .txt .ttl { font-size: 1.250rem; }
	.Opencumpus #Schedule .txt { width: calc(100% - 305px); padding: 10px; }
	.Opencumpus #Schedule .img { width: 135px; }
	
/* ---------------------------------------------------
Qualification
-------------------------------------------------- */
	.Qualification #Mainvisual h1 { height: 150px; }
	.Qualification .flex .column .txt { padding: 20px; }
	#Pass h2,#License h2,#Employment h2 , #Supporters_salon h2 , #Internship h2 { font-size: 1.375rem; }
	#License dl { padding: 20px 0; line-height: 2.00em; }
	#License dl dt { width: 250px; }
	#License dl dd { width: calc(100% - 250px); padding: 0 20px; font-size: 0.875rem; }

	#Pass p,#License h2 + p { font-size: 0.875rem; }
	.Qualification .flex .column p { font-size: 0.875rem; }
	#Employment p { font-size: 0.875rem; }
  .Society #Flow .flex_ttl { width: 100%; margin-right: 0; }
  .Society #Flow p.txt { width: 100%; }
  .Society #Flow .step_num { width: 45px; height: 45px; font-size: 10px; }
  .Society #Flow h3.flow_ttl { padding: 10px 15px; margin: 30px 0 10px; }
 

/* ---------------------------------------------------
Society
-------------------------------------------------- */
  .Society #Mainvisual h1 { height: 150px; }
/*	.Society .flex .column .txt { padding: 20px; }*/
  .Society .flex { display: block; }
  .Society .flex .column { width: 100%; }
  .Society .flex .column:not(:last-child) { margin-bottom: 30px; }
  .Society section { margin-bottom: 60px; }
  .Society section:last-of-type { margin-bottom: 0; }
  .Society #Flow .wrapper { display: block; }
  .Society #Kyuhukin .link_btn a { margin-top: 20px; }
  .Society #Taisyo .hayami h3.tenchi_line { margin-bottom: 30px; }
  
/* ---------------------------------------------------
Recruit
-------------------------------------------------- */
  .Recruit #Mainvisual h1 { height: 150px; }
  .Recruit section dl { line-height: 1.8em; }
  .Recruit section dt { width: 100%; padding-bottom: 0; border-bottom: none; }
  .Recruit section dd { width: 100%; padding-top: 0;  }
  .Recruit h3.obi { margin-bottom: 0; }
  .Recruit .anchor_link ul li { font-size: 16px; }

  /* ---------------------------------------------------
Offer
-------------------------------------------------- */
	.Offer p { font-size: 0.875rem; text-align: left; }
	.Offer h1 + p > br { display: none; }
	
	.contact { margin: 55px auto 0 auto; padding: 40px 20px; }
	.contact dt { font-size: 1.125em; }
	.contact dd { width: auto; margin-left: 20px; }
	.contact dd span { font-size: 0.875rem; }
	.contact dd strong { font-size: 3.313rem; margin-top: 10px; }
	
	#Protector .flex .txt { margin: 50px 0 25px 0; padding-bottom: 20px; }
	#Protector .flex .txt h2 { padding: 0 15px; font-size: 1.250rem; height: 80px; position: relative; }
	#Protector .flex .txt h2::after { font-size: 8.438rem; position: absolute; right: 0; z-index: -1; }
	#Protector .flex .txt p { margin-top: 10px; font-size: 0.875rem; }
	
	#Teacher .flex .column h2 { font-size: 1.000rem; display: flex; justify-content: center; align-items: center; }
	#Teacher .flex .column p { font-size: 0.875rem; margin-top: 20px; }
	
	#Graduate h2 { margin-top: 80px; }
	#Graduate table { font-size: 0.875rem; }

/* ---------------------------------------------------
Request
-------------------------------------------------- */
	.Request h1 + p { font-size: 0.875rem; }
	.Request h1 + p br { display: none; }
	.Request dl dd p.pink { color: var(--sub-font-color); position: static; margin-bottom: -30px; } 
	.Request .btn a { color: #fff; }
	.Request dl { font-size: 1.125rem; }
	.Request dl dt { width: 9em; padding: 40px 2em 40px 0; }
	.Request dl dt::after { right: 10px; font-size: 0.938rem; }
	.Request dl dd { width: calc(100% - 9em); padding: 40px 15px; }
	.Request dl dd label { font-size: 1.125rem; }
	.Request dl dd span { font-size: 1.125rem; }
	.Request input[type="text"],.Request input[type="email"],.Request textarea,.Request .select select { font-size: 1.125rem }
	.address > div,.highschool > div { font-size: 1.125rem; margin-left: 0; }
	
	.Request .btn input { font-size: 1.375rem; }
	
	
/* ---------------------------------------------------
Privacy
-------------------------------------------------- */
	.Privacy dl dt { font-size: 1.000rem; margin-top: 50px; padding: 10px 20px; }
	.Privacy dl dd { margin: 20px 0 0 0; font-size: 0.938rem; }
	.Privacy dl dd svg { width: 12px; }
	.Privacy .inner > p { font-size: 0.875rem; margin-top: 40px; }

}


@media screen and (max-width:600px) {
	img.sp,br.br { display: block; }
	img.pc { display: none; }
	.topicpath { display: none; }
	
	.wp-pagenavi,.pagenavi { width: calc(100% - 30px); margin: 60px auto 0 auto; }
	
/* ---------------------------------------------------
News
-------------------------------------------------- */
	#News dl { border: none; }
	#News dl dt { width: 100%; text-align: left; border-bottom: none; padding: 0 10px; color: #9e9e9f; }
	#News dl dt::after { display: none; }
	#News dl dd { width: 100%; padding: 0 10px 10px 10px; font-size: 1.250rem; margin-top: 10px; }
	#News dl dd + dt { margin-top: 30px; }
	
	#News article p { margin: 20px 15px 0 15px; line-height: 1.5em; }
	#News article .img { padding-top: 0; position: static; }
	#News article .img img { position: static; transform: translate(0, 0); }
	#News article .img + p { margin-top: 30px; }
	
/* ---------------------------------------------------
Blog
-------------------------------------------------- */
	.Blog .List { justify-content: center; margin-top: 20px; }
	.Blog .List .column { width: 100%; margin-top: 65px; margin-left: 0; border-bottom: 1px solid #666; padding-bottom: 40px; margin-top: 35px; }
	
	.Blog #Nav { max-width: 600px; flex-wrap: wrap; width: 100%; }
	.Blog #Nav > div { max-width: 300px; width: 100%; margin: 0 auto; }
	.Blog #Nav > div + div { margin-top: 30px; }
	
	.Blog .blocks-gallery-item { width: 100%!important; margin-left: 0!important; margin-right: 0!important; }
	
/* ---------------------------------------------------
Open Cumpus
-------------------------------------------------- */
	.Opencumpus h1 { max-width: 330px; width: 90%; margin: 90px auto 0 auto; }
	.Opencumpus h1 span { width: 25%; }
	.Opencumpus #Mainvisual { aspect-ratio: 600 / 712; width: 90%; margin: 25px auto 0 auto; background-image: url(../../images/opencampus/main_img_sp.jpg); }
	.Opencumpus #Mainvisual::after { max-width: 150px; width: 40%; right: 0; top: 95%; z-index: 1; }
	.Opencumpus #Mainvisual p { font-size: 1.000rem; top: -70px; right: 9%; width: 28px; }

	.Opencumpus #Lead p { width: 90%; margin: 20px auto 0 auto; padding: 0; }
	.Opencumpus #Lead p.ttl { line-height: 1.500em; margin-top: 60px; }
	.Opencumpus #Lead p.ttl + p { font-size: 0.875rem; }
	
	.Opencumpus #Lead .bg { margin-top: 170px; padding-bottom: 40%; }
	.Opencumpus #Lead .bg .img { margin: -140px auto 0 auto; width: 100%; }
	.Opencumpus #Lead .btn { margin-top: 50px; }
	.Opencumpus #Lead .btn a { height: auto; background: #FFF; font-size: 1.125rem; flex-wrap: wrap; padding: 25px; }
	.Opencumpus #Lead .btn a strong { display: block; width: calc(100% + 30px); margin-top: 0; font-size: 1.500rem; border-top: 1px solid #000; margin-top: 15px; margin-left: -15px; padding: 10px 15px 0 15px; box-sizing: border-box; }
	.Opencumpus #Lead .btn a strong::before { display: none; }
	.Opencumpus #Lead .btn a::after { content: ""; display: block; width: calc(100% + 50px); margin: 20px 0 -25px -25px; padding-top: 50%; background: url(../../images/opencampus/img_schedule02.jpg); background-size: 100% auto; }
	
	.Opencumpus #List .inner { margin-top: -30%; }
	.Opencumpus #List h2 { max-width: 255px; width: 100%; text-align: center; margin-left: auto; margin-right: auto; }
	.Opencumpus #List .btn { width: 100%; margin-top: 20px; flex-wrap: wrap; justify-content: space-around; }
	.Opencumpus #List .btn li { width: 275px; height: 80px; margin: 0 auto; }
	.Opencumpus #List .date { justify-content: space-between; font-size: clamp(1.875rem, 1.161rem + 3.57vw, 2.5rem); }
	.Opencumpus #List .date:after,.Opencumpus #List .date::before { content: ""; width: 22%; order: 10000; }
	.Opencumpus #List .date li { margin: 40px 0 0; width: 22%; }
	.Opencumpus #List .list li { text-indent: -1em; margin-left: 1em; }
	.Opencumpus #List p { line-height: 1.5em; }

	.Opencumpus #Schedule { background: none; }
	.Opencumpus h2 { max-width: 410px; width: 90%; }
	.Opencumpus #Schedule h2 { max-width: 410px; width: 90%; font-size: 3.500rem; }
	.Opencumpus #Schedule h2::before { width: 100%; margin: 0 auto; }	
	.Opencumpus #Schedule .box::after { content: ""; display: block; width: calc(100% + 12%); height: 45px; background: #fae1e5; position: absolute; top: -45px; left: -6%; z-index: -1; }
	.Opencumpus #Schedule .box { background: #FFF; padding: 30px 0; flex-wrap: wrap; }
	.Opencumpus #Schedule .date { font-size: 3.438rem; width: 200px; height: 200px; margin: 0 auto; order: 1; }
	.Opencumpus #Schedule .date span { font-size: 1.500rem; }
	.Opencumpus #Schedule .txt { width: 100%; order: 2; margin-top: 30px; }
	.Opencumpus #Schedule .txt .ttl,.Opencumpus #Schedule .txt .time { text-align: center; }
	.Opencumpus #Schedule .img img { position: static; transform: translate(0, 0); width: 100%; height: auto; }
	.Opencumpus #Schedule .img { width: 100%; order: 3; margin-top: 30px; }
	.Opencumpus #Schedule .btn { width: 100%; order: 4; height: 75px; display: flex; }
	.Opencumpus #Schedule .btn a { width: 50%; height: auto; font-size: 0.938em; position: relative; }
	
/* ---------------------------------------------------
Qualification
-------------------------------------------------- */
/*	#Pass .img { margin-top: 35px; background: var(--main-bg-color); width: calc(100% + 12%); margin-left: -6%; padding: 8% 0; }*/
	#Pass .img img { margin: 0 auto; max-width: inherit; width:100%; }
	#Pass .img::before { display: none; }
	
	#License h2,#Employment h2,#Supporters_salon h2 , #Internship h2 { margin-top: 60px; }
  #Supporters_salon .supporters_salon_img03 { margin-bottom: 30px; }
  #Supporters_salon .flex .box { width: 100%; margin-bottom: 25px; }
  #Supporters_salon .flex .box h3 { font-size: 18px; margin-bottom: 0; }
  #Supporters_salon .flex .box p { font-size: 0.875rem; margin-top: 10px;}
  #Supporters_salon .supporters_salon_img04 { width: 70%; margin: 0 auto; }
  #Internship .internship_box { width: 48%; margin-bottom: 20px; }
  #Internship .internship_flex { flex-wrap: wrap; }
  #Internship .internship_box p.chusyaku { margin-top: 10px; line-height: 1.3; }
  
	.Qualification .flex .column { width: 100%; }
	.Qualification .flex .column:first-child { margin-top: 20px; }
	.Qualification .flex .column + .column { margin-top: 50px!important; }
	.Qualification .flex .column > .img:first-child { margin-top: -50px; }

	#License dl { display: block; padding: 20px; margin-top: 50px; }
	#License dl dt { width: 100%; display: block; border-right: none; text-align: left; }
	#License dl dd { width: 100%; padding: 0; margin-top: 10px; line-height: 2.00em; }
  
/* ---------------------------------------------------
Society
-------------------------------------------------- */
  .Society #Flow .flow_box p.txt { width: 100%; }
  
  
/* ---------------------------------------------------
Offer
-------------------------------------------------- */
	.Offer h1 + p { text-align: left; }
	
	#Protector .flex .img { display: none; }
	#Protector .flex .txt { width: 100%; margin: 75px 0 0 0; }
	#Protector .flex .txt::before { content: ""; display: block; width: 130px; height: 7px; background: var(--sub-font-color); margin: auto; }
	#Protector .flex .txt h2 { border-left: none; padding: 0; display: block; height: auto; text-align: center; margin-top: 40px; }
	#Protector .flex .txt h2::before { counter-increment: number 1; content: "0"counter(number); font-family: var(--sub-font); font-style: normal; font-weight: 300; font-size: 7.688rem; color: #e5e6e6; line-height: 0.8em; display: block; text-align: center; margin-bottom: -25px; }
	#Protector .flex .txt h2::after { display: none; }
	#Protector .flex .txt p { padding: 0; margin-top: 20px; }
	#Protector .flex .txt .img { display: block; margin-top: 30px; }
	
	.contact { width: calc(100% + 12%); margin-left: -6%; padding: 30px 30px 40px 30px; align-items: center; }
	.contact dt { display: none; }
	.contact dd { width: 100%; padding: 0; line-height: 1.5em; font-size: 0.813rem; }
	.contact dd br { display: none; }
	.contact dd span { display: block; font-size: 1.00rem; margin: 0; }
	.contact dd strong { font-size: 2.688rem; display: block; margin-top: 20px; }
	
	#Teacher .flex .column { width: 100%; margin-top: 35px; }
	
	#Teacher,#Company,#Graduate { padding-top: 100px; }
	#Company .inner { display: flex; flex-direction: column; }
	#Company .inner h1 { order: 1; }
	#Company .inner p { order: 2; }
	#Company .btn { margin: 40px auto 0 auto; order: 3; width: 100%; }
	#Company dl { order: 4; }
	
	#Graduate h2 { text-align: center; line-height: 1.3em; margin-top: 50px; }
	#Graduate table { margin-top: 30px; display: none;  }
	#Graduate p.sp { display: block; text-align: center; margin-top: 30px; }
	#Graduate p.sp br { display: block; }
	#Graduate p.sp + p { border: 1px solid #000; padding: 15px; text-align: center; }
	

/* ---------------------------------------------------
Request
-------------------------------------------------- */
	.Request h1 + p { text-align: left; }
	.Request .btn { margin-top: 40px; flex-wrap: wrap; }
	.Request .btn a { width: 100%; height: 80px; }
	.Request .btn a + a { margin-top: 20px; }
	
	.Request dl dd p.pink { margin-bottom: -10px; } 
	
	.Request dl { margin-top: 45px; }
	.Request dl dt { width: 100%; padding: 10px 0 0 0; }
	.Request dl dt::after { padding: 10px 0 0 0; font-size: 0.875rem; }
	.Request dl dd { width: 100%; margin-top: 10px; padding: 20px 0; font-size: 1.00rem }
	.Request dl dd p { margin-top: 5px; }
	.highschool > div,.address > div { flex-wrap: wrap; }
	.address .w7,.highschool .w4 { display: block; width: 100%; }
	.address .addr2,.address .addr3,.address .hogo_addr2,.address .hogo_addr3,.Request .address .select,.highschool .school,.highschool .school_gakka,.Request .highschool .select,.gakka { display: block; width: 100%; margin-top: 5px; }
	.Request .tel,.Request .mobile,.Request .your-mail,.Request .acceptance,.Request .gaika,.Request .katei,.Request .other { width: 100%; }
	.address .addr2 input,.address .addr3 input,.address .hogo_addr2 input,.address .hogo_addr3 input,.Request .tel input,.Request .your-mail input,.gakka input,.mobile input { width: 100%; }
	.Request .acceptance .wpcf7-list-item { width: 100%; }
	.consent br,.birthday br {display: none; }
	.kind,.gender { width: 100%; }
	.wpcf7-checkbox,.wpcf7-radio { display: flex; }
	.wpcf7-list-item { width: 45%; }
	.Request dl dd label,.Request dl dd span,.Request .select select { font-size: 0.938rem; }
	
	.Request form .btn input { font-size: 1.1250rem; height: 60px; letter-spacing: 0; }
	.wpcf7-response-output { line-height: 1.5em; font-size: 1.125rem; }
	.birth_year,.graduation_year,.campus_year { width: 4em; display: block; }
	.birth_year input,.graduation_year input,.campus_year input { width: 100%; }
	.Request .select { font-size: 1.00rem; }
	.Request .select::before { width: 6px; height: 11px; }
	.Request .select::after { width: 30px; height: 100%; }
	.graduation_date + dd .graduation_date { border: 1px solid #000; }
	.Request .birthday { font-size: 1.00rem; letter-spacing: 0em; }
	
	.Request .wpcf7-checkbox .wpcf7-list-item,.Request .wpcf7-acceptance .wpcf7-list-item { width: 100%; }
	.Request dl dt { padding-left: 2.5em; padding-right: 2.5em; }
	
/* ---------------------------------------------------
404
-------------------------------------------------- */
	.error h1 { font-size: 3em; margin-top: 50px; }
	.error h1 + p { font-size: 0.875rem; }
	.error p + p { font-size: 0.875rem; }
	.error p + p br.sp { display: block; }

	.error .btn a { height: 60px; font-size: 1.250rem; }
}

@media screen and (max-width:414px) {
.oc .pagenavi { flex-wrap: wrap; }
.oc .app { width: 100%; }
.oc .top { width: 100%; border-left: 1px solid #eb6d94; }
}
