@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans&display=swap');
/*--------------------------------------------------------------------------------------------------

   common

--------------------------------------------------------------------------------------------------*/


/*reset-------------------------------------------------*/
*, *:before, *:after {
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 -o-box-sizing: border-box;
 -ms-box-sizing: border-box;
 box-sizing: border-box;
}

body,div,h1,h2,h3,h4,h5,h6,p,dl,dt,dd {
	margin: 0;
	padding: 0;
}

table {
 border-collapse: collapse;
	border-spacing: 0;
}

img {
	border: none;
	vertical-align: top;
 -webkit-backface-visibility: hidden;
}

h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
	font-weight: normal;
}

header,section,article,aside,footer,nav {
 display: block;
}

/*-------------------------------------------------reset*/

/*common-------------------------------------------------*/
body {
	margin: 0;
	padding: 0;
	color: #000000;
	font-size: 14px;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
	line-height: 1.6;
	overflow-x: hidden;
}

a:link {
	color: #CC1452;
}

a:visited {
	color: #000000;
}

a:hover, a:active {
	color: #CC1452;
}

.clear:after {
 content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.clear {
 display: inline-table;
 overflow: hidden;
}

/* mac \*/
* html .clear {
 height: 1%;
}
.clear {
 display: block;
}
/* macend */

.alignleft {
	float: left;
	margin: 0 40px 32px 0;
}

.alignright {
	float: right;
	margin: 0 0 32px 40px;
}

.aligncenter {
	display: block;
	margin: 0 auto;
}

.pc {
	display: block;
}

.sp {
	display: none;
}

.comp {
	color: #FF0000;
}

.mgnb20 {
	margin-bottom: 20px !important;
}

/*-------------------------------------------------common*/


/*------------------------------------------------------------------------------------------------
  header
--------------------------------------------------------------------------------------------------*/
#header {
	display: flex;
	justify-content: space-between;
	padding: 20px 30px;
}

#header h1,
#header p {
	font-size: 25px;
	font-weight: 700;
	line-height: 1.2;
}

#header h1 a,
#header p a {
	text-decoration: none;
	color: #142850;
}

#header h1 span,
#header p span {
	font-size: 15px;
	font-weight: 500;
	display: block;
}

#header h1 span:nth-child(2),
#header p span:nth-child(2) {
	display: inline-block;
	position: relative;
	top: -3px;
	margin-left: 10px;
	background: linear-gradient(to right, #fff100 0%,#fff766 50%);
	font-weight: 400;
	padding: 4px 16px;
	border-radius: 16px;
}

#header ul {
	margin: 3px 0 0;
	padding: 0;
	list-style: none;
	text-align: right;
	display: flex;
}

#header ul li {
	margin: 0 0 0 30px;
	padding: 0;
}

#header ul li:last-child {
	margin-left: 10px;
}

#header ul li a {
	text-decoration: none;
	color: #142850;
	font-size: 15px;
	display: block;
	padding: 9px 0;
}

#header ul li a:hover {
	font-weight: 500;
	color: #CC1452;
}

#header ul li.btn a {
	background: url(../image/arrow-01.png) #142850 no-repeat 90% center;
	color: #FFF;
	border: 2px solid #142850;
	border-radius: 32px;
 -webkit-transition: all .3s;
 -moz-transition: all .3s;
 -o-transition: all .3s;
 transition: all  .3s;
	padding: 8px 40px 8px 30px;
}

#header ul li.btn a:hover {
	background: url(../image/arrow-02.png) #FFF no-repeat 90% center;
	color: #142850;
}



/*------------------------------------------------------------------------------------------------
  footerMenu
--------------------------------------------------------------------------------------------------*/
#fmenu {
	position: relative;
	bottom: 0;
	padding: 60px;
	background-color: #F1F1F1;
}

#fmenu .wrap {
	width: 1060px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

#fmenu .wrap ul.text {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
}

