@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&family=Zen+Old+Mincho&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;
}

.edu-tas-beginner-<uniquifier> {
  font-family: "Edu TAS Beginner", cursive;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.noto-serif-jp-<uniquifier> {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.noto-sans-jp-<uniquifier> {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.zen-old-mincho-regular {
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  font-style: normal;
}


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

common

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

.brSp {
    display:none;
}

@media only screen and (max-width: 580px) {
    br.brPc {
        display:none;
    }
    .brSp {
        display:block;
    }
}
.site-main {
    margin-top:70px;
}
@media only screen and (max-width: 980px) {
    .site-main {
        margin-top:0;
    }
}

.entry-header {
    background-color:#f3f0ed;
    background-image:url(../images/common/headBk.svg);
    background-position:top left;
    background-repeat:no-repeat;
    background-size:cover;
    height:250px;
    display:flex;
    align-items:center;
    border-radius:0 0 50px 50px;
}
@media only screen and (max-width: 980px) {
    .entry-header {
        background-size:contain;
        height:150px !important;
    }
}
@media only screen and (max-width: 768px) {
    .entry-header {
        border-radius:0 0 20px 20px;
        height:120px !important;
    }
}
.entry-header .entry-title {
    margin:0;
    font-family:'Zen Old Mincho', serif;
    font-weight:400;
    font-style:normal;
    position:relative;
    padding-left:60px;
    font-size:clamp(2.2rem, 4vw, 4rem);
}
.entry-header .entry-title::before {
    content:'';
    position:absolute;
    left:0;
    top:55%;
    width:50px;
    height:1px;
    background:#f18eac;
    transform:translateY(-50%);
}
@media only screen and (max-width: 480px) {
    .entry-header .entry-title {
        margin-top:0.5em;
        margin-bottom:0;
    }
}
.entry-header .pageSlug {
    font-family:'Noto Serif JP', serif;
    font-optical-sizing:auto;
    font-weight:600;
    font-style:normal;
    font-size:50px;
    color:#bdb4b3;
    font-size:clamp(1.4rem, 8vw, 8rem);
    margin:0;
}
@media only screen and (max-width: 480px) {
    .entry-header {
        display:block;
    }
    .entry-header .pageSlug {
        width:100%;
        text-align:right;
    }
}

.searchList {
    border-bottom:1px dashed #f18eac;
    padding:1em 0;
}
.searchList a {
    text-decoration:none;
    color:#333333;
    display:block;
    transition:0.15s all;
}
.searchList a:hover {
    color:#f18eac;
}

.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:#f18eac;
    color:#ffffff;
}
.pager .flexContainer .prev,
.pager .flexContainer .back {
    border-right:1px solid #cccccc;
}

.singleDate {
    margin-bottom:40px;
}
.singleDate span {
    font-size:1.4rem;
    color:#ffffff;
    font-weight:bold;
    background:#f18eac;
    display:inline-block;
    padding:2px 15px;
    border-radius:3px;
}

.postList {
    list-style:none;
    margin:0;
}
.postList li {
    border-bottom:1px dotted #cccccc;
    padding:1em 0;
    margin:0.5em 0;
}
.postList li a {
    display:block;
}
.postList li a .listDate {
    display:inline-block;
    width:100px;
    font-weight:bold;
    font-size:1.4rem;
}
@media only screen and (max-width: 768px) {
    .postList li a .listDate {
        display:block;
    }
}

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

header

===============================================================*/
.site-header {
    /*background-color: rgba(243, 240, 237, 0.6);*/
    background:#f3f0ed !important;
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:999;
    background:#ffffff;
    transition:transform 0.3s ease;
    will-change:transform;
    height:70px;
}
.site-header.hide-header {
    transform:translateY(-100%);
}
.site-header.show-header {
    transform:translateY(0%);
}

@media only screen and (max-width: 980px) {
    .site-header {
        background-color:rgba(243, 240, 237, 0.6);
        position:static;
        padding-left:5px;
    }
}
.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;
}
.head__layout1 .branding__nav {
    margin-right:240px;
    font-family:'Zen Old Mincho', serif;
    font-weight:400;
    font-style:normal;
}
.head__layout1 .btnMenu {
    position:absolute;
    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:#cccccc;
    color:#ffffff;
    text-decoration:none;
}
.head__layout1 .btnMenu a i {
    font-size:3rem;
}
.head__layout1 .btnMenu a span {
    margin-top:5px;
    display:block;
    font-size:1rem;
}
.head__layout1 .btnMenu1 {
    top:0;
    right:140px;
}
.head__layout1 .btnMenu1 a {
    background:#573731;
}
.head__layout1 .btnMenu2 {
    top:0;
    right:70px;
}
.head__layout1 .btnMenu2 a {
    background:#bdb4b3;
}
.head__layout1 .btnMenu3 {
    top:0;
    right:0;
}
.head__layout1 .btnMenu3 a {
    background:#f18eac;
}
@media only screen and (max-width: 980px) {
    .head__layout1 nav.glNaviPc {
        display:none;
    }
    .head__layout1 .branding__nav {
        display:none;
    }
}
@media only screen and (max-width: 980px) {
    .head__layout1 .btnMenu1 {
        top:0;
        right:210px;
    }
    .head__layout1 .btnMenu1 a {
        background:#573731;
    }
    .head__layout1 .btnMenu2 {
        top:0;
        right:140px;
    }
    .head__layout1 .btnMenu2 a {
        background:#bdb4b3;
    }
    .head__layout1 .btnMenu3 {
        top:0;
        right:70px;
    }
    .head__layout1 .btnMenu3 a {
        background:#f18eac;
    }
}
@media only screen and (max-width: 560px) {
    .head__layout1 .btnMenu {
        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:#f18eac;
}

/*==ナビゲーション全体の設定*/
nav.glNaviPc {
    color:#f18eac;
    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:#573731;
    font-size:1.6rem;
}
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:#573731;
    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);
    /* 表示時 */
    /* 以降はレイアウトなど前回と同じ ---------------------- */
    position:fixed;
    left:0;
    width:100vw;
    top:0;
    top:69px;
    /* JS でヘッダー高を上書き */
    z-index:998;
    background:#573731;
    padding:30px 0;
}
.mega-menu.active {
    opacity:1;
    transform:translateY(0);
    /* 0 まで滑らかに下りてくる */
    visibility:visible;
    pointer-events:auto;
}
.mega-menu .mega-inner {
    max-width:1300px;
    margin:0 auto;
    padding:0 32px;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(210px, 210px));
    gap:15px;
    justify-content:center;
    align-items:center;
    justify-items:center;
    /* 子リンクの遅延フェード */
}
.mega-menu .mega-inner a {
    font-size:1.4rem;
    background:#ffffff;
    display:block;
    text-decoration:none;
    color:#222222;
    opacity:0;
    transform:translateY(10px);
    animation:fadeUp 0.45s forwards;
    border-radius:30px;
    padding:10px;
    width:100%;
    /* カード幅を揃えたい場合は指定 */
    text-align:center;
    transition:0.15s all;
    /* 文字列を中央揃え             */
}
.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%;
}
.mega-menu .mega-inner a span {
    display:block;
    margin:4px auto;
}
.mega-menu .mega-inner a:hover {
    transform:translateY(-4px);
    background:#bdb4b3;
}

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

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

