@charset "utf-8";
/*
Theme Name: マルイチ水産テーマ
Theme URI: http://madecom.co.jp
Description: madecomtheme
Version: 1.0
Author: madecom
Author URI: http://madecom.co.jp
*/


/* 以下ブログテーマのスタイル */


a {
	outline: none;
	-webkit-transition-duration: 0.25s;
	transition-duration: 0.25s;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
	display: block;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-size: 17px;
	margin: 0;
	padding: 0;
	line-height: 170%;
	font-family: "Noto Sans JP", "メイリオ", Meiryo, "Open Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Verdana, Helvetica, "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ＭＳ Ｐゴシック", "MS PGothic", Arial, sans-serif;
	position: relative;
	font-weight: 400;
	background: url(images/haikei_washi.jpg) 0 0 repeat;
	color: #333333;
}


h1 {
	font-weight: 700;
}

h1 img {
	max-width: 100%;
}

h2 {
	font-size: 28px;
	margin: 0 0 30px 0;
	font-weight: 700;
	line-height: 1.6;
	padding: 0 0 0 0;
}

h3 {
	font-size: 25px;
	margin: 15px 0 10px 0;
	font-weight: 700;
	line-height: 1.6;
}

h2.gfont_en {
	margin-bottom: 40px;
	font-size: 340%;
	font-weight: 800;
	letter-spacing: 0.03em;
}

h3 span.small {
	font-size: 70%;
	display: block;
	letter-spacing: 0.1em;
}

h4 {
	font-size: 18px;
	font-weight: 700;
	margin: 10px 0 15px 0;
}

a,
a:visited {
	color: #515cae;
	text-decoration: underline;
}

a:hover,
a:active {
	color: #0066cf;
	text-decoration: none;
}

ul {
	padding: 0;
	margin: 0;
}

ol {
	counter-reset: num;
	list-style-type: none !important;
	padding: 0;
	margin: 0 0 20px 0;
}

ol li {
	position: relative;
	padding-left: 30px;
	line-height: 1.5em;
	padding: 0.3em 0.5em 0.3em 30px;
}

ol li:before {
	position: absolute;
	counter-increment: num;
	content: counter(num);
	display: inline-block;
	background: #333;
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	left: 0;
	width: 22px;
	height: 22px;
	line-height: 22px;
	text-align: center;
	top: 7px;
}

li {
	list-style-type: none;
	padding: 0;
	margin: 0;
}

p {
	padding: 10px 0;
}

hr {
	border: none;
	margin: 10px 0;
	clear: both;
}

input {
	margin: 3px;
	padding: 2px;
}

.aligncenter input {
	padding: 5px 20px;
}

table {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	margin: 5px 0;
	padding: 0;
	border-collapse: collapse;
}

th, td {
	padding: 8px 10px;
	text-align: left;
}

.alignright {
	float: right;
	margin: 0 0 15px 30px;
}

.alignleft {
	float: left;
	margin: 0 30px 15px 0;
}

.aligncenter {
	text-align: center;
	display: block;
	margin: 15px auto;
}

