@charset "UTF-8";
/*
@mixin mPc { 
	@media screen and (min-width: 961px) and (max-width: 1280px){
		@content;
	}	
}
*/
/* Reset */
/*-----------------------------------------------*/
html {
  min-height: 100%;
  height: auto !important;
  height: 100%;
  width: auto !important;
  width: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  font-size: 62.5%; }

body {
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.02em;
  vertical-align: baseline;
  color: #000000;
  box-sizing: padding-box;
  background-color: #FFFFFF;
  margin: 0;
  padding: 0;
  overflow-x: hidden; }

body {
  animation: fadeIn 2s ease 0s 1 normal;
  -webkit-animation: fadeIn 2s ease 0s 1 normal; }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
:root {
  box-sizing: border-box; }

*, *:before, *:after {
  box-sizing: inherit; }

* {
  min-height: 0vw;
  /* Safari clamp関数対策 */ }

div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
  border: 0;
  outline: 0;
  font-size: 16px;
  font-weight: inherit;
  font-style: inherit;
  vertical-align: baseline;
  margin: 0;
  padding: 0; }
  @media screen and (max-width: 960px) {
    div, span, applet, object, iframe,
    h1, h2, h3, h4, h5, h6, p, blockquote, pre,
    a, abbr, acronym, address, big, cite, code,
    del, dfn, em, font, img, ins, kbd, q, s, samp,
    small, strike, strong, sub, sup, tt, var,
    dl, dt, dd, ol, ul, li,
    fieldset, form, label, legend,
    table, caption, tbody, tfoot, thead, tr, th, td {
      font-size: 15px; } }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0px; }

a {
  text-decoration: none;
  color: #000000; }
  a.decoration {
    text-decoration: underline; }
    a.decoration:visited, a.decoration:focus, a.decoration:active {
      text-decoration: underline;
      outline: 0; }
  a:visited, a:focus, a:active {
    text-decoration: none;
    color: #000000;
    outline: 0; }

/* clearfix */
/*-----------------------------------------------*/
.clearfix:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0; }

* html .clearfix {
  zoom: 1; }

*:first-child + html .clearfix {
  zoom: 1; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  transition: all .25s ease-out;
  /*a &:hover {
  	filter:alpha(opacity=80);
  	-moz-opacity: 0.8;
  	opacity: 0.8;
  }*/ }
  img .centerize {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    display: block; }

.centerize {
  text-align: center;
  margin-left: auto;
  margin-right: auto; }

.center {
  text-align: center !important; }

.right {
  text-align: right !important; }

.left {
  text-align: left !important; }

.rightBox {
  float: right !important; }

.leftBox {
  float: left !important; }

.clear {
  clear: both; }

.bold {
  font-weight: bold !important; }

.noline {
  border: none !important; }

.hide {
  display: none !important; }

@media screen and (max-width: 767px) {
  .onlyPc {
    display: none; } }
@media screen and (min-width: 768px) {
  .onlySp {
    display: none; } }
/*-----------------------------------------------*/
/* Reset */
strong {
  font-weight: bold; }

#container {
  overflow: hidden;
  position: relative; }

@media screen and (max-width: 960px) {
  body.fixed {
    overflow: hidden; } }
/* ----------------------------------------
	header
---------------------------------------- */
header#masthead {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 60px;
  background-color: #f2f6f9;
  color: #FFFFFF;
  transition: all .25s ease-out;
  z-index: 10; }
  @media screen and (min-width: 961px) {
    header#masthead {
      height: 120px;
      /*background: rgba(255,255,255,0);*/ } }
  header#masthead .site_title {
    position: absolute;
    top: 15px;
    left: 2%;
    z-index: 11; }
    @media screen and (min-width: 961px) {
      header#masthead .site_title {
        top: 30px; } }
    header#masthead .site_title img {
      width: 150px;
      /*filter: brightness(0) invert(1);*/ }
      @media screen and (min-width: 961px) and (max-width: 1280px) {
        header#masthead .site_title img {
          width: 200px; } }
      @media screen and (min-width: 1281px) {
        header#masthead .site_title img {
          width: 380px; } }
  header#masthead.fixed {
    background: #f2f6f9; }
    @media screen and (min-width: 961px) {
      header#masthead.fixed {
        height: 80px; } }
    header#masthead.fixed .site_title {
      top: 50%;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%); }
      header#masthead.fixed .site_title img {
        width: 120px;
        filter: brightness(1) invert(0); }
        @media screen and (min-width: 961px) {
          header#masthead.fixed .site_title img {
            width: 140px; } }
  header#masthead .site_title.active img {
    filter: brightness(0) invert(1); }

