@charset "UTF-8";

/*--------------------*/
/*----main----*/
/*-------------------*/
.main-visial{
background-color: var(--color-red);
width: 100%;
padding: 100px 0 150px 0;
position: relative;
z-index: -2;
overflow: hidden;
}

/* メイン画像 */
.main-visial .main_img{
position: absolute;
z-index: -1;
top: -5vw;
right: -9vw;
width: 53%;
}
.main-visial .main_img_in{
display: none;
}
/*◎2000px以上で表示非表示*/
@media screen and (min-width: 2000px) {
.main-visial .main_img{
display: none;
}
.main-visial .main_img_in{
display: block;
width: 120%;
}
}

/* 画像と文字囲み */
.main-visial .content{
display:grid;
grid-template-columns: 1fr 1fr;
column-gap: 20px;
}

/* 文字全体囲み */
.main-visial .main_info{
/*上下中心 */
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
}

/* 3つの◯ */
.main-visial .point{
display: grid;
grid-template-columns: 1fr 1fr 1fr;
column-gap: 10px;
margin-top: 10px;
}
.main-visial .point li{opacity: 0;}
.main-visial .point li:nth-child(1){animation-delay: 0.3s;}
.main-visial .point li:nth-child(2){animation-delay: 0.5s;}
.main-visial .point li:nth-child(3){animation-delay: 0.7s;}



/* ゲレンデ、営業、天気 共通 */
.slope_info .title,
.slope_info .open-close,
.slope_info .weather-box{
padding: 7px;
  display: grid;
  place-content: center;
}

/*ゲレンデ情報*/
.slope_info{
background-color: var(--color-white);
margin-top: 20px;
border-radius: 15px;
outline: 3px solid;
display: grid;
grid-template-columns: 100px 1fr 1fr;
}
.slope_info .title{
background-color: var(--color-blue);
font-size: var(--s16);
color: var(--color-white);
border-radius: 15px 0 0 15px;
text-align: center;
}

/* 営業情報 */
.slope_info .open-close{
position: relative;
}
.slope_info .open-close::after{
position: absolute;
top:10%;
right: 0;
content: "";
display: block;
width: 1px;
height: 80%;
background-color: var(--color-gray);
}
.slope_info .open-close .telopText{
font-size: var(--s30);
}

/* 天気 */
.slope_info .weather-box{
grid-template-columns: 1fr 1fr;
}
.slope_info .weather-box .img{
width: 100%;
text-align: right;
padding-right: 5px;
}
.slope_info .weather-box .temperature{
font-size: var(--s20);
}


/*-------------縦（これは横の上）--------------*/
/*高さ800px以下（ノートパソコン対策）*/
@media screen and (max-height: 800px) {
.main-visial{
padding: 80px 0 150px 0;
}
.main-visial .main_img{
top: -5vw;
right: -4vw;
width: 54%;
}
.main-visial .content{
grid-template-columns: 45% 1fr;
column-gap: 0;
}
.main-visial .content .point{
width: 80%;
margin: 0 auto;
}
}


/*-------------幅--------------*/
/*◎幅1400px以下*/
@media screen and (max-width: 1400px) {
.main-visial .main_img{width: 60%;}
.main-visial .content{
grid-template-columns: 40% 1fr;
column-gap: 0;
}
}
/*◎幅1100px以下*/
@media screen and (max-width: 1100px) {
.main-visial{
padding: 120px 0 130px 0;
}
.main-visial .main_img{
width: 70%;
top: -1vw;
right: -13vw;
}
.main-visial .content{
grid-template-columns: 47% 1fr;
}
}
/*◎860px以下*/
@media screen and (max-width: 860px) {
.main-visial{
padding: 100px 0 30vw 0;
}
.main-visial .main_img{
top: -10vw;
right: -15vw;
width: 70vw;
}
.main-visial .content{
  display:block;
}
.main-visial .content .main_title{
width: 55vw;
}
.main-visial .content .point{
width: 80%;
margin: 0 auto;
}
.slope_info .title,
.slope_info .open-close,
.slope_info .weather-box{
padding: 5px;
}
.slope_info{
border-radius: 7px;
display: grid;
grid-template-columns: 50% 50%;
  grid-template-areas:
    "areaA areaA"
    "areaB areaC";
}
.slope_info .title{
font-size: var(--s14);
border-radius: 7px 7px 0 0;
grid-area: areaA;
}
.slope_info .title br{display: none;}
.slope_info .open-close{
grid-area: areaB;
}
.slope_info .open-close .telopText{
font-size: var(--s18);
}
.slope_info .weather-box{
grid-area: areaC;
}
.slope_info .weather-box .temperature{
font-size: var(--s16);
}
}
/*◎400px以下*/
@media screen and (max-width: 400px) {
.main-visial .content .point{
width: 85%;
}
}







