@charset "UTF-8";
/* ===================================
	File Name   : common.css
	Description : Base Layout CSS
	Editor      : Bface Saeki
	Last Editor : Bface Saeki
	
	Update Description :
	[2021/04/19] 関連展示会（モーダル）「Related Exhibition Setting」　削除
	[2021/02/04] 新規作成
====================================== */

/*========== Style Contents ==========

	1. Global Redefinition
	2. Font Redefinition
	3. Base Box Setting
	4. Common Items Setting
		- Basic Link
	 	- Header Items
		- Global Navigation
	 	- Footer Items

====================================== */



/*===== 1. Global Redefinition =====*/
body {
  background: linear-gradient(90deg, #ebebeb 0px, #fff 1px) left top / 12.5%;
	color: #333333;
	line-height: 1.4;
  margin: 0px auto;
}

dt,li,strong,em,span { line-height: 1.2;}

img { max-width: 100%;}

sup {
  font-size: 1.0rem;
  vertical-align: text-top;
}

figure img { display: block;}

time { font-family: 'Merriweather Sans', 'Noto Sans JP', sans-serif;}

hr {
  margin: 0;
  border: none;
  border-bottom: 1px solid #ccc;
  background: none;
}


@media (max-width: 768px) {
  figure svg {
    display: block;
    width: 100%;
    height: auto
  }
}



/*===== 2. Font Redefinition =====*/
html { font-size: 62.5%;}

body {
	font-size: 1.6em;
	font-family: sans-serif;
}

@media (max-width: 768px) {
	html { font-size: calc(100vw / 76.8 * 2.048);}
}
@media (max-width: 640px) { html { font-size: calc(100vw / 64 * 1.7067);}}
@media (max-width: 480px) { html { font-size: calc(100vw / 48 * 1.28);}}
@media (max-width: 375px) { html { font-size: calc(100vw / 37.5 * 1);}}
@media (max-width: 360px) { html { font-size: calc(100vw / 36);}}
@media (max-width: 320px) { html { font-size: calc(100vw / 32);}}

@media (min-width: 1536px){ html { font-size: calc(100vw / 153.6);}}


@font-face {
  font-family: 'icomoon';
  src:  url('./fonts/icomoon.eot?elux7q');
  src:  url('./fonts/icomoon.eot?elux7q#iefix') format('embedded-opentype'),
    url('./fonts/icomoon.ttf?elux7q') format('truetype'),
    url('./fonts/icomoon.woff?elux7q') format('woff'),
    url('./fonts/icomoon.svg?elux7q#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

@font-face {
  font-family: 'icomoon';
  src:  url('./fonts2/icomoon.eot?elux7q');
  src:  url('./fonts2/icomoon.eot?elux7q#iefix') format('embedded-opentype'),
    url('./fonts2/icomoon.ttf?elux7q') format('truetype'),
    url('./fonts2/icomoon.woff?elux7q') format('woff'),
    url('./fonts2/icomoon.svg?elux7q#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}


[class^="ico_"], [class*=" ico_"] {
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ico_blank:before {
  content: " \e900";
  color: currentColor;
  font-size: 1.2rem;
}
.ico_pdf:before {
  content: " \e903";
  color: currentColor;
  font-size: 1.4rem;
}
.ico_twitter:before {
  content: "\e904";
  color: #fff;
}
.ico_exhibition:before {
  content: "\e901";
  color: #fff;
}

.ico_online:before {
  content: "\e956";
  color: #fff;
}

.ico_lang:before {
  content: "\e902";
  color: #fff;
}

a:hover .ico_blank:before,
a:hover .ico_pdf:before { color: #2172b3;}


@media (max-width: 768px) {
  a:hover .ico_blank:before,
  a:hover .ico_pdf:before { color: currentColor;}
}



/*===== 3. Base Box Setting =====*/
main {
  display: block;
  margin: 40px 0 60px;
}

section,
aside { padding: 0 10px;}

article section:not(:last-child) { margin-bottom: 50px;}


@media (max-width: 768px) {
  main { margin: 5.34vw 2.67vw 8vw;}
  
  section,
  aside { padding: 0;}
  
  article section:not(:last-child) { margin-bottom: 8vw;}
}

@media (min-width: 1536px){ 
  main { margin: 4rem 5rem 8rem;}
}



/*===== 4. Common Items Setting =====*/
/* Basic Link */
a {
  display: inline-block;
	color: hsl(206.71deg 68.87% 41.57%);
	outline: hidden;
  font-weight: 500;
  font-family: 'Noto Sans JP', sans-serif;
	text-decoration: none;
}

a:hover { color: hsl(206.71deg 68.87% 60.57%);}

a.soon {
  opacity: .6;
  pointer-events: none;
}

a img { transition: .25s;}
a:hover img { opacity: .6;}


@media (max-width: 768px) {
  a:not(.textlink):not(.buttonlink):not(.boxlink) { padding: 1.34vw 0;}
  a:hover { color: hsl(207,82%,55%);}
  
  a img { transition: none;}
  a:hover img { opacity: 1;}

  footer a:not([target]):not([href$=".pdf"]):not(.boxlink)::after {
    width: 1.34vw;
    height: 1.34vw;
    margin: -.67vw 0 0 .67vw;
  }
}


/* Header Items */
header {
  display: flex;
  justify-content: space-between;
  padding: 20px 10px;
  font-family: 'Merriweather Sans', 'Noto Sans JP', sans-serif;
}

h1 {
    display: block;
    font-size: 2em;
    margin-block-start: 0.67em;
    margin-block-end: 0.67em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    font-weight: bold;
    unicode-bidi: isolate;
}

header > div:first-child {
  flex: 1;
  margin-right: 20px;
}

header > div:first-child > :first-child {
  max-width: 300px;
  margin-bottom: 15px;
}

header > div:first-child > :first-child img {
  width: 100%;
}

header > div:first-child > div {
  position: absolute;
  top: 35px;
  left: 340px;
}
@media screen and (max-width: 1280px) {
  h1 {
    display: block;
    font-size: 2em;
    margin-block-start: 1.12em;
    margin-block-end: 1.12em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    font-weight: bold;
    unicode-bidi: isolate;
}
  header > div:first-child > div {
  top: 50px;
}
}

header > div:first-child dl {
  display: flex;
  align-items: center;
  line-height: 1.2;
  margin-bottom: 1rem;
}
header > div:first-child dl:not(:last-child) { margin-right: 20px;}

header > div:first-child dt {
  position: relative;
  margin-right: 10px;
  padding-right: 10px;
  font-size: 1.8rem;
}
header > div:first-child dt::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background: #333;
  content: "";
}

header > div:first-child dd span { font-size: 2.4rem;}

header > div:first-child dd span + span::before {
  display: inline-block;
  width: 6px;
  height: 10px;
  margin: 0 5px;
  background: linear-gradient(to bottom left, transparent 50%, currentColor 50.01%) no-repeat top left / 100% 50%, linear-gradient(to top left, transparent 50%, currentColor 50.01%) no-repeat bottom right / 100% 50%;
  transform: translateY(-25%);
  content: "";
} 

header > div:first-child dd p { font-size: 2.0rem;}

header > div:first-child dd p a {  
  position: relative;
  border: 1px solid #333;
  margin-left: 10px;
  padding: .5rem .5em .5em .8em !important;
  color: #333;
  font-size: 1.4rem;
  text-align: center;
  transition: all .3s;
}
header > div:first-child dd p a:hover {
  background: #333;
  color: #fff;
}
header > div:first-child dd p a:hover::before {
  border-left: 6px solid #fff;
}
header > div:first-child dd p a:before {
  position: absolute;
  top: 50%;
  left: 0;
  border: 6px solid transparent;
  border-left: 6px solid #333333;
  transform: translateY(-50%);
  content:'';
}

header #head_inquiry {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

header #head_inquiry li {
  display: flex;
  align-items: center;
  margin-left: 10px;
}

header #head_inquiry a {
/*  min-width: 100px;*/
  min-width: 95px;
  background: #333;
  padding: .5rem;
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
}
header #head_inquiry a:hover { background: #666;}

header #head_inquiry #inq_tweet a { background: hsl(203,89%,53%);}
header #head_inquiry #inq_tweet a:hover { background: hsl(203,99%,63%);}
header #head_inquiry #inq_kyushu a { background: hsl(216,49%,40%);}
header #head_inquiry #inq_kyushu a:hover { background: hsl(216,59%,50%);}
header #head_inquiry #inq_online a { background: hsl(200,100%,40%);}
header #head_inquiry #inq_online a:hover { background: hsl(200,100%,55%);}

header #btn_gnavi { display: none;}

header #sns_x{
  background: #000;
  padding: 15px;
  margin: 0 0 0 10px;
  width: 60px;
  height: 60px;
}

@media (max-width: 1024px) {
  header {
    display: block;
    padding: 2.67vw;
  }

  header > div:first-child { margin-right: 0;}

  header > div:first-child > :first-child {
    display: block;
    max-width: none;
    width: calc(100% - 21.34vw - 5.34vw);
    margin: 2.67vw auto;
  }

  header > div:first-child > :first-child a { width: 100%;}

  header > div:first-child > div {
    display: block;
    margin-bottom: 2.67vw;
    position: relative;
    top: auto;
    left: auto;
  }
  
  header > div:first-child dl:not(:last-child) { margin: 0 0 1.34vw;}

  header > div:first-child dt {
    margin-right: 1.34vw;
    padding-right: 1.34vw;
    font-size: 2vw;
  }

  header > div:first-child dd span { font-size: 2.67vw;}

  header > div:first-child dd span + span::before {
    width: 1vw;
    height: 2vw;
    margin: 0 1.34vw;
    transform: none;
  }

  header > div:first-child dd p { font-size: 2.67vw;}

  header #head_inquiry { 
    justify-content: space-between;
    flex-wrap: wrap;
  }

  header #head_inquiry li {
/*
    flex: 1;
*/
    margin: 0 0 1.34vw;
    width: calc(33.33% - 1.34vw);
  }
  
    header #head_inquiry::after {
      content: "";
      display: block;
      width: calc(33.33% - 2vw);
    }

  
  header #head_inquiry li iframe { transform: scale(1.2);}

  header #head_inquiry a {
    width: 100%;
    min-width: auto;
    padding: 1rem;
    font-size: 1.2rem;
    white-space: nowrap;
  }
  
  header #head_inquiry a { background: #333 !important;}

  header #head_inquiry #inq_tweet a { background: hsl(203,89%,53%) !important;}
  header #head_inquiry #inq_kyushu a { background: hsl(216,49%,40%) !important;}
  header #head_inquiry #inq_online a { background: hsl(200,100%,40%) !important;}
  
  header #btn_gnavi { display: block;}
  
  header #sns_x{
    display: none;
  }
}


