@charset "UTF-8";
header { width: 100%; padding: 30px 20px 20px; background: url("../img/bg_header01.svg") repeat-x top center, #fff; }
@media only screen and (max-width: 1024px) { header { padding: 20px 10px 10px; } }
@media only screen and (max-width: 768px) { header { background-size: auto 5px; } }
@media only screen and (max-width: 576px) { header { padding: 15px 0 0; } }
header #headerIn { max-width: 1440px; margin: 0 auto; position: relative; width: 100%; z-index: 999; background: #fff; height: 185px; }
@media only screen and (max-width: 1280px) { header #headerIn { height: 140px; } }
@media only screen and (max-width: 1024px) { header #headerIn { height: inherit; } }
header #headerIn h1 { position: absolute; left: 0; right: 0; bottom: 0.75em; margin: 0 auto; width: 280px; z-index: 1; text-align: center; padding: 0 30px; }
@media only screen and (max-width: 1280px) { header #headerIn h1 { width: 220px; padding: 0 20px; } }
@media only screen and (max-width: 1024px) { header #headerIn h1 { position: inherit; margin-bottom: 10px; bottom: 0; } }
@media only screen and (max-width: 576px) { header #headerIn h1 { padding: 0; width: 120px; } }
header #headerIn h1 img { width: 100%; }
header #headerIn #gNav { margin: 0 auto; position: absolute; left: 0; right: 0; bottom: 0; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav { position: relative; left: inherit; right: inherit; bottom: inherit; } }
@media only screen and (max-width: 768px) { header #headerIn #gNav { display: none; } }
header #headerIn #gNav > ul { display: flex; justify-content: center; align-items: center; }
header #headerIn #gNav > ul > li { text-align: center; font-size: 1.1em; }
@media only screen and (max-width: 1280px) { header #headerIn #gNav > ul > li { font-size: 0.95em; } }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li { font-size: 0.9em; } }
header #headerIn #gNav > ul > li:hover { background: #d8efa9; }
header #headerIn #gNav > ul > li:hover > a { color: #333; display: block; }
header #headerIn #gNav > ul > li:hover .menu { transition: max-height 1s ease-in; max-height: 9999px; }
header #headerIn #gNav > ul > li a { padding: 0.75em 0; display: block; color: #333; text-decoration: none; }
@media only screen and (max-width: 1280px) { header #headerIn #gNav > ul > li a { padding: 0.6em 0; } }
header #headerIn #gNav > ul > li a[target="_blank"]::after { content: "\e905"; font-family: lib; font-weight: normal; font-size: 0.6em; color: #666; padding-left: 0.75em; display: inline-block !important; vertical-align: text-top; }
header #headerIn #gNav > ul > li.toggle > a { cursor: default; }
header #headerIn #gNav > ul > li.toggle > a::before { font-family: lib; font-weight: normal; display: inline-block !important; color: #999; content: "\e904"; font-size: 0.9em; margin-right: 0.25em; }
header #headerIn #gNav > ul > li:nth-child(1) { width: 13%; border-left: 1px dashed #999; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(1) { width: 13%; } }
header #headerIn #gNav > ul > li:nth-child(2) { width: 24%; border-left: 1px dashed #999; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(2) { width: 23%; } }
header #headerIn #gNav > ul > li:nth-child(3) { width: 13%; margin-right: 135px; border-left: 1px dashed #999; border-right: 1px dashed #999; }
@media only screen and (max-width: 1280px) { header #headerIn #gNav > ul > li:nth-child(3) { margin-right: 110px; } }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(3) { width: 13%; margin-right: 0; border-right: none; } }
header #headerIn #gNav > ul > li:nth-child(4) { width: 15%; margin-left: 135px; border-left: 1px dashed #999; border-right: 1px dashed #999; }
@media only screen and (max-width: 1280px) { header #headerIn #gNav > ul > li:nth-child(4) { margin-left: 110px; } }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(4) { width: 17%; margin-left: 0; } }
header #headerIn #gNav > ul > li:nth-child(5) { width: 19%; border-right: 1px dashed #999; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(5) { width: 19%; } }
header #headerIn #gNav > ul > li:nth-child(6) { width: 16%; border-right: 1px dashed #999; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav > ul > li:nth-child(6) { width: 15%; } }
header #headerIn #gNav > ul > li:nth-child(7) { display: none; }
header #headerIn #gNav .menu { max-height: 0; overflow: hidden; width: 100%; left: 0; position: absolute; z-index: 2; background: #d8efa9; }
header #headerIn #gNav .menu ul { padding: 80px 30px; }
header #headerIn #gNav .menu ul li { text-align: center; font-size: 1.2em; margin: 0 0.5em; }
@media only screen and (max-width: 1024px) { header #headerIn #gNav .menu ul li { margin: 0; } }
header #headerIn #gNav .menu ul li a { border-radius: 10px; border: 3px solid #fff; background: rgba(255, 255, 255, 0.6); padding: 1.5em 1em; transition: .5s; }
header #headerIn #gNav .menu ul li a:hover { background: white; }
header #headerIn #headerSub { position: absolute; top: -10px; right: 0; }
@media only screen and (max-width: 1024px) { header #headerIn #headerSub { top: 0; } }
@media only screen and (max-width: 768px) { header #headerIn #headerSub { display: none; } }
header #headerIn #headerSub ul#fontSize { display: flex; align-items: center; justify-content: flex-end; white-space: nowrap; line-height: 1; padding: 0; margin-bottom: 10px; }
@media only screen and (max-width: 1280px) { header #headerIn #headerSub ul#fontSize { font-size: 0.9em; } }
header #headerIn #headerSub ul#fontSize li { padding: 0.5em 0.6em; color: #333; text-align: center; }
header #headerIn #headerSub ul#fontSize li.changeBtn { cursor: pointer; background: #fff; border: 1px solid #568e1b; }
header #headerIn #headerSub ul#fontSize li.changeBtn:nth-child(2) { border-right: none; }
header #headerIn #headerSub ul#fontSize li.changeBtn:nth-child(3) { border-left: none; }
header #headerIn #headerSub ul#fontSize li.changeBtn:hover { background: #e1f5cc; }
header #headerIn #headerSub ul#fontSize li.active { background: #568e1b; cursor: default; font-weight: bold; color: #fff; }
header #headerIn #headerSub ul#fontSize li.active:hover { background: #568e1b; }
header #headerIn #headerSub p a { display: flex; align-items: center; background: #a6db3e; padding: 8px 15px; border-radius: 5px; }
header #headerIn #headerSub p a:hover { background: #93ca26; }
header #headerIn #headerSub p a img:nth-child(1) { height: 2.3em; margin-right: 10px; }
@media only screen and (max-width: 1280px) { header #headerIn #headerSub p a img:nth-child(1) { height: 2em; } }
header #headerIn #headerSub p a img:nth-child(2) { height: 1.3em; }
@media only screen and (max-width: 1280px) { header #headerIn #headerSub p a img:nth-child(2) { height: 1em; } }
header.clone-nav { position: fixed; top: 0; left: 0; z-index: 2; width: 100%; transition: 0; transform: translateY(-100%); }
@media only screen and (max-width: 768px) { header.clone-nav { position: relative; display: none; } }
header.clone-nav.is-show { padding: 1em 20px 0.5em; transition: .3s; transform: translateY(0); background: #fff; box-shadow: 0 0 3px 0 rgba(0, 0, 0, 0.3); }
@media only screen and (max-width: 768px) { header.clone-nav.is-show { display: none; } }
header.clone-nav.is-show #headerIn { height: calc( 1.1em + (0.75em * 2) + 0.5em); }
header.clone-nav.is-show #headerIn h1 { display: none; }
header.clone-nav.is-show #headerIn #headerSub { display: none; }
@media only screen and (max-width: 1024px) { header.clone-nav.is-show #headerIn #gNav > ul > li { font-size: 0.8em; } }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(1) { width: 11%; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(2) { width: 21%; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(3) { width: 10%; margin-right: 0; border-right: none; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(4) { width: 14%; margin-left: 0; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(5) { width: 17%; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(6) { width: 13%; }
header.clone-nav.is-show #headerIn #gNav > ul > li:nth-child(7) { display: block; width: 14%; border-right: 1px dashed #999; }

.cd-header, .cd-primary-nav { display: none; }
@media only screen and (max-width: 768px) { .cd-header, .cd-primary-nav { display: block; } }

.container { width: 100%; max-width: 1480px; padding-right: 20px; padding-left: 20px; margin: 0 auto; }
@media only screen and (max-width: 768px) { .container { padding-right: 15px; padding-left: 15px; } }

#pageTitle { width: 100%; padding: 5em 0; background-image: url("../img/bg_pageTitle01.jpg"); background-size: cover; background-repeat: no-repeat; background-position: center; text-align: center; }
@media only screen and (max-width: 576px) { #pageTitle { padding: 3em 0; } }
#pageTitle section { width: auto; min-width: 360px; background: rgba(255, 255, 255, 0.8); border: 2px solid white; border-radius: 10px; display: inline-block; padding: 1.5em 3em; margin: 0 2em; }
@media only screen and (max-width: 576px) { #pageTitle section { min-width: inherit; padding: 1em 2em; } }
#pageTitle section h1 { font-family: "Kosugi Maru", sans-serif; font-size: 2.4em; font-weight: bold; }
@media only screen and (max-width: 1280px) { #pageTitle section h1 { font-size: 2.2em; } }
@media only screen and (max-width: 1024px) { #pageTitle section h1 { font-size: 2em; } }
@media only screen and (max-width: 768px) { #pageTitle section h1 { font-size: 1.5em; } }
@media only screen and (max-width: 576px) { #pageTitle section h1 { font-size: 1.3em; } }

nav#breadcrumbs { background: #fff8e5; margin: 0 auto 5em; padding: 0 0; }
nav#breadcrumbs ol { max-width: 1480px; margin: auto; padding: 0.5em 20px; font-size: 0.85em; text-align: left; display: flex; flex-wrap: wrap; }
nav#breadcrumbs ol li { list-style-type: none; color: #666; }
nav#breadcrumbs ol li::before { content: ">"; padding-right: 1em; padding-left: 1em; }
@media only screen and (max-width: 576px) { nav#breadcrumbs ol li::before { padding-right: 0.5em; padding-left: 0.5em; } }
nav#breadcrumbs ol li:first-child:before { content: ""; padding-right: 0; padding-left: 0; }
nav#breadcrumbs ol li a { font-weight: bold; text-decoration: underline; color: #333; }
nav#breadcrumbs ol li a:hover { color: #568e1b; }

#contents { display: flex; justify-content: space-between; }
#contents main { width: calc(100% - (50px + 260px)); }
@media only screen and (max-width: 1280px) { #contents main { width: calc(100% - (50px + 240px)); } }
@media only screen and (max-width: 1024px) { #contents main { width: calc(100% - (40px + 220px)); } }
@media only screen and (max-width: 768px) { #contents main { width: 100%; } }
#contents main.full { width: 100%; }
#contents nav#side { width: 260px; }
@media only screen and (max-width: 1280px) { #contents nav#side { width: 240px; } }
@media only screen and (max-width: 1024px) { #contents nav#side { width: 220px; } }
@media only screen and (max-width: 768px) { #contents nav#side { display: none; } }
#contents nav#side p.title { background: #568e1b; padding: 0.75em 1em; font-size: 1.2em; color: #fff; font-weight: bold; }
#contents nav#side ul li { border: 1px solid #568e1b; border-top: none; text-indent: -1em; }
#contents nav#side ul li a { display: block; padding: 1em 1em 1em 2em; color: #333; text-decoration: none; }
#contents nav#side ul li a::before { font-family: lib; content: "\e901"; color: #568e1b; }
#contents nav#side ul li a:hover { background: #eff9e4; }

.subTitle01 { border-bottom: 4px solid #568e1b; font-size: 1.4em; font-weight: bold; margin-bottom: 1em; }

.subTitle02 { position: relative; padding: 0 0 0.2em 0.7em; border-bottom: 1px solid #ccc; margin-top: 2em; margin-bottom: 1em; font-size: 1.6em; font-weight: bold; }
@media only screen and (max-width: 1280px) { .subTitle02 { font-size: 1.5em; } }
@media only screen and (max-width: 768px) { .subTitle02 { font-size: 1.3em; } }
@media only screen and (max-width: 576px) { .subTitle02 { font-size: 1.2em; } }
.subTitle02::after { position: absolute; top: 0.2em; left: 0; content: ''; width: 5px; height: 1.4em; background-color: #568e1b; }
.subTitle02:not(:first-of-type) { margin-top: 3em; }

.subTitle03 { font-weight: bold; font-size: 1.2em; }
@media only screen and (max-width: 576px) { .subTitle03 { font-size: 1em; } }
.subTitle03::before { content: "●"; color: #568e1b; margin-right: 0.25em; }

.subTitle04 { text-align: center; }
.subTitle04 span { position: relative; display: inline-block; margin-bottom: 2em; font-size: 2.2em; font-weight: bold; }
@media only screen and (max-width: 768px) { .subTitle04 span { font-size: 2em; } }
@media only screen and (max-width: 576px) { .subTitle04 span { font-size: 1.5em; } }
.subTitle04 span:before { content: ''; position: absolute; bottom: -15px; display: inline-block; width: 60px; height: 6px; left: 50%; transform: translateX(-50%); background-color: #568e1b; border-radius: 3px; }

footer { margin-top: 50px; border-top: 2px solid #f2e7c7; width: 100%; }
@media only screen and (max-width: 768px) { footer { border-top: none; } }
footer #footerNav { padding: 2em 20px; background: #fff8e5; }
@media only screen and (max-width: 1024px) { footer #footerNav { padding: 2em 10px; } }
@media only screen and (max-width: 768px) { footer #footerNav { display: none; } }
footer #footerNav #footerNavIn { margin: 0 auto; max-width: 1440px; display: flex; justify-content: space-between; }
footer #footerNav #footerNavIn nav { width: calc((100% - 120px) / 5); }
footer #footerNav #footerNavIn nav p { font-weight: bold; font-size: 1em; border-bottom: 3px double #999; padding-bottom: 0.25em; margin-bottom: 0.5em; }
@media only screen and (max-width: 1280px) { footer #footerNav #footerNavIn nav p { font-size: 0.9em; } }
footer #footerNav #footerNavIn nav p::before { font-family: lib; font-weight: normal; display: inline-block !important; color: #568e1b; content: "\e904"; margin-right: 0.25em; }
footer #footerNav #footerNavIn nav p a { color: #333; }
@media only screen and (max-width: 1280px) { footer #footerNav #footerNavIn nav ul { font-size: 0.9em; } }
footer #footerNav #footerNavIn nav ul li { font-size: 0.9em; }
footer #footerNav #footerNavIn nav ul li::before { font-family: lib; font-weight: normal; display: inline-block !important; color: #568e1b; content: "\e901"; }
footer #footerNav #footerNavIn nav ul li a { color: #333; }
footer #footerNav #footerNavIn nav ul li a[target="_blank"]::after { content: "\e905"; font-family: lib; font-weight: normal; font-size: 0.8em; color: #666; padding-left: 0.75em; display: inline-block !important; }
footer #footerNav > nav { max-width: 1440px; margin: 2em auto 0; }
footer #footerNav > nav ul { display: flex; }
@media only screen and (max-width: 1280px) { footer #footerNav > nav ul { font-size: 0.9em; } }
footer #footerNav > nav ul li { font-weight: bold; margin-right: 3em; }
footer #footerNav > nav ul li::before { font-family: lib; font-weight: normal; display: inline-block !important; color: #568e1b; content: "\e903"; }
footer #footerNav > nav ul li a { color: #333; }
footer #footerNav > nav ul li a[target="_blank"]::after { content: "\e905"; font-family: lib; font-weight: normal; font-size: 0.8em; color: #333; padding-left: 0.75em; display: inline-block !important; }
footer #footerBottom { background: #568e1b; color: #fff; padding: 2em 20px; }
@media only screen and (max-width: 1024px) { footer #footerBottom { padding: 2em 10px; } }
footer #footerBottom #footerBottomIn { display: flex; justify-content: space-between; max-width: 1440px; margin: 0 auto; }
@media only screen and (max-width: 768px) { footer #footerBottom #footerBottomIn { display: inherit; } }
footer #footerBottom #footerBottomIn .sec01 h1 { font-size: 1.4em; }
footer #footerBottom #footerBottomIn .sec01 ul { display: flex; }
@media only screen and (max-width: 768px) { footer #footerBottom #footerBottomIn .sec01 ul { display: inherit; } }
footer #footerBottom #footerBottomIn .sec01 ul li { margin-right: 1em; }
footer #footerBottom #footerBottomIn .sec01 ul li a { color: #fff; }
footer #footerBottom #footerBottomIn .sec02 p span { vertical-align: middle; }
footer #footerBottom #footerBottomIn .sec02 p span.icon-facebook01 { color: #fff; font-size: 1.8em; margin-right: 5px; }
footer #footerBottom #footerBottomIn .sec02 p a { color: #fff; }
footer small { text-align: center; font-size: 0.8em; padding: 0.25em 0; }

#page-top.page-top { display: none; }
#page-top.page-top a.move-page-top { margin: 0; padding: 0; position: fixed; z-index: 2; right: 25px; bottom: 25px; display: block; background: rgba(166, 219, 62, 0.8); border-radius: 50%; width: 60px; height: 60px; line-height: 60px; cursor: pointer; color: #235904; text-decoration: none; text-align: center; -webkit-transition: all 0.3s; -moz-transition: all 0.3s; transition: all 0.3s; }
@media only screen and (max-width: 576px) { #page-top.page-top a.move-page-top { right: 15px; bottom: 20px; width: 50px; height: 50px; line-height: 50px; } }
#page-top.page-top a.move-page-top:hover { background: #a6db3e; }