/* ------.hamburger------------ */
@media screen and (max-width: 960px) {
  .hamburger {
    display: block;
    position: absolute;
    z-index: 99;
    right: 3%;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 30px;
    height: 32px;
    cursor: pointer;
    text-align: center;
    z-index: 100;
    /*&::before, &::after {
    	position: absolute;
    	left: 0;
    	top: 12px;
    	content: "MENU";
    	font-family: $lato;
    	font-size: 1.0rem;
    	font-weight: 500;
    	color: #FFFFFF;
    	letter-spacing: .3em;
    	line-height: 1;
    	transition: all .4s;
    }
    &::after {
    	top: 24px;
    	content: "CLOSE";
    	opacity: 0;
    }*/ }
    .hamburger span {
      position: absolute;
      right: 0;
      top: 8px;
      width: 30px;
      height: 2px;
      display: block;
      background-color: #005fb7;
      border-radius: 1px;
      -moz-border-radius: 1px;
      -webkit-border-radius: 1px;
      transition: all .4s; }
      .hamburger span:nth-child(2) {
        top: 16px; }
      .hamburger span:nth-child(3) {
        top: 24px; }
    .hamburger.fixed::before {
      color: #005fb7; }
    .hamburger.fixed span {
      background-color: #005fb7; }
    .hamburger.active::before {
      top: 0px;
      opacity: 0; }
    .hamburger.active::after {
      top: 12px;
      opacity: 1;
      color: #FFFFFF; }
    .hamburger.active span {
      background-color: #FFFFFF; }
      .hamburger.active span:nth-child(1) {
        top: 16px;
        transform: rotate(45deg); }
      .hamburger.active span:nth-child(2) {
        transform: scaleX(0); }
      .hamburger.active span:nth-child(3) {
        top: 16px;
        transform: rotate(135deg); } }
@media screen and (min-width: 961px) {
  .hamburger {
    display: none; } }

/* ------#nav_global------------ */
#nav_global {
  /* ----------------------- */ }
  @media screen and (max-width: 960px) {
    #nav_global {
      position: fixed;
      z-index: -1;
      top: 0;
      left: 0;
      right: 0;
      /*background-image: linear-gradient(90deg, rgba(10, 86, 163, 1), rgba(11, 95, 179, 1) 15%, rgba(11, 184, 222, 1));*/
      background: #005fb7;
      text-align: center;
      transition: all 0.4s;
      padding: 0 5% 50px;
      width: 100%;
      height: 100%;
      opacity: 0;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      pointer-events: none; }
      #nav_global ul.nav_main {
        display: inline-block;
        margin: 120px auto 20px;
        max-width: 600px;
        width: 90%;
        text-align: left; }
        #nav_global ul.nav_main > li {
          border-bottom: 1px solid #FFFFFF; }
          #nav_global ul.nav_main > li a {
            position: relative;
            display: block;
            margin: 0 auto;
            padding: 15px 10px;
            font-size: 1.5rem;
            font-weight: 400;
            color: #ffffff; }
            #nav_global ul.nav_main > li a::after {
              position: absolute;
              right: 15px;
              top: 50%;
              margin-top: -3px;
              width: 6px;
              height: 6px;
              content: "";
              border-top: 2px solid #FFFFFF;
              border-right: 2px solid #FFFFFF;
              -webkit-transform: rotate(45deg);
              transform: rotate(45deg); }
          #nav_global ul.nav_main > li.head_contact {
            margin: 0 auto;
            max-width: 400px;
            width: 100%;
            padding-top: 20px;
            border-bottom: none;
            background: #005fb7;
            color: #FFFFFF; } }
        @media screen and (max-width: 960px) and (min-width: 961px) {
          #nav_global ul.nav_main > li.head_contact {
            width: 120px; } }
  @media screen and (max-width: 960px) {
            #nav_global ul.nav_main > li.head_contact a {
              padding: 15px 20px;
              color: #FFFFFF;
              text-align: center;
              background-color: #005fb7;
              border-radius: 5px;
              -moz-border-radius: 5px;
              -webkit-border-radius: 5px; }
              #nav_global ul.nav_main > li.head_contact a::after {
                display: none; }
          #nav_global ul.nav_main > li.drop .nav_sub > ul {
            margin-left: 2em; }
            #nav_global ul.nav_main > li.drop .nav_sub > ul li {
              border-top: 1px dotted #ffffff; }
              #nav_global ul.nav_main > li.drop .nav_sub > ul li a {
                padding: 15px;
                font-size: 1.3rem; }
      #nav_global.active {
        opacity: 1;
        z-index: 10;
        pointer-events: auto; } }
  @media screen and (min-width: 961px) {
    #nav_global {
      display: block;
      position: relative;
      top: 30%;
      -webkit-transform: translateY(-30%);
      transform: translateY(-30%);
      transition: all .25s ease-out; }
      #nav_global ul.nav_main {
        position: relative;
        padding-right: 1%;
        display: flex;
        justify-content: flex-end;
        width: 100%;
        height: 100%;
        top: 55px; }
        #nav_global ul.nav_main > li {
          position: relative;
          padding: 0 15px;
          /*&:not(.head_contact) {
          	&::before {
          		display: inline-block;
          		position: absolute;
          		top: -15px;
          		left: 0;
          		right: 0;
          		margin: 0 auto;
          		content: " ";
          		width: 0;
          		height: 0;
          		border-style: solid;
          		border-width: 6.9px 4px 0px 4px;
          		border-color: $orange transparent transparent transparent;
          		opacity: 0;
          		transition: all .4s ease-out;
          	}
          }
          &:hover {
          	&::before {
          		top: -8px;
          		opacity: 1;
          	}
          }*/ }
          #nav_global ul.nav_main > li:hover {
            color: #005fb7; }
          #nav_global ul.nav_main > li > a {
            position: relative;
            padding: 0px 0;
            font-size: 1.5rem;
            font-weight: 500;
            color: #000000;
            line-height: 1;
            transition: all .4s ease-out; }
            #nav_global ul.nav_main > li > a:hover {
              color: #005fb7; }
          #nav_global ul.nav_main > li.head_contact {
            top: -45px;
            border-radius: 5px;
            -moz-border-radius: 5px;
            -webkit-border-radius: 5px; }
            #nav_global ul.nav_main > li.head_contact a {
              /*padding: 15px 20px;*/
              padding: 10px 14px;
              display: block;
              color: #ffffff;
              background-color: #005fb7;
              border-radius: 5px;
              -moz-border-radius: 5px;
              -webkit-border-radius: 5px;
              text-align: center;
              line-height: 1.5; }
              #nav_global ul.nav_main > li.head_contact a:hover {
                background-color: #ffa02e; }
              #nav_global ul.nav_main > li.head_contact a img {
                width: 30px;
                display: inline-block; }
          #nav_global ul.nav_main > li.drop {
            position: relative; }
            #nav_global ul.nav_main > li.drop .nav_sub {
              position: absolute;
              /*top: 100%;*/
              left: -20px;
              padding-top: 10px;
              width: -webkit-max-content;
              width: max-content;
              opacity: 0;
              z-index: -1;
              pointer-events: none;
              transition: all .4s ease-out;
              transform: translateY(-20px); }
              #nav_global ul.nav_main > li.drop .nav_sub > ul {
                padding: 5px 20px;
                background-image: linear-gradient(90deg, #0a56a3, #0b5fb3 15%, #0bb8de);
                z-index: 3; }
                #nav_global ul.nav_main > li.drop .nav_sub > ul li a {
                  position: relative;
                  display: block;
                  height: auto;
                  padding: 15px 20px 15px 0;
                  font-size: 1.2rem;
                  color: #FFFFFF;
                  /*&::after {
                  	position: absolute;
                  	right: 0;
                  	top: 50%;
                  	margin-top: -3px;
                  	width: 6px;
                  	height: 6px;
                  	content: "";
                  	border-top: 2px solid $orange;
                  	border-right: 2px solid $orange;
                  	-webkit-transform: rotate(45deg);
                  	transform: rotate(45deg);
                  }*/ }
                  #nav_global ul.nav_main > li.drop .nav_sub > ul li a:hover {
                    color: #ffb000; }
                #nav_global ul.nav_main > li.drop .nav_sub > ul li:not(:last-child) {
                  border-bottom: 1px dotted #ffffff; }
            #nav_global ul.nav_main > li.drop:hover .nav_sub {
              opacity: 1;
              z-index: 2;
              pointer-events: auto;
              transform: translateY(0); }
          #nav_global ul.nav_main > li.sp {
            display: none; }
      #nav_global.fixed {
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%); }
        #nav_global.fixed ul.nav_main {
          top: 35px; }
          #nav_global.fixed ul.nav_main > li a {
            font-size: 1.2rem;
            color: #000000; }
          #nav_global.fixed ul.nav_main > li.head_contact {
            top: -35px; }
            #nav_global.fixed ul.nav_main > li.head_contact a {
              padding: 5px 20px;
              color: #ffffff;
              font-size: 1.2rem; }
              #nav_global.fixed ul.nav_main > li.head_contact a img {
                width: 20px; } }

