@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Libre+Baskerville:400,700");

/***********************

common

***********************/

.mt5 {
  margin-top: 5px;
}

.mt10 {
  margin-top: 10px;
}

.mt20 {
  margin-top: 20px;
}

.mt30 {
  margin-top: 30px;
}

.mt40 {
  margin-top: 40px;
}

.mt50 {
  margin-top: 50px;
}

.mt60 {
  margin-top: 60px;
}

.mt70 {
  margin-top: 70px;
}

.mt80 {
  margin-top: 80px;
}

.mt90 {
  margin-top: 90px;
}

.mt100 {
  margin-top: 100px;
}

.mb5 {
  margin-bottom: 5px;
}

.mb10 {
  margin-bottom: 10px;
}

.mb20 {
  margin-bottom: 20px;
}

.mb30 {
  margin-bottom: 30px;
}

.mb40 {
  margin-bottom: 40px;
}

.mb50 {
  margin-bottom: 50px;
}

.mb60 {
  margin-bottom: 60px;
}

.mb70 {
  margin-bottom: 70px;
}

.mb80 {
  margin-bottom: 80px;
}

.mb90 {
  margin-bottom: 90px;
}

.mb100 {
  margin-bottom: 100px;
}

p.page-top {
  display: none;
}

#pagetop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 50px;
  height: 50px;
  background-color: #fff;
  border: 4px solid #334281;
  text-align: center;
  border-radius: 50%;
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

#pagetop a {
  display: block;
  width: 50px;
  height: 50px;
  color: #334281;
}

#pagetop svg {
  width: 20px;
  font-size: 2em;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.breadcrumbs {
  color: #333;
  background-color: #EBEBEB;
  margin: 0;
  padding: 0;
  font-size: 15px;
  line-height: 28px;
}

.breadcrumbs span {
  margin: 0;
  padding: 0;
  display: inline-block;
  color: #666;
}

.breadcrumbs span a {
  margin: 0;
  padding: 0 0 0 10px;
  display: inline-block;
}

.breadcrumbs span a span {
  color: #334281;
}

.breadcrumbs span a:after {
  content: "\f0da";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

.breadcrumbs span a svg {
  margin-left: 0.5em;
}

.breadcrumbs .home {
  background-color: #334281;
  position: relative;
  margin-right: 28px;
  padding-left: 40px;
}

.breadcrumbs .home span {
  color: #fff;
}

.breadcrumbs .home:after {
  position: absolute;
  right: -28px;
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 28px 0 0 28px;
  border-color: transparent transparent transparent #334281;
}

.breadcrumbs .home svg {
  display: none;
}

.breadcrumbs a {
  color: #333;
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
}

p {
  line-height: normal;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

blockquote {
  display: block;
  -webkit-margin-before: 1em;
  -webkit-margin-after: 1em;
  -webkit-margin-start: 40px;
  -webkit-margin-end: 40px;
}

.aligncenter {
  display: block;
  margin: 0 auto;
}

.alignright {
  float: right;
}

.alignleft {
  float: left;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.clearfix {
  zoom: 1;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

.lib {
  font-family: "Libre Baskerville", serif;
}

.flex_box {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-content: flex-start;
  align-content: flex-start;
  align-items: flex-start;
}

.flex_box_c {
  -webkit-justify-content: center;
  justify-content: center;
}

.flex_end {
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

.w1300 {
  width: 1300px;
//  max-width: 100%;
  max-width: 95%;
  margin: auto;
}

ul {
  list-style: none;
}

.empty_box {
  height: 1px;
  margin: 0;
  padding: 0;
  list-style: none;
}


/********************

layout

********************/

#menu_culum {
  overflow-x: hidden;
}

body {
  font-weight: 500;
  color: #333;
  font-size: 100%;
  line-height: 1.65em;
}

#title_area {
  width: 100%;
  text-align: center;
}

#title_area h1, #title_area .title {
  font-size: 2.8em;
  font-weight: bold;
  line-height: normal;
  margin: 0.8em 0;
  margin-top: 60px;
  margin-bottom: 60px;
}

#title_area h1:after, #title_area .title:after {
  content: "";
  background-color: #334281;
  width: 63px;
  height: 3px;
  margin: auto;
  display: block;
  margin-top: 0.5em;
}

#main_content {
  width: -webkit-calc(100% - 260px);
  width: calc(100% - 260px);
  padding-right: 50px;
  box-sizing: border-box;
}

#main_content-column1 {
  width: 100%;
  font-size: 122%;
}

#sidebar {
  width: 260px;
}

#content {
  width: 100%;
}

.w1000 {
  width: 1000px;
  max-width: 100%;
  margin: auto;
}

.read_btn a {
  width: 250px;
  height: 60px;
  line-height: 60px;
  display: block;
  background-color: #334281;
  text-align: center;
  text-decoration: none;
  color: #fff;
  margin: auto;
  position: relative;
  font-size: 122%;
}

.read_btn a:after {
  position: relative;
  content: "";
  background-image: url("/rrm/wp-content/themes/hyogodai/images/ico/ico_read_more.png");
  height: 8px;
  width: 28px;
  right: -2px;
  top: -2px;
  display: inline-block;
}


/***********************

header

************************/

body, html {
  margin: 0;
  padding: 0;
  font-size: 14px;
}

p {
  font-size: 14px;
}

header .header_area .logo_top_nav .logo .title {
  padding: 0;
}

header .header_area .logo {
  padding-left: 40px;
  margin-bottom: 0;
  padding-top: 20px;
  width: 550px;
  font-weight: bold;
  box-sizing: border-box;
}

header .header_area .logo h1 {
  margin: 0;
}

header .header_area .logo a {
  color: #000;
  text-decoration: none;
  font-size: 1.7vw;
  font-size: 32px;
  background-image: url("/rrm/wp-content/themes/hyogodai/images/logo.png");
  background-size: 83px auto;
  background-repeat: no-repeat;
  padding-left: 90px;
  box-sizing: border-box;
  height: 83px;
  display: block;
  padding-top: 13px;
  line-height: 1.2em;
  white-space: nowrap;
}

header .header_area .logo a span {
  display: block;
  font-size: 0.5em;
  margin-bottom: 5px;
  line-height: 1em;
}

header .header_area .logo_top_nav {
  width: -webkit-calc(100% - 140px);
  width: calc(100% - 140px);
}

header .header_area .logo_top_nav .header_top {
  background-color: #334281;
  height: 45px;
  color: #fff;
}

header .header_area .logo_top_nav .title {
  line-height: 45px;
  padding: 0 20px;
}

header .header_area .logo_top_nav #fontSize {
  margin: 0;
  padding: 0;
}

header .header_area .logo_top_nav #fontSize li {
  line-height: 45px;
  height: 45px;
  width: 45px;
  background-color: #334281;
  text-align: center;
  color: #fff;
  cursor: pointer;
}

header .header_area .logo_top_nav #fontSize li.active {
  background-color: #fff;
  color: #334281;
}

header .header_area .request {
  width: 140px;
  font-size: 122%;
  text-align: center;
  background-color: #960000;
}

header .header_area .request a {
  color: #fff;
  width: 140px;
  height: 140px;
  display: block;
  text-decoration: none;
  padding-top: 43px;
  box-sizing: border-box;
  transition: 0.2s ease;
}

header .header_area .request a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

header .header_area .request a img {
  display: block;
  margin: auto;
  margin-top: 10px;
  width: 20px;
}

header .google {
  text-align: right;
}

header input.gsc-input, header .gsc-input-box, header .gsc-input-box-hover, header .gsc-input-box-focus {
  background-color: transparent;
  border: none;
  border-bottom: 1px solid #fff;
  color: #fff;
}

header #___gcse_1, header #___gcse_0 {
  width: 230px;
  padding-top: 7px;
  display: inline-block;
  vertical-align: top;
}

header #___gcse_1 .gsc-control-cse, header #___gcse_0 .gsc-control-cse {
  padding: 0;
  background-color: transparent;
  border: none;
}

header #___gcse_1 .gsc-control-cse input, header #___gcse_0 .gsc-control-cse input {
  background-color: none;
}