@media (max-width: 768px) {
  header > div:first-child > :first-child {
    width: calc(100% - 13.34vw - 5.34vw);
    margin: 2.67vw 0;
    padding: 0 !important;
  }
  
  header > div:first-child dt { font-size: 1.4rem;}

  header > div:first-child dd { font-size: 1.4rem;}

  header > div:first-child dd span { font-size: 1.8rem;}
  
  header > div:first-child dd span + span::before {
    width: 1.34vw;
    height: 2.67vw;
    transform: translateY(-25%);
  }

  header > div:first-child dd p { font-size: 1.8rem;}

  header > div:first-child dd p a {  
    margin-left: 2.67vw;
  }
  header > div:first-child dd p a:before {
    border: 1.6vw solid transparent;
    border-left: 1.6vw solid #333333;
  }
}


/* Global Navigation */
#gnavi {
  display: flex;
  justify-content: flex-end;
  position: relative;
  margin-bottom: 10px;
}

#gnavi a.buttonlink { margin: 0;}

#gnavi > ul {
  display: flex;
  margin-right: 10px;
}

#gnavi > ul > li > a {
  display: flex;
  align-items: center;
  position: relative;
  height: 100%;
  padding: 0 10px;
  color: inherit;
}
#gnavi > ul > li > a:hover,
#gnavi > ul > li > a.active,
#gnavi > ul > li.dropdown > a { color: #2172b3;}

