@charset "UTF-8";
/*----------------------------------------
Reset  Default Styles
----------------------------------------*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  font-size: inherit;
  vertical-align: baseline;
}

i, em {
  font-style: normal;
}

small {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

body {
  line-height: 1;
}

main, article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ul, li {
  list-style: none;
}

th, td {
  vertical-align: middle;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  color: inherit;
  text-decoration: none;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

ul, dl, ol {
  text-indent: 0;
}

li {
  list-style: none;
}

img {
  border: 0;
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #282828;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

button,
input {
  line-height: normal;
}

input,
textarea {
  background-image: -webkit-linear-gradient(hsla(0deg, 0%, 100%, 0), hsla(0deg, 0%, 100%, 0)); /* Removing the inner shadow, rounded corners on iOS inputs */
  padding: 4px 8px;
  border: 1px solid #282828;
  background: #fff;
}

button,
input[type=button],
input[type=reset],
input[type=submit] {
  cursor: pointer;
  -webkit-appearance: button;
}

em, i {
  font-style: normal;
}

* {
  box-sizing: border-box;
}

html {
  word-wrap: break-word;
  font-size: 62.5%;
  margin: 0;
  padding: 0;
}

body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  position: relative;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.7;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: 800;
  -webkit-text-size-adjust: 100%;
  min-width:1000px;
}


@media only screen and (max-width: 768px) {
	body {
		min-width:auto;
	}
}

a {
	color:#0b308e;
  transition: filter 0.3s ease;
}
a:hover {
  filter: brightness(120%);
}
@media only screen and (max-width: 768px) {
  a:hover {
    filter: none;
  }
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  transition: filter 0.3s ease;
}
button:hover {
  filter: brightness(120%);
}
@media only screen and (max-width: 768px) {
  button:hover {
    filter: none;
  }
}
button:active, button:focus, button:visited {
  color: #000;
}

button,
a,
img {
  outline: none;
}

/*------------------------------------------------------
  contents
------------------------------------------------------*/

.sp {display:none;}

@media only screen and (max-width: 768px) {
  .pc {display:none;}
  .sp {display:block;}
}

body {
  position: relative;
  width: 100%;
  line-break: strict;
}

.wrapper {
  width: 100%;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  font-weight: 500;
  -webkit-text-size-adjust: 100%;
  font-feature-settings: "palt";
  background-color: #fff;
}


.header {
  position: relative;
  text-align: center;
}

.bankName {
  position: relative;
  z-index: 1;
  padding: 20px 0;
  text-align: center;
  background-color: #fff;
}
.bankName img {
  width: auto;
  height: 40px;
  vertical-align: middle;
}
@media only screen and (max-width: 768px) {
  .bankName {
    padding: 10px 0;
  }
}

.mainImage {
  position: relative;
  width:100%;
  height:450px;
  margin: auto;
  background-image: url(../images/main_back.jpg);
  background-repeat: no-repeat;
  background-position:center bottom;
  background-size: cover;
}
.mainImage__inner {
  max-width:1200px;
  width:100%;
  margin:0 auto;
  position: relative;
}

.mainImage__inner h1 {
	width: 500px;
	height:auto;
	padding-top:50px;
	float:left;
}

.catch {
	position: absolute;
	right: -130px;
	top: 50px;
}

	.catch img {
		width: 805px;
	}

.day {
	width: 805px;
	margin-top: 30px;
	/* float: right; */
	position: absolute;
	right: -30px;
	top: 300px;
}

	.day img {
		max-width:805px;
	}

@media only screen and (max-width: 1000px) {
	.catch {
		right: -100px;
	  }
	  .catch img {
		width: 700px;
	  }

}


@media only screen and (max-width: 768px) {

	.mainImage {
		height:650px;
		margin: 0 auto;
	  }

	.mainImage__inner h1 {
		min-width: auto;
		padding: 50px 0 0 0;
		float: none;
		margin: 0 auto;
		width:100%;
	}
	.mainImage__inner h1 img {
		max-width:100%;
		height:auto;
	}


	.catch {
		padding-top: 40px;
		min-width: auto;
		position: relative;
		margin-top: -60px;
		right: auto;
		top: auto;
	  }
	  .catch img {
		width: 60vw;
	  }

	.day {
		width: 100%;
		max-width: 540px;
		position: relative;
		bottom: -30px;
		left: 0;
		text-align: center;
		margin: 0 auto;
		margin-top: 0px;
		margin-top: -100px;
		padding-left: 20px;
		right: auto;
		top: auto;
	}

	.day img{
		max-width:100%;
		width:100%;
		height:auto;
		margin:0 auto;
	}
}