header #___gcse_1 #gsc-i-id2, header #___gcse_0 #gsc-i-id2 {
  background-color: transparent !important;
  color: #fff;
}

header #___gcse_1 .gsib_a, header #___gcse_0 .gsib_a {
  padding: 2px 6px 0;
}

header #___gcse_1 .cse .gsc-search-button-v2, header #___gcse_1 .gsc-search-button-v2, header #___gcse_0 .cse .gsc-search-button-v2, header #___gcse_0 .gsc-search-button-v2 {
  background-image: none !important;
  padding: 6px 12px;
  background-color: transparent !important;
  border: 1px solid transparent;
}

header .top_nav #menu {
  width: -webkit-calc(100% - 70px);
  width: calc(100% - 70px);
  box-sizing: border-box;
}

header #head_nav li {
  width: 30%;
}

header #head_nav li a {
  color: #000000;
  text-decoration: none;
}

header #head_nav li a:before {
  content: "\f0da";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

header #head_nav li a svg {
  margin-right: 5px;
}

header .mail {
  color: #334280;
  font-size: 186%;
  text-align: center;
  width: 70px;
}

header .mail a {
  color: #334280;
  transition: 0.2s ease;
}

header .mail a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

header .top_nav {
  padding-top: 45px;
  width: 540px;
}

header .top_nav .flex_box {
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

header .top_nav .flex_box #menu {
  border-right: 1px solid #B4B4B5;
}

header .top_nav .flex_box #menu ul {
  margin: 3px 0;
  padding: 0;
}

header .top_nav .flex_box #menu ul a:hover {
  color: #334281;
}

header .global_nav {
  margin: 40px 0;
  margin-top: 20px;
}

header #top_nav {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: box;
}

header #top_nav>li>a {
  position: relative;
}

header #top_nav>li>a:after {
  position: absolute;
  left: 50%;
  bottom: -15px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  display: block;
  content: "";
  background-color: #000;
  width: 0;
  height: 1px;
  margin: auto;
  transition: 0.2s ease;
}

header #top_nav>li>a:hover:after {
  width: 4em;
}

header #top_nav li {
  font-size: 122%;
  -webkit-box-flex: 1;
  box-flex: 1;
  text-align: center;
  font-weight: bold;
  position: relative;
}

header #top_nav li:last-child:after {
  display: none;
}

header #top_nav li:after {
  content: "";
  display: block;
  width: 1px;
  height: 1.2em;
  position: absolute;
  right: 0;
  top: 0;
  background-color: #9E9E9F;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

header #top_nav li a {
  color: #000;
  text-decoration: none;
}

header #top_nav li a:hover {
  color: #334281;
}

header #top_nav li:last-child .sub-menu {
  left: auto;
  right: 0;
  width: 340px;
}

header #top_nav li .sub-menu {
  position: absolute;
  left: 0;
  top: 20px;
  font-size: 81.6%;
  padding-top: 20px;
  width: 550px;
  display: none;
  z-index: 10;
}

header #top_nav li .sub-menu li {
  text-align: left;
  background-color: #fff;
  border-left: 1px solid #C8C9CA;
  border-right: 1px solid #C8C9CA;
  padding: 0 15px;
}

header #top_nav li .sub-menu li a {
  padding: 15px;
  padding-left: 5px;
  display: block;
  border-bottom: 1px dotted #878787;
}

header #top_nav li .sub-menu li a:before {
  content: "\f054";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

header #top_nav li .sub-menu li a svg {
  margin-right: 5px;
  font-size: 0.6em;
  position: relative;
  top: -0.2em;
}

header #top_nav li .sub-menu li:after {
  display: none;
}

header #top_nav li .sub-menu li:first-child {
  border-top: 1px solid #C8C9CA;
}

header #top_nav li .sub-menu li:last-child {
  border-bottom: 1px solid #C8C9CA;

}

header #top_nav li .sub-menu li:last-child a {
  border: none;
}

header #top_nav li#menu-item-1630 .sub-menu {
  width: 300px;
}

.top_slider {
  height: 600px;
}

.top_slider .slide {
  height: 600px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.top_slider .slick-prev {
  left: 5%;
  color: #000;
  border: 2px solid #000;
  border-radius: 50%;
  height: 40px;
  width: 40px;
  text-align: center;
  z-index: 10;
}

.top_slider .slick-prev:before {
  position: relative;
  left: 15px;
  color: #000;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  display: block;
  width: 6px;
  height: 6px;
  border: 2px solid #000;
  border-right: none;
  border-top: none;
}

.top_slider .slick-next {
  right: 5%;
  color: #000;
  border: 2px solid #000;
  border-radius: 50%;
  height: 40px;
  width: 40px;
  text-align: center;
}

.top_slider .slick-next:before {
  position: relative;
  left: 12px;
  color: #000;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  display: block;
  width: 6px;
  height: 6px;
  border: 2px solid #000;
  border-left: none;
  border-bottom: none;
}

.top_slider .slick-dots {
  max-width: 100%;
  width: 1300px;
  margin: auto;
  text-align: right;
  left: 50%;
  bottom: -50px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.top_slider .slick-dots li {
  width: 54px;
  height: 2px;
}

.top_slider .slick-dots li button {
  width: 54px;
  height: 2px;
}

.top_slider .slick-dots li button:before {
  content: "";
  width: 54px;
  height: 2px;
  background-color: #334280;
}

.catch_copy {
  position: relative;
}

.catch_copy>div {
  position: absolute;
  top: -160px;
  z-index: 100;
}

.catch_copy p {
  font-size: 75px !important;
  line-height: 1.1em;
  margin: 0;
  font-weight: bold;
  text-shadow: 2px 2px 0 #fff;
}

.catch_copy p:first-letter {
  color: #334281;
}


/************************

TOP

*************************/

#wrapper #main {
  padding-top: 160px;
}

#wrapper #main h2 {
  font-size: 193%;
  padding-left: 40px;
  position: relative;
}

#wrapper #main h2:after {
  content: "";
  left: 0;
  bottom: 0;
  width: 100px;
  height: 3px;
  background-color: #000;
  display: block;
  margin-top: 17px;
}

#wrapper #main h2:before {
  position: absolute;
  left: 0;
  top: 27%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "";
  background-image: url("/rrm/wp-content/themes/hyogodai/images/ico/ico_title.png");
  height: 30px;
  width: 30px;
  display: inline-block;
}

#wrapper #main .left_content a {
  color: #333;
  text-decoration: none;
}

#wrapper #main .left_content .main_content {
  font-size: 122%;
}

#wrapper #main .left_content .main_content a:hover .img div {
  transform: scale(1.1);
}

#wrapper #main .left_content .main_content p {
  font-weight: 500;
}

#wrapper #main .left_content .main_content .img {
  height: 410px;
  position: relative;
  overflow: hidden;
}

#wrapper #main .left_content .main_content .img div {
  height: 410px;
  background-size: cover;
  background-position: center;
  transition: 0.5s ease;
}

#wrapper #main .left_content .main_content .img time {
  position: absolute;
  width: 250px;
  height: 65px;
  left: 30px;
  top: 30px;
  text-align: center;
  background-color: #fff;
  border-top: 3px solid #334281;
  font-size: 20px;
  font-weight: bold;
  line-height: 65px;
  box-sizing: border-box;
  letter-spacing: 0.05em;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center;
}

#wrapper #main .left_content .main_content .img time span {
  vertical-align: bottom;
  font-size: 39px;
  padding: 0 3px;
}

#wrapper #main .left_content .sub_content_link:hover .sub_content .sub_img div {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

#wrapper #main .left_content .sub_content {
  -webkit-align-items: stretch;
  align-items: stretch;
  margin-top: 30px;
}

#wrapper #main .left_content .sub_content .sub_img {
  width: 350px;
  overflow: hidden;
}

#wrapper #main .left_content .sub_content .sub_img div {
  height: 190px;
  background-size: cover;
  background-repeat: no-repeat;
  transition: 0.5s ease;
}