#gnavi > ul > li.dropdown > a::after {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 20px;
  height: 10px;
  background: linear-gradient(to bottom right, transparent 50%, rgba(0,0,0,.8) 50.01%) no-repeat top left / 50% 100%, linear-gradient(to bottom left, transparent 50%, rgba(0,0,0,.8) 50.01%) no-repeat top right / 50% 100%;
  transform: translateX(-50%);
  content: "";
}

#gnavi ul ul {
  display: none;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 3;
  width: 50vw;
  max-width: 100%;
  min-width: 600px;
  padding: 20px;
  background: rgba(0,0,0,.8);
  transform: translateY(100%);
}

#gnavi ul ul li {
  display: inline-block;
  margin: 0 20px 10px 0;
}

#gnavi ul ul li a { color: #ccc;}
#gnavi ul ul li a.soon { color: #999;}
#gnavi ul ul li a:hover { color: #fff;}

#gnavi ul ul li a:hover .ico_blank:before,
#gnavi ul ul li a:hover .ico_pdf:before { color: currentColor;}

#gnavi ul ul li a:not([target]):not([href$=".pdf"])::after {
  display: inline-block;
  width: 4px;
  height: 4px;
  margin: -3px 0 0 3px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
  vertical-align: middle;
  content: "";
}

#gnavi ul li.dropdown ul { display: block;}

