@charset "utf-8";
/* CSS Document */

/* -------------------------------------------------- UTILITY  -------------------------------------------------- */

.mt-10	{ margin-top:-10px !important; }
.mt-5	{ margin-top:-5px !important; }
.mt0	{ margin-top:0px !important; }
.mt5	{ margin-top:5px !important; }
.mt10	{ margin-top:10px !important; }
.mt15	{ margin-top:15px !important; }
.mt20	{ margin-top:20px !important; }
.mt25	{ margin-top:25px !important; }
.mt30	{ margin-top:30px !important; }
.mt40	{ margin-top:40px !important; }
.mt50	{ margin-top:50px !important; }
.mt60	{ margin-top:60px !important; }
.mt100	{ margin-top:100px !important; }

.mr0	{ margin-right:0px !important; }
.mr5	{ margin-right:5px !important; }
.mr10	{ margin-right:10px !important; }
.mr15	{ margin-right:15px !important; }
.mr20	{ margin-right:20px !important; }
.mr25	{ margin-right:25px !important; }
.mr30	{ margin-right:30px !important; }
.mr40	{ margin-right:40px !important; }
.mr50	{ margin-right:50px !important; }
.mr100	{ margin-right:100px !important; }

.mb0	{ margin-bottom:0px !important; }
.mb3	{ margin-bottom:3px !important; }
.mb5	{ margin-bottom:5px !important; }
.mb10	{ margin-bottom:10px !important; }
.mb15	{ margin-bottom:15px !important; }
.mb20	{ margin-bottom:20px !important; }
.mb25	{ margin-bottom:25px !important; }
.mb30	{ margin-bottom:30px !important; }
.mb40	{ margin-bottom:40px !important; }
.mb50	{ margin-bottom:50px !important; }
.mb100	{ margin-bottom:100px !important; }

.ml0	{ margin-left:0px !important; }
.ml2	{ margin-left:2px !important; }
.ml5	{ margin-left:5px !important; }
.ml10	{ margin-left:10px !important; }
.ml15	{ margin-left:15px !important; }
.ml20	{ margin-left:20px !important; }
.ml25	{ margin-left:25px !important; }
.ml30	{ margin-left:30px !important; }
.ml40	{ margin-left:40px !important; }
.ml50	{ margin-left:50px !important; }
.ml100	{ margin-left:100px !important; }


/* -------------------------------------------------- FONT -------------------------------------------------- */

/* defalt font-size */
.f9 { font-size: 62.5% !important; }
.f10 { font-size:77% !important; }
.f11 { font-size:85% !important; }
.f12 { font-size:93% !important; }
.f13 { font-size:100% !important; }
.f14 { font-size:108% !important; }
.f15 { font-size:116% !important; }
.f16 { font-size:123.1% !important; }
.f17 { font-size:131% !important; }
.f18 { font-size:138.5% !important; }
.f19 { font-size:146.5% !important; }
.f20 { font-size:153.9% !important; }
.f21 { font-size:161.6% !important; }
.f22 { font-size:167% !important; }
.f23 { font-size:174% !important; }
.f24 { font-size:182% !important; }
.f25 { font-size:189% !important; }
.f26 { font-size:197% !important; }


.B	{ font-weight:bold !important; }
.blue	{ color:#2c8ed2 !important; }
.gray	{ color:#aaa !important; }
.red	{ color:#e6002d !important; }
.black	{ color:#000000 !important; }
.white	{ color:#ffffff !important; }

.right	{ text-align: right !important; }
.center	{ text-align: center !important; }

@media print , screen and (min-width: 768px) {
.pc-right	{ text-align: right !important; }
}

.pc { display: block !important; }
.sp { display: none !important; }
@media only screen and (max-width: 767px) {
    .pc { display: none !important; }
    .sp { display: block !important; }
}

sup {
	font-size: 70%;
	vertical-align: top;
	position: relative;
	top: -0.6em;
}

.img_hover:hover {
	opacity: 0.7 ;
}

@media print , screen and (min-width: 768px) {
.mt0_pc {
	margin-top:0px !important;
}
.mt-25_pc	{ margin-top:-25px !important; }
}


/* main
---------------------------------- */

#main {
	padding: 35px 0;
}
#container #main {
	float: left;
	width: 100%;
}

@media print , screen and (min-width: 768px) {
#container {
	width: 100%;
}
#container #main {
	width: 100%;
}
#container #main .con_area {
	width: 950px;
	margin-left: auto;
	margin-right: auto;
}
}

.bg_blue {
	background-color: #edf7ff;
	padding: 5px 0;
}


@media only screen and (max-width: 767px) {
.bg_blue {
	margin: 0 -10px;
	padding: 10px 10px;
}
}



/* navi-block
---------------------------------- */

.navi-block {
	margin-bottom: 70px;
}