#wrapper #main .left_content .sub_content .sub_text {
  width: -webkit-calc(100% - 370px);
  width: calc(100% - 370px);
  font-size: 122%;
}

#wrapper #main .left_content .sub_content .sub_text h4 {
  font-size: 155%;
  margin: 0;
  margin-bottom: 10px;
  line-height: 1.2em;
}

#wrapper #main .left_content .sub_content .sub_text time {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  line-height: 65px;
  box-sizing: border-box;
  letter-spacing: 0.05em;
  border-bottom: 2px solid #000;
  padding-bottom: 10px;
}

#wrapper #main .left_content .sub_content .sub_text time span {
  vertical-align: bottom;
  font-size: 39px;
  padding: 0 3px;
}

#wrapper #main .right_content ul li {
  margin-bottom: 40px;
}

#wrapper #main .right_content ul li a {
  text-decoration: none;
  color: #000;
}

#wrapper #main .right_content ul li a:hover .thumb img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

#wrapper #main .right_content ul li .thumb {
  width: 150px;
  overflow: hidden;
}

#wrapper #main .right_content ul li .thumb img {
  transition: 0.5s ease;
  vertical-align: top;
  width: 150px;
  height: 150px;
  object-fit: cover;
  object-position: center;
  font-family: 'object-fit: cover;object-position: center;';
}

#wrapper #main .right_content ul li .content {
  width: -webkit-calc(100% - 150px);
  width: calc(100% - 150px);
  padding-left: 20px;
  box-sizing: border-box;
  font-size: 122%;
  font-weight: 500;
}

#wrapper #main .right_content ul li .content .title {
  margin-top: 0;
  font-weight: bold;
}

#wrapper #main .right_content ul li .content .title:after {
  content: "";
  background-color: #000;
  width: 65px;
  height: 1px;
  display: block;
  margin-top: 10px;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

#content_wrapper .left_content {
  width: 59%;
}

#content_wrapper .right_content {
  width: 41%;
  padding-left: 50px;
  box-sizing: border-box;
}

#content_wrapper #news {
  padding-top: 30px;
}

#content_wrapper #news h2 {
  display: inline-block;
}

#content_wrapper #news nav {
  width: auto;
}

#content_wrapper #news nav ul {
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

#content_wrapper #news nav li {
  text-align: center;
  position: relative;
  line-height: 58px;
  text-align: center;
  text-decoration: underline;
  cursor: pointer;
  display: inline-block;
  padding: 0 25px;
}

#content_wrapper #news nav li.active {
  background-color: #334281;
  text-align: center;
  color: #fff;
  text-decoration: none;
}

#content_wrapper #news nav li.active:after {
  position: absolute;
  content: "";
  left: 50%;
  bottom: -7px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 6.5px 0 6.5px;
  border-color: #334281 transparent transparent transparent;
}

#content_wrapper #news .content {
  padding-top: 2em;
  padding-left: 20px;
  box-sizing: border-box;
}

#content_wrapper #news .content .read_btn a {
  background-color: #334281;
  padding-left: 20px;
  box-sizing: border-box;
  font-size: 122%;
  transition: 0.2s ease;
}

#content_wrapper #news .content .read_btn a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

#content_wrapper #news .content .read_btn a:after {
  position: relative;
  content: "";
  background-image: url("/rrm/wp-content/themes/hyogodai/images/ico/ico_read_more.png");
  height: 8px;
  width: 28px;
  right: -2px;
  top: -2px;
  display: inline-block;
}

#content_wrapper #news .content .inner {
  display: none;
}

#content_wrapper #news .content .show {
  display: block;
  animation: shows 1s;
}

@keyframes shows {
  0% {
    -ms-filter: "alpha( opacity=0 )";
    filter: alpha(opacity=0);
    opacity: 0;
  }
  100% {
    -ms-filter: "alpha( opacity=100 )";
    filter: alpha(opacity=100);
    opacity: 1;
  }
}

#content_wrapper #news .content .loop .box {
  width: 380px;
  max-width: 100%;
}

#content_wrapper #news .content .loop .box a {
  color: #000;
  text-decoration: none;
  transition: 0.2s ease;
}

#content_wrapper #news .content .loop .box a .loop_thumb div {
  overflow: hidden;
}

#content_wrapper #news .content .loop .box a .loop_thumb div img {
  transition: 0.5s ease;
}

#content_wrapper #news .content .loop .box a:hover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

#content_wrapper #news .content .loop .box p {
  margin-top: 5px;
  margin-bottom: 0;
}

#content_wrapper #news .content .loop .box .loop_thumb {
  position: relative;
  margin-bottom: 0;
}

#content_wrapper #news .content .loop .box .loop_thumb .no-image {
  height: 230px;
  background-color: #f2f2f2;
  text-align: center;
  position: relative;
}

#content_wrapper #news .content .loop .box .loop_thumb .no-image svg {
  color: #333;
  font-size: 60px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}

#content_wrapper #news .content .loop .box .loop_thumb img {
  vertical-align: top;
  height: 230px;
  width: 100%;
  object-fit: cover;
  object-position: center;
  font-family: 'object-fit: cover;object-position: center;';
}

#content_wrapper #news .content .loop .box .loop_thumb time {
  position: absolute;
  z-index: 2;
  top: -20px;
  left: -20px;
  background-color: #fff;
  width: 72px;
  height: 72px;
  border: 2px solid #000;
  text-align: center;
  padding-top: 17px;
  font-size: 14px;
  box-sizing: border-box;
  line-height: 1.2em;
}

#content_wrapper #news .content .loop .box .loop_thumb time span {
  display: block;
}

#content_wrapper #news .content .loop .box .loop_text {
  margin-bottom: 30px;
}

#banner {
  padding: 100px 0;
}

#banner a {
  transition: 0.2s ease;
}

#banner a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}


/*********************

loop

*********************/


/*********************

archive

*********************/

.archive #page_content nav {
  width: 520px;
}

.archive #page_content nav li {
  width: 130px;
  text-align: center;
  position: relative;
  line-height: 58px;
  text-align: center;
  text-decoration: underline;
  cursor: pointer;
}

.archive #page_content nav li.active {
  background-color: #334281;
  text-align: center;
  color: #fff;
  text-decoration: none;
}

.archive #page_content nav li.active:after {
  position: absolute;
  content: "";
  left: 50%;
  bottom: -7px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 6.5px 0 6.5px;
  border-color: #334281 transparent transparent transparent;
}

.archive #page_content .content {
  padding-top: 2em;
  padding-left: 20px;
  box-sizing: border-box;
}

.archive #page_content .content .read_btn a {
  background-color: #334281;
  padding-left: 20px;
  box-sizing: border-box;
  font-size: 122%;
  transition: 0.2s ease;
}

.archive #page_content .content .read_btn a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

.archive #page_content .content .read_btn a:after {
  position: relative;
  content: "";
  background-image: url("/rrm/wp-content/themes/hyogodai/images/ico/ico_read_more.png");
  height: 8px;
  width: 28px;
  right: 0;
}

.archive #page_content .content .inner {
  display: none;
}

.archive #page_content .content .show {
  display: block;
}

.archive #page_content .content .loop .box {
  width: 380px;
  max-width: 100%;
}

.archive #page_content .content .loop .box a {
  color: #000;
  text-decoration: none;
  transition: 0.2s ease;
}

.archive #page_content .content .loop .box a .loop_thumb div {
  overflow: hidden;
}

.archive #page_content .content .loop .box a .loop_thumb div img {
  transition: 0.5s ease;
}

.archive #page_content .content .loop .box a:hover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.archive #page_content .content .loop .box p {
  margin-top: 5px;
  margin-bottom: 0;
}

.archive #page_content .content .loop .box .loop_thumb {
  position: relative;
  margin-bottom: 0;
}

.archive #page_content .content .loop .box .loop_thumb .no-image {
  height: 230px;
  background-color: #f2f2f2;
  text-align: center;
  position: relative;
}

.archive #page_content .content .loop .box .loop_thumb .no-image svg {
  color: #333;
  font-size: 60px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}

