  @charset "UTF-8";
html {
  font-size: 62.5%;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}

@media all and (-ms-high-contrast: none) {
  html {
    font-family: Verdana, Meiryo, sans-serif;
  }
}

@media all and (-ms-high-contrast: active) {
  html {
    font-family: Verdana, Meiryo, sans-serif;
  }
}

body {
  color: #262626;
  font-size: 1.4rem;
  line-height: 1.6;
  margin: 0;
  padding: 0;
  min-width: 318px;
}

h2, h3 {
  font-family: Roboto Condensed;
}

p {
  margin: 0 0 24px;
}

a {
  color: #0066CC;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.flex {
  display: flex;
}

.category_val,
.display_class {
  display: none;
}

.pager {
  display: none;
  margin: 48px 0 0;
}

.pager .pagination {
  text-align: center;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
}

.pager .pagination li {
  list-style: none;
  margin: 0 12px 0 0;
  padding: 0;
  width: 32px;
  height: 32px;
  text-align: center;
  position: relative;
  color: #2B7DB0;
}

.pager .pagination li.pre a, .pager .pagination li.next a {
  border: none;
}

.pager .pagination li.pre a span, .pager .pagination li.next a span {
  display: none;
}

.pager .pagination li.pre a:before, .pager .pagination li.next a:before {
  content: '';
  width: 8px;
  height: 8px;
  border: 0;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  margin-top: -4px;
}

.pager .pagination li.pre a:before {
  border-bottom: solid 2px #202020;
  border-left: solid 2px #202020;
  right: 30%;
}

.pager .pagination li.pre a:hover:before {
  border-bottom: solid 2px #ffffff;
  border-left: solid 2px #ffffff;
}

.pager .pagination li.next a:before {
  border-top: solid 2px #202020;
  border-right: solid 2px #202020;
  left: 30%;
}

.pager .pagination li.next a:hover:before {
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
}

.pager .pagination li.current {
  box-sizing: border-box;
  border: 1px solid #E5E5E5;
  border-radius: 2px;
  display: table;
  color: #fff;
  background: transparent linear-gradient(227deg, #2989B4 0%, #325EA8 100%) 0% 0% no-repeat padding-box;
}

.pager .pagination li.current span {
  display: table-cell;
  vertical-align: middle;
}

.pager .pagination li a {
  box-sizing: border-box;
  border: 1px solid #E5E5E5;
  border-radius: 2px;
  vertical-align: middle;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  display: table;
  color: #2B7DB0;
  text-decoration: none;
}

.pager .pagination li a span {
  display: table-cell;
  vertical-align: middle;
}

.pager .pagination li a:hover, .pager .pagination li a.active {
  color: #fff;
  background: transparent linear-gradient(227deg, #2989B4 0%, #325EA8 100%) 0% 0% no-repeat padding-box;
  border: none;
}

.pager .pagination li:last-child {
  margin: 0;
}

.pager .pagination li.edge {
  position: relative;
}

.pager .pagination li.edge span {
  display: none;
}

.pager .pagination li.edge:before {
  content: '';
  width: 8px;
  height: 8px;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  margin-top: -4px;
  border-bottom: solid 2px #202020;
  border-left: solid 2px #202020;
  right: 30%;
}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

@media (max-width: 768px) {
  .ggmap {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
  }
  .ggmap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-width: 600px;
    max-height: 400px;
  }
}

.jp_language h2, .jp_language h3,
.cn_language h2,
.cn_language h3,
.tw_language h2,
.tw_language h3 {
  font-family: inherit;
}

.jp_language header > div > div .burger-nav nav ul li a,
.cn_language header > div > div .burger-nav nav ul li a,
.tw_language header > div > div .burger-nav nav ul li a {
  font-family: inherit;
}

.jp_language .sub #SubMainvisual .parent_title,
.cn_language .sub #SubMainvisual .parent_title,
.tw_language .sub #SubMainvisual .parent_title {
  font-family: inherit;
}

.jp_language .sub #SubMainvisual .title_back .detail_title,
.cn_language .sub #SubMainvisual .title_back .detail_title,
.tw_language .sub #SubMainvisual .title_back .detail_title {
  font-family: inherit;
}

.cn_language, .tw_language {
  font-family: 'Segoe UI',SegoeUI,'Microsoft YaHei',微软雅黑,"Helvetica Neue",Helvetica,Arial,sans-serif;
}

.scroll_prevent > body {
  position: fixed !important;
  z-index: -1;
  width: 100vw;
  height: 100%;
}

/* ===============================================
  ヘッダー
=============================================== */
header {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 47px;
}

header > div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 10px 0;
}

header > div h1 {
  margin: 0;
}

header > div h1 a {
  white-space: nowrap;
  text-decoration: none;
  display: flex;
  align-items: flex-end;
}

header > div h1 a img {
  width: 120px;
  vertical-align: bottom;
}

header > div h1 a span {
  font-weight: normal;
  font-size: 1.3rem;
  color: #FFF;
  background: #325EA8;
  padding: 0 23px;
  text-align: center;
  margin: 0 0 4px 10px;
}

header > div > div .burger-nav nav ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  justify-content: flex-end;
}

header > div > div .burger-nav nav ul li {
  list-style: none;
  margin-left: 20px;
}

header > div > div .burger-nav nav ul li a {
  font-family: Roboto;
  font-size: 1.6rem;
  color: #202020;
  font-weight: bold;
  text-decoration: none;
  position: relative;
  display: inline-block;
  padding: 4px 10px 2px 10px;
}

