html {
	/*overflow-x : hidden;*/
	text-align: center;
}


img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

body {
	font-size: 14.5px;
	width: 100%;
	overflow-x: hidden;
	line-height: 200%;
}

h1,
h2,
h3,
h4,
h5 {
	margin: 0px;
	padding: 0px;
}

p {
	margin: 0px;
	padding: 0px;
}

ul,
li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

.pointer {
	cursor: pointer;
}

.pointer:hover,
a img:hover {
	opacity: 0.6;
}

.hover-non,
.hover-non img:hover {
	opacity: 1.0 !important;
}

.indent {
	text-indent: 1em;
}

.container {
	position: relative;
	width: 880px;
	text-align: left;
}




.pl-non {
	padding-left: 0px !important;
}

.mt,
.mt-sm {
	margin-top: 20px;
}

p.mt2 {
	line-height: 200%;
}


.mt-lg {
	margin-top: 40px;
}

.mt-lg2 {
	margin-top: 80px;
}

#menu {
	padding-top: 8px;
	margin-left: 50px;
}

#menu li {
	display: inline;
	font-weight: 800;
}

#menu a {
	margin-right: 14px;
	color: #9b8658;
	font-size: 12px;
}

#icon-contact {
	margin-top: -4px;
	margin-left: 4px;
	vertical-align: middle;
}



.border-top {
	margin: 0px;
	height: 6px;
	background: url(../img/border-top.webp) no-repeat center center;
	background-size: 100% 6px;
}

.border-bottom {
	margin: 0px;
	margin-top: -3px;
	height: 6px;
	background: url(../img/border-bottom.webp) no-repeat center center;
	background-size: 100% 6px;
}

.border-left,
.border-left-smxs {
	padding-left: 30px;
	border-left: solid 1px #e1ded1;
}

.cicle-white-maru {
	padding: 10px 30px;
	padding-bottom: 60px;
	;
	padding-right: 120px;
	background: rgba(255, 255, 255, 0.2);
	border: solid 1px #CCCCCC;
	line-height: 200%;
	font-weight: 800;
	text-align: center;
	font-size: 13px;

	border-radius: 40px;
	-webkit-border-radius: 40px;
	-moz-border-radius: 40px;
}

.cicle-frame {
	background: #FFFFFF url(../img/backframe-center.webp) repeat-y;
	background-size: 100% auto;
	font-size: 14px;
}

.cicle-frame .up {
	background: url(../img/backframe-up.webp) no-repeat left top;
	background-size: 100% auto;
}

.cicle-frame dd {
	font-size: 13px;
	line-height: 200%;
}

.cicle-frame .bottom {
	background: url(../img/backframe-bottom.webp) no-repeat left bottom;
	background-size: 100% auto;

	padding: 20px 20px;
}

.non-image {
	background: #FFFFFF;
}

.cicle-frame .up2 {
	background: url(../img/backframe2-up.webp) no-repeat left top;
	background-size: 100% auto;
}

.cicle-frame .bottom2 {
	padding: 30px;
	background: url(../img/backframe2-bottom.webp) no-repeat left bottom;
	background-size: 100% auto;
}

.judge dt {
	text-align: left;
}

.judge dt p.grapha img {
	max-width: 100%;
}

.judge dt p.title {
	padding-top: 20px;
	font-size: 20px;
	text-align: center;
}

.judge dd {
	padding-top: 10px;
	font-size: 12px;
	line-height: 170%;
	text-align: left;
}

.title2 {
	font-size: 20px;
	font-weight: 800;
}

#main {
	position: relative;
	background: #000000;
}

#main #sns {
	margin-top: 20px;
	position: absolute;
	right: 0;
	text-align: right;
}

#main #sns a {
	margin-top: 20px;
	display: block;
}

#main #obi {
	position: absolute;

	width: 100%;
	bottom: 5%;
}

#main2 {
	position: relative;
	padding-top: 58px;
	padding-bottom: 50px;
	background: #000000 url(../img/main2.webp) no-repeat top center;
	background-size: 100% 100%;
	color: #FFFFFF;
	font-size: 18px;
	min-height: 614px;
}

#main2 #toro {
	position: absolute;
	top: 50%;
	margin-top: -240px;
	right: -10px;
}

#message {
	padding-top: 40px;
	padding-bottom: 40px;

}