@media screen and (max-width: 960px) {
  #nav_subglobal {
    display: none; } }
@media screen and (min-width: 961px) {
  #nav_subglobal {
    position: absolute;
    border: 1px solid #00233f;
    background: #ebebeb;
    border: 1px solid #dde7e9;
    padding: 5px 10px;
    right: 180px;
    top: 15px;
    width: 330px;
    border-radius: 7px; }
    #nav_subglobal.fixed {
      top: 10px; }
      #nav_subglobal.fixed a {
        font-size: 1.1rem !important; } }
@media screen and (min-width: 961px) {
  #nav_subglobal ul.nav_sub {
    display: flex;
    justify-content: space-between; } }
#nav_subglobal ul.nav_sub li {
  width: 33.333%; }
  #nav_subglobal ul.nav_sub li:nth-of-type(1) {
    border-right: 1px solid #cccccc; }
  #nav_subglobal ul.nav_sub li:nth-of-type(2) {
    border-right: 1px solid #cccccc; }
  #nav_subglobal ul.nav_sub li a {
    font-size: 1.3rem;
    text-align: center;
    padding: 0px 10px;
    display: block; }
    #nav_subglobal ul.nav_sub li a:hover {
      color: #005fb7; }

@media screen and (max-width: 960px) {
  .head_contact {
    border-radius: 5px;
    background: #00233f !important;
    padding-top: 0px !important;
    margin-top: 20px !important; }
    .head_contact a {
      background: #00233f !important; }
    .head_contact img.icon_fukidashi {
      width: 30px;
      margin-right: 10px; } }

/* ----------------------------------------
	#content
---------------------------------------- */
#information #content {
  margin: 0px auto 0;
  margin-top: 60px; }
  @media screen and (min-width: 768px) {
    #information #content {
      margin-top: 100px; } }

