@charset "UTF-8";
*,
*:before,*:after{
margin:0;
padding:0;
box-sizing:border-box;
font-feature-settings: "palt";
}
:where([hidden]:not([hidden=until-found])){
display:none!important;
}
:where(html){
-webkit-text-size-adjust:none;
color-scheme:dark light;
}
@supports not (min-block-size: 100dvb){
:where(html){block-size:100%
}
}@media (prefers-reduced-motion: no-preference){
:where(html:focus-within){
scroll-behavior:smooth
}
}:where(body){
block-size:100%;
block-size:100dvb;
line-height:1.5;
font-family:system-ui,sans-serif;
-webkit-font-smoothing:antialiased;
}:where(input,button,textarea,select){
font:inherit;
color:inherit;
}:where(textarea){
resize:vertical;
resize:block;
}:where(button,label,select,summary,[role=button],[role=option]){
cursor:pointer;
}:where(:disabled){
cursor:not-allowed;
}:where(label:has(>input:disabled),label:has(+input:disabled)){
cursor:not-allowed;
}:where(button){
border-style:solid;
}:where(a){
text-underline-offset:.2ex;
}:where(ul,ol){
list-style:none
}:where(img,svg,video,canvas,audio,iframe,embed,object){
display:block
}:where(img,picture,svg){
max-inline-size:100%;
block-size:auto;
}:where(p,h1,h2,h3,h4,h5,h6){
overflow-wrap:break-word;
}:where(h1,h2,h3){
line-height:calc(1em + .5rem)
}:where(hr){
border:none;
border-block-start:1px solid;
color:inherit;
block-size:0;
overflow:visible;
}:where(:focus-visible){
outline:2px solid var(--focus-color, Highlight);
outline-offset:2px;
}:where(.visually-hidden:not(:focus,:active,:focus-within,.not-visually-hidden)){
clip-path:inset(50%)!important;
height:1px!important;
width:1px!important;
overflow:hidden!important;
position:absolute!important;
white-space:nowrap!important;
border:0!important;
}

._sp{
display:none!important;
}@media screen and (max-width: 787px){
._sp{display:block!important;
}}
._sp_df{
display:none!important;
}@media screen and (max-width: 787px){
._sp_df{
display:flex!important;
}}
._pc{
display:block!important;
}@media screen and (max-width: 787px){
._pc{display:none!important;
}}
._pc_df{
display:flex!important;
}@media screen and (max-width: 787px){
._pc_df{display:none!important;
}}
._tab{
display:none!important;
}@media screen and (max-width: 1000px){
._tab{
display:block!important;
}}
._tab_pc{
display:block!important;
}@media screen and (max-width: 1000px){
._tab_pc{
display:none!important;
}}
html,body{
height:100vh;
height:calc(var(--vh, 1vh) * 100);
width:100%;
font-feature-settings: "palt";
}
body{
width:100%;
background:#EDF6F9;
font-size:15px;
line-height:1.8;
color:#4C4948;
font-family:Zen Kaku Gothic New,sans-serif;
}@media screen and (max-width: 787px){
body{
font-size:17px;
}
}
body a{
text-decoration:none;
color:#4C4948;
}

.grecaptcha-badge{
display:none;
}
.lowkeyvisual{
padding:200px 0 140px;
margin:0 auto;
position:relative;
}@media screen and (max-width: 787px){
.lowkeyvisual{
width:100%;
padding:120px 0 50px;
}
}
.lowkeyvisual-title{
width:90%;
margin:0 auto;
border-bottom:1px solid #c5c5c5;
padding:0 3%;
}
.lowkeyvisual-title .jp{
font-size:1.2vw;
font-weight:400;
display:inline-block;
padding:0 10px;
margin-left:10px;
margin-bottom:30px;
line-height:1.4;
}@media screen and (max-width: 787px){
.lowkeyvisual-title .jp{
font-size:15px;
margin-left:5px;
margin-bottom:15px;
}
}
.lowkeyvisual-title .en{
font-size:12vw;
font-family:Manrope,sans-serif;
font-weight:700;
letter-spacing:-.2rem;
display:block;
line-height:.77;
}@media screen and (max-width: 787px){
.lowkeyvisual-title .en{
font-size:16vw;
}
}
.lowcontents{
width:85%;
display:flex;
align-items:flex-start;
margin:0 auto 140px
}@media screen and (max-width: 787px){
.lowcontents{
width:calc(100% - 60px);
flex-wrap:wrap;
margin:0 auto 60px;
}
}
.lowcontents-nav{
position:sticky;
top:120px;
left:0;
}@media screen and (max-width: 787px){
.lowcontents-nav{
position:static;margin-bottom:50px;
}}
.lowcontents-nav li:not(:last-child){
margin-bottom:10px;
}@media screen and (max-width: 787px){.lowcontents-nav li:not(:last-child){
margin-bottom:5px;
}}
.lowcontents-main{
width:calc(100% - 300px);
margin:0 0 0 auto;
}@media screen and (max-width: 1000px){
.lowcontents-main{
width:calc(100% - 200px)
}}@media screen and (max-width: 787px){
.lowcontents-main{
width:100%;
}}
.lowcontents-sectitle{
margin-bottom:60px;
}@media screen and (max-width: 787px){
.lowcontents-sectitle{
margin-bottom:40px;
}}
.lowcontents-sectitle span{
display:inline-block;
}
.lowcontents-sectitle span:first-child{
text-shadow:2px 2px 0px rgb(0,248,255);
font-size:47px;
font-family:Manrope,sans-serif;
line-height:1;
font-weight:200;
margin-right:15px;
}@media screen and (max-width: 787px){
.lowcontents-sectitle span:first-child{
display:block;
margin-bottom:15px;
font-size:32px;
}}
.lowcontents-sectitle span:last-child{
font-size:17px;
background:#00f8ff;
font-weight:400;
line-height:1;
padding:3px 5px
}@media screen and (max-width: 787px){
.lowcontents-sectitle span:last-child{
font-size:14px;
}}
button{
margin:0;
padding:0;
outline:0;
border:0;
border-radius:0;
background:transparent;
color:inherit;
vertical-align:middle;
text-align:inherit;
font:inherit;
-webkit-appearance:none;
-moz-appearance:none;
appearance:none;
}
.btn{
position:fixed;
top:10px;
right:10px;
z-index:10;
width:65px;
height:65px;
background-image: url("../2025image/base/menu_area.svg");
}
.btn-line{
display:block;
position:relative;
width:45%;
height:2px;
background-color:hsla(0,0%,100%,0.00);
transition:.2s;
left:50%;
transform:translate(-50%)
}
.menu_icon{
display:block;
position:relative;
width:60%;
height:auto;
top: 14px;
left:50%;
transform:translate(-50%)
}
.btn-line:before,
.btn-line:after{
content:"";
position:absolute;
width:100%;
height:100%;
background-color:#ffffff;
transition:.5s;
}
.btn-line:before{
transform:translateY(0px);

}
.btn-line:after{
transform:translateY(8px);
}
.btn-line.open{
background-color:transparent;
}
.btn-line.open:before,
.btn-line.open:after{
content:"";
transition:.2s
}
.btn-line.open:before{
transform:rotate(45deg);
}
.btn-line.open:after{
transform:rotate(-45deg);
}@media screen and (max-width: 1000px){
.menu{
display:flex;
align-items:center;
justify-content:center;
flex-wrap:wrap;
align-content:center;
position:absolute;
top:-5px;
right:-75%;
left:auto!important;
width:70%;
height:fit-content;
color:#efefef;
background:rgba(255,255,255,.90);
transition:.5s;
padding:70px 0 30px;
border-radius:10px;
}
.menu li{
width:80%;
display:inline-block!important
}
.menu li{
margin-bottom:10px;
}
.menu li a{
border:1px solid #1486AD;
background-color: #EDF6F9;
}

.menu a{
display:flex;
justify-content:center;
padding:12px 20px;
border-radius:30px;
}
.menu a span{
margin-left:5px;
}
.menu-list{
display:flex;
align-items:center;
justify-content:center;
width:100%;
}
.menu-list:hover{
background-color:#ffffff;
cursor:pointer;
transition:.3s;
border-radius:30px;
}
.menu.open{
position:absolute;
right:-5px;
}
}@media screen and (min-width: 1000px){
.btn{
display:none;
}
.menu{
display:flex;
flex-direction:row;
position:fixed;
top:18px;
left:50%;
transform:translate(-25%);
width: 75%;
/* width:fit-content;
height:fit-content; */
}
.menu-list a{
background-color:#ffffffbf;
border:1px solid #D4D4D4;
display:flex;
padding:10px 35px;
font-size:15px;
}
.menu-list a span{
margin-right:5px;
}
.menu-list:first-child a{
border-radius:30px 0 0 30px;
}
.menu-list:last-child a{
border-radius:0 30px 30px 0;
}
}@media screen and (max-width: 1200px){
.menu{
left:54%;
}
.menu-list a{
padding:10px 18px;
font-size:14px;
}
}
.header{
position:fixed;
top:14px;
left:14px;
z-index:999;
width:calc(100% - 28px);
display:flex;
justify-content:space-between;
align-items:center;
}
.header-logo{
background:#fff;
box-shadow: 0 5px 15px 0 rgba(0, 0, 0, .2);
display:inline-block;
width:380px;
border-radius:50px;
padding:8px 20px 8px 11px;
}@media screen and (max-width: 787px){
.header-logo{
width:250px;
}
}
.header-logo img{
width:100%;
}
.header-cta{
display:flex;
justify-content:center;
align-items:center;
padding:14px 30px;
border-radius:50px;
}@media screen and (max-width: 1000px){
.header-cta{
display:none;
}
}
.header-cta .otherlink{
margin-left:5px;
}