#message .container {
	margin-top: 40px;
	width: 965px;

}

#message .frame,
.rank45 .frame {
	padding-top: 1px;
	background: url(../img/message/frame-up.webp) no-repeat;
	min-height: 330px;
	color: #FFFFFF;
}

#message .frame .up,
.rank45 .frame .up {
	padding-bottom: 1px;
	background: url(../img/message/frame-bottom.webp) no-repeat left bottom;

}

#message .frame .center,
.rank45 .frame .center {
	padding: 30px;
	border-left: solid 3px #d4961d;
	border-right: solid 3px #d4961d;
}


#main3 {
	padding-top: 250px;
	background: #393939 url(../img/backline.webp) no-repeat top center;
	line-height: 180%;
}

#main3-1 {
	padding: 0 13px;
}

#main3-2 {
	margin-top: -100px;
	padding-top: 0px;
	padding-bottom: 250px;
}

#main4{
    padding: 60px 0px 100px;
	background : url(../img/backphoto.webp) no-repeat left bottom;
	background-size : 100% auto;
	font-size : 12px;
	line-height : 250%;
}

#main4 .catchcopy1{
    margin: 1.25rem 0;
    font-size: 28px;
    font-weight: bold;
    text-align: left;
    letter-spacing: 1px;
    line-height: 1.8;
}

#main4 .catchcopy2{
    margin: 10px 0;
    font-size: 11px;
    font-weight: bold;
    letter-spacing: 1px;
}

#main4 img{
    width: 200px;
}

#main4-mt-xs p{
    margin: 1.25rem 0;
    line-height: 2;
}

#main5 {
	padding-top: 42px;
}

.dl-service {
	margin-top: 20px;
}

.dl-service dt {
	height: 240px;
}

.dl-service dd .body {
	padding-top: 25px;
	height: 140px;
	text-align: left;
	font-size: 13px;
	line-height: 200%;
}

/* #footer{
	margin-top : 70px;
	padding-top : 29px;
	padding-bottom : 70px;
	background : #000000;
	color : #FFFFFF;
} */

footer {
	color: #fff;
	font-size: 12px;
	text-align: center;
	border-top: 5px solid #e0d68a;
	background: #111;
	padding: 40px 0;
	font-family: 'Noto Sans JP', Meiryo, sans-serif;
}

footer p {
	font-size: 100%;
	vertical-align: baseline;
	border: 0;
	outline: 0;
	background: transparent;
	margin: 0;
	padding: 0;
}

footer .wrap {
	width: 1000px;
	margin: 0 auto;
	position: relative;
}

@media screen and (min-width: 768px) {

	/*pc*/
	footer .copy {
		font-size: 10px
	}
}

@media screen and (max-width: 767px) {

	/*sp*/
	footer {
		font-size: 8px;
		padding-bottom: 36px;
	}

	footer .wrap {
		width: 100%;
	}
}

.text-small {
	font-size: 50%;
}

.border-left2-smxs {
	background: url(../img/bou.webp) no-repeat left top;
}

.kizyun {
	margin-top: -5px;
}

.kizyun dt {
	margin-top: 5px;
}


.slick-prev,
.slick-next {
	position: absolute;
	top: 50%;
	margin-top: -24px;
	width: 29px;
	height: 49px;
	z-index: 9001;
}

.slick-prev,
.slick-prev:hover {
	left: 2%;
	background: url(../img/arrow-left.webp) no-repeat;
}

.slick-next,
.slick-next:hover {
	right: 2%;
	background: url(../img/arrow-right.webp) no-repeat;
}

.slick-prev:before,
.slick-next:before {
	content: "";
}

.slider-nav,
.slider-nav p {
	position: relative !important;
}

.slider-nav p {
	margin-top: 30px;
	margin-left: 15px;
}

.slide-dots {
	text-align: center;
}

.slide-dots li {
	padding: 0px;
	margin-right: 10px;
	margin-top: 20px;
	display: inline-block;
}

.slide-dots li button {
	text-indent: -9999px;
	background: url(/img/maru.webp) no-repeat;
	border: none;
	height: 13px;
}

.slide-dots li.slick-active button {
	background: url(/img/maru-a.webp) no-repeat;
}


.slider-nav .slick-active {
	border: solid 5px #393939 !important;
}

.slider-nav .slick-current {
	border: solid 5px #FFFFFF !important;
}