header > div > div .burger-nav nav ul li a::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 2px;
  background: #333;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform .3s;
}

header > div > div .burger-nav nav ul li a:hover::after {
  transform: scale(1, 1);
}

header > div > div .burger-nav nav ul li:first-child {
  margin-left: 0;
}

header > div > div .burger-nav nav ul li.current a::after {
  transform: scale(1, 1);
}

header > div > div .burger-nav nav ul li.current a:hover::after {
  transform: scale(0, 1);
}

header > div > div .burger-nav nav ul.pc_none {
  display: none;
}

header > div > div .burger-nav > div {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 6px;
}

header > div > div .burger-nav > div > a {
  display: inline-flex;
  margin-right: 10px;
  transition: all .2s;
  padding: 6px 20px;
}

header > div > div .burger-nav > div > a:hover {
  opacity: .7;
}

header > div > div .burger-nav > div .global_icon {
  padding: 2px;
  padding-left: 24px;
  padding-right: 10px;
  background: #426BAF;
  position: relative;
  color: #FFF;
  text-decoration: none;
  border-radius: 15px;
  margin-right: 20px;
}

header > div > div .burger-nav > div .global_icon:before {
  content: "";
  position: absolute;
  left: 6px;
  top: 0;
  bottom: 0;
  margin: auto;
  display: block;
  width: 12px;
  height: 12px;
  background-image: url(/common/images/global-icon.svg);
  background-repeat: no-repeat;
  background-size: 12px 12px;
  background-position: center;
}

header > div > div .burger-nav > div .mail_icon {
  width: 60px;
  overflow: hidden;
  position: relative;
  text-align: center;
}

header > div > div .burger-nav > div .mail_icon img {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  margin: auto;
}

header > div > div .burger-nav > div .mail_icon .mask {
  width: 100%;
  position: absolute;
  top: 50px;
  left: 0;
  background-color: rgba(0, 0, 0, 0.4);
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  border-radius: 15px;
}

header > div > div .burger-nav > div .mail_icon .mask .caption {
  font-size: 1.5rem;
  color: #fff;
  text-align: center;
}

header > div > div .burger-nav > div .mail_icon:hover {
  opacity: 1;
}

header > div > div .burger-nav > div .mail_icon:hover .mask {
  top: 0px;
}

header > div > div .burger-nav > div .search_area {
  display: flex;
}

header > div > div .burger-nav > div .search_area .search_icon {
  display: inline-flex;
  transition: all .2s;
  padding: 6px 20px;
  width: 13px;
}

header > div > div .burger-nav > div .search_area .search_form {
  display: none;
  white-space: nowrap;
}

header > div > div .burger-nav > div .search_area .search_form input {
  border: none;
  outline: none;
}

header > div > div .burger-nav > div .search_area .search_form input[type="search"] {
  border-bottom: 1px solid #ccc;
  padding: 4px 2px;
}

header > div > div .burger-nav > div .search_area .search_form input[type="submit"] {
  width: 60px;
  height: 25px;
  line-height: 1;
  border-radius: 15px;
  cursor: pointer;
  padding: 5px 9px;
  transition: all .2s;
}

header > div > div .burger-nav > div .search_area .search_form input[type="submit"]:hover {
  background: #5f5f5f;
  color: #fff;
}

header > div > div .burger-nav > div .lang_select {
  position: relative;
  margin-left: 20px;
}

header > div > div .burger-nav > div .lang_select select {
  height: 26px;
  font-size: 1.6rem;
  color: #325EA8;
  background: rgba(255, 255, 255, 0);
  font-weight: bold;
  border: none;
  padding: 4px 30px 4px 10px;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
}

header > div > div .burger-nav > div .lang_select select::-ms-expand {
  display: none;
}

header > div > div .burger-nav > div .lang_select:after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border: 0px;
  border-bottom: solid 2px #325EA8;
  border-right: solid 2px #325EA8;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 4px;
  margin-top: -6px;
  pointer-events: none;
}

header > div > div .burger-nav > div.pc_none {
  display: none;
}

/* ===============================================
  メインコンテンツ
=============================================== */
/* ----------------------------------------------
　　トップページ
---------------------------------------------- */
.main {
  /* トップページ　メインビジュアル */
  /* トップページ　コンテンツ */
}

.main .alert_top {
background-color: #f2f237;
width: 100%;
}
.main .alert_top.gray_color {
background-color: #656565;
}
.main .alert_top.blue_color {
background-color: #346cb6;
}
.main .alert_top.gray_color .urgent_wrap a,
.main .alert_top.blue_color .urgent_wrap a {
color: #ffffff;
}

.main .urgent_info {
min-height: 30px;
max-width: 1280px;
margin: 0 auto;
overflow: hidden;
padding: 0 47px;
}

.main .urgent_wrap {
padding: 14px 0 12px;
display: flex;
}

.main .urgent_wrap a {
color: #202020;
}

.main .urgent_wrap span {
width: 24px;
margin-right: 20px;
position: relative;
}

.main .alert_top .urgent_info .urgent_wrap span:before {
content:"";
position: absolute;
width: 24px;
height: 24px;
top: 0;
right: 0;
bottom: 0;
left: 0;
margin: auto;
background-image: url(/common/images/alert.svg);
background-repeat: no-repeat;
background-size: 24px 24px;
background-position: center;
}