/* ================================================================= */
/* 追従する申し込みボタン */
/* ================================================================= */
#entry {
  width: 290px;
  position: fixed;
  z-index: 15;
  right: 0.5rem;
  bottom: 0.5rem;
  color: #fff;
  text-align: left;
  overflow: hidden;
  opacity: 0;
  transform: translateX(100%);
  transition: all 1s ease;
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .4);
  background-color: #FFEB00;
  border-radius:50px;
}
#entry.is-in-r {
  opacity: 1;
  transform: translateX(-1%);
  transition: all 1s 1s ease;
}@media screen and (max-width: 787px) {
#entry {
width: 48%;
  position: fixed;
  z-index: 15;
  left: 0.5rem;
  bottom: 0.5rem;
transform: translateX(200%);
}
#entry.is-in-r {
  opacity: 1;
  transform: translateX(101%);
  transition: all 1s 1s ease;
}
}

#bus {
  width: 290px;
  position: fixed;
  z-index: 12;
  left: 0.5rem;
  bottom: 0.5rem;
  color: #fff;
  text-align: left;
  overflow: hidden;
  opacity: 0;
  transform: translateX(-105%);
  transition: all 1s ease;
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .4);
  background-color: #00A5A8;
  border-radius:50px;
}
#bus.is-in {
  opacity: 1;
  transform: translateX(0%);
  transition: all 1s 1s ease;
}@media screen and (max-width: 787px) {
#bus {
width: 48%;
}
#bus.is-in {
  transform: translateX(-1%);
}
}

