
/*====ページ全体
==========================================================*/
body {
	margin: 0 auto;
	padding: 0;
	font-family: "メイリオ","Hiragino Kaku Gothic ProN",sans-serif;
	background:url(bg.jpg) center top;
	background-attachment: fixed;
	width: 100%;
	word-wrap: break-word;
	overflow-wrap: break-word;
	font-size: 20px;
}

img {
	border:none;
	margin: 0;
	padding: 0;
	line-height: 0;
	vertical-align: bottom;
	max-width: 100%;
}

table {
	max-width: 1000px;
	border-collapse: collapse;
	border-spacing: 0;
}

.social_buttons {
	margin: 0px auto 0;
	padding: 20px 20px 0;
	max-width: 1160px;
	background-color: #fff;
}

.nbo_header {
	text-align: center;
}

.nbo_header img{
	vertical-align: top;
}

#ContentsArea {
	background:url(img_bg.jpg) center top no-repeat;
	margin:0;
	padding:0;
	text-align: left;
	width:100%;
	overflow: hidden;
}

#header {
	background-color: #fff;
	width: 100%;
}

a {
	text-decoration: none;
	color:#4AC3E2;
	border:none;
}

a:hover	{
	color:#37AFFF;
	text-decoration:underline;
}

.triangle{
	color: #D1DADE;
}

.Video {
	display: block;
	margin: 0 auto 0;
	max-width: 820px;
	padding-bottom: 20px;
}

.Videotitle{
	font-size: 80%;
	margin-top: 20px;
	color: #000;
	font-weight: bold;
	text-align: center;
	padding-bottom: 5px;
}

.localFooter {
	background-color: #fff;
	max-width: 1180px!important;
}

#bpGlobalFooter{
	max-width: 1200px!important;
}

h1 {
	max-width: 1200px;
	max-height: 450px;
	margin:0;
	padding:0;
	line-height:0;
	background:url(img_main01.jpg) center top no-repeat;
}


h2 { margin:0px auto 0;
	color: #000;
	max-width: 1150px;
	font-size: 30px;
	font-weight: bold;
	letter-spacing: -0.1em;
	background-color: #fff;
}

h2#ttl1,h2#ttl2,h2#ttl3,h2#ttl4,h2#ttl5,h2#ttl6,h2#ttl7,h2#ttl8,h2#ttl9 {
	font-weight: bold;
	margin-top: 20px;
	padding: 15px 0px 0 0px;
	text-align: center;
	line-height: 1.2;
	font-family: YuGothic,/* Mac用 */
	'Yu Gothic', /* Windows用 */
	sans-serif;
	background:url(h2_bg.png) left bottom no-repeat;
	background-size: contain;
	aspect-ratio: 1150/70;
	margin-bottom: 0.5em;
}



h2#ttl1W,h2#ttl2W,h2#ttl3W {
	background:url(ttl_bg02.jpg) left top;
	padding: 5px 10px 5px 30px;

}

h2.ttl_con {
	color: #fff;
	font-weight: bold;
	font-size: 17px;
	padding: 2px 0 2px 10px;
	font-family: YuGothic,/* Mac用 */
	'Yu Gothic', /* Windows用 */
	serif;
	background-color: #023656;
}


h2.ttl_conW {
	background-color: #01A982;
	padding: 5px 0 5px 10px;
}


.blue_prof {
	margin-top: 30px;
  background-image: linear-gradient(180deg, rgba(65, 164, 253, 1), rgba(18, 95, 173, 1));
	width: auto;
}

.blue_prof .photo1{
	max-width: 1920px;
	text-align: center;
	padding: 0;
}


.eachTextAnime span{opacity: 0;}
.textanimettl span {
	--main-delay: 0.05s;/* ここをベースにする */
}