.main #TopMainvisual {
  width: 100%;
  position: relative;
  margin-bottom: 44px;
}

.main #TopMainvisual > div {
  min-width: 600px;
  width: 100%;
  padding-top: 30px;
}

.main #TopMainvisual > div ul {
  margin: 0 0 0 auto;
  padding: 0;
  width: calc(100% - 256px);
  height: 600px;
  object-fit: cover;
  font-family: 'object-fit: cover';
  display: block;
  z-index: 1;
  position: relative;
}


.main #TopMainvisual > div ul .slick-prev,
.main #TopMainvisual > div ul .slick-next {
  z-index: 1;
  opacity: 1;
  width: 43px;
  height: 43px;
  background: #999999;
  border-radius: 25px;
}

.main #TopMainvisual > div ul .slick-prev:before,
.main #TopMainvisual > div ul .slick-next:before {
  content: '';
  width: 12px;
  height: 12px;
  border: 0;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  margin-top: -8px;
  right: 11px;
}

.main #TopMainvisual > div ul .slick-prev:focus,
.main #TopMainvisual > div ul .slick-next:focus {
  background: #999999;
}

.main #TopMainvisual > div ul .slick-prev:hover,
.main #TopMainvisual > div ul .slick-next:hover {
  background: #999999;
  opacity: .7;
}

.main #TopMainvisual > div ul .slick-prev {
  left: 10px;
}

.main #TopMainvisual > div ul .slick-prev:before {
  right: 11px;
  border-left: solid 4px #FFF;
  border-bottom: solid 4px #FFF;
}

.main #TopMainvisual > div ul .slick-next {
  right: 10px;
}

.main #TopMainvisual > div ul .slick-next:before {
  left: 11px;
  border-top: solid 4px #FFF;
  border-right: solid 4px #FFF;
}

.main #TopMainvisual > div ul .slick-prev:before,
.main #TopMainvisual > div ul .slick-next:before {
  opacity: 1;
  font-size: 50px;
  color: #999999;
}

.main #TopMainvisual > div ul .slick-prev {
  left: 10px;
  z-index: 1;
}

.main #TopMainvisual > div ul .slick-next {
  right: 10px;
}

.main #TopMainvisual > div video {
  margin: 0 0 0 auto;
  padding: 0;
  width: calc(100% - 256px);
  height: auto;
  object-fit: cover;
  font-family: 'object-fit: cover';
  display: block;
  z-index: 1;
  position: relative;
}

.main #TopMainvisual > div img {
  width: 100%;
  height: 600px;
  object-fit: cover;
  font-family: 'object-fit: cover';
}

.main #TopMainvisual > div:after {
  content: '';
  width: 100%;
  height: 98%;
  display: block;
  background: transparent linear-gradient(220deg, #2989B4 0%, #325EA8 100%) 0% 0% no-repeat padding-box;
  position: absolute;
  top: 0;
  z-index: -1;
}

.main #TopMainvisual h2 {
  font-family: Roboto Condensed;
  color: #fff;
  margin: 0;
  padding: 0;
  position: absolute;
  bottom: 50px;
  left: 47px;
  font-size: 9.6rem;
  line-height: 1.2;
  z-index: 2;
}

.main article .news_wrapper {
  position: relative;
}

.main article .news_wrapper:after {
  content: "";
  display: block;
  width: 60%;
  height: 100%;
  top: 0;
  right: 0;
  background: transparent linear-gradient(180deg, #FFFFFF 0%, #F5F5F5 100%) 0% 0% no-repeat padding-box;
  position: absolute;
  z-index: 0;
}

.main article #TopNewsInfo {
  position: relative;
  max-width: 1280px;
  margin: 0 auto 80px;
  padding: 0 47px;
  z-index: 1;
}

.main article #TopNewsInfo h3 {
  font-size: 3.4rem;
  line-height: 1;
  margin: 0 0 18px;
}

.main article #TopNewsInfo > div {
  display: flex;
}

.main article #TopNewsInfo > div .news_content {
  display: flex;
  max-width: 680px;
  width: 100%;
}

.main article #TopNewsInfo > div .news_content > div {
  width: 100%;
  max-width: 300px;
  margin-right: 40px;
}

.main article #TopNewsInfo > div .news_content > div section a {
  text-decoration: none;
  transition: all .2s;
}

.main article #TopNewsInfo > div .news_content > div section a img {
  width: 100%;
  max-width: 300px;
  height: 187px;
  object-fit: contain;
  font-family: 'object-fit: contain;';
  border: 1px solid #F0F0F0;
}

.main article #TopNewsInfo > div .news_content > div section a div h4 {
  font-size: 1.6rem;
  line-height: 1.4;
  color: #0066CC;
  margin: 0 0 8px;
  visibility: hidden;
  word-break: break-word;
}

@media all and (-ms-high-contrast: none) {
  .main article #TopNewsInfo > div .news_content > div section a div h4 {
    font-weight: normal;
  }
}

@media all and (-ms-high-contrast: active) {
  .main article #TopNewsInfo > div .news_content > div section a div h4 {
    font-weight: normal;
  }
}

.main article #TopNewsInfo > div .news_content > div section a div time {
  color: #999999;
  display: block;
  margin-bottom: 8px;
}

.main article #TopNewsInfo > div .news_content > div section a div p {
  color: #202020;
  border-top: 1px dashed #D6D6D6;
  padding-top: 8px;
  margin: 0;
  visibility: hidden;
  word-break: break-word;
}

