@charset "UTF-8";

/* ヒーローエリア（ローディング画面） */
#loading {
  position: fixed;
  top: 0; 
  left: 0; 
  width: 100%; 
  height: 100%; 
  background: #fff; 
  display: flex; 
  flex-direction: column; 
  justify-content: center; 
  align-items: center; 
  transition: all 0.3s; 
  z-index: 200;
}

#loading img {
	display: block;
}

.loaded {
	opacity: 0;
	visibility: hidden;
}

/* コンテンツ */

.ttl_entry {
	background: #e67e22;
}

.ttl_entry h2 {
	text-align: left;
	font-family: Noto Serif JP,serif;
	color: #FFF;
	max-width: 1050px;
	margin: 0 auto;
	padding: 15px;
}

.entry {
	padding: 40px 30px;
}

.entry .container {
	max-width: 1050px;
	margin: 0 auto;
}

.flow {
  width: 100%; /* ステップフロー全体の横幅を指定 */
  display: flex;            /* flexboxで横並びにする */
  justify-content: space-between; /* 横並びにしたものを等間隔で並べる */
  margin-bottom: 40px;
}

.flow li {
  color: #000;        /* 文字色を黒に指定 */
  font-size: 14px;    /* 文字サイズを指定 */
  width: calc(100% / 3); /* 横幅を三等分した1つの大きさに指定 */
  background: #e5e5e5;   /* 背景色をグレーに指定 */
  line-height: 50px;  /* 行間(高さの代わり)を指定 */
  text-align: center; /* 文字を中央寄せにする */
  position: relative; /* 基準位置とする */
}

.flow li:not(:first-child):not(:last-child) { 
  padding: 0 0 0 10px;  /* 最初と最後以外には左に適度な余白を指定 */
}

.flow li::before,
.flow li::after {
  content: "";  /* 疑似要素では必須 */
  width: 0;     /* 横幅を0に指定 */
  height: 0;　　/* 高さを0に指定 */
  display: block;  /* ブロック要素にする */
  position: absolute; /* 相対位置に指定 */
}

.flow li::before {
  border: solid 32px transparent;     /* 32pxのborderを指定 */
  border-right: solid 13px transparent;  /* 幅を合わせるため右線は13pxにする */
  border-left: solid 13px #FFF;          /* 白い三角形を作成して▷の形で上に重ねて削り取る */
  top: -7px;  /* 重ねる位置(縦軸)を調整 */
  left: 0;    /* 重ねる位置(横軸)を調整 */
  z-index: 1; /* 重なり順を指定 */
}

.flow li::after {
  border: solid 25px transparent;  /* 25pxのborderを指定 */
  border-left: solid 10px #E5E5E5; /* 左のborderで背景色と同じ矢印の部分を作成する */
  border-right: solid 10px transparent; /* 幅を合わせるために右線は10pxにする */
  top: 0;       /* 重ねる位置(縦軸)を調整 */
  right: -20px; /* 重ねる位置(横軸)を調整 */
  z-index: 2;   /* 重なり順の優先度を他よりも上げる */
}

.flow li:first-child::before,
.flow li:last-child::after {
  content: none;  /* 最初のliの左と最後のliの右は作らない */
}

.flow li.current {
  color: #FFF;
  background: #e67e22;
}

.flow li.current::after {
  border-left: solid 10px #e67e22;
}

.entry .container h3 {
	border-left: 6px solid #e67e22;
	font-size: 16px;
	font-weight: normal;
	padding-left: 10px;
	margin-bottom: 20px;
}

.entry .container dl {
	margin-bottom: 20px;
	color: #000;
}

.entry .container dl dt {
	padding: 15px;
	background: #e5e5e5;
	margin: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.entry .container dl dt span {
	display: block;
}

.entry .container dl dt span.req {
	background: #e67e22;
	color: #FFF;
	padding: 3px 6px;
}

.entry .container dl dd {
	padding: 15px;
	background: #eee;
	margin: 0;
}

.entry .container dl.pri dt,
.entry .container dl.pri dd {
	background: #facd89;
}

.entry .container dl dd input.text,
.entry .container dl dd textarea {
	font-size: 16px;
	background: #fff;
	border: 1px solid #b6b6b6;
	width: 100%;
}

.entry .container dl dd textarea {
	height: 100px;
}

.entry .container div.privacy {
	padding: 20px;
	background: #eee;
	margin-bottom: 40px;
}

.entry .container div.privacy p {
	color: #000;
	margin: 0;
	padding: 0;
}

.entry .container p.last {
	color: #000;
	margin-bottom: 60px;
	padding: 0;
}

.entry .container .btn {
	display: flex;
	justify-content: center;
}

.entry .container input.submit-btn {
	background: #e67e22;
	color: #fff;
	font-size: 16px;
	border: none;
	border-radius: 6px;
	padding: 10px 60px;
	cursor: pointer;
}

img.image_add {
	display: block;
	width: 100%;
	max-width: 194px;
	height: auto;
	margin-top: 1em;
}

/* 大きい画面用の設定 */
@media(min-width:1050px) {
	.entry {
	padding: 60px 0px;
	}
	.entry .container dl {
	display: flex;
	}
	.entry .container dl dt {
	flex: 0 0 300px;
	}
	.entry .container dl dd {
	flex: 1;
	}
}