/* --------------------------------------------------------------------------
 top banner
-------------------------------------------------------------------------- */



#container.banner {
	border-bottom: solid 1px #e1e1e1;
	box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-webkit-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-ms-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	background: #f6f6f6;
	height: 278px;
}

.topbnr {
	position: relative;
	width: 1024px;
	height: 258px;
	margin: 0 auto;
	padding: 20px 0 0;
	box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-webkit-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	-ms-box-shadow: inset 0 3px 3px -2px rgba(0, 0, 0, 0.2);
	background: url(/pc/assets/img/main_top_2411.jpg) bottom right no-repeat;
	background-size: contain;
	display: flex;
	justify-content: space-between;
}

.topbnr p.tag {
	display: inline-block;
	background: #0050aa;
	color: #ffffff;
	border-radius: 18px;
	-webkit-border-radius: 18px;
	-moz-border-radius: 18px;
	-ms-border-radius: 18px;
	margin: 20px 0 24px 65px;
	padding: 4px 28px 2px;
	font-size: 18px;
}

.topbnr h1 {
	display: inline-block;
	box-shadow: inset 0 -10px 0 0 #ffdf75;
	-webkit-box-shadow: inset 0 -10px 0 0 #ffdf75;
	-moz-box-shadow: inset 0 -10px 0 0 #ffdf75;
	-ms-box-shadow: inset 0 -10px 0 0 #ffdf75;
	margin: 0 0 15px 65px;
	line-height: 1.0em;
	letter-spacing: -0.02em;
}

.topbnr .etc {
	display: inline-block;
	color: #0050aa;
	font-size: 23px;
	margin: 0 0 10px;
}

.topbnr__right {
	position: absolute;
	right: 40px;
	top: 225px;
}

/* --------------------------------------------------------------------------
 province
-------------------------------------------------------------------------- */

h2.prov {
	display: inline-block;
	padding: 33px 33px 4px;
	border-bottom: dotted 2px #0050aa;
	border-left: none;
	margin: 0 0 32px;
	color: #0050aa;
	font-size: 19px;
}

ul#prov {
	width: 1024px;
	margin: 0 auto 39px;
}

ul#prov li {
	float: left;
	width: 185px;
	background: #0050aa;
	border-bottom: solid 3px #d9d9d9;
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	-ms-border-radius: 6px;
	margin-left: 17px;
	padding: 3px;
	text-align: center;
}

ul#prov li:first-child {
	margin: 0;
}

ul#prov li .title {
	color: #ffffff;
	border-radius: 3px 3px 0 0;
	-webkit-border-radius: 3px 3px 0 0;
	-moz-border-radius: 3px 3px 0 0;
	-ms-border-radius: 3px 3px 0 0;
	padding: 9px 0 11px;
}

ul#prov li .title span {
	font-size: 18px;
}

ul#prov li .items {
	background: #ffffff;
	color: #0050aa;
	border-radius: 0 0 4px 4px;
	-webkit-border-radius: 0 0 4px 4px;
	-moz-border-radius: 0 0 4px 4px;
	-ms-border-radius: 0 0 4px 4px;
	padding: 21px 0 5px;
}

ul#prov li .items h3 {
	display: inline-block;
	box-shadow: inset 0 -6px 0 0 #ffdf75;
	-webkit-box-shadow: inset 0 -6px 0 0 #ffdf75;
	-moz-box-shadow: inset 0 -6px 0 0 #ffdf75;
	-ms-box-shadow: inset 0 -6px 0 0 #ffdf75;
	margin: 0 0 6px;
	font-size: 19px;
	line-height: 1.1em;
}

#promise {
	width: 950px;
	border: solid 5px #e2efff;
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	padding: 32px;
	margin: 0 0 39px;
	text-align: left;
}

#promise .title {
	font-size: 18px;
	color: #0050aa;
	font-weight: 600;
}

#promise dt {
	margin: 20px 0 0;
}

#promise dd {
	font-size: 19px;
	margin: -38px 0 0 48px;
}

#promise dd span.emph {
	font-size: 28px;
	color: #0050aa;
}

/* --------------------------------------------------------------------------
 solution
-------------------------------------------------------------------------- */

ul#bbold {
	width: 752px;
	margin: 0 auto;
}

ul#bbold li {
	float: left;
	width: 362px;
	margin: 0 16px 20px 0;
	background: #0050aa;
	border-bottom: solid 3px #d9d9d9;
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	padding: 3px;
}

