@charset "UTF-8";

/* common
------------------------------------------------*/
#main .post .h2outer h2 {
	margin-top: 90px;
}
#main .post > h2.align-center {
	position: relative;
	margin: 0 0 30px;
	padding: 90px 0 20px;
	letter-spacing: 0.03em;
	line-height: 1.5;
	font-size: 35px;
}
#main .post > h2.align-center:after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	background: #67B3F5;
	width: 80px;
	height: 4px;
	margin: 0 0 0 -40px;
}
#main .post p + h2.align-center {
	padding-top: 70px;
}
#main .post h3 {
	position: relative;
	margin: 40px 0 25px;
	padding: 0 0 0 30px;
	text-align: left;
}
#main .post h3:before {
	content: "";
	position: absolute;
	top: 10px;
	left: 0;
	background: #67B3F5;
	width: 20px;
	height: 20px;
	border-radius: 50%;
}
.wp-block-gallery.has-nested-images figure.wp-block-image {
  flex-grow: 0;
}
#main .post ol {
	padding: 0 0 0 1.5em;
}
#main .post ol li {
	margin: 10px 0;
}
#main .post table {
	width: 100%;
	background: #fff;
	border-collapse: collapse;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	margin: 0 0 30px;
}
#main .post table th,
#main .post table td {
	padding: 10px 20px;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
#main .post table th {
	background: #E3F4FF;
}
#main .post .wp-block-file {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	border: 2px solid #ACBFD0;
	border-radius: 20px;
	padding: 20px;
}
#main .post .wp-block-file:not(.wp-element-button) {
	font-size: 1em;
}
#main .post .wp-block-file .wp-block-file__button {
	color: #fff;
}
#main .post .returnbtn {
	margin: 40px 0;
	text-align: center;
}
#main .post .returnbtn a {
	display: inline-block;
	position: relative;
	background: #666;
	border-radius: 60px;
	padding: 15px 20px 15px 40px;;
	font-size: 16px;
	color: #fff;
}
#main .post .returnbtn a:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 25px;
	width: 6px;
	height: 6px;
	border-top: solid 2px #fff;
	border-left: solid 2px #fff;
	transform: translate(0, -50%) rotate(-45deg);
}
#main .post .returnbtn a:hover {
	opacity: 0.8;
}
@media screen and (max-width:767px) {
	#main .post .h2outer h2 {
		margin-top: 40px;
	}
	#main .post > h2.align-center {
		padding: 40px 0 20px;
		letter-spacing: 0.01em;
		font-size: 23px;
	}
	#main .post p + h2.align-center {
		padding-top: 30px;
	}
	#main .post h3 {
		margin: 30px 0 15px;
		padding: 0 0 0 25px;
	}
	#main .post h3:before {
		top: 8px;
		width: 15px;
		height: 15px;
	}
	#main .post table th,
	#main .post table td {
		padding: 7px 10px;
	}
	#main .post img {
		display: block;
		margin: 0 auto 10px;
	}
	#main .post .wp-block-file {
		padding: 15px;
	}
}