.main article #TopNewsInfo > div .news_content > div section a:hover {
  opacity: .7;
}

.main article #TopNewsInfo > div .news_list {
  width: 100%;
  max-width: 600px;
}

.main article #TopNewsInfo > div .news_list ul {
  margin: 0;
  padding: 0;
}

.main article #TopNewsInfo > div .news_list ul li {
  list-style: none;
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px dashed #D6D6D6;
  display: flex;
}

.main article #TopNewsInfo > div .news_list ul li time {
  display: inline-block;
  width: 100%;
  max-width: 100px;
  margin-right: 30px;
}

.main article #TopNewsInfo > div .news_list ul li a {
  color: #0066CC;
  text-decoration: none;
}

.main article #TopNewsInfo > div .news_list ul li a:hover {
  text-decoration: underline;
}

.main article #TopProjects {
  max-width: 1280px;
  margin: 0 auto 80px;
  padding: 0 47px;
}

.main article #TopProjects h3 {
  font-size: 3.4rem;
  margin: 0 0 18px;
}

.main article #TopProjects > div {
  display: flex;
}

.main article .services_wrapper {
  position: relative;
}

.main article .services_wrapper:after {
  content: "";
  display: block;
  min-width: 768px;
  width: 60%;
  height: 100%;
  top: 0;
  left: 0;
  background: linear-gradient(180deg, #303754 0%, #443D3D 100%);
  position: absolute;
  z-index: 0;
}

.main article #TopServices {
  max-width: 1280px;
  margin: 0 auto 80px;
  position: relative;
  z-index: 1;
  padding: 0 47px;
}

.main article #TopServices > div {
  display: flex;
  align-items: center;
}

.main article #TopServices > div .services_content {
  width: 100%;
  max-width: 60%;
  margin: 87px 56px 0 0;
  color: #FFFFFF;
}

.main article #TopServices > div .services_content h3 {
  font-size: 3.4rem;
  margin: 0 0 18px;
}

.main article #TopServices > div .services_content p {
  margin: 0 0 37px;
  line-height: 1.4;
}
.main article #TopServices > div .services_content p.no_margin {
  margin: 0;
}
.main article #TopServices > div .services_content .btn {
  margin-bottom: 84px;
}

.main article #TopServices > div .services_content .btn a {
  background: rgba(255, 255, 255, 0);
  border: 1px solid #FFFFFF;
  color: #FFFFFF;
}

.main article #TopServices > div .services_content .btn a:hover {
  opacity: 1;
  background: #FFFFFF;
  color: #202020;
}

.main article #TopServices > div .services_content .btn a:hover:hover:before {
  border-top: solid 1px #202020;
}

.main article #TopServices > div .services_content .btn a:hover:hover:after {
  border-bottom: solid 1px #202020;
}

.main article #TopServices > div .services_img {
  position: relative;
  padding-right: 20px;
  margin-left: 20px;
}

.main article #TopServices > div .services_img img {
  max-width: 530px;
  vertical-align: bottom;
  margin-left: -20px;
}

.main article #TopServices > div .services_img::after {
  content: '';
  position: absolute;
  display: block;
  width: calc(100% - 20px);
  height: calc(100% - 10px);
  background: #AB7474;
  z-index: -1;
  bottom: 30px;
  left: 20px;
}

/* ----------------------------------------------
　　下層ページ
---------------------------------------------- */
.sub {
  /* 下層ページ　メインビジュアル */
  /* 下層ページ　コンテンツ */
}

.sub #SubMainvisual {
  width: 100%;
  position: relative;
  margin-bottom: 12px;
}

.sub #SubMainvisual > div {
  min-width: 585px;
  width: 100%;
  padding-bottom: 40px;
  position: relative;
}

.sub #SubMainvisual > div img {
  width: calc(100% - 35%);
  min-width: calc(100% - 35%);
  height: 403px;
  object-fit: cover;
  font-family: 'object-fit: cover';
  margin: 0 0 0 auto;
  padding-right: 20px;
  box-sizing: border-box;
  display: block;
  z-index: 1;
}

.sub #SubMainvisual > div.no_image {
  padding-bottom: 0;
}

.sub #SubMainvisual > div.no_image .title_back {
  position: relative;
}

.sub #SubMainvisual .parent_title {
  font-family: Roboto Condensed;
  color: #202020;
  padding: 0 47px;
  font-size: 3.2rem;
  line-height: 1;
  z-index: 2;
  max-width: 1280px;
  margin: 0 auto 8px;
}

.sub #SubMainvisual .title_back {
  width: 100%;
  position: absolute;
  bottom: 0;
}

.sub #SubMainvisual .title_back .detail_title {
  font-family: Roboto Condensed;
  color: #fff;
  padding: 26px 47px;
  font-size: 4.6rem;
  line-height: 1.3;
  z-index: 2;
  max-width: 1280px;
  margin: auto;
  /*word-break: break-all;*/
  word-break: break-word;
}

.sub #SubMainvisual .title_back:after {
  content: '';
  width: 100%;
  height: calc(100% - 40px);
  display: block;
  background: linear-gradient(220deg, #2989B4 0%, #325EA8 100%);
  position: absolute;
  bottom: 0;
  z-index: -1;
}

.sub #SubMainvisual .title_back.no_parent:after {
  max-width: 100%;
  width: 100%;
  height: 100%;
}

