@charset "UTF-8";
/*--------------------------------
キーカラー	：d0121b ea3546
黒			：241b15  271f1d
濃グレー	：726a68
中グレー	：bab7b6
薄グレー	：d4d2d2
白グレー	：fbf9f9
白			：fff
 --------------------------------*/
/* --------------------------------
 * base
 * -------------------------------- */
body {
  font-size: 1.8rem;
}
h1, h2, h3, h4, h5, h6 {
  font-size: 1.8rem;
}
/* --------------------------------
 * header
 * -------------------------------- */
#header {}
#header_pc {}
.head_rsv {
  padding-right: 0px !important;
}
.head_rsv a {
  background: url(../../img/btn_icon1.svg) no-repeat center bottom #ea3546;
  position: relative;
  top: -2.3rem;
  display: block;
  padding: 2.2rem;
}
.head_rsv a:link, .head_rsv a:visited, .head_rsv a:active {
  color: #FFF;
}
.head_rsv a:hover {
  opacity: 1;
  background: url(../../img/btn_icon1.svg) no-repeat right bottom #ea3546;
}

/* --------------------------------
 * nav
 * -------------------------------- */
nav {
}

.hmenu {}
/* -- スクロール後の上メニュー -- */
.header-area_pc {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
	max-height: 85px;
  margin-left: auto;
  margin-right: auto;
  padding: 0px 10px;
}
.nav_fixed .site-logo,
.nav_fixed .site-description {
	transform: translateY(-2rem);
	transition-duration: .3s;
}
.nav_fixed {
  position: fixed;
  top: 0;
  left: 0;
	height: calc(95px - 2rem);
	transition-duration: .3s;
  background: rgb(1, 202, 220);
  background: linear-gradient(180deg, rgba(1, 202, 220, 1) 0%, rgba(0, 36, 124, 1) 50%);
}
/* z-index */
#container {
  position: relative;
  z-index: 1;
}
#header {
  position: relative;
  z-index: 900;
}
#nav-toggle, .open #nav-toggle {
  z-index: 1000;
}
#global-nav {
  z-index: 990;
}
/* --------------------------------
 * parts
 * -------------------------------- */
.per10 {
  width: 10% !important;
}
.per20 {
  width: 20% !important;
}
.per30 {
  width: 30% !important;
}
.per40 {
  width: 40% !important;
}
.per50 {
  width: 50% !important;
}
.per60 {
  width: 60% !important;
}
.per70 {
  width: 70% !important;
}
.per80 {
  width: 80% !important;
}
.per90 {
  width: 90% !important;
}
.per100 {
  width: 100% !important;
  margin-bottom: 40px;
}
.row2 {
  width: 45% !important;
}
.row3 {
  width: 30% !important;
}
.row4 {
  width: 20% !important;
}
.row8 {
  width: 12.5% !important;
}
.margin_l {
  margin-left: 5%;
}
.margin_r {
  margin-right: 5%;
}
figure {
  font-size: 1.6rem;
  margin: 0 auto 4rem;
}
.alignL_PC {
  text-align: left !important;
}
.alignC_PC {
  text-align: center !important;
}
.alignR_PC {
  text-align: right !important;
}
.btn1 a, .btn2 a {
  min-width: 40rem;
}
.btn4 a {
  min-width: 40rem;
}
aside .btn1 a, aside .btn2 a, aside .btn4 a, aside .btn5 a {
  min-width: 100%;
  width: 100%;
}
/* --------------------------------
 * article
 * -------------------------------- */
article {
  position: relative;
  flex-basis: 75%;
  margin-right: 4%;
}
.page_title_area {
  background: #02020b url("../../img/page_title_back1.png") repeat-x center;
}
.page_title_area h2 {
  display: block;
  width: 100%;
  padding-right: 25vw;
  height: 285px;
  color: #FFF;
  font-size: 3.2rem;
  text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.95);
  font-weight: 500;
  text-align: left;
}
.page_title_area h2 span {
  display: block;
  position: relative;
  top: 50%;
  -webkit-transform: translateY(-50%); /* Safari用 */
  transform: translateY(-50%);
}
.article_cont {}
/* --------------------------------
 * aside
 * -------------------------------- */
aside {
  /*  position: sticky;
  position: -webkit-sticky;
  top: 100px;*/
  flex-basis: 21%;
  align-self: baseline;
}
/* --------------------------------
 * 強制系
 * -------------------------------- */
.margin_t0_PC {
  margin-top: 0 !important;
}
.margin_b0_PC {
  margin-bottom: 0 !important;
}
.margin_l0_PC {
  margin-left: 0 !important;
}
.margin_r0_PC {
  padding-right: 0 !important;
}
.padding_t0_PC {
  padding-top: 0 !important;
}
.padding_b0_PC {
  padding-bottom: 0 !important;
}
.padding_l0_PC {
  padding-left: 0 !important;
}
.padding_r0_PC {
  padding-right: 0 !important;
}
.display_no_PC {
  display: none !important;
}
.br-sp {
  display: none;
}
/* --------------------------------
 * PC-SP contents switch
 * -------------------------------- */
.pc_cont {
  display: inherit !important;
}
.sp_cont {
  display: none !important;
}