#fmenu .wrap ul.text li {
	margin: 0 32px 0 0;
	padding: 0;
}

#fmenu .wrap ul.text li a {
	color: #142850;
	text-decoration: none;
	font-weight: 500;
	display: block;
	padding: 8px 0;
}

#fmenu .wrap ul.text li a:hover {
	color: #CC1452;
	font-weight: 500;
}

#fmenu .wrap ul.btn {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
}

#fmenu .wrap ul.btn li {
	margin: 0 0 0 30px;
	padding: 0;
}

#fmenu .wrap ul.btn li a {
	display: block;
	background: url(../image/arrow-02.png) #FFF no-repeat 90% center;
	color: #142850;
	text-decoration: none;
	border: 2px solid #142850;
	border-radius: 32px;
 -webkit-transition: all .3s;
 -moz-transition: all .3s;
 -o-transition: all .3s;
 transition: all  .3s;
	padding: 8px 40px 8px 30px;
	font-weight: 500;
}

#fmenu .wrap ul.btn li a:hover {
	background: url(../image/arrow-01.png) #142850 no-repeat 90% center;
	color: #FFF;
}


/*------------------------------------------------------------------------------------------------
  footer
--------------------------------------------------------------------------------------------------*/
#footer {
	background-color: #142850;
	padding: 30px 0;
}

#footer .wrap {
	width: 1060px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #FFF;
}

#footer .wrap .title {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.4;
}

#footer .wrap .title span {
	display: block;
	font-size: 14px;
	font-weight: 400;
}

#footer .wrap .copy {
 font-family: 'Josefin Sans', sans-serif;
}

#pagetop {
	position: fixed;
	bottom: 140px;
	right: 79px;
	z-index: 100;
}

/*------------------------------------------------------------------------------------------------
  common
--------------------------------------------------------------------------------------------------*/
.arrowbtn a {
	position: relative;
	display: block;
	width: 220px;
	border-bottom: 1px solid #828282;
	text-decoration: none;
	color: #000;
	padding: 16px 10px;
	font-size: 16px;
	font-weight: 500;
}

.arrowbtn a:before {
	position: absolute;
	top: calc( 50% - 4px);
	right: 16px;
	width: 40px;
 height: 8px;
	content: "";
 border-bottom: 1px solid #828282;
 border-right: 1px solid #828282;
 transform: skew(45deg);
	transition: all .3s;
}

.arrowbtn a:hover:before {
	right: 8px;
	border-color: #218FD2;
}

.arrowbtn2 a {
	position: relative;
	display: block;
	width: 220px;
	border-bottom: 1px solid #FFF;
	text-decoration: none;
	color: #FFF;
	margin: 20px auto 0;
	padding: 16px 10px;
	font-size: 16px;
	font-weight: 500;
	text-align: left;
}

.arrowbtn2 a:before {
	position: absolute;
	top: calc( 50% - 4px);
	right: 16px;
	width: 40px;
 height: 8px;
	content: "";
 border-bottom: 1px solid #FFF;
 border-right: 1px solid #FFF;
 transform: skew(45deg);
	transition: all .3s;
}

.arrowbtn2 a:hover:before {
	right: 8px;
	border-color: #FFF;
}

.arrowbtn3 a {
	position: relative;
	display: block;
	width: 480px;
	text-decoration: none;
	text-align: center;
	padding: 12px 8px;
	border: 2px solid #142850;
	line-height: 1.4;
	margin: 20px auto 60px;
	border-radius: 40px;
	color: #000;
}

.arrowbtn3 a:before {
	position: absolute;
	top: calc( 50% - 4px);
	right: 24px;
	width: 40px;
 height: 8px;
	content: "";
 border-bottom: 1px solid #828282;
 border-right: 1px solid #828282;
 transform: skew(45deg);
	transition: all .3s;
}