/* ================================================================= */
/* TOP　キービジュアル　フェードイン */
/* ================================================================= */
.keyvisual{
width:100%;
height:100vh;
position:relative;
overflow:hidden;
top:-10px;
}@media screen and (max-width: 787px){
.keyvisual{
height:100vh;
top:-7px;
margin-bottom: -35%;
}
}
.keyvisual-maintext{
position:absolute;
top:30%;
left:35%;
z-index:2
}@media screen and (max-width: 787px){
.keyvisual-maintext{
top:35%;
left:5%;
}
}
.keyvisual-maintext img{
display:inline-block;
width: 620px;
height: auto;
margin:0 0 2% 1%;
}
.keyvisual-maintext .shadow {
-webkit-filter: drop-shadow(0px 4px 10px rgba(20, 134, 173, 0.45)); 
filter: drop-shadow(0px 4px 10px #1486AD); 
}@media screen and (max-width: 787px){
.keyvisual-maintext img{
display:inline-block;
width: 80%;
height: auto;
margin:0 auto;
text-align: center;
}
}
.keyvisual-bgimg{
width:100%;
height:100vh;
}
.keyvisual-bgimg img{
width:100%;
height:100%;
object-fit:cover
}
.keyvisual-imgbox{
height:100%;
display:grid;
grid-template:calc(25% - 14px) 40%/1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
grid-gap:10px;
padding:10px 0px;
}@media screen and (max-width: 787px){
.keyvisual-imgbox{
grid-template:calc(20% - 30px) 25% 18% 10%/1fr 1fr 1fr 1fr 1fr 1fr;
grid-gap:5px;
padding:5px 0px;
}
}
/*============================== kv-section-1 =============*/
.keyvisual-imgbox .kv-section-1{
grid-row:1/3;
grid-column:1/10;
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-1{
grid-row:1/3;
grid-column:1/7;
}
}
.keyvisual-imgbox .kv-section-1 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-1 .slider-item:nth-child(1){
animation-delay:.3s;
}
.keyvisual-imgbox .kv-section-1 .slider-item:nth-child(2){
animation-delay:4s;
}
.keyvisual-imgbox .kv-section-1 .slider-item:nth-child(3){
animation-delay:8s;
}
/*============================== kv-section-2 =============*/
.keyvisual-imgbox .kv-section-2{
grid-row:1/3;
grid-column:10/14;
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-2{
grid-row:3/4;
grid-column:1/3;
}
}
.keyvisual-imgbox .kv-section-2 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-2 .slider-item:nth-child(1){
animation-delay:.6s;
}
.keyvisual-imgbox .kv-section-2 .slider-item:nth-child(2){
animation-delay:4.3s;
}
.keyvisual-imgbox .kv-section-2 .slider-item:nth-child(3){
animation-delay:8.3s;
}
/*============================== kv-section-3 =============*/
.keyvisual-imgbox .kv-section-3{
grid-row:3/5;
grid-column:1/4
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-3{
grid-row:3/4;
grid-column:3/5;
}
}
.keyvisual-imgbox .kv-section-3 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-3 .slider-item:nth-child(1){
animation-delay:.9s;
}
.keyvisual-imgbox .kv-section-3 .slider-item:nth-child(2){
animation-delay:4.6s;
}
.keyvisual-imgbox .kv-section-3 .slider-item:nth-child(3){
animation-delay:8.6s;
}
/*============================== kv-section-4 =============*/
.keyvisual-imgbox .kv-section-4{
grid-row:3/5;
grid-column:4/7
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-4{
grid-row:3/4;
grid-column:5/7;
}
}
.keyvisual-imgbox .kv-section-4 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-4 .slider-item:nth-child(1){
animation-delay:1.2s;
}
.keyvisual-imgbox .kv-section-4 .slider-item:nth-child(2){
animation-delay:4.9s;
}
.keyvisual-imgbox .kv-section-4 .slider-item:nth-child(3){
animation-delay:8.9s;
}
/*============================== kv-section-5 =============*/
.keyvisual-imgbox .kv-section-5{
grid-row:3/5;
grid-column:7/14
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-5{
grid-row:4/5;
grid-column:1/4;
}
}
.keyvisual-imgbox .kv-section-5 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-5 .slider-item:nth-child(1){
animation-delay:1.5s;
}
.keyvisual-imgbox .kv-section-5 .slider-item:nth-child(2){
animation-delay:5.2s;
}
.keyvisual-imgbox .kv-section-5 .slider-item:nth-child(3){
animation-delay:9.2s;
}
/*============================== kv-section-6 =============*/
.keyvisual-imgbox .kv-section-6{
display: none;
}@media screen and (max-width: 787px){
.keyvisual-imgbox .kv-section-6{
display: inline-grid;
grid-row:4/5;
grid-column:4/7;
}
}
.keyvisual-imgbox .kv-section-6 .slider-item{
opacity:0;
animation:slideShow 12s linear infinite 0s;
}
.keyvisual-imgbox .kv-section-6 .slider-item:nth-child(1){
animation-delay:1.8s;
}
.keyvisual-imgbox .kv-section-6 .slider-item:nth-child(2){
animation-delay:5.5s;
}
.keyvisual-imgbox .kv-section-6 .slider-item:nth-child(3){
animation-delay:9.7s;
}

.keyvisual-imgbox>div{
overflow:hidden;
display:block;
position:relative
}

.keyvisual-imgbox img{
width:100%;
height:100%;
object-fit:cover;
position:absolute;
top:0;
left:0;
}@keyframes slideShow{
0%{
opacity:0;
animation-timing-function:ease-in;
}
8%{
opacity:1;
animation-timing-function:ease-out;
}
20%{
opacity:1;
}
50%,
to{
opacity:0;
}
}

/* ================================================================= */
/* 無限スライダー */
/* ================================================================= */
.slide_box_bg{
background-color: #ffffff;
width: 100%;
padding: 3% 0% 0% 0%;
height: auto;
margin-bottom: 80px;
}
.slide_box_bg .slide_box{
padding: 0% 0% 3% 0%;
margin: 0 calc(50% - 50vw) 120px calc(50% - 50vw);
width: 100vw;
position: relative;
z-index: 10;
background-color: #ffffff;
}
.slide_box_bg .slide_box .slide{
display: block;
width: 100%;
}
.slide_box_bg .slide_box .slide .slide__item {
    margin-right: 10px;
    margin-left: 10px;
}@media screen and (max-width: 787px){
.slide_box_bg{
background-color: #ffffff;
width: 100%;
height: 280px;
padding: 9.5% 0% 0% 0px;
margin-bottom: 70px;
}
.slide_box_bg .slide_box{
display: block;
padding: 0% 0% 0% 0px;
margin: 0 calc(50% - 50vw) 120px calc(50% - 50vw);
width: 100%;
height: 200px;
position: relative;
overflow: hidden;
z-index: 10;
}
.slide_box_bg .slide_box .slide{
display: block;
width: 1200px;
position: absolute;
top: 0px;
}
.slide_box_bg .slide_box .slide .slide__item {
    margin-right: 10px;
    margin-left: 10px;
}
}

/* ================================================================= */
/* 次回日程・スケジュール・タイムテーブル */
/* ================================================================= */
.day_next{
margin: 0px auto;
display: block;
width: 600px;
height: auto;
padding: 60px 0px 80px 0px;
position: relative;
}
.day_next h4{
margin: 0px auto;
display: block;
width: 68%;
height: auto;
padding: 0px 0px 25px 0px;
}
.day_next .popicon{
display: block;
width: 45%;
height: auto;
position: absolute;
top: 0px;
left: 85%;
}
.day_next .day_area{
display: flex;
justify-content: center;
flex-wrap: wrap;
width: 100%;
height: auto;
padding: 0px 0px 20px 0px;
clear: both;
}
.day_next .day_area img{
display: block;
width: 50%;
height: auto;
margin: 0px auto 0px auto;
}
.day_next .day{
margin: 0px auto;
display: block;
width: 600px;
height: auto;
padding: 0px 45px 0px 45px;
float: left;
}
.day_next .time{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 20px 0px;
}
.day_next a{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 0px 0px;
text-decoration: underline;
text-align: center;
font-size: 1.7vw;
color: #1486AD;
}
.day_next .icon{
margin: 20px auto;
display: block;
width: 50%;
height: auto;
padding: 0px 0px 0px 0px;
text-align: center;
}
@media screen and (max-width: 787px){
.day_next{
margin: 0px auto 50px auto;
display: block;
width: 62%;
height: auto;
padding: 0px 0px 0px 0px;
position: relative;
}
.day_next h4{
margin: 0px auto;
display: block;
width: 78%;
height: auto;
padding: 0px 0px 20px 0px;
}
.day_next .popicon{
display: block;
width: 36%;
height: auto;
position: absolute;
top: 2%;
left: 90%;
}
.day_next .day_area{
display: block;
justify-content: center;
flex-wrap: wrap;
width: 100%;
height: auto;
padding: 0px 0px 15px 0px;
margin-left: auto;
}
.day_next .day_area img{
display: block;
width: 80%;
height: auto;
margin: 0px auto;
}
.day_next .day{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 15px 0px;
float: none;
}
.day_next .time{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 3% 0px;
}
.day_next a{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 0px 0px;
text-decoration: underline;
text-align: center;
font-size: 1.05em;
}
.day_next .icon{
margin: 20px auto -5px auto;
display: block;
width: 60%;
height: auto;
padding: 0px 0px 0px 0px;
text-align: center;
}
}
/* ================================================================= */

.detail{
margin: 0px auto;
/*height: 1220px;*/
height:auto;
padding: 4% 0px 110px 0px;
position: relative;
background-color: #ffffff;
width: 100vw;
}
.detail .schedule{
margin: 0px auto;
display: flex;
width: 100%;
height: auto;
padding: 0px 0px;
position: relative;
}

.detail .schedule .schedule_daylist{
margin: 0px auto;
display: block;
width: 1100px;
height: auto;
padding: 0px;
}
.detail .schedule .schedule_daylist h4{
margin: 0px auto;
display: block;
width: 60%;
height: auto;
text-align: center;
}
.detail .schedule .schedule_daylist .kochira{
margin: 0px auto;
display: block;
width: 80%;
height: auto;
padding: 10px 0px 0px 0px;
text-align: center;
font-size: 1.4vw;
color: #1486AD;
text-decoration: underline;
}

.detail .schedule .schedule_daylist ul{
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
position: relative;
padding-top: 15px;
margin: 0px auto 0px 50px;
}
.detail .schedule .schedule_daylist ul li{
padding:15px 20px;
width: 250px;
height: auto;
}
.detail .schedule .schedule_daylist ul li a{
display: block;
width: 100%;
height: auto;
}
/* ================================================================= */
.campus{
margin: 0px auto 3% auto;
display: flex;
width: 100vw;
height: auto;
padding: 0px 0px 5% 0px;
background-color: #ffffff;
justify-content: center;
flex-wrap: wrap;
position: relative;
}
.campus .tap_subject{
display: block;
width: 300px;
height: auto;
padding: 0px;
margin: 0px auto;
position: absolute;
left: 50%;
transform: translateX(-50%);
top: 0px;
}

.campus .campus_s,
.campus .campus_p{
margin: 0px 0px;
width: 640px;
height: auto;
padding: 0px 60px;
}
.campus .campus_s h5{
display: block;
margin: 0px auto 20px auto;
width: 35%;
}
.campus .campus_p h5{
display: block;
margin: 0px auto 20px auto;
width: 55%;
}
.campus .campus_s h6,
.campus .campus_p h6{
text-align: center;
font-size: 1.5vw;
color: #1486AD;
}
.campus .campus_s h6 span{
display: block;
color: #4C4948;
font-size: 0.9vw;
margin-top: -2%;
font-weight: 200;
}
.campus_s ul,
.campus_p ul{
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
}
.campus_s ul li,
.campus_p ul li{
font-size: 17pt;
text-align: center;
padding: 4px 40px 4px 15px;
margin: 10px 10px;
width: auto;
height: auto;
background-color: #fff;
border-radius: 30px;
color: #1486AD;
box-shadow: 0 5px 15px 0 rgba(0, 0, 0, .2);
position:relative;
}
.campus_s ul li:after {
content: "";
background: url("../2025image/base2_new/icon_arrow.svg") no-repeat;
display: inline-block;
width: 25px;
height: 25px;
position:absolute;
top: 0;
bottom: 0;
right: 10px;
margin: auto 0;
}
.campus_p ul li:after {
content: "";
background: url("../2025image/base2_new/icon_arrow.svg") no-repeat;
display: inline-block;
width: 25px;
height: 25px;
position:absolute;
top: 0;
bottom: 0;
right: 10px;
margin: auto 0;
}
.campus_s ul li br,
.campus_p ul li br{
display: none;
}

@media screen and (max-width: 787px){
.detail{
width: 100%;
height: auto;
margin: 0px auto;
padding: 0px 0px 5% 0px;
position: relative;
}
.detail .schedule{
margin: 0px auto;
display: flex;
width: 100%;
height: auto;
padding: 0px 0px;
position: relative;
flex-wrap:wrap;
}
.detail .schedule .schedule_daylist{
margin: 0% auto 0px auto;
width: 100%;
height: auto;
display: block;
padding: 0% 0% 5% 0%;
float: none;
}
.detail .schedule .schedule_daylist h4{
padding: 10% 0px 20px 0px;
width: 85%;
margin: 0px auto;
}

.detail .schedule .schedule_daylist a{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 0px 0px;
text-align: center;
font-size: 3.6vw;
}
.detail .schedule .schedule_daylist ul{
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
position: relative;
padding-top: 20px;
margin: 0px auto 0px auto;
width: 90%;
}
.detail .schedule .schedule_daylist ul li{
padding:3% 0.5%;
width: 33%;
}
/* 
.detail .schedule .schedule_2{
margin: 0px auto 60px auto;
display: block;
width: 100%;
height: auto;
padding: 0px;
position: relative;
float: none;
clear: both;
}
*/

.detail .schedule .time_schedule{
display: block;
width: 100%;
height: auto;
margin: 0px auto 0px auto;
padding-top: 20%;
padding-bottom: 15%;
background-color:#EDF6F9;
overflow-x: hidden;
}
.detail .schedule .time_schedule .tap{
display: block;
margin: 0px;
width: 48%;
height: auto;
padding: 0px;
position: absolute;
left: 70%;
transform: translate(-50%, -50%);
top: 6%;
}
.detail .schedule .time_schedule .time{
display: block;
margin: 0px 0px 0px 3.5%;
width: auto;
height: 79%;
padding: 0px;
position: absolute;
}

.campus{
margin: 0px auto 0px auto;
display: flex;
width: 100%;
height: auto;
padding: 0px 0px 10% 0px;
position: relative;
background-color: #ffffff;
}
.campus .tap_subject{
display: block;
margin: 0px auto 6% auto;
width: 70%;
height: auto;
padding: 0px;
position: relative;
transform: none;
left: 0px;
top: 0px;
}
.campus .campus_s,
.campus .campus_p{
margin: 0px auto 0px auto;
display: block;
width: 50%;
padding: 0px 1%;
height: auto;
float: left;
}
.campus .campus_s{
border-right: solid 1px #4C4948;
}
.campus .campus_s:after {
  content: "";
  display: block;
  overflow: hidden;
  position: absolute;
  top: 12%;
  left: 49%;
  height: 13%;
  border-right: 8px solid #ffffff;
  z-index: 10;
}
.campus_s ul,
.campus_p ul{
display: block;
justify-content: center;
flex-wrap: wrap;
position: relative;
}

.campus_s ul li,
.campus_p ul li{
text-align: left;
font-size: 3.8vw;
padding: 2% 3% 2% 8%;
width: 90%;
height: auto;
line-height: normal;
position: relative;
}
.campus_s ul li:after {
content: "";
background: url("../2025image/base2_new/icon_arrow.svg") no-repeat;
display: inline-block;
width: 22px;
height: 22px;
position:absolute;
top: 0;
bottom: 0;
right: 10px;
margin: auto 0;
}
.campus_p ul li:after {
content: "";
background: url("../2025image/base2_new/icon_arrow.svg") no-repeat;
display: inline-block;
width: 25px;
height: 25px;
position:absolute;
top: 0;
bottom: 0;
right: 10px;
margin: auto 0;
}
.campus_s ul li br,
.campus_p ul li br{
display: block;
}
.campus .campus_s h5{
display: block;
margin: 0px auto 15px auto;
width: 60%;
}
.campus .campus_p h5{
display: block;
margin: 0px auto 15px auto;
width: 90%;
}
.campus .campus_s h6,
.campus .campus_p h6{
text-align: center;
font-size: 5vw;
color: #1486AD;
}
.campus .campus_s h6 span{
display: block;
color: #4C4948;
font-size: 3vw;
margin-top: -5%;
font-weight: 200;
}
}
/* ================================================================= */
/* オープンキャンパス　特徴 */
/* ================================================================= */

/*
.topstory .topstory-inner h3{
width: 100%;
height: auto;
display: block;
text-align: center;
margin: 0px auto 20px auto;
color: #1486AD;
font-weight: 600;
font-size: 50pt;
position: relative;
}
.topstory .topstory-inner h3 br{
display: none;
}
@media screen and (max-width: 787px){
.topstory .topstory-inner h3{
width: 100%;
height: auto;
display: block;
text-align:center;
margin: 0px auto 0px auto;
color: #1486AD;
font-weight: 500;
font-size: 2.09em;
letter-spacing: 0em;
padding-left: 0%;
line-height: 1;
position: absolute;
left: 1%;
top: 2%;
}
.topstory .topstory-inner h3 br{
display: block;
}
}
.topstory-tatetext{
position:absolute;
top:6%;
left: 8%;
width:3.3vw;
z-index:2;
}@media screen and (max-width: 787px){
.topstory-tatetext{
position:sticky;
top:9%;
left:7%;
transform:translate(0);
height:calc(180vh - 300px);
width:10vw;
margin-top:0%;
}
}
.topstory-tatetext img{
width:100%;
}
.topstory .topstory-tatetext .pc_img{
display: block;
}
.topstory .topstory-tatetext.sp_img{
display: none;
}
@media screen and (max-width: 787px){
.topstory-tatetext img{
width:auto;
height:100%;
}
.topstory .topstory-tatetext .pc_img{
display: none;
}
.topstory .topstory-tatetext.sp_img{
display: block;
}
}@media screen and (max-width: 787px){
.topstory .topstory-inner{
width:calc(110% - 120px);
margin:0 0 0 auto;
}
}
.topstory-item{
width:55%;
margin:0 0% 3% 18%;
display:flex;
justify-content:space-between;
align-items:center;
flex-wrap:wrap;
}@media screen and (max-width: 787px){
.topstory-item{
width:100%;
margin:0 0% -1% 0%;
}
}
.topstory-textbox{
width:45%;
position: relative;
left: 0%;
}@media screen and (max-width: 787px){
.topstory-textbox{
width:80%;
margin-bottom:10px;
position: relative;
left: 6%;
}
}
.topstory-textbox .maintext{
display:block;
font-size:28pt;
color: #1486AD;
line-height: 1;
padding-bottom: 3%;
}@media screen and (max-width: 787px){
.topstory-textbox .maintext{
font-size:5.6vw;
margin-bottom: -5px;
line-height: 1;
padding-bottom: 5%;
}
}
.topstory-textbox p{
line-height:1.5;
text-align: justify;
font-size:17pt;
}@media screen and (max-width: 787px){
.topstory-textbox p{
line-height:1.5;
font-size:4.2vw;
letter-spacing: -0.08em;
}
}
.topstory-imgbox{
width:48%;
padding-bottom: 0%;
}@media screen and (max-width: 787px){
.topstory-imgbox{
width:100%!important;
padding-bottom: 3%;
margin:20px 0px 0px auto;
position: relative;
left: 2%;
}
}
.topstory-imgbox img{
width:100%;
}
*/

.topstory{
width: 100%;
height: auto;
clear: both;
padding:0px 0px 150px 0px;
position:relative;
overflow:hidden;
margin-bottom: -50px;
}@media screen and (max-width: 787px){
.topstory{
padding:0% 0px 15% 0px;
overflow:visible;
display:block;
/*
display:flex;
align-items:flex-start;*/
width: 100%;
margin-bottom: 0px;
}
}
.topstory h3{
width: 100%;
height: auto;
display: block;
text-align: center;
margin: 0px auto 0px auto;
color: #1486AD;
font-weight: 600;
font-size: 50pt;
position: relative;
top: 2%;
}
.topstory h3 br{
display: none;
}
@media screen and (max-width: 787px){
.topstory h3{
width: 100%;
height: auto;
display: block;
text-align:center;
margin: 0px auto 0px auto;
color: #1486AD;
font-weight: 500;
font-size: 2.09em;
letter-spacing: 0em;
padding-left: 0%;
line-height: 1;
position: absolute;
left: 1%;
/*
left: 50%;
transform: translateX(-50%); */
top: 5%;
}
.topstory h3 br{
display: block;
}
}


.box {
	width:100%;
	margin:20px auto 0px auto;
    position: relative;
    min-height: 700px; 
}
.box .flexslider {
	width:100%;
	margin:0px auto;
    position: relative;
    height: auto; 
    background-attachment: fixed;
}

.box .flexslider .topics li {
padding: 0px 25px;
}

/*
.flexslider .slider .topi_01{
background-image: url("../2025image/topics/slide_01sp.png");
background-repeat: no-repeat;
background-position: center;
background-size: 100%;
width: 1280px;
height: 630px;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
position: relative;
}*/
@media screen and (max-width: 787px){

.box {
	width:100%;
	margin:0px auto 0px auto;
    position: relative;
    height: 600px;
    overflow: hidden;
    min-height: inherit;
}
.box .flexslider {
/*width:325%;*/
width:100%;
height: auto;
    position: relative; 
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
	top:0;
}
.box .flexslider .topics li {
padding: 0px 10px;
}
}



/* ================================================================= */
/* プレゼント */
/* ================================================================= */
.present{
margin: 0px auto 0px auto;
display: block;
height: 950px;
width: auto;
padding: 0px 0px 0px 0px;
position: relative;
}
.present h3{
width: 350px;
margin: 0 auto;
padding-top: 40px;
}
.present .area{
width: 850px;
height:auto;
display: block;
position: relative;
top: 0px;
z-index: 4;
margin: 0 auto;
}
.present .area .title{
width: 300px;
position: relative;
top: 40px;
margin: 0 auto -40px auto;
}
.present .area p{
width: 100%;
height: auto;
font-size: 20pt;
position: relative;
top: 30px;
text-align: justify;
}
.present ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 120px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
@media screen and (max-width: 787px){
.present{
margin: 0px auto;
display: block;
height: auto;
width: 100%;
padding: 0px 0px 30% 0px;
position: relative;
}
.present h3{
width: 50%;
margin: 0 auto;
}
.present .area{
width: 80%;
height:auto;
display: block;
position: relative;
top: 20px;
left: 0%;
z-index: 4;
}
.present .area .title{
width: 60%;
position: relative;
top: 0px;
margin: 0 auto;
}
.present .area p{
width: 100%;
height: auto;
font-size: 4.3vw;
position: relative;
top: 20px;
text-align: justify;
letter-spacing: 1;
}
.present ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 40px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
}

/* ================================================================= */
/* 学びを体験 */
/* ================================================================= */
.manabi{
margin: 0px auto;
display: block;
height: 1000px;
width: auto;
padding: 0px 0px 0px 0px;
position: relative;
}
.manabi h3{
width: 350px;
margin: 0 auto;
}
.manabi .area{
width: 850px;
height:auto;
display: block;
position: relative;
top: 0px;
z-index: 4;
margin: 0 auto;
}
.manabi .area .title{
width: 300px;
position: relative;
top: 30px;
margin: 0 auto;
}
.manabi .area p{
width: 100%;
height: auto;
font-size: 20pt;
position: relative;
top: 60px;
text-align: justify;
}
.manabi ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 100px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}