#content {
  margin: 0px auto 0;
  padding: 0px 0px 0px 0px;
  min-height: 650px;
  height: 100%;
  /*@include minTabw {
  	margin-top: 100px;
  }*/ }
  #content #main {
    position: relative;
    padding: 0px 0px 0px 0px; }
    @media screen and (min-width: 961px) {
      #content #main {
        padding: 0px 0px 0px 0px; } }
  #content .inner {
    margin: 0 auto;
    padding: 60px 5%;
    max-width: 1100px;
    width: 100%; }
    @media screen and (min-width: 768px) and (max-width: 960px) {
      #content .inner {
        padding: 80px 5%; } }
    @media screen and (min-width: 961px) and (max-width: 1280px) {
      #content .inner {
        padding: 100px 5%; } }
    @media screen and (min-width: 1281px) {
      #content .inner {
        padding: 120px 30px; } }
  #content .inner2 {
    margin: 0 auto;
    padding: 80px 5%;
    max-width: 1100px;
    width: 100%; }
    @media screen and (min-width: 961px) and (max-width: 1280px) {
      #content .inner2 {
        padding: 100px 5%; } }
    @media screen and (min-width: 1281px) {
      #content .inner2 {
        padding: 150px 30px; } }
  #content .inner3 {
    margin: 0 auto;
    padding: 25px 5%;
    max-width: 900px;
    width: 100%; }
    @media screen and (min-width: 768px) {
      #content .inner3 {
        padding: 40px 20px; } }
  #content section,
  #content div.group {
    position: relative; }
  #content section.last,
  #content div.group.last {
    margin-bottom: 0; }
  #content section:after,
  #content div.group:after {
    content: "";
    display: block;
    clear: both;
    height: 1px;
    overflow: hidden; }
  #content .fullWidth {
    margin-left: -500%;
    margin-right: -500%;
    padding-left: 500%;
    padding-right: 500%; }
  #content .flex_between {
    display: flex;
    justify-content: space-between; }
  #content .flex_center {
    display: flex;
    justify-content: center; }
  #content p {
    margin: 0 0 1em;
    line-height: 1.8; }
  #content ol.decimal li {
    list-style-type: decimal;
    margin-left: 23px;
    padding: 0 0 10px 10px; }
  #content ul.square li {
    list-style-type: square;
    margin-left: 20px;
    padding: 0 0 10px 0px; }
  #content ul.disc li {
    list-style-type: disc;
    margin-left: 20px;
    margin-bottom: 1em; }
  #content ul.listWrap li.empty {
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important; }
    #content ul.listWrap li.empty::after {
      display: none; }