#gnavi > a.buttonlink {
  display: flex;
  margin-left: 10px;
}
#gnavi > a.buttonlink span { 
  align-items: center;
  font-size: 1.4rem;
}

/*#gnavi > a:last-child { display: none;}*/


/* button active */
[class^="active"] body {
  overflow: hidden; 
  height: 100vh;
}
[class^="active"] body::after {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 98;
  width: 100%;
  height: 100vh;
  background-color: rgba(255, 255, 255, 0.8);
  background-image: repeating-linear-gradient(135deg, transparent, transparent 4px, rgba(255,255,255,1) 4px, rgba(255,255,255,1) 5px);
  content: "";
}


@media (max-width: 1024px){
  #gnavi {
    display: none;
    position: fixed;
    top: 0;
    right: -50%;
    z-index: 99;
    overflow-y: scroll;
    width: 80%;
    height: 100vh;
    height: -webkit-fill-available;
    margin-bottom: 0;
    padding: calc(2.67vw + 10.67vw + 2.67vw) 2.67vw 2.67vw;
    background: rgba(0, 0, 0, 0);
  }
  
  #gnavi a.buttonlink { margin: 0 auto;}

  #gnavi > ul {
    display: block;
    margin: 0 0 2.67vw;
    background: none;
    -webkit-overflow-scrolling: touch;
  }
  
  #gnavi > ul li {
    margin-bottom: 2px;
    padding-bottom: 2px;
  }
  #gnavi > ul li:not(:last-child) { border-bottom: 1px dotted #666;}
  
  #gnavi > ul > li > a {
    padding: 2.67vw;
    background: rgba(0,0,0,.25);
    color: #fff;
  }
  
  #gnavi > ul > li > a:hover,
  #gnavi > ul > li.dropdown > a { color: #fff;}
  #gnavi > ul > li > a.active { color: #2172b3;}

  #gnavi > ul > li.dropdown > a::after {
    width: 5.34vw;
    height: 1.34vw;
    background: linear-gradient(to bottom right, transparent 50%, rgba(0,0,0,1) 50.01%) no-repeat top left / 50% 100%, linear-gradient(to bottom left, transparent 50%, rgba(0,0,0,1) 50.01%) no-repeat top right / 50% 100%;
  }

  #gnavi ul ul {
    position: static;
    width: 100%;
    min-width: auto;
    padding: 0;
    background: none;
    transform: none;
  }

  #gnavi ul ul li {
    display: block;
    margin: 0;
  }

  #gnavi ul ul li a {
    display: block;
    position: relative;
    padding: 4vw 4vw 4vw 2.67vw;
    font-size: 1.4rem;
    background: rgba(0,0,0,1);
  }
  
  #gnavi ul ul li a::after {
    position: absolute;
    top: 50%;
    right: 2.67vw;
    transform: translateY(-50%);
  }

  #gnavi ul ul li a:not([target]):not([href$=".pdf"])::after {
    width: 1.34vw;
    height: 1.34vw;
    margin: 0;
    transform: translateY(-50%) rotate(45deg);
  }
  #gnavi ul ul li a i {
    position: absolute;
    right: 2.67vw;
  }
  
  #gnavi > a.buttonlink {
    display: block;
    margin: 0 auto 10px;
  }
  
  #gnavi > a.buttonlink span { 
    min-height: 56px;
    font-size: 1.6rem;
  }
  #gnavi > a.buttonlink:hover span {
    margin: 0;
    box-shadow: 0 4px 0 #152F80;
  }
  /*Twitter-ico #gnavi > a:last-child { 
    display: block;
    margin: 5.34vw auto;
    width: 10.66vw;
    text-align: center;
    background: #fff;
    padding:2.67vw;
  }*/
  #gnavi > a:last-child img{
    vertical-align:top;
  }

  
  /* button */
  header #btn_gnavi {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 1.34vw;
    right: 1.34vw;
    z-index: 100;
    max-width: 13.34vw;
    min-height: 13.34vw;
    margin: 0;
    padding: 1.34vw 4vw;
    background: linear-gradient(135deg, #2172b3 0%, #114d7e 50%, #2172b3 100%) no-repeat left top / 200% auto;
  }
  header #btn_gnavi::before {
    position: absolute;
    top: 2px;
    left: 2px;
    width: calc(100% - 6px);
    height: calc(100% - 6px);
    border: 1px solid rgba(255,255,255,.5);
    content: "";
  }
  
  header #btn_gnavi b {
    margin: -1.34vw 0 2.67vw;
    text-shadow: 0 2px 1px rgba(0, 0, 0, .15); 
    color: #fff;
    font-size: 2vw;
  }
  
  header #btn_gnavi span {
    display: block;
    position: relative;
    width: 100%;
    height: 2px;
  }
  header #btn_gnavi span::before,
  header #btn_gnavi span::after {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    box-shadow: 0 2px 1px rgba(0, 0, 0, .15); 
    background: #fff;
    content: "";
  }
  header #btn_gnavi span::before  { top: .67vw;}
  header #btn_gnavi span::after  { top: -.67vw;}
  
  .active_nav header #btn_gnavi { background: linear-gradient(135deg, #152F80 0%, #152F80 100%) no-repeat left top / 100% auto;}
  
  .active_nav header #btn_gnavi span { animation: navBAR .25s ease-in-out forwards;}
  .active_nav #btn_gnavi span::before { animation: navBAR01 .25s ease-in-out forwards;}
  .active_nav #btn_gnavi span::after { animation: navBAR02 .25s ease-in-out forwards}
  
  
  .active_nav #gnavi {
    display: block;
    animation: navSP .4s ease-in-out forwards;
  }
}