.manabi ul li,
.oc ul li,
.exam ul li,
.present ul li{
width: 450px;
height: auto;
padding:0px 30px;
}
.manabi ul li .sub_img_pc,
.oc ul li .sub_img_pc,
.exam ul li .sub_img_pc,
.present ul li .sub_img_pc{
display: block;
}
.manabi ul li .sub_img_sp,
.oc ul li .sub_img_sp,
.exam ul li .sub_img_sp,
.present ul li .sub_img_sp{
display: none;
}
.manabi ul li h5,
.oc ul li h5,
.exam ul li h5,
.present ul li h5{
font-size: 22pt;
padding:3px 0px 0px 0px;
color: #1486AD;
line-height: 30pt;
}
.manabi ul li h5 br,
.oc ul li h5 br,
.exam ul li h5 br{
display: none;
}
.manabi ul li p,
.oc ul li p,
.exam ul li p,
.present ul li p{
font-size: 16pt;
text-align: justify;
}
@media screen and (max-width: 787px){
.manabi{
margin: 0px auto;
display: block;
height: auto;
width: 100%;
padding: 0px 0px 25% 0px;
position: relative;
}
.manabi h3{
width: 50%;
margin: 0 auto;
}
.manabi .area{
width: 80%;
height:auto;
display: block;
position: relative;
top: 20px;
left: 0%;
}
.manabi .area .title{
width: 60%;
position: relative;
top: 0px;
left: 0%;
}
.manabi .area p{
width: 100%;
height: auto;
font-size: 4.3vw;
position: relative;
top: 20px;
text-align: justify;
letter-spacing: 1;
}
.manabi ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 60px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}