@media only screen and (max-width: 450px) {
	.mainImage {
		height:550px;
		margin: 0 auto;
	  }
}

.section__inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 30px 0 60px 0;
  position:relative;
}

@media only screen and (max-width: 768px) {
	.section__inner {
		padding-right:1em;
		padding-left:1em;
		padding-bottom:90px;
	}
}


	h2  {
		font-size: 3.0rem;
		position: relative;
		display: flex;
		justify-content: center;/*左右中央配置*/
		margin-bottom:1em;
		color: #d1ab6f;
	  }
	  h2::before {
		position: absolute;
		content: '';
		top: 100%;
		width: 10%;/*線の長さ*/
		height: 8px;/*線の太さ*/
		border-radius: 2px;/*線の角を丸くする*/
		background-color: #d1ab6f;/*線の色*/
		margin-right: 0;
	  }




/* h2:before, h2:after {
	content: "";
	flex-grow: 1;
	height: 2px;
	background: #444;
	display: block;
} */

h2:before {
	margin-right: .4em;
}

h2:after {
	margin-left: .4em;
}

/* .dark h2{
	color: #d1ab6f;
}

.dark > div > div{
	color: #FFF;
} */

table{
	color: #000;
}

.kikan {
	background:#f4ead2;
}

.big {
	font-size:2.2rem;
	font-weight:bold;
}

.tC {
	text-align:center;
}
@media only screen and (max-width: 400px) {
	.taisyo .tC,
	.tokuten .tC {
		text-align:left;
	}
}

.mT1em {
	margin-top:1em;
}

.fR {
	float:right;
}

.indent {
	margin-left:1.5em;
	text-indent:-1.5em;
}

.txt-s {
	font-size:1.4rem;
}

@media only screen and (max-width: 768px) {
	h2 {font-size:2.5rem;}
	.big {font-size:1.8rem;}
}

.taisyo {
	background:url(../images/back.png);
	position:relative;
}

	.taisyo .section__inner::after {
		width:130px;
		height:190px;
		background:url(../images/person1.png) no-repeat;
		content:"";
		position:absolute;
		bottom:0;
		right:0;
	}

@media only screen and (max-width: 768px) {
	.taisyo .section__inner::after {
		width:80px;
		height:100px;
		background:url(../images/person1.png) no-repeat;
		background-size:contain;
		content:"";
		position:absolute;
		bottom:0;
		right:0;
	}
}

.b-blue {
	background:#f4ead2;
}

.tokuten .mT1em {
	position:relative;
	width:700px;
	margin:1em auto;
}

	.tokuten .mT1em::after {
		content:"";
		width:210px;
		height:205px;
		position:absolute;
		left:-150px;
		bottom:-10px;
		background:url(../images/person2.png) no-repeat;
	}

@media only screen and (max-width: 768px) {
	.tokuten .mT1em {
		width:80%;
	}

	.tokuten .mT1em::after {
		content:"";
		width:100px;
		height:100px;
		position:absolute;
		left:-50px;
		bottom:-10px;
		background:url(../images/person2.png) no-repeat;
		background-size:contain;
	}
}


h3 {
	font-size:2.5rem;
	background:#d1ab6f;
	padding:0.2em;
	text-align:center;
	margin-bottom:1em;
}

	h3 span {
		background:#0b308e;
		color:white;
		padding:0 0.5em;
		margin-right:0.5em;
	}
@media only screen and (max-width: 400px) {
	h3 span {display:block; margin-right:0;}
}

.service img {
	max-width:250px;
	height:auto;
	/* margin-left:1em; */
	
}

dl {
	border:solid 5px #f7820d;
	overflow:hidden;
	display:flex;
	align-items: center;
	background:#f7820d;
}

	dt {
		padding:0.5em;
		width:210px;
		font-weight:bold;
		color:white;
		text-align:center;
		font-size:2.0rem;
		
	}
	
	dd {
		padding:0.5em;
		background:white;
		width: calc(100% - 210px);
		height:100%;
	}
	
	.disc li {
		list-style:disc;
		margin-left:1em;
	}

