@charset 'UTF-8';
@import url('https://fonts.googleapis.com/css2?family=Edu+TAS+Beginner:wght@400..700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Maru+Gothic:wght@400;500;700;900&display=swap');
/*
.zen-maru-gothic-regular {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.zen-maru-gothic-medium {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.zen-maru-gothic-bold {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.zen-maru-gothic-black {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 900;
  font-style: normal;
}
*/
/*===============================================================

common

===============================================================*/
/*　List
---------------------------------------- */
.nolist {
    list-style:none;
    padding:0;
    margin:0;
}

/*　br
---------------------------------------- */
@media only screen and (max-width: 768px) {
    .brPc {
        display:none;
    }
}
.entry-header {
    background-image:url(../images/common/waveBk.svg);
    background-position:bottom;
    background-repeat:no-repeat;
    background-size:contain;
    height:20vh;
    position:relative;
}
.entry-header .breadcrumbs {
    position:absolute;
    right:0;
    bottom:0;
}
@media only screen and (max-width: 768px) {
    .entry-header {
        height:100px;
    }
    .entry-header .breadcrumbs {
        bottom:-20px;
    }
}

.page-content,
.entry-content {
    background-color:#eef3fa;
    padding-bottom:60px;
}
@media only screen and (max-width: 768px) {
    .page-content,
    .entry-content {
        padding-top:30px;
    }
}

.indexList {
    display:flex;
    flex-wrap:wrap;
    list-style:none;
    justify-content:flex-start;
    gap:20px;
    margin:0;
}
.indexList li {
    width:calc(33.3% - 20px);
    text-align:center;
}
.indexList li a {
    text-decoration:none;
    display:block;
    color:#0068b7;
    font-weight:900;
}
.indexList li .index_listImg {
    width:100%;
    aspect-ratio:651/416;
    overflow:hidden;
    border-radius:8px;
}
.indexList li .index_listImg img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
@media only screen and (max-width: 768px) {
    .indexList {
        gap:10px;
    }
    .indexList li {
        width:calc(50% - 10px);
    }
}

.pager {
    margin:40px 0;
}
.pager .flexContainer {
    display:flex;
    border-top:1px solid #cccccc;
    border-bottom:1px solid #cccccc;
}
.pager .flexContainer > div {
    width:33.333%;
    text-align:center;
}
.pager .flexContainer > div a {
    display:block;
    width:100%;
    height:100%;
    padding:20px;
    text-decoration:none;
    color:#333333;
    font-weight:bold;
    transition:all 0.3s ease;
}
.pager .flexContainer > div a:hover {
    background-color:#0068b7;
    color:#ffffff;
}
.pager .flexContainer .prev,
.pager .flexContainer .back {
    border-right:1px solid #cccccc;
}

.childrenFlex {
    margin:2em 0;
    display:flex;
    gap:15px;
    flex-wrap:wrap;
    justify-content:center;
}
.childrenFlex .children__item {
    width:calc(25% - 15px);
}
.childrenFlex .children__item .itemInner a {
    display:block;
    width:100%;
    background-color:#0068b7;
    color:#ffffff;
    text-align:center;
    padding:15px 5px;
    border-radius:30px;
    text-decoration:none;
    transition:0.15s all;
    font-size:1.4rem;
}
.childrenFlex .children__item .itemInner a:hover {
    background-color:#35bf9e;
}

@media only screen and (max-width: 768px) {
    .childrenFlex .children__item {
        width:calc(50% - 15px);
    }
}
@media only screen and (max-width: 480px) {
    .childrenFlex .children__item {
        width:calc(100% - 0px);
    }
}
/*===============================================================

header

===============================================================*/
.head__layout1 {
    position:relative;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
}
.head__layout1 h1.site-title {
    margin:0;
    padding:5px;
}
.head__layout1 h1.site-title img {
    max-width:260px;
}
@media only screen and (max-width: 480px) {
    .head__layout1 h1.site-title {
        padding:11px 5px;
    }
    .head__layout1 h1.site-title img {
        max-width:200px;
    }
}
.head__layout1 .branding__nav {
    margin-right:150px;
}
.head__layout1 .btnMenu {
    position:absolute;
    top:0;
    right:70px;
    line-height:1.2;
}
.head__layout1 .btnMenu a {
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    width:70px;
    height:70px;
    background:#35bf9e;
    color:#ffffff;
    text-decoration:none;
}
.head__layout1 .btnMenu a i {
    font-size:3rem;
}
.head__layout1 .btnMenu a span {
    display:block;
    font-size:1.2rem;
}
@media only screen and (max-width: 980px) {
    .head__layout1 nav.glNaviPc {
        display:none;
    }
    .head__layout1 .branding__nav {
        display:none;
    }
}

/*===============================================================

gmnavi

===============================================================*/
.site-gnav {
    list-style:none;
    margin:0 0 0 0;
    padding:0;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:500;
}
.site-gnav li a {
    text-decoration:none;
    color:#0068b7;
}

/*==ナビゲーション全体の設定*/
nav.glNaviPc {
    color:#0068b7;
    text-align:left;
}
nav.glNaviPc ul.site-gnav {
    list-style:none;
    margin:px 0 0 0;
    padding:0;
    display:flex;
    align-items:flex-end;
    gap:15px;
}
nav.glNaviPc ul.site-gnav li a {
    display:inline-block;
    text-decoration:none;
    color:#333333;
    font-size:1.8rem;
}
nav.glNaviPc ul.site-gnav li.has-mega {
    position:relative;
}
nav.glNaviPc ul.site-gnav li.has-mega > a {
    position:relative;
    padding-right:1.6em;
}
nav.glNaviPc ul.site-gnav li.has-mega > a::before,
nav.glNaviPc ul.site-gnav li.has-mega > a::after {
    content:'';
    position:absolute;
    top:50%;
    right:0.4em;
    width:8px;
    height:2px;
    background-color:#333333;
    transform-origin:center;
    transition:transform 0.3s ease;
}
nav.glNaviPc ul.site-gnav li.has-mega > a::before {
    transform:translateY(-50%) rotate(45deg);
}
nav.glNaviPc ul.site-gnav li.has-mega > a::after {
    transform:translateY(-50%) rotate(-45deg);
    right:0.1em;
}
nav.glNaviPc ul.site-gnav li.has-mega.active > a::before {
    transform:translateY(-50%) rotate(-45deg);
}
nav.glNaviPc ul.site-gnav li.has-mega.active > a::after {
    transform:translateY(-50%) rotate(45deg);
}

