@media screen and (max-width: 679px) {
	/* base */
	html {
		margin: 0;
		padding: 0;
		height: 100%;
		width: 100%;
		overflow-x: hidden;
		font-size: 62.5%;
	}
	body {
		margin: 0;
		padding: 0;
		height: 100%;
		width: 100%;
		background-color: #fff;
		color: #666;
		font-family: '游ゴシック', YuGothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', Verdana , sans-serif;
		font-weight: 400;
		font-size: 1.4rem;
		-webkit-text-size-adjust: 100%;
	}
	img {
		border: none;
		max-width: 100%;
		height: auto;
		width: auto;
	}
	a {
		outline: none;
		transition: 0.3s ease;
	}
	a:link,
	a:visited {
		color: #333;
		text-decoration: none;
		transition: 0.3s ease;
	}
	a:hover,
	a:active {
		color: #000;
		text-decoration: none;
	}
	.clear {
		clear: both;
	}
	.pc {
		display: none;
	}
	p {
		line-height: 1.6;
	}

	/* loading */
	.loading-wrap {
		width: 100%;
		height: 100%;
		background: #fff;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 20001;
	}
	.loading-wrap img {
		width: 200px;
		position: absolute;
		top: 50%;
		left: 50%;
		margin-top: -20px;
		margin-left: -100px;
	}

	/* header */
	.header {
		width: 100%;
		height: 36px;
		background-color: #fff;
		margin: -36px 0 0;
		position: relative;
		z-index: 100;
		display: flex;
		justify-content: center;
		align-items: center;
		position: -webkit-sticky; /* Safari */
		position: sticky;
		top: 0;
		font-size: 14px;
		box-shadow: 0 0 5px rgba(0,0,0,0.15);
	}
	.header img {
		width: 100px;
	}
	.header .ja {
		position: relative;
		top: 1px;
	}
	.header .ja img {
		width: 28px;
		height: 17px;
	}

	/* intro */
	.intro {
		width: 100%;
		height: 100%;
		position: relative;
		background-color: #00A0E9;
		overflow-x: hidden;
		z-index: 1;
	}
	.intro .inner {
		width: 100%;
		height: 100%;
		background-image: url(/assets/top/text.gif);
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
	}
	.fix-sea .intro .inner {
		background-attachment: fixed;
	}

	/* copy */
	.intro .copy {
		width: 100%;
		height: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		background-image: url(/assets/top/map.svg?_=202003250333);
		background-position: center center;
		background-repeat: no-repeat;
		background-size: 85%;
	}
	.intro .copy.mis {
		background-image: url(/assets/top/map-mis.svg?_=202010270602);
		background-size: 100%;
	}
	.intro .copy h1 {
		display: block;
		width: 85%;
		height: 85%;
		margin: -36px auto 0;
		background-image: url(/assets/top/copy.svg?_=202003250333);
		background-position: top center;
		background-repeat: no-repeat;
		text-indent: -9999px;
	}

	/* qr */
	.intro .qr {
		display: none;
	}

	/* section */
	.section {
		clear: both;
		width: 100%;
		margin: 0;
		padding: 0;
		position: relative;
		text-align: center;
	}
	.section .inner {
		clear: both;
		width: 94%;
		margin: 0 auto;
		padding: 0;
		position: relative;
	}

	.section h1,
	.section h2,
	.section h3 {
		clear: both;
		color: #00A0E9;
		margin: 0;
		padding: 0;
	}
	.section h1 {
		font-size: 2rem;
	}
	.section h2 {
		font-size: 1.8rem;
	}
	.section h3 {
		font-size: 1.6rem;
	}

	/* service area */
	.service-area {
		padding: 50px 0;
		box-sizing: border-box;
		box-shadow: 0 1px 3px rgba(0,0,0,0.1);
		position: relative;
		z-index: 90;
	}
	.service-area .remark {
		font-size: 0.8rem;
	}
	.service-area .map {
		width: 100%;
		margin: 20px auto 0;
	}
	.service-area .attention {
		font-size: 1.2rem;
		text-align: right;
	}

	/* panels */
	.service-area .panels {
		display: flex;
		flex-wrap: wrap;
		margin: 0 auto;
	}
	.service-area .panel {
		border-radius: 5px;
		background-color: #eee;
		box-sizing: border-box;
		padding: 10px;
		width: 48%;
		margin: 0 auto 2% 1%;
	}
	.service-area .panels.wide .panel {
		width: 100%;
	}
	.service-area .ja-list {
		font-size: 1.1rem;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.service-area .ja-list span {
		white-space: nowrap;
	}
	.service-area .ja-list img {
		height: 10px;
	}

	.service-area .btn {
		margin: 20px auto 0;
	}
	.service-area .btn a {
		margin: 0 auto;
		display: block;
		width: 90%;
		max-width: 320px;
		height: 60px;
		line-height: 60px;
		border-radius: 30px;
		font-weight: bold;
		background-color: #00A0E9;
		color: #fff;
		background-image: url(/assets/top/icon-search.svg);
		background-position: center left 30px;
		background-repeat: no-repeat;
		background-size: 15px;
		text-indent: 10px;
	}
	.service-area .btn a:hover {
		background-color: #0D86BE;
	}

	/* service out area */
	.service-out-area {
		padding: 50px 0;
		box-sizing: border-box;
		background-color: #fafafa;
		box-shadow: 0 1px 5px rgba(0,0,0,0.1);
		position: relative;
		z-index: 80;
	}
	.service-out-area .map {
		width: 100%;
		margin: 0 auto 20px;
	}
	.service-out-area p {
		text-align: left;
	}
	.service-out-area .request {
		width: 94%;
		margin: 0 auto;
	}
	.request table {
		width: 100%;
		border: none;
		text-align: left;
		border-collapse: collapse;
	}
	.request table th {
		width: 100%;
		display: block;
	}
	.request table td {
		width: 100%;
		display: block;
	}
	.request input,
	.request textarea {
		appearance: none;
		-webkit-appearance: none;
		-moz-appearance: none;
		width: 100%;
		box-sizing: border-box;
		padding: 10px;
		background-color: #fff;
		border: 1px solid #ddd;
		border-radius: 8px;
		margin: 5px 0;
	}
	.request textarea {
		min-height: 60px;
	}
	.request .btn-request {
		margin: 20px auto 0;
		display: block;
		width: 90%;
		max-width: 320px;
		height: 60px;
		line-height: 60px;
		border-radius: 30px;
		font-size: 1.6rem;
		font-weight: bold;
		background-color: #00A0E9;
		color: #fff;
		background-image: url(/assets/top/icon-mail.svg);
		background-position: center left 20px;
		background-repeat: no-repeat;
		background-size: 16px;
		text-indent: 5px;
		border: 0;
		cursor: pointer;
		transition: 0.3s ease;
	}
	.request .btn-request:hover {
		background-color: #0D86BE;
	}

	.ranking {
		margin: 30px auto 0;
		background-color: #fff;
		box-shadow: 0 0 5px rgba(0,0,0,0.15);
		border-radius: 15px;
		padding: 20px;
		box-sizing: border-box;
	}

	.ranking .lists {
		margin: 20px auto 0;
	}
	.ranking .list {
		width: 100%;
		margin: 0 auto;
		font-size: 1.4rem;
	}
	.ranking .list ul {
		margin: 0;
		padding: 0;
		list-style: none;
		text-align: left;
	}
	.ranking .list ul li {
		margin: 4px 0;
		text-decoration: underline;
	}
	.ranking .list ul span {
		font-family: YuMincho, 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝体', 'Yu Mincho', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
		width: 45px;
		display: inline-block;
		text-decoration: none;
	}

	/* flyer */
	.flyer {
		padding: 50px 0;
		box-sizing: border-box;
		background-color: #D9EDF5;
		box-shadow: 0 1px 5px rgba(0,0,0,0.15);
		position: relative;
		z-index: 70;
	}
	.flyer .inner {
		background-color: #fff;
		border-radius: 10px;
		box-shadow: 0 0 5px rgba(0,0,0,0.15);
		padding: 30px;
		box-sizing: border-box;
	}
	.flyer h1 {
		margin: 0 auto;
		display: flex;
		align-items: center;
	}
	.flyer h1:before,
	.flyer h1:after {
		content: '';
		flex-grow: 1;
		height: 1px;
		background: #00A0E9;
		display: block;
	}
	.flyer h1:before {
		margin-right: 10px;
	}
	.flyer h1:after {
		margin-left: 10px;
	}
	.flyer .column {
		margin: 0 auto;
		display: flex;
		flex-direction: column;
	}
	.flyer .left,
	.flyer .right {
		width: 100%;
	}
	.flyer .left,
	.flyer .right {
		width: 48%;
	}
	.flyer div ul {
		text-align: left;
		list-style: none;
		padding: 0;
		margin: 15px auto;
	}
	.flyer div ul li {
		padding-left: 15px;
		text-indent: -15px;
		margin: 8px 0;
	}
	.flyer div ul li:before {
		content: '●';
		color: #00A0E9;
		font-size: 1rem;
		margin-right: 5px;
	}
	.flyer h3 {
		display: inline-block;
		margin: 20px auto 0;
		padding-left: 36px;
		background-repeat: no-repeat;
	}
	.flyer h3.icon1 {
		background-image: url(/assets/top/icon1.svg);
		background-position: left top 2px;
		background-size: 28px;
	}
	.flyer h3.icon2 {
		background-image: url(/assets/top/icon2.svg);
		background-position: left top;
		background-size: 26px;
	}
	.flyer h3.icon3 {
		background-image: url(/assets/top/icon3.svg);
		background-position: left top 3px;
		background-size: 26px;
	}
	.flyer h3.icon4 {
		background-image: url(/assets/top/icon4.svg);
		background-position: left top 2px;
		background-size: 30px;
	}
	.flyer h3.icon5 {
		background-image: url(/assets/top/icon5.svg);
		background-position: left top 1px;
		background-size: 21px;
	}
	.flyer h3.icon6 {
		background-image: url(/assets/top/icon6.svg);
		background-position: left top 2px;
		background-size: 28px;
	}
	.flyer h3.icon7 {
		background-image: url(/assets/top/icon7.svg);
		background-position: left top 1px;
		background-size: 20px;
	}
	.flyer h3.icon8 {
		background-image: url(/assets/top/icon8.svg);
		background-position: left top 3px;
		background-size: 26px;
	}

	/* farmer */
	.farmer {
		padding: 80px 0;
		box-sizing: border-box;
		background-color: #00A0E9;
		box-shadow: 0 1px 5px rgba(0,0,0,0.15);
		position: relative;
		z-index: 70;
		color: #fff;
	}
	.farmer h1 {
		color: #fff;
	}
	.farmer p {
		text-align: left;
	}
	.farmer .btn a {
		margin: 30px auto 0;
		display: block;
		width: 90%;
		max-width: 320px;
		height: 60px;
		line-height: 60px;
		border-radius: 30px;
		font-weight: bold;
		background-color: #fff;
		color: #00A0E9;
		background-image: url(/assets/top/icon-login.svg);
		background-position: center left 30px;
		background-repeat: no-repeat;
		background-size: 15px;
		text-indent: 10px;
	}
	.farmer .btn a:hover {
		background-color: #eee;
	}

	/* youtube */
	.youtube {
		width: 320px;
		height: 180px;
	}
	.youtube-caption {
		width: 320px;
	}

	/* app */
	.app {
		max-height: 460px;
		padding: 0;
		background-image: url(/assets/top/app-bg.jpg);
		background-position: center top;
		background-repeat: no-repeat;
		background-size: cover;
		box-shadow: 0 1px 5px rgba(0,0,0,0.15);
		position: relative;
		z-index: 60;
		overflow: hidden;
	}
	.app .gradation {
		min-height: 520px;
		box-sizing: border-box;
		padding: 20px 0;
		background-image: url(/assets/top/gr.png);
		background-position: center top;
		background-repeat: repeat-x;
	}
	.app h1 {
		width: 70%;
		max-width: 360px;
		margin: 20px auto;
	}
	.app p {
		width: 90%;
		margin: 0 auto;
		text-align: left;
	}
	.app .download {
		width: 80%;
		max-width: 280px;
		margin: 30px auto;
		display: flex;
		justify-content: space-between;
	}
	.app .download img {
		max-height: 45px;
		box-shadow: 0 0 5px rgba(255,255,255,0.8);
		transition: 0.3s ease;
	}
	.app .download img:hover {
		opacity: 0.7;
	}

	/* justify button list */
	.justify-button-list > span {
		width: 50%;
	}
}

@media screen and (orientation: landscape) {
	.intro .copy {
		background-size: 45%;
	}
	.service-area .panel {
		width: 24%;
	}
	.service-out-area .map {
		width: 100%;
		margin: 0 auto 20px;
	}
	.service-out-area .request {
		max-width: 400px;
	}
	.ranking .lists{
		display: flex;
	}
	.ranking .list{
		width: 48%;
	}
}

/* アクションバー表示時のコンテンツ余白 */
body.has-action-bar #page-area {
	padding-bottom: 60px;
}