.archive #page_content .content .loop .box .loop_thumb img {
  vertical-align: top;
  height: 230px;
  width: 100%;
  object-fit: cover;
  object-position: center;
  font-family: 'object-fit: cover;object-position: center;';
}

.archive #page_content .content .loop .box .loop_thumb time {
  position: absolute;
  z-index: 2;
  top: -20px;
  left: -20px;
  background-color: #fff;
  width: 72px;
  height: 72px;
  border: 2px solid #000;
  text-align: center;
  padding-top: 15px;
  font-size: 14px;
  box-sizing: border-box;
  line-height: 1.2em;
}

.archive #page_content .content .loop .box .loop_thumb time span {
  display: block;
}


/*********************

sidebar

*********************/

#main #sidebar .has_parent {
  padding: 0 15px;
  box-sizing: border-box;
  background-color: #EDEDED;
  padding-bottom: 20px;
}

#main #sidebar #searchform {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  border: 1px solid #ccc;
}

#main #sidebar #searchform input.s {
  width: calc(100% - 40px);
  height: 40px;
  box-sizing: border-box;
  border: none;
  padding-left: 10px;
}

#main #sidebar #searchform button {
  border: none;
  box-sizing: border-box;
  height: 40px;
  background-color: #334281;
  width: 40px;
  padding: 0;
}

#main #sidebar #searchform button svg {
  color: #fff;
  height: 18px;
  width: auto;
}

#main #sidebar h3 {
  text-align: center;
  margin: 0;
  padding: 1em 0;
  padding-top: 0;
  border-bottom: 1px dotted #000;
  margin-bottom: 1em;
  font-size: 136%;
}

#main #sidebar h3:before {
  display: block;
  content: "";
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 12.5px 0 12.5px;
  border-color: #fff transparent transparent transparent;
  margin-bottom: 10px;
}

#main #sidebar .has_parent ul li {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  margin-bottom: 1em;
}

#main #sidebar .has_parent ul li:before {
  content: "\f054";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

#main #sidebar .has_parent ul li svg {
  width: 20px;
  padding-top: 0.3em;
  font-size: 14px;
}

#main #sidebar .has_parent ul li a {
  display: block;
  width: calc(100% - 20px);
  color: #333;
  text-decoration: none;
}

#main #sidebar .has_parent ul li.current_page_item {
  font-weight: bold;
}

#main #sidebar .has_parent ul li.current_page_item a {
  color: #334281;
}

#main #sidebar #calendar_wrap table {
  border: none;
}

#main #sidebar #calendar_wrap table caption {
  padding: 10px 0;
}

#main #sidebar #calendar_wrap table th, #main #sidebar #calendar_wrap table td {
  padding: 0;
  text-align: center;
  border: 1px solid #ccc;
  color: #666;
}

#main #sidebar #calendar_wrap table th a, #main #sidebar #calendar_wrap table td a {
  color: #334281;
}

#main #sidebar #calendar_wrap table tfoot th, #main #sidebar #calendar_wrap table tfoot td {
  border: none;
}

#main #sidebar li.widget-container li {
  position: relative;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-items: flex-start;
  align-items: flex-start;
  margin-bottom: 1em;
}

#main #sidebar li.widget-container li:before {
  content: "\f054";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

#main #sidebar li.widget-container li svg {
  width: 20px;
  padding-top: 0.3em;
  font-size: 14px;
}

#main #sidebar li.widget-container li a {
  display: block;
  width: calc(100% - 20px);
  color: #333;
  text-decoration: none;
}

#main #sidebar li.widget-container li.current_page_item {
  font-weight: bold;
}

#main #sidebar li.widget-container li.current_page_item a {
  color: #334281;
}

#main #sidebar select {
  border: 1px solid #ccc;
  height: 50px;
  padding: 15px;
  box-sizing: border-box;
  width: 100%;
}


/**********************

single

************************/


/**********************

page

************************/

.singlepage #main_content, .page #main_content {
  font-size: 122%;
}

.singlepage #main_content time, .page #main_content time {
  text-align: right;
  padding-bottom: 50px;
  display: block;
}

.singlepage #main_content h1, .page #main_content h1 {
  font-size: 146%;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  padding: 1em 0;
  padding-left: 0.5em;
  margin-top: 0;
  line-height: 1.5em;
}

.singlepage #main_content .content, .page #main_content .content {
  /*table¥Ç¥¶¥¤¥ó¥Æ¥ó¥×¥ì©`¥È¡¡¤³¤³¤«¤é¡¡à_¹«ˆ@wordpress¤ÎÖÐÉí¤òÀûÓÃ 2016/06/03*/
  /*table¥Ç¥¶¥¤¥ó¥Æ¥ó¥×¥ì©`¥È¡¡¤³¤³¤Þ¤Ç¡¡à_¹«ˆ@wordpress¤ÎÖÐÉí¤òÀûÓÃ 2016/06/03*/
}

.singlepage #main_content .content p, .page #main_content .content p {
  margin-bottom: 1.8em;
  vertical-align: bottom;
  line-height: 1.8em;
}

.singlepage #main_content .content .alignleft, .singlepage #main_content .content .alignright, .page #main_content .content .alignleft, .page #main_content .content .alignright {
  margin: 15px;
}

.singlepage #main_content .content h3, .page #main_content .content h3 {
  padding: 20px 0 20px;
  border-top: 4px solid #ceaa7a;
}

.singlepage #main_content .content table, .page #main_content .content table {
  width: 100%;
  margin-bottom: 40px;
  border-collapse: separate;
  border-spacing: 2px 5px;
}

.singlepage #main_content .content table th, .page #main_content .content table th {
  font-weight: normal;
  text-align: left;
  padding-right: 10px;
  white-space: nowrap;
}

.singlepage #main_content .content table td, .page #main_content .content table td {
  padding-right: 20px;
  vertical-align: middle;
}

.singlepage #main_content .content table td:nth-child(3n), .page #main_content .content table td:nth-child(3n) {
  width: 5em;
}

.singlepage #main_content .content .tb01, .page #main_content .content .tb01 {
  border-collapse: collapse;
  color: #555;
  width: 99%;
  margin: 0 0 1.5em 1px;
}

.singlepage #main_content .content .tb01, .singlepage #main_content .content .tb01 th, .singlepage #main_content .content .tb01 td, .page #main_content .content .tb01, .page #main_content .content .tb01 th, .page #main_content .content .tb01 td {
  border: 1px solid #d4e0ee;
  color: #555;
}

.singlepage #main_content .content .tb01 td, .singlepage #main_content .content .tb01 th, .page #main_content .content .tb01 td, .page #main_content .content .tb01 th {
  padding: 10px;
}

.singlepage #main_content .content .tb01 th, .page #main_content .content .tb01 th {
  text-align: center;
  background: #e6edf5;
  color: #4f76a3;
}

.singlepage #main_content .content .tb01 tr, .page #main_content .content .tb01 tr {
  background: #fcfdfe;
}

.singlepage #main_content .content .tb11, .page #main_content .content .tb11 {
  border: 0 !important;
  border-spacing: 0;
  border-collapse: collapse;
  border-bottom: 2px solid #6678b1 !important;
  width: 100%;
  background: #fff;
}

.singlepage #main_content .content .tb11 th, .singlepage #main_content .content .tb11 td, .page #main_content .content .tb11 th, .page #main_content .content .tb11 td {
  text-align: center;
  border: 0px;
}

.singlepage #main_content .content .tb11 th, .page #main_content .content .tb11 th {
  color: #FFF;
  padding: 10px 8px;
  background: #6678b1;
  border-bottom: 2px solid #6678b1;
}

.singlepage #main_content .content .tb11 td, .page #main_content .content .tb11 td {
  color: #669;
  padding: 8px 8px;
  border-bottom: 1px solid #6678b1;
}

.singlepage #main_content .content .tb11 tr:nth-child(2n+1), .page #main_content .content .tb11 tr:nth-child(2n+1) {
  background: #F7F7F7;
}

.singlepage #main_content .content ul, .page #main_content .content ul {
  margin: 0 0 20px 30px;
}

