@charset "utf-8";
/*
Theme Name: SANYODENKI
Author: YES-REFORM CO., LTD.
*/

/* ======================================================

	structure CSS

========================================================= */


/* ======================================================

	body

========================================================= */
html, body{
	position: relative;
	height: 100%!important;
}
body {
	display: none;
	color:#222;
	font-size:16px;
	font-size:1.6rem;
	line-height:1.8em;
	min-width:1000px;
}
@media screen and (max-width: 1000px) {
	body{
		min-width:100%;
		background: none;}
}

@media screen and (max-width: 768px) {
	body{word-wrap:break-word;
		font-size:14px;
		font-size: 1.4rem;
	}
}

@media screen and (max-width: 599px) {
	body{
		font-size:14px;
		font-size: 1.4rem;}
}


/* ======================================================

	header

========================================================= */
.header{
	z-index: 2000;
	position: fixed;
	top:0;
	width: 100%;
	height: 85px;
	background: linear-gradient(rgba(0, 43, 94,1) 0%,  rgba(1, 21, 46,1) 100%);
}
.header .inner{
	position: relative;
	margin: 0 auto;
	width: 1000px;
	height: 85px;
}

.header .inner::after{content:" ";display:block;clear:both;font-size:0;}

.h_logo{
	float: left;
	display: table;
	padding-top: 10px;
	padding-left: 10px;
}
.h_logo a{
	color: #fff;
	text-decoration: none;
	transition: .3s;
}
.h_logo span{
	display:table-cell;
	vertical-align: middle;
}

.h_logo a:hover{
	opacity: 0.7;
}

.gnav{
	float:right;}

.gnav ul{
	display: flex;
	align-items: center;
	height: 85px;}

.gnav ul li a{
	position: relative;
	display:block;
	margin: 0 10px;
	padding: 10px 10px;
	color: #fff;
	text-decoration: none;}

.gnav ul li a::after {
	position: absolute;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #fff;
	bottom: -1px;
	transform: scale(0, 1);
	transform-origin: center top;
	transition: transform 0.3s;
}

.gnav ul li a:hover::after,
.gnav ul li.current a::after{
	transform: scale(1, 1);
}

.nav_btn {display:none;}
.gnav_sp{
	position: absolute;
	top: 0;
	right: -50%;
	height: 100vh;
	overflow: auto;
	padding-top: 120px;
	padding: 120px 50px 30px;
	width: 40%;
	background: linear-gradient(rgba(0, 43, 94,1) 0%,  rgba(1, 21, 46,1) 100%);
	transition: all 0.6s;
}