.mb0 {
	margin-bottom: 0px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb120 {
	margin-bottom: 120px !important;
}

.mr20 {
	margin-right: 20px;
}

.mr40 {
	margin-right: 40px;
}

.pd0 {
	padding: 0px !important;
}

.pd20 {
	padding: 0 20px;
}

.pd30 {
	padding: 30px 0;
}

.pd60 {
	padding: 60px 0;
}

.pd90 {
	padding: 90px 0 !important;
}

.clear {
	clear: both;
}

/* For modern browsers */
.clearfix:before,
.clearfix:after {
	content: "";
	display: block;
	overflow: hidden;
}

.clearfix:after {
	clear: both;
}

.bg-gray {
	background-color: #f7f7f7;
}

/* For IE 6/7 (trigger hasLayout) */
.clearfix {
	zoom: 1;
}

.flexwrap, .flex {
	display: flex;
	flex-wrap: wrap;
}

.flex-b, .flex-2{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
 .flex-4, .flex-3{
	gap: 16px;
	display: flex;
	flex-wrap: wrap;
 }
.flex-c{
	justify-content: center;
}
.flex-2-c, .flex-2 li {
	width: 48%;
	margin-bottom: 20px;
}

.flex-3 li {
flex: 0 0 calc((100% - 32px) / 3);
	margin-bottom: 30px;
}

.flex-4 li {
flex: 0 0 calc((100% - 48px) / 4);
}

.flex-5 li {
	width: 20%;
}

.flex20 {
	width: 18%;
}

.flex30 {
	width: 28%;
}

.flex40 {
	width: 38%;
}

.flex50 {
	width: 50%;
}

.flex60 {
	width: 58%;
}

.flex70 {
	width: 67%;
}

.flex80 {
	width: 78%;
}

.flex-2-c li {
	width: 100%;
}

.alc {
	align-items: center;
}

.jcc {
	justify-content: center;
}

.reverse {
	flex-direction: row-reverse;
}

.bold {
	font-weight: bold;
}

.small {
	font-size: 85%;
	line-height: 1.5;
}

.small70 {
	font-size: 70%;
}

.big {
	font-size: 140%;
	line-height: 1.8;
	font-weight: 700;
}

.big2 {
	font-size: 120%;
	line-height: 1.8;
	font-weight: 700;
}

.txt-l {
	font-size: 110%;
	line-height: 1.8;
}

.red {
	color: #c20a00;
}

.blue {
	color: #006eb9;
}

.yellow {
	color: #cea700;
}

.underline {
	border-bottom: 2px solid #6687ae;
}

.gray {
	color: #9b9b9b;
}

.txr {
	text-align: right;
}

.txc {
	text-align: center;
}

.txc .centertxt {
	text-align: left;
	display: inline-block;
}

.lsl {
	letter-spacing: 0.15em;
}

.lhl {
	line-height: 2.4;
}

a.pdficon[href $='.pdf'] {
	padding: 4px 0 5px 25px;
	margin: 5px 5px 5px 0;
	line-height: 190%;
	background: transparent url(images/pdf.png) no-repeat left center;
}

.min {
	font-family: "Noto Serif JP", serif;
	font-weight:700;
	font-style: normal;
}

h2.adfont {
	font-size: 300%;
}

.contents {
	position: relative;
}

.wrap800 {
	max-width: 800px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

.wrap980 {
	max-width: 980px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

.wrap1100 {
	width: 80%;
	max-width: 1100px;
	box-sizing: border-box;
	padding: 0;
	margin: 0 auto;
}


.wrap1200 {
	width: 80%;
	max-width: 1200px;
	box-sizing: border-box;
	padding: 0 10px;
	margin: 0 auto;
}

@media screen and (max-width: 1300px) {
	.wrap1100 {
		width: 96%;
	}
}

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

	.wrap1200 {
		width: 92%;
	}

	.wrap800, .wrap980 {
		padding: 0;
	}

	h2.gfont_en {
		margin-bottom: 20px;
		font-size: 200%;
		font-weight: 800;
		letter-spacing: 0.02em;
	}

	.flex-b {
		flex-direction: column;
	}

	.flex-2-c, .flex-3 li, .flex30, .flex40, .flex50, .flex60, .flex70, .flex80, .links li {
		width: 100%;
	}

	.mb40, .mb30 {
		margin-bottom: 10px !important;
	}

	.mb60, .mb90, .mb120 {
		margin-bottom: 30px !important;
	}

	.mr20, .mr40 {
		margin-right: 0;
	}

	.pd30 {
		padding: 14px 0;
	}

	.pd60, .pd90 {
		padding: 30px 0 !important;
	}


	.lhl {
		line-height: 2;
	}
}


/*ページネーション*/
.post-navigation {
	overflow: hidden;
	padding: 12px 5px;
	display: flex;
	margin-top: 60px;
	justify-content: space-between;

}

.prev, .all, .next {
	width: 33%;
}

.prev a, .all a, .next a {
	display: inline-block;
	padding: 2px 14px;
	font-size: 90%;
	border: 1px solid #666;
	color: #666;
	text-decoration: none;
	font-weight: 500;
}

.prev a:hover, .all a:hover, .next a:hover {
	border: 1px solid #2256b8;
	color: #2256b8;
	background-color: #ebe4e4;
}

#header {
	width: 100%;
	padding: 0;
	transition: .4s;
	z-index: 999;
	background: url(images/bg_blue.png) 0 0 repeat;
}

@media screen and (min-width: 768px) {

	.pc_lhl {
		line-height: 2.4;
	}

	.pc_lsl {
		letter-spacing: 0.15em;
	}

	.pc_img_s {
		max-width: 75%;
	}
}

.logo {
	width: 360px;
	padding: 10px 0;
	margin-left: 10px;

}

.logo h1 {
	margin-right: 8px;
}

#mainvisual {
	height: 100vh;
	position: relative;
}



/*ドロップダウンメニュ*/

nav#navigation ul {
	display: flex;
	flex-direction: row;
	justify-content: flex-end;
	font-weight: 700;
	letter-spacing: 0.06em;
}

nav#navigation ul li {
	list-style: none;
	position: relative;
}