.openbtn5,
#g-nav5 {
    display:none;
}

@media only screen and (max-width: 980px) {
    /*　#g-nav5.openbtn5
  =============================================================== */
    #g-nav5 {
        display:block;
        /*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 {
        justify-content:center;
        align-items:start;
        height:100vh;
        background-color:#ece7de;
        padding:60px 0;
        text-align:center;
    }
    .site-gnavSp {
        margin:2em auto;
        padding:0;
        list-style:none;
        padding:0;
        width:96%;
        background-color:#f8f8f8;
        border-radius:8px;
        box-shadow:0 4px 6px rgba(0, 0, 0, 0.1);
        max-width:480px;
    }
    .site-gnavSp li {
        border-bottom:1px solid #dddddd;
        position:relative;
    }
    .site-gnavSp li:last-child {
        border-bottom:none;
    }
    .site-gnavSp li a,
    .site-gnavSp li label {
        display:block;
        padding:12px 16px;
        color:#573731;
        text-decoration:none;
        font-size:16px;
        transition:background 0.3s;
        cursor:pointer;
    }
    .site-gnavSp li a:hover,
    .site-gnavSp li label:hover {
        background:#bdb4b3;
        color:#ffffff;
    }
    .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;
    }
    .site-gnavSp li ul li {
        border-bottom:none;
    }
    .site-gnavSp li ul li a {
        padding-left:24px;
        font-size:14px;
        color:#666666;
    }
    .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:#573731;
    }
    .site-gnavSp li input[type=checkbox]:checked + label::after {
        transform:translateY(-50%) rotate(180deg);
    }
    /*========= ボタンのためのCSS ===============*/
    .openbtn5 {
        display:block;
        position:fixed;
        z-index:9999;
        /*ボタンを最前面に*/
        top:0;
        right:0;
        cursor:pointer;
        width:70px;
        height:70px;
        background:none;
    }
    .openbtn5 div.inTxt {
        position:absolute;
        display:inline-block;
        color:#573731;
        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:#573731;
        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

===============================================================*/
.site-info {
    background:#ece7de;
    padding:30px 20px;
    margin:30px auto 0;
    width:96%;
    border-radius:30px 30px 0 0;
}

.copy {
    background:#573731;
    color:#ffffff;
    text-align:center;
    font-size:1.4rem;
    padding:0.1em 0;
}

.footerFlex {
    display:flex;
    gap:20px;
}
.footerFlex .flex__itemL {
    width:calc(30% - 20px);
}
.footerFlex .flex__itemR {
    width:calc(70% - 20px);
}
@media only screen and (max-width: 980px) {
    .footerFlex {
        flex-direction:column;
        gap:0;
    }
    .footerFlex .flex__itemL {
        width:100%;
        order:2;
        text-align:center;
        margin-top:30px;
    }
    .footerFlex .flex__itemR {
        width:100%;
        order:1;
    }
}
@media only screen and (max-width: 680px) {
    .footerFlex .flex__itemL {
        margin-top:10px;
    }
    .footerFlex .flex__itemR {
        display:none;
    }
}

.innerFlex {
    display:flex;
    gap:20px;
    font-size:1.4rem;
    font-family:'Zen Old Mincho', serif;
    font-weight:400;
    font-style:normal;
}
.innerFlex h3 {
    margin-bottom:0.5em;
}
.innerFlex ul {
    list-style:none;
    margin-left:14px;
}
.innerFlex ul li {
    margin-bottom:0.5em;
}
.innerFlex .flex__item {
    width:calc(25% - 20px);
}
.innerFlex .flex__item a {
    text-decoration:none;
    color:#333333;
    transition:0.15s all;
}
.innerFlex .flex__item a:hover {
    color:#f18eac;
}

.footerBtn {
    display:flex;
    gap:20px;
    align-items:center;
    justify-content:center;
}
.footerBtn .flex__item {
    font-size:1.4rem;
}
.footerBtn .flex__item a {
    display:block;
    background:#bdb4b3;
    color:#ffffff;
    padding:3px 20px;
    border-radius:20px;
    text-decoration:none;
}
.footerBtn .flex__item a:hover {
    opacity:0.8;
}
.footerBtn .flex__item2 a {
    background:#f18eac;
}

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

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.2rem;
    text-align:right;
    padding:5px 5px 0 0;
}
.breadcrumbs a {
    color:#333333;
}
.breadcrumbs a:hover {
    color:#f18eac;
}
@media only screen and (max-width: 480px) {
    .breadcrumbs {
        display:none;
    }
}

/*　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:#573731;
}
.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:#ece7de;
    border-color:#cccccc !important;
}

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

@media only screen and (max-width: 768px) {
    .wp-pagenavi {
        flex-wrap:wrap;
        gap:3px;
        padding:10px;
        justify-content:center;
        overflow-x:hidden;
    }
    .wp-pagenavi a,
    .wp-pagenavi span {
        font-size:13px;
        padding:8px 12px;
    }
}
/* 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
===============================================================*/
/* mainV
========================================================================== */
.mainV {
    position:relative;
    overflow:hidden;
}
.mainV .waveBk {
    position:absolute;
    bottom:0;
    width:100%;
}
.mainV .main_catch2,
.mainV .main_catch1 {
    display:inline-block;
    position:absolute;
    z-index:10;
    background-color:rgba(255, 255, 255, 0.9);
    padding:15px 35px;
    font-family:'Zen Old Mincho', serif;
    font-weight:500;
    font-style:normal;
    font-size:clamp(1.6rem, 2.2vw, 2.2rem);
}
.mainV .main_catch1 {
    top:45%;
    left:5%;
}
.mainV .main_catch2 {
    top:60%;
    left:10%;
}
@media only screen and (max-width: 768px) {
    .mainV .main_catch2,
    .mainV .main_catch1 {
        padding:10px 35px;
    }
    .mainV .main_catch1 {
        top:130px;
        left:5%;
    }
    .mainV .main_catch2 {
        top:200px;
        left:10%;
    }
}
@media only screen and (max-width: 600px) {
    .mainV .main_catch2,
    .mainV .main_catch1 {
        padding:10px 20px;
    }
    .mainV .main_catch1 {
        top:20%;
        left:2%;
    }
    .mainV .main_catch2 {
        top:45%;
        left:6%;
    }
}
@media only screen and (max-width: 480px) {
    .mainV {
        padding-bottom:80px;
    }
    .mainV .main_catch2,
    .mainV .main_catch1 {
        position:static;
        padding:0 20px;
        background:none !important;
    }
    .mainV .main_catch {
        position:absolute;
        border-radius:15px;
        padding:10px 0;
        background-color:rgba(255, 255, 255, 0.9);
        z-index:10;
        width:96%;
        margin:0 auto 0;
        left:50%;
                transform:translateX(-50%);
        -webkit-transform:translateX(-50%);
            -ms-transform:translateX(-50%);
        text-align:center !important;
    }
}

.newsFlex {
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
    align-items:start;
    margin-top:2em;
    gap:20px;
}
@media only screen and (max-width: 768px) {
    .newsFlex {
        display:block;
    }
}
@media only screen and (max-width: 480px) {
    .newsFlex {
        margin-top:0;
    }
}
.newsFlex .newsAll_pc {
    font-family:'Zen Old Mincho', serif;
    font-weight:400;
    font-style:normal;
}
.newsFlex .newsAll_pc a {
    border-radius:20px;
    display:inline-block;
    background:#573731;
    color:#ffffff;
    text-decoration:none;
    padding:5px 35px;
    transition:0.15s all;
}
.newsFlex .newsAll_pc a:hover {
    background:#bdb4b3;
}
.newsFlex .newsAll_sp {
    display:none;
}
@media only screen and (max-width: 480px) {
    .newsFlex .newsAll_pc {
        display:none;
    }
    .newsFlex .newsAll_sp {
        display:block;
        font-family:'Zen Old Mincho', serif;
        font-weight:400;
        font-style:normal;
    }
    .newsFlex .newsAll_sp a {
        border-radius:20px;
        display:inline-block;
        background:#573731;
        color:#ffffff;
        text-decoration:none;
        padding:5px 35px;
        transition:0.15s all;
    }
    .newsFlex .newsAll_sp a:hover {
        background:#bdb4b3;
    }
}
.newsFlex .news__item1 {
    width:180px;
}
.newsFlex .news__item1 h2 {
    font-size:clamp(1.8rem, 2.6vw, 2.6rem);
    color:#573731;
    font-family:'Zen Old Mincho', serif;
    font-weight:400;
    font-style:normal;
}
.newsFlex .news__item1 h2 .ja {
    display:block;
    font-size:1.4rem;
}
.newsFlex .news__item1 h2 .eng {
    display:block;
    font-size:1.4rem;
    color:#573731;
}
.newsFlex .news__item1 h2 .eng::before {
    content:'●';
    color:#f18eac;
}
.newsFlex .news__item2 {
    width:calc(100% - 200px);
}
.newsFlex .news__item2 dl {
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
    align-items:start;
    margin-bottom:30px;
    border-bottom:1px dashed #cccccc;
    padding:0.5em 0 1em;
}
.newsFlex .news__item2 dl dt {
    width:200px;
}
.newsFlex .news__item2 dl dt .newsCat {
    font-size:1.4rem;
    background:#bdb4b3;
    color:#ffffff;
    display:inline-block;
    border-radius:15px;
    padding:1px 15px;
    margin:0 4px;
}
.newsFlex .news__item2 dl dd {
    width:calc(100% - 200px);
    margin:0;
}
.newsFlex .news__item2 dl dd a {
    text-decoration:none;
    line-height:1.5;
    color:#333333;
    transition:0.15s all;
}
.newsFlex .news__item2 dl dd a:hover {
    color:#ece7de;
}
@media only screen and (max-width: 768px) {
    .newsFlex {
        display:block;
    }
    .newsFlex .news__item1 {
        width:100%;
    }
    .newsFlex .news__item2 {
        width:100%;
    }
    .newsFlex .news__item2 dl {
        display:block;
    }
    .newsFlex .news__item2 dl dd,
    .newsFlex .news__item2 dl dt {
        width:100%;
    }
}

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

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;
    min-width:230px;
    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;
}

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

_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:red;
    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:#f18eac;
    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:#573731;
    color:#ffffff;
    font-weight:bold;
    font-size:20px;
}

.feas-submit-button,
.search-submit,
.search-Btn {
    border-radius:6px;
    display:inline-block;
    background:#f18eac !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 #f18eac;
    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:#f18eac;
    color:#ffffff;
    display:inline-block;
    padding:10px 20px;
    border-radius:0 0 20px 20px;
}
.formRes table {
    margin-top:30px;
}
.formRes table th {
    background:#f18eac;
    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;
}

input[type=submit],
button[type=submit] {
    cursor:pointer;
}