@media screen and (max-width: 1000px) {
	.header .inner{
		width: 100%;
	}

	.gnav{display: none;}

	.nav_btn {
		display:block;
		z-index: 2000;
		position:absolute;
		top:30px;
		right: 0;
		width: 40px;
		height: 50px;
		cursor: pointer;
	}
	.nav_btn span {
		display: block;
		position: absolute;
		height: 2px;
		width: 100%;
		background: #fff;
		left: 0;
		-webkit-transition: .3s ease-in-out;
		-moz-transition: .3s ease-in-out;
		transition: .3s ease-in-out;
	}
	.nav_btn span:nth-child(1) {top: 0;}
	.nav_btn span:nth-child(2) {top: 12px;}
	.nav_btn span:nth-child(3) {top: 24px;}

	.nav_btn.open span:nth-child(1) {
		top: 10px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.nav_btn.open span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.nav_btn.open span:nth-child(3) {
		top: 10px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	.nav_btn:hover{
		opacity: 0.5;
	}
	
	.gnav_sp.open{
		right: 0;
	}

	.gnav_sp nav{
		display: flex;
		justify-content: space-around;
		margin: 0 auto 50px;
	}

	.gnav_sp ul li {
		position: relative;
		margin-bottom: 30px;
		padding-left: 30px;
	}

	.gnav_sp ul li::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 20px;
		height: 20px;
		background: -moz-linear-gradient(top left, #70cce3, #2bb1d2); 
		background: -webkit-linear-gradient(top left, #70cce3, #2bb1d2); 
		background: linear-gradient(to bottom right, #70cce3, #2bb1d2);
		border-radius: 3px;
		opacity: 0.7;
	}

	.gnav_sp ul li a {
		display: block;
		text-decoration: none;
		font-size: 18px;
		color: #fff;
	}

	.gnav_sp ul li a:hover{
		text-decoration: underline;
	}

	.gnav_sp ul li ul{
		margin-top: 20px;
	}

	.gnav_sp ul li ul li{
		margin-bottom: 10px;
	}

	.gnav_sp ul li ul li::before {
		content: "";
		position: absolute;
		top: 0.7em;
		left: 0;
		width: 15px;
		height: 1px;
		background: #fff;
		border-radius:0
	}

	.gnav_sp ul li ul li a{
		font-size: 100%;
	}

	
	.h_logo{
		padding-left: 10px;
	}

	.nav_btn {
		display: block;
		top:30px;
		right:20px;
	}	
	.gnav_sp{
		padding-top: 100px;
		right: -70%;
		width: 60%;
	}	
	.gnav_sp nav{
		padding: 0 30px;
		width: 100%;
	}
	
	.gnav_sp > ul{width: 50%;}
	
}

@media screen and (max-width:768px){
	
	.header{height: 50px;}
	.header .inner{height: 50px;}
	
	.h_logo{
		padding-top: 8px;
	}
	.h_logo a{
		line-height: 1;
		font-size: 12px;}
	
	.h_logo span{
		margin-bottom: 5px;
	}
	.h_logo img{
		padding-right: 5px;
		width: auto;
		height: 35px;
	}
	
	.nav_btn {
		top:15px;
		right:20px;
		width: 35px;
		height: 40px;
	}
	
	.nav_btn span:nth-child(2) {top: 10px;}
	.nav_btn span:nth-child(3) {top: 20px;}
	
	.nav_btn:hover{opacity: 1;}
	
	.gnav_sp{
		padding: 80px 20px 20px;
		right: -90%;
		width: 80%;
	}
	
	.gnav_sp nav{
		display: block;
	}
	
	.gnav_sp > ul{width: 100%;}
	
	.gnav_sp ul li {
		margin-bottom: 20px;
	}
	.gnav_sp ul li a {
		font-size: 16px;
	}
	
	.gnav_sp ul li ul{
		margin-top: 10px;
	}
	.gnav_sp ul li ul li{
		margin-bottom: 10px;
	}


}

@media screen and (max-width:599px){
	.gnav_sp nav{
		padding: 0 20px;
	}
	
	.gnav_sp ul li a {
		font-size: 16px;
	}
	.gnav_sp{
		padding: 80px 15px 20px;
		right: -90%;
		width: 90%;
	}
	
	.nav_btn {
		top:13px;
		right: 15px;
		width: 30px;
		height: 23px;
	}
	
}

/* ======================================================

	contents

========================================================= */
.contents{
	margin:85px auto 0;
	width:100%;
	background: url("images/bg_body.jpg") center top repeat-y;
	background-size: 100%;}

.section_inner{
	margin:0 auto;
	padding: 30px 60px;
	width:1000px;}

.section_inner p{
	margin-bottom: 1.5em;}

@media screen and (max-width:1000px){
	.contents{
		margin:85px auto 0;
		background: none;}
	
	.section_inner{
		padding:60px 60px;
		width:100%;}

}

@media screen and (max-width:768px){
	.contents{
		margin:50px auto 0;}
	.section_inner{
		padding:30px 20px;}

}

@media screen and (max-width:599px){
	.section_inner{
		padding:10px 20px;}

}


/* タイトルとメニュー
========================================== */
.titleArea{
	background-color: #2c426b;
}

.titleArea > div{
	margin: 0 auto;
	padding: 30px;
	width: 1000px;
	background: url("images/mv.jpg") center top no-repeat;
	background-size: cover;
}
.titleArea.sub > div{
	background-image:none;
	background-color: #2c426b;
}

.titleArea h1{
	line-height: 1.3;
	font-size: 26px;
	font-weight: normal;
	color: #fff;
}

.sub_menu_box {
    display: flex;
    flex-wrap: wrap;
    /* margin-top: 30px; */
}
.sub_menu {
	margin-top: 30px;
	padding-left: 20px;
	width:50%;
}
.sub_menu li{
	position: relative;
	padding-left: 30px;
}
.sub_menu li{margin-bottom: 10px;}

.sub_menu li a{
	display: block;
	text-decoration: none;
	color: #fff;
}
.sub_menu li::before {
	content: "";
	position: absolute;
	top: 0.7em;
	left: 0;
	width: 15px;
	height: 1px;
	background: #fff;
	border-radius:0
}

.sub_menu li a:hover{
	text-decoration: underline;
}

/*2カラムにする場合*/
.sub_menu_box{
	display: flex;
	flex-wrap: wrap;
	/* margin-top: 30px; */
}
.sub_menu_box .sub_menu {
	margin-top: 0;
	padding-left: 20px;
	width:50%;
}
.sub_menu dt,
.sub_menu dd {
	margin-bottom: 10px;
}
.sub_menu dt {
	position: relative;
	padding-left: 30px;
	font-weight: bold;
}
.sub_menu dd {
	padding-left: 2em;
}
.sub_menu dt::before {
	content: "";
	position: absolute;
	top: 0.7em;
	left: 0;
	width: 15px;
	height: 1px;
	background: #fff;
	border-radius: 0;
}
.sub_menu dt a,
.sub_menu dd a {
	display: block;
	text-decoration: none;
	color: #fff;
}

@media screen and (max-width: 1000px) {
	.titleArea{
		width: 100%;
		height: auto;}
	
	.titleArea > div{
		padding: 30px;
		width: 100%;
	}
	
	.titleArea h1,
	.titleArea.sub h1{
		font-size: 30px;
	}
	
}

@media screen and (max-width:768px){
	.titleArea{
		padding:0;
		background: none;
	}
	.titleArea.sub{padding:0;}

	.titleArea > div{
		padding: 20px;
	}

	.titleArea h1,
	.titleArea.sub h1{
		width: 100%;
		font-size:26px;
	}

	.sub_menu_box{
		display: block;
	}

	.sub_menu_box .sub_menu,
	.sub_menu {
		width: 100%;
	}

	.sub_menu li{margin-bottom: 10px;}
	.sub_menu li a{
		font-size: 16px;
	}
	.sub_menu_box .sub_menu,
	.sub_menu {
		width: 100%;
	}
	.sub_menu dt a,
	.sub_menu dd a {
		font-size: 16px;
	}
}

@media screen and (max-width:599px){
	.titleArea h1,
	.titleArea.sub h1{
		font-size: 18px;
	}
	.sub_menu li a{
		font-size: 14px;
	}
	.sub_menu dt a,
	.sub_menu dd a {
		font-size: 14px;
	}
}

@media screen and (max-width:399px){
	.sub_menu dt br,
	.sub_menu dd br{
		display: none;
	}
}


/* ページの説明文
========================================== */
.introArea{}

.introArea .inner{
	margin: 0 auto;
	padding:40px 60px;
	width: 1000px;
}

.introArea p{font-size: 16px;}
.introArea p:not(:last-child){margin-bottom: 1.5em;}


@media screen and (max-width: 1000px) {
	.introArea{
	}
	.introArea .inner{
		padding:60px 60px;
		width: 100%;
	}
}

@media screen and (max-width: 768px) {
	.introArea .inner{
		padding:30px 20px;
	}

	.introArea p{font-size: 16px;}
}

@media screen and (max-width: 599px) {
	.introArea p{font-size: 16px;}
}


/* 概要
========================================== */
.overviewArea{
	margin-top: 70px;
	padding:0 30px 30px;
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 1.8em, rgba(243,244,245,0.7) 1.8em, rgba(243,244,245,0.7) 100%);
}

.overviewArea .inner{
	margin: 0 auto;
	width: 100%;
	max-width: 880px;
	text-align: left;
	line-height: 1.7;
}
.overviewArea h1{
    /*margin-bottom: 20px;
	line-height: 1.8;*/
	margin-bottom: 10px;
	line-height: 2.8;
	text-align: center;
	font-size: 22px;
	font-weight: bold;
}
.overviewArea ul{
	display: inline-block;
	margin-bottom: 20px;
}
/* .overviewArea > .inner > ul{
	width: 70%;
} */
.overviewArea ul li > dl{
	display: block;
	margin-top: 10px;
	margin-bottom: 0;
}
.overviewArea ul li{
	font-size: 18px;
	font-weight: bold;
	text-align: left;
}
.overviewArea > .inner > ul > li > div{
	margin-left: 4.6em;
	text-indent: -4.6em;
}
.overviewArea > .inner > ul > li > dl > dd > div{
	margin-left: 2.1em;
	text-indent: -2.1em;
}
.overviewArea ul li:not(:last-child){
	margin-bottom: 2em;
}
.overviewArea ul li span{
	font-size: 14px;
}
.overviewArea > .inner > ul > li > dl > dd{
	margin-top: 0.2em;
}
.overviewArea li .overviewArea_txt {
	display: flex;
	flex-wrap: wrap;
	column-gap: 0.5em;
	position: relative;
	margin-top: 0.3em;
	margin-left: 1em!important;
	text-indent: 0!important;
	line-height: 1.4;
}
.overviewArea li .overviewArea_txt::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 0.25em;
	right: calc(100% + 0.3em);
	width: 0.6em;
	height: 0.6em;
	border-radius: 50%;
	background-color: #01152e;
}
.overviewArea li .overviewArea_txt > span {
	font-size: 16px;
}
.overviewArea .secBlock + .secBlock {
	margin-top: 1.2em;
}
.overviewArea .overviewTitle {
	margin:0; text-align:left;
}
.overviewArea .overviewCont {
	display: flex;
	/* align-items: flex-end; */
	flex-wrap: wrap;
	gap: 0.6em;
	margin: 0.4em 0 0 0;
	text-align:left;
}
.overviewArea .overviewCont .heading {
	width: 6em;
}
.overviewArea .overviewCont .text {
	width: calc(100% - (0.6em + 6em));
	font-size:1.15em;
	font-weight:inherit;
}
.overviewArea .proposal {
	margin: 30px auto;
}
.overviewArea .proposal .secBlock {
	/* width: fit-content; */
	max-width: 510px;
	margin: 0 auto;
	font-weight: 600;
}
.overviewArea .proposal .txt_through {
	text-decoration-thickness: 2px;
}
.overviewArea .proposal .note {
	max-width: 492px;
	margin: 1.2em auto 0;
	padding-left: 1em;
	text-indent: -1em;
	font-size: 14px;
	line-height: 1.6;
}

@media screen and (max-width: 1000px) {
	.overviewArea .inner{
		width: 100%;
	}

	.overviewArea ul{
		display: inline-block;
		width: 100%;
	}

}

@media screen and (max-width: 768px) {
	.overviewArea{
		/* padding:0 20px 50px; */
		background: rgb(255,255,255);
		background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 1.8em, rgba(243,244,245,1) 1.8em, rgba(243,244,245,1) 100%);
	}

	.overviewArea h1{
		margin-bottom: 30px;
		font-size: 26px;
	}

	.overviewArea > .inner > ul{
		width: 100%;
	}

	.overviewArea ul li{
		/*font-size: 20px;*/
	}

	.overviewArea ul li:not(:last-child){
		margin-bottom: 20px;
	}

	.overviewArea ul li span{
		display: block;
		font-size: 16px;
	}

	.overviewArea > .inner > ul > li > div{
		margin-left: 0;
		text-indent: 0;
	}

	.overviewArea > .inner > ul > li > dl > dd > div{
		margin-left: 0;
		text-indent: 0;
	}
}

@media screen and (max-width: 599px) {
	.overviewArea{
		padding:0 20px 30px;
		background: rgb(255,255,255);
		background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 1.8em, rgba(243,244,245,1) 1.8em, rgba(243,244,245,1) 100%);
	}

	.overviewArea h1{
		margin-bottom: 20px;
		font-size: 20px;}

	.overviewArea ul li{
		font-size: 16px;
	}

	.overviewArea ul li span{
		font-size: 14px;
	}

	.overviewArea li .overviewArea_txt {
		flex-direction: column;
	}

	.overviewArea li .overviewArea_txt > span {
		font-size: 15px;
	}
}