.textanimettl span:nth-child(1)  {--delay-num: 1}
.textanimettl span:nth-child(2)  {--delay-num: 2}
.textanimettl span:nth-child(3)  {--delay-num: 3}
.textanimettl span:nth-child(4)  {--delay-num: 4}
.textanimettl span:nth-child(5)  {--delay-num: 5}
.textanimettl span:nth-child(6)  {--delay-num: 6}
.textanimettl span:nth-child(7)  {--delay-num: 7}
.textanimettl span:nth-child(8)  {--delay-num: 8}
.textanimettl span:nth-child(9)  {--delay-num: 9}
.textanimettl span:nth-child(10) {--delay-num: 10}
.textanimettl span:nth-child(11) {--delay-num: 11}
.textanimettl span:nth-child(12) {--delay-num: 12}
.textanimettl span:nth-child(13) {--delay-num: 13}
.textanimettl span:nth-child(14) {--delay-num: 14}
.textanimettl span:nth-child(15) {--delay-num: 15}
.textanimettl span:nth-child(16) {--delay-num: 16}
.textanimettl span:nth-child(17) {--delay-num: 17}
.textanimettl span:nth-child(18) {--delay-num: 18}
.textanimettl span:nth-child(19) {--delay-num: 19}
.textanimettl span:nth-child(20) {--delay-num: 20}
.textanimettl span:nth-child(21) {--delay-num: 21}
.textanimettl span:nth-child(22) {--delay-num: 22}
.textanimettl span:nth-child(23) {--delay-num: 23}
.textanimettl span:nth-child(24) {--delay-num: 24}
.textanimettl span:nth-child(25) {--delay-num: 25}
.textanimettl span:nth-child(26) {--delay-num: 26}
.textanimettl span:nth-child(27) {--delay-num: 27}
.textanimettl span:nth-child(28) {--delay-num: 28}
.textanimettl span:nth-child(29) {--delay-num: 29}
.textanimettl span:nth-child(30) {--delay-num: 30}
.textanimettl span:nth-child(31) {--delay-num: 31}
.textanimettl span:nth-child(32) {--delay-num: 32}
.textanimettl span:nth-child(33) {--delay-num: 33}
.textanimettl span:nth-child(34) {--delay-num: 34}
.textanimettl span:nth-child(35) {--delay-num: 35}
.textanimettl span:nth-child(36) {--delay-num: 36}
.textanimettl span:nth-child(37) {--delay-num: 37}
.textanimettl span:nth-child(38) {--delay-num: 38}
.textanimettl span:nth-child(39) {--delay-num: 39}
.textanimettl span:nth-child(40) {--delay-num: 40}
.textanimettl span:nth-child(41) {--delay-num: 41}
.textanimettl span {
	animation-delay: calc(var(--main-delay) * var(--delay-num))!important;
} 
.eachTextAnime.appeartext.on span{ animation:text_anime_on 1s ease-out forwards; }
@keyframes text_anime_on {
	0% {opacity:0;}
	100% {opacity:1;}
}

h3 {
	padding: 4px 15px 2px;
	margin: 0 0 10px;
	background-color: #787878;
	color: #fff;
	font-size: 14px;
	border-radius: 50px;
	font-family: YuGothic,/* Mac用 */
	'Yu Gothic', /* Windows用 */
	serif;
}

h4 {
	margin:5px 5px;
	padding:0;
	line-height:0;
}

p {
	margin:0;
	padding:0 0 10px;
}

.abs {
	position: absolute;
}

.shoulder{
	text-align: right;
	font-size: 15px;
	font-weight: bold;
	padding-right: 20px;
	background-color: #fff;
}
.caption {
	display: block;
	padding: 5px;
	margin-bottom: 10px;
	font-size: 80%;
	line-height: 1.3;
	color: white;
	background-color: #1651BD;
}

.link a{
	display: block;
	border-bottom: 1px dotted #ccc;
	padding: 5px 20px;
	margin: 10px 20px;
}
.link a:nth-last-child(1)
{
	border-bottom: 1px dotted #fff
}