.singlepage #main_content .content ul li, .page #main_content .content ul li {
  list-style: circle;
  list-style-position: inside;
  margin-bottom: 10px;
}

.singlepage #main_content .content dl, .page #main_content .content dl {
  margin-bottom: 20px;
  overflow: hidden;
}

.singlepage #main_content .content dl dt, .page #main_content .content dl dt {
  float: left;
}

.singlepage #main_content .content dl dd, .page #main_content .content dl dd {
  overflow: hidden;
  zoom: 1;
}

#main .page_english #page_content {
  overflow: hidden;
}

#main .page_english .content h2 {
  text-align: center;
  margin-bottom: 60px;
}

#main .page_english .content h2:before, #main .page_english .content h2:after {
  content: "";
  width: 25px;
  height: 1px;
  display: inline-block;
  background-color: #333;
  vertical-align: middle;
  margin: 0 5px;
}

#main .page_english .content h3 {
  text-align: center;
  margin-bottom: 40px;
  margin-top: 60px;
}

#main .page_english .content .flex_box_re {
  -webkit-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

#main .page_english .content .flex_box_re .img img {
  right: 0;
}

#main .page_english .content .flex_box {
  -webkit-align-items: center;
  align-items: center;
}

#main .page_english .content .flex_box .img {
  position: relative;
  height: 450px;
  z-index: 1;
  width: -webkit-calc(100% - 648px);
  width: calc(100% - 648px);
}

#main .page_english .content .flex_box .img img {
  position: absolute;
  max-width: none;
  top: 0;
}

#main .page_english .content .flex_box .text {
  position: relative;
  z-index: 2;
  width: 648px;
}

#main .page_english .content .flex_box .text .white {
  background-color: rgba(255, 255, 255, 0.7);
  padding: 20px;
  box-sizing: border-box;
}

#main .page_english .content .flex_box .text .white p {
  line-height: 1.8em;
}

#main .page_english .content .ecglish_sub_text {
  margin: 0 -100vw;
  margin-top: 60px;
  margin-bottom: 20px;
  padding: 0 100vw;
  padding-top: 10px;
  padding-bottom: 50px;
  background-color: #F5F6F7;
}

#main .page_english .content .ecglish_sub_text .text-center {
  text-align: center;
}

#main .page_english .content .ecglish_sub_text .inner {
  width: 900px;
  margin: auto;
  max-width: 100%;
}

#main .page_english .content .ecglish_sub_text p {
  line-height: 1.8em;
}

#main .page_english .content .english_facluties table {
  border: none;
  width: 900px;
  max-width: 100%;
  margin: auto;
  margin-bottom: 20px;
  background-color: transparent;
}

#main .page_english .content .english_facluties table tr, #main .page_english .content .english_facluties table th, #main .page_english .content .english_facluties table td {
  border: none;
}

#main .page_english .content .english_facluties table th {
  background-color: #EEEEEF;
}

#main .page_english .content .english_facluties table th, #main .page_english .content .english_facluties table td {
  border-top: 1px dotted #000;
  border-bottom: 1px dotted #000;
  font-size: 95%;
  line-height: 1.8em;
}

#main .page_english .content .english_info p {
  text-align: center;
  line-height: 1.8em;
  padding-bottom: 2em;
}

#main .page_english .content .english_info ul {
  width: 720px;
  line-height: 1.8em;
  max-width: 100%;
  margin: auto;
  margin-bottom: 3em;
}

.page_poster .poster p {
  text-align: center;
}

.page_poster .poster .flex_box {
  -webkit-justify-content: space-around;
  justify-content: space-around;
}

.page_poster .poster_inner {
  overflow-x: auto;
}

.page_poster .poster_top {
  position: relative;
  width: 1060px;
  margin: auto;
  height: 725px;
  margin-bottom: 50px;
  margin-top: 40px;
}

.page_poster .poster_top .poster_img {
  position: absolute;
  display: inline-block;
}

.page_poster .poster_top .poster_img:nth-child(1) {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 375px;
  z-index: 10;
}

.page_poster .poster_top .poster_img:nth-child(2) {
  top: 50px;
  left: 0;
  width: 252px;
  z-index: 9;
}

.page_poster .poster_top .poster_img:nth-child(3) {
  top: 40px;
  right: 0;
  width: 192px;
  z-index: 8;
}

.page_poster .poster_top .poster_img:nth-child(4) {
  top: 430px;
  left: 130px;
  width: 172px;
  z-index: 7;
}

.page_poster .poster_top .poster_img:nth-child(5) {
  top: 370px;
  right: 50px;
  width: 250px;
  z-index: 6;
}

.page_science-cafe-rrm .documents_li, .page_documents .documents_li {
  text-align: center;
  margin-top: 30px;
  -webkit-align-items: stretch;
  align-items: stretch;
  padding: 0 15px;
}

.page_science-cafe-rrm .documents_li div, .page_documents .documents_li div {
  border: 3px solid #DBDCDC;
  border-radius: 5px;
  width: 360px;
  max-width: 100%;
}

.page_science-cafe-rrm .documents_li div a, .page_documents .documents_li div a {
  font-size: 126%;
  color: #000;
  text-decoration: none;
  display: block;
  height: 100%;
  padding: 30px 0;
  padding-top: 40px;
  transition: 0.4s ease;
  box-sizing: border-box;
}

.page_science-cafe-rrm .documents_li div a:hover, .page_documents .documents_li div a:hover {
  color: #fff;
  background-color: #334281;
}

.page_science-cafe-rrm .documents_li div a:hover svg, .page_documents .documents_li div a:hover svg {
  color: #fff;
}

.page_science-cafe-rrm .documents_li div a:after, .page_documents .documents_li div a:after {
  content: "\f107";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

.page_science-cafe-rrm .documents_li div a svg, .page_documents .documents_li div a svg {
  margin: 10px auto;
  color: #334281;
  display: block;
  margin-bottom: 15px;
}


/**********************

footer

************************/

footer {
  background-color: #091F4D;
  background-image: url("/rrm/wp-content/themes/hyogodai/images/background/bg_footer.jpg");
  background-size: cover;
  background-position: center bottom;
  color: #fff;
  padding-top: 50px;
}

footer ul#footer_nav {
  border-bottom: 1px dotted #fff;
  justify-content: flex-end;
  padding-bottom: 20px;
}

footer ul#footer_nav li {
  padding: 0 10px;
  border-right: 1px solid #fff;
  font-size: 108%;
}

footer ul#footer_nav li:last-child {
  border-right: none;
}

footer .home svg {
  margin-right: 5px;
}

footer .footer_main_nav_ul, footer #footer_nav2 {
  margin-bottom: 30px;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}

footer .footer_main_nav_ul>li, footer #footer_nav2>li {
  width: 33%;
  padding-right: 30px;
  box-sizing: border-box;
  margin-bottom: 30px;
}

footer .footer_main_nav_ul .sub_menu, footer .footer_main_nav_ul .sub-menu, footer #footer_nav2 .sub_menu, footer #footer_nav2 .sub-menu {
  margin-top: 1em;
}

footer .footer_main_nav_ul .sub_menu li, footer .footer_main_nav_ul .sub-menu li, footer #footer_nav2 .sub_menu li, footer #footer_nav2 .sub-menu li {
  margin-bottom: 3px;
}

footer .footer_main_nav_ul .sub_menu li:before, footer .footer_main_nav_ul .sub-menu li:before, footer #footer_nav2 .sub_menu li:before, footer #footer_nav2 .sub-menu li:before {
  content: "\f0da";
  display: none;
  font-family: "Font Awesome 5 Solid";
}

footer .footer_main_nav_ul .sub_menu li svg, footer .footer_main_nav_ul .sub-menu li svg, footer #footer_nav2 .sub_menu li svg, footer #footer_nav2 .sub-menu li svg {
  margin-right: 5px;
  margin-left: 5px;
}

footer .footer_bottom {
  padding-top: 30px;
  padding-bottom: 30px;
}

footer .footer_bottom>.flex_box {
  margin-bottom: 20px;
}