.navi-block.end {
	margin-top: 70px;
	margin-bottom: 50px;
}

@media print , screen and (min-width: 768px) {
.navi-block.end {
	margin-top: 100px;
	margin-bottom: 0;
}
}

#contents {
	margin-top: -70px;
	padding-top: 70px;
}


/* contents-block
---------------------------------- */

.contents-block {
	margin-bottom: 60px;
}
.contents-block img {
	width: 100%;
}

.contents-block h2 {
	background: none;
	margin: 0;
	padding: 0;
}
.contents-block h3, .contents-block h4 {
	background: none;
	margin: 0;
	padding: 0;
	border-bottom: none;
	color: #383838 !important;
}

@media print , screen and (min-width: 768px) {
.contents-block {
	margin-bottom: 100px;
}
}

@media only screen and (max-width: 767px) {
#contents {
	margin-top: -80px;
}
}

/* col_4
---------------------------------- */

.col_4 {
	width: 100%;
	display: flex;
	display: -ms-flexbox; /* IE10 */
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /* IE10 */
	margin-top: 20px;
}
.col_4 > div {
	width: calc(25% - 6px);
	margin-right: 8px;
	border: 1px solid #d5d5d5;
	box-sizing: border-box;
	position: relative;
	overflow:hidden;
}
.col_4 > div:last-child {
	margin-right: 0;
}
.col_4 > div img {
	width: calc(100%);
	padding: 0 1px 0 0px;
}
.col_4 > div .wh-bk {
	width: calc(100%);
	position: absolute;
	background-color: #fff;
	bottom: 0;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	justify-content: center;
	opacity: 0.9;
	padding: 5px 0;
}
.col_4 > div .wh-bk p {
	color: #000;
	font-size: 131% !important;
	font-weight: 400;	
}
.col_4 > div a:hover img{
	transform:scale(1.1,1.1);
	transition: .3s ease-in-out;
}
.col_4 > div.active {
	border: 2px solid #a03131;
	box-sizing: border-box;
}


@media only screen and (max-width: 767px) {
.col_4 > div {
	width: calc(50% - 5px);
	margin-right: 10px;
}
.col_4 > div:nth-child(n+3) {
	margin-top: 10px;
}
.col_4 > div:nth-child(2n) {
	margin-right: 0;
}
.col_4 > div .wh-bk p {
	font-size: 108% !important;
}
}


/* ul_navi
---------------------------------- */

ul.ul_navi li a{
	display: block;
	width: 100%;
	padding: 10px 0;
	text-decoration: none;
	color: #222;
	font-weight: bold;
	line-height: 140%;
}

ul.ul_navil li.current a{
color: #222;
}
ul.ul_navi li:hover{
background-color: #fce7ec;
}

ul.ul_navi li.active{
background-color: #e41747;
}
 ul.ul_navi li.active a{
color: #fff;
}


@media print , screen and (min-width: 768px) {
ul.ul_navi {
	display: table;
	margin: 0 auto;
	padding: 0;
	width: 100%;
	text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}
ul.ul_navi li{
	display: table-cell;
	width: 12.5%;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #bebebe;
}
ul.ul_navi li:last-child{
	width: 12.5%;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #bebebe;
}
ul.ul_navi li a{
	height: 76px;
    display: flex;
    justify-content: center;
    align-items: center;
}
}


@media only screen and (max-width: 767px) {
ul.ul_navi.head {
	display:none;
}
ul.ul_navi {
margin: 0 auto;
padding: 0;
width: 100%;
text-align: center;
}
ul.ul_navi li{
	width: 100%;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #bebebe;
}
ul.ul_navi li:last-child{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #bebebe;
}
}


/* タイトル1重線
---------------------------------- */

h2.top_title {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #cd0000;
	margin-bottom: 30px;
}
@media print , screen and (min-width: 768px) {
	h2.top_title {
		margin: -15px 0 50px 0;
	}
}

h2.cp_title {
	position: relative;
	margin-top: 60px;
	padding-top: 8px;
	padding-bottom: 10px;
	color: #000;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #cd0000;
}

h2.cp_title2 {
	position: relative;
	margin-top: 60px;
	padding-bottom: 14px;
}
h2.cp_title2::before {
	position: absolute;
	left: 0;
	content: '';
	width: 100%;
	height: 6px;
	box-sizing: border-box;
	bottom: 0;
	border-top: 2px solid #cd0000;
	border-bottom: 1px solid #cd0000;
}

h2.cp_title3 {
	position: relative;
	margin-top: 60px;
	padding: 20px;
	color: #cd0035;
	background-color:#fff6f2;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #cd0000;
}



h2.cp_title span.ssize, h2.cp_title2 span.ssize, h2.cp_title3 span.ssize {
	font-size: 16px !important;
	font-weight: 300 !important;
}