#bg-black {
	background: #393939;
}

#rank {
	margin-top: -50px;
	background: #393939;
}

.rank {
	margin-top: 50px;
	position: relative;
	overflow-x: hidden;
}

.rank .main-photo {
	min-height: 670px;
}

.btn-rank13 {
	padding-left: 14px;
}

.rank-title {
	position: absolute;
	top: 6px;
	left: 50%;
	margin-left: -490px;
	z-index: 9000;
}

.rank-title img {
	width: 290px;
}

.main-pic {
	position: relative;
}

.rank .container {
	width: 1080px;
}

.rank .frame {
	margin-top: 40px;

	min-height: 330px;
	background: url(../img/rank1/frame-up.webp) no-repeat;
	background-size: 100% auto;
	color: #FFFFFF;
}

.rank .frame .up {
	background: url(../img/rank1/frame-bottom.webp) no-repeat left bottom;
	background-size: 100% auto;
}

.rank .frame .center {
	padding: 40px 20px;
	border-left: solid 3px #d4971e;
	border-right: solid 3px #d4971e;
	background-size: 100% auto;
}


#rank2 .border-top {
	position: relative;
	background: url(../img/rank2/border.webp) no-repeat;
	background-size: 100% auto;
	z-index: 1000;
}

#rank2 .frame {
	background-image: url(../img/rank2/frame-up.webp);
}

#rank2 .frame .up {
	background-image: url(../img/rank2/frame-bottom.webp);
}

#rank2 .frame .center {
	border-left: solid 3px #aeaeae;
	border-right: solid 3px #aeaeae;
}


#rank3 .border-top {
	position: relative;
	background-image: url(../img/rank3/border.webp);
	z-index: 1000;
}

#rank3 .frame {
	background-image: url(../img/rank3/frame-up.webp);
}

#rank3 .frame .up {
	background-image: url(../img/rank3/frame-bottom.webp);
}

#rank3 .frame .center {
	border-left: solid 3px #be9164;
	border-right: solid 3px #be9164;
}




.active-photo {
	border: solid 5px #FFFFFF;
}

.rank .frame2 {
	margin-top: 40px;
	padding: 40px 20px;
	min-height: 370px;
	background: url(../img/rank1/frame2.webp) no-repeat;
	background-size: 100% auto;
	color: #FFFFFF;
}

.rank .frame2 .title2 {
	margin-top: 20px;
	text-align: center;
}

.rank45 .main-pic .slick-list {
	border: solid 5px #ffdf61;
}

.rank45 .frame {
	color: #FFFFFF;

}

.rank45 .center {
	padding: 30px 40px;
}

.rank45 .container {
	width: 920px;
}

.rank45 .arrow-left {
	left: -6%;
}

.rank45 .arrow-right {
	right: -6%;
}

.rank45 {
	margin-top: 30px;
	padding-top: 20px;
	border-top: solid 1px #444444;
}

#rank610 {
	margin-top: 50px;
	color: #FFFFFF;
	line-height: 120%;
}

#rank610 .container {
	margin-bottom: 40px;
	padding: 0px;
	width: 892px;
	background: url(../img/rank6/frame-up.webp) no-repeat;
	background-size: 100% auto;
}

#rank610 .container .up {
	background: url(../img/rank6/frame-bottom.webp) no-repeat left bottom;
	background-size: 100% auto;
}

#rank610 .container .center {
	padding: 20px;
	padding-top: 40px;
	background: url(../img/rank6/frame-center.webp) repeat-y;
	background-size: 100% auto;
}

#rank610 .indent2 {
	line-height: 170%;
}


#rank610 .title {
	margin-top: 5px;
}

#rank610 .total {
	margin-top: 10px;
}

#rank610 .photo img {
	height: 170px;
}

.rank710 {
	margin-top: 20px;
	padding-top: 20px;

	border-top: solid 1px #b3b3b3;

}

.rank610 {
	padding: 0 5px;
}

.title-sub {
	color: #ffe681;
	text-align: center;
	font-size: 21px;
	font-weight: 400;
	line-height: 35px;
}

#social {
	margin-top: 8px;
}

#social .li {
	margin-bottom: 10px;
	margin-left: 10px;
	display: inline-block;
}

#banner {
	position: relative;
	display: block;
}

