/*style.css*/

html{
  scroll-behavior: smooth;
}


[lang=ja] body {
	line-height: 0;
}


.container-fuild {
	margin: 0;
	padding: 0;
	overflow: hidden;
}

.col-md-9 {
	padding: 0;
}

/* グローバルナビ */
#globalNavi ul {
    display: flex;
    list-style-type: none;
    margin: 0 auto;
    padding: 6px 0;
}

.navbar-toggler{
  margin-bottom: 10px;
  margin-left: 10px;
  margin-top: 10px;
}

.navbar-light .navbar-toggler {
    border-color: rgba(0,0,0,0);
}

/*
.navbar-dark .navbar-toggler {
	border: 1px solid #999;
}
*/

.navbar-toggler-icon {
	width: 2.5em;
}

/* 固定 */
.fixed {
    position: fixed;
    top: 0;
    padding: 0;
    width: 100%;
    z-index: 1000;
}

/* reset css */

p {
	margin: 0;
	padding: 0;
}

/* base css */

a {
	color: #000;
}

a img:hover {
	opacity: .8;
}

li a {
	color: #fff;
	text-decoration: underline;
	line-height: 1.8;
}

.navbar {
	padding: 0;
}

.navbar-light {
	background: #fff;
	border-bottom: 2px solid #ccc;
}

.navbar-light .navbar-nav .active>.nav-link, .navbar-dark .navbar-nav .nav-link.active, .navbar-dark .navbar-nav .nav-link.show, .navbar-dark .navbar-nav .show>.nav-link {
	padding: 5px 25px;
}

.navbar-light .navbar-nav .nav-link {
	padding: 10px 25px;
	color: #000;
	text-decoration: none;
}

.navbar-light .navbar-nav .nav-link:hover {
	color: #ccc;
}

[lang=ja] h1, [lang=ja] h1 {
	font-size: 20px;
	font-weight: normal;
	line-height: 1.8;
	margin-bottom: 0;
  padding: 0 20px 20px 20px;
}

[lang=ja] h2, [lang=ja] h2 {
	font-size: 18px;
	line-height: 1.8;
	font-weight: normal;
	text-align: left;
}

[lang=ja] h3, [lang=ja] h3 {
	font-size: 24px;
	line-height: 1.8;
  font-weight: 500;
	text-align: left;
  background: #00459b;
  color: #fff;
  padding: 20px;
  text-decoration: underline;
}

[lang=ja] h4, [lang=ja] h4 {
	font-size: 20px;
	line-height: 1.8;
  font-weight: 500;
	text-align: left;
  background: #00459b;
  color: #fff;
  padding: 20px;
}

[lang=ja] .sec31 p {
	line-height: 1.9;
}

[lang=ja] .sec07 p {
	line-height: 1.4;
}

/* table */

.table td, .table th {
	vertical-align: middle;
}



/* margin class */

.mt5 {
	margin-top: 5px;
}

.mt10 {
	margin-top: 10px;
}

.mt20 {
	margin-top: 20px;
}

.mt30 {
	margin-top: 30px;
}

.mt40 {
	margin-top: 40px;
}

.mt50 {
	margin-top: 50px;
}

.mt60 {
	margin-top: 60px;
}

.mt70 {
	margin-top: 70px;
}

.mt80 {
	margin-top: 80px;
}

.mt90 {
	margin-top: 90px;
}

.mt100 {
	margin-top: 100px;
}


.mb10 {
	margin-bottom: 10px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb60 {
	margin-bottom: 60px;
}

.mb70 {
	margin-bottom: 70px;
}

.mb80 {
	margin-bottom: 80px;
}

.mb90 {
	margin-bottom: 90px;
}

.mb100 {
	margin-bottom: 100px;
}

/* padding class */

.pad10 {
	padding: 10px;
}

.pad15 {
	padding: 15px;
}

.pad20 {
	padding: 20px;
}

.pt5 {
	padding-top: 5px;
}

.pt10 {
	padding-top: 10px;
}

.pt15 {
	padding-top: 15px;
}

.pt20 {
	padding-top: 20px;
}

.pt30 {
	padding-top: 30px;
}

.pt40 {
	padding-top: 40px;
}

.pt50 {
	padding-top: 50px;
}

.pt60 {
	padding-top: 60px;
}

.pt70 {
	padding-top: 70px;
}


.pb10 {
	padding-bottom: 10px;
}

.pb20 {
	padding-bottom: 20px;
}

.pb30 {
	padding-bottom: 30px;
}

.pb40 {
	padding-bottom: 40px;
}

.pb50 {
	padding-bottom: 50px;
}

/*  */

.balloon1 {
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 7px 10px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  background: #e0edff;
}

.balloon1:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #e0edff;
}

