@charset "UTF-8";
/*
Theme Name: linera
Version: 1.0.0
*/


.headwrap {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}
.headwrap ul {
	display: flex;
	gap: 30px;
}
.headwrap ul li a {
	display: block;	
}
#lineralogo img { max-width: 300px; }

#headerL.fixed {
	position: fixed;
	top: 0px;
	width: 100%;
	background: #fff;
	padding: 10px;
	z-index: 100;
	display: block;
	text-align: center;
}
@keyframes fade-in {
	0% {opacity: 0; transform: translate3d(0,50px,0);}
	100% {opacity: 1; transform: translate3d(0,0,0);}
}

.animation.fade-in.on {
	animation-name:fade-in;
	animation-duration:1s;
	animation-timing-function: ease-out;
	animation-iteration-count:1;
	animation-direction:normal;
	animation-fill-mode: forwards;
}

.animation {
	opacity: 0;
}

#ft_top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 9999;
	width: 60px;
	height: 60px;
	background-color: #424242;
	border-radius: 2px;
	display: flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	font-size: 0;
	transition: all 0.3s ease;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

#ft_top::before {
	content: "";
	display: block;
	width: 14px;
	height: 14px;
	border-top: 3px solid #DBD4CA;
	border-left: 3px solid #DBD4CA;
	transform: rotate(45deg);
	margin-top: 6px; /* 垂直方向の微調整 */
}

#ft_top:hover {
	background-color: #555555;
	transform: translateY(-5px);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.3);
}

/* css追加をここの上に記載 */

@media (max-width: 1640px) {
}

@media (max-width: 1500px) {
}

@media (max-width: 1450px) {

}

@media (max-width: 1270px) {

}
@media (max-width: 767px) {
	#lineralogo img { max-width: 200px; }
	#gnavi.menu_open { left: 0px; background: #DBD4CA; }
	.headwrap .lineranavi {
		margin-top:55px;
		margin-left: auto;
		margin:0;
		padding: 0;
		width:100%;
		height: auto;
		float: none;
		display:  none;
	}

	.headwrap .lineranavi ul{
		display: block;
		list-style-type: none;
		margin: 0px 0;
		padding: 0px 0;
		text-align: left;
	}

	.lineranavi li{
		display:block;
		margin: 0px;
		padding: 0px 0px;
		width:100%;
		box-sizing: border-box;
		border-bottom:1px #333 solid;
		background: #DBD4CA;
	}
	.lineranavi li.lineranavi1{
		border-top:1px #333 solid;	
	}


	.lineranavi span.wrap,
	.lineranavi a{
		display: block;
		text-align: left;
		padding: 1em 2em;
		position: relative;
		color: #333;
		width: auto;
		height: 100%;
		font-size: 15px;
		border: 0px !important;
		line-height: 1.7em;
	}
	.lineranavi a:after {
		content: "";
		position: absolute;
		right: 10px;
		top: 10px;
		width: auto;
		opacity: 1;
		display: none;
	}
	.lineranavi span.pcbr { display: inline; }

	.lineranavi a:hover {color: #e00;}
	.lineranavi a:hover{
		-webkit-transition: color 0.2s, font 0.2s;
		-moz-transition: color 0.2s, font 0.2s;
		transition: color 0.2s, font 0.2s;
	}

	.lineranavi a:hover:after { background-color: #fff; }
	header #headerL.fixed { padding: 0px;  }
	#ft_top {
		position: fixed;
		bottom: 5px;
		right: 5px;
		z-index: 9999;
		width: 50px;
		height: 50px;
	}

}

/****************************************************
* 端末ごとの調整で、PCのcssはここ以下に追加しない
*****************************************************/