#banner span {
	position: absolute;
	display: block;
	top: 50%;
	left: 20%;
	margin-top: -0.9em;
	font-size: 100%;
	color: #FFFFFF;
}

.photo-copy {
	margin-left: 15px;
	color: #FFFFFF;
}

.indent2 {
	padding-left: 1em;
	text-indent: -1em;
}

#rank610 .indent2 {
	line-height: 180%;
}

@media screen and (max-width: 1100px) {
	#rank1 .container {
		width: 98%;
	}
}

@media screen and (max-width: 767px) {
	body {
		font-size: 18px;
		min-width: 0px;
	}


	.container {
		width: 95%;
	}

	.width-max-lg {
		margin-left: -5%;
		width: 110%;
		max-width: 110%;
	}

	.mt-sm {
		margin-top: 0px;
	}

	.mt-xs {
		margin-top: 20px;
	}


	#main #sns {
		margin-top: 0px;
	}


	#main2 {
		padding-bottom: 120px;
		color: #FFFFFF;
		font-size: 18px;
		height: auto;
		background-position-y: bottom;
		background-size: auto 100%;
	}

	#main2 #toro {
		position: absolute;
		top: 50%;
		margin-top: -50px;
		bottom: 8%;
		right: 0px;
		width: 100px;
	}

	#main3-border {
		padding-top: 50px;
	}

	#main3 {
		margin-top: 0px;
		padding-top: 10px;
		background: #393939;
	}

	#main3-1 {
		height: auto;
	}

	#main3-1 .cicle-frame dl {
		padding: 0 5%;
	}

	#main3-1 .cicle-frame dt {
		padding: 0 15%;
	}

	#main3-2 {
		margin-top: 0px;
		padding-top: 50px;
		height: auto;
	}

	#main3-3 .cicle-frame {
		background: #FFFFFF;
	}

	#main3-3 .cicle-frame .bottom,
	#main3-3 .cicle-frame .up {
		background: none;
	}

	.judge {
		height: auto;
	}

	.judge dt .grapha {
		text-align: center;
	}

	.judge dt .grapha img {
		width: 70% !important;
	}

	.border-left-smxs {
		padding: 0px;
		padding-top: 30px;
		border-top: solid 1px #e1ded1;
		border-left: none;
	}

	#main4{
        padding: 50px 0px 60px;
		background : #c2e2ff url(../img/sp/backphoto.webp) no-repeat left bottom;
		background-size : 100% auto;
	}
    
    #main4 .catchcopy1{
        font-size: 20px;
    }

    #main4 img{
        width: 200px;
    }
    
	#main4-mt-xs{
		margin-top : 30px;
	}

	.service-title {
		margin-top: 50px;
	}

	.dl-service dt {
		height: auto;
	}

	.dl-service dd .body {
		height: auto;
		padding-bottom: 10px;
	}


	.border-left2-smxs {
		padding-left: 0px;
		border-left: none;
		background: none;
	}

	.cicle-white-maru {
		padding-right: 30px;
		text-align: left;
	}

	.white-left {
		padding-right: 100px;
	}


	#main3-1 {
		padding: 0;
	}

	.rank .container {
		width: 98%;
	}

	.arrow-left,
	.arrow-right {
		position: absolute;
		left: 2%;
		top: 50%;
		margin-top: -30px;
		z-index: 9001;
	}

	.arrow-right {
		left: auto;
		right: 2%;
	}

	#rank {
		background: #393939;
		margin-top: -50px;
	}

	.rank {
		margin-top: 50px;
		position: relative;
	}

	.rank .main-photo {
		margin-top: 40px;
		min-height: 0px;
	}

	.rank-title {
		width: 94%;
		padding-left: 7%;
		position: static;
		margin-left: 0px;
		margin-bottom: 30px;
	}

	.rank-title img {
		width: 100%;
	}

	.rank .container {
		width: 95%;
	}

	.rank .mt-lg {
		margin-top: 10px;
	}

	.rank .frame2 {
		text-align: left;
		background: url(../img/rank1/sp/frame2.webp) no-repeat;
		background-size: 100% 100%;
	}

	.rank .frame2 .title2 {
		text-align: left;
	}


	.rank45 .main-pic {
		margin-left: -4%;
		width: 108%;
		border: none;
	}


	.rank45 .container {
		width: 98%;
	}

	.rank45 .arrow-left {
		left: 2%;
	}

	.rank45 .arrow-right {
		right: 2%;
	}


	#rank610 img {
		margin-top: 20px;
	}


	#rank610 .title {
		margin-top: 5px;
	}

	#rank610 .total {
		margin-top: 10px;
	}

	#rank610 .photo img {
		height: auto;
	}


	#message .container {
		width: 98%;

	}

	#message .font-xs-mini {
		font-size: 15px;
	}

	#main3 .back-up {
		padding: 0px;
		background: none;

	}

	#main3 .back-center {
		background: none;
	}

	#banner span {
		margin-top: -1em;
		font-size: 90%;
	}

	#social {
		margin-top: 8px;
	}

	#social .li {
		margin-bottom: 10px;
		margin-left: 10px;
		display: inline-block;
	}

	#social {
		text-align: center;
	}

	.font-xs-mini {
		font-size: 13px;
	}

	.title-sub {
		font-size: 17px;
	}

	.photo-copy {
		font-size: 12px;
	}

	.indent2 {
		font-size: 15px;
	}

	#rank610 .indent2 {
		line-height: 240%;
	}


}