.sub .main_contents {
  max-width: 1280px;
  margin: auto;
  padding: 0 47px;
  /*　ぱんくずリスト　*/
  /*　ページコンテンツ　*/
  /*　サイドメニュー　*/
  /*　コンテンツ　*/
}

.sub .main_contents .breadcrumb {
  margin-bottom: 52px;
}

.sub .main_contents .breadcrumb nav ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}

.sub .main_contents .breadcrumb nav ul li {
  list-style: none;
  position: relative;
  display: inline-block;
  padding-right: 24px;
}

.sub .main_contents .breadcrumb nav ul li a {
  text-decoration: none;
  color: #356CB6;
}

.sub .main_contents .breadcrumb nav ul li a:hover {
  text-decoration: underline;
}

.sub .main_contents .breadcrumb nav ul li::after {
  content: '';
  width: 4px;
  height: 4px;
  border: 0;
  border-top: solid 1px #A8A8A8;
  border-right: solid 1px #A8A8A8;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 8px;
  margin-top: -2px;
}

.sub .main_contents .breadcrumb nav ul li:last-child {
  padding: 0;
  word-break: break-all;
}

.sub .main_contents .breadcrumb nav ul li:last-child::after {
  content: none;
}

.sub .main_contents section {
  margin-bottom: 48px;
}

.sub .main_contents .content_wrap {
  margin-bottom: 120px;
}

.sub .main_contents .side_menu {
  width: 320px;
  margin-left: 40px;
  margin-bottom: 120px;
}

.sub .main_contents .side_menu.news_side {
  display: none;
}

.sub .main_contents .side_menu aside > nav > ul {
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
}

.sub .main_contents .side_menu aside > nav > ul li {
  list-style: none;
  border-bottom: 1px dashed #D6D6D6;
  box-sizing: border-box;
  letter-spacing: -0.05rem;
}

.sub .main_contents .side_menu aside > nav > ul li.current {
  color: #FFF;
  background: transparent linear-gradient(261deg, #2989B4 0%, #325EA8 100%);
  border-bottom: none;
  padding: 16px 47px 16px 16px;
  position: relative;
}

.sub .main_contents .side_menu aside > nav > ul li.current:after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #FFF;
  border-right: solid 2px #FFF;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 16px;
  margin-top: -4px;
}

.sub .main_contents .side_menu aside > nav > ul li.current.parent:after {
  border-top: none;
  border-bottom: solid 2px #FFF;
}

.sub .main_contents .side_menu aside > nav > ul li a {
  color: #202020;
  text-decoration: none;
  display: block;
  width: 100%;
  padding: 16px 47px 16px 16px;
  box-sizing: border-box;
  transition: all .2s;
  position: relative;
}

.sub .main_contents .side_menu aside > nav > ul li a:after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #202020;
  border-right: solid 2px #202020;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 16px;
  margin-top: -4px;
}

.sub .main_contents .side_menu aside > nav > ul li a:hover {
  color: #ffffff;
  background: rgba(41, 137, 180, 0.5);
}

.sub .main_contents .side_menu aside > nav > ul li a:hover:after {
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
}

.sub .main_contents .side_menu aside > nav .sub_menu_list {
  padding: 0;
}

.sub .main_contents .side_menu aside > nav .sub_menu_list li a {
  padding-left: 2em;
}

.sub .main_contents .side_menu aside > nav .sub_menu_list li.current {
  background: #6E809C;
  padding-left: 2em;
}

.sub .main_contents .side_menu a img {
  width: 100%;
  transition: all .2s;
}
.sub .main_contents .side_menu a:hover img {
  opacity: .7;
}

.sub .main_contents .content {
  width: 920px;
  word-break: break-word;
}

.sub .main_contents .content section:nth-last-child {
  margin-bottom: 0;
}

.sub .main_contents .content section time {
  color: #999999;
  display: block;
  margin-bottom: 8px;
}

.sub .main_contents .content.content_single {
  width: 100%;
}

/* ===============================================
  フッター
=============================================== */
footer {
  background: #356CB6;
  padding: 40px 0 24px;
}

footer nav ul {
  display: flex;
  margin: 0 0 16px;
  padding: 0;
}

footer nav ul li {
  list-style: none;
  margin-right: 32px;
}

footer nav ul li a {
  color: #ffffff;
  text-decoration: none;
  position: relative;
  display: inline-block;
  padding-left: 14px;
}

footer nav ul li a:hover {
  text-decoration: underline;
}

footer nav ul li a:before {
  content: '';
  width: 4px;
  height: 4px;
  border: 0;
  border-top: solid 1px #ffffff;
  border-right: solid 1px #ffffff;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
}

footer nav ul li:first-child:before {
  content: none;
}

footer nav ul li:last-child {
  margin-right: 0;
}

footer nav ul li.outside_link a {
  padding-right: 20px;
}

footer nav ul li.outside_link a:after {
  content: "";
  position: absolute;
  right: 4px;
  top: 0;
  bottom: 0;
  margin: auto;
  display: block;
  width: 9px;
  height: 9px;
  background-image: url(/common/images/outside-icon.png);
  background-repeat: no-repeat;
  background-size: 9px 9px;
  background-position: center;
}

footer .footer_nav {
  max-width: 1280px;
  margin: 0 auto 24px;
  padding: 0 47px;
}

footer .footer_nav .flex {
  justify-content: space-between;
}

footer .footer_nav nav ul {
  flex-wrap: wrap;
}

footer .footer_nav .qr_icon img {
  width: 94px;
}

footer .footer_nav .icon_link {
  text-align: center;
  white-space: nowrap;
}