/* ── メガメニュー本体 ───────────────────────── */
.mega-menu {
    /* 非表示時 = 少し上に隠れている */
    opacity:0;
    transform:translateY(-30px);
    /* ← 上方へオフセット（縮小はしない） */
    visibility:hidden;
    pointer-events:none;
    transition:opacity 0.4s ease, transform 0.45s cubic-bezier(0.25, 0.8, 0.25, 1);
    /* 表示時 */
}
.mega-menu.active {
    opacity:1;
    transform:translateY(0);
    /* 0 まで滑らかに下りてくる */
    visibility:visible;
    pointer-events:auto;
}
.mega-menu {
    /* 以降はレイアウトなど前回と同じ ---------------------- */
    position:fixed;
    left:0;
    width:100vw;
    top:0;
    top:70px;
    /* JS でヘッダー高を上書き */
    z-index:998;
    background:#002c76;
    padding:15px 0;
}
.mega-menu .mega-inner {
    max-width:1300px;
    margin:0 auto;
    padding:30px 32px;
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
    gap:15px;
    justify-items:center;
    /* 子リンクの遅延フェード */
}
.mega-menu .mega-inner a {
    display:block;
    text-decoration:none;
    color:#222222;
    opacity:0;
    transform:translateY(10px);
    animation:fadeUp 0.45s forwards;
    width:100%;
    /* カード幅を揃えたい場合は指定 */
    text-align:center;
    /* 文字列を中央揃え             */
}
.mega-menu .mega-inner a:nth-child(1) {
    animation-delay:0.05s;
}
.mega-menu .mega-inner a:nth-child(2) {
    animation-delay:0.1s;
}
.mega-menu .mega-inner a:nth-child(3) {
    animation-delay:0.15s;
}
.mega-menu .mega-inner a:nth-child(4) {
    animation-delay:0.2s;
}
.mega-menu .mega-inner a:nth-child(5) {
    animation-delay:0.25s;
}
.mega-menu .mega-inner a:nth-child(6) {
    animation-delay:0.3s;
}
.mega-menu .mega-inner a:nth-child(7) {
    animation-delay:0.35s;
}
.mega-menu .mega-inner a:nth-child(8) {
    animation-delay:0.4s;
}
.mega-menu .mega-inner a:nth-child(9) {
    animation-delay:0.45s;
}
.mega-menu .mega-inner a:nth-child(10) {
    animation-delay:0.5s;
}
.mega-menu .mega-inner a:nth-child(11) {
    animation-delay:0.55s;
}
.mega-menu .mega-inner a:nth-child(12) {
    animation-delay:0.6s;
}
.mega-menu .mega-inner a:nth-child(13) {
    animation-delay:0.65s;
}
.mega-menu .mega-inner a:nth-child(14) {
    animation-delay:0.7s;
}
.mega-menu .mega-inner a:nth-child(15) {
    animation-delay:0.75s;
}
.mega-menu .mega-inner a:nth-child(16) {
    animation-delay:0.8s;
}
.mega-menu .mega-inner a:nth-child(17) {
    animation-delay:0.85s;
}
.mega-menu .mega-inner a:nth-child(18) {
    animation-delay:0.9s;
}
.mega-menu .mega-inner a:nth-child(19) {
    animation-delay:0.95s;
}
.mega-menu .mega-inner a:nth-child(20) {
    animation-delay:1s;
}
.mega-menu .mega-inner a img {
    width:100%;
    border-radius:15px;
    box-shadow:4px 4px 0 #ffffff;
}
.mega-menu .mega-inner a span {
    display:block;
    margin:4px auto;
}
.mega-menu .mega-inner a:hover {
    transform:translateY(-4px);
}
.mega-menu .mega-inner a .inTtl {
    color:#ffffff;
}

/* 子リンクのフェードアップ */
@keyframes fadeUp {
    to {
        opacity:1;
        transform:translateY(0);
    }
}
/* キーフレーム -------------------------- */
@keyframes fadeUp {
    to {
        opacity:1;
        transform:translateY(0);
    }
}
/* 開いている見出しリンクの色変化（任意） */
.site-gnav .has-mega.active > a {
    color:#002c76;
}

/* ── サイトナビ（クリック時に色変化させたい時）────── */
.site-gnav .has-mega.active > a {
    color:#002c76;
    /* お好みで */
}

/*　#g-nav5.openbtn5
=============================================================== */
#g-nav5 {
    /*position:fixed;にし、z-indexの数値を小さくして最背面へ*/
    position:fixed;
    z-index:-1;
    opacity:0;
    top:0;
    width:100%;
    height:100vh;
    transition:all 0.3s;
}

/*アクティブクラスがついたら透過なしにして最前面へ*/
#g-nav5.panelactive {
    opacity:1;
    z-index:999;
}

/*ナビゲーションの縦スクロール*/
#g-nav5.panelactive #g-nav-list {
    /*ナビの数が増えた場合縦スクロール*/
    position:fixed;
    z-index:999;
    width:100%;
    height:100vh;
    /*表示する高さ*/
    overflow:auto;
    -webkit-overflow-scrolling:touch;
}

.site-gnavSp-container {
    display:flex;
    justify-content:center;
    align-items:start;
    height:100vh;
    background-color:#0068b7;
    padding:80px 15px 60px;
}

.site-gnavSp {
    display:none;
}

.site-gnavPc {
    width:100% !important;
}
.site-gnavPc .inner {
    width:100% !important;
}

@media only screen and (max-width: 768px) {
    .site-gnavPc {
        display:none;
    }
    .site-gnavSp {
        display:block;
        margin:0;
        padding:0;
        list-style:none;
        padding:0;
        width:100%;
    }
    .site-gnavSp li {
        border-bottom:1px dashed #ffffff;
        position:relative;
        padding:5px;
    }
    .site-gnavSp li:last-child {
        border-bottom:none;
    }
    .site-gnavSp li a,
    .site-gnavSp li label {
        display:block;
        padding:12px 16px;
        color:#ffffff;
        text-decoration:none;
        font-size:16px;
        transition:background 0.3s;
        cursor:pointer;
    }
    .site-gnavSp li a:hover,
    .site-gnavSp li label:hover {
        color:#35bf9e;
    }
    .site-gnavSp li ul {
        list-style:none;
        padding:0;
        margin:0;
        background:#ffffff;
        max-height:0;
        overflow:hidden;
        transition:max-height 0.3s ease-in-out;
        border-radius:15px;
    }
    .site-gnavSp li ul li {
        border-bottom:none;
        border-bottom:1px solid #0068b7;
    }
    .site-gnavSp li ul li a {
        padding-left:24px;
        font-size:14px;
        color:#333333;
    }
    .site-gnavSp li input[type=checkbox] {
        display:none;
    }
    .site-gnavSp li input[type=checkbox]:checked ~ ul {
        max-height:500px;
    }
    .site-gnavSp li label {
        position:relative;
        padding-right:40px;
    }
    .site-gnavSp li label::after {
        content:'▼';
        position:absolute;
        right:16px;
        top:50%;
        transform:translateY(-50%);
        font-size:12px;
        transition:transform 0.3s;
        color:#ffffff;
    }
    .site-gnavSp li input[type=checkbox]:checked + label::after {
        transform:translateY(-50%) rotate(180deg);
    }
}
/*========= ボタンのためのCSS ===============*/
.openbtn5 {
    position:fixed;
    z-index:9999;
    /*ボタンを最前面に*/
    top:0;
    right:0;
    cursor:pointer;
    width:70px;
    height:70px;
    background:#0068b7;
}
.openbtn5 div.inTxt {
    position:absolute;
    display:inline-block;
    color:#ffffff;
    font-size:1.2rem;
    bottom:10px;
    left:20px;
}