/* .entry-content{
	padding-top:50px;
	@include spTab{
		padding-top:50px;
	}
	@include tabPc{
		padding-top:60px;
	}
	@include minPc{
		padding-top:80px;
	}
}
 */
#mainArea {
  position: relative;
  top: -50px;
  padding: 0px 3%; }
  @media screen and (min-width: 481px) and (max-width: 767px) {
    #mainArea {
      top: -100px; } }
  @media screen and (min-width: 768px) {
    #mainArea {
      top: -90px; } }
  #mainArea #mainArea_ol {
    background: #ffffff;
    border-radius: 10px 10px 0px 0px;
    margin: 0 auto;
    max-width: 1280px;
    width: 100%; }
    @media screen and (max-width: 480px) {
      #mainArea #mainArea_ol {
        border-radius: 6px 6px 0px 0px;
        padding: 60px 0%; } }
    @media screen and (min-width: 481px) and (max-width: 960px) {
      #mainArea #mainArea_ol {
        padding: 50px 0% 50px 0%; } }
    @media screen and (min-width: 961px) and (max-width: 1280px) {
      #mainArea #mainArea_ol {
        padding: 50px 0% 50px 0%; } }
    @media screen and (min-width: 1281px) {
      #mainArea #mainArea_ol {
        padding: 80px 50px 120px 50px; } }

