/*
Theme Name: tomiyameister2025
*/

@charset "utf-8";
body{
	color:#363636;
	font-family:"Zen Kaku Gothic New","游ゴシック体","YuGothic","游ゴシック","Yu Gothic","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,Verdana,sans-serif;
	font-size: 16px;
	line-height: 36px;
	word-break: break-all;
	overflow-x: hidden;
	background: #F0F0F0;
	font-feature-settings: "palt";
	font-weight: bold;
}

section{
	position: relative;
}

.mincho{
	font-family:"Zen Old Mincho", serif;
}


body.on{
	overflow:hidden;
}

ul{
	letter-spacing: -.40em; /* �����Ԃ��l�߂Č��Ԃ��폜���� */
}

li{
	letter-spacing: normal; /* �����Ԃ�ʏ�ɖ߂� */
}
a {
	-webkit-transition: all 0.4s;
	-moz-transition: all 0.4s;
	-ms-transition: all 0.4s;
	-o-transition: all 0.4s;
	transition: all 0.4s;
	text-decoration:none;
	opacity:1;
	transition:all 0.4s;
}

a:hover{
	color: #EEDA00;
}

img,
svg{
	max-width:100%;
	height:auto;
	font-size:0;
	vertical-align:top;
}

.clear{
	clear:both;
}

.clearfix_af:after{
	content: "";
	display: block; 
	height: 0; 
	font-size:0;    
	clear: both; 
	visibility:hidden;
}

.clearfix_bf:before{
	content: "";
	display: block; 
	height: 0; 
	font-size:0;    
	clear: both; 
	visibility:hidden;
}
.clearfix_af ,.clearfix_bf{
	display: inline-block;
} 
/* Hides from IE Mac */
* html .clearfix_af{
	height: 1%;
}
.clearfix_af ,.clearfix_bf{
	display:block;
}
/* End Hack */

nav{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: #F0F0F0;
	z-index: 9999;
	opacity: 0;
	transition: all 0.4s;
	pointer-events: none;
}

nav.on{
	opacity: 1;
	pointer-events: unset;
}

nav .nav_logo{
	padding: 40px 0 45px 50px;
}

nav ul{
	padding: 40px 0 45px 50px;
	font-weight: bold;
	font-size: 24px;
	line-height: 76px;
}

ul.year_list{
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

ul.year_list li{
	font-weight: bold;
	font-size: 20px;
	line-height: 26px;
	position: relative;
}

ul.year_list li.act{
	color: #EEDA00;
}

ul.year_list li + li:after{
	content: "";
	display: block;
	width: 2px;
    height: 15px;
    background: #707070;
    position: absolute;
    top: 7px;
    left: -10px;
}

ul.year_list li + li{
	margin-left: 20px;
}

ul.tag_list{
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	font-weight: bold;
	opacity: 0.5;
}

ul.pagination{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 50px;
}

ul.pagination li{
	font-weight: bold;
	font-size: 20px;
	line-height: 26px;
	position: relative;
}

ul.pagination li .current{
	color: #EEDA00;
}

ul.pagination li + li{
	margin-left: 20px;
}

#switchBtnArea {
	position: fixed;
	top: 0;
	width: 100%;
	z-index:9999999;
}

#switchBtnArea .switch_wrap{
	max-width: 1920px;
	padding: 0;
	width: 100%;
}

#switchBtnArea .switchBtn {
	display: block;
	margin-left: auto;
	width: 80px;
	height: 60px;
	position: relative;
	top: 45px;
	right: 30px;
}

#switchBtnArea .switchBtn span {
	margin: auto;
	width: 80px;
	height: 10px;
	display: block;
	position: absolute;
	background-color: #0156df;
	transition: all 0.2s linear;
}
#switchBtnArea .switchBtn span:nth-of-type(1) {top:0;transform: rotate(0);}
#switchBtnArea .switchBtn span:nth-of-type(2) {top:25px;transform: scale(1);}
#switchBtnArea .switchBtn span:nth-of-type(3) {top:50px;transform: rotate(0);}

#switchBtnArea .switchBtn.btnClose span:nth-of-type(1) {top:15px;transform: rotate(-45deg);}
#switchBtnArea .switchBtn.btnClose span:nth-of-type(2) {transform: scale(0);}
#switchBtnArea .switchBtn.btnClose span:nth-of-type(3) {top:15px;transform: rotate(45deg);}

.container1920{
	max-width: 1920px;
	padding: 0;
	margin: auto;
	position: relative;
}

