@charset "UTF-8";
/******************************************************************************
******************************************************************************
**
** style.cssにおいて ( var.3.1.3 )
** -- baseでは基本タグとサイト大枠のCSS指定
** -- headerではヘッダーのCSS指定
** -- global navではグローバルナビのCSS指定
** -- contentではコンテント・メイン・サイドナビのCSS指定
** -- footerではフッターのCSS指定
** -- pagetopではページトップボタンのCSS指定
** -- indexではトップページのCSS指定
** -- pageでは汎用ページのCSS指定
** -- styleでは汎用ページのコンテンツ（データ入れ）で使用する基本タグのCSS指定
**
** 注意事項
** -- CSSの命名規則はApplicatsオリジナルの命名規則を採用しています。
** -- 初期フォントサイズはreset.cssにて14pxにリセットしています。
** -- 行間は1.6にリセットしています。
**        単位は不要です。(スタイル崩れする可能性有)
** -- コンテンツ内のフォントサイズ・行間は
**        [ base ]のcontentsクラスで指定しています。
**        変更する場合はこちらを変更してください。
**
******************************************************************************
******************************************************************************/
/*-------------------------------------------------------------------------------------------------------
*********************************************************************************************************
*********************************************************************************************************
******
****** PCスタイル
******
*********************************************************************************************************
*********************************************************************************************************
-------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
** base
******************************************************************************
----------------------------------------------------------------------------*/
html, body {
 display: flex;
 flex-direction: column;
}
html {
 scroll-padding-top: 150px !important;
}
body {
 min-height: 100vh;
}
.w_base {
 width: 100%;
 max-width: 1220px;
 margin: 0 auto;
 padding-right: 10px !important;
 padding-left: 10px !important;
}
/*----------------------------------------------------------------------------
******************************************************************************
**  color
******************************************************************************
----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
**  font
******************************************************************************
----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
** header
******************************************************************************
----------------------------------------------------------------------------*/
.hd_bg {
 position: sticky;
 top: 0;
 z-index: 10;
 background: #fff;
}
.hd_bg .hd {
 display: flex;
 justify-content: space-between;
 align-items: center;
 padding: 0.85em 0;
}
.hd_bg .hd .hd_logo a {
 display: flex;
 align-items: center;
 text-decoration: none;
}
.hd_bg .hd .hd_logo a .hd_ttl {
 color: #2B2B2D;
 font-size: 22px;
 font-weight: 500;
 line-height: 1.35;
}
.hd_bg .hd .hd_logo a .hd_ttl span {
 display: block;
 font-size: 14px;
}
.hd_bg .hd .hd_logo a img {
 display: block;
 width: 49px;
 height: 42px;
 margin-right: 10px;
}
.hd_bg .hd .hd_upperct {
 display: flex;
 align-items: center;
 gap: 20px;
}
.hd_bg .hd .hd_upperct > * a {
 display: flex;
 align-items: center;
 gap: 10px;
 padding: 10px 20px;
 color: #2B2B2D;
 font-size: 14px;
 font-weight: 500;
 text-decoration: none;
 border: 1px solid #58BCFF;
 transition: all 0.5s ease;
}
.hd_bg .hd .hd_upperct > * a:hover {
 background: #58BCFF;
 color: #fff;
}
/*----------------------------------------------------------------------------
******************************************************************************
** global nav
******************************************************************************
----------------------------------------------------------------------------*/
.nav_bg .nav .nav_list {
 display: flex;
 width: 100%;
 border-top: 1px solid #D8D8D8;
 border-bottom: 1px solid #D8D8D8;
}
.nav_bg .nav .nav_list > li {
 position: relative;
 z-index: 1000;
 display: flex;
 align-items: center;
 width: 100%;
}
.nav_bg .nav .nav_list > li::before {
 content: "";
 display: block;
 width: 1px;
 height: 70%;
 max-height: 48px;
 background: #D8D8D8;
}
.nav_bg .nav .nav_list > li:last-of-type::after {
 content: "";
 display: block;
 width: 1px;
 height: 70%;
 max-height: 48px;
 background: #D8D8D8;
}
.nav_bg .nav .nav_list > li > a {
 display: block;
 width: 100%;
 padding: 0.9em 0;
 color: #2B2B2D;
 font-weight: 700;
 text-align: center;
 text-decoration: none;
 transition: all 0.5s ease;
}
.nav_bg .nav .nav_list > li > a::after {
 display: block;
 content: attr(data-text);
 color: #88CAF6;
 font-family: "Shippori Mincho", serif;
 font-size: 11px;
 font-weight: 700;
 transition: all 0.5s ease;
}
.nav_bg .nav .nav_list > li > a:hover, .nav_bg .nav .nav_list > li > a.current {
 background: #58BCFF;
 color: #fff;
}
.nav_bg .nav .nav_list > li > a:hover::after, .nav_bg .nav .nav_list > li > a.current::after {
 color: #fff;
}
.nav_bg .nav .nav_list > li.current a {
 background: #58BCFF;
 color: #fff;
}
.nav_bg .nav .nav_list > li.current a::after {
 color: #fff;
}
.nav_bg .nav .nav_list > li:hover .child_wrap {
 display: block;
 animation: nav_active 1s ease 0s 1 alternate;
}
.nav_bg .nav .nav_list > li > .child_wrap {
 position: absolute;
 top: 100%;
 left: 0;
 z-index: 100;
 display: none;
 width: 100%;
 background: #58BCFF;
 transition: All 0.5s ease;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li {
 position: relative;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > a {
 display: flex;
 align-items: center;
 width: 100%;
 padding: 10px;
 background: rgba(0, 0, 0, 0.4);
 color: #fff;
 font-weight: 500;
 border-bottom: 1px solid rgba(255, 255, 255, 0.4);
 text-decoration: none;
 transition: all 0.3s ease;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > a::before {
 content: "";
 display: block;
 width: 5px;
 height: 5px;
 margin-right: 10px;
 border-top: 1px solid #fff;
 border-right: 1px solid #fff;
 transform: rotate(45deg);
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > a:hover {
 background: #58BCFF;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > a:hover::before {
 border-top: 1px solid #fff;
 border-right: 1px solid #fff;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li:hover .child_wrap {
 display: block;
 animation: nav_active 1s ease 0s 1 alternate;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > .child_wrap {
 position: absolute;
 top: 0;
 left: 100%;
 z-index: 100;
 display: none;
 width: 100%;
 background: #58BCFF;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > .child_wrap > .sub-menu > li {
 position: relative;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > .child_wrap > .sub-menu > li > a {
 display: flex;
 align-items: center;
 padding: 10px;
 background-color: rgba(0, 0, 0, 0.7);
 color: #fff;
 text-decoration: none;
 border-bottom: 1px solid rgba(255, 255, 255, 0.4);
 transition: all 0.3s ease;
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > .child_wrap > .sub-menu > li > a::before {
 content: "";
 display: block;
 width: 5px;
 height: 5px;
 margin-right: 10px;
 border-top: 1px solid #fff;
 border-right: 1px solid #fff;
 transform: rotate(45deg);
}
.nav_bg .nav .nav_list > li > .child_wrap > .sub-menu > li > .child_wrap > .sub-menu > li > a:hover {
 background-color: #58BCFF;
}
.nav_bg .nav .nav_list > li:last-of-type > .child_wrap > .sub-menu > li > .child_wrap {
 left: -100%;
}
.nav_bg .nav .nav_upperct {
 display: none;
}
/*----------------------------------------------------------------------------
******************************************************************************
** content
******************************************************************************
----------------------------------------------------------------------------*/
.con_bg .con {
 display: flex;
 flex-wrap: wrap;
 justify-content: space-between;
 padding: 20px 0 100px;
}
.con_bg .con .main {
 order: 1;
 width: 100%;
}
/*----------------------------------------------------------------------------
******************************************************************************
** footer
******************************************************************************
----------------------------------------------------------------------------*/
.ft_bg {
 margin-top: auto;
 background: #ECFAFF;
}
.ft_bg .ft {
 padding: 1.25em 0;
}
.ft_bg .ft .ft_copy {
 display: block;
 font-size: 12px;
 text-align: center;
}
/*----------------------------------------------------------------------------
******************************************************************************
** pagetop
******************************************************************************
----------------------------------------------------------------------------*/
.pt {
 position: fixed;
 right: 30px;
 bottom: 30px;
 z-index: 100;
}
.pt .pt_wrap {
 cursor: pointer;
 display: flex;
 flex-direction: column;
 justify-content: center;
 align-items: center;
 width: 63px;
 height: 54px;
 background: #58BCFF;
 border: 1px solid #58BCFF;
 transition: all 0.3s ease;
}
.pt .pt_wrap .pt_btn {
 position: relative;
 top: 8px;
 cursor: pointer;
 display: block;
 width: 26px;
 height: 26px;
 transform: rotate(45deg);
}
.pt .pt_wrap .pt_btn::before, .pt .pt_wrap .pt_btn::after {
 position: absolute;
 top: 0;
 left: 0;
 content: "";
 display: block;
 background: #FFF;
}
.pt .pt_wrap .pt_btn::before {
 width: 2px;
 bottom: 0;
}
.pt .pt_wrap .pt_btn::after {
 height: 2px;
 right: 0;
}
.pt .pt_wrap .pt_ttl {
 position: relative;
 bottom: 3px;
 color: #fff;
 font-family: "Shippori Mincho", serif;
 font-size: 11px;
 font-weight: 700;
}
.pt .pt_wrap:hover {
 background: #fff;
}
.pt .pt_wrap:hover .pt_btn::before, .pt .pt_wrap:hover .pt_btn::after {
 background: #58BCFF;
}
.pt .pt_wrap:hover .pt_ttl {
 color: #58BCFF;
}
/*----------------------------------------------------------------------------
******************************************************************************
** index
******************************************************************************
----------------------------------------------------------------------------*/
.index_slider_wrap {
 display: flex;
 flex-direction: row-reverse;
 height: 100%;
 max-height: 467px;
 margin-top: 20px;
 margin-bottom: 50px;
}
.index_slider_wrap .index_slider {
 width: 65%;
}
.index_slider_wrap .index_slider img {
 width: 100%;
 height: 100vh;
 max-height: 467px;
 -o-object-fit: cover;
 object-fit: cover;
}
.index_slider_wrap .catchcopy_bg {
 display: flex;
 justify-content: center;
 align-items: center;
 width: 35%;
 padding: 20px;
 border: 1px solid #D8D8D8;
 border-right: none;
}
.index_slider_wrap .catchcopy_bg h2 {
 font-size: 26px;
 font-weight: 400;
 text-align: center;
 line-height: 1.7;
}
.index_main {
 order: 1;
 width: calc(100% - 340px);
}
.index_main .index_news {
 position: relative;
}
.index_main .index_news h2 {
 display: flex;
 align-items: center;
 width: 100%;
 padding: 0.5em 0.8em;
 font-size: 18px;
 font-weight: 500;
 border-bottom: 1px solid #D8D8D8;
}
.index_main .index_news h2::after {
 display: block;
 content: attr(data-text);
 margin-left: 15px;
 color: #88CAF6;
 font-family: "Shippori Mincho", serif;
 font-size: 12px;
 font-weight: 700;
}
.index_main .index_news .index_news_scrl {
 max-height: 400px;
 overflow: auto;
}
.index_main .index_news .index_news_scrl .index_news_item {
 display: flex;
 justify-content: space-between;
 width: 100%;
 padding: 1.8em 0.8em;
 border-bottom: 1px solid #D8D8D8;
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_date {
 width: 90px;
 font-family: "Open Sans", sans-serif;
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_ttl {
 width: calc(100% - 100px);
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_ttl a {
 color: #58BCFF;
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_ttl a:hover {
 text-decoration: none;
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_ttl .index_news_item_icon_new {
 display: inline-block;
 color: #C00;
 font-size: 0.9em;
 font-weight: bold;
 margin-left: 0.3em;
}
.index_main .index_news .index_news_scrl .index_news_item .index_news_item_ttl .index_news_item_icon_new:before {
 content: "NEW";
 font-family: "Open Sans", sans-serif;
}
.index_main .index_news .more {
 position: absolute;
 top: 15px;
 right: 0;
}
.index_main .index_news .more a {
 display: flex;
 align-items: center;
 color: #2B2B2D;
 font-size: 14px;
 font-weight: 500;
 text-decoration: none;
 transition: all 0.5s ease;
}
.index_main .index_news .more a::before {
 display: block;
 content: "";
 width: 15px;
 height: 15px;
 margin-right: 5px;
 background: url(../images/icon_more.svg) no-repeat center center;
}
.index_main .index_news .more a:hover {
 color: #58BCFF;
}
.index_side {
 order: 2;
 width: 300px;
}
.index_side .index_link_list {
 margin-bottom: 20px;
}
.index_side .index_link_list ul {
 display: flex;
 flex-direction: column;
 gap: 20px;
}
.index_side .index_link_list ul .index_link_item {
 border: 1px solid #58BCFF;
}
.index_side .index_link_list ul .index_link_item a {
 position: relative;
 display: flex;
 justify-content: center;
 align-items: center;
 width: 100%;
 padding: 15px;
 color: #2B2B2D;
 font-size: 15px;
 font-weight: 500;
 text-decoration: none;
 transition: all 0.3s ease;
}
.index_side .index_link_list ul .index_link_item a:hover {
 background: #58BCFF;
 color: #fff;
}
.index_side .index_link_list ul .index_link_item.img {
 border: none;
}
.index_side .index_link_list ul .index_link_item.img a {
 padding: 0;
}
.index_side .index_link_list ul .index_link_item.img a img {
 width: 100%;
 height: auto;
}
.index_side .index_link_list ul .index_link_item.twitter a::before {
 background: url(../images/icon_twitter.svg) no-repeat center center;
 background-size: cover;
}
.index_side .index_link_list ul .index_link_item.facebook a::before {
 background: url(../images/icon_facebook.svg) no-repeat center center;
 background-size: cover;
}
.index_side .index_link_list ul .index_link_item.instagram a::before {
 background: url(../images/icon_instagram.svg) no-repeat center center;
 background-size: cover;
}
.index_side .index_bnr_list {
 display: flex;
 flex-direction: column;
 gap: 20px;
 margin-bottom: 20px;
}
.index_side .index_bnr_list .index_bnr_item a {
 display: block;
 padding: 0;
 transition: all 0.3s ease;
}
.index_side .index_bnr_list .index_bnr_item a img {
 width: 100%;
 height: auto;
}
.index_side .index_bnr_list .index_bnr_item a:hover::before {
 opacity: 0.8;
}
/*----------------------------------------------------------------------------
******************************************************************************
** page
******************************************************************************
----------------------------------------------------------------------------*/
.news_list .news_item {
 display: flex;
 justify-content: space-between;
 width: 100%;
 padding: 1.8em 0.8em;
 border-bottom: 1px solid #D8D8D8;
}
.news_list .news_item .news_item_date {
 width: 90px;
 font-family: "Open Sans", sans-serif;
}
.news_list .news_item .news_item_ttl {
 width: calc(100% - 100px);
}
.news_list .news_item .news_item_ttl a {
 color: #58BCFF;
}
.news_list .news_item .news_item_ttl a:hover {
 text-decoration: none;
}
.news_date {
 display: flex;
 justify-content: flex-end;
 margin-top: -10px;
 margin-bottom: 20px;
 font-weight: 500;
}
.facility_list {
 cursor: pointer;
 position: relative;
 width: 100%;
}
.facility_list img {
 height: auto;
 width: 100%;
}
.hover-mask {
 align-items: center;
 background: rgba(0, 0, 0, .5);
 bottom: 14px;
 color: #fff;
 display: flex;
 justify-content: center;
 left: 0;
 opacity: 0;
 position: absolute;
 right: 0;
 transition: opacity .6s ease;
 width: 100%;
 height: auto;
 padding: 10px
}
.hover-mask:hover {
 opacity: 1;
}
.hover-mask p {
 width: 90%;
}
/*----------------------------------------------------------------------------
******************************************************************************
** style
******************************************************************************
----------------------------------------------------------------------------*/
.mcon {
 word-wrap: break-word;
}
.mcon a img:hover {
 opacity: 0.8;
 transition: all 0.3s ease;
}
.mcon h1 {
 position: relative;
 display: flex;
 align-items: center;
 min-height: 120px;
 padding: 20px;
 font-size: 30px;
 font-weight: 500;
 margin-bottom: 20px;
 background: url(../images/ttl_bg.jpg) no-repeat center center;
 background-size: cover;
}
.mcon h1::before {
 position: absolute;
 top: 0;
 left: 0;
 content: "";
 width: 100%;
 height: 100%;
 background: rgba(255, 255, 255, 0.3);
}
.mcon h1 span {
 position: relative;
 z-index: 1;
}
.mcon h2 {
 position: relative;
 width: 100%;
 margin-top: 20px;
 margin-bottom: 10px;
 padding: 0.5em 0.3em;
 font-size: 24px;
 font-weight: 500;
 border-bottom: 1px solid #D8D8D8;
}
.mcon h2::before {
 position: absolute;
 bottom: -1px;
 left: 0;
 content: "";
 width: 100px;
 height: 2px;
 background: #58BCFF;
}
.mcon h3 {
 position: relative;
 margin-top: 20px;
 margin-bottom: 10px;
 padding: 0.5em 0.3em;
 font-size: 20px;
 font-weight: 500;
}
.mcon h3::before {
 position: absolute;
 bottom: 0;
 left: 0;
 content: "";
 width: 80px;
 height: 2px;
 background: #88CAF6;
}
.mcon h4 {
 display: flex;
 align-items: center;
 margin-top: 20px;
 margin-bottom: 10px;
 padding: 0.5em 0.3em;
 font-size: 18px;
 font-weight: 500;
}
.mcon h4::before {
 content: "";
 width: 12px;
 height: 12px;
 margin-right: 10px;
 background: #88CAF6;
}
.mcon h5, .mcon h6 {
 margin-top: 20px;
 margin-bottom: 10px;
 font-size: 1.1em;
 font-weight: 500;
}
.mcon hr {
 border: none;
 border-top: 1px dotted #000;
}
.mcon iframe {
 aspect-ratio: 16/9;
 width: 100%;
 height: 100%;
}
.mcon img {
 max-width: 100%;
 height: auto;
}
.mcon ol {
 margin-top: 1em;
 margin-bottom: 0.5em;
}
.mcon ol li {
 margin-left: 2em;
 margin-bottom: 0.5em;
}
.mcon p {
 margin-bottom: 1em;
}
.mcon ul {
 margin-top: 1em;
 margin-bottom: 0.5em;
}
.mcon ul li {
 margin-left: 1.5em;
 margin-bottom: 0.5em;
}
.tooltip {
 position: relative;
 cursor: pointer;
	margin: 80px 0	
}
.tooltip p {
 margin: 0;
 padding: 0;
}
.fukidashi {
 display: none;
 position: absolute;
 padding: 10px;
 font-size: 14px;
 line-height: 1.6em;
 color: #fff;
 border-radius: 5px;
 background: #000;
 width: auto;
	white-space: nowrap
}
.fukidashi:before {
 content: "";
 position: absolute;
 top: 100%;
 left: 30px;
 border: 10px solid transparent;
 border-top: 15px solid #000;
}
.tooltip:hover .fukidashi {
 display: inline-block;
 top: -60px;
 left: 0;
}



.tooltip_last {
 position: relative;
 cursor: pointer;
	margin: 80px 0	
}
.tooltip_last p {
 margin: 0;
 padding: 0;
}
.fukidashi_last {
 display: none;
 position: absolute;
 padding: 10px;
 font-size: 14px;
 line-height: 1.6em;
 color: #fff;
 border-radius: 5px;
 background: #000;
 width:auto;
	white-space: nowrap
}
.fukidashi_last:before {
 content: "";
 position: absolute;
 top: 100%;
 right: 50px;
 border: 10px solid transparent;
 border-top: 15px solid #000;
}
.tooltip_last:hover .fukidashi_last {
 display: inline-block;
 top: -60px;
 right: 0;
}
/*# sourceMappingURL=style.css.map */