/* 新着情報
========================================== */
.news_list{
	margin-bottom: 50px;
}

.news_list dl{
	line-height: 1.5;
	display: table;
	margin-bottom: 10px;
	width: 100%;
	border-bottom: 1px solid #c3c3c3;
}

.news_list dt,
.news_list dd{
	display: table-cell;
	padding: 10px;
}

.news_list dt{
	width: 8em;
	color: #00316a;
}

.news_list dd a{
	color: #222;
	text-decoration: none;
}
.news_list dd a:hover{
	color:#00316a;
	text-decoration: underline;
}

@media screen and (max-width: 599px) {
	.news_list dt,
	.news_list dd{
		display: block;
		width: 100%;
	}
	.news_list dt{padding-bottom: 0;}
	.news_list dd{padding-top: 5px;}
}


/* 株主提案の背景及びポイント
========================================== */
.background_point{
	display: table;
	margin-bottom: 15px;
	
}

.background_point dt,
.background_point dd{
	display: table-cell;
	font-size: 20px;
	font-weight: bold;
	vertical-align: middle;
}

.background_point dt{
	position: relative;
	padding-right: 60px;
	color: #c00100;
}
.background_point dt::before{
	content: "";
	position: absolute;
	top:50%;
	margin-top: -8px;
	width: 10px;
	height: 10px;
	right:30px;
	border-top: solid 2px #222;
	border-right: solid 2px #222;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.background_point dd{
	color: #347b9e;
}