h1{
	padding: 40px 0 45px 50px;
}

.float_wrap{
	display: flex;
	position: relative;
}

.float_wrap .float_title{
	width: 140px;
	text-align: center;
}

.float_wrap .float_title div{
	position:sticky;
	top:125px;
}

.float_wrap .item_wrap{
	width: calc(100% - 140px);
	border-right:1px solid #707070;
}

h2.title span{
	background:#fff;
	font-size: 75px;
	line-height: 1.2;
	display: inline-block;
	padding-left: 50px;
	margin-top: 20px;
}

h2.title span:nth-child(1){
	margin-top: 0;
}

p.catch_comment{
	font-weight: bold;
	font-size: 16px;
	margin-top: 55px;
	margin-left: 50px;
}

.btn{
	background: #0156DF;
	width: 100%;
	display: block;
	font-weight: bold;
	font-size: 21px;
	color: #fff;
	position: relative;
	height: 80px;
	line-height: 80px;
	padding-left: 30px;
	margin-top: 50px;
}

.btn svg{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 40px;
	margin: auto;
	transition: all 0.4s;
}

#voice .voice_wrap{
    margin-left: 50px;
    margin-top: 100px;
    max-width: 1500px;
}

#voice .voice_wrap article a{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	border-top: solid 1px #000;
	padding: 25px 0;
}

#voice .voice_wrap article:last-child a{
	border-bottom: solid 1px #000;
}

#voice .voice_wrap article a .number{
	font-weight: bold;
	font-size: 95px;
	line-height: 1;
	width: 13%;
}

#voice .voice_wrap article a .voice_right{
	flex: 1;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#voice .voice_wrap article a .items{
	width: 54.61%;
	position: relative;
}

#voice .voice_wrap article a .image{
	width: 38.46%;
}

#voice .voice_wrap article a .image img{
	aspect-ratio: 1 / 1;
	object-fit: cover;
}

#voice .voice_wrap article a h3{
	font-weight: bold;
	font-size: 50px;
	line-height: 1.25;
}

#voice .voice_wrap article a p{
	font-weight: bold;
	font-size: 16px;
	margin-top: 60px;
}

#voice .voice_wrap article a .name{
	font-weight: bold;
	font-size: 20px;
	margin-top: 70px;
	margin-bottom: 30px;
}

#voice .voice_wrap article a svg{
	position: absolute;
	bottom: 0;
}

footer > div{
	padding: 100px 0 50px 50px;
}

footer > div img{
	width: 280px;
}

footer .copyright{
	margin-top: 40px;
	font-weight: bold;
	font-size: 16px;
	line-height: 26px;
}

#news .item_wrap{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 50px;
}

#news .item_wrap .img_area{
    width: 35.7%;
	padding-left: 50px;
}

#news .item_wrap .text_area{
    width: 59.1%;
    position: relative;
    padding-bottom: 90px;
}

#news .item_wrap .text_area > a{
    display: block;
    position: relative;
    border-top: solid 1px #000;
    padding-right: 90px;
    padding-top: 10px;
    padding-bottom: 20px;
}

#news .item_wrap .text_area > a:last-of-type{
    border-bottom: solid 1px #000;
}

#news .item_wrap .text_area a svg{
    position: absolute;
    right: 15px;
    top: 0;
    bottom: 0;
    margin: auto;
}

#news .item_wrap .text_area a span{
    font-weight: bold;
    font-size: 15px;
    line-height: 26px;
}

#news .item_wrap .text_area a p{
    font-weight: bold;
    font-size: 16px;
    line-height: 26px;
}


@media only screen and (min-width: 1100px) {
	.sp_only{
		display:none !important;
	}

	#voice .voice_wrap article a:hover{
		color: #EEDA00;
	}

	#voice .voice_wrap article a svg path{
		transition: all 0.4s;
	}

	#voice .voice_wrap article a:hover svg path{
		fill: #EEDA00;
	}

	#voice .voice_wrap article a .image img{
		transition: all 0.4s;
	}

	#voice .voice_wrap article a .image{
		position: relative;
	}

	#voice .voice_wrap article a .image::before{
		content: "";
		position: absolute;
		display: block;
		width: 100%;
		padding-top: 100%;
		background: #EEDA00;
		pointer-events: unset;
		opacity: 0;
		transition: all 0.4s;
	}

	#voice .voice_wrap article a:hover .image::before{
		opacity: 0.3;
	}

	#voice .voice_wrap article a:hover .image:befoer{
	}

	#news .item_wrap .text_area > a:hover{
		color: #EEDA00;
	}

	#news .item_wrap .text_area > a svg path{
		transition: all 0.4s;
	}

	#news .item_wrap .text_area > a:hover svg path{
		fill: #EEDA00;
	}

	.btn:hover{
		opacity: 0.75;
	}

	.btn:hover svg path{
		fill:#EEDA00;
	}
	    
		

}