nav#navigation ul li:last-child {
	border-right: 0;
}

nav#navigation ul li a {
	display: block;
	padding: 14px 17px;
	text-align: center;
	line-height: 1.2;
	color: #fff;
	font-size: 100%;
	text-decoration: none;
	position: relative;
	transition: .4s;
	font-weight: 400;
}

nav#navigation ul li a:hover {
	color: #dcdcdc;
}

.foot-l h3 {
	width: 320px;
}

nav#navigation ul li ul {
	width: 130%;
	position: absolute;
	top: 50px;
	left: -15%;
	visibility: hidden;
	opacity: 0;
	-webkit-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-moz-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-ms-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	-o-transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	transition: visibility 0.1s ease-in, opacity 0.1s ease-in;
	z-index: 9999;
	display: flex;
	flex-direction: column;
}

nav#navigation ul li:hover ul {
	visibility: visible;
	opacity: 1;
}

nav#navigation ul li ul a {
	font-size: 100%;
	display: block;
	line-height: 1.4;
	background-color: #3a4354;
	text-shadow: none;
	padding: 10px 14px;
	color: #FFF;
}

nav#navigation ul li ul a:hover {
	background-color: #5c6e8f;
	color: #FFF;
}

nav#navigation ul li ul li {
	margin: -5px 0 0;
	border-left: none;
	border-bottom: 1px solid #51658a;
	float: none;
	width: 100%;
	-webkit-transition: margin 0.1s ease-in;
	-moz-transition: margin 0.1s ease-in;
	-ms-transition: margin 0.1s ease-in;
	-o-transition: margin 0.1s ease-in;
	transition: margin 0.1s ease-in;
}

nav#navigation ul li:hover ul li {
	margin-top: 0;
}

nav#navigation ul li:hover ul li ul {
	visibility: hidden;
	opacity: 0;
}

nav#navigation ul li:hover ul li:hover ul {
	visibility: visible;
	opacity: 1;
}

.img-s {
	width: 200px;
	height: auto;
}

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

	#header .wrap1200 {
		padding: 0 0 0 8px;
		width: 100%;
	}
}

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

	.pc_only {
		display: none !important;
	}

	.logo, .sp_menulogo {
		width: 260px;
		margin: 5px 0 0 0;
	}

	.sp_menulogo {
		padding-left: 5px;
		margin-top: 10px;
	}

	.sp_txl {
		text-align: left;
	}

	.sp_txc {
		text-align: center;
	}

	.sp_pd {
		padding: 0 14px;
	}

	.sp_img_s {
		width: 60%;
	}

	.sp_img_s80 {
		width: 80%;
	}

	.sp_flex {
		display: flex;
	}

	.sp_txt {
		font-size: 90%;
		line-height: 1.6;
	}

	.sp_reverse {
		flex-direction: column-reverse;
	}

	.sp_small {
		font-size: 80%;
		line-height: 1.6;
	}

	.big {
		font-size: 120%;
	}

	.big2 {
		font-size: 110%;
		line-height: 1.3;
	}

	.big2 p {
		line-height: 1.7;
	}


	#header .wrap1200 {
		padding: 0 0 0 8px;
		width: 100%;
	}


	/*メニュー*/

	.openbtn {
		position: fixed;
		right: 5px;
		top: 5px;
		background: #333;
		cursor: pointer;
		width: 50px;
		height: 50px;
		border-radius: 5px;
		z-index: 9999;
	}

	.openbtn .openbtn-area {
		transition: all .6s;
		/*アニメーションの設定*/
		width: 50px;
		height: 50px;
	}

	.openbtn span {
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 14px;
		height: 3px;
		border-radius: 2px;
		background: #fff;
		width: 45%;
	}

	.openbtn span:nth-of-type(1) {
		top: 15px;
	}

	.openbtn span:nth-of-type(2) {
		top: 23px;
	}

	.openbtn span:nth-of-type(3) {
		top: 31px;
	}

	.openbtn.active .openbtn-area {
		transform: rotate(360deg);
	}

	.openbtn.active span:nth-of-type(1) {
		top: 18px;
		left: 18px;
		transform: translateY(6px) rotate(-45deg);
		width: 30%;
	}

	.openbtn.active span:nth-of-type(2) {
		opacity: 0;
	}

	.openbtn.active span:nth-of-type(3) {
		top: 30px;
		left: 18px;
		transform: translateY(-6px) rotate(45deg);
		width: 30%;
	}

	.sp_menu {
		display: block;
		background-color: #27366d;
		box-sizing: border-box;
		position: fixed;
		top: 0;
		right: -100%;
		width: 100%;
		height: 100vh;
		padding: 0 0 0;
		overflow-y: auto;
		color: #fff;
		z-index: 9998;
		transition: .3s ease-in-out;
		/*滑らかに表示*/
		opacity: 0;
	}

	.sp_menu.active {
		/*display: block;*/
		right: 0;
		opacity: 1;
	}

	.main_link {
		border-top: 1px solid #506b8a;
	}

	.main_link ul {
		display: none;
	}


	.sp_menu .lastl {
		background: none;
		padding-bottom: 20px;
	}

	.sp_menu .lastl img {
		margin-right: 10px;
		vertical-align: middle;
	}

	.sp_menu .main_link a {
		display: block;
		text-decoration: none;
		padding: 10px 10px 14px;
		color: #333;
		font-weight: bold;
		background-color: #fafafa;
		border-bottom: 1px solid #9e9e9e;
	}

	.sp_menu .main_link ul {
		display: flex;
		flex-wrap: wrap;
	}

	.sp_menu .main_link ul li {
		width: 50%;
	}

	.sp_menu .main_link ul a {
		display: block;
		text-decoration: none;
		padding: 10px 10px 14px;
		color: #333;
		font-weight: bold;
		background-color: #e2eaec;
		border-bottom: 1px solid #9e9e9e;
	}

	.sp_menu a.parent {
		background: #fafafa url(images/arrow-sita.svg) center right 10px no-repeat;
		background-size: 20px 20px;
	}

	.sp_menu a.active {
		background: #fafafa url(images/arrow-ue.svg) center right 10px no-repeat;
		background-size: 20px 20px;
	}

	.sp_menu nav {
		padding: 20px 0;
	}
}