@media (max-width: 768px) {
  #gnavi > ul > li > a {
    padding: 4vw 2.67vw;
  }
  
  #gnavi > a.buttonlink { margin-bottom: 2.67vw;}
  
  #gnavi > a.buttonlink span { min-height: 16vw;}
}


@keyframes navSP {
	0% {
    right: -50%;
    opacity: 0;
    background: rgba(0, 0, 0, 0);
	}
	100% {
    right: 0;
    opacity: 1;
    background: rgba(0, 0, 0, .8);
	}
}

@keyframes navBAR {
	0% {
    background: rgba(255,255,255,0);
	}
	100% {
    background: rgba(255,255,255,0);
  }
}
@keyframes navBAR01 {
	0% {
    top: 6px;
	}
	60% {
    top: 0;
    transform: rotate(0);
  }
	80% {
    top: 0;
    transform: rotate(0);
  }
	100% {
    top: 0;
    transform: rotate(45deg);
  }
}
@keyframes navBAR02 {
	0% {
    top: -6px;
	}
	60% {
    top: 0;
    transform: rotate(0);
  }
	80% {
    top: 0;
    transform: rotate(0);
  }
	100% {
    top: 0;
    transform: rotate(-45deg);
  }
}


/* Footer Items */
footer {
  padding-bottom: calc(135px - 1.4rem);
  background: #333;
  color: #ccc;
  font-size: 1.4rem;
}