@media screen and (max-width: 768px) {
	.background_point dt,
	.background_point dd{
		line-height: 1.2;
		font-size: 18px;
	}
}

@media screen and (max-width: 599px) {
	.background_point{
		display: block;
		width: 100%;}
	.background_point dt,
	.background_point dd{
		display: block;
		padding: 0;
		width: 100%;
		font-size: 16px;
		text-align: center;
	}
	
	.background_point dt{margin-bottom: 50px;}
	
	.background_point dt::before{
		top:auto;
		right:auto;
		bottom: -25px;
		left: 50%;
		margin-top: 0;
		width: 10px;
		height: 10px;
		-webkit-transform: translateX(-50%) rotate(135deg);
		transform: translateX(-50%) rotate(135deg);
	}
	
	
}

/* box
========================================== */
.tape_box {
    position: relative;
	margin: 30px 0;
	padding: 30px 30px 20px;
	background: #d7d7d7;
	box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.15);
	color: #000;
}
.tape_box::before {
    content: '';
    position: absolute;
    left: calc(50% - 85px);
    background-color: #d8d8d8;
    opacity: 0.3;
    transform: rotate(2deg);
    width: 170px;
    height: 35px;
    margin: -2.5em auto 0 auto;
    border-left: 3px dotted rgba(0, 0, 0, .1);
    border-right: 3px dotted rgba(0, 0, 0, .1);
}
.tape_box p {
	margin: 0 0 10px;
	padding: 0;
	font-size: 18px;
	font-size: max(14px, min(3vw, 18px));
	font-size: clamp(14px, 3vw, 18px);
	line-height: 1.8em;
}
.tape_box span.txt_line {
	padding-bottom: 3px;
	border-bottom: 2px solid;
	font-weight: bold;
}
.box_black {
	background: #000;
	color: #fff;
}