.balloon1 {
  margin: 0;
  padding: 0;
}


/* background class */

.bg00 {
	padding-top: 20px;
}

.bg01 {
	background: #ededed;
}

.bg02 {
	background: #2a81f0;
}


.fixed-bg {
  min-height: 100vh;
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
}

.bg03 {
	background-image: url(../img/index/sec04.jpg);
}


/*animation調整 cms調整(index.html)
------------------------- */
.anime01 {
	-webkit-transition: .5s ease-in-out;
}

.anime01:hover{
    -webkit-border-top-left-radius: 50%;
    -webkit-border-top-right-radius: 50%;
    -moz-border-radius-topleft: 50%;
    -moz-border-radius-topright: 50%;
    -webkit-border-bottom-right-radius: 50%;
    -webkit-border-bottom-left-radius: 50%;
    -moz-border-radius-bottomright: 50%;
    -moz-border-radius-bottomleft: 50%;
}

/* main contents css*/

p {
	line-height: 1.7;
}

.sec01 {
	color: #fff;
	border-bottom: 6px solid #fdd701;
}

.sec02 {
	font-size: 20px;
	font-weight: 700;
	border-bottom: 2px solid #000;
	line-height: 1.7;
}

.sec03 {
	font-size: 17px;
	line-height: 1.5;
}

.sec03 span {
	color: #2a81f0;
	font-size: 22px;
}

.sec04 {
	color: #fff;
	border-left: 5px solid #fff;
	padding-left: 10px;
	font-size: 20px;
}

.sec04 a{
	color: #fff;
	font-size: 14px;
}

.sec04a {
	color: #fff;
	border-left: 5px solid #ff0000;
	padding-left: 10px;
	font-size: 20px;
}

.sec04b {
	color: #fff;
	padding-left: 10px;
  font-weight: 700;
	font-size: 20px;
  text-decoration: underline;
}

.sec05 {
	border: 2px solid #ffd800;
	padding: 15px;
	font-size: 18px;
}

.sec06 {
	border-bottom: 0.5px solid #000;
	margin-bottom: 10px;
}

.sec07 {
	background: #c8c8c8;
	padding-top: 10px;
	padding-bottom: 10px;
}

.sec08 {
	background: #fff;
	opacity: 0.9;
	padding: 20px;
	font-size: 20px;
}

.sec08a {
	background: #fff;
	padding: 20px;
	font-size: 20px;
}

.sec08b {
	background: #fff;
	font-size: 20px;
}

.sec09 {
	background: #005598;
	padding: 10px 20px;
	color: #fff;
}

.sec10 {
	font-size: 20px;
	line-height: 2.4;
	font-weight: 600;
	letter-spacing: 3px;
}

.sec10 span {
	border-bottom: 2px solid #ff0000;
}

.sec11 {
	border-bottom: 1px solid #ccc;
}

.sec12 {
	font-size: 18px;
	border-left: 6px solid #000;
}

.sec13 {
	font-size: 18px;
}

.sec14 {
	font-size: 20px;
	font-weight: 600;
	border-bottom: 2px solid #ff0000;
}

.sec14a {
	font-size: 18px;
	font-weight: 600;
}

.sec15 {
	font-size: 18px;
	border-bottom: 2px solid #000;
}

.sec16 {
	border-left: 5px solid #000;
	padding-left: 10px;
  font-size: 12px;
}

.sec16a {
	border-left: 5px solid #fdd701;
	padding-left: 10px;
  font-size: 16px;
}

.sec17 th{
	border: none;
	width: 30%;
}

.sec17 td{
	border: none;
}

.sec18 {
	text-align: left;
	height: 150px;
	overflow: auto;
	border: 1px solid #ccc;
	padding: 20px;
	font-size: 14px;
}

.sec19 {
	font-size: 12px;
	text-align: left;
  padding: 10px;
}

.sec20 {
	line-height: 1.8;
}

.sec21 {
	border-bottom: 1px solid #000;
}

.sec22 {
  font-size: 12px;
  padding-left: 15px;
}

.sec23 {
  background: #ffd800;
  border-radius: 6px;
  text-align: center;font-weight: 700;
}

.sec24 {
  text-align: center;
}

.sec25 {
  background: #fef49c;
  padding: 10px;
  font-size: 10px;
  text-align: left;
}

.sec26 {
  border: 2px solid #ccc;
  text-align: left;
  padding: 15px;
}

.sec27 {
  background: #fff;
  padding: 10px;
  font-size: 20px;
}