.bdt { border-top: 1px solid #000; }
.header_sp { display: none;}

.related_contents {
    display: flex;
    max-width: 920px;
    margin: 0 auto;
	flex-wrap: wrap;
	justify-content: space-between;

}

.g_menu {
	background-color: #000;
	margin: 0 auto;
	max-width: 1920px;
	padding-bottom: 10px;
}

.g_menu table {
	margin: 0 auto;
	padding-bottom: 20px;
	max-width: 1920px;
	padding: 0;
	border-spacing:0;
	border-collapse:collapse;
}


.g_menu table tr{
	margin: 0;
	padding: 0;
}


.g_menu table tr td {
	margin: 0;
	padding: 0;
	max-height: 100%!important;
	max-width: 100%!important;
	line-height:0;
}

.g_menu p{
	text-align: center;
	max-width: 1452px;
	max-height: 180px;
	margin: 0 auto;
	padding: 20px 0 20px;
}

.g_menu2 {
	margin: 30px auto;
	max-width: 704px;
	text-align: center;
}
.g_menu2 div.butbox,.g_menu2 div.but2box {
	margin-right: 1px;
	margin-bottom: 1px;
	float: left;
}
.g_menu2 div.butlbox {
	float: left;
}

.photolo {
	margin: 30px 0;
}

.photo1 {
	max-width: 1200px;
}

.photo2 {
	float: right;
	max-width: 500px;
	margin-left: 20px;
	margin-right: -190px;
}

.photo3 {
	max-width: 820px;
	margin:0 auto;
}

.photo4 {
	max-width: 820px;
	margin:0 auto;
}


.lead {
	font-size: 88%;
	max-width: 1000px;
	margin: 0 auto;
	background-color: #fff;
	padding: 20px 100px 20px;
	opacity:0.95;
}
.leadtxt {
	display: block;
	text-align: right;
}

.cl {
	clear: both;
}
.fl {
	float: left;
}
.fr {
	float: right;
}

.flogo {
	float: left;
	margin: 0px 0 30px 0;
}


.smlTxt {
	font-size: 80%;
/	font-weight: bold;
}

.smlTxt span{
	display: block;
	font-weight: normal;
}

.figure {
	margin: 10px auto 0px;
	padding-bottom: 20px;
	max-width: 820px;
	border-right: 1px solid #0054A7;
	border-left: 1px solid #0054A7;
	border-bottom: 1px solid #0054A7;
}

.figure p{
	margin: 0!important;
	padding-bottom: 0!important;
}

.figure .figTtl{
	padding: 5px 10px 5px!important;
	font-size: 90%;
	background-color: #023656;
	color: #fff;

}

.figure .figCap{
	padding: 5px 10px 5px!important;
	font-size: 80%;
	background-color: #0054A7;
	color: #fff;
	line-height: 1.5!important;
}

/*====ヘッダイメージ
==========================================================*/



#MainImgArea {
	max-width: 1200px;
	padding: 0;
	margin: 0 auto 0;
	background:url(img_main01.jpg) center top no-repeat;
	aspect-ratio: 1200/450;
	background-size: contain;
}

#MainImgArea span{
	margin: 0;
	padding: 0;
}

/*====コンテンツサイズ
==========================================================*/
#MainArea{
	width: 100%;
	margin:0;
	padding: 0;
	color:#444;
}
*html #MainArea{
	width: 100%;
}

#LeftArea{
	padding: 0;
	float:none;
	background-color: #fff;
}

.whitearea {
	max-width: 1200px;
	margin: 20px auto;
	opacity:0.95;
}


.whitearea2 {
	background-color: #fff;
	max-width: 1200px;
	margin: 0 auto;
}
.nxt_header {
	max-width: 1000px;
	margin: 0 auto;
}

/*====LeftArea
==========================================================*/

a.alpha:hover {
	opacity: .75; /* Standard: FF gt 1.5, Opera, Safari */
	filter: alpha(opacity=75); /* IE lt 8 */
	-ms-filter: "alpha(opacity=75)"; /* IE 8 */
	-khtml-opacity: .75; /* Safari 1.x */
	-moz-opacity: .75; /* FF lt 1.5, Netscape */
}
/* Page ------------------------------*/

#pag1 {
	background-color: #fff;
}

/* 各記事の設定 ------------------------------*/
.Account{
	margin: 0 auto;
	padding: 0 5px 0 5px;
/	max-width: 960px;
/	font-size: 18px;
	background: #fff;
	line-height: 1.8;
}