@media screen and (min-width: 1001px) {

	.sp_only,
	.sp_br {
		display: none !important;
	}

	.pc_txc {
		text-align: center;
	}

	.pc_txr {
		text-align: right;
	}

	.pc_alc {
		align-items: center;
	}

	.pc_reverse {
		flex-direction: row-reverse;
	}

}

/*----------トップページ------------------------*/

.mainimg{
	background: url(images/mainimg.jpg) right bottom no-repeat;
	background-size: cover;
	padding: 150px 0;
}

.catch{
	width: 50%;
	justify-content: center;
	display: flex;
	align-items: center;
}

#top-img li {
	width: calc(100% / 3);
	height: calc(100vh - 100px);
}

.top-img01 {
	background: url(images/main_01.jpg) center center no-repeat;
	background-size: 100% auto;
	width: 100%;
	height: 100%;
}

.top-img02 {
	width: 100%;
	height: 100%;
	background: url(images/main_02.jpg) center center no-repeat;
	background-size: 100% auto;
}

.top-img03 {
	width: 100%;
	height: 100%;
	background: url(images/main_03.jpg) center center no-repeat;
	background-size: 100% auto;
}


.over-logo {
	position: absolute;
	left: calc(50% - 100px);
	top: calc(50% - 73px);
	width: 200px;
	height: 146px;
}
.top-service{
	background: url(images/bg_blue2.png) 0 0 repeat;
	color: #FFF;
}
.top-service a{
	color: #FFF;
	text-decoration: none;
	font-size: 110%;
}
.top-service h2{
	text-align: center;
	color: #FFF;
	background: url(images/ttl_nami.png) center top no-repeat;
	padding-top: 70px;
	font-size: 230%;
	letter-spacing: 0.05em;
	margin-bottom: 60px;
}


.arrowbtn a{
	font-weight: 400;
	font-size: 140%;
	display: inline-block;
	margin: 20px 20px 0;
	position: relative;
	border-bottom: 1px solid #333;
	padding: 8px 100px 4px 0;
	text-decoration: none;
	color: #333;
	z-index: 2;
}