footer a { color: #ccc;}

footer a:not([target]):not([href$=".pdf"]):not(.boxlink)::after {
  display: inline-block;
  width: 4px;
  height: 4px;
  margin: -3px 0 0 3px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
  vertical-align: middle;
  content: "";
}

footer a.boxlink { font-size: 1.8rem;}

footer a.boxlink span { min-height: 60px;}

footer #footer_sitemap {
  padding: 40px 10px 15px;
  background: #444;
}

footer #footer_sitemap nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

footer #footer_sitemap nav > dl { width: 56.25%;}
footer #footer_sitemap nav > dl:nth-of-type(1) { order: 1;}
footer #footer_sitemap nav > dl:nth-of-type(2) { order: 3;}
footer #footer_sitemap nav > dl:nth-of-type(3) { order: 4;}
footer #footer_sitemap nav > dl:nth-of-type(4) { order: 5; width: 100%;}
footer #footer_sitemap nav > dl:nth-of-type(5) { order: 6; width: 100%;}
footer #footer_sitemap nav > ul {
  order: 2;
  width: 37.5%;
}

footer #footer_sitemap nav > ul li:not(:last-child) { margin-bottom: 10px;}

footer #footer_sitemap dl { margin-bottom: 25px;}

footer #footer_sitemap dt {
  margin-bottom: 15px;
  color: #fff;
  font-weight: bold;
  font-size: 1.8rem;
}

footer #footer_sitemap dd li {
  display: inline-block;
  margin: 0 0 10px 20px;
  vertical-align: top;
}

footer #nav_jma {
  display: flex;
  justify-content: center;
  margin-bottom: 25px;
  padding: 25px 0;
  border-bottom: 1px solid #444;
}

footer #nav_jma > * { margin: 0 15px;}

footer #footer_inquiry {
  display: flex;
  justify-content: space-between;
  padding: 0 10px;
  font-family: 'Noto Sans JP', sans-serif;
}
footer #footer_inquiry > div:nth-child(1) { flex: 5; padding-bottom: 3rem;}
footer #footer_inquiry > div:nth-child(2) { flex: 2; width: 380px;}

footer #footer_inquiry dl {
  margin-bottom: 15px;
  font-weight: bold;
}

footer #footer_inquiry dt {
  margin-bottom: 10px;
  font-size: 2.0rem;
}

footer #footer_inquiry dd { font-size: 1.6rem;}

footer #footer_inquiry dl + ul { display: flex;}

footer #footer_inquiry dl + ul li {
  display: flex;
  align-items: center;
  margin-right: 20px;
  font-size: 1.4rem;
  white-space: nowrap;
}

footer #footer_inquiry dl + ul li p {
  width: 5rem;
  padding: .5rem;
  background: #666;
  text-align: center;
}

footer #footer_inquiry dl + ul li span { margin-left: 10px;}

footer #footer_inquiry > div:nth-child(2) > a {
  display: block;
  margin-bottom: 15px;
}

footer #footer_inquiry > div:nth-child(2) ul { margin-right: -10px;}

footer #footer_inquiry > div:nth-child(2) li:not(:last-child) { margin-bottom: 5px;}

footer #footer_inquiry > div:nth-child(2) ul a {
  display: block;
  padding: 10px;
  background: #666;
}
footer #footer_inquiry > div:nth-child(2) ul a:hover {
  background: #999;
  color: #fff;
}
footer #footer_inquiry > div:nth-child(2) ul a:hover i.ico_blank::before { color: currentColor;}

