/* ------------------------------------------------------------- */
/* layout / parts                                                */
/* ------------------------------------------------------------- */
html {
  overflow-x: hidden !important;
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

body {
  font-size: 16px;
  font-weight: 400;
  color: #000;
  line-height: 2;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.03em;
  line-height: 1.5;
  outline: none;
  overflow-x: hidden;
  background-color: #e4e6e9;
}

input,
textarea {
  font-family: 'Zen Kaku Gothic Antique', sans-serif;
  font-size: 16px;
}

.inner {
  width: 1200px;
  margin: 0 auto;
}

.lower-mv .inner {
  position: relative;
  z-index: 10;
}

@media (max-width: 1472px) {
  .inner {
    width: 90%;
  }
}

.sec-padding {
  padding: 115px 0;
}

.serif {
  font-family: 'Noto Serif JP', serif;
}

.minion {
  font-family: minion-pro, serif;
  font-style: normal;
  font-weight: 400;
}

.m-center {
  display: block;
  margin: 0 auto;
}

.bold {
  font-weight: 700;
}

.u-border {
  border-bottom: solid 1px #fff;
  padding-bottom: 1rem;
}

@media (max-width: 1472px) {
  .u-border {
    padding-bottom: .3rem;
  }
}

.reverse {
  flex-direction: row-reverse;
}


/*-----------------画像--------------------*/
img.fit-cover {
  object-fit: cover;
  font-family:"object-fit:cover;"
}

img.fit-contain {
  object-fit: contain;
  font-family:"object-fit:contain;"
}

figure img {
  width: 100%;
}

img {
  vertical-align: top;
}

/*-----------------flex--------------------*/
.flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.flex.nowrap {
  flex-wrap: nowrap;
}

.flex.right {
  justify-content: end;
}

.flex.center {
  justify-content: center;
}

.flex.left {
  justify-content: flex-start;
}

.flex.vertical {
  flex-direction: column;
  align-items: flex-start;
}

.flex.al-center {
  align-items: center;
}

.flex.al-top {
  align-items: flex-start;
}

.flex.al-bottom {
  align-items: flex-end;
}

.v-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

/*-----------------Link--------------------*/
a {
  text-decoration: none;
  transition: all .3s ease;
}

section li>a {
  display: block;
}

a {
  color: inherit;
}

a:hover {
  opacity: 0.7;
}

/*----------------text---------------------*/
.txt-c {
  text-align: center;
}

.txt-l {
  text-align: left;
}

.txt-r {
  text-align: right;
}

.red {
  color: #E72420;
}


@media (max-width: 768px) {

  /* ------------------------------------------------------------- */
  /* layout / parts                                                */
  /* ------------------------------------------------------------- */
  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }

  a:hover {
    opacity: 1;
  }

  .btn {
    width: 90%;
  }

  .reverse {
    flex-wrap: wrap;
  }
}

.button {
	position: fixed;
	right: 30px;
	bottom: 30px;
	opacity: 0;
	cursor: pointer;
	transition: .3s;
	color: #FFF;
	background: #091d2d;
	border: 1px solid #FFF;
	border-radius: 5px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50px;
	height: 50px;
	z-index: -2;
}
.button.active{
  opacity: 1;
  z-index: 50;
  visibility: visible;
}
.button:hover {
	opacity: 0.8;
}

.txtlink {
  text-decoration: underline;
  transition: .3s;
}
.txtlink:hover {
  text-decoration: none;
}

.rb_bnr {
  position: fixed;
  right: 30px;
  bottom: 90px;
  z-index: 100;
  background: #FFF;
}
.rb_bnr .rb_bnr_inner {
  position: relative;
}
.rb_bnr .rb_bnr_inner #closebanner {
  position: absolute;
  right: -10px;
  top: -10px;
  color: #FFF;
  border-radius: 9999px;
  background: #db3216;
  z-index: 111;
  width: 25px;
  height: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1;
}
@media all and (max-width: 768px) {
  .rb_bnr {
    display: none;
  }
}

.child_menu {
  cursor: auto;
}

.tp-sec-new__wrap img {
  max-width: 100%
}

