@charset "UTF-8";
/******************************* Preface ***************************************/
a:hover { color: #879F33; }

/********************************* body ***************************************/
body { /******************************** header **************************************/ /********************************  Main Content ******************************/ /***********************************  footer ********************************/ }

body header .items { display: flex; flex-wrap: nowrap; flex-direction: row; justify-content: space-between; align-items: center; height: 100px; padding: 0rem 1rem; }

body header .items .header_logo { width: 70%; line-height: 0; }

body header .items .menu_wrapper.open .nav { right: 0; opacity: 1; }

body header .items .menu_wrapper.open .toggle_btn span { background-color: #666666; }

body header .items .menu_wrapper.open .toggle_btn span:nth-child(1) { -webkit-transform: translateY(15px) rotate(-315deg); transform: translateY(15px) rotate(-315deg); }

body header .items .menu_wrapper.open .toggle_btn span:nth-child(2) { opacity: 0; }

body header .items .menu_wrapper.open .toggle_btn span:nth-child(3) { -webkit-transform: translateY(-13px) rotate(315deg); transform: translateY(-13px) rotate(315deg); }

body header .items .menu_wrapper.open #mask { display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000; opacity: .8; z-index: 2; cursor: pointer; }

body header .items .menu_wrapper .nav { display: block; position: fixed; top: 0; right: -100%; bottom: 0; width: 100%; padding: 5rem 1rem; background: #ffffff; overflow-x: hidden; overflow-y: auto; -webkit-overflow-scrolling: touch; transition: all .5s; z-index: 3; opacity: 0; margin-right: 0; }

body header .items .menu_wrapper .nav .menu-header_menu-container { width: 100%; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu { display: flex; flex-direction: column; justify-content: flex-end; align-items: center; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item { position: static; width: 100%; height: auto; padding: 1rem 0; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item a { font-weight: bold; font-size: 1.1rem; padding: 1.1rem 0; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item:nth-child(n+2) { margin-left: 0; border-top: 1px solid #000000; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item .sub-menu { position: static; bottom: auto; left: auto; width: 100%; height: auto; opacity: 1; transform: translate(0, 0); display: none; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item .sub-menu li a { position: static; display: block; }

body header .items .menu_wrapper .nav .menu-header_menu-container .menu > .menu-item .sub-menu li a::after { display: none; }

body header .items .menu_wrapper .toggle_btn { display: block; position: fixed; top: 20px; right: 0; width: 100px; height: 100px; transition: all .5s; cursor: pointer; z-index: 3; }

body header .items .menu_wrapper .toggle_btn span { display: block; position: absolute; left: 0; width: 50px; height: 4px; background-color: #666666; transition: all .5s; }

body header .items .menu_wrapper .toggle_btn span:nth-child(1) { top: 30px; left: 25px; }

body header .items .menu_wrapper .toggle_btn span:nth-child(2) { top: 43px; left: 25px; }

body header .items .menu_wrapper .toggle_btn span:nth-child(3) { bottom: 38px; left: 25px; }

body header .items .menu_wrapper #mask { display: none; transition: all .3s; }

body header .items .menu_wrapper .sub_nav { display: block; }

body header .items .menu_wrapper .sub_nav a.sub_nav_02 { font-size: 0.8rem; margin-right: .8rem; padding: .6rem .8rem; line-height: 1; }

body header .vi_wrapper { position: relative; }

body header .vi_wrapper.vi_wrapper_top .mainVi { width: 100%; height: 90vh; }

body header .vi_wrapper.vi_wrapper_top .mainVi #video-background, body header .vi_wrapper.vi_wrapper_top .mainVi .mask { position: fixed; top: 0; left: 0; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -2; }

body header .vi_wrapper.vi_wrapper_top .mainVi .mask { width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2); }

body header .vi_wrapper.vi_wrapper_top .mainVi .title { position: absolute; top: 40%; left: 7%; color: #ffffff; transform: translate(0, -50%); }

body header .vi_wrapper.vi_wrapper_top .mainVi .title h2 { font-weight: bold; font-size: 2.5rem; line-height: 1.5; margin-bottom: 1rem; }

body header .vi_wrapper.vi_wrapper_top .mainVi .title h3 { font-size: 1.1rem; }

body header .vi_wrapper.vi_wrapper_backpart .mainVi { width: 100%; height: 35vh; }

body header .vi_wrapper.vi_wrapper_backpart .mainVi .mv, body header .vi_wrapper.vi_wrapper_backpart .mainVi .mask { position: fixed; top: 0; left: 0; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: -2; }

body header .vi_wrapper.vi_wrapper_backpart .mainVi .title { position: absolute; top: 50%; left: 0; right: 0; margin: auto; color: #ffffff; transform: translate(0, -50%); }

body header .vi_wrapper.vi_wrapper_backpart .mainVi .title h2 { font-weight: bold; }

body header .vi_wrapper.vi_wrapper_backpart .mainVi .title h2 .main { font-size: 2rem; margin-bottom: .5rem; }

body header .vi_wrapper.vi_wrapper_backpart .mainVi .title h2 .sub { font-size: 1.1rem; }

body header.header-02 .inner { padding: 1.5rem; min-width: 100%; }

body header.header-02 .inner .logo { width: 35%; margin: 0; margin-right: auto; }

body header.header-02 .inner .logo a { display: block; }

body header.header-02 .inner .logo a img { margin-right: 0; }

body header.header-02 .inner .menu-wrapper nav.gnav { display: block; position: fixed !important; top: 0; right: -100%; bottom: 0; width: 100%; padding: 9rem 1rem; background: #879F33; overflow-x: hidden; overflow-y: auto; -webkit-overflow-scrolling: touch; transition: all .5s; z-index: 3; opacity: 0; margin-right: 0; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container { width: 100%; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu { display: flex; flex-wrap: nowrap; flex-direction: column; align-items: flex-end; justify-content: center; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item { position: static; width: 100%; height: auto; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.menu-item-has-children ul.sub-menu { display: none; /* デフォルトでは非表示 */ position: relative; padding: 0; padding-left: 1rem; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.menu-item-has-children ul.sub-menu > li a { position: relative; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.menu-item-has-children ul.sub-menu > li a::after { content: '→'; position: absolute; top: 50%; left: 0; transform: translateY(-50%); font-size: .9rem; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.menu-item-has-children .menu-open .sub-menu { display: block; /* メニューが開いているときに表示 */ }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item:nth-child(n+1) { margin-left: auto; border-top: 1px solid white; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item:last-child { margin-left: auto; border-bottom: 1px solid white; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item a { position: relative; display: block; padding: 2rem 1rem; font-size: 1.5rem; font-weight: bold; color: white; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item a > span { display: block; font-weight: normal; color: white; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.button { padding-top: 2em; padding-left: 0; border-bottom: none; }

body header.header-02 .inner .menu-wrapper nav.gnav .menu-container .menu .menu-item.button a { padding: 1.2rem 0; font-size: 1.1rem; text-align: center; }

body header.header-02 .inner .menu-wrapper .toggle-btn { display: block; position: fixed; top: 0; right: 0; width: 70px; height: 70px; transition: all .5s; cursor: pointer; z-index: 3; }

body header.header-02 .inner .menu-wrapper .toggle-btn span { display: block; position: absolute; left: 50%; transform: translateX(-50%); width: 35px; height: 2px; background-color: #000000; transition: all .5s; }

body header.header-02 .inner .menu-wrapper .toggle-btn span:nth-child(1) { top: 20px; }

body header.header-02 .inner .menu-wrapper .toggle-btn span:nth-child(2) { top: 30px; }

body header.header-02 .inner .menu-wrapper .toggle-btn span:nth-child(3) { bottom: 28px; }

body header.header-02 .inner .menu-wrapper.menu-open .gnav { right: 0; opacity: 1; }

body header.header-02 .inner .menu-wrapper.menu-open .toggle-btn { top: 0; margin-top: 0; }

body header.header-02 .inner .menu-wrapper.menu-open .toggle-btn span { left: 25%; background-color: #ffffff; }

body header.header-02 .inner .menu-wrapper.menu-open .toggle-btn span:nth-child(1) { -webkit-transform: translateY(17px) rotate(-315deg); transform: translateY(9px) rotate(-315deg); }

body header.header-02 .inner .menu-wrapper.menu-open .toggle-btn span:nth-child(2) { opacity: 0; }

body header.header-02 .inner .menu-wrapper.menu-open .toggle-btn span:nth-child(3) { -webkit-transform: translateY(-17px) rotate(315deg); transform: translateY(-11px) rotate(315deg); }

body header.header-02 .inner .menu-wrapper.menu-open #mask { display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000; opacity: .3; z-index: 2; cursor: pointer; }

body header.header-02 .inner .menu-wrapper #mask { display: none; transition: all .3s; }

body header.header-02 .mainvi .copy { align-items: center; top: 78%; bottom: auto; left: 0; height: auto; width: 100%; padding: 1.5rem; transform: translateY(-50%); background: rgba(255, 255, 255, 0.7); }

body header.header-02 .mainvi .copy h1 { padding: 0; }

body header.header-02 .mainvi .copy h1 span { font-size: 6vw; font-weight: bold; line-height: 1.3; letter-spacing: .3rem; }

body header.header-02 .mainvi .copy h1 span.sub { font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; font-size: 1rem; font-weight: 500; line-height: 2; padding-bottom: 0; }

body header.header-02 .mainvi .copy h1 span.sub.sub-01 { font-size: 1.4rem; margin-bottom: 1rem; }

body header.header-02 .mainvi .copy h1 span.sub.sub-02 { font-size: 1.2rem; }

body .content-wrap { padding: 4rem 0; }

body .content-wrap .inner.inner-ss { padding: 0 1.5rem; }

body .content-wrap .inner.inner-s { padding: 0 1.5rem; }

body .content-wrap .inner.inner-m { padding: 0 1.5rem; }

body .content-wrap .inner.inner-l { padding: 0 1.5rem; }

body .content-wrap .inner.inner-artcle { max-width: 100%; padding: 0 1.5rem; }

body .content-wrap h1.section-title, body .content-wrap h2.section-title, body .content-wrap h3.section-title, body .content-wrap h4.section-title, body .content-wrap h5.section-title, body .content-wrap h6.section-title { margin-bottom: 3rem; }

body .content-wrap h1.section-title span.main, body .content-wrap h2.section-title span.main, body .content-wrap h3.section-title span.main, body .content-wrap h4.section-title span.main, body .content-wrap h5.section-title span.main, body .content-wrap h6.section-title span.main { font-size: 2rem; }

body .content-wrap h1.section-title span.sub, body .content-wrap h2.section-title span.sub, body .content-wrap h3.section-title span.sub, body .content-wrap h4.section-title span.sub, body .content-wrap h5.section-title span.sub, body .content-wrap h6.section-title span.sub { font-size: 1rem; }

body .content-wrap h1.section-title.centerline span.main, body .content-wrap h2.section-title.centerline span.main, body .content-wrap h3.section-title.centerline span.main, body .content-wrap h4.section-title.centerline span.main, body .content-wrap h5.section-title.centerline span.main, body .content-wrap h6.section-title.centerline span.main { font-size: 2rem; }

body .content-wrap h1.section-title.centerline span.sub, body .content-wrap h2.section-title.centerline span.sub, body .content-wrap h3.section-title.centerline span.sub, body .content-wrap h4.section-title.centerline span.sub, body .content-wrap h5.section-title.centerline span.sub, body .content-wrap h6.section-title.centerline span.sub { font-size: 1rem; }

body .content-wrap h1.section-title-02, body .content-wrap h2.section-title-02, body .content-wrap h3.section-title-02, body .content-wrap h4.section-title-02, body .content-wrap h5.section-title-02, body .content-wrap h6.section-title-02 { margin-bottom: 3rem; font-size: 1.8rem; font-weight: bold; border-bottom: 1px solid #D9D8C2; padding: 0 1rem 1rem 1rem; }

body .content-wrap h1.content-title, body .content-wrap h2.content-title, body .content-wrap h3.content-title, body .content-wrap h4.content-title, body .content-wrap h5.content-title, body .content-wrap h6.content-title { margin-bottom: 2.5rem; }

body .content-wrap h1.content-title.boder-left-01, body .content-wrap h2.content-title.boder-left-01, body .content-wrap h3.content-title.boder-left-01, body .content-wrap h4.content-title.boder-left-01, body .content-wrap h5.content-title.boder-left-01, body .content-wrap h6.content-title.boder-left-01 { font-size: 1.3rem; }

body .content-wrap h1.content-title.boder-left-02, body .content-wrap h2.content-title.boder-left-02, body .content-wrap h3.content-title.boder-left-02, body .content-wrap h4.content-title.boder-left-02, body .content-wrap h5.content-title.boder-left-02, body .content-wrap h6.content-title.boder-left-02 { font-size: 1.3rem; }

body .content-wrap h1.content-title.boder-left-03 span.main, body .content-wrap h2.content-title.boder-left-03 span.main, body .content-wrap h3.content-title.boder-left-03 span.main, body .content-wrap h4.content-title.boder-left-03 span.main, body .content-wrap h5.content-title.boder-left-03 span.main, body .content-wrap h6.content-title.boder-left-03 span.main { font-size: 1.4rem; }

body .content-wrap h1.content-title.boder-left-03 span.sub, body .content-wrap h2.content-title.boder-left-03 span.sub, body .content-wrap h3.content-title.boder-left-03 span.sub, body .content-wrap h4.content-title.boder-left-03 span.sub, body .content-wrap h5.content-title.boder-left-03 span.sub, body .content-wrap h6.content-title.boder-left-03 span.sub { font-size: .9rem; }

body .content-wrap h1.content-title.boder-left-04 span, body .content-wrap h2.content-title.boder-left-04 span, body .content-wrap h3.content-title.boder-left-04 span, body .content-wrap h4.content-title.boder-left-04 span, body .content-wrap h5.content-title.boder-left-04 span, body .content-wrap h6.content-title.boder-left-04 span { margin-left: 0; }

body .content-wrap h1.content-title.boder-left-04 span.main, body .content-wrap h2.content-title.boder-left-04 span.main, body .content-wrap h3.content-title.boder-left-04 span.main, body .content-wrap h4.content-title.boder-left-04 span.main, body .content-wrap h5.content-title.boder-left-04 span.main, body .content-wrap h6.content-title.boder-left-04 span.main { font-size: 1.6rem; }

body .content-wrap h1.content-title.boder-left-04 span.sub, body .content-wrap h2.content-title.boder-left-04 span.sub, body .content-wrap h3.content-title.boder-left-04 span.sub, body .content-wrap h4.content-title.boder-left-04 span.sub, body .content-wrap h5.content-title.boder-left-04 span.sub, body .content-wrap h6.content-title.boder-left-04 span.sub { font-size: 1rem; }

body .content-wrap h1.content-title.boder-left-05 span.main, body .content-wrap h2.content-title.boder-left-05 span.main, body .content-wrap h3.content-title.boder-left-05 span.main, body .content-wrap h4.content-title.boder-left-05 span.main, body .content-wrap h5.content-title.boder-left-05 span.main, body .content-wrap h6.content-title.boder-left-05 span.main { font-size: 1.6rem; padding-left: 2.8rem; }

body .content-wrap h1.content-title.boder-left-05 span.sub, body .content-wrap h2.content-title.boder-left-05 span.sub, body .content-wrap h3.content-title.boder-left-05 span.sub, body .content-wrap h4.content-title.boder-left-05 span.sub, body .content-wrap h5.content-title.boder-left-05 span.sub, body .content-wrap h6.content-title.boder-left-05 span.sub { font-size: 1rem; }

body .content-wrap h1.content-title.boder-left-06, body .content-wrap h2.content-title.boder-left-06, body .content-wrap h3.content-title.boder-left-06, body .content-wrap h4.content-title.boder-left-06, body .content-wrap h5.content-title.boder-left-06, body .content-wrap h6.content-title.boder-left-06 { border-left: 30px solid #879F33; }

body .content-wrap h1.content-title.boder-left-06 span.main, body .content-wrap h2.content-title.boder-left-06 span.main, body .content-wrap h3.content-title.boder-left-06 span.main, body .content-wrap h4.content-title.boder-left-06 span.main, body .content-wrap h5.content-title.boder-left-06 span.main, body .content-wrap h6.content-title.boder-left-06 span.main { font-size: 1.6rem; }

body .content-wrap h1.content-title.boder-left-06 span.sub, body .content-wrap h2.content-title.boder-left-06 span.sub, body .content-wrap h3.content-title.boder-left-06 span.sub, body .content-wrap h4.content-title.boder-left-06 span.sub, body .content-wrap h5.content-title.boder-left-06 span.sub, body .content-wrap h6.content-title.boder-left-06 span.sub { font-size: 1rem; }

body .content-wrap h1.content-title.boder-bottom-01, body .content-wrap h2.content-title.boder-bottom-01, body .content-wrap h3.content-title.boder-bottom-01, body .content-wrap h4.content-title.boder-bottom-01, body .content-wrap h5.content-title.boder-bottom-01, body .content-wrap h6.content-title.boder-bottom-01 { font-size: 1.3rem; }

body .content-wrap h1.content-title.boder-top-01, body .content-wrap h2.content-title.boder-top-01, body .content-wrap h3.content-title.boder-top-01, body .content-wrap h4.content-title.boder-top-01, body .content-wrap h5.content-title.boder-top-01, body .content-wrap h6.content-title.boder-top-01 { font-size: 1.3rem; }

body .content-wrap h1.content-title.boder-bg-01, body .content-wrap h2.content-title.boder-bg-01, body .content-wrap h3.content-title.boder-bg-01, body .content-wrap h4.content-title.boder-bg-01, body .content-wrap h5.content-title.boder-bg-01, body .content-wrap h6.content-title.boder-bg-01 { font-size: 1.3rem; }

body .content-wrap .news-list-wrap-01 { display: block; }

body .content-wrap .news-list-wrap-01 li { width: 100%; margin-right: 0; margin-bottom: 2rem; }

body .content-wrap .news-list-wrap-01 li a { display: block; }

body .content-wrap .news-list-wrap-01 li a .thumb img { display: block; width: 100%; object-fit: cover; aspect-ratio: 16/10; }

body .content-wrap .news-list-wrap-01 li a .text { padding: .5rem 0; }

body .content-wrap .news-list-wrap-01 li a .text .date { font-size: .9rem; padding-bottom: .5rem; line-height: 1; }

body .content-wrap .news-list-wrap-01 li a .text .date > span { display: inline-block; background: #D9D8C2; color: #ffffff; padding: .3rem .8rem; margin-left: .5rem; }

body .content-wrap .news-list-wrap-02 { display: flex; flex-wrap: wrap; }

body .content-wrap .news-list-wrap-02 li { width: calc( 100% / 2 - 1rem); margin-right: 2rem; margin-bottom: 2rem; }

body .content-wrap .news-list-wrap-02 li:nth-child(2n) { margin-right: 0; }

body .content-wrap .news-list-wrap-02 li a { display: block; }

body .content-wrap .news-list-wrap-02 li a:hover { text-decoration: none; }

body .content-wrap .news-list-wrap-02 li a .thumb img { display: block; width: 100%; object-fit: cover; aspect-ratio: 16/10; border-radius: 15px; }

body .content-wrap .news-list-wrap-02 li a .text { padding: .5rem 0; }

body .content-wrap .news-list-wrap-02 li a .text .date { font-family: "Montserrat", sans-serif; color: #999999; font-size: .8rem; padding-bottom: .5rem; line-height: 1; }

body .content-wrap .news-list-wrap-02 li a .text .date > span { display: inline-block; background: #D9D8C2; color: #ffffff; padding: .3rem .8rem; margin-left: .5rem; }

body .content-wrap .news-list-wrap-03 a { display: block; padding: 2.5rem 0; }

body .content-wrap .news-list-wrap-03 a .thumb { width: 100%; }

body .content-wrap .news-list-wrap-03 a .text { width: 100%; padding-left: 0; padding-top: 1rem; }

body .content-wrap .news-list-wrap-03 a .text .date { font-family: "Montserrat", sans-serif; color: #999999; font-size: .8rem; padding-bottom: .5rem; line-height: 1; }

body .content-wrap .news-list-wrap-03 a .text .date > span { display: inline-block; padding: .3rem .8rem; margin-left: .5rem; }

body .content-wrap .news-list-wrap-03 a .text .title { font-weight: bold; padding-bottom: 1rem; }

body .content-wrap .news-list-wrap-03 a .text .detail { font-size: .9rem; }

body .content-wrap .news-list-wrap-04 li a { display: block; padding: 2.5rem 1rem; }

body .content-wrap .news-list-wrap-05 { background: #EFEFEF; padding: 4rem 2rem; }

body .content-wrap .news-list-wrap-05 li a { position: relative; display: flex; flex-wrap: wrap; align-items: center; padding: 2.5rem 0; padding-right: 2.5rem; }

body .content-wrap .news-list-wrap-05 li a::after { content: "→"; padding: 8px; }

body .content-wrap .news-list-wrap-05 li a .date { font-family: "Montserrat", sans-serif; color: #B0AFB0; font-weight: 500; font-size: .9rem; }

body .content-wrap .news-list-wrap-05 li a .category { display: inline-block; background: #ffffff; color: #000000; font-size: .9rem; padding: .3rem .8rem; margin: 0 1rem; line-height: 1; }

body .content-wrap .news-list-wrap-05 li a .title { width: 100%; padding-top: 1rem; padding-right: 0; }

body .content-wrap .box-1col.box-1col-01 .title::before { width: 15%; }

body .content-wrap .box-1col.box-1col-02 { display: block; }

body .content-wrap .box-1col.box-1col-02 .thumb { width: 100%; }

body .content-wrap .box-1col.box-1col-02 .thumb img { display: block; width: 100%; object-fit: cover; aspect-ratio: 1/1; height: auto; }

body .content-wrap .box-1col.box-1col-02 .text { width: 100%; display: flex; flex-direction: column; padding: 2.5rem 1.5rem; background-color: #F6F6F6; }

body .content-wrap .box-1col.box-1col-02 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-03 { display: block; }

body .content-wrap .box-1col.box-1col-03 .thumb { width: 100%; margin-right: 0; }

body .content-wrap .box-1col.box-1col-03 .thumb img { display: block; width: 100%; }

body .content-wrap .box-1col.box-1col-03 .text { position: relative; margin: -8% auto 0 auto; width: 92%; display: flex; flex-direction: column; padding: 2.5rem 1.5rem; background-color: #F6F6F6; }

body .content-wrap .box-1col.box-1col-03 .text h3.section-title .main { font-size: 2rem; }

body .content-wrap .box-1col.box-1col-03 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-04 { display: block; }

body .content-wrap .box-1col.box-1col-04 .thumb { width: 100%; margin-right: 0; }

body .content-wrap .box-1col.box-1col-04 .thumb img { display: block; width: 100%; object-fit: cover; aspect-ratio: 1/1; height: auto; }

body .content-wrap .box-1col.box-1col-04 .text { width: 100%; display: flex; flex-direction: column; padding: 2.5rem 1.5rem; background-color: #F6F6F6; }

body .content-wrap .box-1col.box-1col-04 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-05 { display: block; }

body .content-wrap .box-1col.box-1col-05 .thumb { width: 100%; }

body .content-wrap .box-1col.box-1col-05 .thumb img { display: block; width: 100%; }

body .content-wrap .box-1col.box-1col-05 .text { width: 100%; display: flex; flex-direction: column; padding: 2.5rem .5rem; }

body .content-wrap .box-1col.box-1col-05 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-06 { display: block; padding: 2.5rem 2rem; }

body .content-wrap .box-1col.box-1col-06 .thumb { width: 100%; }

body .content-wrap .box-1col.box-1col-06 .thumb img { display: block; width: 100%; }

body .content-wrap .box-1col.box-1col-06 .text { width: 100%; display: flex; flex-direction: column; padding: 2.5rem 0rem 0 0rem; }

body .content-wrap .box-1col.box-1col-06 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-06 .text .link-btn { width: 100%; }

body .content-wrap .box-1col.box-1col-07 .text { position: relative; width: 90%; margin: -4rem auto 0 auto; padding: 2.5rem 2rem; }

body .content-wrap .box-1col.box-1col-07 .text h3.section-title { margin-bottom: 2.5rem; }

body .content-wrap .box-1col.box-1col-07 .text h3.section-title .main { font-size: 2rem; }

body .content-wrap .box-1col.box-1col-07 .text > p { font-size: .9rem; }

body .content-wrap .box-1col.box-1col-07 .text .link-btn { width: 100%; }

body .content-wrap .box-1col.box-1col-08 .text .title { font-size: 1.8rem; margin-bottom: 2rem; }

body .content-wrap .box-1col.box-1col-08 .text > p { font-size: .9rem; line-height: 2.2; }

body .content-wrap .box-1col.box-1col-09 { padding: 3.5rem 0; }

body .content-wrap .box-1col.box-1col-09 .text > p { padding: 0 2rem; }

body .content-wrap .box-1col.box-1col-09 .text .link-btn { width: 100%; padding: 0 2rem; }

body .content-wrap .box-1col.box-1col-10 { padding: 3rem 2rem; color: #ffffff; }

body .content-wrap .box-1col.box-1col-10 .box-1col-inner { background-size: cover; padding: 3rem 2rem; }

body .content-wrap .box-1col.box-1col-10 .box-1col-inner .text > p { font-size: .9rem; padding: 0; }

body .content-wrap .box-1col.box-1col-10 .box-1col-inner .text .link-btn { width: 100%; }

body .content-wrap .box-col2-wrap-01 { display: block; }

body .content-wrap .box-col2-wrap-01 .item { width: 100%; margin-right: 0; margin-bottom: 2.5rem; }

body .content-wrap .box-col2-wrap-01 .item .text h4 { font-family: "Montserrat", sans-serif; display: flex; align-items: baseline; justify-content: space-between; padding: 1rem 0 1.5rem; font-size: 2.8rem; font-weight: bold; color: #879F33; }

body .content-wrap .box-col2-wrap-01 .item .text h4 span { display: block; font-weight: 500; font-size: 1rem; }

body .content-wrap .box-col2-wrap-02 { display: block; }

body .content-wrap .box-col2-wrap-02 .item { width: 100%; margin-right: 0; margin-bottom: 2.5rem; }

body .content-wrap .box-col2-wrap-02 .item .text { position: relative; padding: 1rem 1.5rem; }

body .content-wrap .box-col2-wrap-02 .item .text h4 { font-family: "Montserrat", sans-serif; font-size: 1.8rem; font-weight: bold; color: #879F33; line-height: 1.4; }

body .content-wrap .box-col2-wrap-02 .item .text h4 span { font-size: 1rem; }

body .content-wrap .box-col2-wrap-02 .item .text::after { padding: .7rem; }

body .content-wrap .box-col2-wrap-03 { display: block; }

body .content-wrap .box-col2-wrap-03 .item { width: 100%; margin-right: 0; margin-bottom: 1.5rem; padding: 2rem; }

body .content-wrap .box-col2-wrap-03 .item .text h4 { padding: 1rem 0 1.5rem; font-size: 2.8rem; font-weight: bold; text-align: center; }

body .content-wrap .box-col2-wrap-03 .item .text h4 span { font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif; display: block; font-weight: 500; font-size: 1rem; }

body .content-wrap .box-col2-wrap-03 .item .btn-wrap a { width: 100%; padding: 1.5rem 0; }

body .content-wrap .box-col2-wrap-03 .item .btn-wrap a::after { content: "→"; position: absolute; top: 50%; right: .5rem; transform: translateY(-50%); display: block; width: 50px; height: 50px; padding: .6rem 0; line-height: 1; border-radius: 100rem; background: #D9D8C2; color: white; font-size: 2.5rem; text-align: left; }

body .content-wrap .box-col2-wrap-04 { display: block; }

body .content-wrap .box-col2-wrap-04 .item { width: 100%; padding: 2.5rem 3rem; }

body .content-wrap .box-col2-wrap-04 .item .text { color: #ffffff; }

body .content-wrap .box-col2-wrap-04 .item .text h4 { font-family: "Montserrat", sans-serif; display: flex; align-items: center; padding: 1rem 0 1.5rem; font-size: 2.8rem; font-weight: bold; line-height: 1; }

body .content-wrap .box-col2-wrap-04 .item .text h4 span { display: block; font-weight: 500; font-size: 1rem; margin-left: 1rem; padding-left: 1rem; border-left: 1px solid #ffffff; line-height: 2; }

body .content-wrap .box-col2-wrap-04 .item .btn-wrap a { width: 100%; padding: 1rem 0; }

body .content-wrap .box-col2-wrap-05 { display: block; }

body .content-wrap .box-col2-wrap-05 .item { width: 100%; padding: 2rem; }

body .content-wrap .box-col2-wrap-05 .item .text { padding: 3rem; }

body .content-wrap .box-col2-wrap-05 .item .text h4 { position: relative; font-family: "Montserrat", sans-serif; padding-bottom: 3rem; font-size: 2.8rem; font-weight: bold; text-align: center; }

body .content-wrap .box-col2-wrap-05 .item .text h4 span { display: block; font-weight: 500; font-size: 1rem; }

body .content-wrap .box-col2-wrap-05 .item .text h4::after { content: ''; border-bottom: 1px solid #ffffff; display: block; position: absolute; left: 50%; bottom: 1.5rem; transform: translateX(-50%); width: 260px; }

body .content-wrap .box-col2-wrap-05 .item .text .btn-wrap a { display: block; width: 260px; margin: 0 auto; padding: 1rem 0; text-align: center; background-color: #ffffff; border: 1px solid #ffffff; color: #879F33; font-size: 1rem; transition: all .3s; }

body .content-wrap .box-col2-wrap-05 .item .text .btn-wrap a:hover { background: transparent; color: white; opacity: 1; }

body .content-wrap .box-col2-wrap-05 .item.bg-img { background-position: center; background-repeat: no-repeat; background-size: cover; }

body .content-wrap .box-col2-wrap-05 .item.bg-img .text { background-color: rgba(135, 159, 51, 0.7); }

body .content-wrap .box-col2-wrap-06 { display: block; }

body .content-wrap .box-col2-wrap-06 .item { width: 100%; margin-right: 0; }

body .content-wrap .box-col2-wrap-06 .item .text { display: flex; flex-direction: column; justify-content: center; align-items: center; height: 100%; background: #879F33; color: #ffffff; padding: 3rem 2rem; }

body .content-wrap .box-col2-wrap-06 .item .text img { display: block; width: 80px; padding-bottom: 1.5rem; }

body .content-wrap .box-col2-wrap-06 .item .text p { font-size: .9rem; font-weight: 500; }

body .content-wrap .box-col2-wrap-06 .item .text p.title { font-size: 1.1rem; font-weight: bold; padding-bottom: 1.5rem; }

body .content-wrap .box-col2-wrap-06 .item .text p.tel { font-size: 1.1rem; font-weight: bold; }

body .content-wrap .box-col2-wrap-06 .item .text p.tel a { display: inline-block; padding-left: .5rem; font-size: 2rem; font-weight: bold; }

body .content-wrap .box-col2-wrap-06 .item .btn-wrap { width: 100%; }

body .content-wrap .box-col2-wrap-06 .item .btn-wrap a { display: block; width: 90%; margin: 0 auto; padding: 1rem 0; text-align: center; background-color: #ffffff; border: 1px solid #ffffff; color: #879F33; font-size: 1rem; font-weight: bold; transition: all .3s; }

body .content-wrap .box-col2-wrap-06 .item .btn-wrap a:hover { background: #879F33; color: white; opacity: 1; }

body .content-wrap .box-col2-wrap-07 { padding: 2.5rem 3rem; border-radius: 30px; }

body .content-wrap .box-col2-wrap-07 h3 { font-size: 1.6rem; font-weight: bold; padding-bottom: 1.5rem; }

body .content-wrap .box-col2-wrap-07 .contact-box { display: block; }

body .content-wrap .box-col2-wrap-07 .contact-box .item { width: 100%; padding: 1.5rem 0 0; }

body .content-wrap .box-col2-wrap-07 .contact-box .item p { text-align: center; font-weight: 600; font-size: 1.3rem; }

body .content-wrap .box-col2-wrap-07 .contact-box .item p.tel a, body .content-wrap .box-col2-wrap-07 .contact-box .item p.tel span { font-size: 2.5rem; color: #000000; line-height: 1.4; }

body .content-wrap .box-col2-wrap-07 .contact-box .item .contact-btn { margin-top: 1rem; }

body .content-wrap .box-col2-wrap-07 .contact-box .item .contact-btn a { display: block; width: 100%; }

body .content-wrap .box-col2-wrap-07 .contact-box .item:first-child { border-right: none; border-top: 1px solid #000000; }

body .content-wrap .box-col2-wrap-07.bg-main .contact-box .item:first-child { border-right: none; border-top: 1px solid #ffffff; }

body .content-wrap .box-col2-wrap-08 { display: block; }

body .content-wrap .box-col2-wrap-08 a { width: 100%; padding: 3rem; }

body .content-wrap .box-col2-wrap-08 a:first-child { background-color: #D9D8C2; color: black; }

body .content-wrap .box-col2-wrap-08 a:last-child { background: #879F33; position: relative; color: white; }

body .content-wrap .box-col2-wrap-08 a:last-child p.main { color: white; }

body .content-wrap .box-col2-wrap-08 a:last-child:after { content: "→"; position: absolute; top: calc(50% - 0.5em); right: 2.5rem; }

body .content-wrap .box-col2-wrap-08 a p { font-weight: bold; letter-spacing: .1rem; line-height: 1.4; }

body .content-wrap .box-col2-wrap-08 a p.title { font-size: 1.1rem; }

body .content-wrap .box-col2-wrap-08 a p.main { font-family: "Montserrat", sans-serif; font-size: 2rem; }

body .content-wrap .box-col2-wrap-08 a p.sub { font-size: 1rem; }

body .content-wrap .box-3col.box-3col-01 .circle-wrap { display: block; }

body .content-wrap .box-3col.box-3col-01 .circle-wrap .item { width: 100%; padding-top: 5rem; }

body .content-wrap .box-3col.box-3col-02 ul.list { display: flex; flex-wrap: wrap; }

body .content-wrap .box-3col.box-3col-02 ul.list li.list-item { width: 100%; margin-right: 0; margin-bottom: 10%; }

body .content-wrap .box-3col.box-3col-02 ul.list li.list-item .title { font-size: 1.3rem; font-weight: bold; padding: 1rem 1.5rem; }

body .content-wrap .box-3col.box-3col-02 ul.list li.list-item .text { font-size: .9rem; padding: 0 1.5rem 1rem 1.5rem; }

body .content-wrap .box-3col.box-3col-02 ul.list li.list-item .more span { font-size: .95rem; padding: .2rem 1.5rem .3rem 1.5rem; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item { width: 100%; margin-right: 0; margin-bottom: 10%; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item .preface { margin: .7rem 0; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item .preface .label { font-size: .85rem; padding: .1rem 1rem 0 1rem; margin-right: 1rem; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item .preface .date { font-size: .9rem; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item .title { font-size: 1.2rem; }

body .content-wrap .box-3col.box-3col-03 ul.list li.list-item .text { font-size: 1rem; }

body .content-wrap .box-3col.box-3col-04 ul.list li.list-item { width: 100%; margin-right: 0; margin-bottom: 5%; }

body .content-wrap .box-3col.box-3col-04 ul.list li.list-item .text { padding: 1.5rem; }

body .content-wrap .box-3col.box-3col-05 ul.list li.list-item { width: 100%; margin-right: 0; margin-bottom: 8%; }

body .content-wrap .box-3col.box-3col-05 ul.list li.list-item .title { padding: 1rem 1rem; display: flex; align-items: stretch; }

body .content-wrap .box-3col.box-3col-05 ul.list li.list-item .title .num { font-size: 3rem; }

body .content-wrap .box-3col.box-3col-05 ul.list li.list-item .title .ttl { font-size: 1.4rem; margin-top: .3rem; }

body .content-wrap .box-3col.box-3col-05 ul.list li.list-item .text { font-size: .9rem; padding: 0 1rem .5rem 1rem; }

body .content-wrap .box-3col.box-3col-06 ul.list li.list-item { width: 100%; margin-right: 0; margin-bottom: 15%; }

body .content-wrap .box-3col.box-3col-06 ul.list li.list-item .thm { width: 65%; margin: 0 auto 2rem auto; }

body .content-wrap .box-3col.box-3col-06 ul.list li.list-item .text { font-size: 1.1rem; text-align: center; }

body .content-wrap .box-free-wrap.box-free-wrap-01 ul li { width: 100%; }

body .content-wrap .box-free-wrap.box-free-wrap-01 ul li .text { position: absolute; top: 50%; right: 0; transform: translateY(-50%); z-index: 1; color: #ffffff; }

body .content-wrap .box-free-wrap.box-free-wrap-01 ul li .text .main { font-size: 1.5rem; }

body .content-wrap .box-free-wrap.box-free-wrap-01 ul li .text .sub { font-size: 1rem; }

body .content-wrap .box-free-wrap.box-free-wrap-02 ul li { width: 50%; }

body .content-wrap .box-free-wrap.box-free-wrap-02 ul li .text .main { font-size: 2.5rem; }

body .content-wrap .box-free-wrap.box-free-wrap-02 ul li .text .sub { font-size: .85rem; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li { flex-wrap: wrap; margin-bottom: 5rem; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(odd) { flex-direction: column; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(odd) .thumb { margin-left: 0; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(odd) .text .main { text-align: left; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(odd) .text .sub { margin: 0; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(odd) .text .link { margin: 2rem 0 0 auto; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li:nth-child(even) .thumb { margin-right: 0; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li .thumb { width: 100%; margin-bottom: 1.6rem; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li .text { width: 100%; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li .text .main { font-size: 1.5rem; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li .text .sub { width: 100%; font-size: 1rem; }

body .content-wrap .box-free-wrap.box-free-wrap-03 ul li .text .link { width: 100%; }

body .content-wrap .link-btn { width: 100%; }

body .content-wrap .link-btn.link-btn-03 a { font-size: 1.4rem; }

body .content-wrap .table tr { padding: 1.5rem; }

body .content-wrap .table tr th { width: 28%; }

body .content-wrap .table tr td { padding: 1.5rem; }

body .content-wrap .form-01.form-inner { padding: 0 1.5rem; }

body .content-wrap form .form-item { display: block; padding: 1.5rem 0; }

body .content-wrap form .form-item label { width: 100%; }

body .content-wrap form select, body .content-wrap form input, body .content-wrap form textarea { width: 100%; }

body .content-wrap form .radio-wrap { display: flex; flex-wrap: wrap; }

body .content-wrap form .radio-wrap label { display: flex; align-items: center; width: calc(100% / 3); padding-bottom: .5rem; }

body .content-wrap form .radio-wrap input[type="radio"] { position: relative; padding: 0; margin-right: .5rem; width: 16px; height: 16px; border: 1px solid #000; border-radius: 50%; vertical-align: -2px; -webkit-appearance: none; -moz-appearance: none; appearance: none; }

body .content-wrap form .radio-wrap input[type="radio"]:checked:before { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 12px; height: 12px; border-radius: 50%; background: #000; content: ''; }

body .content-wrap form input[type=submit] { width: 90%; }

body .content-wrap .submit-btn { width: 100%; }

body .content-wrap .submit-btn input[type=submit] { width: 100%; font-size: 1.1rem; }

body .content-wrap .conf-btn { display: flex; justify-content: center; margin-top: 2rem; }

body .content-wrap .conf-btn form { display: block; width: 100%; padding: .5rem; }

body .content-wrap .conf-btn input[type=submit] { width: 100%; }

body .content-wrap .map { aspect-ratio: 1/1; }

body .content-wrap .map iframe { width: 100%; height: 100%; max-height: 100%; }

body .legal_ttl { font-size: 1.2rem; margin: 2rem 0; }

body .legal_box { max-height: 300px; overflow-y: scroll; padding: 1.5rem 1.5rem; }

body .legal_box .legal_item ul li { font-size: .95rem; }

body footer.footer-03 .inner { padding: 4rem 0; }

body footer.footer-03 .inner .nav { justify-content: center; padding-bottom: 2rem; display: none; }

body footer.footer-03 .inner .nav .menu-footer-container .menu { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }

body footer.footer-03 .inner .nav .menu-footer-container .menu a { display: block; padding: .5rem 2rem; transition: all .3s; }

body footer.footer-03 .inner .info { text-align: center; }

body footer.footer-03 .inner .info .logo img { max-width: 130px; }

body footer.footer-03 .inner .info .add { padding-bottom: 1rem; }

body footer.footer-03 .inner .info .sns-link { display: flex; justify-content: center; }

body footer.footer-03 .inner .info .sns-link a { display: block; }

body footer.footer-03 .inner .info .sns-link a img { display: block; width: 100%; max-width: 40px; }

body footer.footer-03 .copyright { background: #879F33; color: white; padding: 1rem 0; }

body .h_foot .thm { width: 40%; margin-right: .5rem; }

body .h_foot .ttl { width: 60%; font-weight: bold; font-size: 1.8rem; line-height: 1.5; padding: 2rem 1rem; text-align: center; border-radius: 10px; }

body .wixui-box { padding: 2rem; margin-bottom: 2.5rem; }