.manabi ul li,
.oc ul li,
.exam ul li,
.present ul li{
width: 50%;
height: auto;
padding:0px 1%;
}
.manabi ul li .sub_img_pc,
.oc ul li .sub_img_pc,
.exam ul li .sub_img_pc,
.present ul li .sub_img_pc{
display: none;
}
.manabi ul li .sub_img_sp,
.oc ul li .sub_img_sp,
.exam ul li .sub_img_sp,
.present ul li .sub_img_sp{
display: block;
}
.manabi ul li h5,
.oc ul li h5,
.exam ul li h5,
.present ul li h5{
font-size: 4.4vw;
padding:5% 0px 3% 8%;
font-weight: 500;
color: #1486AD;
letter-spacing: -0.05em;
line-height: 1;
}
.manabi ul li h5 br,
.oc ul li h5 br,
.exam ul li h5 br{
display: block;
}
.manabi ul li p,
.oc ul li p,
.exam ul li p,
.present ul li p{
width: 90%;
font-size: 3.8vw;
text-align: justify;
line-height: 1.5;
padding-left: 8%;
letter-spacing: -0.08em;
}
}

/* ================================================================= */
/* オープンキャンパス体験 */
/* ================================================================= */
.oc{
margin: 0px auto;
display: block;
height: 880px;
width: auto;
padding: 0px 0px 0px 0px;
position: relative;
}
.oc .area{
width: 850px;
height:auto;
display: block;
position: relative;
top: 0px;
z-index: 4;
margin: 0 auto;
}
.oc .area .title{
width: 450px;
position: relative;
top: 30px;
margin: 0 auto;
display: block;
}
.oc .area .title_sp{
display: none;
}
.oc .area p{
width: 100%;
height: auto;
font-size: 20pt;
position: relative;
top: 60px;
text-align: justify;
}
.oc ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 100px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
@media screen and (max-width: 787px){
.oc{
margin: 0px auto;
display: block;
height: auto;
width: 100%;
padding: 0px 0px 25% 0px;
position: relative;
overflow-x: hidden;
}
.oc .area{
width: 80%;
height:auto;
display: block;
position: relative;
top: 20px;
left: 0%;
}
.oc .area .title{
display: none;
}
.oc .area .title_sp{
display: block;
width: 60%;
position: relative;
top: 0px;
left: 0%;
margin: 0 auto;
}
.oc .area p{
width: 100%;
height: auto;
font-size: 4.3vw;
position: relative;
top: 20px;
text-align: justify;
letter-spacing: 1;
}
.oc ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 60px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
}


/* ================================================================= */
/* 入試について */
/* ================================================================= */
.exam{
margin: 0px auto;
display: block;
/*height: 1490px;*/
height: 1000px;
width: auto;
padding: 0px 0px 0px 0px;
position: relative;
}
.exam .area{
width: 850px;
height:auto;
display: block;
position: relative;
top: 0px;
z-index: 4;
margin: 0 auto;
}
.exam .area .title{
width: 300px;
position: relative;
top: 30px;
margin: 0 auto;
}
.exam .area p{
width: 100%;
height: auto;
font-size: 20pt;
position: relative;
top: 60px;
text-align: justify;
}
.exam ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 100px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
@media screen and (max-width: 787px){
.exam{
margin: 0px auto 0px auto;
display: block;
height: auto;
width: 100%;
padding: 0px 0px 50% 0px;
position: relative;
}
.exam .area{
width: 80%;
height:auto;
display: block;
position: relative;
top: 20px;
left: 0%;
}
.exam .area .title{
width: 60%;
position: relative;
top: 0px;
left: 0%;
}
.exam .area p{
width: 100%;
height: auto;
font-size: 4.3vw;
position: relative;
top: 20px;
text-align: justify;
letter-spacing: -0.05em;
}
.exam ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 60px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
}