.arrowbtn a::after{
position: absolute;
bottom: -13px;
margin: auto;
content: "";
vertical-align: middle;
right: 6px;
width: 24px;
height: 24px;
color: #333;

border-top: 1px solid #555555;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);}

.arrowbtn a:hover{
	padding-right: 120px;
	margin-right: 0;
	color: #858585;
}

.arrowbtn a::after{
	border-top: 1px solid #333;}



a.headbtn {
	font-weight: 400;
	font-size: 100%;
	letter-spacing: 0.1em;
	margin: 0 0 0 14px;
	position: relative;
	background: linear-gradient(90deg, rgba(26, 41, 128, 1) 0%, rgba(38, 208, 206, 1) 90%);
	background-size: 200% 100%;
	background-position: 0 0;
	transition: background-position 0.5s ease;
	padding: 10px 20px 10px 43px;
	border-radius: 100vh;
	text-decoration: none;
	color: #fff;

}

.arrowbtn a:hover {
	background-position: right 16px center, 100% 0;
}

a.headbtn:hover {
	background-position: 100% 0;
}

a.headbtn::after {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	left: 20px;
	width: 8px;
	height: 8px;
	border-top: 2px solid #FFF;
	border-right: 2px solid #FFF;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}


.hover-zoom {
	display: inline-block;
	overflow: hidden;
	transition: transform 0.3s ease;
	border: 2px solid rgba(255,255,255,0.4);
	transition: border-color 0.3s ease;
}

.hover-zoom:hover {
	border-color: rgba(255,255,255,0.6);
}

.hover-zoom img {
	display: block;
	width: 100%;
	height: auto;
	transition: transform 0.5s ease, filter 0.5s ease;
}

.hover-zoom:hover img {
	transform: scale(1.08);
	filter: brightness(0.8);
}

.top-sagyou{
	background: url(images/sagyou.jpg) center center no-repeat;
	background-size: cover;
	background-attachment: fixed;
	padding-top: 240px;
	}

.top-sagyoucont{
	background: url(images/haikei_washi.jpg) 0 0 repeat;
	padding: 120px 0;
	position: relative;
}
.top-sagyou-c{
  padding: 4% 0 4% 0;
  background: url(images/bglogo.svg) right 0 no-repeat;
  background-size: 280px auto;
  width: 48%;
}
.top-sagyou-c p{
	font-size: 110%;
}
.top-sagyou-c h3{
	font-size: 230%;
}
.top-sagyou-img {
	flex: 1;
	margin-right: calc(50% - 50vw);
	margin-left: 6%;
	background: url(images/sagyou01.jpg) 0 bottom no-repeat;
}

.flowlist li{
	flex: 0 0 calc((100% - 120px) / 3);
	background-color: #2f2b63;
	border-radius: 10px;
	padding-bottom: 10px;
	box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
	position: relative;
}
.flowlist{
	gap: 60px;
	padding-right: 40px;
	position: relative;
}

.flowlist li::after {
	content: "▶"; /* 文字矢印（または↓や▶に変更可） */
	position: absolute;
	right: -40px; /* gapに合わせて調整 */
	top: 50%;
	transform: translateY(-50%);
	font-size: 24px;
	color: #2f2b63; /* お好みの色に変更 */
}

.flowlist li:last-child::after {
	content: none;
}
.flow-c img{
	width: 100%;
	border-radius: 10px 10px 0 0;
	height: auto;
	border: 8px solid #2f2b63;
}
.flow-c p{
	padding:0 14px 0 14px;
	color: #FFF;
}

@media (max-width: 767px) {

	.mainimg{
	background: url(images/mainimg.jpg) right bottom no-repeat;
	background-size: cover;
	padding: 60px 0;
}

	.catch{
	width:25%;

}
.top-about h2{
	font-size: 100%;
	margin-bottom: 0;
}
.top-about .mb60{
	margin-bottom: 0 !important;
}

  .flowlist {
    flex-direction: column;
    gap: 15px;
	padding: 0;
  }
  .flowlist li {
    flex: 1 0 100%;
  }
  .flowlist li::after {
    content: "▼";
    position: absolute;
    top: auto;
    bottom: -42px;
    left: 50%;
    transform: translateX(-50%);
    right: auto;
  }


  .top-service h2{
		padding: 30px 0 10px 0;
		margin: 0 0 20px;
			font-size: 170%;
		text-shadow: 
			#1e2f67 2px 0px 2px, #1e2f67 -2px 0px 2px,
	#1e2f67 0px -2px 2px, #1e2f67 -2px 0px 2px,
	#1e2f67 2px 2px 2px, #1e2f67 -2px 2px 2px,
	#1e2f67 2px -2px 2px, #1e2f67 -2px -2px 2px,
	#1e2f67 1px 2px 2px, #1e2f67 -1px 2px 2px,
	#1e2f67 1px -2px 2px, #1e2f67 -1px -2px 2px,
	#1e2f67 2px 1px 2px, #1e2f67 -2px 1px 2px,
	#1e2f67 2px -1px 2px, #1e2f67 -2px -1px 2px,
	#1e2f67 1px 1px 2px, #1e2f67 -1px 1px 2px,
	#1e2f67 1px -1px 2px, #1e2f67 -1px -1px 2px;
		background: url(images/ttl_nami.png) center top no-repeat;
		background-size: 200px auto;
	}
	.top-service-c {
		flex-direction: column;
	}
	.top-service-c li{
		width: 100%;
		margin-bottom: 0;
	}

	.top-sagyou{
	background: url(images/sagyou.jpg) 0 0 no-repeat;
	background-size: 100% auto;
	background-attachment:scroll;
	padding-top: 140px;
	}

	.top-sagyoucont{
	padding: 30px 0;
}

.top-sagyou-c{
  padding: 2% 0 2% 0;
  background: none;
  width: 100%;
}
.top-sagyou-c p{
	font-size: 100%;
}
.top-sagyou-c h3{
	font-size: 140%;
}
.top-sagyou-img {
	width: 100%;
	margin:12px 0 0 0;
	height: 400px;
	background: url(images/sagyou01.jpg) center center no-repeat;
	background-size: cover;
	flex: auto;
}
.top-sagyou-c .flex-b{
	flex-direction: row;
}
.top-sagyou-c .flex50{
	width: 48%;
}
}


/*--------------------お問い合わせフォーム-----------------------------*/

input[type="submit"] {
	appearance: none;
	-webkit-appearance: none;
}

.form {
	margin: 0 auto 30px;
}

.form table th, #wpcf7cpcnf table th {
	text-align: left;
	padding: 6px 10px;
	min-width: 20%;
}

.form table td, #wpcf7cpcnf table td {
	padding: 6px 20px;
	text-align: left;
}
#wpcf7cpcnf table td,#wpcf7cpcnf table th{
	border-bottom: 1px solid #cacaca;
}

