@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クラスで指定しています。
**        変更する場合はこちらを変更してください。
**
******************************************************************************
******************************************************************************/
/*-------------------------------------------------------------------------------------------------------
*********************************************************************************************************
*********************************************************************************************************
******
****** style
******
*********************************************************************************************************
*********************************************************************************************************
-------------------------------------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
** base
******************************************************************************
----------------------------------------------------------------------------*/
html, body {
 display: flex;
 flex-direction: column;
}
html {
 scroll-padding-top: 120px !important;
}
body {
 min-height: 100vh;
}
/*----------------------------------------------------------------------------
******************************************************************************
**  color
******************************************************************************
----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
**  font
******************************************************************************
----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------
******************************************************************************
** header
******************************************************************************
----------------------------------------------------------------------------*/
.hd_bg {
 position: sticky;
 top: 0;
 z-index: 10;
 height: 80px;
 background: #fff;
}
.hd_bg .hd {
 display: flex;
 align-items: center;
 height: 100%;
 padding: 0 10px;
}
.hd_bg .hd .hd_logo {
 width: calc(100% - 12vw);
}
.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: 15px;
 line-height: 1.35;
}
.hd_bg .hd .hd_logo a .hd_ttl span {
 display: block;
 font-size: 13px;
 font-weight: 400;
}
.hd_bg .hd .hd_logo a img {
 display: block;
 width: 49px;
 height: 42px;
 margin-right: 10px;
}
.hd_bg .hd .hd_upperct {
 display: none;
}
/*----------------------------------------------------------------------------
******************************************************************************
** global nav
******************************************************************************
----------------------------------------------------------------------------*/
.nav {
 position: fixed;
 top: 80px;
 right: -100%;
 z-index: 100;
 overflow-x: none;
 overflow-y: auto;
 width: 100%;
 height: calc(100% - 80px);
 padding: 10px;
 background: #00538a;
 color: #fff;
 transition: All 0.5s ease;
}
.nav .nav_list {
 background: #58BCFF;
}
.nav .nav_list > li {
 position: relative;
}
.nav .nav_list > li > a {
 position: relative;
 display: block;
 padding: 1em 1em 1em 1.5em;
 color: #fff;
 font-weight: 700;
 text-decoration: none;
 border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
.nav .nav_list > li > a::after {
 display: block;
 content: attr(data-text);
 color: #fff;
 font-family: "Shippori Mincho", serif;
 font-size: 11px;
 font-weight: 700;
 transition: all 0.5s ease;
}
.nav .nav_list > li > a:hover, .nav .nav_list > li > a.current {
 background: #58BCFF;
 color: #fff;
}
.nav .nav_list > li > a:hover::after, .nav .nav_list > li > a.current::after {
 color: #fff;
}
.nav .nav_list > li .child_wrap_btn {
 position: absolute;
 top: 1.35em;
 right: 0.5em;
 z-index: 10;
 flex-shrink: 0;
 width: 30px;
 height: 30px;
 background: #88CAF6;
}
.nav .nav_list > li .child_wrap_btn::before, .nav .nav_list > li .child_wrap_btn::after {
 position: absolute;
 content: "";
 width: 15px;
 height: 1px;
 background-color: #fff;
}
.nav .nav_list > li .child_wrap_btn::before {
 top: 50%;
 left: 50%;
 transform: rotate(0deg) translateX(-50%);
}
.nav .nav_list > li .child_wrap_btn::after {
 top: 50%;
 left: 0.5em;
 transform: rotate(90deg);
 transition: all 0.3s ease;
}
.nav .nav_list > li .child_wrap_btn.close::after {
 transform: rotate(0deg);
}
.nav .nav_list > li .child_wrap {
 display: none;
}
.nav .nav_list > li .child_wrap > .sub-menu li {
 position: relative;
}
.nav .nav_list > li .child_wrap > .sub-menu li a {
 display: flex;
 align-items: center;
 padding: 1em 1em 1em 1.5em;
 background: rgba(0, 0, 0, 0.4);
 color: #fff;
 font-size: 13px;
 text-decoration: none;
 border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}
.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 .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn {
 position: absolute;
 top: 0.65em;
 right: 0.5em;
 z-index: 10;
 flex-shrink: 0;
 width: 30px;
 height: 30px;
 background: #58BCFF;
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn::before, .nav .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn::after {
 position: absolute;
 content: "";
 width: 15px;
 height: 1px;
 background-color: #fff;
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn::before {
 top: 50%;
 left: 50%;
 transform: rotate(0deg) translateX(-50%);
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn::after {
 top: 50%;
 left: 0.5em;
 transform: rotate(90deg);
 transition: all 0.3s ease;
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap_btn.close::after {
 transform: rotate(0deg);
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap > .sub-menu li {
 position: relative;
}
.nav .nav_list > li .child_wrap > .sub-menu li .child_wrap > .sub-menu li a {
 display: flex;
 align-items: center;
 padding: 1em 1em 1em 2em;
 background-color: rgba(0, 0, 0, 0.7);
 color: #fff;
 font-size: 11px;
 text-decoration: none;
 border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}
.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 .nav_list > li .child_wrap > .sub-menu li .child_wrap > .sub-menu li .child_wrap > .sub-menu {
 background: #ccc;
}
.nav .nav_upperct {
 display: flex;
 gap: 10px;
 padding: 15px 10px;
 background: #fff;
}
.nav .nav_upperct > * {
 width: 100%;
}
.nav .nav_upperct > * a {
 display: flex;
 justify-content: center;
 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;
}
.nav .nav_upperct > * a:hover {
 background: #58BCFF;
 color: #fff;
}
.sp_nav_open {
 right: 0 !important;
}
.sp_nav_trigger {
 cursor: pointer;
 z-index: 1000;
 position: fixed !important;
 top: 25px;
 right: 15px;
 margin-top: -5px;
 width: 36px;
 height: 24px;
}
.sp_nav_trigger span {
 display: inline-block;
 position: absolute;
 left: 0;
 width: 100%;
 height: 4px;
 background-color: #000;
 border-radius: 4px;
 transition: all 0.4s;
 box-sizing: border-box;
}
.sp_nav_trigger span:nth-of-type(1) {
 top: 0;
}
.sp_nav_trigger span:nth-of-type(2) {
 top: 10px;
}
.sp_nav_trigger span:nth-of-type(3) {
 bottom: 0;
}
.sp_nav_trigger::after {
 position: absolute;
 left: 0;
 bottom: -20px;
 content: "MENU";
 display: block;
 width: 100%;
 padding-top: 20px;
 color: #000;
 font-size: 10px;
 text-decoration: none;
 text-align: center;
 transition: all 0.4s;
}
.sp_nav_trigger.sp_active::after {
 content: "CLOSE";
 bottom: -25px;
}
.sp_nav_trigger.sp_active span:nth-of-type(1) {
 transform: translateY(10px) rotate(-45deg);
}
.sp_nav_trigger.sp_active span:nth-of-type(2) {
 opacity: 0;
}
.sp_nav_trigger.sp_active span:nth-of-type(3) {
 transform: translateY(-10px) rotate(45deg);
}
/*----------------------------------------------------------------------------
******************************************************************************
** content
******************************************************************************
----------------------------------------------------------------------------*/
.con {
 padding: 0 10px 30px;
}
.con .main {
 margin-bottom: 30px;
}
.con .side .side_head {
 background-color: #EEE;
 color: #111;
 font-size: 16px;
 font-weight: bold;
 margin-bottom: 6px;
 padding: 10px;
 text-align: center;
}
.con .side .side_nav_list li a {
 background: url(../images/icon_arrow_gray.png) no-repeat left center;
 border-bottom: 1px solid #CCC;
 color: #111;
 display: block;
 font-size: 14px;
 padding: 12px 10px;
 text-decoration: none;
}
.con .side .side_nav_list li a:hover {
 text-decoration: underline;
}
/*----------------------------------------------------------------------------
******************************************************************************
** footer
******************************************************************************
----------------------------------------------------------------------------*/
.ft_bg {
 margin-top: auto;
 background: #ECFAFF;
}
.ft_bg .ft {
 padding: 1.25em 0;
}
.ft_bg .ft .ft_copy {
 display: block;
 color: #2B2B2D;
 font-family: "Open Sans", sans-serif;
 font-size: 11px;
 text-align: center;
}
/*----------------------------------------------------------------------------
******************************************************************************
** pagetop
******************************************************************************
----------------------------------------------------------------------------*/
.pt {
 position: fixed;
 right: 15px;
 bottom: 15px;
 z-index: 1;
}
.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 {
 margin-bottom: 20px;
}
.index_slider_wrap .index_slider img {
 width: 100%;
 height: 100vh;
 max-height: 400px;
 -o-object-fit: cover;
 object-fit: cover;
}
.index_slider_wrap .catchcopy_bg {
 display: flex;
 justify-content: center;
 align-items: center;
 padding: 20px;
 border: 1px solid #D8D8D8;
 border-top: none;
}
.index_slider_wrap .catchcopy_bg h2 {
 display: flex;
 justify-content: center;
 align-items: center;
 font-size: 24px;
 font-weight: 400;
 line-height: 1.7;
}
.index_main .index_news {
 position: relative;
}
.index_main .index_news h2 {
 width: 100%;
 padding: 0.5em 0.8em;
 color: #2B2B2D;
 font-size: 18px;
 font-weight: 500;
 border-bottom: 1px solid #D8D8D8;
}
.index_main .index_news h2::after {
 display: block;
 content: attr(data-text);
 color: #88CAF6;
 font-family: "Shippori Mincho", serif;
 font-size: 12px;
 font-weight: 700;
}
.index_main .index_news .index_news_scrl {
 max-height: 40vh;
 overflow: auto;
}
.index_main .index_news .index_news_scrl .index_news_item {
 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 {
 margin-bottom: 10px;
 font-family: "Open Sans", sans-serif;
}
.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 {
 display: flex;
 justify-content: center;
 width: 80%;
 margin: 30px auto 50px;
}
.index_main .index_news .more a {
 display: flex;
 justify-content: center;
 align-items: center;
 width: 100%;
 padding: 20px;
 color: #2B2B2D;
 font-weight: 500;
 text-decoration: none;
 border: 1px solid #58BCFF;
 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 .index_link_list {
 margin-bottom: 20px;
}
.index_side .index_link_list ul {
 display: flex;
 flex-wrap: wrap;
 gap: 20px;
}
.index_side .index_link_list ul .index_link_item {
 width: calc((100% - 20px) / 2);
 border: 1px solid #D8D8D8;
}
.index_side .index_link_list ul .index_link_item a {
 position: relative;
 display: flex;
 justify-content: center;
 align-items: center;
 width: 100%;
 height: 100%;
 padding: 10px 15px;
 color: #2B2B2D;
 font-size: 14px;
 text-decoration: none;
 transition: all 0.3s ease;
}
.index_side .index_link_list ul .index_link_item a:hover {
 background: #ECFAFF;
}
.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-wrap: wrap;
 gap: 20px;
 margin-bottom: 20px;
}
.index_side .index_bnr_list .index_bnr_item {
 width: calc((100% - 20px) / 2);
}
.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 {
 width: 100%;
 padding: 1.8em 0.8em;
 border-bottom: 1px solid #D8D8D8;
}
.news_list .news_item:first-of-type {
 border-top: 1px solid #D8D8D8;
}
.news_list .news_item .news_item_date {
 margin-bottom: 10px;
 font-family: "Open Sans", sans-serif;
}
.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: 0;
 color: #fff;
 display: flex;
 height: auto;
 justify-content: center;
 left: 0;
 opacity: 0;
 position: absolute;
 right: 0;
 bottom: 0;
 transition: opacity .6s ease;
 width: 100%;
 height: auto;
 padding: 10px
}
.hover-mask:hover {
 opacity: 1;
}
.hover-mask p {
 width: 80%;
}
/*----------------------------------------------------------------------------
******************************************************************************
** style
******************************************************************************
----------------------------------------------------------------------------*/
.mcon {
 line-height: 1.6;
 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: 90px;
 padding: 20px;
 font-size: 26px;
 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;
 color: #2B2B2D;
 font-size: 22px;
 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;
 color: #2B2B2D;
 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;
 color: #2B2B2D;
 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;
 color: #2B2B2D;
 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: 100px 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;
 overflow-wrap: break-word;
}
/*.fukidashi:before {
 content: "";
 position: absolute;
 top: 100%;
 left: 10px;
 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;
 overflow-wrap: break-word;
}
/*.fukidashi_last:before {
 content: "";
 position: absolute;
 top: 100%;
 right: 100px;
 border: 10px solid transparent;
 border-top: 15px solid #000;
}*/
.tooltip_last:hover .fukidashi_last {
 display: inline-block;
 top: -60px;
 right: 0;
}
/*-------------------------------------------------------------------------------------------------------
*********************************************************************************************************
*********************************************************************************************************
******
****** tabスタイル
******
*********************************************************************************************************
*********************************************************************************************************
-------------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 415px) and (max-width: 1024px) {
 /*----------------------------------------------------------------------------
  ******************************************************************************
  ** index
  ******************************************************************************
  ----------------------------------------------------------------------------*/
 /*----------------------------------------------------------------------------
  ******************************************************************************
  ** page
  ******************************************************************************
  ----------------------------------------------------------------------------*/
} /*# sourceMappingURL=sp.css.map */