footer .footer_nav .icon_link a {
  margin: 0 20px 0 0;
  transition: all .2s;
}

footer .footer_nav .icon_link a:last-child {
  margin: 0;
}

footer .footer_nav .icon_link a:hover {
  opacity: .7;
}

footer .footer_nav_under_line {
  border-top: 1px solid #87A7D1;
}

footer .footer_nav_under {
  max-width: 1280px;
  margin: auto;
  padding: 0 47px;
}

footer .footer_nav_under nav {
  margin: 24px 0 0;
}

footer .footer_nav_under ul {
  margin: 0;
}

footer .footer_nav_under.flex {
  justify-content: space-between;
}

footer .cpyright {
  text-align: center;
  margin: 24px 0 0;
}

footer .cpyright p {
  color: #FFF;
  margin: 0;
}

/* ===============================================
  レスポンシブ
  タブレット?端末（共通）
=============================================== */
@media (max-width: 1024px) {
  .flex {
    display: block;
  }
  /* ヘッダー */
  header {
    padding: 0 17px 10px;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
  }
  header > div {
    padding: 16px 0 0;
    margin: 0;
    width: 100%;
  }
  header > div h1 {
    margin: 0;
  }
  header > div > div .burger_icon {
    display: block;
    width: 20px;
    height: 18px;
    cursor: pointer;
    position: absolute;
    top: 28px;
    right: 20px;
    z-index: 1;
  }
  header > div > div .burger_icon span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #325EA8;
    border-radius: 4px;
    transition: all 0.4s;
  }
  header > div > div .burger_icon span:nth-of-type(1) {
    top: 0;
  }
  header > div > div .burger_icon span:nth-of-type(2) {
    top: 8px;
  }
  header > div > div .burger_icon span:nth-of-type(3) {
    bottom: 0;
  }
  header > div > div .burger_icon.is-burger-nav-open {
    z-index: 11;
  }
  header > div > div .burger_icon.is-burger-nav-open span {
    background-color: #FFF;
  }
  header > div > div .burger_icon.is-burger-nav-open span:nth-of-type(1) {
    transform: translateY(8px) rotate(-45deg);
  }
  header > div > div .burger_icon.is-burger-nav-open span:nth-of-type(2) {
    opacity: 0;
  }
  header > div > div .burger_icon.is-burger-nav-open span:nth-of-type(3) {
    transform: translateY(-8px) rotate(45deg);
  }
  header > div > div .is-burger-nav-open {
    position: fixed;
    top: 30px;
    right: 20px;
  }
  header > div > div .burger-nav {
    display: none;
  }
  header > div > div .burger-nav.open {
    display: block;
    font-size: 1.8rem;
    line-height: 1.6;
    color: #fff;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    overflow-y: auto;
    z-index: 10;
    background-color: rgba(0, 0, 0, 0.8);
    width: 100%;
    height: 100%;
  }
  header > div > div .burger-nav.open nav {
    text-align: left;
    width: 150px;
    margin: 80px auto 40px;
  }
  header > div > div .burger-nav.open nav ul {
    display: block;
    margin-bottom: 40px;
  }
  header > div > div .burger-nav.open nav ul li {
    margin-left: 0;
    margin-bottom: 24px;
  }
  header > div > div .burger-nav.open nav ul li:last-child {
    margin-bottom: 0;
  }
  header > div > div .burger-nav.open nav ul li a {
    display: block;
    width: 100%;
    padding: 0;
    box-sizing: border-box;
    color: #fff;
    font-size: 2.0rem;
  }
  header > div > div .burger-nav.open > div {
    display: block;
  }
  header > div > div .burger-nav.open > div ul {
    width: 150px;
    margin: 0 auto 80px;
    list-style: none;
    line-height: 1;
    padding: 0;
  }
  header > div > div .burger-nav.open > div ul li {
    margin-bottom: 16px;
    text-align: left;
    text-indent: 0.5em;
  }
  header > div > div .burger-nav.open > div ul li.outside_link a {
    color: #fff;
    font-size: 1.4rem;
    position: relative;
  }
  header > div > div .burger-nav.open > div ul li.outside_link a:before {
    content: '';
    width: 4px;
    height: 4px;
    border: 0;
    border-top: solid 1px #ffffff;
    border-right: solid 1px #ffffff;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    left: -10px;
    margin-top: -4px;
  }
  header > div > div .burger-nav.open > div ul li.outside_link a:after {
    content: "";
    position: absolute;
    right: -16px;
    top: 5px;
    left: auto;
    display: block;
    width: 9px;
    height: 9px;
    background-image: url(/common/images/outside-icon.png);
    background-repeat: no-repeat;
    background-size: 9px 9px;
    transform: unset;
  }
  header > div > div .burger-nav.open > div ul li.outside_link.no_icon a:after {
    content: none;
  }
  header > div > div .burger-nav.open > div .search_area {
    display: block;
    flex-wrap: wrap;
    width: 220px;
    margin: 0 auto 35px;
    text-align: center;
  }
  header > div > div .burger-nav.open > div .search_area > div {
    display: flex;
  }
  header > div > div .burger-nav.open > div .search_area .search_icon {
    padding: 0;
    cursor: unset;
    display: block;
    position: relative;
  }
  header > div > div .burger-nav.open > div .search_area .search_icon > img {
    position: absolute;
    bottom: 0;
    left: 0;
  }
  header > div > div .burger-nav.open > div .search_area input[type=search] {
    background-color: transparent;
    color: #ffffff;
    border: none;
    border-bottom: 1px solid #CCCCCC;
    width: 100%;
    margin: 0 10px;
    outline: none;
  }
  header > div > div .burger-nav.open > div .search_area input[type=submit] {
    display: inline-block;
    width: 120px;
    height: 24px;
    margin: 24px auto 0;
    line-height: 1.2;
    background: #426BAF 0% 0% no-repeat padding-box;
    color: #ffffff;
    border-radius: 12px;
    border: none;
    cursor: pointer;
    transition: all .2s;
  }
  header > div > div .burger-nav.open > div .search_area input[type=submit]:hover {
    opacity: .7;
  }
  header > div > div .burger-nav.open .lang_select {
    display: inline-block;
    margin-left: 0;
    margin-bottom: 40px;
  }
  header > div > div .burger-nav.open .lang_select select {
    color: #FFF;
    cursor: pointer;
  }
  header > div > div .burger-nav.open .lang_select select option {
    font-size: 1.5rem;
    color: #202020;
  }
  header > div > div .burger-nav.open .lang_select:after {
    border-bottom: solid 2px #FFF;
    border-right: solid 2px #FFF;
    right: 15px;
  }
  header > div > div .burger-nav.open .icon_link {
    width: 198px;
    margin: 0 auto 80px;
    display: flex;
    justify-content: space-around;
    align-items: center;
  }
  header > div > div .burger-nav.open .icon_link a:hover {
    opacity: .7;
  }
  /* トップページ メインコンテンツ */
  .main #TopMainvisual h2 {
    bottom: -20px;
  }
  .main #TopMainvisual > div {
    padding-top: 0;
  }
  .main #TopMainvisual > div ul {
    width: calc(100% - 20px);
    height: 493px;
  }
  .main #TopMainvisual > div img {
    height: 493px;
    box-sizing: border-box;
  }
  .main #TopMainvisual > div > img {
    width: calc(100% - 20px);
    margin: 0 0 0 auto;
  }
  .main #TopMainvisual > div:after {
    margin-top: 30px;
  }
  .main .urgent_info {
    margin: 0 18px;
    padding: 0;
  }
  .main article .services_wrapper:after {
    min-width: 100%;
    width: 100%;
    height: 90%;
    bottom: 0;
    top: auto;
  }
  .main article .services_wrapper #TopServices > div {
    flex-wrap: wrap;
  }
  .main article .services_wrapper #TopServices > div .services_content {
    max-width: 100%;
    margin: 30px 20px 0;
    order: 2;
  }
  .main article .services_wrapper #TopServices > div .services_img {
    width: 100%;
    padding: 0 20px 0 20px;
    order: 1;
  }
  .main article .services_wrapper #TopServices > div .services_img::after {
    width: calc(100% - 60px);
    left: 40px;
  }
  .main article .services_wrapper #TopServices > div .services_img img {
    width: 100%;
    max-width: 100%;
  }
  /* 下層ページ メインコンテンツ */
  .sub #SubMainvisual > div {
    min-width: 100%;
  }
  .sub #SubMainvisual > div img {
    min-width: calc(100% - 300px);
    box-sizing: border-box;
    padding: 0;
  }
  .sub #SubMainvisual > div:after {
    width: calc(100% - 10px);
    height: 87px;
  }
  .sub #SubMainvisual .parent_title {
    font-size: 2.4rem;
  }
  .sub #SubMainvisual .title_back .detail_title {
    font-size: 3.2rem;
  }
  .sub #SubMainvisual .title_back:after {
    width: calc(100% - 10px);
    height: calc(100% - 32px);
  }
  .sub .main_contents .content_wrap {
    margin-bottom: 60px;
  }
  .sub .main_contents .side_menu {
    width: 100%;
    margin: 0 0 120px;
  }
  .sub .main_contents .side_menu .modal-nav {
    display: none;
  }
  .sub .main_contents .side_menu .modal-nav.open {
    display: block;
    position: fixed;
    right: 0;
    top: 0;
    bottom: 0;
    padding: 50px 28px;
    background: #fff;
    overflow-y: auto;
    z-index: 10;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
  }
  .sub .main_contents .side_menu .modal-nav.open > .modal_close {
    display: block;
    width: 20px;
    height: 18px;
    margin: 0 0 0 auto;
    cursor: pointer;
    position: relative;
    top: -5px;
    right: -5px;
    z-index: 11;
  }
  .sub .main_contents .side_menu .modal-nav.open > .modal_close span {
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #202020;
    border-radius: 4px;
    transition: all 0.4s;
  }
  .sub .main_contents .side_menu .modal-nav.open > .modal_close span:nth-of-type(1) {
    top: 0;
    transform: translateY(4px) rotate(-45deg);
  }
  .sub .main_contents .side_menu .modal-nav.open > .modal_close span:nth-of-type(2) {
    top: 8px;
    transform: translateY(-4px) rotate(45deg);
  }
  .sub .main_contents .side_menu .modal-nav.open .facility_usages_list > div,
  .sub .main_contents .side_menu .modal-nav.open .region_list > div {
    display: flex;
  }
  .sub .main_contents .side_menu .modal-nav.open .facility_usages_list > div .flex_right,
  .sub .main_contents .side_menu .modal-nav.open .region_list > div .flex_right {
    margin: 24px 0 0;
  }
  .sub .main_contents .content {
    width: 100%;
  }
}