ul#bbold li:first-child {
	width: 368px;
	border: none;
	padding: 0;
	background: #ffffff;
}

ul#bbold li:nth-child(even) {
	margin: 0 0 20px;
}

ul#bbold li .inner {
	position: relative;
	background: #ffffff;
	min-height: 350px;
	padding: 20px 24px;
	border-radius: 13px;
	-webkit-border-radius: 13px;
	-moz-border-radius: 13px;
	-ms-border-radius: 13px;
}

ul#bbold li .photo {
	margin: 0 0 24px;
}

ul#bbold li h3 {
	background: #0050aa;
	color: #fff;
	border-radius: 20px;
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	-ms-border-radius: 20px;
	width: 314px;
	margin: 0 auto 20px;
	padding: 10px 0 8px;
	font-size: 16px;
	text-align: center;
}

ul#bbold li dl {
	border-bottom: dotted 1px #bbbbbb;
	padding: 14px 0;
}

ul#bbold li dl.fst {
	border-top: dotted 1px #bbb;
}

ul#bbold li dl dd {
	margin: -21px 0 0 24px;
	line-height: 1.2em;
}

ul#bbold li .btn-mid {
	position: absolute;
	bottom: 20px;
	left: 24px;
}

/* --------------------------------------------------------------------------
 merit
-------------------------------------------------------------------------- */

ul#lbold {
	width: 752px;
	margin: 0 auto;
}

ul#lbold li {
	float: left;
	position: relative;
	width: 338px;
	margin: 0 16px 16px 0;
	border: solid 5px #e2efff;
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	padding: 10px;
	text-align: center;
}

ul#lbold li:nth-child(even) {
	margin: 0 0 16px;
}

ul#lbold li .tag {
	position: absolute;
	top: -5px;
	left: 26px;
	width: 50px;
	height: 50px;
	background: url(/pc/assets/img/base_tag.png) bottom right no-repeat #0050aa;
	border-radius: 0 0 4px 4px;
	-webkit-border-radius: 0 0 4px 4px;
	-moz-border-radius: 0 0 4px 4px;
	-ms-border-radius: 0 0 4px 4px;
	font-size: 20px;
	padding: 10px 0 0;
	margin: 0;
	color: #fff;
	text-align: center;
	line-height: 1.0em;
	z-index: 999;
}

ul#lbold li .tag span {
	display: block;
	font-size: 10px;
}

ul#lbold li img {
	width: 338px;
	margin: 0 auto 24px;
}

ul#lbold li h3 {
	display: inline-block;
	font-size: 32px;
	color: #0050aa;
	border-bottom: dotted 2px #0050aa;
	margin: 0 0 28px;
	padding: 0 0 3px;
}

ul#lbold li h3 span.rub {
	font-size: 20px;
}

ul#lbold li p.txt {
	width: 294px;
	color: #0050aa;
	line-height: 1.5em;
	min-height: 4.5em;
	margin: 0 auto 12px;
	text-align: left;
}

/* --------------------------------------------------------------------------
 flow
-------------------------------------------------------------------------- */

ul#lwide {
	width: 752px;
	margin: 0 auto;
}

ul#lwide li {
	position: relative;
	width: 700px;
	margin: 27px 0 0;
	border: solid 5px #e2efff;
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	padding: 21px 21px 18px;
}

ul#lwide li:first-child {
	margin: 0;
}

ul#lwide li i {
	position: absolute;
	left: 48px;
	bottom: -32px;
}

ul#lwide li .step {
	color: #0050aa;
	float: left;
	width: 88px;
	margin-right: 30px;
	text-align: center;
	font-size: 72px;
	line-height: 1.0em;
}

ul#lwide li .step .tag {
	background: #0050aa;
	color: #fff;
	border-radius: 12px;
	-webkit-border-radius: 12px;
	-moz-border-radius: 12px;
	-ms-border-radius: 12px;
	margin: 0 0 16px;
	padding: 4px 0 2px;
	font-size: 12px;
	line-height: 1.3em;
}

ul#lwide li .subs {
	float: left;
	width: 548px;
}

ul#lwide li .subs h3 {
	color: #0050aa;
	font-size: 18px;
	border-bottom: dotted 1px #0050aa;
	padding: 0 0 12px;
	margin: 0 0 16px;
}

/* --------------------------------------------------------------------------
 cost
-------------------------------------------------------------------------- */