.form td p, .form th p, .form p ,#wpcf7cpcnf p{
	padding: 0;
}

.form .input-l input,
.form .input-l textarea {
	width: 100%;
}

input#zip {
	width: 150px;
}

.form input.wpcf7-submit, .form input.wpcf7-confirm, .wpcf7cp-btns .wpcf7-form-control {
	padding: 12px 40px;
	background-color: #1397a2;
	color: #FFF;
	border-radius: 5px;
	border: none;
	font-size: 110%;
	font-weight: bold;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: .4s;
}
.wpcf7cp-btns{
	text-align: center;
}
.wpcf7cp-btns .wpcf7-form-control:hover {
	cursor: pointer;
	background-color: #067781;
}

input[type="submit"]:hover {
	background-color: #01656e;
	cursor: pointer;
}

.formReq {
	background-color: #da452a;
	color: #FFF;
	font-size: 70%;
	font-weight: bold;
	padding: 3px 5px 5px 5px;
	line-height: 100%;
	display: inline-block;
	border-radius: 5px;
	margin-left: 5px;
	margin-right: 5px;
}

#wpcf7cpcnf {
	border: none !important;
	background-color: rgb(245, 241, 241) !important;
}

.form input.wpcf7-back {
	background-color: #dcdcdc;
	color: #000;
	padding: 12px 46px;
	display: inline-block;
	margin-left: 5px;
}

.privacyp {
	padding: 20px 10px;
}

span.wpcf7-list-item {
	margin: 0 !important;
}

form input,
form textarea {
	box-sizing: border-box;
	padding: 8px 10px;
}

.form .wpcf7-submit:disabled {
	background-color: #dcdcdc !important;
	color: #999 !important;
	padding: 12px 40px;
}

.form input[type="checkbox"],
.form input[type="radio"],
input#consentCheckbox {
	accent-color: #e40000;
	transform: scale(1.5);
}

.form .wpcf7-list-item label {
	padding: 2px 8px;
}

.form .wpcf7-list-item label:has(input:checked) {
	background-color: #feffd8;
}
div.wpcf7 .wpcf7-spinner {
    display: none !important;
}

.wpcf7cp-form-hide{
	display: none;
}
div#wpcf7cpcnf{
	position:  relative !important;
}

@media screen and (min-width: 768px) {

	.form {
		padding: 0 20px;
	}
}

.wpcf7-checkbox label {
	margin-right: 10px;
}

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

	.form table, #wpcf7cpcnf table,
	.form table tbody, #wpcf7cpcnf table tbody,
	.form table tr, #wpcf7cpcnf table tr,
	.form table th, #wpcf7cpcnf table th,
	.form table td, #wpcf7cpcnf table td,
	.form textarea, #wpcf7cpcnf textarea {

		display: block;
		box-sizing: border-box;
		width: 100%;
	}

	.form textarea, form input, form textarea {
		max-width: 100% !important;
	}

	.sp-l input {
		width: 100%;
	}

	.sp-vertical .mwform-checkbox-field {
		display: block;
		margin-left: 0 !important;
	}

	.wpcf7-submit, .form input.wpcf7-confirm {
		font-size: 17px;
		padding: 3px 25px;
		background: #e9e9e9;
		color: #363B3F;
		border-radius: 4px;
		-webkit-border-radius: 4px;
		-moz-border-radius: 4px;
		border-top: none;
		border-right: none;
		border-left: none;
		border-bottom: solid 4px #dcdcdc;
	}

	.wpcf7-submit:hover, .form input.wpcf7-confirm:hover {
		background-color: #dcdcdc;
		color: #dc143c;
	}
}
/*---------フッター--------------------------*/