footer .footer_bottom .btn a {
  text-align: center;
  width: 123px;
  height: 123px;
  background-color: #fff;
  border-radius: 50%;
  padding-top: 40px;
  display: block;
  box-sizing: border-box;
  font-size: 122%;
  font-weight: bold;
  color: #02153B;
  text-decoration: none;
  transition: 0.2s ease;
}

footer .footer_bottom .btn a:hover {
  -ms-filter: "alpha( opacity=70 )";
  filter: alpha(opacity=70);
  opacity: 0.7;
}

footer .footer_bottom .btn a:after {
  content: "";
  background-image: url("/rrm/wp-content/themes/hyogodai/images/ico/ico_read_more_f.png");
  background-repeat: no-repeat;
  height: 8px;
  width: 28px;
  display: block;
  margin: auto;
  margin-top: 5px;
}

footer .footer_bottom .address {
  padding-bottom: 20px;
}

footer .footer_bottom .address p.sitename {
  font-size: 122% !important;
  font-weight: bold;
}

footer .footer_bottom .address address {
  font-style: normal;
  font-size: 108%;
}

footer .footer_bottom ul {
  display: inline-block;
}

footer .footer_bottom ul li {
  display: inline-block;
}

footer .footer_bottom ul.ft_contact {
  margin-right: 80px;
}

footer .footer_bottom ul.ft_contact li {
  margin-right: 20px;
}

footer .footer_bottom ul.ft_contact li svg {
  font-size: 172%;
}

footer .footer_bottom ul.ft_lang li {
  padding: 0 5px;
  border-bottom: 1px solid #fff;
  font-size: 122%;
  width: 27px;
  text-align: center;
}

footer .footer_bottom ul.ft_lang li.en, footer .footer_bottom ul.ft_lang li.ja_off {
  -ms-filter: "alpha( opacity=50 )";
  filter: alpha(opacity=50);
  opacity: 0.5;
}

footer .footner_copy {
  display: inline-block;
  float: right;
  font-size: 79%;
  padding-top: 5px;
}

footer a {
  color: #fff;
  text-decoration: none;
}

footer .footer_main_nav .col-sm-6 {
  width: 50%;
}

footer .footer_main_nav .col-sm-3 {
  width: -webkit-calc(100% / 4);
  width: calc(100% / 4);
}

@media only screen and (max-width: 1250px) {
  header .header_area .logo {
    width: 43%;
    padding-left: 15px;
  }
  header .header_area .logo a {
    font-size: 2.4vw;
  }
  header .top_nav {
    width: 57%;
  }
  header .top_nav #menu {
    width: -webkit-calc(100% - 67px);
    width: calc(100% - 67px);
    box-sizing: border-box;
  }
  header .mail {
    width: 67px;
    box-sizing: border-box;
  }
  header #top_nav li {
    font-size: 100%;
  }
  #slider_sp {
    overflow: hidden;
  }
  #slider_sp .slide {
    text-align: center;
  }
  #slider_sp .slide a {
    display: inline-block;
  }
  #slider_sp .slide img {
    margin: auto;
    display: block;
  }
  .catch_copy>div {
    padding-left: 15px;
  }
  #main {
    padding: 0 15px;
    box-sizing: border-box;
  }
  #wrapper_page #main {
    padding: 0;
  }
  #wrapper_page #main #page_content {
    padding: 0 15px;
  }
  footer {
    padding-left: 15px;
    padding-right: 15px;
    box-sizing: border-box;
  }
}

@media screen and (max-width: 1000px) {
  #content_wrapper #news>.flex_box {
    display: block;
  }
  #content_wrapper #news nav {
    width: 100%;
  }
  #content_wrapper #news nav .flex_box {
    -webkit-justify-content: center;
    justify-content: center;
  }
}