@media screen and (max-width: 768px) {
	.tape_box {
		padding: 20px 20px 10px;
	}
}

/* ======================================================

	footer

========================================================= */
#footer{
	width:100%;
	background-color:#01152e;}

.footerArea{
	margin:0 auto;
	padding:40px 0 0;
	width:1000px;}

.f_logo{
	margin-bottom: 30px;
	text-align: center;
}

.f_logo a{
	transition: 0.3s;
}

.f_logo a:hover{
	opacity: 0.7;
}

.f_discramer{
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px solid #fff;
	color:#fff;
	font-size:14px;
}

.f_nav{
	display: flex;
	justify-content: center;
	margin-bottom: 30px;}

.f_nav li{
	margin-bottom:5px;}

.f_nav li a{
	display: block;
	padding: 10px 15px;
	color:#fff;
	text-decoration:none;}

.f_nav li a:hover{
	text-decoration:underline;}

.f_box{}

.external_link{
	display: flex;
	justify-content: center;
	margin-bottom: 20px;
}

.external_link li{
	margin: 0 10px;
}

.external_link li a{
	color: #fff;
	font-size: 14px;
	text-decoration: none;
}
.external_link li a:hover{
	text-decoration: underline;
}

.copyright{
	display: block;
	padding: 5px 10px;
	color: #fff;
	font-size:14px;
	text-align:center;}