.acc {
	margin:10px 20px 0;
}

.AccountImg {
	margin:0 10px 5px 0;
	padding:0;
	float:left;
}
.acc .sp {
	margin:0 0 10px 0;
	padding:0 0 10px 0;
	font-weight: bold;
	color: #366F82;
}
.acc .sp2 {
	margin:15px 0;
	padding:15px 0;
	font-weight: bold;
	border-top: #CCC dashed 1px;
}

/* ContactAreaの設定 ------------------------------*/

#ContactArea {
	margin:0;
	padding:10px;
}

#Contact {
	margin:5px;
	padding:10px 0 0 0;
}

#ContactTxt {
	margin:0 0 0 10px;
	padding:0;
	float:left;
	line-height:1.5em;
}

.contact {
	word-break: break-all;
}

#ContactTxt p{
	margin:0px;
}
#ContactImg {
	margin:0 0 0 0;
	float:right;
}

/* PageTopの設定 ------------------------------*/
.PageTop {
	margin:0 110px 0;
	padding:0;
}

/*====Add
==========================================================*/
.mt20
{
	margin-top: 20px;
}

.mt10
{
	margin-top: 10px;
}


/* margin-top */
.mt1{margin-top: 1px;}
.mt2{margin-top: 2px;}
.mt3{margin-top: 3px;}
.mt4{margin-top: 4px;}
.mt5{margin-top: 5px;}
.mt10{margin-top: 10px;}
.mt15{margin-top: 15px;}
.mt20{margin-top: 20px;}
.mt30{margin-top: 30px;}
.mt40{margin-top: 40px;}
.mt50{margin-top: 50px;}
.mt60{margin-top: 60px;}

/* margin-right */
.mr1{margin-right: 1px;}
.mr2{margin-right: 2px;}
.mr3{margin-right: 3px;}
.mr4{margin-right: 4px;}
.mr5{margin-right: 5px;}
.mr10{margin-right: 10px;}
.mr15{margin-right: 15px;}
.mr20{margin-right: 20px;}
.mr30{margin-right: 30px;}

/* margin-bottom */
.mb0{margin-bottom: 0px;}
.mb1{margin-bottom: 1px;}
.mb2{margin-bottom: 2px;}
.mb3{margin-bottom: 3px;}
.mb4{margin-bottom: 4px;}
.mb5{margin-bottom: 5px;}
.mb10{margin-bottom: 10px;}
.mb15{margin-bottom: 15px;}
.mb20{margin-bottom: 20px;}
.mb30{margin-bottom: 30px;}
.mb50{margin-bottom: 50px;}


/* margin-left */
.ml1{margin-left: 1px;}
.ml2{margin-left: 2px;}
.ml3{margin-left: 3px;}
.ml4{margin-left: 4px;}
.ml5{margin-left: 5px;}
.ml10{margin-left: 10px;}
.ml15{margin-left: 15px;}
.ml20{margin-left: 20px;}

/* padding-top */
.pt1{padding-top: 1px;}
.pt2{padding-top: 2px;}
.pt3{padding-top: 3px;}
.pt4{padding-top: 4px;}
.pt5{padding-top: 5px;}
.pt10{padding-top: 10px;}
.pt15{padding-top: 15px;}
.pt20{padding-top: 20px!important;}

/* padding-right */
.pr1{padding-right: 1px;}
.pr2{padding-right: 2px;}
.pr3{padding-right: 3px;}
.pr4{padding-right: 4px;}
.pr5{padding-right: 5px;}
.pr10{padding-right: 10px;}
.pr15{padding-right: 15px;}
.pr20{padding-right: 20px;}

/* padding-bottom */
.pb0{padding-bottom: 0px;}
.pb1{padding-bottom: 1px;}
.pb2{padding-bottom: 2px;}
.pb3{padding-bottom: 3px;}
.pb4{padding-bottom: 4px;}
.pb5{padding-bottom: 5px;}
.pb10{padding-bottom: 10px;}
.pb15{padding-bottom: 15px;}
.pb20{padding-bottom: 20px!important;!}