@media (max-width: 1099px) {

	.pc_only{
		display:none !important;
	}

	p.catch_comment{
		margin-right: 50px;
	}
    
	#news .item_wrap .text_area{
		width: 100%;
	}

	#voice .voice_wrap{
		margin-right: 50px;
	}

	#voice .voice_wrap article a .voice_right{
		flex-direction: column-reverse;
	}

	#voice .voice_wrap article a .image{
		width: 100%;
		max-width: 500px;
	}

	#voice .voice_wrap article a .items{
		width: 100%;
	}

	#voice .voice_wrap article a svg{
		position: relative;
	}

	#voice .voice_wrap article a .number{
		width: 100%;
		margin-bottom: 20px;
	}

	#news .item_wrap .img_area{
		display: none;
	}

	#about > p{
		padding-right: 50px;
	}

	#voice .voice_wrap article a{
		display: block;
	}

	#voice .voice_wrap article a h3{
		margin-top: 20px;
	}

}


@media (max-width: 599px) {

	body{
		font-size: 14px;
		line-height: 1.85;
	}

	h1{
		padding: 20px;
	}

	h1 img{
		width: 225px;
	}

	nav .nav_logo{
		padding: 20px;
	}

	nav .nav_logo img{
		width: 225px;
	}

	nav ul{
		padding: 20px;
		font-size: 16px;
		line-height: 2.75;
	}

	#switchBtnArea .switchBtn{
		width: 40px;
		height: 30px;
		top: 22px;
		right: 10px;
	}

	#switchBtnArea .switchBtn span{
		width: 40px;
		height: 5px;
	}

	#switchBtnArea .switchBtn span:nth-of-type(2){
		top: 11px;
	}

	#switchBtnArea .switchBtn span:nth-of-type(3){
		top: 22px;
	}

	.float_wrap{
		display: block;
	}

	.float_wrap .item_wrap{
		width: 100%;
		border-right: 0;
	}

	h2.title span{
		font-size: 35px;
		padding-left: 20px;
		margin-top: 10px;
	}

	p.catch_comment{
		margin-left: 20px;
		margin-top: 25px;
		margin-right: 80px;
		font-size: 14px;
		line-height: 30px;
	}

    .btn_area{
        margin: 0 20px;
       display: block;
    }

    .btn_area .btn{
        width: 100%;
        padding-left: 20px;
        font-size: 16px;
		height: 40px;
		line-height: 40px;
		margin-top: 20px;
    }

	.btn svg{
		width: 15px;
		right: 10px;
	}
	
    footer > div{
        padding: 20px;
    }

    footer > div img{
        width: 170px;
    }

    footer .copyright{
        font-size: 10px;
        margin-top: 20px;
    }

    #voice .voice_wrap{
        margin: 50px 20px 0 20px;
    }

	p.catch_comment{
		line-height: 1.85;
	}

    #voice .voice_wrap article a{
        display: block;
    }

    #voice .voice_wrap article a .number{
        width: 100%;
        font-size: 47px;
		margin-bottom: 0;
    }

    #voice .voice_wrap article a .image{
        margin-top: 20px;
        max-width: 250px;
    }

    #voice .voice_wrap article a h3{
        font-size: 25px;
        line-height: 35px;
        margin-top: 20px;
    }

    #voice .voice_wrap article a p{
        margin-top: 30px;
        font-size: 14px;
		margin-top: 20px;
    }

    #voice .voice_wrap article a .name{
        font-size: 16px;
        margin-top: 20px;
        margin-bottom: 20px;
    }

    #voice .voice_wrap article a svg{
        width: 25px;
    }

    #news .news_title{
        width: 165px;
    }

    #news .item_wrap .text_area a span{
        font-size: 12px;
    }

    #news .item_wrap .text_area > a{
        padding-right: 40px;
        padding-top: 5px;
        padding-bottom: 10px;
    }

    #news .item_wrap .text_area a p{
        font-size: 14px;
    }

    #news .item_wrap .text_area a svg{
        width: 23px;
    }

    #news .btn_area{
        margin-left: 0;
    }

	#news .item_wrap .text_area{
		padding-bottom: 0;
	}


}