.sec28 {
  color: #fff;
  line-height: 2.0;
}

.sec29 {
  background: #ffd800;
  padding: 10px 20px;
}

.sec30 {
	font-size: 20px;
	padding: 20px;
  background: #fdd701;
}

.sec31 {
  font-size: 20px;
}

.sec32 {
  padding: 0 20px;
  border-bottom: 2px solid #2a81f0;
  padding-bottom: 10px;
}

.sec33 {
  background: #2a81f0;
  color: #fff;
}

.sec34 {
  font-size: 20px;
}

.sec35 a{
    text-decoration: underline;
    color: #2a81f0;
}

.sec36 {
  border: 2px solid #f00;
  font-size: 14px;
  padding: 0 10px;
  color: #f00;
  font-weight: 700;
  margin-right: 10px;
}

.sec37 {
  background: #00459b;
  border-radius: 6px;
  border: 5px solid #ffd800;
  padding: 10px;
  text-align: center;
  font-size: 24px;
  letter-spacing: 2px;
  color: #fff;
  margin-top: 10px;
}

.sec37:hover {
  opacity: 0.8;
}

.sec38 {
  font-size: 14px;
}

.sec39 {
  text-align: center;
  font-size: 20px;
  color: #00459b;
  font-weight: 700;
  background: #fff;
  padding-top: 10px;
  padding-bottom: 10px;
}

[lang=ja] h2, [lang=ja] h2.sec39 {
  text-align: center;
  font-size: 20px;
  color: #00459b;
  font-weight: 700;
  background: #fff;
  padding-top: 10px;
  padding-bottom: 10px;
}

.sec40 {
  font-size: 16px;
  line-height: 2.0;
}

.sec40 a  {
  text-decoration: underline;
  color: #0551b0;
}

.sec40 span{
  font-weight: 700;
}

.sec41 {
  text-align: left;
  font-size: 20px;
  font-weight: 700;
  background: #ffd800;
  display: inline-block;
  padding: 20px 40px;
  text-decoration: underline;
  height: 220px;
}

.sec42 {
  text-align: left;
  font-size: 20px;
  font-weight: 700;
  background: #ffd800;
  padding: 20px 40px;
  text-decoration: underline;
}



/* dl */
dl {
  line-height: 1.4;
  margin-top: 5px;
}


/* card */

.card-body {
	line-height: 1.8;
	padding: 10px 35px;
	font-size: 18px;
}

.card-header {
	padding: 10px 15px;
}



/* carousel side flat image */
.carousel-item .img-fluid {
  width:100%;
  height:auto;
}

.carousel-item{
  height: auto;
}

/* carousel Vertical horizontal res image
.carousel-item a {
  display: block;
  width:100%;
}

.carousel-item .show-image {
  display: block;
  width:100%;
}
*/

/* bx slider */

div.slider {
    width:620px;
    display:block;
    margin:0 auto;
}

ul.bxslider01 li {/*メインスライダー*/
    display:block;
    width:620px;
    height:400px;
}

ul.bxslider01 li img{
    display:block;
    width:620px;
    height:auto;
}

ul.bxslider02 li a {/*サムネイル*/
    display:block;
    width:100px;
    height:60px;
}

ul.bxslider02 li a img{/*サムネイルの画像*/
    display:block;
    width:100px;
    height:auto;
}

div.controlWrap {
    width:620px;
    display:block;
    position:relative;
    margin:0 auto;
}

div.controlWrap p#PrevIcon a{/*矢印画像（前へ）*/
    display:block;
    width:13px;
    height:19px;
    position:absolute;
    background: url(../img/btn_prev.png) left center no-repeat;
    color:#fff;
    top:20px;
    left:20px;
    text-indent:-9999px;
}

div.controlWrap p#NextIcon a{/*矢印画像（次へ）*/
    display:block;
    width:13px;
    height:19px;
    position:absolute;
    background: url(../img/btn_next.png) left center no-repeat;
    color:#fff;
    top:20px;
    right:20px;
    text-indent:-9999px;
}


.img-square{
	overflow: hidden;
	height: 255px;
}

.btn01 {
	padding: 25px 20px;
	font-weight: 500;
	border-radius: 3px;
	border: 1px solid #717171;
	background: #fff;
}

.btn01:hover {
	padding: 35px 35px;
	transition: 1s;
	border-radius: 30px;
	background: #888888;
	color: #fff;
}


/* google map res */

.maps {
  margin: 0 auto;
  position: relative;
  width: 100%;
  padding-top: 30.25%;
}

.maps iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

.maps2 {
  margin: 0 auto;
  position: relative;
  width: 100%;
  padding-top: 35.25%;
}