/* recipe
------------------------------------------------*/
#main .post .box {
	background: #fff;
	border: 2px solid #ACBFD0;
	border-radius: 20px;
	padding: 20px;
}
#main .post .box h4 {
	background: #E3F4FF;
	border-radius: 5px;
	margin: 0 0 5px;
	padding: 10px;
}
#main .post .box table,
#main .post .box th,
#main .post .box td {
	background: none;
	border: 0;
	margin: 0 0 10px;
	padding: 10px 0;
	text-align: left;
	font-weight: 500;
}
#main .post .box th,
#main .post .box td {
	border-bottom: 1px solid #ccc;
}
#main .post .box p {
	margin: 0;
}
.recipe #main .post ol {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	list-style-type: decimal;
	list-style-position: inside;
	margin: 0 0 30px;
	padding: 0;
}
.recipe #main .post ol li {
	background: #fff;
	border: 2px solid #ACBFD0;
	border-radius: 20px;
	width: 32.5%;
	padding: 20px;
	line-height: 1.5;
	text-align: center;
	font-size: 22px;
	box-shadow: 5px 5px 0 rgba(172, 191, 208, 0.5);
}
.recipe #main .post .recipelist {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.recipe #main .post .recipelist:after,
.recipe #main .post .recipelist:before {
	content: "";
	display: block;
	width: 23.5%;
}
.recipe #main .post .recipelist:before {
	order: 1;
}
.recipe #main .post .recipelist li {
	width: 23.5%;
	margin: 0 0 20px;
	line-height: 1.5;
}
.recipe #main .post .recipelist li a {
	display: block;
}
.recipe #main .post .recipelist li .img {
	position: relative;
	width: 100%;
	height: 0;
	margin: 0 0 10px;
	padding-top: 80%;
	overflow: hidden;
}
.recipe #main .post .recipelist li .img:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.02);
}
.recipe #main .post .recipelist li .img img {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	max-width: 100%;
	max-height: 100%;
}
.pazza #main .post ol li:nth-child(3),
.pazza #main .post ol li:nth-child(4),
.pazza #main .post ol li:nth-child(5),
.carta #main .post ol li:nth-child(2),
.carta #main .post ol li:nth-child(3),
.carta #main .post ol li:nth-child(4),
.tartare #main .post ol li:nth-child(1),
.tartare #main .post ol li:nth-child(4),
.tartare #main .post ol li:nth-child(5) {
	position: relative;
	min-height: 150px;
	padding-right: 250px;
}
.carta #main .post ol li:nth-child(3) {
	padding-right: 450px;
}
.pazza #main .post ol li:nth-child(3):after,
.pazza #main .post ol li:nth-child(4):after,
.pazza #main .post ol li:nth-child(5):after,
.carta #main .post ol li:nth-child(2):after,
.carta #main .post ol li:nth-child(3):after,
.carta #main .post ol li:nth-child(4):after,
.tartare #main .post ol li:nth-child(1):after,
.tartare #main .post ol li:nth-child(4):after,
.tartare #main .post ol li:nth-child(5):after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 210px;
	height: 150px;
}
.pazza #main .post ol li:nth-child(3):after {
	background: url(/wp-content/uploads/2014/03/pazza-flow1.jpg) no-repeat 0 0;
	background-size: cover;
}
.pazza #main .post ol li:nth-child(4):after {
	background: url(/wp-content/uploads/2014/03/pazza-flow2.jpg) no-repeat 0 0;
	background-size: cover;
}
.pazza #main .post ol li:nth-child(5):after {
	background: url(/wp-content/uploads/2014/03/pazza-flow3.jpg) no-repeat 0 0;
	background-size: cover;
}
.carta #main .post ol li:nth-child(2):after {
	background: url(/wp-content/uploads/2014/03/carta-flow1.jpg) no-repeat 0 0;
	background-size: cover;
}
.carta #main .post ol li:nth-child(3):after {
	background: url(/wp-content/uploads/2014/03/carta-flow3.jpg) no-repeat 0 0;
	background-size: cover;
}
.carta #main .post ol li:nth-child(3):before {
	content: "";
	position: absolute;
	top: 0;
	right: 220px;
	background: url(/wp-content/uploads/2014/03/carta-flow2.jpg) no-repeat 0 0;
	background-size: cover;
	width: 210px;
	height: 150px;
}
.carta #main .post ol li:nth-child(4):after {
	background: url(/wp-content/uploads/2014/03/carta-flow4.jpg) no-repeat 0 0;
	background-size: cover;
}
.tartare #main .post ol li:nth-child(1):after {
	background: url(/wp-content/uploads/2014/03/tartare-flow1.png) no-repeat 0 0;
	background-size: cover;
}
.tartare #main .post ol li:nth-child(4):after {
	background: url(/wp-content/uploads/2014/03/tartare-flow2.png) no-repeat 0 0;
	background-size: cover;
}
.tartare #main .post ol li:nth-child(5):after {
	background: url(/wp-content/uploads/2014/03/tartare-flow3.png) no-repeat 0 0;
	background-size: cover;
}
#main .post .profilebox {
	background: #fff;
	margin: 30px 0 0;
	padding: 20px;
}
#main .post .profilebox p {
	margin: 0;
}
#main .post .profilebox p strong {
	font-size: 20px;
}
#main .post .profilebox img {
	width: auto;
}
.tartare #main .post .point {
	display: flex;
	align-items: center;
	background: #fff;
	border: 2px solid #ACBFD0;
	border-radius: 20px;
	margin: 30px 0 0;
	padding: 20px;
}
.tartare #main .post .point p {
	width: 140px;
	margin: 0;
}
.tartare #main .post .point p + p {
	width: calc(100% - 140px);
}
.tartare #main .post .point p b {
	font-size: 20px;
}
@media screen and (max-width:767px) {
	.recipe #main .post ol {
		margin: 0 0 10px;
	}
	.recipe #main .post ol li {
		width: 100%;
		margin: 0 0 10px;
	}
	.recipe #main .post .recipelist:after {
		width: 31.5%;
	}
	.recipe #main .post .recipelist:before {
		content: none;
	}
	.recipe #main .post .recipelist li {
		width: 31.5%;
	}
	#main .post .profilebox p strong,
	.tartare #main .post .point p b {
		font-size: 17px;
	}
	.tartare #main .post .point img {
		margin: 0;
	}
}
@media screen and (max-width:600px) {
	#main .post .profilebox {
		padding: 20px 0;
	}
	.carta #main .post ol li:nth-child(3) {
		min-height: auto;
		padding-bottom: 155px;
		padding-right: 0;
	}
	.carta #main .post ol li:nth-child(3):after {
		top: auto;
		right: auto;
		bottom: 0;
		left: 0;
	}
	.carta #main .post ol li:nth-child(3):before {
		top: auto;
		right: auto;
		bottom: 0;
		left: 220px;
	}
}
@media screen and (max-width:480px) {
	.recipe #main .post .recipelist:after {
		content: none;
	}
	.recipe #main .post .recipelist li {
		width: 48.5%;
	}
	.pazza #main .post ol li:nth-child(3),
	.pazza #main .post ol li:nth-child(4),
	.pazza #main .post ol li:nth-child(5),
	.carta #main .post ol li:nth-child(2),
	.carta #main .post ol li:nth-child(4),
	.tartare #main .post ol li:nth-child(1),
	.tartare #main .post ol li:nth-child(4),
	.tartare #main .post ol li:nth-child(5) {
		min-height: none;
		padding-bottom: 155px;
		padding-right: 0;
	}
	.pazza #main .post ol li:nth-child(3):after,
	.pazza #main .post ol li:nth-child(4):after,
	.pazza #main .post ol li:nth-child(5):after,
	.carta #main .post ol li:nth-child(2):after,
	.carta #main .post ol li:nth-child(4):after,
	.tartare #main .post ol li:nth-child(1):after,
	.tartare #main .post ol li:nth-child(4):after,
	.tartare #main .post ol li:nth-child(5):after {
		top: auto;
		right: auto;
		bottom: 0;
		left: 0;
	}
	.carta #main .post ol li:nth-child(3) {
		padding-bottom: 330px;
	}
	.carta #main .post ol li:nth-child(3):before {
		left: 0;
		bottom: 175px;
	}
	.tartare #main .post .point {
		padding: 15px;
	}
	.tartare #main .post .point p {
		width: 100px;
	}
	.tartare #main .post .point p + p {
		width: calc(100% - 120px);
		margin: 0 0 0 20px;
	}
}
/* photo-studio
------------------------------------------------*/
.photo-studio #main .post .swiper {
	position: relative;
	margin-bottom: 40px;
}
.photo-studio #main .post .swiper img {
	max-width: 100%;
	height: auto;
}
.photo-studio #main .post .swiper-container-horizontal > .swiper-pagination-bullets {
	bottom: -30px;
}
.photo-studio #main .post .swiper .swiper-pagination-bullet {
	width: 12px;
	height: 12px;
}
.photo-studio #main .post .swiper .swiper-pagination-bullet-active {
	background: #F5927A;
}
/* about
------------------------------------------------*/
.about #main .post ul {
	display: flex;
	flex-wrap: wrap;
	list-style: disc;
	margin: 0;
	padding: 0 0 0 1.5em;
}
.about #main .post ul li {
	width: 50%;
	margin: 0 0 10px;
}
.about #main .post table th .margin-left {
	margin-left: 1em;
}
@media screen and (max-width:767px) {
	.about #main .post ul li {
		width: 100%;
	}
	.about #main .post table th .margin-left {
		margin: 0;
	}
}
/* gi-mark
------------------------------------------------*/
.gi-mark #main .post dl {
	margin: 50px auto 40px;
}
.gi-mark #main .post dl dt {
	float: left;
	width: 190px;
	padding: 20px 0;
}
.gi-mark #main .post dl dt.required:before {
	content: "必須";
	background: #F5927A;
	margin: 0 5px 0 0;
	padding: 5px;
	vertical-align: text-bottom;
	font-size: 10px;
	color: #fff;
}
.gi-mark #main .post dl dd {
	border-bottom: 1px solid #999;
	min-height: 27px;
	margin: 0;
	padding: 20px 5px 20px 190px;
}
.mw_wp_form input,
.mw_wp_form textarea {
	box-sizing: border-box;
	margin: 0 2px;
	padding: 7px;
	font-size: 15px;
}
.mw_wp_form p input {
	border: 1px solid #000;
}
.mw_wp_form #camp,
.mw_wp_form #kana,
.mw_wp_form #name,
.mw_wp_form #mail { width: 100%; }
.mw_wp_form #message { width: 100%; min-height: 140px; }
.mw_wp_form p.btn input {
	border: 1px solid #999;
	background: #666;
	border-radius: 3px;
	padding: 10px 40px;
	color: #fff;
}
.mw_wp_form p.btn input:hover {
	background: #444;
}
@media screen and (max-width:767px) {
	.gi-mark #main .post dl {
		margin: 30px auto;
	}
	.gi-mark #main .post dl dt {
		float: none;
		width: 100%;
		padding: 20px 0 0;
	}
	.gi-mark #main .post dl dd {
		min-height: auto;
		padding: 10px 0 20px;
	}
}
/* contact
------------------------------------------------*/
.contact #main .post p {
	text-align: center;
}
.contact #main .post .largesize {
	margin: 40px 0 10px;
	font-size: 30px;
}
.contact #main .post .largesize strong {
	font-size: 42px;
}
@media screen and (max-width:1024px) {
	.contact #main .post .largesize {
		font-size: 20px;
	}
	.contact #main .post .largesize strong {
		font-size: 32px;
	}
}
@media screen and (max-width:480px) {
	.contact #main .post .largesize {
		font-size: 16px;
	}
	.contact #main .post .largesize strong {
		font-size: 23px;
	}
}
/* sitemap-page
------------------------------------------------*/
.sitemap-page #main .post ul {
	list-style-type: disc;
	list-style-position: inside;
	padding: 100px 0;
}
.sitemap-page #main .post ul li {
	border-bottom: 2px solid #ACBFD0;
	padding: 20px;
	font-size: 18px;
}
.sitemap-page #main .post ul li:first-child {
	border-top: 2px solid #ACBFD0;
}
.sitemap-page #main .post ul ul {
	padding: 0;
}
.sitemap-page #main .post ul li li {
	border: 0;
	padding: 15px 0 0 30px;
}
.sitemap-page #main .post ul li li:first-child {
	border: 0;
}
@media screen and (max-width:767px) {
	.sitemap-page #main .post ul {
		padding: 0;
	}
	.sitemap-page #main .post ul li {
		font-size: 16px;
	}
}
/* miyagisalmon
------------------------------------------------*/
.miyagisalmon #main .post h3 {
	padding: 0;
	text-align: center;
}
.miyagisalmon #main .post h3:before {
	content: none;
}
.miyagisalmon #main .environment .flex {
	align-items: center;
	margin: 0 0 30px;
}
.miyagisalmon #main .environment .flex p,
.miyagisalmon #main .environment .flex dl {
	width: 48%;
	margin: 0;
}
.miyagisalmon #main .environment .flex p img {
	border-radius: 20px;
	max-width: 100%;
	height: auto;
}
.miyagisalmon #main .environment .flex dt {
	letter-spacing: 0.02em;
	font-size: 25px;
	font-weight: 700;
}
.miyagisalmon #main .environment .flex dd {
	margin: 10px 0 0;
}
.miyagisalmon #main .environment .flex dd ul {
	display: flex;
}
.miyagisalmon #main .environment .flex dd ul li {
	margin: 0 15px 0 0;
}
.miyagisalmon #main .season dl {
	display: flex;
	width: 66%;
	margin: 0 auto 40px;
	background: #fff;
	border: 2px solid #ACBFD0;
	border-radius: 20px;
	padding: 10px 20px 15px;
	box-shadow: 10px 10px 0 rgba(172,191,208,0.5);
}
.miyagisalmon #main .season dl dt {
	margin: 0 20px 0 0;
	line-height: 1.6;
}
.miyagisalmon #main .season dl dt .bg {
	background: #E3F4FF;
	width: 64px;
	padding: 0 0 5px;
	border-radius: 10px;
	text-align: center;
	font-weight: 700;
	font-size: 14px;
}
.miyagisalmon #main .season dl dt .bg.txt {
	padding: 10px 0;
}
.miyagisalmon #main .season dl dt .bg i {
	font-size: 25px;
	font-style: normal;
}
.miyagisalmon #main .season dl dt .bg span {
	font-size: 18px;
	font-weight: 400;
}
.miyagisalmon #main .season dl dt .arrow {
	position: relative;
	top: 2px;
}
.miyagisalmon #main .season dl dt .arrow:before {
	content: "▼";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 12px;
	height: 12px;
	line-height: 1;
	letter-spacing: -0.06em;
	font-size: 12px;
	font-weight: 700;
	color: #888;
}
.miyagisalmon #main .season dl dd {
	width: 100%;
	margin: 0;
}
.miyagisalmon #main .season dl dd strong {
	display: block;
	letter-spacing: 0.1em;
	text-align: center;
	font-size: 25px;
}
.miyagisalmon #main .season h3 + dl dd {
	padding: 0 84px 0 0;
}
.miyagisalmon #main .season .flex .case {
	width: 48%;
}
.miyagisalmon #main .season .flex .case dl {
	position: relative;
	width: 100%;
}
.miyagisalmon #main .season .flex .case dl:first-child:before,
.miyagisalmon #main .season .flex .case dl:after {
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	background: #ACBFD0;
	width: 20px;
	height: 10px;
	margin: 0 0 0 -10px;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.miyagisalmon #main .season .flex .case dl:after {
	bottom: -30px;
}
.miyagisalmon #main .season .flex .case dl:first-child:before {
	top: -25px;
}
.miyagisalmon #main .season .flex .case:nth-child(2) dl {
	background: #C3F1FF;
	border-color: #fff;
}
.miyagisalmon #main .season .flex .case:nth-child(2) dl dt .bg {
	background: #fff;
}
.miyagisalmon #main .season .flex .case dl dd {
	position: relative;
}
.miyagisalmon #main .season .flex .case dl:first-child dd:after {
	content: "";
	display: block;
	position: absolute;
	top: -30px;
	height: 76px;
}
.miyagisalmon #main .season .flex .case:first-child dl:first-child dd:after {
	right: 0;
	background: url(img/ill-season01.png) no-repeat 0 0;
	background-size: cover;
	width: 130px;
}
.miyagisalmon #main .season .flex .case:last-child dl:first-child dd:after {
	right: -20px;
	background: url(img/ill-season02.png) no-repeat 0 0;
	background-size: cover;
	width: 98px;
}
.miyagisalmon #main .season .flex dl dd strong {
	position: relative;
	z-index: 1;
	text-align: left;
}
.miyagisalmon #main .season .flex + dl {
	position: relative;
}
.miyagisalmon #main .season .flex + dl:after {
	content: "";
	display: block;
	position: absolute;
	top: 10px;
	right: 20px;
	background: url(img/ill-season03.png) no-repeat 0 0;
	background-size: cover;
	width: 140px;
	height: 72px;
}
.miyagisalmon #main .place img {
	max-width: 100%;
	height: auto;
}
.miyagisalmon #main .horizontal_scroll {
  --sticky-container-height: 100vh;
  height: var(--sticky-container-height);
  min-height: 100vh;
}
.miyagisalmon #main .horizontal_scroll p {
	margin: 0;
}
.miyagisalmon #main .horizontal_scroll .sticky {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
}
.miyagisalmon #main .horizontal_scroll .scroller {
  display: flex;
  overflow: auto;
}
.miyagisalmon #main .horizontal_scroll .scroller.nobar {
  overflow: hidden;
}
.miyagisalmon #main .horizontal_scroll .scroller .case {
	background: #f0f;
  width: 370px;
	height: 100vh;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg1 {
	background: url(img/bg-box01.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg2 {
	background: url(img/bg-box02.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg3 {
	background: url(img/bg-box03.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg4 {
	background: url(img/bg-box04.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg5 {
	background: url(img/bg-box05.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg6 {
	background: url(img/bg-box06.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case.bg7 {
	background: url(img/bg-box07.jpg) no-repeat center top;
	background-size: 100% auto;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap {
	display: flex;
	flex-wrap: wrap;
  align-items: center;
	align-content: flex-end;
  width: 320px;
	height: 80vh;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap h2 {
	background: rgba(255,255,255,0.7);
	width: 100%;
	margin: 0;
	padding: 10px 0;
	text-align: center;
	letter-spacing: 0.03em;
	line-height: 1.2;
	font-size: 20px;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap > p {
	width: 100%;
	margin: 15px 0 10px;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt {
	position: relative;
	margin: 0 0 5px;
	letter-spacing: 0.07em;
	font-size: 18px;
	font-weight: 700;
	color: #408BC4;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt span {
	position: relative;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt span:before,
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt span:after {
	content: "";
	display: block;
	position: absolute;
	background: #408BC4;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt span::before {
	top: 50%;
	right: -90px;
	width: 80px;
	height: 3px;
	opacity: 1;
	animation: moved1 1.5s ease-in-out infinite;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrolltxt span:after {
	top: 50%;
	right: -10px;
	transform: rotate(30deg);
	width: 10px;
	height: 3px;
	margin: -2px 0 0;
	opacity: 0;
	animation: moved2 1.5s ease-in-out infinite;
}
@keyframes moved1 {
	0% {
		right: -10px;
		width: 0;
		opacity: 1;
	}
	50% {
		opacity: 1;
	}
	100% {
		right: -90px;
		width: 80px;
		opacity: 0;
	}
}
@keyframes moved2 {
	0% {
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
	100% {
		right: -90px;
		opacity: 0;
	}
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrollline {
	position: absolute;
	top: 50%;
	right: -90px;
	width: 80px;
	height: 3px;
	overflow: hidden;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .wrap .scrollline .line {
	display: block;
	background: linear-gradient(to right, rgba(64, 139, 196, 1) 50%, rgba(64, 139, 196, 0) 50%);
	background-position: 100% 0;
	background-size: 200% 100%;
	border-radius: 10px;
	width: 100%;
	height: 100%;
	animation: scrollmove 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .bg {
  background: #fbfbef;
	box-shadow: 10px 10px 0 rgba(0,0,0,0.2);
  width: 100%;
	height: 60vh;
	padding: 0 20px 20px;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .bg p {
	margin: 0;
}
.miyagisalmon #main .horizontal_scroll .scroller .case .bg .ill {
	border-bottom: 1px solid #ACBFD0;
	margin: 0 0 20px;
	text-align: center;
}
.miyagisalmon #main .post .voice h2 {
	margin: 100px 0 0;
	padding: 0 50px;
	line-height: 1.4;
}
.miyagisalmon #main .post .voice .h2outer h2:before,
.miyagisalmon #main .post .voice .h2outer h2:after {
	height: 90px;
}
.miyagisalmon #main .post .voice img {
	max-width: 100%;
	height: auto;
}
.miyagisalmon #main .post .voice .flex {
	margin: 0 0 30px;
}
.miyagisalmon #main .post .voice .h2outer + .flex.voice2 {
	margin: 40px 0 30px;
}
.miyagisalmon #main .post .voice .flex p,
.miyagisalmon #main .post .voice .flex dl {
	margin: 0;
}
.miyagisalmon #main .post .voice .flex.voice1 p {
	width: 230px;
}
.miyagisalmon #main .post .voice .flex.voice1 dl {
	width: calc(100% - 230px);
}
.miyagisalmon #main .post .voice .flex.voice2 p {
	width: 330px;
}
.miyagisalmon #main .post .voice .flex.voice2 dl {
	width: calc(100% - 330px);
}
.miyagisalmon #main .post .voice .flex dt {
	 letter-spacing: 0.05em;
	font-size: 18px;
	font-weight: 700;
}
.miyagisalmon #main .post .voice .flex dd {
	margin: 10px 0 0;
}
.miyagisalmon #main .post .voice .flex dd + dd {
	text-align: right;
}
@media screen and (max-width:1024px) {
	.miyagisalmon #main .season dl {
		width: 100%;
	}
	.miyagisalmon #main .season dl dt .arrow {
		width: 30px;
		transform: rotate(-90deg);
	}
	.miyagisalmon #main .season dl dt .arrow:before {
		top: -8px;
		left: 17px;
		transform: none;
	}
	.miyagisalmon #main .season .flex .case dl {
		display: block;
	}
	.miyagisalmon #main .season .flex .case dl:first-child {
		padding: 40px 20px 15px;
	}
	.miyagisalmon #main .season .flex .case dl dt .bg {
		display: flex;
		justify-content: center;
		align-items: baseline;
		width: 100%;
	}
	.miyagisalmon #main .season .flex .case dl dt {
		margin: 0 0 5px;
	}
	.miyagisalmon #main .season .flex .case dl dd strong {
		font-size: 20px;
	}
	.miyagisalmon #main .season .flex .case dl:first-child dd:after {
		top: -100px;
		height: 60px;
	}
	.miyagisalmon #main .season .flex .case:first-child dl:first-child dd:after {
		width: 102px;
		right: -20px;
	}
	.miyagisalmon #main .season .flex .case:last-child dl:first-child dd:after {
		width: 77px;
	}
	.miyagisalmon #main .season .flex + dl:after {
    top: 15px;
    right: -5px;
		width: 115px;
		height: 60px;
	}
}
@media screen and (max-width:767px) {
	.miyagisalmon #main .season .flex .case dl {
		padding: 10px 10px 15px;
	}
	.miyagisalmon #main .season .flex .case dl:first-child {
		padding: 40px 10px 15px;
	}
	.miyagisalmon #main .environment .flex p,
	.miyagisalmon #main .environment .flex dl {
		width: 100%;
	}
	.miyagisalmon #main .environment .flex p img {
		display: block;
		margin: 0 auto 10px;
	}
	.miyagisalmon #main .environment .flex dt {
		text-align: center;
		font-size: 18px;
	}
	.miyagisalmon #main .environment .flex dd {
		text-align: center;
	}
	.miyagisalmon #main .environment .flex dd ul {
		justify-content: center;
	}
	.miyagisalmon #main .environment .flex dd ul li:last-child {
		margin: 0;
	}
	.miyagisalmon #main .season h3 + dl {
		align-items: center;
	}
	.miyagisalmon #main .season dl dt .bg {
		line-height: 1;
	}
	.miyagisalmon #main .season dl dd {
		line-height: 1.5;
		font-size: 14px;
	}
	.miyagisalmon #main .season dl dd strong,
	.miyagisalmon #main .season .flex .case dl dd strong {
		text-align: center;
		font-size: 17px;
	}
	.miyagisalmon #main .season .flex .case dl dd strong {
		margin: 0 0 5px;
	}
	.miyagisalmon #main .season .flex + dl:after {
		top: 0;
	}
	.miyagisalmon #main .horizontal_scroll {
		height: auto;
		min-height: auto;
		margin: 30px -20px 0;
	}
	.miyagisalmon #main .horizontal_scroll .sticky {
		min-height: auto;
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case {
		width: 300px;
		height: 550px;
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case.bg1 {
		padding-left: 10px;
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case .wrap {
		width: 270px;
		height: 500px;
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case .bg {
		height: 300px;
		box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.2);
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case .bg p:first-child img {
		height: 60px;
	}
	.miyagisalmon #main .horizontal_scroll .scroller .case .bg p {
		line-height: 1.5;
		font-size: 14px;
	}
	.miyagisalmon #main .post .voice {
		padding: 0 20px;
	}
	.miyagisalmon #main .post .voice h2 {
		margin: 40px 0 0;
		padding: 0 40px;
	}
	.miyagisalmon #main .post .voice .h2outer h2:before,
	.miyagisalmon #main .post .voice .h2outer h2:after {
		height: 70px;
	}
	.miyagisalmon #main .post .voice .h2outer + .flex.voice2 {
		margin: 30px 0;
	}
	.miyagisalmon #main .post .voice .flex p {
		text-align: center;
	}
	.miyagisalmon #main .post .voice .flex dt {
		margin: 5px 0 0;
		text-align: center;
	}
	.miyagisalmon #main .post .voice .flex.voice1 p,
	.miyagisalmon #main .post .voice .flex.voice1 dl,
	.miyagisalmon #main .post .voice .flex.voice2 p,
	.miyagisalmon #main .post .voice .flex.voice2 dl {
		width: 100%;
	}
	.miyagisalmon #main .post .voice .flex dt {
		font-size: 16px;
	}
}
@media screen and (max-width:480px) {
	.miyagisalmon #main .inner {
		overflow-x: hidden;
    -ms-overflow-style: none;
    scrollbar-width: none;
	}
	.miyagisalmon #main .environment .flex dd {
		text-align: left;
	}
	.miyagisalmon #main .season dl {
		width: 100%;
		margin: 0 0 30px;
		box-shadow: 5px 5px 0 rgba(172,191,208,0.5);
	}
	.miyagisalmon #main .season .flex .case {
		width: 49%;
	}
	.miyagisalmon #main .season .flex .case dl:first-child:before {
		top: -20px;
	}
	.miyagisalmon #main .season .flex .case dl:after {
		bottom: -25px;
	}
	.miyagisalmon #main .season .flex + dl {
		padding: 10px 20px 70px;
	}
	.miyagisalmon #main .season .flex + dl:after {
		top: 40px;
		right: auto;
		left: 50%;
		margin: 0 0 0 -57px;
	}
	.miyagisalmon #main .season .flex .case:first-child dl:first-child dd:after {
		right: 0;
	}
	.miyagisalmon #main .season .flex .case:last-child dl:first-child dd:after {
		right: -12px;
	}
}
@keyframes scrollmove {
	0% {
		background-position: 100% 0;
	}
	75% {
		background-position: 0 0;
	}
	100% {
		background-position: -100% 0;
	}
}