a.contactbtn {
	background:#111b35 url(images/mail.svg) 20px center no-repeat;
	background-size: 24px auto;
	text-decoration: none;
	color: #ffffff;
	border-radius: 6px;
	border: 1px solid rgba(255,255,255,0.3);
	font-weight: 700;
	padding: 14px 70px 14px 50px;
	font-size: 110%;
	display: block;
	margin-right: 24px;
	box-shadow: rgba(0, 0, 0, 0.15) 1.4px 1.4px 2.2px;
}

a.contactbtn:hover {
	background:#3f548a url(images/mail.svg) 20px center no-repeat;
	background-size: 24px auto;
}

.footer {
	margin: 0 auto 0;
	padding: 80px 30px 80px;
	font-weight: 500;
	font-size: 90%;
	color: #fff;
	background:url(images/bg_blue.png) 0 0 repeat;
}

.footer h3 {
	max-width: 300px;
	width: 300px;
	margin: 0 auto;
}

.footer a, .footinfo-c a {
	text-decoration: none;
	color: #FFF;
}

.foottel {
	font-size: 150%;
	font-weight: 700;
}

.footer p.copy {
	font-size: 12px;
	padding: 0;
	color: #fff;
	clear: both;
}

.footer p.copy a, .footer p.copy a:visited {
	color: #fff;
}


@media (min-width: 768px) and (max-width: 1300px) {
	footer .wrap1200 {
		width: 95%;
	}
}

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

	.footer {
		padding: 14px 8px 50px;
	}

	.footer h3 {
		max-width: 240px;
	}

	.footlogo {
		justify-content: space-between;
	}

	footer p {
		padding-top: 0px;
		font-size: 85%;
	}

	.footer p.copy {
		font-size: 10px;
		margin: 0 0 10px 0;
		line-height: 1.3;
		padding-bottom: 0;
	}

	.footer .mb20 {
		margin-bottom: 8px !important;
	}

	#top-img li {
		height: 300px;
	}


}

/*---------------------------*/

.wp-pagenavi {
	text-align: center;
}

.wp-pagenavi a, .wp-pagenavi span {
	padding: 3px 10px !important;
	margin: 2px 5px !important;
}

.wp-pagenavi {
	margin-bottom: 30px;
}

#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
}

#page-top a img {
	width: 60px;
	display: block;
}


.contactbox {
	position: relative;
}

.g_map {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 8px;
	padding-left: 8px;
	padding-right: 8px;
	height: 0;
	overflow: hidden;
}

.g_map iframe,
.g_map object,
.g_map embed,
.g_map video {
	position: absolute;
	top: 0;
	left: 8px;
	width: calc(100% - 16px);
	height: 100%;
}

/*--------------------下層ページ---------------------*/
.contents-page {
	position: relative;
}

.pagettl {
	letter-spacing: 0.1em;
	padding: 116px 0 0;
	margin: 60px 0 80px 0;
	position: relative;
	color: #2f2b63;
	text-align: center;
	font-size: 110%;
	background: url(images/ttl_nami2.png) center top no-repeat;

}

.sttl {
	line-height: 1.4;
	font-size: 150%;
	padding: 24px 24px 24px 24px;
	border-top:3px solid #2f2b63;
	border-bottom: 3px solid #2f2b63;
	margin-bottom: 30px;
	position: relative;
	color: #2f2b63;

}


.sttl2 {
	font-size: 120%;
	border-left: 4px solid #2f2b63;
	padding-left: 10px;
	color: #2f2b63;
		font-family: "Noto Serif JP", serif;
	font-weight:700;
	font-style: normal;
	margin-bottom: 14px;
}


.sttl3 {
	font-size: 120%;
	border-bottom: 1px solid #06307a;
	padding: 5px 10px 5px 5px;
	line-height: 1.3;
	margin-bottom: 10px;
}

.table01 {
	margin: 10px 0 30px 0;
	font-size: 90%;
	line-height: 1.6;
	border-top: 1px solid #d4d4df;
}

.table02 {
	margin: 10px 0 30px 0;
	font-size: 90%;
	line-height: 1.6;
	border-top: 1px solid #d4d4df;
}

.table03 {
	margin: 0;
}