/* ----------------------------------------
	#共通
---------------------------------------- */
/* ----------------------------------------
	.wp-pagenavi
---------------------------------------- */
.wp-pagenavi {
  margin: 0px auto 50px;
  padding: 15px 0 0;
  width: 100%;
  text-align: center;
  /*border-top: 1px solid #E2E2E2;*/
  /*display: flex;*/
  justify-content: center;
  display: inline-block; }
  @media screen and (min-width: 768px) {
    .wp-pagenavi {
      margin: 50px auto 0; } }
  .wp-pagenavi a,
  .wp-pagenavi span {
    text-decoration: none !important;
    white-space: nowrap;
    border: 1px solid #00233f !important;
    margin: 2px 4px !important;
    padding: 8px 10px !important;
    font-size: 1.3rem;
    line-height: 1;
    color: #00233f;
    display: inline-block;
    transition-property: all;
    transition: 0.2s linear; }
    .wp-pagenavi a.current, .wp-pagenavi a.previouspostslink, .wp-pagenavi a.nextpostslink, .wp-pagenavi a:hover,
    .wp-pagenavi span.current,
    .wp-pagenavi span.previouspostslink,
    .wp-pagenavi span.nextpostslink,
    .wp-pagenavi span:hover {
      font-weight: normal;
      color: #FFFFFF;
      background: #00233f;
      border: 1px solid #00233f;
      display: inline-block; }
    .wp-pagenavi a.extend,
    .wp-pagenavi span.extend {
      border: none; }

/* ----------------------------------------
	.p_navi
---------------------------------------- */
.p_navi {
  margin: 0px auto 0;
  padding: 30px 0 0;
  width: 100%;
  text-align: center;
  display: flex;
  justify-content: center; }
  @media screen and (min-width: 768px) {
    .p_navi {
      margin: 50px auto 0; } }
  .p_navi div {
    margin: 0 3px; }
  .p_navi a {
    display: inline-block;
    padding: 8px;
    font-size: 1.3rem;
    line-height: 1;
    color: #ffffff;
    text-decoration: none !important;
    transition: 0.2s linear;
    background: #005fb7;
    border-radius: 5px; }
    .p_navi a:hover {
      color: #FFFFFF;
      background: #3eb3e7; }
  .p_navi .prev a:before {
    content: url("../images/common/arrow_before.svg");
    display: inline-block;
    width: 10px;
    background-size: contain;
    padding-right: 5px; }
  .p_navi .next a:after {
    content: url("../images/common/arrow_next.svg");
    display: inline-block;
    width: 10px;
    background-size: contain;
    padding-left: 5px; }
  .p_navi .list a {
    padding: 8px 20px; }

/* ----------------------------------------
	#foot_banner_area
---------------------------------------- */
#foot_banner_area {
  position: relative;
  background: #FFFFFF;
  text-align: center; }
  #foot_banner_area .inner {
    margin: 0 auto;
    padding: 50px 5%;
    max-width: 1100px;
    width: 100%; }
    @media screen and (min-width: 768px) and (max-width: 1280px) {
      #foot_banner_area .inner {
        padding: 80px 5%; } }
    @media screen and (min-width: 1281px) {
      #foot_banner_area .inner {
        padding: 80px 30px; } }
  @media screen and (max-width: 767px) {
    #foot_banner_area ul.banner {
      max-width: 400px;
      margin: 0px auto; } }
  @media screen and (min-width: 768px) {
    #foot_banner_area ul.banner {
      margin: 0px auto;
      display: flex;
      justify-content: space-between; } }
  @media screen and (max-width: 767px) {
    #foot_banner_area ul.banner li {
      margin-bottom: 15px; } }
  @media screen and (min-width: 768px) {
    #foot_banner_area ul.banner li {
      width: 49%; } }
  #foot_banner_area ul.banner li:hover img {
    opacity: 0.8; }