/*×に変化*/
.openbtn5 span {
    display:inline-block;
    transition:all 0.4s;
    position:absolute;
    left:20px;
    height:3px;
    border-radius:2px;
    background-color:#ffffff;
    width:45%;
}

.openbtn5 span:nth-of-type(1) {
    top:18px;
}

.openbtn5 span:nth-of-type(2) {
    top:26px;
}

.openbtn5 span:nth-of-type(3) {
    top:34px;
}

.openbtn5.active span:nth-of-type(1) {
    top:24px;
    left:26px;
    transform:translateY(6px) rotate(-45deg);
    width:30%;
}

.openbtn5.active span:nth-of-type(2) {
    opacity:0;
}

.openbtn5.active span:nth-of-type(3) {
    top:36px;
    left:26px;
    transform:translateY(-6px) rotate(45deg);
    width:30%;
}

/*===============================================================

footer

===============================================================*/
.sec8Wrap {
    padding:5% 0;
    text-align:center;
}

.site-footer {
    width:96%;
    background-color:#002c76;
    margin:0 auto;
    border-radius:30px 30px 0 0;
    padding:30px 0 0 0;
}

.site-info {
    text-align:center;
    font-size:1.4rem;
    color:#ffffff;
    padding:5px 0;
}

.footerFlex {
    color:#ffffff;
    width:100% !important;
}
.footerFlex .flex__itemL {
    width:30%;
    padding:15px;
}
.footerFlex .flex__itemL .footerTtl {
    font-size:clamp(1.8rem, 2.8vw, 2.8rem);
    font-weight:700;
}
.footerFlex .flex__itemL .footerTtl .mini {
    display:block;
    font-size:1.6rem;
}
.footerFlex .flex__itemL {
    order:1;
}
.footerFlex .flex__itemR {
    width:70%;
    order:2;
}
@media only screen and (max-width: 1100px) {
    .footerFlex {
        flex-direction:column;
    }
    .footerFlex .flex__itemL {
        text-align:center;
        width:100% !important;
        margin-bottom:15px;
        order:2 !important;
    }
    .footerFlex .flex__itemR {
        order:1 !important;
        width:100% !important;
    }
}

.footerMenu {
    justify-content:space-between;
    align-items:stretch !important;
}
.footerMenu .flex__item {
    padding:15px 15px;
}
.footerMenu .flex__item:not(:first-child) {
    border-left:1px dashed #ffffff;
}
.footerMenu .flex__item h3 {
    width:100%;
}
.footerMenu .flex__item h3::after {
    font-family:'Font Awesome 6 Free';
    content:'\f105';
    font-weight:900;
    padding-right:5px;
    /*文字との隙間*/
    color:#ffffff;
    /*アイコンの色*/
    margin-left:15px;
}
.footerMenu .flex__item ul {
    list-style:none;
    margin:15px 0 15px 10px;
    padding:0;
    font-size:1.4rem;
}
.footerMenu .flex__item ul li::before {
    font-family:'Font Awesome 6 Free';
    content:'-';
    font-weight:900;
    padding-right:5px;
    /*文字との隙間*/
    color:#ffffff;
    /*アイコンの色*/
}
@media only screen and (max-width: 778px) {
    .footerMenu .flex__item:not(:first-child) {
        border-left:0 dashed #ffffff;
    }
}
.footerMenu .flex__item3 {
    width:28%;
}
.footerMenu .flex__item1 {
    width:30%;
}
.footerMenu .flex__item2 {
    width:42%;
}
.footerMenu a {
    color:#ffffff;
    text-decoration:none;
}
.footerMenu a:hover {
    color:#35bf9e;
}

@media only screen and (max-width: 768px) {
    .footerMenu {
        display:none !important;
    }
}
.footerTel {
    color:#ffffff;
}
.footerTel a,
.footerTel a:link,
.footerTel a:visited,
.footerTel a:hover,
.footerTel a:active {
    color:#ffffff !important;
    text-decoration:none;
}

/*===============================================================

parts

===============================================================*/
/* page-top
========================================================================== */
a.page-top {
    position:fixed;
    bottom:40px;
    right:8px;
            border-radius:50px;
    -webkit-border-radius:50px;
       -moz-border-radius:50px;
    -ms-filter:'alpha(opacity=80)';
      -moz-opacity:1;
    -khtml-opacity:1;
           opacity:1;
    z-index:10000;
}

/*　パンくずリスト
========================================================================== */
.breadcrumbs {
    font-size:1.4rem;
}
.breadcrumbs a {
    color:#333333;
}
.breadcrumbs a:hover {
    color:#0068b7;
}

/*　singleページのナビゲーション
========================================================================== */
.nav-links {
    display:flex;
    justify-content:space-around;
    font-size:14px;
    margin:10px 0;
    padding:10px;
}
.nav-links a {
    color:#333333;
    text-decoration:none;
}
.nav-links a:hover {
    color:#35bf9e;
}
.nav-links .nav-previous,
.nav-links .nav-next {
    margin:10px;
}

/*　ページャー　wp-pagenavi
=============================================================== */
.wp-pagenavi {
    /*
  clear: both;
  text-align: center;
  margin-top: 60px;
  */
    display:flex;
    flex-wrap:wrap;
    gap:4px;
    justify-content:center;
    align-items:center;
    max-width:100%;
    padding:8px;
    box-sizing:border-box;
}

.wp-pagenavi a,
.wp-pagenavi span {
    color:#999999;
    background-color:#ffffff;
    border:solid 1px #e0e0d2;
    padding:8px 15px !important;
    margin:0 2px;
    white-space:nowrap;
       -moz-border-radius:3px;
    -webkit-border-radius:3px;
            border-radius:3px;
    -webkit-transition:0.2s ease-in-out;
       -moz-transition:0.2s ease-in-out;
         -o-transition:0.2s ease-in-out;
            transition:0.2s ease-in-out;
    text-align:center;
    text-decoration:none;
}

.wp-pagenavi a:hover {
    color:#ffffff;
    background-color:#435bb7;
    border-color:#cccccc !important;
}

.wp-pagenavi span.current {
    color:#ffffff;
    background-color:#0068b7;
    border-color:#0068b7;
    font-weight:bold;
}