.maps2 iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

/* 分割指定 */

.col-xs-1-5, .col-sm-1-5, .col-md-1-5, .col-lg-1-5,
.col-xs-2-5, .col-sm-2-5, .col-md-2-5, .col-lg-2-5,
.col-xs-3-5, .col-sm-3-5, .col-md-3-5, .col-lg-3-5,
.col-xs-4-5, .col-sm-4-5, .col-md-4-5, .col-lg-4-5 {
    position: relative;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px;
}
/* スマホ（767px以下） */
.col-xs-1-5 {width: 19.9%;float: left;}
.col-xs-2-5 {width: 38,8%;float: left;}
.col-xs-3-5 {width: 59.9%;float: left;}
.col-xs-4-5 {width: 79.9%;float: left;}
/* タブレット（768px～991px） */
@media (min-width: 768px) {
    .col-sm-1-5 {width: 19.9%;float: left;}
    .col-sm-2-5 {width: 39.9%;float: left;}
    .col-sm-3-5 {width: 59.9%;float: left;}
    .col-sm-4-5 {width: 79.9%;float: left;}
}
/* PC（992px～1119px） */
@media (min-width: 992px) {
    .col-md-1-5 {width: 19.9%;float: left;}
    .col-md-2-5 {width: 39.9%;float: left;}
    .col-md-3-5 {width: 59.9%;float: left;}
    .col-md-4-5 {width: 79.9%;float: left;}
}
/* PC大画面（1200px以上）*/
@media (min-width: 1200px) {
    .col-lg-1-5 {width: 19.9%;float: left;}
    .col-lg-2-5 {width: 39.9%;float: left;}
    .col-lg-3-5 {width: 59.9%;float: left;}
    .col-lg-4-5 {width: 79.9%;float: left;}
}



/* ページトップ */
#page-top {
    position: fixed;
    top: 245px;
}
#page-top a {
    text-decoration: none;
}
#page-top a:hover {
    opacity: 0.8;
}

#page-top2 {
    position: fixed;
    top: 375px;
}
#page-top2 a {
    text-decoration: none;
}
#page-top2 a:hover {
    opacity: 0.8;
}

#page-top3 {
    position: fixed;
    top: 508px;
}
#page-top3 a {
    text-decoration: none;
}
#page-top3 a:hover {
    opacity: 0.8;
}


/* naname */

.contents {
  position: relative;
  overflow: hidden;
	/*
  margin: 10% 0;
	*/
  padding: 80px 0;
}

.contents:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 120%;
  height: 80%;
  margin: 8% -10% 0;
  background: #6e6e6e;
  -webkit-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: rotate(-3deg);
  -ms-transform: rotate(-3deg);
  transform: rotate(-3deg);
  z-index: -1;
}

.contents_inner {
  box-sizing: boder-box;
  width: 100%;
  max-width: auto;
  height: 100%;
  margin: 0 auto;
  padding: 100px 0px;
  color: #000;
  text-align: center;
}

/* naname */

.contents2 {
  position: relative;
  overflow: hidden;
	/*
  margin: 10% 0;
	*/
  padding: 80px 0;
}

.contents2:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 120%;
  height: 80%;
  margin: 8% -10% 0;
  background: #e6e6e6;
  -webkit-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: rotate(-3deg);
  -ms-transform: rotate(-3deg);
  transform: rotate(-3deg);
  z-index: -1;
}

.contents_inner2 {
  box-sizing: boder-box;
  width: 100%;
  max-width: auto;
  height: 100%;
  margin: 0 auto;
  padding: 100px 0px;
  color: #000;
  text-align: center;
}

/*back*/

#page_top{
  width: 90px;
  height: 90px;
  position: fixed;
  right: 0;
  bottom: 0;
  opacity: 0.6;
}
#page_top a{
  position: relative;
  display: block;
  width: 90px;
  height: 90px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 25px;
  color: #fdd701;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -40px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
#page_top a::after{
  content: 'PAGE TOP';
  font-size: 13px;
  color: #fff;
  position: absolute;
  top: 45px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
  color: #000;
}

/* animationa */

.img-animation {
  animation: img-opacity 3s cubic-bezier(.4, 0, .2, 1);
  overflow: hidden;
  position: relative;
}

.img-animation:before {
  animation: img-animation 2s cubic-bezier(.4, 0, .2, 1) forwards;
  background: #fff;
  bottom: 0;
  content: '';
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}

@keyframes img-opacity {
  0% {
    opacity: 0;
  }
}

@keyframes img-animation {
  100% {
    transform: translateX(100%);
  }
}