@media screen and (max-width:1000px){
	.footerArea{
		padding:30px 60px 0;
		width:100%;}
}

@media screen and (max-width: 768px) {
	.footerArea{
		padding:30px 20px 0;}
	
	.f_nav{
		flex-wrap: wrap;}

	.f_nav li{
		width: 50%;
		text-align: center;}
	
	.f_nav li a{
		padding:5px 10px;}
	
}

@media screen and (max-width: 599px) {
	.f_discramer{
		font-size:12px;
	}
	
	.f_nav li a{
		font-size:14px;}
	
	.copyright{
		font-size:12px;}

}

/* ==============================================

	pagetop

================================================= */
#pageTop{
	position:fixed;
	line-height: 1;
	right:20px;
	bottom:20px;
	z-index: 100;}

#pageTop a{
	display: block;
	position:relative;
	padding:30px;
	background-color:#002b5e;
	color:#fff;
	font-size: 1.2rem;
	text-decoration: none;
}

#pageTop a::before{
	position:absolute;
	content: "";
	top:25px;
	left:50%;
	margin-left: -5px;
	width: 10px;
	height: 10px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	transition: all .3s;
	}

#pageTop:hover a::before{
	top:15px;
	}
@media screen and (max-width: 768px) {
	#pageTop{
		right:0;
		bottom:60px!important;}
}

@media screen and (max-width:599px) {
	#pageTop a{
		padding:25px;
	}
	#pageTop a::before{
		top:20px;
		}
	#pageTop:hover a::before{
		top:15px;
		}
}

/* 共通
========================================== */
.imgBox{
	margin-bottom:18px;
	padding: 20px;
	text-align: center;
	background-color: #fff;
	box-shadow: 0 0 10px #ccc;
}

.imgBox img{
	max-width: 100%;
	height: auto;
}

.imgBox iframe{
	width: 100%;
	height: 100%;
	aspect-ratio: 160/90;
}

.bg_gray{
	position: relative;
	background-color:rgba(243, 244, 245,0.7);}

@media screen and (max-width:599px) {
	.imgBox{
		margin-bottom:10px;
	}
}

/* =======================================

	下層ページ

========================================== */
#topicPath{
	line-height: 1.2;
	margin: 0 auto;
	padding-top: 15px;
	width: 1000px;
	text-align: right;
}

#topicPath li{
	display: inline;
	list-style-type: none;
	font-size: 14px;}

#topicPath li:before {
	content: "/";
	padding: 0 10px;}

#topicPath li:first-child:before {content: none;}

#topicPath li a{color: #555;}

#topicPath li .home{color:#E65401;}

@media screen and (max-width: 1000px) {
	#topicPath{
		padding:10px 20px;
		width:100%;
	}
}

@media screen and (max-width:768px) {
	#topicPath li{
		font-size: 12px;
	}
}



/* Pager（共通）
========================================== */
.main_pager{
	position: relative;
	margin: 60px auto 0;
	padding-bottom: 80px;
	width: 1000px;
}