@media only screen and (max-width: 768px) {
    .wp-pagenavi {
        flex-wrap:wrap;
        gap:6px;
        padding:10px;
        justify-content:center;
        overflow-x:hidden;
    }
    .wp-pagenavi a,
    .wp-pagenavi span {
        font-size:13px;
        padding:6px 10px;
    }
}
/* search
========================================================================== */
#searchform {
    margin-bottom:32px;
}
#searchform input {
    font-size:18px;
    padding:2px 12px;
}
#searchform input:focus {
    outline:none;
}

/* ggmap
========================================================================== */
.ggmap {
    clear:both;
    position:relative;
    padding-bottom:56.25%;
    padding-top:30px;
    height:0;
    overflow:hidden;
    margin-top:16px;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:94%;
    display:inline;
}

/* youtube
========================================================================== */
.youtube {
    clear:both;
    position:relative;
    padding-bottom:56.25%;
    padding-top:0;
    height:0;
    overflow:hidden;
    margin-top:0;
}

.youtube video,
.youtube iframe,
.youtube object,
.youtube embed {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    display:inline;
}

/*youtube 中央揃え*/
.wp-block-embed-youtube {
    text-align:center;
    /* ブロック全体を中央揃え */
}

.wp-block-embed-youtube iframe {
    display:block;
    /* ブラウザのデフォルト動作を防ぐ */
    margin:0 auto;
    /* iframeを中央揃え */
}