/* ===============================================
  レスポンシブ
  タブレット
=============================================== */
@media (max-width: 1024px) and (min-width: 768px) {
  /* トップページ */
  .main #TopMainvisual h2 {
    font-size: 4.4rem;
    left: 10px;
  }
  .main #TopMainvisual div {
    min-width: 100%;
  }
  .main article #TopNewsInfo {
    padding: 0 47px 10px;
  }
  .main article #TopNewsInfo > div {
    display: block;
  }
  .main article #TopNewsInfo > div .news_content {
    max-width: 100%;
    justify-content: center;
    margin: 0 0 30px;
  }
  .main article #TopNewsInfo > div .news_content > div:last-child {
    margin-right: 0;
  }
  .main article #TopNewsInfo > div .news_list {
    max-width: 100%;
  }
  .main article #TopProjects > div {
    display: block;
  }
  /* 下層ページ */
  .sub #SubMainvisual > div {
    min-width: 100%;
  }
  .sub #SubMainvisual > div img {
    min-width: calc(100% - 300px);
    box-sizing: border-box;
    padding: 0;
  }
  .sub #SubMainvisual > div:after {
    width: calc(100% - 10px);
    height: 87px;
  }
}

/* ===============================================
  レスポンシブ
  スマホ
=============================================== */
@media (max-width: 768px) {
  /* トップページ */
  .main #TopMainvisual h2 {
    font-size: 4.4rem;
    left: 10px;
  }
  .main #TopMainvisual div {
    min-width: 100%;
  }
  .main article .services_wrapper:after {
    min-width: 100%;
    width: 100%;
    bottom: 0;
    top: auto;
  }
  .main article .services_wrapper #TopServices {
    padding: 0 13px;
  }
  .main article .services_wrapper #TopServices > div {
    flex-wrap: wrap;
  }
  .main article .services_wrapper #TopServices > div .services_content {
    max-width: 100%;
    margin: 30px 0 0;
    order: 2;
  }
  .main article .services_wrapper #TopServices > div .services_content .btn {
    margin-bottom: 56px;
  }
  .main article .services_wrapper #TopServices > div .services_content h3 {
    font-size: 3.2rem;
  }
  .main article .services_wrapper #TopServices > div .services_img {
    width: 100%;
    padding: 0;
    order: 1;
    margin-left: 10px;
  }
  .main article .services_wrapper #TopServices > div .services_img img {
    margin-left: -10px;
  }
  .main article .services_wrapper #TopServices > div .services_img::after {
    width: 100%;
    height: calc(100% - 20px);
    left: 0;
  }
  .main article .news_wrapper:after {
    content: none;
  }
  .main article #TopNewsInfo {
    padding: 0 13px;
    margin-bottom: 80px;
  }
  .main article #TopNewsInfo > div {
    display: block;
  }
  .main article #TopNewsInfo > div .news_content {
    display: block;
    margin-right: 0;
  }
  .main article #TopNewsInfo > div .news_content > div {
    max-width: 100%;
    margin: 0 0 35px;
  }
  .main article #TopNewsInfo > div .news_content > div section a img {
    max-width: 100%;
    height: auto;
  }
  .main article #TopNewsInfo > div .news_list ul {
    display: none;
  }
  .main article #TopNewsInfo h3 {
    font-size: 3.2rem;
  }
  .main article #TopProjects {
    padding: 0 13px;
  }
  .main article #TopProjects > div {
    display: block;
  }
  .main article #TopProjects h3 {
    font-size: 3.2rem;
  }
  /* 下層ページ */
  .sub #SubMainvisual > div {
    min-width: 100%;
  }
  .sub #SubMainvisual > div img {
    min-width: calc(100% - 300px);
    height: 200px;
    box-sizing: border-box;
    padding: 0;
  }
  .sub #SubMainvisual > div:after {
    width: calc(100% - 10px);
    height: 87px;
  }
  .sub #SubMainvisual .parent_title {
    font-size: 2.4rem;
    margin: 0 16px 6px;
    padding: 0;
  }
  .sub #SubMainvisual .title_back .detail_title {
    font-size: 3.2rem;
    padding: 24px 16px;
  }
  .sub #SubMainvisual .title_back:after {
    height: calc(100% - 30px);
  }
  .sub .main_contents {
    padding: 0 10px;
  }
  .sub .main_contents .breadcrumb {
    margin-bottom: 26px;
  }
  .sub .main_contents .breadcrumb nav {
    display: none;
  }
  .sub .main_contents .content {
    width: 100%;
  }
  /* フッター */
  footer {
    padding: 0;
  }
  footer .footer_nav {
    padding: 20px 0;
    margin: 0;
  }
  footer .footer_nav nav {
    display: none;
  }
  footer .footer_nav .icon_link img {
    width: auto;
  }
  footer .footer_nav_under {
    max-width: 100%;
    padding: 0;
  }
  footer .footer_nav_under nav ul {
    justify-content: center;
  }
  footer .footer_nav_under .cpyright {
    padding: 0 0 24px;
  }
  .contact form {
    margin: 24px 0 80px;
  }
  .contact form .form_list {
    display: block;
    width: 100%;
  }
  .contact form .form_list dt {
    max-width: 100%;
    padding: 0;
  }
  .contact form .form_list dd {
    width: 100%;
    margin: 0 0 14px;
  }
  .contact form .form_list dd input {
    margin: 0;
  }
}
/*# sourceMappingURL=base.css.map */