.main_pager li.prev,
.main_pager li.next{
	position:absolute;}

.main_pager li.prev{
	top:0;
	left:0;}
.main_pager li.next{
	top:0;
	right:0;
	text-align:right;}


.main_pager li a{
	position: relative;
	transition: all .3s;
}

.main_pager li a::before{
	content: "";
	position: absolute;
	top:50%;
	margin-top: -7px;
	width: 10px;
	height: 10px;
	transition: all .3s;
}

.main_pager li.prev a::before{
	left: 20px;
	border-top: solid 2px #fff;
	border-left: solid 2px #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.main_pager li.next a::before{
	right: 20px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.main_pager li a:hover{background-color: #002b5e;}
.main_pager li.prev a:hover::before{left: 15px;}
.main_pager li.next a:hover::before{right: 15px;}

.main_pager li a{
	padding: 15px 50px;
	background-color:#002b5e;
	color: #fff;
	text-decoration: none;
}

@media screen and (max-width:1000px){
	.main_pager{
		width: 100%;
	}

	.main_pager li.prev{left:60px;}
	.main_pager li.next{right:60px;}
}


@media screen and (max-width:768px){
	.main_pager{
		padding-bottom: 20px;
	}

	.main_pager li.prev{left:20px;}
	.main_pager li.next{right:20px;}

}

@media screen and (max-width:599px){
	.main_pager li.prev,
	.main_pager li.next{
		margin-bottom:30px;
		width:100%;
		position:static;
		text-align:center;}

	.main_pager li.prev{
		margin-bottom: 50px;
	}
}

/* 対話
========================================== */
.talk_box{
}

.talk_box dl{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom:30px;
}

.talk_box dt{
	width: 200px;
	text-align: center;
}
.talk_box dt span{
	line-height: 1.2;
	display: block;
	margin-top: 10px;
	font-size: 120%;
	font-weight: bold;
}

.talk_box dd{
	position: relative;
	width: calc(100% - 240px);
	padding: 1.5em 30px;
	background-color: #fff;
	border: 2px solid #222;
	border-radius: 10px;
}
.talk_box dd:before,
.talk_box dd:after{
	content: "";
	position: absolute;
	top: 30px;
	left: -45px;
	width: 0;
	height: 0;
}
.talk_box dd:before{
	border-style: solid;
	border-color:#222 transparent transparent transparent;
	border-width: 40px 0 0 45px;
}
.talk_box dd:after{
	z-index: 10;
	top: 32px;
	left: -40px;
	border-style: solid;
	border-color:#fff transparent transparent  transparent;
	border-width: 35px 0 0 40px;
}

.talk_box .partner dd:before,
.talk_box .partner dd:after{
	left: auto;
	right: -45px;
}

.talk_box .partner dd:before{
	border-color: #222 transparent transparent transparent;
	border-width:40px 45px 0 0;
}
.talk_box .partner dd:after{
	right: -40px;
	border-color:#fff transparent transparent  transparent;
	border-width: 35px 40px 0 0;
}

.talk_box .partner{
	margin-bottom: 30px;
	flex-flow: row-reverse;
}

.talk_box .yokogawa dt span{color:#009DC4;}
.talk_box .yokogawa dd{border-color:#009DC4;}
.talk_box .yokogawa dd:before{border-color:#009DC4 transparent transparent transparent;}

.talk_box .kyokuto dt span{color:#98999D;}
.talk_box .kyokuto dd{border-color:#98999D;}
.talk_box .kyokuto dd:before{border-color:#98999D transparent transparent transparent;}

.talk_box .wakita dt span{color:#00335a;}
.talk_box .wakita dd{border-color:#00335a;}
.talk_box .wakita dd:before{border-color:#00335a transparent transparent transparent;}



@media screen and (max-width: 599px) {
	.talk_box dl{
		display: block;
		margin-bottom: 30px;
	}
	.talk_box dt{
		margin-bottom: 10px;
		width: 100%;
	}
	
	.talk_box dd{
		width: 100%;
		padding: 20px;
	}
	
	.talk_box dd:before,
	.talk_box dd:after{
		top: -30px;
		left:20px;
	}
	
	.talk_box dd:before{
		border-color: transparent transparent #222 transparent;
		border-width: 0 0 30px 30px;
	}
	.talk_box dd:after{
		top: -25px;
		left:23px;
		border-color: transparent transparent #fff transparent;
		border-width: 0 0 25px 25px;
	}
	.talk_box .partner dd:before{
		right:20px;
		border-width: 30px 0 0 30px;
		border-color: transparent transparent transparent #222;
	}
	.talk_box .partner dd:after{
		right:23px;
		border-width: 25px 0 0 25px;
		border-color: transparent transparent transparent #fff;
	}
	.talk_box .yokogawa dd:before{border-color:transparent transparent transparent #009DC4;}
	.talk_box .kyokuto dd:before{border-color:transparent transparent transparent #98999D;}
	.talk_box .wakita dd:before{border-color:transparent transparent transparent #00335a;}
	
}

/* 対話リスト
========================================== */
.opinion_list{}

.opinion_list > li{
	position: relative;
	margin-bottom: 20px;
}

.opinion_list > li::before{
	content: "";
	position: absolute;
	top:5px;
	left:-55px;
	background: url("images/icon_talk.png") left top no-repeat;
	width: 46px;
	height: 46px;
}

.opinion_list li .title{
	line-height: 1.5;
	display: block;
	margin-bottom: 20px;
	padding: 15px 0;
	border-bottom: 1px solid #222;
	color: #222;
	font-size: 100%;
	font-weight: normal;
}

.opinion_list li a:hover{
	color:#00316a;
	text-decoration: underline;
}

.opinion_list li .text ul{
	margin-bottom: 20px;
}

.opinion_list li .text ul li{
	position: relative;
	margin-bottom:10px;
	padding-left:18px;
}
.opinion_list li .text ul li::after {
	display: block;
	content: '';
	position: absolute;
	top: .5em;
	left:0;
	width: 10px;
	height: 10px;
	background-color: #00316a;
	}



@media screen and (max-width: 1000px) {
	.opinion_list{
		margin-left: 40px;
	}
}

@media screen and (max-width: 768px) {
	.opinion_list{
		margin-left: 40px;
	}
	.opinion_list li::before{
		top:10px;
		left:-50px;
		width: 35px;
		height: 35px;
		background-size: contain;
	}
}

@media screen and (max-width: 599px) {

}

/* ボタン
========================================== */
.link_btn {
    margin: 60px auto 40px;
    width: 60%;
}
.link_btn a {
    display: block;
    padding: 10px;
    background: #000;
    color: #fff;
    text-align: center;
    font-size: 18px;
    text-decoration: none;
    transition: 0.5s;
}

@media screen and (max-width: 599px) {
	.link_btn {
		width: 80%;
	}
	.link_btn a {
		font-size: 16px;
	}
}

/* ======================================================
   印刷用CSS（Chrome PDF用）
========================================================= */
@media print {
  .break-before { break-before: page; page-break-before: always; }
  .break-after  { break-after:  page; page-break-after:  always; }
  .avoid-break  { break-inside: avoid; page-break-inside: avoid; }

  h2 { break-after: avoid; page-break-after: avoid; }
  thead { display: table-header-group; }
  tfoot { display: table-footer-group; }

  @page { size: A4; margin: 12mm; }
}

/* YouTubeファサード
========================================== */
.yt-facade{
	position: relative;
	cursor: pointer;
	aspect-ratio: 16/9;
	overflow: hidden;
}
.yt-facade img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.yt-facade__play{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 68px;
	height: 48px;
	padding: 0;
	border: 0;
	border-radius: 12px;
	background: rgba(0, 0, 0, .75);
	cursor: pointer;
	transition: background .2s;
}
.yt-facade__play::before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	margin: 0 auto;
	border-style: solid;
	border-width: 10px 0 10px 16px;
	border-color: transparent transparent transparent #fff;
}
.yt-facade:hover .yt-facade__play,
.yt-facade:focus-within .yt-facade__play{
	background: #f00;
}