/*--------------------*/
/*----news----*/
/*-------------------*/
.top-topics{
background-color: var(--color-white);
border-radius: var(--radius);
margin-top:var(--box_m_top);
padding-top: 80px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.top-topics{
border-radius: var(--radius-sp);
margin-top:var(--box_m_top-sp);
padding-top: 50px;
}
}

.top-topics .content{
position: relative;
}

.top-topics .top-topics-bt{
text-align: center;
margin: 30px 0;
}

/*キャラクター*/
.top-topics .top-character{
width: 43%;
display: grid;
grid-template-columns: 1fr 1fr;
column-gap: 10px;
position: absolute;
top:-25vw;
right: 0;
}


/*-------------縦（これは横の上）--------------*/
/*高さ800px以下（ノートパソコン対策）*/
@media screen and (max-height: 800px) {
.top-topics .top-character{
width: 42%;
top:-15vw;
right: 0;
}
}

/*-------------横--------------*/
/*◎1000px以上*/
@media screen and (min-width: 1000px) {
.top-topics .top-character{
width: 400px;
top:-250px;
}
}

/*◎幅1100px以下*/
@media screen and (max-width: 1100px) {
.top-topics .top-character{
width: 42%;
top:-23vw;
}
}
/*◎860px以下*/
@media screen and (max-width: 860px) {
.top-topics .top-character{
width: 50%;
top:-22vw;
}
}
/*◎670px以下*/
@media screen and (max-width:670px) {
.top-topics .top-character{
width: 60%;
top:-25vw;
right: -5vw;
}
}
/*◎400px以下*/
@media screen and (max-width:400px) {
.top-topics .top-character{
width: 60%;
top:-28vw;
}
}




/*--------------------*/
/*----opening----*/
/*-------------------*/
.op{
margin-top: 150px;
position: relative;
overflow: hidden;
padding-top: 5vw;
margin-bottom: 200px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.op{
margin-bottom: 100px;
}
}

.op .op_img{
width: 55%;
max-width: 700px;
position: absolute;
top:0;
right: -10vw;
}
.op .op_info_img{
display: none;
}
/*◎1500px以上で表示非表示*/
@media screen and (min-width: 1500px) {
.op .op_img{
display: none;
}
.op .op_info_img{
display: block;
}
}

.op .content{
display:grid;
grid-template-columns: 1fr 1fr;
column-gap: 20px;
}
/*◎950px以下*/
@media screen and (max-width: 950px) {
.op{
margin-top: 100px;
padding-top: 0;
padding-bottom: 65vw;
}
.op .content{
display:block;
}
.op .op_img{
width: 70vw;
max-width: 70vw;
top:auto;
right: 0;
left: 0;
bottom: 0;
margin: 0 auto;
}
}

/* 営業概要 */
.op .op_info .box01{
margin-top: 30px;
}
.op .op_info dl{
display: grid;
grid-template-columns: 50px 1fr;
column-gap: 10px;
margin-bottom: 10px;
}
.op .op_info dl:last-child{
margin-bottom: 0px;
}
.op .op_info dt{
color: var(--color-white);
background-color: var(--color-black);
padding: 5px;
border-radius: 10px;
  display: grid;
  place-items: center;
}
.op .op_info dd p{
font-size: var(--s20);
}



/*--------------------*/
/*----slop map----*/
/*-------------------*/
.slope_map{
border-radius: var(--radius);
margin-top:var(--box_m_top);
background-color: var(--color-red);
padding: 100px 0;
background-image: url(../img/cours_back.webp);
background-size:contain;
background-position:top center;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.slope_map{
border-radius: var(--radius-sp);
margin-top:var(--box_m_top-sp);
margin-top: 80px;
padding: 50px 0;
}
}

.slope_map .content{
margin-bottom: 80px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.slope_map .content{
margin-bottom: 50px;
}
}

.slope_map .title01 .ja_txt{
color: var(--color-white);
}

/* タイトル */
.slope_map .slope_title{
display: grid;
grid-template-columns:1fr 250px;
}
.slope_map .slope_title .title01 .en-se_txt{
margin-top: -20px;
}
.slope_map .slope_title .img{
margin-top: -40px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.slope_map .slope_title{
display:block;
}
.slope_map .slope_title .title01 .en-se_txt{
margin-top: -10px;
}
.slope_map .slope_title .img{
margin-top: -10vw;
text-align: right;
}
.slope_map .slope_title .img img{
width: 55%;
}
}




/* マップ画像 */
.slope_map .slope_map_img{
margin: 30px 0 20px 0;
text-align: center;
}
.slope_map .slope_map_img img{
outline: 3px solid var(--color-black);
border-radius: 10px;
}
.slope_map .slope_map_img a{
display:inline-block;
margin-top: 30px;
}