.arrowbtn3 a:hover {
	background-color: #142850;
	color: #FFF;
}

.arrowbtn3 a:hover:before {
	right: 16px;
	border-color: #FFF;
}


/*------------------------------------------------------------------------------------------------
  second
--------------------------------------------------------------------------------------------------*/
#second {
}

#second .pagettl {
	position: relative;
	height: 320px;
}

#second .pagettl:before {
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	width: 30%;
	height: 320px;
 animation: slide-skew 1s;
	background: url(../image/back-07.png) no-repeat 100% 0;
	background-size: cover;
	z-index: -1;
	overflow: hidden;
}
 
@keyframes slide-skew {
  0% {
    transform: translate(180px,30px);
    opacity: 0;
  }
		40% {
    transform: translate(180px,30px);
    opacity: 0;
  }
  100% {
    transform: translate(0,0);
    opacity: 1;
  }
}

#second .pagettl .wrap {
	position: relative;
	height: 320px;
	display: flex;
	align-items: center;
}

#second .pagettl .wrap h1 {
	width: 1200px;
	margin: 0 auto;
	padding: 0 0 0 30px;
	font-size: 40px;
	font-weight: 700;
	animation: slide-ttl 2s;
	color: #142850;
	text-shadow: 1px 1px 1px #fff, 1px -1px 1px #fff, -1px 1px 1px #fff, -1px -1px 1px #fff, 3px 3px 10px #fff, -3px -3px 10px #fff;
}

@keyframes slide-ttl {
  0% {
    opacity: 0;
				transform: translateX(-80px);
  }
  60% {
    opacity: 0;
				transform: translateX(-80px);
  }
  100% {
    opacity: 1;
				transform: translateX(0);
  }
}


#second .pagettl .wrap h1 span {
	font-size: 26px;
	display: block;	
}

#second .pan {
	position: relative;
	text-align: right;
	z-index: 10;
	background-color: #FFF;
}

@keyframes btmtoup {
  0% {
    opacity: 0;
				transform: translateY(40px);
  }
  70% {
    opacity: 0;
				transform: translateY(40px);
  }
  100% {
    opacity: 1;
				transform: translateY(0);
  }		
}

#second .pan ul {
	display: inline-block;
	justify-content: flex-end;
	background-color: #142850;
	color: #FFF;
	margin: -16px 0 0;
	padding: 16px;
	list-style: none;
	animation: btmtoup 3s;
}

#second .pan ul li {
	display: inline;
}

#second .pan ul li a {
	color: #FFF;
	text-decoration: none;
}

#second .pan ul li a:hover {
	text-decoration: underline;
}

#second .content {
	width: 1060px;
	margin: 0 auto;
	padding: 100px 0 40px;
	animation: btmtoup 3s;
	font-size: 16px;
	line-height: 1.8;
}

#second .content h2 {
	position: relative;
	background-color: #3DAEE2;
 font-size: 24px;
 font-weight: 500;
	color: #FFF;
	padding: 4px 8px;
	margin: 0 0 20px;
}

#second .content h2::before {
	position: absolute;
	content: "";
	top: 0;
	left: -34px;
 border-top: 51px solid transparent;
 border-right: 34px solid #3DAEE2;
}

#second .content h2::after {
	position: absolute;
	content: "";
	top: 0;
	right: -34px;
 border-bottom: 51px solid transparent;
 border-left: 34px solid #3DAEE2;
}

#second .content h3 {
  position: relative;
  margin: 0 0 16px;
  padding: 6px 16px 14px 16px;
  font-size: 22px;
  font-weight: 500;
  background-color: #F3F2F1;
}

#second .content h3:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #3DAEE2, #3DAEE2 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #3DAEE2, #3DAEE2 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

#second .content p {
	margin: 0 0 64px;
}

#second .content ul {
	margin-right: 20px;
}

#second .content ul li {
	margin-bottom: 12px;
	line-height: 1.6;
}