.zero {
	float: left;
	position: relative;
	width: 124px;
	height: 110px;
	margin-right: 32px;
	background: #e2efff;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	padding: 14px 0 0;
	color: #0050aa;
	text-align: center;
}

.zero .num {
	font-size: 90px;
	line-height: 1.0em;
	letter-spacing: -0.1em;
	padding-left: 12px;
	margin: -3px 0 0;
}

.zero .num span {
	font-size: 20px;
	letter-spacing: 0;
	text-shadow: -2px -2px 1px #e2efff;
	line-height: 1.0em;
	z-index: 999;
}

.info {
	float: left;
	width: 596px;
}

/* --------------------------------------------------------------------------
 point
-------------------------------------------------------------------------- */

ul#bthin {
	width: 752px;
	margin: 0 auto;
}

ul#bthin li {
	float: left;
	width: 312px;
	margin: 0 16px 16px 0;
	background: #ffffff;
	border: solid 2px #0050aa;
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	padding: 26px;
}

ul#bthin li:nth-child(even) {
	margin: 0 0 16px;
}

ul#bthin li .pnum {
	float: left;
	width: 88px;
	margin-right: 24px;
	text-align: center;
}

ul#bthin li .pnum .ttl {
	background: url(/pc/assets/img/top/tag_point.png) bottom center no-repeat;
	margin: 0 0 5px;
	color: #0050aa;
}

ul#bthin li .pnum .ttl span {
	display: block;
	font-size: 11px;
}

ul#bthin li .pnum .bdg {
	width: 68px;
	background: #0050aa;
	color: #fff;
	font-size: 42px;
	line-height: 1.0em;
	border-radius: 50%;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	-ms-border-radius: 50%;
	padding: 13px 0;
	margin: 0 auto;
}

ul#bthin li .subs {
	float: left;
	width: 200px;
}

ul#bthin li .subs h3 {
	display: inline-block;
	color: #0050aa;
	box-shadow: inset 0 -6px 0 0 #ffdf75;
	-webkit-box-shadow: inset 0 -6px 0 0 #ffdf75;
	-moz-box-shadow: inset 0 -6px 0 0 #ffdf75;
	-ms-box-shadow: inset 0 -6px 0 0 #ffdf75;
	font-size: 20px;
	margin: 0 0 6px;
	line-height: 1.0em;
}

ul#bthin li .subs p {
	margin: 26px 0 0;
}

ul#bthin li .subs p.lst {
	min-height: 15em;
}

/* --------------------------------------------------------------------------
 philosophy
-------------------------------------------------------------------------- */

.philosophy dl {
	display: table;
	width: 710px;
	border-bottom: dotted 1px #0050aa;
	padding: 32px 21px;
}

.philosophy dl.fst {
	border-top: dotted 1px #0050aa;
}

.philosophy dl.lst {
	margin: 0 0 24px;
}

.philosophy dt {
	display: table-cell;
	vertical-align: middle;
	width: 70px;
	font-family: 'Lora', serif;
	color: #0050aa;
	font-size: 60px;
	line-height: 1.0em;
	background: url(/pc/assets/img/top/tag_philosophy.png) bottom center no-repeat;
	text-align: center;
}

.philosophy dd {
	display: table-cell;
	vertical-align: middle;
	font-size: 22px;
	line-height: 1.6em;
	padding-left: 38px;
}

/* --------------------------------------------------------------------------
 greeting
-------------------------------------------------------------------------- */

.ceo {
	float: left;
	width: 224px;
	margin-right: 32px;
}

.greeting {
	float: left;
	width: 496px;
}

.greeting p.txt {
	margin: 0 0 32px;
}

.greeting .ceo_name {
	text-align: right;
	margin: 0 0 16px auto;
	width: 175px;
	height: 77px;
	background: url(/pc/assets/img/top/ceo_name.png) top left no-repeat;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

.newsStrong {
	font-size: 28px !important;
	color: #B20000;
}

.newsRed {
	color: #B20000;
}

.news {
	font-size: 20px !important;
	text-align: center;
	margin: 30px auto -10px;
	border: 4px solid #da4033;
	border-radius: 4px;
	padding: 20px 0px;
	position: relative;
	max-width: 1000px;
}

.news::before {
	background-color: #fff;
	color: #da4033;
	content: "お知らせ";
	font-weight: bold;
	left: 1em;
	padding: 0 .5em;
	position: absolute;
	top: -1em;
}

.newstxt {
	font-size: 20px;
}

.newsBrSP {
	display: none;
}

.newsAnnot {
	display: none;
}