/* padding-left */
.pl1{padding-left: 1px;}
.pl2{padding-left: 2px;}
.pl3{padding-left: 3px;}
.pl4{padding-left: 4px;}
.pl5{padding-left: 5px;}
.pl10{padding-left: 10px;}
.pl15{padding-left: 15px;}
.pl20{padding-left: 20px!important;}
.pl30{padding-left: 30px;}
.pl40{padding-left: 40px;}

/* padding */
.pg1{padding: 1px;}
.pg2{padding: 2px;}
.pg3{padding: 3px;}
.pg4{padding: 4px;}
.pg5{padding: 5px;}
.pg10{padding: 10px;}
.pg15{padding: 15px;}
.pg20{padding: 20px;}
.pg30{padding: 30px;}
.pg40{padding: 40px;}

.line {
    border-bottom: 1px dotted #696969;
}

.kome {font-size: 80%; padding: 5px 10px 0 0;}

.kkb {
	color: #868686;
	font-weight: bold;
}

#bookmarkBox {
    float: left;
    width: 300px;
}

br {line-height: 0.8;}

.nam {font-weight: bold;}


.mod {
	color: #000;
	font-weight: bold;
}

.name {
	font-weight: bold;
	color: #0054A7;
}


#backnumber {
	display: block;
	margin-top: 10px!important;
}


.globalFooter {
	background-color: #fff;
	padding: 15px 0!important;
}

.named {
	font-weight: bold;
	color: #3339cc;
}	

.named2 {
	font-weight: bold;
	color: #0066CC;
}

.named3 {
	font-weight: bold;
	color: #0066CC;
}

	
.figttl {
	padding: 2px 5px 0;
	font-weight: bold;
	display: block;
	background-color: #dcdcdc;
}
.figcap {
	color: #fff;
	padding: 5px 10px;
	line-height: 1.4;
	font-size: 14.5px;
	display: block;
	background-color: #0054A7;
	margin-bottom: 15px;
}

.linkcap {
	padding: 5px 2px;
	max-width: 456px;
	font-size: 12px;
	letter-spacing: -0.01em;
	line-height: 1.4;
}

.accS {
	padding: 0 5px 0;
	margin: 0 auto;
	font-size: 18px;
}

.accST {
	padding: 35px 90px 35px;
	margin: 0 auto 0;
	background-color: #fff;
	font-size: 18px;
}

.sp_nxt_header { display:none; }
.sp { display:none; }
.sp_bio { display:none; }
.spbr { display:none; }

.column {
	background-color: #ECECEC;
	margin: 15px 0;
}

.column .cttl {
	padding: 5px;
	color: #70C1D3;
	background:url(columnbg.jpg) left center;
	font-size: 20px;
	font-weight: bold;
}

.column .txta {
	padding: 5px 10px;
}

.column .foot {
	padding: 5px 10px;
}

.column .foot a{
	color: #444!important;
}

.column span {
	padding: 2px 5px;
	margin-right: 15px;
	display: inline;
	background-color: #F2881A;
	color: #fff;
	margin-bottom: 15px;
	border-radius: 4px;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.4;
}


@media screen and (max-width:1452px)
	{
.g_menu {
	margin-left: 0!important;
}

	}

@media screen and (max-width:1220px)
	{
#ContentsArea {
	background:none;
	}


	}

@media screen and (max-width:1000px)
	{
#ContentsArea {
	background:none;
	}

.lead {
	font-size: 80%;
	max-width: 980px;
	margin: 0 auto;
	padding: 20px 10px;
}


.Account{
	font-size: 16px;
	line-height: 1.8;
	margin:0!important;
	padding: 0!important;
	}

.whitearea2 {
	margin-top: 0;
}

#MainImgArea {
	max-width: 1160px;
	margin: 0 auto 0px;
	padding: 0;
}

.accS {
	padding: 0 20px 0;
	margin: 0 auto;
}

.accST {
	padding: 30px 20px 0;
	margin: 0 auto;
}


}