/* ----------------------------------------
	#mastfoot
---------------------------------------- */
#mastfoot {
  position: relative;
  line-height: 1.3;
  background: #dde7e9;
  /* ------pagetop------------*/ }
  #mastfoot p, #mastfoot div, #mastfoot a, #mastfoot span {
    color: #00233f; }
  #mastfoot .inner {
    margin: 0 auto;
    padding: 60px 5%;
    max-width: 1270px;
    width: 100%; }
    @media screen and (min-width: 768px) and (max-width: 1280px) {
      #mastfoot .inner {
        padding: 80px 5%; } }
    @media screen and (min-width: 1281px) {
      #mastfoot .inner {
        padding: 100px 30px; } }
  @media screen and (min-width: 961px) {
    #mastfoot .inner {
      display: flex;
      justify-content: space-between; } }
  @media screen and (max-width: 960px) {
    #mastfoot .inner #infoArea {
      text-align: center; } }
  @media screen and (min-width: 961px) {
    #mastfoot .inner #infoArea {
      border-right: 1px solid #00233f;
      padding-top: 15px;
      padding-bottom: 15px;
      padding-right: 4%; } }
  @media screen and (min-width: 961px) and (max-width: 1280px) {
    #mastfoot .inner #infoArea {
      width: 35%; } }
  @media screen and (min-width: 1281px) {
    #mastfoot .inner #infoArea {
      width: 440px; } }
  @media screen and (max-width: 960px) {
    #mastfoot .inner #sitemapArea {
      display: none; } }
  @media screen and (min-width: 961px) and (max-width: 1280px) {
    #mastfoot .inner #sitemapArea {
      width: 60%; } }
  @media screen and (min-width: 1281px) {
    #mastfoot .inner #sitemapArea {
      width: -webkit-calc(100% -440px);
      width: calc(100% - 440px); } }
  #mastfoot .inner #sitemapArea #sitemapArea_ol {
    max-width: 640px;
    width: 100%;
    text-align: left;
    float: right; }
  #mastfoot #infoArea {
    position: relative; }
    #mastfoot #infoArea .foot_logo {
      max-width: 340px;
      width: 100%; }
      @media screen and (max-width: 480px) {
        #mastfoot #infoArea .foot_logo {
          max-width: 250px; } }
      @media screen and (max-width: 960px) {
        #mastfoot #infoArea .foot_logo {
          margin: 0px auto;
          margin-bottom: 10px; } }
      @media screen and (min-width: 961px) {
        #mastfoot #infoArea .foot_logo {
          margin-bottom: 20px; } }
    #mastfoot #infoArea .footName {
      width: 100%;
      margin-bottom: 40px; }
    #mastfoot #infoArea #copyright {
      font-size: 1.2rem !important;
      text-align: center; }
      @media screen and (min-width: 961px) {
        #mastfoot #infoArea #copyright {
          text-align: left;
          position: absolute;
          left: 0px;
          bottom: 15px; } }
  @media screen and (min-width: 961px) {
    #mastfoot #sitemapArea #sitemapArea_ol {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; } }
  #mastfoot #sitemapArea ul.main {
    display: inline-block;
    padding-left: 2%; }
    #mastfoot #sitemapArea ul.main li a {
      font-size: clamp(1.4rem, 1.2vw, 1.4rem);
      padding-left: 10px;
      padding: 11px 0px 5px 15px;
      display: block;
      position: relative; }
      #mastfoot #sitemapArea ul.main li a:hover {
        text-decoration: underline; }
      #mastfoot #sitemapArea ul.main li a::before {
        content: url("../images/common/arrow_blue.svg");
        display: inline-block;
        width: 7px;
        background-size: contain;
        position: absolute;
        left: 0px; }
  #mastfoot #sitemapArea ul.sub a::before {
    display: none !important; }
  #mastfoot .pagetop {
    position: fixed;
    right: 5px;
    bottom: 10px;
    z-index: 99; }
    @media screen and (min-width: 768px) {
      #mastfoot .pagetop {
        right: 10px;
        bottom: 20px; } }
    #mastfoot .pagetop img {
      width: 50px; }
      @media screen and (min-width: 768px) {
        #mastfoot .pagetop img {
          width: 60px; } }

/* ----------------------------------------
	reCAPTCHA
---------------------------------------- */
/*reCAPTCHA*/
.grecaptcha-badge {
  visibility: hidden; }

/*reCAPTCHA*/
p.recaptcha {
  padding-top: 20px;
  font-size: 1.0rem;
  font-weight: 400;
  color: #626262; }
  @media screen and (max-width: 960px) {
    p.recaptcha {
      margin: 0px auto;
      text-align: center; } }
  @media screen and (min-width: 961px) {
    p.recaptcha {
      text-align: left; } }
  p.recaptcha a {
    color: #626262;
    font-size: 1.0rem; }
    p.recaptcha a:hover {
      text-decoration: underline; }