.table01 th, .table01 td, .table02 th, .table02 td {
	border-bottom: 1px solid #d4d4df;
	padding: 14px 16px;
	background-color: #f5f1f1;
}

.table01 th, .table02 th {
	white-space: nowrap;
	background-color: #2f2b63;
	color: #FFF;
}

.nowrap {
	white-space: nowrap;
}

.simplebox {
	padding: 24px 30px;
	background-color:#fdfbfb;
	background-image: url(images/kazari_l.png),url(images/kazari_r.png);
	background-position: 0 0 , right 0;
	background-repeat: no-repeat;
	box-shadow: rgba(0, 0, 0, 0.15) 0px 2px 8px;
	margin-bottom: 30px;
	border: 1px solid #dfd9ae;
}

.simplebox h4 {
	margin: 0;
	border-bottom: 1px solid #c0c0c0;
}

.simplebox2 {
	padding: 16px 30px;
	border: 2px solid #999;
	background-color: rgba(255,255,255,0.4);
	margin-bottom: 30px;
}
.simplebox2 h3{
	font-size: 110%;
	margin: 0;
}
.list01 {
	margin-left: 20px;
}

.list01 li {
	list-style-type: disc;
	margin-bottom: 2px;
}

.list01 li::marker {
	color: #00215e;
}



@media screen and (max-width: 1200px) {
	.pagettl {
		padding: 24px 0 10px 0;
		margin: 14px 0 10px;
		text-shadow: 
			#f2eeeb 2px 0px 2px, #f2eeeb -2px 0px 2px,
	#f2eeeb 0px -2px 2px, #f2eeeb -2px 0px 2px,
	#f2eeeb 2px 2px 2px, #f2eeeb -2px 2px 2px,
	#f2eeeb 2px -2px 2px, #f2eeeb -2px -2px 2px,
	#f2eeeb 1px 2px 2px, #f2eeeb -1px 2px 2px,
	#f2eeeb 1px -2px 2px, #f2eeeb -1px -2px 2px,
	#f2eeeb 2px 1px 2px, #f2eeeb -2px 1px 2px,
	#f2eeeb 2px -1px 2px, #f2eeeb -2px -1px 2px,
	#f2eeeb 1px 1px 2px, #f2eeeb -1px 1px 2px,
	#f2eeeb 1px -1px 2px, #f2eeeb -1px -1px 2px;
		background: url(images/ttl_nami2.png) center top no-repeat;
		background-size: 200px auto;
	}

	.pagettl h1 {
		font-size: 120%;
		padding: 10px;
	}

.sttl{
		font-size: 110%;
		padding: 12px 0;
}

}

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


	.table01,
	.table01 tbody,
	.table01 tr,
	.table01 th,
	.table01 td {
		display: block;
		box-sizing: border-box;
		width: 100%;
	}

	.table01 th, .table01 td {
		padding: 8px 5px;
		font-size: 90%;
	}

	.table01 th {
		border-bottom: none;
		padding: 5px;
	}


	.table02 td {
		line-height: 1.6;
		font-size: 90%;
		padding: 5px;
	}


	h2, h3 {
		font-size: 120%;
	}

	.simplebox {
		padding: 10px 14px;
		margin-bottom: 10px;
		background-color: #f5f5f5;
	}

	.list01 li {
		line-height: 1.5;
	}

	.simplebox2 {
		padding: 10px 16px;
	}
}

.fade-in {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 1.5s, transform 1s;
}

.fade-in.active {
	opacity: 1;
	transform: translateY(0px);
}

/* 2つ目の要素に200msのdelayをかける */
.fade2 {
	-moz-transition-delay: 200ms;
	-webkit-transition-delay: 200ms;
	-o-transition-delay: 200ms;
	-ms-transition-delay: 200ms;
	transition-delay: 200ms;
}

/* 3つ目の要素に400msのdelayをかける */
.fade3 {
	-moz-transition-delay: 400ms;
	-webkit-transition-delay: 400ms;
	-o-transition-delay: 400ms;
	-ms-transition-delay: 400ms;
	transition-delay: 400ms;
}

@media screen and (max-width: 767px) {
	.sptate {
		flex-direction: row;
	}

	.sptate .flex-2-c {
		width: 48%;
	}

	.footinfo {
		padding: 0 14px;
		flex-direction: column;
	}

	.footinfo-c-r {
		border: none;
	}

	.footinfo-c {
		padding: 0 1em;
	}

.sp2retsu li{
	flex: 0 0 calc((100% - 16px) / 2);
}

}

.head-r1 {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.iconsns {
	width: 30px;
	height: 30px;
}

.spsns {
	margin-right: 20px;
}