@charset "utf-8";
/* common.css */
/*-------    common      ------*/
#contentsArea {
  color: #313131;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 13px;
  line-height: 20px;
}
#contentsArea a {
  color: #313131;
}
#contentsArea * {
  box-sizing: border-box;
}
#contentsArea .inner {
  width: 960px;
  margin: auto;
}
#contentsArea:not(:has(.spotBox)) .inner {
  overflow: hidden;
}
#contentsArea #searchArea {
  &:has(#searchModSection) {
    margin: 80px 0;
  }
  .rn-searchMod__buttonSearch, .rn-searchMod__formDomLink {
    color: #fff;
  }
  .inner {
    width: 100%;
    overflow: visible;
  }
}
.fs24 {
  font-size: 24px !important;
}
.fs18 {
  font-size: 18px !important;
}
.fs16 {
  font-size: 16px !important;
}
.fs15 {
  font-size: 15px !important;
}
.fs14 {
  font-size: 14px !important;
}
.fs12 {
  font-size: 12px !important;
}
.fs11 {
  font-size: 11px !important;
}
.fs10 {
  font-size: 10px !important;
}
.fwB {
  font-weight: bold !important;
}
.fwN {
  font-weight: normal !important;
}
.mb0 {
  margin-bottom: 0 !important;
}
.mt0 {
  margin-top: 0 !important;
}
.ma0 {
  margin: 0 !important;
}
.mb5 {
  margin-bottom: 5px !important;
}
.mb10 {
  margin-bottom: 10px !important;
}
.mb15 {
  margin-bottom: 15px !important;
}
.mb20 {
  margin-bottom: 20px !important;
}
.mb30 {
  margin-bottom: 30px !important;
}
.mb40 {
  margin-bottom: 40px !important;
}
.mt10 {
  margin-top: 10px !important;
}
.mt15 {
  margin-top: 15px !important;
}
.mt20 {
  margin-top: 20px !important;
}
.mt30 {
  margin-top: 30px !important;
}
.mt40 {
  margin-top: 40px !important;
}
.ml15 {
  margin-left: 15px !important;
}
.ml40 {
  margin-left: 40px !important;
}
.ml01 {
  margin-left: 1em !important;
}
.mr01 {
  margin-right: 1em !important;
}
.pt0 {
  padding-top: 0 !important;
}
.pr0 {
  padding-right: 0 !important;
}
.pr01 {
  padding-right: 1em !important;
}
.pr10 {
  padding-right: 10px !important;
}
.pl10 {
  padding-left: 10px !important;
}
.pl20 {
  padding-left: 20px !important;
}
.taC {
  text-align: center !important;
}
.taR {
  text-align: right !important;
}
.dpI {
  display: inline !important;
}
.dpB {
  display: block !important;
}
.clearfix {
  overflow: hidden;
}
.linkTxt {
  text-align: right;
}
.linkTxt a {
  background: no-repeat right center;
  padding-right: 17px;
  text-decoration: none;
}
.linkTxt a:hover {
  text-decoration: underline;
}
.linkTxt.link01 a {
  background-image: url(../img/arrow01.png);
  color: #69413c !important;
  font-weight: bold;
}
.linkTxt.link02 a {
  background-image: url(../img/arrow03.png);
  color: #375375 !important;
  font-weight: bold;
}
.linkTxt.link03 a {
  background-image: url(../img/arrow04.png);
  color: #f7d997 !important;
  font-weight: bold;
}
.linkTxt.link04 a {
  background-image: url(../img/arrow05.png);
  color: #cb525c !important;
  font-weight: bold;
}
.linkTxt.link05 a {
  background-image: url(../img/arrow06.png);
  padding-right: 21px;
  color: #69413c !important;
  font-weight: bold;
}
.linkTxt.link06 a {
  background-image: url(../img/arrow07.png);
  color: #624266 !important;
  font-weight: bold;
}
.linkBtn {
  text-align: center;
}
.linkBtn a {
  font-size: 16px;
  line-height: 30px;
  color: #fff !important;
  padding: 0 64px 0 38px;
  text-decoration: none;
  display: inline-block;
  position: relative;
}
.linkBtn a:after {
  content: "";
  vertical-align: middle;
  width: 16px;
  height: 16px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 38px;
  margin: auto;
  background: url(../img/arrow02.png) no-repeat center center / 16px;
}
.linkBtn.link01 a {
  background: #5b5902;
}
.linkBtn.link01 a:hover {
  background: #6c6a04;
}
.linkBtn.link02 a {
  background: #cb525c;
}
.linkBtn.link02 a:hover {
  background: #d56968;
}
#pageTop {
  bottom: 20px;
  right: 20px;
}
/*-------    mvArea      ------*/
#mvArea .inner {
  padding: 20px 0 0;
}
/*-------    gnaviArea      ------*/
.gnaviArea {
  box-shadow: 0px 4px 6px -1px rgba(0, 0, 0, .1);
}
#fotnaviArea .gnaviArea {
  box-shadow: none;
  border-bottom: 2px solid #ac7f79;
}
#fotnaviArea .gnaviArea:after {
  border-bottom: 4px solid #f1d8d9;
}
.gnaviArea .gnaviList {
  width: 904px;
  margin: auto;
  padding: 7px 0 4px;
  overflow: hidden;
}
.gnaviArea .gnaviList li {
  float: left;
}
.gnaviArea .gnaviList li:not(:last-child) {
  margin-right: 70px;
}
/*-------    mainArea      ------*/
#mainArea {
  padding-bottom: 35px;
}
#mainArea .secTitle {
  text-align: center;
  position: relative;
  z-index: 8;
  margin-top: 10px;
}
#mainArea .secTitle + .line {
  height: 49px;
  background: url(../img/title_bg.png) repeat-x left center;
  position: relative;
  margin: -15px auto 15px;
}
#mainArea .secTitle + .line span {
  display: block;
  width: 140px;
  height: 49px;
  margin: auto;
  background: #fff;
}
#mainArea .secTitle + .line span:before {
  content: url(../img/title_icon.png);
  width: 135px;
  height: 49px;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 5;
}
.subTitle {
  text-align: center;
  margin-bottom: 20px;
}
.lead {
  text-align: center;
  margin-bottom: 30px;
}
/*-------    searchBox      ------*/
#searchBox {
  width: 920px;
  margin: 50px auto 40px;
  font-family: Meiryo, 'Lucida Grande', 'Hiragino Kaku Gothic ProN', sans-serif;
}
#searchBox .md_searchTab {
  margin: 0;
}
#searchBox .md_searchTab .md_search_tabList {
  margin: 0 3px 0 0;
  float: left;
}
#searchBox .md_list {
  position: relative;
}
#searchBox .md_searchTabDome {
  position: absolute;
  top: 0;
  right: 0;
}
#searchBox .md_search_tabList a {
  /*background: url(../img/search_tab_bg01.png) no-repeat left top;*/
  background: #fff;
  border: 2px solid #69413c;
  border-bottom: none;
  border-radius: 4px 4px 0 0;
  padding: 11.5px 0;
  text-align: center;
  width: 180px;
  font-size: 16px;
  font-weight: bold;
  color: #69413c;
  display: block;
  text-decoration: none;
}
#searchBox .md_search_tabList a.is_block, #searchBox .md_search_tabList a:hover {
  /*background: url(../img/search_tab_bg02.png) no-repeat left top;*/
  background: #69413c;
  color: #fff;
}
#searchBox .md_search_tabList a:hover {
  opacity: 1;
}
#searchBox .md_searchTabDome {
  margin-left: 3px;
}
#searchBox .md_searchTabDome li {
  margin: 0 6px 0 0;
  float: left;
}
#searchBox .md_searchTabDome li:first-child {
  margin-left: 9px;
}
#searchBox .md_searchTabDome a {
  width: auto;
  padding: 8px 12px 9px 15px;
  background: #fff;
  border: 2px solid #69413c;
  border-radius: 4px;
  font-size: 13px;
}
#searchBox .md_searchTabDome a:hover {
  background: #69413c;
}
#searchBox .md_searchTabDome a:after {
  content: url(../img/search_tab_arrow_off.png);
  margin-left: 8px;
}
#searchBox .md_searchTabDome a:hover:after {
  content: url(../img/search_tab_arrow_on.png);
}
#searchBox .md_searchTabDome li:last-child {
  margin: 0;
}
#searchBox #js_tabBody {
  border: solid 4px #69413c;
  padding: 15px 20px;
  clear: both;
}
#searchBox #js_tabBody .js_menuDest {
  left: inherit;
  right: 0
}
#searchBox #js_tabBody .md_search_item .md_search_label_reqIcon {
  width: 33px;
}
#searchBox #js_tabBody .md_search_label {
  background-color: #ac7f79;
}
#searchBox #js_tabBody .md_search_label.is_nonBg {
  background: 0 0;
}
/*-------    contactArea      ------*/
#contactArea {
  margin: 80px 0;
}
#contactArea #info {
  width: 960px;
  border: 1px solid #ccc;
  padding: 20px;
}
#hojinArea {
  position: relative;
  margin-top: 20px;
}
#hojinArea .btn {
  position: absolute;
  top: 16px;
  right: 15px;
}
#hojinArea .btn:hover {
  opacity: .8;
}