/****************************************

    /* 商品・サービス

*****************************************/

#service {
	padding: 40px 0;
	font-family: 'Noto Sans JP', Meiryo, sans-serif;
}

#service h2 {
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 4px;
}

#service ul {
	width: 100%;
	display: flex;
	margin: 0 auto;
}

#service ul li {
	flex: 1;
	border-right: 1px dotted #ddd;
	margin: 30px auto;
	padding: 20px;
	font-size: 14px;
	line-height: 25px;
}

#service ul li:last-child {
	border-right: 1px dotted #fff;
}

#service ul li h3 {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 4px;
	margin: 0 0 10px;
}

#service ul li h4 {
	margin: 10px 0;
}

#service ul li h4 img {
	height: 21px;
}

#service ul li>a {
	display: inline-block;
	text-decoration: none;
	font-weight: bold;
	letter-spacing: 4px;
	margin: 10px 0 0;
}

#service ul li>a::after {
	font-family: FontAwesome;
	font-weight: normal;
	content: "\f101";
	margin: 0 0 0 .5em;
}

#service ul li>a:hover {
	color: #888;
}

#service .annotation {
	color: #888;
	font-size: 10px;
	text-align: right;
}

@media screen and (max-width: 800px) {

	#service {
		padding: 30px 10px;
	}

	#service h2 {
		font-size: 20px;
	}

	#service ul {
		flex-direction: column;
	}

	#service ul li {
		flex: 1;
		border-right: none;
		border-bottom: 1px dotted #ddd;
		margin: 0 auto;
		padding: 20px;
	}

	#service ul li:last-child {
		border-right: none;
		border-bottom: none;
	}

	#service ul li h3 {
		font-size: 20px;
	}

	#service ul li>img {
		display: block;
		margin: 0 auto;
	}

	#service .annotation {
		text-align: left;
	}

}

#service .wrap {
	/* width: 1000px; */
	margin: 0 auto;
	position: relative;
}

#service a {
	color: #333;
	text-decoration: underline;
	transition-duration: .3s;
}

#service p {
	font-size: 100%;
	vertical-align: baseline;
	border: 0;
	outline: 0;
	background: transparent;
	margin: 0;
	padding: 0;
}

/****************************************

    /* Link Box

*****************************************/
#linkBox {
    padding: 1.25rem 0;
    text-align: center;
}

#linkBox * {
    line-height: 1.8 !important;
}

#linkBox .justify-content-center {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
}

#linkBox .flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    margin: 0 auto;
}

#linkBox .flex>.col {
    width: 100%;
}

#linkBox .flex>* {
    min-height: 0%;
}

#linkBox .flex-grow-1 {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    flex-grow: 1;
}

#linkBox .flex-grow-2 {
    -webkit-box-flex: 2;
    -webkit-flex-grow: 2;
    flex-grow: 2;
}

#linkBox .wrap {
    position: relative;
    max-width: 960px;
    margin: 0 auto;
    padding: 0 20px;
}

#linkBox h2 {
    margin: 0 0 10px;
    color: #652;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}

#linkBox .pastEvent h2 {
    margin-bottom: 30px;
}

#linkBox .pastEvent .col {
    padding: 0 4%;
}

#linkBox .pastEvent .col:not(:last-child) {
    border-right: 1px solid #ccc;
}