@media screen and (min-width:641px) and (max-width:1000px){


.banner {
	width: 49%;
	min-height: auto;
	margin-bottom: 10px;
	}



h2 {
	font-size: 26px;
	}
}

@media screen and (max-width:721px) {

.pc { display:none; }
.sp { display:inline; }


}

@media screen and (max-width:640px) {


h2 {
	letter-spacing: 0em;
}

.lead {
	font-size: 70%!important;
	max-width: 820px;
	margin: 0px;
	padding-top: 20px;
}
.shoulder{
	font-size: 12px;
	padding-right: 10px;
}


#MainArea{
}

.g_menu p{
	text-align: center;
	padding: 0;
}

.link a {
	margin: 10px 0;
}

#LeftArea {
	padding-top: 15px;
	padding-left: 0;
	padding-right: 0;
	width: 100%;
	margin: 0 auto;
	border-left: none;
	border-right: none;
	}


.acc { 
	margin-left: 0;
	margin-right: 0;
	}

.accS {
	padding: 0 10px 0;
	margin: 0 auto;
	font-size: 15px;
}

.accST {
	padding: 10px 10px 10px;
	margin: 0 auto;
	font-size: 15px;
}


h2.ttl_con {
	font-size: 4vw;
	padding: 7 15px;
	}

.header_pc { display: none;}

.figttl { 
	padding-left: 10px;
	padding-right: 10px;
	}

.header_sp { 
	display: block;
	padding: 8px 0;
	text-align: center;
	}
.photoH {
	max-width: 250px;
	}

.PageTop {
	margin:0 10px 0;

	}
.banner {
	min-height: auto;
	margin-bottom: 15px;
	}

.related_contents {
	flex-direction: column;
	align-items: center;
	}
}

@media screen and (min-width:401px) and (max-width:640px){

h2 { font-size: 3vw; 
	letter-spacing: 0em;
}

#ContactArea,
.linkcap {
	font-size: 3vw;
	}
.br-pc { display:none; }


.lead {
	font-size: 90%;
	max-width: 820px;
	margin: 0px;
	padding-top: 15px;
}


.flogo {
	float: none;
	margin: 0px 0 10px 0;
}


}

@media screen and (max-width:450px) {
body {
	background-color: #fff;
}

.flogo {
	float: none;
	margin: 0px 0 10px 0;
}

.whitearea2 {
	margin-top: 0;
	font-size: 3.5vw;
}

h2 {
	letter-spacing: 0em;
}

.nxt_header { display:none;}
.sp_nxt_header { display:inline; 
	width: 100%;
	text-align: center;
}

.bdt { display:none; }
.sp_bio {
	display:inline; 
	width: 100%;
	padding-bottom: 10px;
	font-size: 14PX;
}

.photoH {
	max-width: 150px;
}


.bio_l {width: 100%;
	padding: 5px 0px 10px 5px;
}
.bio_r {width: 100%;
	padding: 5px 5px 5px 0px;
}
/br.sp { display: none; }
h2#ttl1, h2#t, 
tl2, h2#ttl3, h2#ttl4, h2.ttl_con {
	border-radius: 0px;
}

.acc .sp {
    margin: 0 0 -1px 0;
    padding: 0 0 0 0;
}
.br-pc { display:none; }


.cb{
  clear: both;
}
.biotxt { font-size: 14px; }
}

@media screen and (max-width:400px) {
h2 { font-size: 3.5vw;
	letter-spacing: 0em;
}

#ContactArea,
.linkcap {
    font-size: 4vw;
}

.header_sp img { max-width: 170px; }
.Account {
    font-size: 15px;
    line-height: 1.6;
}
.figttl {
    padding-left: 7px;
    padding-right: 0px;
}
}
@media screen and (max-width:330px) {
.figttl {
    padding-left: 0px;
    padding-right: 0px;
}
.Account {
    font-size: 13px;
    margin: 0 auto;
    line-height: 1.6;
}

.accS {
	padding: 0;
	margin: 10 auto;
}

.accST {
	padding: 5px;
	margin: 10px auto 0;
}

}

@media(min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
  }
}