footer #footer_inquiry + p {
  display: inline-block;
  margin: 0 10px;
  font-family: Arial, Helvetica, "sans-serif";
  transform: translateY(-100%);
}


@media (max-width: 768px) {
  footer {
		padding-bottom: calc(6rem + 16.02vw);
	}
  
  footer a:not([target]):not([href$=".pdf"]):not(.boxlink)::after {
    width: 1.34vw;
    height: 1.34vw;
    margin: -.67vw 0 0 .67vw;
  }

  footer a.boxlink { font-size: 1.4rem;}

  footer a.boxlink span {
    min-height: 5.5rem;
    padding: 1rem 5.34vw 1rem 2.66vw
  }
  
  footer #footer_sitemap { padding: 5.34vw 0 1.34vw;}

  footer #footer_sitemap nav { display: block;}

  footer #footer_sitemap nav > dl { width: 100%;}
  footer #footer_sitemap nav > dl:not(:last-child) { border-bottom: 1px solid #999;}
  
  footer #footer_sitemap nav > ul {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }
  
  footer #footer_sitemap nav > ul li  {width: calc(50% - 1.34vw);;}
  
/*  footer #footer_sitemap nav > ul li:not(:last-child) { margin-bottom: 0;}*/

  footer #footer_sitemap dl { margin-bottom: 0;}

  footer #footer_sitemap dt {
    position: relative;
    margin-bottom: 0;
    padding: 5.34vw 0;
  }
  
  footer #footer_sitemap dt::before,
  footer #footer_sitemap dt::after {
    position: absolute;
    top: 50%;
    right: 2.67vw;
    background: #fff;
    transform: translateY(-50%);
    content: "";
  }
  footer #footer_sitemap dt::before { width: 5.34vw; height: 2px;}
  footer #footer_sitemap dt::after {
    right: calc(2.67vw + 2.68vw - 1px);
    width: 2px;
    height: 5.34vw;
  }
  footer #footer_sitemap dt.active::after { display: none;}

  footer #footer_sitemap dd { display: none;}
  
  footer #footer_sitemap dd ul { margin-bottom: 2.67vw;}

  footer #footer_sitemap dd li {
    display: block;
    margin: 0 0 0 4vw;
    padding-bottom: 2.67vw;
  }
  
  footer #footer_sitemap .active dd { display: block;}
  
  footer #footer_sitemap nav > ul li,
  footer #footer_sitemap nav > ul li:not(:last-child) { margin-bottom: 1.34vw;}

  footer #nav_jma {
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-bottom: 5.34vw;
    padding: 0;
  }

  footer #nav_jma > * {
    width: 50%;
    margin: 0;
  }
  footer #nav_jma > *:not(:last-child) { border-bottom: 1px solid #444;}
  footer #nav_jma > *:nth-child(odd) { border-right: 1px solid #444;}
  
  footer #nav_jma a {
    display: block;
    padding: 4vw 2.67vw;
  }

  footer #footer_inquiry {
    display: block;
    padding: 0 2.67vw;
  }
  footer #footer_inquiry > div:nth-child(1) { flex: none; padding: 0;}
  footer #footer_inquiry > div:nth-child(2) {
    flex: none;
    width: auto;
    text-align: center;
  }

  footer #footer_inquiry dl { margin-bottom: 4vw;}

  footer #footer_inquiry dt {
    margin-bottom: 2.67vw;
    font-size: 1.8rem;
  }
  
  footer #footer_inquiry dd { font-size: 1.4rem;}

  footer #footer_inquiry dl + ul {
    display: block;
    margin-bottom: 5.34vw;
    padding-bottom: 5.34vw;
    border-bottom: 1px dotted #444;
  }

  footer #footer_inquiry dl + ul li { margin-right: 0;}
  footer #footer_inquiry dl + ul li:not(:last-child) { margin-bottom: 1.34vw;}

  footer #footer_inquiry dl + ul li span { margin-left: 2.67vw;}

  footer #footer_inquiry > div:nth-child(2) > a {
    display: inline-block;
    width: 70%;
    margin-bottom: 2.67vw;
  }

  footer #footer_inquiry > div:nth-child(2) ul {
    margin: 0 0 5.34vw;
    text-align: left;
  }

  footer #footer_inquiry > div:nth-child(2) li:not(:last-child) { margin-bottom: 1.34vw;}

  footer #footer_inquiry > div:nth-child(2) ul a { padding: 2.67vw;}
  footer #footer_inquiry > div:nth-child(2) ul a:hover {
    background: #666;
    color: inherit;
  }

  footer #footer_inquiry + p {
    display: block;
    margin: 0;
    font-size: 1.3rem;
    text-align: center;
    transform: none;
  }
}