@media only screen and (max-width: 850px) {
  #pagetop {
    right: 5px;
    bottom: 5px;
    transform: scale(0.8);
  }
  .drawer-hamburger {
    z-index: 9000;
    right: 0;
    top: 1px;
    padding: 18px .5rem 30px;
  }
  .drawer-overlay {
    background-color: rgba(0, 0, 0, 0.6);
  }
  .drawer-open .drawer-hamburger .drawer-hamburger-icon:before, .drawer-open .drawer-hamburger .drawer-hamburger-icon:after {
    background-color: #fff;
  }
  .drawer-open .drawer-hamburger p {
    color: #fff;
  }
  .drawer--right.drawer-open .drawer-hamburger {
    right: 80vw;
  }
  .drawer--right .drawer-nav {
    right: -80vw;
  }
  .drawer-nav {
    z-index: 8999;
    background-color: #334280;
    width: 80vw;
  }
  .drawer-nav .gsc-control-cse {
    border: none;
    margin: 15px;
    padding: 5px;
  }
  .drawer-nav .cse .gsc-search-button-v2, .drawer-nav .gsc-search-button-v2 {
    padding: 6px 8px;
    background-color: transparent;
    border: none;
  }
  .drawer-nav .cse .gsc-search-button-v2 svg, .drawer-nav .gsc-search-button-v2 svg {
    color: #334280;
    fill: #334280;
  }
  .drawer-nav .ft_contact {
    background-color: rgba(0, 26, 47, 0.2);
  }
  .drawer-nav .ft_contact li {
    width: 50%;
    padding: 15px 0;
    text-align: center;
    font-size: 13px;
    box-sizing: border-box;
  }
  .drawer-nav .ft_contact li:first-child {
    border-right: 1px solid rgba(255, 255, 255, 0.4);
  }
  .drawer-nav .ft_contact li a {
    padding: 0;
  }
  .drawer-nav .ft_contact svg {
    display: block;
    margin: auto;
    font-size: 28px;
  }
  .drawer-nav a {
    color: #fff;
    text-decoration: none;
    padding: 20px 10px;
    padding-right: 20px;
    box-sizing: border-box;
    display: block;
  }
  .drawer-nav .sp_nav {
    background-color: #334280;
  }
  .drawer-nav .sp_nav li {
    position: relative;
    font-size: 12px;
    line-height: 1.5em;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    transition: 0.2s ease;
  }
  .drawer-nav .sp_nav li:after {
    content: "\f054";
    display: none;
    font-family: "Font Awesome 5 Solid";
  }
  .drawer-nav .sp_nav li svg {
    position: absolute;
    top: 22px;
    right: 10px;
    color: #fff;
  }
  .drawer-nav .sp_nav>li {
    position: relative;
  }
  .drawer-nav .sp_nav>li:after {
    position: absolute;
  }
  .drawer-nav .sp_nav li.menu-item-has-children>a {
    pointer-events: none;
  }
  .drawer-nav .sp_nav li.menu-item-has-children>svg {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    right: 12px;
  }
  .drawer-nav .sp_nav li.menu-item-has-children ul {
    display: none;
  }
  .drawer-nav .sp_nav li.menu-item-has-children ul svg {
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .drawer-nav .sp_nav li.menu-item-has-children ul a {
    padding: 15px 10px;
  }
  .drawer-nav #menu-nav_top li {
    width: 50%;
    border-right: 1px solid rgba(255, 255, 255, 0.4);
    box-sizing: border-box;
  }
  .drawer-nav #menu-nav_top li:nth-child(even) {
    border-right: none;
  }
  .drawer-nav .sp_nav li.on>svg {
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
  }
  .drawer-nav .sub-menu li {
    background-color: #263260;
  }
  .drawer-overlay {
    z-index: 8998;
  }
  .drawer-hamburger-icon, .drawer-hamburger-icon::after, .drawer-hamburger-icon::before {
    height: 1px;
  }
  .drawer-hamburger-icon::before {
    top: -6px;
  }
  .drawer-hamburger-icon::after {
    top: 6px;
  }
  .drawer-hamburger {
    font-family: "Libre Baskerville", serif;
  }
  .drawer-hamburger span {
    width: 25px;
  }
  .drawer-hamburger p {
    transform: scale(0.5);
    margin: 0;
    position: relative;
    left: -6px;
    top: 9px;
  }
  .hamburger {
    display: block;
    -webkit-transform: scale(0.6);
    transform: scale(0.6);
    top: 15px;
    right: 0;
    color: #000000;
  }
  .hamburger:after {
    color: #000000;
  }
  .hamburger .hamburger__icon {
    background-color: #000000;
  }
  .hamburger .hamburger__icon:before, .hamburger .hamburger__icon:after {
    background-color: #000000;
  }
  .fat-nav {
    background-color: #091F4D;
    top: 68px;
    border-top: 1px solid #333;
    overflow-y: auto;
    height: -webkit-calc(100% - 68px);
    height: calc(100% - 68px);
  }
  .fat-nav nav {
    height: 100%;
  }
  .fat-nav ul {
    display: block;
    background-color: #091F4D;
  }
  .fat-nav ul li.menu-item-has-children {
    position: relative;
  }
  .fat-nav ul li.menu-item-has-children:after {
    content: "\f067";
    display: none;
    color: #fff;
    font-family: "Font Awesome 5 Solid";
  }
  .fat-nav ul li.menu-item-has-children svg {
    position: absolute;
    right: 10px;
    top: 15px;
  }
  .fat-nav ul li.menu-item-has-children>a {
    pointer-events: none;
  }
  .fat-nav ul li {
    font-size: 14px;
    text-align: left;
    border-bottom: 1px dotted #334280;
    box-sizing: border-box;
    overflow: hidden;
    padding: 0;
  }
  .fat-nav ul li ul li:last-child {
    border-bottom: none;
  }
  .fat-nav ul li a {
    color: #fff;
    padding: 10px;
    display: block;
  }
  .w1000 {
    min-width: 100%;
    width: 100%;
    padding: 0 15px;
    box-sizing: border-box;
  }
  .home h1 {
    margin: 0;
  }
  header {
    padding-top: 68.5px;
  }
  header .header_area {
    position: fixed;
    top: 0;
    border-top: 5px solid #334281;
    width: 100%;
    z-index: 1000;
    background-color: #fff;
  }
  header .header_area .header_top {
    display: none;
  }
  header .header_area .logo_top_nav {
    width: 100%;
  }
  header .header_area .logo_top_nav .flex_end {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
  }
  header .header_area .logo_top_nav .flex_end .google {
    padding-left: 15px;
  }
  header .header_area .logo_top_nav .flex_end .flex_box {
    display: none;
  }
  header .header_area .logo {
    padding: 0;
    margin-bottom: 0;
    box-sizing: border-box;
    width: 100%;
  }
  header .header_area .logo .title {
    box-sizing: border-box;
    padding: 0px;
  }
  header .header_area .logo a {
    background-size: 40px auto;
    background-position: 10px center;
    padding-right: 70px;
    padding-top: 10px;
    padding-left: 55px;
    font-size: 13px;
    height: 58px;
    margin-top: 4px;
    box-sizing: border-box;
    display: block;
  }
  header .header_area .logo a span {
    margin-bottom: 5px;
    margin-top: 5px;
    font-size: 10px;
  }
  header .header_area .request {
    width: 50px;
    position: fixed;
    top: 9px;
    right: 35px;
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
  }
  header .header_area .request a {
    height: 100%;
    width: 50px;
    padding: 0;
  }
  header .header_area .request a div {
    font-size: 10px;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  header .header_area .request a div img {
    width: 18px;
    margin-bottom: 2px;
  }
  /******************  TOP  ******************/
  .top_slider {
    height: 50vw;
  }
  .top_slider .slick-prev, .top_slider .slick-next {
    width: 30px;
    height: 30px;
  }
  .top_slider .slick-prev:before {
    left: 10px;
  }
  .top_slider .slick-next:before {
    left: 8px;
  }
  .top_slider .slide {
    height: 50vw;
  }
  .top_slider .slick-dots {
    bottom: -30px;
    overflow-x: hidden;
  }
  .top_slider .slick-dots li {
    width: 25px;
  }
  .top_slider .slick-dots li button:before {
    width: 25px;
  }
  .catch_copy {
    padding-top: 15px;
  }
  .catch_copy>div {
    top: -20vw;
  }
  .catch_copy P {
    font-size: 8vw !important;
  }
  #wrapper #main {
    padding-top: 40px;
  }
  #wrapper #main h2 {
    font-size: 16px;
    padding-left: 1.5em;
  }
  #wrapper #main h2:before {
    width: 1em;
    height: 1em;
    top: 34%;
    background-size: 1em auto;
  }
  #wrapper #main h2:after {
    width: 3em;
    margin-top: 5px;
    margin-bottom: 4px;
  }
  #wrapper #main .left_content .main_content {
    font-size: 14px;
  }
  #wrapper #main .left_content .main_content .img {
    height: auto;
  }
  #wrapper #main .left_content .main_content .img time {
    left: 10px;
    top: 10px;
    font-size: 10px;
    height: auto;
    padding: 8px;
    line-height: 15px;
    width: auto;
  }
  #wrapper #main .left_content .main_content .img time span {
    font-size: 1.8em;
  }
  #wrapper #main .left_content .main_content .img:after {
    content: "";
    display: block;
    padding-top: 55%;
  }
  #wrapper #main .left_content .sub_content .sub_img {
    width: 100%;
    margin-bottom: 15px;
  }
  #wrapper #main .left_content .sub_content .sub_img div {
    height: auto;
  }
  #wrapper #main .left_content .sub_content .sub_img div:after {
    content: "";
    display: block;
    padding-top: 40%;
  }
  #wrapper #main .left_content .sub_content .sub_text {
    width: 100%;
    font-size: 100%;
  }
  #wrapper #main .left_content .sub_content .sub_text time {
    font-size: 10px;
    line-height: 34px;
  }
  #wrapper #main .left_content .sub_content .sub_text time span {
    font-size: 1.5em;
  }
  #wrapper #main .left_content .sub_content .sub_text h4 {
    font-size: 16px;
    margin-bottom: 0;
    margin-top: 0.3em;
  }
  #wrapper #main .right_content ul {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  #wrapper #main .right_content ul li {
    width: 100%;
    margin-bottom: 20px;
  }
  #wrapper #main .right_content ul li .thumb {
    width: 80px;
    height: 80px;
  }
  #wrapper #main .right_content ul li .thumb img {
    width: 80px;
    height: 80px;
  }
  #wrapper #main .right_content ul li .content {
    width: -webkit-calc(100% - 80px);
    width: calc(100% - 80px);
    font-size: 100%;
    font-size: 12px;
    line-height: normal;
  }
  #wrapper #main .right_content ul li .content p.title {
    font-size: 14px;
    font-weight: bold;
  }
  #wrapper #content_wrapper {
    padding: 0;
  }
  #content_wrapper {
    padding: 0 15px;
    box-sizing: border-box;
  }
  #content_wrapper .left_content {
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
  }
  #content_wrapper .right_content {
    width: 100%;
    padding: 0;
  }
  #content_wrapper #news .archive_nav {
    width: 100%;
  }
  #content_wrapper #news nav {
    width: 100%;
  }
  #content_wrapper #news nav ul {
    -webkit-justify-content: flex-start;
    justify-content: center;
  }
  #content_wrapper #news nav li {
    width: auto;
    font-size: 12px;
    line-height: 38px;
    padding: 0 20px;
  }
  #content_wrapper #news .content {
    margin-top: 0px;
    padding-left: 0;
  }
  #content_wrapper #news .content .loop .box {
    width: calc(50% - 7.5px);
    margin: 0 0 15px 0;
  }
  #content_wrapper #news .content .loop .box .loop_thumb {
    width: 100%;
    height: auto;
  }
  #content_wrapper #news .content .loop .box .loop_thumb .no-image {
    height: auto;
  }
  #content_wrapper #news .content .loop .box .loop_thumb img {
    width: 100%;
    height: 26vw;
  }
  #content_wrapper #news .content .loop .box .loop_text {
    width: 100%;
    padding-left: 0;
    margin-bottom: 0;
    box-sizing: border-box;
  }
  #content_wrapper #news .content .loop .box .loop_text time {
    font-size: 10px;
  }
  #content_wrapper #news .content .loop .box .loop_text h3 {
    margin-top: 0;
    font-size: 12px;
    line-height: normal;
    overflow: auto;
    height: auto;
  }
  #content_wrapper #news .content .read_btn a {
    font-size: 100%;
    height: 50px;
    line-height: 50px;
  }
  #banner {
    padding: 50px 0;
    overflow: hidden;
  }
  #banner .banner_inner {
    margin: 0 -15px;
  }
  #banner .col-xs-6 {
    margin-bottom: 10px;
  }
  #banner #slider_sp .slide {
    padding: 0 15px;
    box-sizing: border-box;
    margin-bottom: 0;
  }
  #banner #slider_sp .slick-prev {
    left: 2%;
    color: #000;
    border: 2px solid #000;
    border-radius: 50%;
    height: 40px;
    width: 40px;
    text-align: center;
    z-index: 10;
  }
  #banner #slider_sp .slick-prev:before {
    position: relative;
    left: 15px;
    color: #000;
    content: "";
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    display: block;
    width: 6px;
    height: 6px;
    border: 2px solid #000;
    border-right: none;
    border-top: none;
  }
  #banner #slider_sp .slick-next {
    right: 2%;
    color: #000;
    border: 2px solid #000;
    border-radius: 50%;
    height: 40px;
    width: 40px;
    text-align: center;
  }
  #banner #slider_sp .slick-next:before {
    position: relative;
    left: 12px;
    color: #000;
    content: "";
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    display: block;
    width: 6px;
    height: 6px;
    border: 2px solid #000;
    border-left: none;
    border-bottom: none;
  }
  #banner #slider_sp .slick-prev, #banner #slider_sp .slick-next {
    width: 30px;
    height: 30px;
    background-color: #fff;
  }
  #banner #slider_sp .slick-prev:before {
    left: 10px;
  }
  #banner #slider_sp .slick-next:before {
    left: 8px;
  }
  /******************  PAGE  ******************/
  #title_area h1, #title_area .title {
    font-size: 28px;
    margin: 30px 0;
  }
  .page #main_content {
    width: 100%;
    padding: 0;
    padding-bottom: 50px;
  }
  .page #main_content h1 {
    font-size: 24px;
  }
  .page #sidebar {
    width: 100%;
    padding-bottom: 50px;
  }
  .page #sidebar .has_parent {
    margin-bottom: 30px;
  }
  .page #sidebar .has_parent ul li {
    font-size: 100%;
  }
  .breadcrumbs {
    font-size: 10px;
  }
  .breadcrumbs .home {
    padding-left: 10px;
  }
  #main .page_english .content h2 {
    line-height: normal;
    font-size: 20px;
    margin-bottom: 30px;
  }
  #main .page_english .content .flex_box .img {
    width: 100%;
    height: auto;
  }
  #main .page_english .content .flex_box .img img {
    position: static;
    max-width: 100%;
  }
  #main .page_english .content .flex_box .text {
    width: 100%;
    padding: 0;
  }
  #main .page_english .content .flex_box .text .white {
    padding: 0;
  }
  .page_poster .poster .flex_box {
    -webkit-justify-content: space-between !important;
    justify-content: space-between !important;
  }
  .page_poster .poster_top {
    position: static;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    height: auto;
    margin-bottom: 0;
    width: 100%;
    margin-top: 0;
  }
  .page_poster .poster_top .poster_img {
    position: static;
    width: 32% !important;
    margin-bottom: 20px !important;
  }
  .page_poster .poster_top .poster_img:nth-child(1) {
    transform: none;
    margin: auto;
    width: 80% !important;
    text-align: center;
  }
  .page_poster .poster_top .poster_img:nth-child(1) img {
    margin: auto;
  }
  .page_science-cafe-rrm .documents_li, .page_documents .documents_li {
    -webkit-justify-content: center;
    justify-content: center;
  }
  .page_science-cafe-rrm .documents_li div a, .page_documents .documents_li div a {
    position: relative;
    box-sizing: border-box;
    padding: 15px 0;
    font-size: 14px;
  }
  .page_science-cafe-rrm .documents_li div a svg, .page_documents .documents_li div a svg {
    display: inline-block;
    margin: 0;
    position: absolute;
  }
  .page_science-cafe-rrm .documents_li div a svg.fa-file-pdf, .page_documents .documents_li div a svg.fa-file-pdf {
    left: 15px;
  }
  .page_science-cafe-rrm .documents_li div a svg.fa-angle-down, .page_documents .documents_li div a svg.fa-angle-down {
    right: 15px;
  }
  #banner {
    padding-right: 15px;
    padding-left: 15px;
  }
  footer {
    padding-top: 15px;
    overflow: hidden;
  }
  footer .footer_main_nav {
    width: 100%;
    padding: 0 15px;
    box-sizing: border-box;
  }
  footer .footer_main_nav .footer_main_nav_ul {
    margin-bottom: 0;
  }
  footer .footer_main_nav .footer_main_nav_ul .col-xs-12 {
    width: 100%;
  }
  footer .footer_main_nav .col-xs-12 {
    width: 100%;
  }
  footer .footer_bottom {
    padding: 0;
    text-align: center;
    box-sizing: border-box;
  }
  footer .footer_bottom .address {
    margin-bottom: 0;
    padding-bottom: 0;
  }
  footer .footer_bottom .address p.sitename {
    font-size: 100% !important;
  }
  footer .footer_bottom .address p.sitename:after {
    content: "";
    display: block;
    width: 3em;
    height: 1px;
    margin: auto;
    margin-top: 10px;
    background-color: #fff;
  }
  footer .footer_bottom .address address {
    text-align: left;
    font-size: 12px;
  }
  footer .footer_bottom ul.ft_contact {
    margin: 0 -15px;
    margin-top: 20px;
    margin-bottom: 20px;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    display: block;
  }
  footer .footer_bottom ul.ft_contact li {
    padding: 10px 0;
    font-size: 12px;
    width: calc( 50% - 10px);
    margin: 0;
    text-align: center;
    box-sizing: border-box;
  }
  footer .footer_bottom ul.ft_contact li:first-child {
    border-right: 1px dotted #fff;
  }
  footer .footer_bottom ul.ft_contact li svg {
    font-size: 16px;
  }
  footer .footer_bottom ul.ft_lang {
    display: block;
  }
  footer .footer_bottom .address {
    width: 100%;
  }
  footer .footer_bottom .btn {
    margin: auto;
    display: none;
  }
  footer .footner_copy {
    display: block;
    float: none;
    margin-top: 20px;
    padding-bottom: 15px;
    font-size: 10px;
  }
}