/* コースリスト*/
.slope_map .slope_course{
margin-top: 40px;
}
.slope_map .slope_course .slope_course_list{
display:grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 20px;
}
.slope_map .slope_course .slope_course_list .item img{
outline: 3px solid var(--color-black);
border-radius: 10px;
}
.slope_map .slope_course .slope_course_list .item figcaption{
color: var(--color-white);
margin-top: 5px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.slope_map .slope_course .slope_course_list{
grid-template-columns: repeat(2, auto);
gap: 10px;
}
}





/*--------------------*/
/*----lift_fees----*/
/*-------------------*/
.lift_fees{
border-radius: var(--radius);
margin-top:var(--box_m_top);
background-color: var(--color-white);
padding: 100px 0;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.lift_fees{
padding: 50px 0;
border-radius: var(--radius-sp);
margin-top:var(--box_m_top-sp);
}
}


.lift_fees_info{
display: grid;
grid-template-columns: 1fr 1fr;
column-gap: 50px;
}
/*◎900px以下*/
@media screen and (max-width: 900px) {
.lift_fees_info{
display: block;
}
}

.lift_fees_info .title03{
display: block;
}
.lift_fees_info table{
width: 100%;
}
.lift_fees_info table td{
text-align: center;
}
.lift_fees_info .list_kome{
margin: 10px 0;
}


/* 団体 */
/*◎900px以下*/
@media screen and (max-width: 900px) {
.lift_group{
margin-top: 80px;
}
}
.lift_group .box02 dl{
display: grid;
grid-template-columns: 70px 1fr;
column-gap: 10px;
border-bottom: 1px solid;
padding: 10px 0;
}
.lift_group .box02 dt{
background-color: var(--color-white);
border: 1px solid;
border-radius: 5px;
padding: 5px;
  display: grid;
  place-items: center;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.lift_group .box02 dl{
display:block;
padding: 10px 0;
margin: 10px 0px 10px 0;
border-bottom: 0px;
}
.lift_group .box02 dt{
margin-bottom: 5px;
}
}


.lift_group .box02 .tel{
display: block;
font-size: var(--s30);
margin: 10px 0;
}

/* レンタル */
.lift_fees .box01{
text-align: center;
margin-top: 50px;
}
.lift_fees .box01 .list_maru{
display: flex;
justify-content: center;
flex-wrap: wrap;
}
.lift_fees .box01 .list_maru li{
margin: 3px 15px;
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.lift_fees .box01{
text-align:left;
}
}



/*--------------------*/
/*----Access----*/
/*-------------------*/
.access {
margin-top: 80px;
}
/*◎900px以下*/
@media screen and (max-width: 900px) {
.access {
margin-top: 50px;
}
}

.access .inner{
display: grid;
grid-template-columns: 1fr 1fr;
column-gap: 30px;
}
/*◎900px以下*/
@media screen and (max-width: 900px) {
.access .inner{
display: block;
}
}

.access .access_info :is(.jr, .buss, .car){
border-top:1px solid var(--color-gray-table);
display: grid;
grid-template-columns: 50px 1fr;
column-gap: 20px;
margin: 5px 0;
padding: 5px 0;
}
.access .access_info :is(.jr, .buss, .car) .title{
border: 1px solid var(--color-gray-table);
padding: 5px;
border-radius: 5px;
margin: 5px 0;
  display: grid;
  place-items: center;
}

/* jr */
.access .access_info .jr{
margin-top: 30px;
}
.access .access_info .jr .list_maru li::before {
background-color: var(--color-red);
}

/* buss */
.access .access_info .buss .list_maru li:first-child{
border-bottom:1px solid var(--color-gray-table);
}
.access .access_info .buss .list_maru li::before {
background-color:#0073C1;
}

/* car */
.access .access_info .car{
border-bottom:1px solid var(--color-gray-table);
}
.access .access_info .car .list_maru li::before {
background-color: #00943A;
}

/* 地図 */
/*◎900px以下*/
@media screen and (max-width: 900px) {
.access_map{
margin-top: 40px;
}
}
.access_map .img{
position: relative;
}
.access_map .img img{
width: 35%;
position: absolute;
top: -50px;
right: 0;
}
/*◎900px以下*/
@media screen and (max-width: 900px) {
.access_map .img img{
width: 20%;
}
}
/*◎768px以下*/
@media screen and (max-width: 768px) {
.access_map .img img{
width: 30%;
}
}

.access_map iframe{
width: 100%;
height: 400px;
}
/*◎900px以下*/
@media screen and (max-width: 900px) {
.access_map iframe{
width: 100%;
height: 300px;
}
}