@media only screen and (max-width: 768px) {
	article .fR {margin-bottom:1em;}
	dl {clear:both;}
	h3 {font-size:2.2rem;}
}

@media only screen and (max-width: 400px) {
	article .fR {float:none; text-align:center;}
	article .fR img {margin:0 auto;}
	dl {display:block;}
	dt,dd {width:100%;}
}

article {
	margin-bottom:3em;
	overflow:hidden;
}

.link {
	font-size:1.4rem;
	margin-top:1em;
}

.box {
	border:solid 5px #f7820d;
}

h4 {
	background:#f7820d;
	color:white;
	padding: .2em;
	margin-bottom:0.5em;
}

	.flexbox_wap {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: flex;
		-webkit-flex-wrap: wrap; /* Safari */
		flex-wrap: wrap;
    	justify-content: flex-start;
    }

.service .flexbox_wap > li {
	width:50%;
	padding:1em;
}

.service .flexbox_wap.col-3 > li{
		width: 33%;
	}

.service .flexbox_wap.col-3 img{
		width: 100%;
		max-width: 250px;
	}


@media only screen and (max-width: 400px) {
	.service .flexbox_wap > li {
		width:100%;
	}
}


table{
	width: 100%;
	border-collapse: collapse;
	background:white;
}
table td,
table th{
	padding: 1em;
	vertical-align: middle;
	border: solid 1px #e1e1e1;
	line-height: 140%;
}
table th{
	background: #d1ab6f;
	font-weight: bold;
	color: black;
}
table table{
	text-align: center;
}
table table th{
	font-weight: normal;
	text-align: center;
}

table td {
	text-align:center;
}

table img {
	max-width:200px;
	margin:0 auto;
}


@media only screen and (max-width: 1024px) {

	.service .flexbox_wap.col-3 > li{
		width: 50%;
	}

}


@media only screen and (max-width: 768px) {
	table {
		margin-bottom:1em;
	}
	.service .flexbox_wap.col-3 > li{
		width: 100%;
	}

}
@media only screen and (max-width: 400px) {
	table img {
		max-width:100px;
	}
}

.attention {
	background:#eee;
}



.footer {
	background:#0b308e;
	color:white;
	text-align:center;
	padding:1em;
}


#page-top {
	position: fixed;
	bottom: 30px;
	right: 20px;
	font-weight: bold;
	font-size: 80%;
	z-index: 5;
	text-align: center;
}
@media all and (max-width: 768px) {
	#page-top {
		bottom: 20px;
		right: 10px;
	}
}
#page-top a {
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	background: rgba(12, 46, 147, 0.8);
	color: #fff;
	opacity: 0.7;
}
@media all and (max-width: 768px) {
	#page-top a {
		width: 40px;
		height: 40px;
	}
}
#page-top a:hover {
	opacity: 0.7;
}
#page-top a:active {
	opacity: 1;
}
#page-top a:after {
	position: absolute;
	right: 19px;
	top: 43%;
	display: block;
	content: "";
	width: 12px;
	height: 12px;
	border-top: 3px solid #FFF;
	border-right: 3px solid #FFF;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
@media all and (max-width: 768px) {
	#page-top a:after {
		right: 14px;
		top: 40%;
	}
}

.small{
	font-size: 90%;
}


.marker {
 
    background:linear-gradient(transparent 60%, #ff6 60%);
	color: #000;
 
}


@media only screen and (max-width: 500px) {
	.service .flexbox_wap li {
		width:100%;
	  }
}


#order {
	position:fixed;
	bottom:0;
	left:0;
	width:100%;
	height:80px;
	background-color: rgba(0, 0, 0, 0.6);
	text-align:center;
}
.order_contents {
	position:fixed;
	bottom:0;
	left:0;
	text-align:center;
	width:100%;
	height:60px;
}

#order a {
	background:#f7820d;
	color:white;
	font-size:2.0rem;
	padding:0.5em 4em;
	position:relative;
}

#order a:hover {
	opacity:0.8;
}


#order a::after {
	position: absolute;
	content: "";
	display: block;
	top: 50%;
	right: 23px;
	width: 11px;
	height: 23px;
	background-image: url(../images/icon_arrow_right.svg);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	transform: translateY(-50%);
  }