@media screen and (min-width: 850px) and ( max-width:1024px){
  header .header_area .logo a {
        background-size: 50px auto;
        padding-left: 50px;
        padding-top: 6px;
  }
}


@media screen and (min-width: 850px) and ( max-width:1024px){
  header .top_nav {
        padding-top: 25px;
  }
}

.st-view{
        position: relative;
        padding-bottom: 56.25%;
        padding-top: 30px;
        height: 0;
        overflow: hidden;
}

.st-view iframe,
.st-view object,
.st-view embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
}


/***********************
added on 2021/05/12
***********************/

.singlepage #page_content .w1300 > .flex_box {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-flow: column;
  -ms-flex-flow: column;
  flex-flow: column;
}

@media only screen and (min-width: 1025px) {
  .singlepage #page_content .w1300 > .flex_box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row;
    -ms-flex-flow: row;
    flex-flow: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

.singlepage #page_content .w1300 > .flex_box #main_content {
  width: 100%;
  padding-right: 0;
}

@media only screen and (min-width: 1025px) {
  .singlepage #page_content .w1300 > .flex_box #main_content {
    width: calc(100% - 260px);
    padding-right: 50px;
  }
}

.singlepage #page_content .w1300 > .flex_box #sidebar {
  width: 100%;
}

@media only screen and (min-width: 1025px) {
  .singlepage #page_content .w1300 > .flex_box #sidebar {
    width: 260px;
  }
}