@media print , screen and (min-width: 768px) {
	h2.top_title, h2.cp_title, h2.cp_title2, h2.cp_title3 {
		font-size: 22px !important;
	}
	h2.cp_title span.ssize, h2.cp_title2 span.ssize, h2.cp_title3 span.ssize {
		font-size: 18px !important;
	}
	h2.cp_title3 {
		padding: 30px;
	}
}

/* タイトル上下線
---------------------------------- */
h2.wl_title {
  padding: 1rem 0;
  border-top: 1px solid #3c34a5;
  border-bottom: 1px solid #3c34a5;
  color:#3c34a5;
}

@media print , screen and (min-width: 768px) {
h2.wl_title {
	font-size: 23px !important;
	margin-top: 100px;
}
}



/* タイトルh3
---------------------------------- */
h3.cp_title {
	margin-top: 50px;
	color: #dd005e !important;
}

h3.cp_title_underline {
	margin-top: 70px;
	padding-bottom: 15px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #333;	
}

h3.cp_title2 {
	font-size: 17px !important;
	margin-top: 50px;
}

h3.cp_title3 {
	font-size: 20px !important;
	margin-top: 50px;
	color: #dd005e !important;
}

h3.cp_title4 {
	font-size: 17px !important;
	margin-top: 30px;
	margin-bottom: -10px;
}
h3.cp_title5 {
	font-size: 17px !important;
	margin-top: 60px;
	padding-bottom: 5px;
}



h3.pre_title {
	display: flex;
	margin-top: 50px;
}

h3.pre_title::before {
	content: '';
	width: 25px;
	height: 4px;
	background-color: #3c34a5;
	margin-right: 8px;
	margin-top: 0.7em;
}

@media print , screen and (min-width: 768px) {
h3.cp_title {
	font-size: 23px !important;
	margin-top: 80px;
}
h3.cp_title_underline {
	font-size: 23px !important;
	margin-top: 120px;
}
h3.cp_title2, h4.cp_title3 {
	font-size: 20px !important;
	margin-top: 80px;
}

h3.cp_title4 {
	font-size: 21px !important;
	margin-top: 40px;
	margin-bottom: 0px;
}
.basic-block h3.cp_title4 {
	margin-top: 0;
	margin-bottom: 40px;
}
h3.cp_title5 {
	font-size: 21px !important;
	margin-top: 80px;
	padding-bottom: 10px;
}
}






/* 記事
---------------------------------- */
.basic-block {
	margin-top: 25px;
	clear: both;
}
.basic-block p {
	color: #383838;
	line-height: 200% !important;
}
.basic-block p:nth-child(n+2) {
	margin-top: 1.5em;
}

.basic-block.center-w800 {
	text-align: center;
	margin-top: 80px;
	margin-left: auto;
	margin-right: auto;
	justify-content: center;
	max-width: 800px;
}
.basic-block.center-w800 img {
	margin: 0 0 -15px;
	padding: 0;
}
.basic-block.center-w800 a:hover img {
	opacity: 0.7;
}

.contents-block p.stepdown {
	text-indent: 1em;
}

.basic-block.expansion {
	margin-top: 30px;
}

.float_none {
	clear: both;
	margin: 0;
	padding: 0;
	width: 100%;
}

.basic-block figure img {
	max-width: 100%;
}

.basic-block figure p {
	width: 100%;
	font-size: 14px !important;
	line-height: 150% !important;
	margin-top: 0.5em !important;
	margin-bottom: 50px;
}


a:hover .btn.btn-primary {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
	transition:0.5s;
}
/*
.btn.btn-primary {
	position: relative;
	overflow:hidden;
}
a:hover .btn.btn-primary img {
	transform:scale(1.1,1.1);
	transition: .3s ease-in-out;
}
*/

.basic-block ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
  margin: 20px 0;
}
.basic-block li {
  line-height: 200% !important;
  padding-left: 30px;
  position: relative;
}
.basic-block li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	background-color: #fff;
	border: 1px solid #383838;
	border-radius: 50%;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 20px;
	width: 20px;
	color: #383838 !important;
	position: absolute;
	top: 6px;
	left: 0;
	font-size: 12px !important;
	line-height:0 !important;
}

.p_name {
	font-weight: 700;
}
.p_name.blue {
	color: #2c63c6;
}
.p_name.red {
	color: #b94607;
}
.p_name.orange {
	color: #d76500;
}
.p_name.green {
	color: #188000;
}
.p_name.emerald {
	color: #0297bc;
}