/*  scroll-hint
========================================================================== */
@keyframes scroll-hint-appear {
    0% {
        transform:translateX(40px);
        opacity:0;
    }
    10% {
        opacity:1;
    }
    50%,
    100% {
        transform:translateX(-40px);
        opacity:0;
    }
}
.scroll-hint.is-right-scrollable {
    background:linear-gradient(270deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint.is-right-scrollable.is-left-scrollable {
    background:linear-gradient(90deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0)), linear-gradient(270deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint.is-left-scrollable {
    background:linear-gradient(90deg, rgba(0, 0, 0, 0.15) 0, rgba(0, 0, 0, 0) 16px, rgba(0, 0, 0, 0));
}

.scroll-hint-icon {
    position:absolute;
    top:calc(50% - 25px);
    left:calc(50% - 60px);
    box-sizing:border-box;
    width:120px;
    height:80px;
    border-radius:5px;
    transition:opacity 0.3s;
    opacity:0;
    background:rgba(0, 0, 0, 0.7);
    text-align:center;
    padding:20px 10px 10px 10px;
}

.scroll-hint-icon-wrap {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    max-height:100%;
    pointer-events:none;
}

.scroll-hint-text {
    font-size:10px;
    color:#ffffff;
    margin-top:5px;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon {
    opacity:0.8;
}

.scroll-hint-icon:before {
    display:inline-block;
    width:40px;
    height:40px;
    color:#ffffff;
    vertical-align:middle;
    text-align:center;
    content:'';
    background-size:contain;
    background-position:center center;
    background-repeat:no-repeat;
    background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDM8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIiBmaWxsPSIjZmZmIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon:after {
    content:'';
    width:34px;
    height:14px;
    display:block;
    position:absolute;
    top:10px;
    left:50%;
    margin-left:-20px;
    background-repeat:no-repeat;
    background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDE8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIgZmlsbD0iI2ZmZiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiIGZpbGw9IiNmZmYiLz48L2c+PC9nPjwvc3ZnPg==);
    opacity:0;
    transition-delay:2.4s;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:after {
    opacity:1;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:before {
    animation:scroll-hint-appear 1.2s linear;
    animation-iteration-count:2;
}

.scroll-hint-icon-white {
    background-color:#ffffff;
    box-shadow:0 4px 5px rgba(0, 0, 0, 0.4);
}

.scroll-hint-icon-white:before {
    background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDQ8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon-white:after {
    background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDI8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiLz48L2c+PC9nPjwvc3ZnPg==);
}

.scroll-hint-icon-white .scroll-hint-text {
    color:#000000;
}

/*===============================================================

top

===============================================================*/
.sec1Wrap {
    position:relative;
}
.sec1Wrap ::after {
    content:'';
    position:absolute;
    bottom:-260px;
    left:0;
    width:100%;
    height:300px;
    z-index:-1;
    /* テキストの下に配置 */
}

.mainV_wrap {
    text-align:right;
    z-index:1;
    height:80vh;
    overflow:hidden;
}
@media only screen and (max-width: 1140px) {
    .mainV_wrap {
        height:auto;
    }
}
.mainV_wrap img {
    width:80%;
    height:auto;
    border-radius:30px 0 0 30px;
}
@media only screen and (max-width: 768px) {
    .mainV_wrap img {
        width:96%;
    }
}

/*
.mainV_wrap {
    text-align: right;
    z-index: 1;

    img {
        width: 80%;

        @media only screen and (max-width:$screen-m) {
            width: 96%;
        }
    }
}
    */
.mainTxt_wrap {
    position:absolute;
    bottom:50px;
    background-color:rgba(255, 255, 255, 0.6);
    padding:2%;
    border-radius:0 30px 30px 0;
}
.mainTxt_wrap .inTtl {
    font-weight:700;
    color:#002c76;
    font-size:clamp(2.4rem, 5.6vw, 5.6rem);
}
.mainTxt_wrap p {
    font-weight:700;
    font-size:clamp(1.4rem, 1.8vw, 1.8rem);
}
@media only screen and (max-width: 768px) {
    .mainTxt_wrap {
        position:inherit;
        bottom:0;
        width:80%;
        border-radius:20px 20px 20px 20px;
        margin:-60px auto 0;
        text-align:center;
        background-color:rgba(255, 255, 255, 0.8);
    }
    .mainTxt_wrap p {
        text-align:left;
    }
}
@media only screen and (max-width: 480px) {
    .mainTxt_wrap {
        width:96%;
        margin:0 auto 0;
    }
}

.importantNews {
    padding:1em 0;
}
.importantNews ul {
    list-style:none;
    margin:0;
}
.importantNews ul li {
    background:#ffffff;
    margin-bottom:30px;
    border-top:dashed #f89a27;
    border-bottom:dashed #f89a27;
}
.importantNews ul li a {
    display:block;
    padding:1.5em 1.5em;
    color:#35bf9e;
    text-decoration:none;
}

.sec2Wrap {
    position:relative;
    margin-top:60px;
}
.sec2Wrap > ::after {
    content:'';
    position:absolute;
    top:-100px;
    left:0;
    width:100%;
    height:680px;
    background-color:#eef3fa;
    z-index:-1;
    /* テキストの下に配置 */
}
@media only screen and (max-width: 768px) {
    .sec2Wrap > ::after {
        height:600px;
    }
}

.newsFlex .flex__item {
    width:50%;
}
.newsFlex .flex__itemL {
    background:#ffffff;
    border-radius:20px;
    padding:20px;
}
.newsFlex .flex__itemR {
    padding-left:20px !important;
}
@media only screen and (max-width: 768px) {
    .newsFlex {
        display:block;
    }
    .newsFlex .flex__item {
        width:100% !important;
    }
    .newsFlex .flex__itemR {
        padding-left:0 !important;
        margin-top:30px;
    }
}

/*　お知らせリスト
 =============================================================== */
dl.listDl {
    border-bottom:1px dashed #cccccc;
}
dl.listDl dt {
    padding-top:15px;
}
dl.listDl dd {
    margin:0;
}
dl.listDl dd a {
    display:block;
    padding:0 0 15px 0;
    text-decoration:none;
    color:#333333;
    transition:0.15s all;
}
dl.listDl dd a:hover {
    color:#35bf9e;
}

.ttl_eng_ja h2 {
    font-size:clamp(2rem, 2.6vw, 2.6rem);
    color:#0068b7;
}
.ttl_eng_ja h2 .eng {
    display:block;
    font-size:clamp(1.4rem, 1.8vw, 1.8rem);
    color:#35bf9e;
    position:relative;
    padding-left:18px;
}
.ttl_eng_ja h2 .eng::before {
    content:'●';
    color:#35bf9e;
    position:absolute;
    left:0;
    top:4px;
    line-height:1.8rem;
    font-size:1.4rem;
}

.ttl_blue h2 {
    background:#0068b7;
    color:#ffffff;
    text-align:center;
    border-radius:30px;
    font-size:clamp(1.6rem, 2.2vw, 2.2rem);
    padding:6px 0;
    margin-bottom:15px;
}
.ttl_blue h2 .mini {
    font-size:1.4rem;
    display:inline-block;
    margin-right:10px;
}

/*　空き情報テーブル
 =============================================================== */
.vacabtTbl table {
    border:3px solid #35bf9e;
}
.vacabtTbl td,
.vacabtTbl th {
    border:1px solid #35bf9e;
}
@media only screen and (max-width: 768px) {
    .vacabtTbl td,
    .vacabtTbl th {
        width:760px;
    }
}
.vacabtTbl td,
.vacabtTbl th {
    padding:12px;
    text-align:center;
}
.vacabtTbl th {
    background:#d1f6ed;
    color:#333333;
}
.vacabtTbl td {
    background:#ffffff;
    color:#35bf9e;
    font-weight:bold;
}

.sec3Wrap {
    background:#ffffff;
    width:96%;
    border-radius:0 20px 20px 0;
    margin-top:60px;
    padding:3% 1%;
    position:relative;
}
.sec3Wrap > ::after {
    content:'';
    position:absolute;
    top:250px;
    left:0;
    width:100%;
    height:100px;
    background-color:#eef3fa;
    width:60%;
    z-index:1;
    /* テキストの下に配置 */
}
@media only screen and (max-width: 768px) {
    .sec3Wrap > ::after {
        top:150px;
        height:300px;
        width:80%;
    }
}
@media only screen and (max-width: 768px) {
    .sec3Wrap {
        width:100%;
    }
}

.sec3Flex {
    position:relative;
    z-index:30;
}
.sec3Flex .flex__itemL {
    width:35%;
    text-align:center;
}
.sec3Flex .flex__itemL img {
    max-width:280px;
    border-radius:20px;
}
.sec3Flex .flex__itemR {
    width:65%;
    padding-left:20px;
}
@media only screen and (max-width: 768px) {
    .sec3Flex {
        display:block;
        width:100%;
    }
    .sec3Flex .flex__itemL {
        width:100% !important;
    }
    .sec3Flex .flex__itemR {
        padding-top:30px;
        width:100% !important;
    }
}

.coCatch {
    font-weight:700;
    color:#002c76;
    font-size:clamp(2rem, 2.8vw, 2.8rem);
    margin-bottom:15px;
}

.eventFlex {
    display:flex;
    flex-wrap:wrap;
    margin:30px 0;
    gap:24px;
    justify-content:space-between;
    align-items:stretch;
}
.eventFlex .flex__item {
    width:calc(33.333% - 16px);
    background:#ffffff;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    height:100%;
}
.eventFlex .flex__item a {
    display:flex;
    flex-direction:column;
    height:100%;
    text-decoration:none;
    color:inherit;
}
.eventFlex .flex__item a .eventImg {
    position:relative;
    width:100%;
    aspect-ratio:16/9;
    overflow:hidden;
    border-radius:15px;
}
.eventFlex .flex__item a .eventImg img {
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
    display:block;
    transition:transform 0.3s ease;
}
.eventFlex .flex__item a .eventImg:hover img {
    transform:scale(1.05);
}
.eventFlex .flex__item a .eventImg .eventTag {
    position:absolute;
    top:8px;
    right:8px;
    background:#35bf9e;
    color:#ffffff;
    padding:4px 8px;
    font-size:12px;
    border-radius:4px;
}
.eventFlex .flex__item a .eventDate {
    font-size:14px;
    color:#666666;
    margin:12px 16px 4px;
}
.eventFlex .flex__item a .eventTtl {
    font-size:16px;
    font-weight:bold;
    line-height:1.4;
    margin:0 16px 16px;
    flex-grow:1;
    display:flex;
    align-items:flex-start;
    color:#333333;
}
.eventFlex .flex__item a:hover .eventTtl {
    color:#0068b7;
}

.eventListFlex .flex__item {
    background:#eef3fa;
}

@media only screen and (max-width: 768px) {
    .eventFlex .flex__item {
        width:calc(50% - 12px);
    }
}
@media only screen and (max-width: 480px) {
    .eventFlex .flex__item {
        width:100%;
    }
}
.twoBtn {
    justify-content:center;
    align-items:center;
}
.twoBtn a {
    display:inline-block;
    padding:15px 40px;
    background:#35bf9e;
    color:#ffffff;
    border-radius:30px;
    margin:5px 10px;
    text-decoration:none;
    transition:0.15s all;
}
.twoBtn a:hover {
    opacity:0.8;
}
.twoBtn a.type2 {
    background:#0068b7;
}

.sec5Wrap {
    background:#0068b7 url(../images/top/logobig.svg) no-repeat center center;
    color:#ffffff;
    width:96%;
    margin:60px auto 0;
    border-radius:20px;
    padding:3%;
}
.sec5Wrap h2 {
    text-align:center;
    margin-bottom:30px;
}
.sec5Wrap .innerTxt {
    text-align:center;
    margin:0 auto;
}

.sec5Flex {
    gap:24px;
    justify-content:space-between;
}
.sec5Flex .flex__item {
    width:calc(25% - 18px);
    background:#ffffff;
    padding:8px;
    position:relative;
    border-radius:8px;
    transition:box-shadow 0.3s;
}
.sec5Flex .flex__item a {
    display:block;
    text-decoration:none;
    color:inherit;
    transition:0.15s all;
}
.sec5Flex .flex__item a .inImg {
    overflow:hidden;
    border-radius:12px;
}
.sec5Flex .flex__item a .inImg img {
    width:100%;
    height:auto;
    display:block;
    transition:transform 0.3s ease;
}
.sec5Flex .flex__item a .inImg:hover img {
    transform:scale(1.05);
}
.sec5Flex .flex__item a .inTtl {
    margin-top:12px;
    font-size:16px;
    line-height:1.5;
    color:#333333;
    font-weight:bold;
    text-align:center;
    height:60px;
}
.sec5Flex .flex__item a::after {
    content:'';
    position:absolute;
    bottom:8px;
    right:8px;
    width:0;
    height:0;
    border-left:15px solid transparent;
    border-top:15px solid #35bf9e;
    transform:rotate(90deg);
    transition:0.15s all;
}
.sec5Flex .flex__item:hover {
    box-shadow:0 4px 12px rgba(0, 0, 0, 0.1);
}
.sec5Flex .flex__item:hover .inTtl {
    color:#0068b7;
}
.sec5Flex .flex__item:hover a::after {
    bottom:6px;
    right:6px;
}

@media (max-width: 768px) {
    .clumFlex .flex__item {
        width:calc(50% - 12px);
    }
}
@media (max-width: 480px) {
    .clumFlex .flex__item {
        width:100%;
    }
}
.topSliderWrap {
    padding:60px 0;
}
@media only screen and (max-width: 768px) {
    .topSliderWrap {
        padding:30px 0;
    }
}
.topSliderWrap .topSlider {
    margin:0 -8px;
    background:url(../images/top/sec6Bk.svg) no-repeat center center;
}
@media only screen and (max-width: 768px) {
    .topSliderWrap .topSlider {
        margin:0;
    }
}
.topSliderWrap .topSlider li {
    padding:0 15px;
    box-sizing:border-box;
}
.topSliderWrap .topSlider li img {
    width:100%;
    height:auto;
    display:block;
    border-radius:8px;
}
.topSliderWrap .topSlider li:nth-child(odd) {
    margin-top:30px;
}

.sec6Flex1 {
    gap:30px;
    align-items:center;
    justify-content:center;
    font-weight:bold;
}
.sec6Flex1 .flex__item1 {
    background-image:url(../images/top/sec6Bk1.png);
    background-position:center center;
    background-repeat:no-repeat;
    background-size:contain;
    padding:80px 20px;
    width:46%;
}
.sec6Flex1 .flex__item2 {
    background-image:url(../images/top/sec6Bk2.png);
    background-position:center center;
    background-repeat:no-repeat;
    background-size:contain;
    padding:80px 20px;
    margin-top:60px;
    width:46%;
}
.sec6Flex1 .flex__item3 {
    background-image:url(../images/top/sec6Bk3.png);
    background-position:center center;
    background-repeat:no-repeat;
    background-size:contain;
    padding:40px 20px;
    width:46%;
}
@media only screen and (max-width: 768px) {
    .sec6Flex1 .flex__item1 {
        padding:20px 20px;
    }
    .sec6Flex1 .flex__item2 {
        padding:20px 20px;
    }
    .sec6Flex1 .flex__item3 {
        padding:20px 20px;
    }
}
@media only screen and (max-width: 480px) {
    .sec6Flex1 .flex__item1 {
        padding:20px 20px;
        width:100%;
    }
    .sec6Flex1 .flex__item2 {
        width:100%;
        margin-top:10px;
    }
    .sec6Flex1 .flex__item3 {
        width:100%;
    }
}

.sec7Wrap {
    position:relative;
    width:100%;
    padding-top:29.53%;
    background:url('../images/top/sec7Bk.jpg') no-repeat center center;
    background-size:cover;
    overflow:hidden;
}
@media (max-width: 920px) {
    .sec7Wrap {
        background:url('../images/top/sec7Bk2.jpg') no-repeat center center;
        background-size:cover;
        padding-top:64.79%;
    }
}
.sec7Wrap .inWrap {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
}
.sec7Wrap .inWrap .inner {
    width:100%;
    position:relative;
    height:100%;
    text-align:center;
    display:flex;
    align-items:center;
    justify-content:center;
}
.sec7Wrap .inWrap .inner .sec7Flex {
    position:absolute;
    bottom:30px;
    text-align:center;
}
.sec7Wrap .inWrap .inner .sec7Flex .inTxt {
    font-size:clamp(1.8rem, 3.6vw, 3.6rem);
    font-weight:700;
    color:#ffffff;
    text-align:left;
}
.sec7Wrap .inWrap .inner .sec7Flex .inlink {
    padding:20px;
}
.sec7Wrap .inWrap .inner .sec7Flex .inlink a {
    display:inline-block;
    padding:15px 40px;
    background:#35bf9e;
    color:#ffffff;
    border-radius:30px;
    margin:5px 10px;
    text-decoration:none;
    transition:0.15s all;
}
.sec7Wrap .inWrap .inner .sec7Flex .inlink a:hover {
    opacity:0.8;
}
@media only screen and (max-width: 920px) {
    .sec7Wrap .inWrap .inner .sec7Flex {
        display:block;
    }
}

/*===============================================================

archive

===============================================================*/
.reclistFlex {
    display:flex;
    flex-wrap:wrap;
    gap:40px;
}
.reclistFlex > .flex__item {
    position:relative;
    width:calc(50% - 40px);
    background:#ffffff;
    padding:20px 20px 80px 20px;
    border-radius:15px;
}
.reclistFlex > .flex__item a {
    text-decoration:none;
    color:#333333;
    transition:0.15s all;
}
.reclistFlex > .flex__item a:hover .more {
    background-color:#35bf9e;
    color:#ffffff;
}
.reclistFlex > .flex__item h3 {
    background:#0068b7;
    color:#ffffff;
    text-align:center;
    padding:0.5em;
    border-radius:30px;
}
.reclistFlex > .flex__item .moreWrap {
    position:absolute;
    bottom:15px;
    left:50%;
            transform:translateX(-50%);
    -webkit-transform:translateX(-50%);
        -ms-transform:translateX(-50%);
}
.reclistFlex > .flex__item .moreWrap .more {
    border:1px solid #cccccc;
    display:inline-block;
    padding:10px;
    border-radius:5px;
}
@media only screen and (max-width: 860px) {
    .reclistFlex {
        flex-direction:column;
        gap:15px;
    }
    .reclistFlex .flex__item {
        width:100%;
        margin-bottom:25px;
    }
}

.reclist2Flex {
    border-bottom:1px dashed #cccccc;
}
.reclist2Flex > .flex__itemL {
    color:#35bf9e;
    width:30%;
    font-weight:bold;
    padding:20px;
}
.reclist2Flex > .flex__itemR {
    width:70%;
}

/*===============================================================

single

===============================================================*/
.singleFlex {
    display:flex;
    gap:20px;
}
.singleFlex .layout__itemL {
    width:calc(100% - 300px);
    padding:15px;
}
.singleFlex .layout__itemL h1.entry-title {
    border-bottom:6px dotted #0068b7 !important;
    padding:0 0 0.5em 0;
}
.singleFlex .layout__itemR {
    width:300px;
    background:#ffffff;
    padding:15px;
    border-radius:15px;
}
.singleFlex .layout__itemR h2 {
    background:#0068b7;
    color:#ffffff;
    font-size:1.8rem;
    padding:5px 20px;
    border-radius:15px;
}
.singleFlex .layout__itemR ul {
    list-style:none;
    margin:10px 15px 10px 15px;
}
.singleFlex .layout__itemR ul li {
    border-bottom:1px dotted #cccccc;
}
.singleFlex .layout__itemR ul li a {
    display:block;
    padding:10px 0;
    text-decoration:none;
    color:#000000;
}
.singleFlex .layout__itemR ul li a:hover {
    color:#35bf9e;
}
@media only screen and (max-width: 980px) {
    .singleFlex {
        display:block;
    }
    .singleFlex .layout__itemL {
        width:100%;
    }
    .singleFlex .layout__itemR {
        width:100%;
    }
}

.pager {
    margin:0 0;
}
.pager .flexContainer {
    display:flex;
    border-top:1px solid #cccccc;
    border-bottom:1px solid #cccccc;
}
.pager .flexContainer > div {
    width:33.333%;
    text-align:center;
}
.pager .flexContainer > div a {
    display:block;
    width:100%;
    height:100%;
    padding:20px;
    text-decoration:none;
    color:#333333;
    font-weight:bold;
    transition:all 0.3s ease;
}
.pager .flexContainer > div a:hover {
    background-color:#0068b7;
    color:#ffffff;
}
.pager .flexContainer .prev,
.pager .flexContainer .back {
    border-right:1px solid #cccccc;
}

/*===============================================================

form

===============================================================*/
input[type=file] {
    border:0 solid #cccccc;
}

/*テキスト--------------------------------------*/
input[type=email],
input[type=text],
input[type=search],
textarea {
    width:100%;
    border-radius:4px;
    box-sizing:border-box;
    border:1px solid #cccccc;
    background:#ffffff;
            appearance:none;
    -webkit-appearance:none;
       -moz-appearance:none;
    padding:6px 6px 10px;
    font-size:2rem;
}

input[type=search] {
    width:70%;
}

select,
input[type=search],
textarea,
input[type=text]:focus {
    outline:0;
}

/*チェックボックス--------------------------------------*/
/*リセット */
input[type=checkbox] {
    height:20px;
    width:20px;
    padding-top:10px;
    margin-right:5px;
}

/* チェックボックスデザイン */
input[type=checkbox] {
    cursor:pointer;
    padding-left:0;
    vertical-align:middle;
}

.wpcf7-list-item-label {
    vertical-align:middle;
    display:inline-block;
    line-height:1.5;
}

input[type=radio] {
    font-size:1.8rem;
    border-radius:50%;
    margin-right:0.25rem;
    line-height:0.71428571;
    border:1px solid #cccccc;
    width:15px;
    height:15px;
    vertical-align:middle;
}

input[type=radio]:checked::before {
    margin:-0.4rem 0 0 -1.3rem;
    height:2.5rem;
    width:2.5rem;
}

/*セレクトボックス--------------------------------------*/
.select {
    display:inline-flex;
    align-items:center;
    position:relative;
}

.select::after {
    position:absolute;
    right:15px;
    width:10px;
    height:7px;
    background-color:#535353;
    clip-path:polygon(0 0, 100% 0, 50% 100%);
    content:'';
    pointer-events:none;
}

select {
    appearance:none;
    max-width:520px;
    height:2.8em;
    padding:0.4em calc(0.8em + 30px) 0.4em 0.8em;
    border:1px solid #cccccc;
    border-radius:3px;
    background-color:#ffffff;
    color:#333333;
    font-size:1em;
    cursor:pointer;
    background:rgba(255, 255, 255, 0.9) url(../images/common/selectBk.png) no-repeat right;
}

.item_select {
    padding:15px 0;
}
.item_select select {
    width:100%;
}

/*******************************************************************************

_form.scss

*******************************************************************************/
.Form {
    margin-top:0;
    margin-left:auto;
    margin-right:auto;
    max-width:100%;
    padding:10px;
}
.Form table th {
    position:relative;
    padding-right:70px !important;
}
.Form table th .Form-Item-Label-Required {
    position:absolute;
    top:50%;
    right:0;
            transform:translateY(-50%);
    -webkit-transform:translateY(-50%);
        -ms-transform:translateY(-50%);
    border-radius:6px;
    margin-right:8px;
    padding-top:4px;
    padding-bottom:4px;
    width:48px;
    display:inline-block;
    text-align:center;
    background:#f89a27;
    color:#ffffff;
    font-size:14px;
}
.Form table th .Form-Item-Label-Any {
    position:absolute;
    top:50%;
    right:0;
            transform:translateY(-50%);
    -webkit-transform:translateY(-50%);
        -ms-transform:translateY(-50%);
    border-radius:6px;
    margin-right:8px;
    padding-top:8px;
    padding-bottom:8px;
    width:48px;
    display:inline-block;
    text-align:center;
    background:#cccccc;
    color:#333333;
    font-size:14px;
}
.Form table td img {
    max-width:100%;
}
.Form p {
    margin-bottom:0 !important;
}
.Form .Form-Item {
    border-top:1px solid #cccccc;
    padding-top:24px;
    padding-bottom:24px;
    width:100%;
    display:flex;
    align-items:center;
}
.Form .Form-Item-school {
    margin-bottom:32px;
    overflow:hidden;
}
.Form .Form-Item2 {
    border-top:1px solid #cccccc;
    padding-top:24px;
    padding-bottom:24px;
    width:100%;
    display:block;
    align-items:center;
}
.Form .Form-Item:nth-child(5) {
    border-bottom:1px solid #cccccc;
}
.Form .Form-Item-Label {
    width:100%;
    max-width:300px;
    letter-spacing:0.05em;
    font-weight:bold;
    font-size:18px;
    background:#cccccc;
    height:100%;
}
.Form .Form-Item-Label2 {
    width:100%;
    letter-spacing:0.05em;
    font-weight:bold;
    font-size:14px;
    display:block;
    padding:24px 0;
}
.Form .Form-Item-Input {
    border:1px solid #cccccc;
    border-radius:6px;
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    flex:1;
    width:100%;
    /*max-width: 410px;*/
    background:#ffffff;
    font-size:18px;
}
.Form .Form-Item-Input2 {
    border:1px solid #cccccc;
    border-radius:6px;
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    flex:1;
    width:220px;
    max-width:410px;
    background:#ffffff;
    font-size:18px;
}
.Form .Form-Item-Input3 {
    border:1px solid #cccccc;
    border-radius:6px;
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    width:80%;
    background:#eaedf2;
    font-size:18px;
}
.Form .Form-Item-Input4 {
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    flex:1;
    width:100%;
    /*max-width: 410px;*/
    background:#ffffff;
    font-size:16px;
}
.Form .Form-Item-Input-tel3,
.Form .Form-Item-Input-tel2,
.Form .Form-Item-Input-tel1 {
    border:1px solid #cccccc;
    border-radius:6px;
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    flex:1;
    width:90px;
    max-width:410px;
    background:#ffffff;
}
.Form .Form-Item-Input-year {
    border:1px solid #cccccc;
    border-radius:6px;
    margin-left:0;
    padding-left:1em;
    padding-right:1em;
    height:48px;
    flex:1;
    width:90px;
    max-width:410px;
    background:#ffffff;
}
.Form .formselect {
    -webkit-appearance:none;
       -moz-appearance:none;
            appearance:none;
    width:100%;
    height:48px;
    background:#eaedf2;
    position:relative;
    z-index:1;
    padding:0 40px 0 10px;
    border-radius:2px;
    background:rgba(255, 255, 255, 0.9) url(../images/common/selectBk.png) no-repeat right;
    border-radius:6px;
}
.Form select {
    margin-bottom:10px;
}
@media only screen and (max-width: 480px) {
    .Form .formBlock {
        display:block;
        margin-bottom:5px;
    }
}
.Form .formselectW120 {
    width:120px;
}
.Form .formselectW200 {
    width:200px;
}
.Form .form3Box {
    width:100%;
}
.Form .Form-Item-Label.isMsg {
    margin-top:8px;
    margin-bottom:auto;
}
.Form .Form-Item-Textarea {
    border:1px solid #dddddd;
    border-radius:6px;
    padding-left:1em;
    padding-right:1em;
    height:160px;
    flex:1;
    width:100%;
    font-size:18px;
}
.Form .Form-Btn {
    border-radius:6px;
    margin-top:32px;
    margin-left:auto;
    margin-right:auto;
    padding-top:20px;
    padding-bottom:20px;
    width:280px;
    display:inline;
    letter-spacing:0.05em;
    background:#0068b7;
    color:#ffffff;
    font-weight:bold;
    font-size:20px;
}
.Form .Form-Btn2 {
    border-radius:6px;
    margin-top:32px;
    margin-left:auto;
    margin-right:auto;
    padding-top:20px;
    padding-bottom:20px;
    width:180px;
    display:inline;
    letter-spacing:0.05em;
    background:#35bf9e;
    color:#ffffff;
    font-weight:bold;
    font-size:20px;
}

.feas-submit-button,
.search-submit,
.search-Btn {
    border-radius:6px;
    display:inline-block;
    background:#0068b7 !important;
    color:#ffffff !important;
    font-weight:bold;
    font-size:16px;
    padding:15px 25px 15px !important;
    cursor:pointer;
}

.form-lower dt {
    font-size:85%;
}
.form-lower dd {
    margin-bottom:16px;
}

@media screen and (max-width: 768px) {
    .Form {
        margin-top:40px;
    }
    .Form .Form-Item {
        padding-left:14px;
        padding-right:14px;
        padding-top:16px;
        padding-bottom:16px;
        flex-wrap:wrap;
    }
    .Form .Form-Item-Label {
        max-width:inherit;
        display:flex;
        align-items:center;
        font-size:15px;
    }
    .Form .Form-Item-Label.isMsg {
        margin-top:0;
    }
    .Form .Form-Item-Label-Required {
        border-radius:4px;
        padding-top:4px;
        padding-bottom:4px;
        width:32px;
        font-size:10px;
    }
    .Form .Form-Item-Label-Any {
        border-radius:4px;
        padding-top:4px;
        padding-bottom:4px;
        width:32px;
        font-size:10px;
    }
    .Form .Form-Item-Input {
        margin-left:0;
        height:40px;
        flex:inherit;
        font-size:15px;
    }
    .Form .Form-Item-Textarea {
        margin-top:18px;
        margin-left:0;
        height:200px;
        flex:inherit;
        font-size:15px;
    }
    .Form .Form-Btn {
        margin-top:24px;
        padding-top:8px;
        padding-bottom:8px;
        width:160px;
        font-size:16px;
    }
    .Form .Form-Btn2 {
        margin-top:24px;
        padding-top:8px;
        padding-bottom:8px;
        width:160px;
        font-size:16px;
    }
}
/* カレンダー入力フィールドのサイズを調整 */
input[type=date] {
    font-size:16px;
    /* フォントサイズ */
    height:40px;
    /* 高さ */
    padding:10px;
    /* 内側の余白 */
    width:100%;
    /* 幅を調整（必要に応じて変更） */
    box-sizing:border-box;
    /* パディング込みでサイズ計算 */
}

/* カレンダーアイコンの調整（モダンブラウザでサポート） */
input[type=date]::-webkit-calendar-picker-indicator {
    font-size:20px;
    /* アイコンのサイズ */
}

.wpcf7-form-control.wpcf7-submit {
    cursor:pointer;
    /* マウスオーバー時に指マークになる */
}

/*フォームテーブル*/
.formRes {
    border:3px solid #0068b7;
    padding:0 30px 30px 30px !important;
    margin-bottom:60px;
    background-color:#ffffff;
}
@media only screen and (max-width: 480px) {
    .formRes {
        padding:0 10px 10px 10px !important;
    }
}
.formRes h1.entry-title {
    margin:0 auto;
    background-color:#0068b7;
    color:#ffffff;
    display:inline-block;
    padding:10px 20px;
    border-radius:0 0 20px 20px;
}
.formRes table {
    margin-top:30px;
}
.formRes table th {
    background:#0068b7;
    color:#ffffff;
    width:25%;
    font-weight:normal;
    padding:15px;
    border-bottom:1px solid #cccccc;
    text-align:left;
}
.formRes table td {
    border-bottom:1px solid #cccccc;
    padding:15px 0 15px 15px;
}
@media screen and (max-width: 768px) {
    .formRes table th,
    .formRes table td {
        width:100%;
        display:block;
    }
    .formRes table td {
        border-bottom:0 solid #cccccc;
        padding:15px 15px 15px 15px;
    }
}

div.wpcf7 .wpcf7-spinner {
    display:block;
}

#cf7-confirm {
    background:#f9f9f9;
    padding:20px;
    border-radius:10px;
    text-align:center;
    display:none;
}
#cf7-confirm h3 {
    margin-bottom:15px;
}
#cf7-confirm table td {
    text-align:left;
}
/*# sourceMappingURL=master.css.map */