/* ================================================================= */
/* 学食・ランチ紹介 */
/* ================================================================= */
.lunch{
margin: 0px auto 0px auto;
display: block;
padding: 0px 0px 80px 0px;
position: relative;
width: 100vw;
height: auto;
left: 50%;
background-position: center;
transform: translateX(-50%);
}
.lunch .image{
display: block;
width: 100vw;
height: 550px;
margin: 0px auto 0px auto;
background-image: url("../2025image/base2_new/03_img_title.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
position: relative;
top: -50px;
}
.lunch h3{
display: block;
width: 480px;
height: auto;
position: absolute;
z-index: 4;
top: -200px;
left: 38%;
}
.lunch p{
text-align: center;
font-size: 22px;
width: 100%;
display: block;
margin: -10px auto 0px auto;
}
.lunch ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
margin: 30px auto 0px auto;
width: 1000px;
height: auto;
z-index: 3;
}
.lunch ul li{
width: 45%;
height: auto;
padding:0.5%;
}

@media screen and (max-width: 787px){
.lunch{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0 0 60px 0;
position: relative;
}
.lunch .image{
display: block;
width: 100vw;
height: 0px;
padding-top: 62%;
margin: 0px auto 30px auto;
background-image: url("../2025image/base2_new/03_img_title_sp.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
position: relative;
top: 0px;
}
.lunch h3{
display: block;
width: 65%;
height: auto;
margin: 0px auto 0px auto;
position: absolute;
top: -11%;
left: 18%;
}
.lunch p{
text-align: justify;
font-size: 4.3vw;
width: 80%;
display: block;
margin: 0px auto;
}
.lunch ul{
clear: both;
display: flex;
justify-content: center;
flex-wrap: wrap;
position: relative;
top: 20px;
margin: 0px auto 0px auto;
width: auto;
height: auto;
z-index: 3;
}
.lunch ul li{
width: 80%;
height: auto;
padding: 2% 0%;
}
}


/* ================================================================= */
/* オープンキャンパスのまわり方 */
/* ================================================================= */
.oc_guide{
margin: 0px auto 120px auto;
display: block;
width: 100%;
position: relative;
}
.oc_guide h3{
width: 550px;
margin: 0 auto 30px auto;
position: relative;
top: 0px;
}
.oc_guide .guide_pc{
margin: 0px auto 0px auto;
display: block;
width: 70%;
position: relative;
top: 0px;
}
.oc_guide .guide_sp{
display: none;
}
@media screen and (max-width: 787px){
.oc_guide{
margin: 0px auto;
display: block;
width: 100%;
height: auto;
position: relative;
}
.oc_guide h3{
width: 93%;
margin: 0 auto 30px auto;
position: relative;
top: 0px;
left: 2%;
}
.oc_guide .guide_pc{
display: none;
}
.oc_guide .guide_sp{
margin: 0px auto 0px auto;
display: block;
width: 90%;
position: relative;
}
}


/* ================================================================= */
/* 無料宿泊体験 */
/* ================================================================= */
.stay{
margin: 0px auto 0px auto;
display: block;
padding: 0 0 50px 0;
position: relative;
background-color: #ffffff;
width: 100vw;
left: 50%;
background-position: center;
transform: translateX(-50%);
}
.stay .image{
display: block;
width: 100vw;
height: 550px;
margin: 0px auto 40px auto;
background-image: url("../2025image/base/06_img_pc.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
position: relative;
top: 0px;
}
.stay h3{
display: block;
width: 380px;
height: auto;
margin: 0px auto 50px auto;
}
.stay p{
text-align: center;
font-size: 22px;
width: 100%;
display: block;
margin: 0px auto;
}
.stay .point{
width: 600px;
padding: 30px 40px 35px 40px;
height: auto;
opacity: 1;
background-color: #ffffff;
border: solid 1px #1486AD;
box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, .1);
border-radius: 30px;
margin: 35px auto 0px auto;
position: relative;
}
.stay .point h4{
display: block;
width: 180px;
height: auto;
margin: 0px auto 20px auto;
}
.stay .point ul li::before{
  content: "●";
  color: #1486AD;
  padding-right: 3px;
}
.stay .point ul li{
font-size: 18px;
padding: 3px 0;
}
.stay .apply{
width: 600px;
padding: 10px 10px 40px 10px;
height: auto;
opacity: 1;
background-color: #EDF6F9;
margin: 35px auto 0px auto;
position: relative;
}
.stay .apply br{
display: none;
}
.stay .apply h5{
/* color: #fc8786; */
text-align: center;
font-size: 20px;
display: block;
padding-bottom: 10px;
}
.stay .apply a,
.stay .apply a img{
width: 500px;
height: auto;
display: block;
margin: 0px auto;
}
.stay .apply a:hover{
opacity: 0.6;
}
.stay .chuui{
width: 550px;
height: auto;
margin: 60px auto 20px auto;
}
.stay .chuui h6{
font-size: 16px;
}
.stay .chuui ul li{
font-size: 16px;
padding: 2px 0;
}

@media screen and (max-width: 787px){
.stay{
margin: 60px auto 80px auto;
display: block;
width: 100%;
height: auto;
padding: 0% 0px 60px 0px;
position: relative;
}
.stay .image{
display: block;
width: 100vw;
height: 0px;
padding-top: 62%;
margin: 0px auto 50px auto;
background-image: url("../2025image/base/06_img_sp.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
position: relative;
top: 0px;
}
.stay h3{
display: block;
width: 42%;
height: auto;
margin: 0px auto 30px auto;
}
.stay p{
text-align: justify;
font-size: 4.3vw;
width: 80%;
display: block;
margin: 0px auto;
}
.stay .point{
width: 80%;
padding: 20px 20px 15px 20px;
height: auto;
border-radius: 30px;
margin: 35px auto 40px auto;
position: relative;
}
.stay .point h4{
display: block;
width: 140px;
height: auto;
margin: 0px auto 5px auto;
}
.stay .point ul li{
font-size: 18px;
padding: 3px 0;
text-indent: -18px;
margin-left: 18px;
}
.stay .apply{
width: 90%;
padding: 20px 20px 25px 20px;
height: auto;
opacity: 1;
margin: 35px auto 10px auto;
position: relative;
}
.stay .apply br{
display: block;
}
.stay .apply h5{
text-align: center;
font-size: 3.7vw;
display: block;
padding-bottom: 10px;

}
.stay .apply a,
.stay .apply a img{
width: 98%;
height: auto;
display: block;
margin: 0px auto;
}

.stay .chuui{
width: 80%;
height: auto;
margin: 30px auto 0px auto;
}
.stay .chuui h6{
font-size: 3.6vw;
}
.stay .chuui ul li{
font-size: 3.6vw;
padding: 2px 0;
letter-spacing: -0.1em;
}
}

/* ================================================================= */
/* アクセス */
/* ================================================================= */
.access{
margin: 0px auto 0px auto;
display: block;
width: 100%;
height: auto;
padding: 0px 0px 20px 0px;
position: relative;
}
.access .image{
display: block;
width: 100vw;
height: 550px;
margin: 0px auto 50px auto;
background-image: url("../2025image/base/07_img_pc.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.access h3{
display: block;
width: 210px;
height: auto;
margin: 0px auto 80px auto;
}
.access div{
width: 785px;
height: auto;
margin: 0px auto 80px auto;
}
.access div h4{
display: block;
width: 340px;
height: auto;
margin: 0px auto 0px auto;
}
.access div iframe{
width: 800px;
height: 480px;
display: block;
margin: 30px auto 20px auto;
}
.access div .access_text_s{
width: 424px;
height: 215px;
display: block;
padding-left: 40px;
}
.access div .access_text_p{
width: 402px;
height: 100px;
display: block;
padding-left: 40px;
}
.access .others{
background-color: #ffffff;
width: 100%;
padding: 40px 0px 60px 0px;
}
.access .others .inner{
width: 750px;
height: auto;
display: block;
margin: 0px auto 0px auto;
}
.access .others .inner h5{
font-size: 18pt;
padding:10px 0px 0px 0px;
color: #1486AD;
text-align: center;
}
.access .others .inner h5 img{
width: 55%;
padding:10px 0px 8px 0px;
margin: 0px auto;
display:block; 
}
.access .others .inner p{
font-size: 16pt;
}
.access .others .inner .big{
font-size: 18pt;
}
@media screen and (max-width: 787px){
.access{
margin: 0px auto 20px auto;
display: block;
width: 100%;
height: auto;
padding: 0 0 25px 0;
position: relative;
}
.access .image{
display: block;
width: 100vw;
height: 0px;
padding-top: 62%;
margin: 0px auto 50px auto;
background-image: url("../2025image/base/07_img_sp.png");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.access h3{
display: block;
width: 30%;
height: auto;
margin: 0px auto 40px auto;
}
.access div{
width: 100%;
height: auto;
margin: 0px auto 40px auto;
}
.access div h4{
display: block;
width: 45%;
height: auto;
margin: 0px auto 0px auto;
}
.access div iframe{
width: 100%;
height: 340px;
display: block;
margin: 20px auto 20px auto;
}
.access div .access_text_s{
width: 85%;
height: auto;
display: block;
padding-left: 7%;
}
.access div .access_text_p{
width: 83%;
height: auto;
display: block;
padding-left: 7%;
}
.access .others{
background-color: #ffffff;
width: 100%;
padding: 10px 0px 45px 0px;
}
.access .others .inner{
width: 86%;
height: auto;
display: block;
margin: 0px auto 0px auto;
}
.access .others .inner h5{
font-size: 4vw;
padding:5% 0px 0px 0px;
color: #1486AD;
text-align: left;
font-weight: 500;
}
.access .others .inner h5 img{
width: 70%;
padding:10px 0px 8px 0px;
margin: 0px 0px;
display:block; 
}
.access .others .inner p{
width: 100%;
text-align: justify;
font-size: 3.6vw;
line-height: normal;
}
.access .others .inner .big{
font-size: 4.2vw;
}
}

/* ================================================================= */
/* 無料送迎バスツアー */
/* ================================================================= */
.buss{
width: 800px;
height: auto;
    padding: 50px 60px 40px 60px;
    opacity: 1;
    overflow:visible;
    background-color: #ffffff;
    border: solid 1px #1486AD;
    box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, .1);
    border-radius: 30px;
    margin: 0px auto 170px auto;
    position: relative;
    top: 100px;
    z-index: 3;
}
.buss h3{
display: block;
width: 400px;
height: auto;
margin-left: 26%;
    position: relative;
    top: -170px;
    z-index: 4;
    margin-bottom: -160px;
}
.buss .hidden_box h4{
display: block;
width: 400px;
height: 80px;
margin: 0px auto 30px auto;
}
.buss .hidden_box .hidden_show img{
display: block;
margin: 20px auto 0 auto;
}
.buss .hidden_box .hidden_show .img1{
background-image: url("../2025image/bus/buss_01.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
height: 400px;
width: 630px;/* 縦÷1296 ×630 */
}

.buss .hidden_box .hidden_show .img2{
background-image: url("../2025image/bus/0809_oka.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
height: 245px;
width: 630px;/* 縦÷1296 ×630 */
}

.buss .hidden_box .hidden_show .img3{
background-image: url("../2025image/bus/0809_toku.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
height: 427px;
width: 630px;/* 縦÷1296 ×630 */
}

.buss h5{
display: block;
width: 500px;
height: 40px;
margin: 50px auto;
background-image: url("../2025image/base/buss_p.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .tel{
display: block;
width: 480px;
height: 128px;
margin: 0px auto 50px auto;
background-image: url("../2025image/base/buss_tel.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .url{
display: block;
width: 380px;
height: 80px;
margin: 30px auto 80px auto;
}
.buss p{
width: 480px;
font-size: 22px;
display: block;
margin: 0px auto 0px auto;
}
.buss .bus_manu{
width: 95%;
height: auto;
text-align: justify;
font-size: 22px;
display: block;
margin: 20px auto 0px auto;
line-height: 38px;
}
.buss .hidden_box .hidden_show .manual{
width: auto;
height: auto;
display: block;
color: #1486AD;
font-size: 22px;
text-decoration: underline;
margin: 10px 0px 30px 0px;
text-align: center;
}

/*　　＝＝＝＝＝＝＝　バスツアー申込　別バージョン　＝＝＝＝＝＝＝　*/
.buss .request{
width: 80%;
height: auto;
margin: 0px auto;
display: block;
}

.buss .request .button{
width: 60%;
height: auto;
margin: 30px auto;
display: block;
}

.buss .request .manual{
width: 45%;
height: auto;
display: block;
border: 1px solid #1486AD;
background-color: #EDF6F9;
border-radius: 3em;
font-size: 18px;
margin: 40px auto 20px auto;
text-decoration: none;
text-align: center;
padding: 6px 10px;
}
.buss .request .manual:hover{
opacity: 0.6;
}
.buss .request h5{
font-size: 24px;
color: #333;
text-align: center;
margin: 0px auto 25px auto;
background: linear-gradient(rgba(0,0,0,0) 0%, rgba(0,0,0,0) 60%, #FFF100 60%, #FFF100 85%,rgba(0,0,0,0) 85%, rgba(0,0,0,0) 100%);
padding: 0;
height: auto;
width: 70%;
display: block;
text-indent: 0;
white-space: nowrap;
overflow: auto;
}
.buss .request .tel{
display: block;
width: 480px;
height: 128px;
margin: 0px auto 40px auto;
background-image: url("../2025image/base/buss_tel.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .request .url{
display: block;
width: 380px;
height: 80px;
margin: 30px auto 80px auto;
}
.buss .request p{
width: 75%;
font-size: 20px;
display: block;
margin: 0px auto 0px auto;
}

/*　　＝＝＝＝＝＝＝　開閉での表示　＝＝＝＝＝＝＝　*/
.hidden_box {
    margin: 2em 0;/*前後の余白*/
    padding: 0;
}

/*ボタン装飾*/
.hidden_box label .label_title1 {
width:70%;
height: 65px;
display: block;
margin: 5px auto;
background-color:#5aae80;
padding: 4px 10%;
border-radius: 65px;
position: relative;
z-index: 10;
}
.hidden_box label .label_title2 {
width:70%;
height: 65px;
display: block;
margin: 5px auto;
background-color:#7b75a9;
padding: 4px 10%;
border-radius: 65px;
}
.hidden_box label .label_title1 img,
.hidden_box label .label_title2 img{
width: 65%;
height: auto;
display: block;
margin: 3px auto 0px auto;
}
.hidden_box label .label_title1:hover{
opacity: 0.5;
}
.hidden_box label .label_title2:hover{
opacity: 0.5;
}

/*ボタンホバー時*/
.hidden_box label:hover {
    background: #efefef;
}

/*チェックは見えなくする*/
.hidden_box input {
    display: none;
}

/*中身を非表示にしておく*/
.hidden_box .hidden_show {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
    padding: 10px 0;
    height: auto;
    opacity: 1;
    overflow:visible;
}

/*背景白　クリックで中身表示*/
.hidden_box .hidden_show_w {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}
/*背景白　クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show_w {
    padding: 50px 0;
    height: auto;margin-top: 40px;
    background-color: #ffffff;
    opacity: 1;
    overflow:visible;
}
/*　　＝＝＝＝＝＝＝＝＝＝＝＝＝＝　*/


/*　　＝＝＝＝＝＝＝　開閉での表示（イエロー・角丸）　＝＝＝＝＝＝＝　*/
.hidden_box_y {
    margin: 2em 0;/*前後の余白*/
    padding: 0;
}


/*ボタンホバー時*/
.hidden_box_y label:hover {
    background: #efefef;
}

/*チェックは見えなくする*/
.hidden_box_y input {
    display: none;
}

/*中身を非表示にしておく*/
.hidden_box_y .hidden_show_y,
.hidden_box_y .hidden_show_y_eve{
    height: 0;
    padding: 0;
    margin: 0 auto;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.hidden_box_y input:checked ~ .hidden_show_y {
    padding: 100px 60px 0px 60px;
    height: auto;
    opacity: 1;
    overflow:visible;
    width: 848px;
    background-color: #ffffff;
    border: solid 2px #fff100;
    border-radius: 30px;
    margin: 0 auto;
    position: relative;
    z-index: 3;
    top: -35px;
    
}
.hidden_box_y input:checked ~ .hidden_show_y_eve {
    padding: 65px 60px 60px 60px;
    height: auto;
    opacity: 1;
    overflow:visible;
    width: 848px;
    background-color: #ffffff;
    border: solid 2px #fff100;
    border-radius: 30px;
    margin: 0 auto;
    position: relative;
    z-index: 3;
    top: -110px;
    
}

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

.buss{
width: 85%;
    padding: 50px 0px 0px 0px;
    height: auto;
    opacity: 1;
    overflow:visible;
    border-radius: 30px;
    margin: 0px auto 70px auto;
    position: relative;
    top: 10px;
    z-index: 3;
}
.buss h3{
display: block;
width: 80%;
height: auto;
margin-left: 18%;
    position: relative;
    top: -135px;
    z-index: 4;
    margin-bottom: -135px;
}
.buss .hidden_box h4{
display: block;
width: 75%;
height: 40px;
margin: -20px auto 40px auto;
}
.buss .hidden_box .hidden_show img{
height: auto;
display: block;
margin: 0px auto 30px auto;
}

.buss .hidden_box .hidden_show .img1{
background-image: url("../2025image/bus/buss_01s.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
width: 80%;
height: 0px;
padding-top: 101%;
}
.buss .hidden_box .hidden_show .img2{
background-image: url("../2025image/bus/0809_oka_sp.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
width: 80%;
height: 0px;
padding-top: 53%;
}
.buss .hidden_box .hidden_show .img3{
background-image: url("../2025image/bus/0809_toku_sp.png");
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
width: 80%;
height: 0px;
padding-top: 99%;
}



.buss h5{
display: block;
width: 70%;
height: 0px;
padding-top: 25%;
margin: 30px auto 0px auto;
background-image: url("../2025image/base/buss_p_s.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .tel{
display: block;
width: 80%;
height: 0px;
padding-top: 35%;
margin:-10px auto 10px auto;
background-image: url("../2025image/base/buss_tel.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .url{
display: block;
width: 80%;
height: 80px;
margin: 20px auto 50px auto;
}
.buss p{
width: 80%;
font-size: 4.3vw;
display: block;
margin: 0px auto 0px auto;
letter-spacing: -1px;
}
.buss .bus_manu{
text-align: justify;
font-size: 4.3vw;
width: 80%;
display: block;
margin: 20px auto 0px auto;
line-height: normal;
padding-bottom: 20px;
}
.buss .hidden_box .hidden_show  .manual{
width: auto;
height: auto;
display: block;
font-size: 4.3vw;
margin: 10px 0px 30px 0px;
text-align: center;
}

/*　　＝＝＝＝＝＝＝　バスツアー申込　別バージョン　＝＝＝＝＝＝＝　*/
.buss .request{
width: 80%;
height: auto;
margin: 0px auto;
display: block;
}

.buss .request .button{
width: 80%;
height: auto;
margin: 10px auto 0px auto;
display: block;
}

.buss .request .manual{
width: 75%;
height: auto;
display: block;
color: #333;
border: 3px solid #47c0cf;
background-color: #BFEAEF;
border-radius: 3em;
font-size: 15px;
margin: 10px auto 20px auto;
text-decoration: none;
text-align: center;
padding: 2px 5px;
}
.buss .request .manual:hover{
opacity: 0.6;
}
.buss .request h5{
font-size: 18px;
color: #333;
text-align: center;
margin: 0px auto 5px auto;
background: linear-gradient(rgba(0,0,0,0) 0%, rgba(0,0,0,0) 60%, #FFF100 60%, #FFF100 85%,rgba(0,0,0,0) 85%, rgba(0,0,0,0) 100%);
padding: 0;
height: auto;
width: 100%;
display: block;
text-indent: 0;
white-space: nowrap;
overflow: auto;
}
.buss .request .tel{
display: block;
width: 100%;
height: 0px;
padding-top: 35%;
margin:0px auto 10px auto;
background-image: url("../2025image/base/buss_tel.svg");
background-position: center center;
background-repeat: no-repeat;
background-size: 100%;
text-indent: 300%;
white-space: nowrap;
overflow: hidden;
}
.buss .request .url{
display: block;
width: 80%;
height: 80px;
margin: 20px auto 50px auto;
}
.buss .request p{
width: 100%;
font-size: 16px;
display: block;
margin: 0px auto 0px auto;
}

}



/* ================================================================= */
/* footer　フッター */
/* ================================================================= */
footer {
clear: both;
width:100%;
height: auto;
padding: 0px 0 80px 0;
margin:100px auto 0px auto;
display: block;
position: relative;
bottom: 0;
overflow: hidden;
}
footer .sns_icon{
	list-style: none;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
footer .sns_icon li{
padding: 0px 15px;
}
footer .sns_icon li a img,
footer .sns_icon li a{
width: 100px;
height: auto;
display: block;
}
footer .sns_icon li a img:hover{
opacity: 0.7;
}
footer .home{
clear: both;
width:400px;
height: auto;
display: block;
margin: 60px auto;
text-align: center;
}
footer .list{
width:auto;
height: auto;
padding: 10px 10px;
display: block;
margin: 60px auto;
text-align: center;
color: #333;
text-decoration: underline;
font-size: 25px;
}
footer .list:hover{
opacity: 0.6;
}
footer .reason{
width:294px;
height: 168px;
display: block;
position: relative;
margin: 0px auto;
}
footer address {
width:100%;
height:auto;
display: inline-block;
margin:50px auto 0px auto;
text-align:center;
font-family: "Hiragino Sans";
font-style: normal;
font-size: 15px;
color: #ffffff;
}
footer address a{
display: block;
text-decoration: none;
}
footer address a:hover{
opacity: 0.6;
}

footer address .f_rogo{
width: 268px;
height: 55px;
display: block;
margin:20px auto;
}
footer address .f_contact{
display: inline-block;
width: 130px;
height: 40px;
padding-top: 20px;
}
footer address .f_tel{
display: inline-block;
width: 130px;
height: 40px;
padding-top: 20px;
}
footer #copyright {
clear: both;
display: block;
width: 100%;
height: 15px;
padding-top: 50px;
padding-bottom:20px;
}
footer #copyright p {
font-size:10pt;
text-align: center;
}
@media screen and (max-width: 787px){
footer {
clear: both;
width:100%;
margin:0px auto 0px auto;
display: block;
position: relative;
bottom: 0;
padding: 20px 0px 110px 0px;
}

footer .sns_icon{
	list-style: none;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
footer .sns_icon li{
padding: 0px 2%;
}

footer .sns_icon li a img,
footer .sns_icon li a{
width: 75px;
display: block;
}
footer .sns_icon li a img:hover{
opacity: 0.7;
}
footer .home{
clear: both;
width:60%;
height: auto;
display: block;
margin: 45px auto 0px auto;
text-align: center;
}
footer .list{
clear: both;
width:70%;
height: auto;
padding: 8px 0px;
display: block;
margin: 45px auto;
text-align: center;
font-size: 5vw;
letter-spacing: -1px;
}
footer .reason{
width:60%;
height: auto;
display: block;
position: relative;
margin: 0px auto;
}
footer address {
width:100%;
height:auto;
display: inline-block;
margin:20px auto 0px auto;
font-size: 15px;
}
footer address a{
display: block;
text-decoration: none;
}
footer address .f_rogo{
width: 60%;
height: 60%;
display: block;
margin:20px auto 10px auto;
}

footer address .f_contact,
footer address .f_tel{
display: inline-block;
width: 40%;
height: 40%;
padding-top: 15px;
}


footer #copyright {
clear: both;
display: block;
width: 100%;
height: auto;
padding-top: 100px;
padding-bottom:0px;
}
footer #copyright p {
font-size:8pt;
text-align: center;
}

}