@media print , screen and (min-width: 768px) {
.basic-block {
	margin-top: 35px;
}
.basic-block p {
	font-size: 138.5% !important;
}

.basic-block.expansion {
	margin-top: 60px;
}

.basic-block figure {
	max-width: 470px;
	margin-bottom: 0.5em;
}

.basic-block.w400 figure {
	max-width: 400px;
	margin-bottom: 0.5em;
}

.basic-block.w530 figure {
	max-width: 530px;
	margin-bottom: 0.5em;
}

.basic-block figure img {
	margin-top: 10px;
}

.basic-block figure p {
	margin-bottom: 0;
}

.basic-block.p-right figure {
	float: right;
	margin-left: 30px;
}
.basic-block.p-left figure {
	float: left;
	margin-right: 30px;
}
.basic-block li {
	font-size: 17px !important;
}
.basic-block li:before {
	top: 7px;
}
}



/* 画像ポップアップ
---------------------------------- */
.rel {
	position: relative;
}
.img-display {
	border: 2px solid #204b82;
	box-sizing: border-box;
}
.glassmark {
    width: 42px;
    height: 42px;
    display: flex;
    position: absolute;
    top: 0;
    right: 0;
}
.glassmark, .glassmark img {
    width: 42px;
    height: 42px;
}

@media print , screen and (min-width: 768px) {
.glassmark, .glassmark img {
    width: 63px;
    height: 63px;
}
}


/* 価値創造ストーリー オレンジバック
---------------------------------- */
.story-bg {
	background-color: #fff6f2;
	padding: 30px;	
}
.story-bg p {
	color: #383838;
	line-height: 200% !important;
}

@media print , screen and (min-width: 768px) {
.story-bg p {
	font-size: 138.5% !important;
}
}

/* スペシャル対談
---------------------------------- */
.basic-block p.p_talking_title {
	margin-top: 50px;
	margin-bottom: 1em;
	font-weight: 700;
	font-size: 17px !important;
}

.basic-block.bottom-link {
	width: 100%;
	margin-top: 80px;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	justify-content: center;
}

@media print , screen and (min-width: 768px) {
.basic-block p.p_talking_title {
	font-size: 23px !important;
	margin-top: 80px;
}
}

@media only screen and (max-width: 767px) {
.basic-block.talking_space {
	margin-top: 50px;
}
.basic-block.bottom-link {
	margin-top: 50px;
}
}

.container_link_block {
	display: flex;
	width: 100%;
	text-align: left;

}
.container_link_block p {
	padding: 0.7em 0 0;
	margin: 0 !important;
	font-size: 15px !important;
	line-height: 160% !important;
	text-decoration: none;
}

.container_link_block a {
	text-decoration: none;
}
.container_link_block a:hover img {
	opacity: 0.7;
	transition:0.5s;
}
.container_link_block .contents_l {
	width: 40%;
	margin: 0 5%;
}
.container_link_block .contents_r {
	width: 40%;
	margin: 0 5%;
}

@media only screen and (max-width: 767px) {
.container_link_block {
	display: block;
	width: 90%;
}
.container_link_block .contents_l {
	width: 100%;
	margin: 0;
}
.container_link_block .contents_r {
	width: 100%;
	margin: 4rem 0 0;
}
}


p.arrow_left {
  position: relative;
  display: inline-block;
  width : calc(100% - 36px);
  font-size: 19px !important;
  font-weight: 700;
}

a:hover p.arrow_left span {
	border-bottom-width: 2px;
	border-bottom-style: solid;
	border-bottom-color: #111;	
}
 
.arrow_left::before {
  content: "";
  margin: auto;
  position: absolute;
  top: 5px;
  bottom: 0;
  right: -30px;
  width: 11px;
  height: 11px;
  border-top: 3px solid #000;
  border-right: 3px solid #000;
  transform: rotate(45deg);
}
 
.arrow_left::after { 
  content: "";
  margin: auto;
  position: absolute;
  top: 4px;
  bottom: 0;
  right: -30px;
  width: 30px;
  height: 3px;
  background: #000;
}
@media only screen and (max-width: 767px) {
p.arrow_left {
  font-size: 17px !important;
}
}


p.indent {
	padding-left:1.5em;
	text-indent:-1.5em;
	font-size: 13.5px !important;
	line-height: 130% !important;
	padding-bottom: 1.5em;
}
p.indent span {
	padding-right:0.5em;
}



p.arrow_right {
  position: relative;
  padding-left: 23px;
  font-size: 15px !important;
}
p.arrow_right::before { /* くの字の表示設定 */
  content: "";
  margin: auto 0 auto -20px;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 7px;    /* くの字を山なりに見た時、左側の長さ */
  height: 7px;   /* くの字を山なりに見た時、右側の長さ */
  border-top: 2px solid #fa0f51;     /* くの字を山なりに見た時、左側の太さと色 */
  border-right: 2px solid #fa0f51;   /* くの字を山なりに見た時、右側の太さと色 */
  transform: rotate(45deg);    /* くの字の向き */
}