.contact-btn{
	background-color: rgba(0, 0, 0, 0.6);
	display: block;
	padding: 10px 10px;
	position: fixed;
	left: 0;
	bottom: 0;
	width: 100%;
	text-align: center;
	z-index: 3;
  transition: all 1s;
	transform: translateY(110px);
	max-height: 110px;
}

.contact-btn.isActive{
  transition: all 1s;
	transform: translateY(0);
}

.contact-btn ul{
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	}

.contact-btn ul li{
	width: calc(50% - 10px);
}

.contact-btn ul li a{
	width: 100%;
	line-height: 30px;
	font-size: 1.8rem;
	background: linear-gradient(135deg, #0080CC 0%, #114d7e 50%, #0080CC 100%) no-repeat left top / 200% auto;
}
/*右下バナー2つVer*/
/*.contact-btn{
	background-color: rgba(0, 0, 0, 0.6);
	display: block;
	padding: 10px;
	position: fixed;
	right: 0;
	bottom: 0;
	width: 50%;
	min-width: 760px;
	text-align: center;
	z-index: 3;
  transition: all 1s;
	transform: translateY(110px);
}

.contact-btn.isActive{
  transition: all 1s;
	transform: translateY(0);
}

.contact-btn ul{
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
  padding: 0
	}

.contact-btn ul li{
	width: calc(50% - 5px);
}

.contact-btn ul li a {
  width: 100%;
  font-size: 1.8rem;
  background: #fff
}
.contact-btn ul li img {
  vertical-align: bottom
}
*/
/*右下バナー1つVer*/
/*
.contact-btn{
	background-color: rgba(0, 0, 0, 0.6);
	display: block;
	padding: 10px;
	position: fixed;
	right: 0;
	bottom: 0;
	width: 25%;
  min-width: 360px;
	text-align: center;
	z-index: 3;
  transition: all 1s;
	transform: translateY(110px);
}

.contact-btn.isActive{
  transition: all 1s;
	transform: translateY(0);
}

.contact-btn ul{
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
  padding: 0
	}

.contact-btn ul li a {
  width: 100%;
  font-size: 1.8rem;
  background: #fff
}
.contact-btn ul li img {
  vertical-align: bottom
}
*/


@media (max-width: 768px) {
  .contact-btn{
		padding: 4vw 0;
		transform: translateY(29.333vw);
		max-height: none;
	}

	.contact-btn ul li{
		width: calc(50% - 1.34vw);
	}

	.contact-btn ul li a{
		width: 100%;
		line-height: 8vw;
		font-size: 3.733vw;
	}
	/*右下バナー2つVer*/
  /*.contact-btn{
		padding: 4vw 2.67vw;
		transform: translateY(29.333vw);
		min-width: auto;
    width: 100%
	}
  .contact-btn ul li a:not(.textlink):not(.buttonlink):not(.boxlink) {
    padding: 0
  }*/
  /*右下バナー1つVer*/
  /*.contact-btn{
		padding: 4vw 0;
		transform: translateY(29.333vw);
		min-width: auto;
    width: 100%
	}
	.contact-btn ul li a{
		width: 50%;
		line-height: 8vw;
		font-size: 3.733vw;
	}
  .contact-btn ul li a:not(.textlink):not(.buttonlink):not(.boxlink) {
    padding: 0
  }*/
}