#linkBox .pastEvent .col:nth-child(2n) {
    width: 194%;
}


@media all and (-ms-high-contrast:none) {

    *::-ms-backdrop,
    #linkBox .pastEvent .col:nth-child(2n) {
        width: 150%;
    }
}

#linkBox .pastEvent img {
    padding-bottom: 3px;
}

#linkBox .pastEvent .underline img {
    border-bottom: #000 1px solid;
}

#linkBox .shareSns .col {
    overflow: hidden;
    width: 40px;
    margin: 10px;
}

#linkbox img {
    vertical-align: middle !important;
}

@media screen and (max-width: 31.25em) and (orientation: portrait) {
    #linkBox {
        padding: 10px 0 15px;
    }

    #linkBox .flex.responsive {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        flex-direction: column;
    }

    #linkBox .pastEvent {
        width: 100%;
        padding: 0 10px;
    }

    #linkBox .pastEvent h2 {
        margin-bottom: 10px;
    }

    #linkBox .shareSns {
        width: 100%;
        margin: 1.25rem 0 0;
        padding: 0 10px;
    }

    #linkBox .shareSns .col {
        width: 8vw;
        margin: 0 6.5vw;
    }
}

@media screen and (max-width: 800px) {
    #linkBox .flex {
        flex-direction: row;
    }
}



#linkBox {
  padding-top: 2rem;
  text-align: center;
}


#linkBox .pastEvent img {
  vertical-align: middle;
  padding-bottom: 3px;
}

#linkBox .pastEvent .underline img {
  border-bottom: #000 1px solid;
}

#linkBox .pastEvent .col {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

#linkBox .pastEvent .col p {
  padding-right: 5%;
}

#linkBox .pastEvent .col p img {
  height: 90%;
}

#linkBox .pastEvent .col ul {
  display: flex;
}

#linkBox .pastEvent .col ul li {
  padding-left: 8%;
  margin-left: 8%;
  border-left: 1px solid #ccc; 
}

#linkBox .pastEvent .col ul li img {
  height: 90%;
}

#linkBox .pastEvent .col ul li:first-child {
  margin: 0;
  padding: 0;
  border: none;
}

#linkBox .shareSns {
  width: 80%;
}


/* ---------------------------NEWリンクボックス---------------------------
*/

.flex_wrap img{
    height: 20px;
    margin-left: 10px;
    
}

.flex_wrap img.point{
    border-bottom: solid 1.5px #333;
    height: 34px;
    /*padding-bottom: 6px;*/
    position: relative;
    bottom: -3px;
}

.flex_wrap{
    align-items: center;
}


.nav_wrap {
  width: 100%;
}

.nav_wrap h2{
  width: 100%;
  margin-bottom: 26px;
}

.flex_wrap {
  width: 50%;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.flex_wrap p {
  width: 30%;
}

.flex_wrap ul {
  width: 70%;
}

.flex_wrap p img,
.flex_wrap ul img {
  width: 100%;
}

.flex_wrap ul li.underline img {
  border-bottom: 1px solid #000;
}

.flex_wrap ul img {
  padding-bottom: 2px;
}

.flex_wrap ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.flex_wrap ul li {
  width: 40%;
  padding-left: 8%;
  margin-left: 8%;
  position: relative;
}

.flex_wrap ul li.p_2019:before {
  content: "";
  width: 1px;
  height: 60%;
  background: #ccc;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-70%);
}

.flex_wrap ul li.p_2019.underline:before {
  display: none;
}
 #linkBox h2.nav.ttl{
        margin-bottom: 26px;
    }
 .flex_wrap img.nav-top{
    margin-right: 20px;
}


@media screen and (max-width: 31.25em) and (orientation: portrait) {
  #linkBox {
    padding-top: 10px;
  }
  #linkBox .pastEvent {
    width: 100%;
    padding: 0 10px;
  }
  #linkBox .pastEvent h2 {
    margin-bottom: 10px;
  }
  #linkBox .shareSns {
    width: 100%;
    margin: 1rem 0 0;
    padding: 0 10px;
  }
  #linkBox .shareSns .col {
    width: 8vw;
    margin: 0 6.5vw;
  }
}

@media screen and (max-width: 330px){
    .flex_wrap img{
        height: 17px;
    }
    
    .flex_wrap img.point{
    height: 28px;
    }
}

