@charset "utf-8";

/*
 * style.css
 *
 *  version --- 1.0
 *  updated --- 2017/11/30
 */

/* !HTML5 elements
---------------------------------------------------------- */
header, 
footer, 
nav, 
section, 
aside, 
article {
    display: block;
}

/* !Reseting
---------------------------------------------------------- */
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

fieldset {
  border: none;
}

ul,
ol,
li {
	list-style: none;
}

img {
	max-width: 100%;
    height: auto;
	vertical-align: top;
}

table {
	border-collapse: collapse;
}

button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

select::-ms-expand {
	display: none;
}

input[type=radio]::-ms-check,
input[type=checkbox]::-ms-check{
	display: none;
}

select,
input[type=radio],
input[type=checkbox],
input[type=text],
input[type=password],
input[type=email],
input[type=tel],
input[type=number],
input[type=reset],
input[type=button],
input[type=submit],
textarea {
	appearance: none;
	border-radius: 0;
	font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

input[type=text]::-ms-clear,
input[type=tel]::-ms-clear,
input[type=number]::-ms-clear{
	display: none;
}

input[type=reset],
input[type=button],
input[type=submit]  {
	font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	cursor: pointer;
}

*,
*:before,
*::after {
	box-sizing: border-box;
}
/* !Clearfix
---------------------------------------------------------- */
.clearfix {
    display: block;
    min-height: 1%;
}

.clearfix:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
}

* html .clearfix {
    height: 1%;
}

/* !Layout
---------------------------------------------------------- */
html {
    overflow-y: scroll;
    font-size: 62.5%;
}
body {
	letter-spacing: 0.06em;
	font-family: YakuHanJP, "Zen Kaku Gothic New", sans-serif;
    font-size: 1.6rem;
    -webkit-text-size-adjust: none;
    line-height: 1.5;
    font-weight: normal;
    color: #333;
    -webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.font-notosans {
	font-family: YakuHanJP, "Noto Sans JP", sans-serif;
}
.font-zentokyo {
	font-family: "Zen Tokyo Zoo", system-ui;
}

@media screen and (max-width: 374px) {
	html {
		font-size: 2.6667vw;
	}
}

/* !Base Fonts -------------------------------------------------------------- */
a {
    color: inherit;
    text-decoration: none;
}

.no-link {
	pointer-events: none;
}

/*** hover ***/
@media screen and (min-width: 960px) {
    a {
        transition: all 0.5s;
    }

    .op {
        transition: opacity 0.5s ease-out;
    }

    .op:hover {
        opacity: .7;
    }

    a[href^="tel:"] {
        cursor: default;
        pointer-events:none;
    }
}

.is-hide {
    display: none;
}

.unload {
	overflow: hidden;
	height: 100vh;
}
#loading {
	position: fixed;
	left: 0;
	top: 0;
	z-index: 1;
	padding: 30rem 0 10rem;
	width: 100%;
	height: 100vh;
}
#loading .bg {
	transition-duration: 1s;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #00A23F;
	z-index: -1;
}
#loading .head {
	margin: 0 auto;
	writing-mode: tb-rl;
	writing-mode: vertical-rl;
	letter-spacing: 0.2em;
	line-height: 2;
	color: #fff;
	font-size: 3rem;
	font-weight: 700;
}
#loading .head p {
	opacity: 0;
	animation: fadeindown 1s forwards;
	animation-delay: 0.5s;
}
#loading .head p:nth-of-type(2) {
	animation-delay: 0.7s;
}
#loading .head p:nth-of-type(3) {
	animation-delay: 0.9s;
}
#loading .head p:nth-of-type(4) {
	animation-delay: 1.1s;
}
#loading .bike {
	opacity: 0;
	animation: fadein 1s forwards;
	animation-delay: 2s;
	margin: 5.8rem auto 0;
	text-align: center;
}
#loading .bike img {
	max-width: 15.5rem;
}
@keyframes fadeindown {
	0% {
		opacity: 0;
		transform: translateY(-2rem);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes fadein {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

#loading.is-loading .loading-inner {
	opacity: 0;
	transition: opacity .5s;
}

/* !wrapper
---------------------------------------------------------- */
#wrapper {
	position: relative;
	z-index: 2;
	background: url(../img/common/bg.png) center center repeat #F9F9F9;
	background-size: 100% auto;
}

.home:not(.is-loading) #wrapper {
	clip-path: rect(43rem calc(50% + 27.4rem) 93.2rem calc(50% - 27.4rem) round 2.8rem);
	opacity: 0;
	pointer-events: none;
}

.home #loading.is-loading + #wrapper {
	opacity: 1;
	clip-path: rect(0 100% 100% 0 round 0);
	pointer-events: auto;
	transition: opacity .5s .5s, clip-path .5s linear 2s;
}

#g-navi:before,
#header.active:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: url(../img/common/bg.png) center center repeat #F9F9F9;
	background-size: 100% auto;
}
/* sp */
@media screen and (max-width: 750px) {
	.home:not(.is-loading) #wrapper {
		/* padding: 7rem 0 0; */
		clip-path: rect(45rem calc(2rem + ((100% - 4rem) * .95)) 68rem calc(2.1rem + ((100% - 4rem) * .05)) round 1rem);
	}
	
	#loading {
		padding-top: 15rem;
	}
	#loading .head {
		font-size: 2rem;
	}
	
}

/* !header
---------------------------------------------------------- */
#header {
	display: flex;
	justify-content: space-between;
	position: fixed;
	left: 0;
	top: 0;
	transition-duration: 0.5s;
	z-index: 90;
	width: 100%;
}
#header.active {
	background: rgba(249,249,249,0.9);
}

.header-logo {
	display: flex;
	align-items: center;
	padding: 0 9rem;
	height: 11rem;
}
.header-logo a {
	display: block;
	position: relative;
}
.header-logo img {
	transition-duration: 0.5s;
	width: 15rem;
}
.header-logo .on {
	opacity: 0;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}

.btn-menu {
	cursor: pointer;
	position: relative;
	z-index: 5;
	width: 19rem;
	background: url(../img/common/icon_menu.svg)no-repeat center #00A23F;
	background-size: ;
	border-bottom-left-radius: 2rem;
}
.btn-menu.is-active {
	background-image: url(../img/common/icon_menu_close.svg);
}

#g-navi {
	display: none;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 3;
	width: 100%;
	height: 100vh;
	background: #F9F9F9;
}
.nav-content {
	display: flex;
	align-items: center;
	padding: 5rem 0;
	height: 100vh;
}
.nav-content .inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	max-width: 138rem;
}
.nav-content .left {
	width: 33%;
	max-width: 41rem;
}
.nav-content .right {
	width: 62%;
	max-width: 77rem;
}
#g-navi .logo {
	margin-bottom: 2.5rem;
	text-align: center;
	line-height: 1;
	letter-spacing: 0.1em;
	color: #00A23F;
	font-weight: 900;
	font-size: 1.5rem;
}
#g-navi .logo img {
	display: block;
	margin: 2rem auto 0;
	width: 100%;
	max-width: 28rem;
}
#g-navi .btns a {
	margin-top: 2.5rem;
	font-size: 2.4rem;
}
#g-navi .links1 {
	margin-left: -3rem;
}
#g-navi .links1 li {
	float: left;
	padding-left: 1rem;
	margin: -2px 0 0 3rem;
	width: calc(50% - 3rem);
	border-top: 2px solid #DEDEDE;
	border-bottom: 2px solid #DEDEDE;
}
#g-navi .links1 li a {
	display: block;
	background: url(../img/common/icon_link.svg)no-repeat right 1rem center;
	background-size: 2rem;
	letter-spacing: 0.03em;
	line-height: 1;
}
#g-navi .tit a {
	padding: 3.5rem 4rem 3.5rem 0;
	font-size: 2.4rem;
	font-weight: 700;
}
#g-navi .sub-tit {
	padding: 0 0 2rem;
}
#g-navi .sub-tit a {
	margin-bottom: 0.5rem;
	font-size: 2rem;
	font-weight: 500;
}
#g-navi .sub-tit span {
	display: inline-block;
	position: relative;
	padding: 0.8rem 0;
}
#g-navi .sub-tit span:after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	transition-duration: 0.5s;
	width: 0%;
	border-bottom: 1px solid;
}
#g-navi .links2 {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 6rem;
	margin-top: 4rem;
	letter-spacing: 0.03em;
	font-size: 2rem;
	font-weight: 500;
}

.header-links {
	margin-right: 7rem;
}
.header-links ul {
	display: flex;
	align-items: center;
	gap: 0 4rem;
	height: 100%;
	font-size: 1.8rem;
	font-weight: 700;
}
.header-links .download {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem 5rem;
	height: 6rem;
	background: linear-gradient(90deg, #F98C33, #ECCA6D);
	border-radius: 5rem;
	font-size: 1.7rem;
	font-weight: 900;
	color: #fff;
}

#header .download-cv {
	visibility: hidden;
	opacity: 0;
	position: fixed;
	left: 2rem;
	right: 2rem;
	bottom: 2rem;
	transition-duration: 0.3s;
	padding: 1.4rem 1.5rem;
	background: #fff;
	border-radius: 2rem;
}
#header .download-cv a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 6.5rem;
	background: linear-gradient(90deg, #F98C33, #ECCA6D);
	border-radius: 5rem;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 600;
}
#header .download-cv.show {
	visibility: visible;
	opacity: 1;
}


@media screen and (max-width: 1200px) {
	.header-logo {
		padding: 0 5rem;
	}
	
	.header-links {
		margin-right: 5rem;
	}
	.header-links ul {
		gap: 0 2rem;
	}
	
	.header-links .download {
		padding: 1rem 2.5rem;
	}
}
@media screen and (max-width: 959px) {
	.header-logo {
		padding: 0 3rem;
	}
	.header-links {
		margin-right: 3rem;
	}
	.header-links a {
		font-size: 1.6rem;
	}
	.header-links .download {
		font-size: 1.5rem;
	}
	
	.nav-content .inner {
	    display: block;
	}
	.nav-content .left,
	.nav-content .right {
		margin: 0 auto;
		width: auto;
	}
	
	#g-navi .links1 {
	    margin: 5.5rem 0 0 0;
	}
}
/*** hover ***/
@media screen and (min-width: 960px) {
	#g-navi .links1 a:hover {
		background-position: right center;
		background-image: url(../img/common/icon_link_gre.svg);
		color: #00A23F;
	}
	#g-navi .sub-tit a:hover span:after {
		width: 100%;
	}
	#g-navi .sub-tit .color-ora:hover {
		background-image: url(../img/common/icon_link_ora.svg);
		color: #F98C33;
	}	
	#g-navi .links2 a:hover {
		color: #00A23F;
	}
	
	.header-links a:hover {
		opacity: 0.7;
	}
}
/* sp */
@media screen and (max-width: 750px) {
	.header-logo {
	    padding: 0 2rem;
	    height: 7rem;
	}
	.btn-menu {
		width: 8rem;
		background-size: 3rem;
	}
	
	#g-navi {
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}
	.nav-content {
	    display: block;
		padding: 18rem 0;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	    height: 100vh;
	}
	.nav-content .inner {
	    display: block;
	}
	.nav-content .left {
		max-width: 33.3rem;
	}
	.nav-content .left,
	.nav-content .right {
	    width: auto;
	}
	#g-navi .logo {
	    margin-bottom: 4rem;
	}
	#g-navi .logo img {
		margin-top: 1.5rem;
		max-width: 21.4rem;
	}
	#g-navi .btns a {
	    margin-top: 2rem;
	    font-size: 1.8rem;
	}
	#g-navi .links1 li {
	    float: none;
	    padding-left: 1rem;
	    margin: -2px 0 0 0;
	    width: auto;
	}
	#g-navi .tit a {
	    padding: 2.5rem 4rem 2.5rem 0;
	    font-size: 2rem;
	}
	#g-navi .sub-tit {
	    padding: 0 0 1.6rem;
	}
	
	#g-navi .sub-tit a {
		font-size: 1.8rem;
	}
	
	#g-navi .links2 {
	    display: block;
	    gap: 1rem 7rem;
	    margin-top: 5rem;
	    font-size: 1.6rem;
	}
	#g-navi .links2 li {
		padding: 0 1rem 1.6rem;
	}
	
	.header-links {
		display: none;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		position: absolute;
		left: 0;
		top: 0;
		z-index: 3;
		padding: 10rem 2rem 8rem;
		width: 100%;
		height: 100vh;
		background: #00A23F;
	}
	.header-links ul {
		display: block;
		gap: 0;
	}
	.header-links li + li {
		border-top: 2px solid #DEDEDE;
	}
	.header-links li a {
		display: block;
		padding: 2.5rem 4rem 2.5rem 1rem;
		background: url(../img/common/icon_link_wh.svg) no-repeat right 1rem center;
		background-size: 2rem;
		line-height: 1;
	}
	.header-links .download {
		margin-top: 3rem;
	}
	
	
}

/* !footer
---------------------------------------------------------- */
#footer {
	overflow: hidden;
	position: relative;
}

#footer .txt-swiper {
	position: relative;
}
#footer .txt-circle:before {
	left: -10%;
	top: -10%;
	width: 120%;
	height: 120%;
}

.page-top {
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	left: 6.6rem;
	bottom: -5.3rem;
	z-index: 2;
	width: 18.3rem;
	height: 18.3rem;
	background: rgba(210,237,220,0.3);
	border-radius: 50%;
}
#footer .bike {
	position: absolute;
	left: 22rem;
	bottom: 10rem;
	z-index: 2;
	transform: rotate(30deg);
	width: 15rem;
}

.footer-bg {
	position: relative;
	margin-top: -4rem;
	padding: 8rem 5rem 7rem;
	background: rgba(255,255,255,0.8);
	border-radius: 7rem 7rem 0 0;
	box-shadow: 0 -1rem 2.4rem rgba(0,0,0,0.05);
}
.footer-inner {
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 150rem;
}
.foot-logo {
	margin-right: 5rem;
}
.foot-logo img {
	width: 23.8rem;
}
#footer .right {
	width: calc(100% - 24rem);
	max-width: 81rem;
}
#footer .btns {
	display: flex;
	justify-content: space-between;
	gap: 0 2rem;
	margin-bottom: 3.2rem;
}
#footer .btns a {
	height: 5.8rem;
    width: 100%;
	font-size: 2rem;
}
.foot-links {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0 3rem;
}
.foot-links a {
	display: block;
	background: url(../img/common/icon_link.svg) no-repeat right 1rem center;
	background-size: 1.2rem;
}
.foot-links .li {
	padding: 2rem 0;
	margin-top: -1px;
	border-top: 1px solid #DEDEDE;
	border-bottom: 1px solid #DEDEDE;
	line-height: 1.5;
	font-weight: 500;
}
.foot-links .level1 {
	position: relative;
	padding: 0.2rem 2.4rem 0.2rem 1rem;
	letter-spacing: 0.03em;
	font-size: 2rem;
}
.foot-links .level2 {
	position: relative;
	margin-top: 1.1rem;
	padding: 0 2.4rem 0 3rem;
	font-size: 1.8rem;
}
.foot-links .level2 span {
	display: inline-block;
	position: relative;
}
.foot-links .level2 span:after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -0.5rem;
	transition-duration: 0.3s;
	width: 0;
	border-bottom: 1px solid;
}
.function-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0 3rem;
	margin-top: 3.2rem;
	font-weight: 500;
	font-size: 1.6rem;
}
.function-links .links {
	display: flex;
	gap: 0 3rem;
	font-size: 1.8rem;
} 

@media screen and (max-width: 1200px) {
	.page-top {
		left: -5rem;
	}
	#footer .bike {
	    left: 8rem;
		bottom: 12rem;
	}
	
	.function-links .links {
	    gap: 0 3rem;
	}
}
@media screen and (max-width: 1024px) {
	.foot-logo {
	    margin-right: 2.5rem;
	}
	.foot-logo img {
	    width: 18rem;
	}
	#footer .right {
		width: auto;
	}
	.foot-links {
		gap: 0 1.6rem;
	}
	.foot-links .level2 {
	    padding-left: 2rem;
	}
}

@media screen and (max-width: 959px) {
	.function-links,
	.function-links .links {
		font-size: 1.3rem;
	}
}

/*** hover ***/
@media screen and (min-width: 960px) {
	.foot-links a:hover {
		color: #00A23F;
		background-image: url(../img/common/icon_link_gre.svg);
		background-position: right center;
	}
	.foot-links .level2:hover span:after {
		width: 100%;
	}
	.function-links .links a:hover {
		color: #00A23F;
	}
}

/* sp */
@media screen and (max-width: 750px) {
	
	.footer-bg {
	    margin-top: -5rem;
	    padding: 6rem 2rem;
	}
	.page-top,
	#footer .bike {
		display: none;
	}
	.footer-inner {
	    display: block;
	}
	#footer .right {
	    width: auto;
	}
	.foot-logo {
		margin-bottom: 4rem;
		text-align: center;
	}
	.foot-logo img {
	    width: 18.4rem;
	}
	#footer .btns {
	    display: block;
	    margin: 0 auto 4rem;
		max-width: 30.3rem;
	}
	#footer .btns a + a {
		margin-top: 1rem;
	}
	.foot-links {
	    grid-template-columns: repeat(1, 1fr);
	    margin: 0 auto;
		max-width: 30.3rem;
	}
	.foot-links .li {
	    padding: 1.5rem 0;
	    line-height: 1;
	}
	.function-links {
	    display: block;
	    margin-top: 4rem;
		text-align: center;
	}
	.foot-links .level1 {
	    font-size: 1.6rem;
	}
	.foot-links .level2 {
	    padding-left: 3rem;
	    font-size: 1.3rem;
	    margin-top: 1.8;
	}
	.function-links {
		font-size: 1.3rem;
	}
	.function-links .links {
		justify-content: center;
	    gap: 0 2rem;
		font-size: 1.3rem;
	}
	
	#copyright {
		margin-top: 3rem;
	}
	
}


/* !common
---------------------------------------------------------- */
@media screen and (min-width: 751px) {
    .is-sp {
        display: none !important;
    }
}

@media only screen and (max-width : 750px){
	.is-pc {
		display: none !important;
	}
}

.inner,
.inner-small {
	margin: 0 auto;
	padding: 0 5rem;
	width: 100%;
	max-width: 160rem;
}
.inner-small {
	max-width: 138rem;
}

@media screen and (max-width: 959px) {
	.inner,
	.inner-small {
		padding: 0 3rem;
	}
}

.color-gre {
	color: #00A23F;
}
.color-ora {
	color: #F98C33;
}

#main-visual .kv {
	position: relative;
	z-index: 2;
	padding: 15.4rem 0;
}
#main-visual .kv .bg {
	opacity: 0;
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
}
#main-visual .kv .bg img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
#main-visual .head {
	opacity: 0;
	margin-bottom: 8rem;
	text-align: center;
}

.photo-list {
	position: relative;
	max-width: 54.8rem;
	margin: 0 auto;
}
.photo-list li {
	width: 100%;
	height: 54.8rem;
	position: relative;
	z-index: 4;
	transform-origin: center bottom;
  transition: transform 1s cubic-bezier(0.215,0.610,0.355,1.000),opacity 1s cubic-bezier(0.215,0.610,0.355,1.000);
  will-change: transform;
}

.photo-list li img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 2.8rem;
  box-shadow: 0 .3rem .6rem rgba(0,0,0,0.16);
}

:is(.photo-list li):after {
	border: .4rem solid #00A23F;
	border-radius: 2.8rem;
    width: 100%;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    opacity: 0;
    transition: opacity 1s cubic-bezier(0.215,0.610,0.355,1.000);
    content: '';
}

:is(.photo-list li):is([data-status=active],[data-status=first],[data-status=prev]):after {
    opacity: 1;
}

:is(.photo-list li):is(:not([data-status=active],[data-status=first])) {
    left: 0;
    position: absolute;
    top: 0
}

:is(.photo-list li):is([data-status=active],[data-status=first],[data-status=prev]) {
    transform: rotate(0deg);
    z-index: 5
}

:is(.photo-list li):is([data-status=next]) {
    transform: rotate(-6deg) translate3d(1.25em, 0, 0);
}

:is(.photo-list li):is([data-status=prev]) {
    opacity: 0;
    transform: rotate(10deg) translate3d(-1em, 0, 0);
    z-index: 6
}

:is(.photo-list li):is([data-status=prev-prev]) {
    opacity: 0;
    transform: rotate(-10deg)
}

:is(.photo-list li):is([data-status=standby]) {
		opacity: .2;
    transform: rotate(6deg) translate3d(-1em, 0, 0);
}

:is(.photo-list li):is([data-status=first]):after {
    content: none
}

:is(.photo-list li):is([data-status=first]) img {
    transform: scale(1.3)
}

:is(.photo-list li):is([data-status=third]) {
    opacity: 0;
    transform: rotate(10deg);
    transition: none
}

:is(.photo-list li):is([data-status=undefined]) {
    opacity: 0
}

#main-visual .btns {
	display: flex;
	gap: 2rem;
	position: relative;
	z-index: 3;
	padding: 1.4rem 2rem;
	margin: -5.4rem auto 0;
	max-width: 90rem;
	background: #fff;
	border-radius: 8rem;
	box-shadow: 0 0.4rem 2.4rem rgba(0,0,0,0.05);
}
#main-visual .btns a {
	width: 100%;
}

.btn-link .btn {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 8rem;
	border-radius: 8rem;
	letter-spacing: 0.12em;
	color: #fff;
	font-weight: 600;
	font-size: 2.2rem;
}
.btn-link .green-st {
	background: linear-gradient(90deg, #35B264, #AEDA7B);
}
.btn-link .orange-st {
	background: linear-gradient(90deg, #F98C33, #ECCA6D);
}

.btn-link2 {
	margin-top: 5rem;
	text-align: center;
	line-height: 1;
	letter-spacing: 0.12em;
}
.btn-link2 .tit {
	margin-bottom: 3rem;
	font-weight: 900;
	font-size: 3.2rem;
}

@media screen and (max-width: 959px) {
	.btn-link2 .tit {
		font-size: 3rem;
	}
}

.btn-link2 .btn {
	display: inline-flex;
	align-items: center;
	position: relative;
	padding: 0 8rem;
	width: 100%;
	max-width: 60rem;
	height: 10rem;
	border-radius: 8rem;
	color: #fff;
	font-weight: 700;
	font-size: 2.2rem;
}
.btn-link2 .btn:before {
	content: "";
	position: absolute;
	right: 8rem;
	top: 0;
	transition-duration: 0.3s;
	height: 100%;
	width: 2rem;
	background: url(../img/common/icon_link_wh.svg)no-repeat center;
	background-size: 100%;
}
.btn-link2 .orange-st {
	background: linear-gradient(90deg, #F98C33 0%, #ECCA6D 100%);
}
.btn-link2 .green-st {
	background: linear-gradient(90deg, #35B264 0%, #AEDA7B 100%);
}

.head-large {
	margin-bottom: 6rem;
	text-align: center;
	line-height: 1;
	color: #6C624F;
}
.head-large p + p {
	margin-top: 2.5rem;
}
.head-large .eng {
	letter-spacing: 0.05em;
	font-size: 4.8rem;
	font-weight: 900;
}
.head-large .jap {
	font-size: 2rem;
	font-weight: 700;
}

.head-small {
    text-align: center;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.6;
}

.js-image-scroll {
	overflow: hidden;
	display: flex;
}
.js-image-scroll ul {
	display: flex;
	align-items: flex-start;
}
.js-image-scroll ul:nth-child(odd) {
	animation-name: image-loop-left1;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
}
.js-image-scroll ul:nth-child(even) {
    animation-name: image-loop-left2;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
}
@keyframes image-loop-left1 {
	0% {
	    transform: translateX(100%);
	}
	100% {
	    transform: translateX(-100%);
	}
}
@keyframes image-loop-left2 {
	0% {
	    transform: translateX(0);
	}
	100% {
	    transform: translateX(-200%);
	}
}
.txt-swiper li {
	overflow: hidden;
	padding-right: 9rem;
	width: auto;
	text-align: center;
}
.txt-swiper h3 {
	white-space: nowrap;
	word-wrap: break-word;
	word-break:break-all;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1;
	color: #53BE7C;
	font-size: 10.6rem;
	font-weight: 400;
}


@media screen and (max-width: 900px) {
	#main-visual .btns {
		margin: -5.4rem 5rem 0;
	}
}
/*** hover ***/
@media screen and (min-width: 960px) {
	.btn-link .green-st:hover {
		background: #fff;
		border: 3px solid #00A23F;
		color: #00A23F;
	}
	.btn-link .orange-st:hover {
		background: #fff;
		border: 3px solid #F98C33;
		color: #F98C33;
	}
	.btn-link2 .btn:hover:before {
		right: 7rem;
	}
	.btn-link2 .green-st:hover {
		background: #fff;
		border: 3px solid #00A23F;
		color: #00A23F;
	}
	.btn-link2 .green-st:hover:before {
		background-image: url(../img/common/icon_link_green.svg);
	}
	.btn-link2 .orange-st:hover {
		background: #fff;
		border: 3px solid #F98C33;
		color: #F98C33;
	}
	.btn-link2 .orange-st:hover:before {
		background-image: url(../img/common/icon_link_orange.svg);
	}
}

/* sp */
@media screen and (max-width: 750px) {
	.inner,
	.inner-small {
		padding: 0 2rem;
	}
	
	#main-visual .kv {
	    padding: 12rem 0 10rem;
	}	
	#main-visual .head {
		text-align: center;
	}
	.photo-list {
	    max-width: 90%;
	}
	.photo-list li {
	    width: 100%;
	    height: 74.667vw;
	}
	.photo-list li img {
		border-radius: 1rem;
	}
	.photo-list li.current2 img {
		border-width: 2px;
	}
	:is(.photo-list li):after {
		border-radius: 1rem;
	}
	#main-visual .btns {
	    display: block;
		transform: translateY(0);
	    padding: 2rem 1.5rem;
	    margin: 3rem 2rem 0;
	    border-radius: 2rem;
	    box-shadow: 0 0.4rem 2.4rem rgba(0, 0, 0, 0.05);
	}
	#main-visual .btns a {
		height: 4.5rem;
	}
	#main-visual .btns a + a {
		margin-top: 0.8rem;
	}
	
	.btn-link .btn {
		height: 6.5rem;
		font-size: 1.8rem;
	}
	.btn-link2 {
	    margin-top: 5.5rem;
	}
	.btn-link2 .tit {
		line-height: 1.6;
	    font-size: 3rem;
	}
	.btn-link2 .btn {
	    padding: 0 2.5rem;
	    height: 7rem;
	    font-size: 1.8rem;
	}
	.btn-link2 .btn:before {
	    right: 2.5rem;
	}
		
	.head-large {
	    margin-bottom: 4rem;
	}
	.head-large p + p {
	    margin-top: 2rem;
	}
	.head-large .eng {
	    font-size: 4rem;
	}
	
	.head-small {
		font-size: 1.7rem;
	}
}


/* !page
---------------------------------------------------------- */
.top-news {
	padding: 10rem 0 0; 
}
.top-news .news-type {
	display: flex;
}
.top-news .news-type .item {
	overflow: hidden;
	width: 50%;
}
.top-news .head-news {
	max-width: 77rem;
	line-height: 1;
	font-size: 3.2rem;
	font-weight: 700;
} 

@media screen and (max-width: 959px) {
	.top-news .head-news {
		font-size: 2.3rem;
	}
}

.top-news .head-news .con {
	display: inline-block;
	padding: 1.65rem 4rem;
	width: 100%;
	max-width: 60rem;
	border-radius: 3rem 3rem 0 0;
}
.top-news .head-news .con:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	margin-right: 1rem;
	width: 1.2rem;
	height: 0.2rem;
	border-radius: 1rem;
}
.top-news .list {
	position: relative;
	z-index: 2;
	padding: 1.5rem 0 5rem;
	max-width: 75rem;
}
.top-news .list:before {
	content: "";
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 50%;
	z-index: -1;
	transform: translateX(-50%);
	height: 100%;
	width: 200rem;
}
.top-news .list dl {
	padding: 3.5rem 0;
	display: flex;
	width: 100%;
	flex-direction: column-reverse;
}
.top-news .list dl + dl {
	border-top: 1px solid #D9D9D9;
}
.top-news .list dd {
	margin-bottom: 1.6rem;
	overflow:hidden;  
	text-overflow:ellipsis;  
	white-space:nowrap;
	font-size: 1.8rem;
	font-weight: 500;
}
.top-news .list dt {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	line-height: 1;
}

.top-news .list .date {
	font-size: 1.6rem;
	line-height: 1.2;
}

.top-news .list .tags {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .5rem;
}

.top-news .list .tag {
	padding: 0.3rem 1rem 0.4rem;
	border-radius: 2rem;
	color: #fff;
	font-size: 1.5rem;
}
.btn-golist {
	margin-top: 1.5rem;
	text-align: center;
}
.btn-golist a {
	display: inline-flex;
	align-items: center;
	padding: 0 7rem;
	height: 5rem;
	width: 100%;
	max-width: 33rem;
	background: no-repeat right 7rem center #fff;
	border-radius: 5rem;
	border: 2px solid;
	font-weight: 700;
	font-size: 1.4rem;
}

.top-news .green-st.item {
	padding-left: 5rem;
}
.top-news .green-st .head-news,
.top-news .green-st .list {
	margin-left: auto;
}
.top-news .green-st .list {
	padding-left: 2rem;
}
.top-news .green-st .head-news .con,
.top-news .green-st .list:before {
	background: #ECF7F0;
}
.top-news .green-st .head-news .con:before,
.top-news .green-st .list .tag {
	background: #00A23F;
}
.top-news .green-st .list dl {
	padding-right: 4rem;
}
.green-st .btn-golist a {
	background-image: url(../img/common/icon_link_gre.svg);
	border-color: #00A23F;
	color: #00A23F;
}
.top-news .orange-st.item {
	padding-right: 5rem;
}
.top-news .orange-st .head-news .con,
.top-news .orange-st .list:before {
	background: #FFFAEF;
}
.top-news .orange-st .list dl {
	padding-left: 4rem;
}
.top-news .orange-st .head-news .con:before,
.top-news .orange-st .list .tag {
	background: #F98C33;
}
.orange-st .btn-golist a {
	background-image: url(../img/common/icon_link_ora.svg);
	border-color: #F98C33;
	color: #F98C33;
}

.top-about {
	overflow: hidden;
	padding: 12rem 0;
}
.top-about .head {
	text-align: center;
	letter-spacing: 0.05em;
	color: #6C624F;
	font-weight: 700;
	font-size: 3.2rem;
}
.top-about .head .big {
	font-weight: 900;
	font-size: 5rem;
}
.bike-circle {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	margin: 5.5rem auto 11rem;
	padding: 3rem 0;
	width: 27rem;
	height: 27rem;
	background: #D2EDDC;
	border-radius: 50%;
}
.txt-circle:before {
	content: "";
	pointer-events: none;
	position: absolute;
	left: -15%;
	top: -15%;
	width: 130%;
	height: 130%;
	background: url(../img/common/txt_circle.svg)no-repeat center;
	background-size: 100%;
	animation: rotateCircle 30s linear infinite;
}
@keyframes rotateCircle {
    from {
      transform: rotate(0deg);
    }
    to {
      transform: rotate(360deg);
    }
}
.bike-circle img {
	max-width: 20.2rem;
}
.top-about .sub {
	text-align: center;
	line-height: 2;
	font-size: 2.4rem;
	letter-spacing: .06em;
	font-weight: 500;
}
.top-about .sub p + p {
	margin-top: 2em;
}
.foucs-line {
	background: linear-gradient(0deg, #F98C33 0.5rem, transparent 0.5rem);
}

.about-swiper {
	margin: 8rem auto 0;
}
.about-swiper .swiper-slide {
	width: 50rem;
	height: 50rem;
}
.about-swiper .swiper-slide:nth-of-type(odd) {
	margin-top: 9rem;
}
.about-swiper .slide-ctrl {
	position: relative;
	margin-top: 7.5rem;
	padding: 0 5rem;
	max-width: 160rem;
}
.about-swiper .swiper-scrollbar {
	position: static;
	height: 0.2rem;
	width: calc(100% - 30rem);
	background: #DEDEDE;
}
.slide-ctrl .swiper-scrollbar .swiper-scrollbar-drag {
	background: #00A23F;
}
.about-swiper .swiper-button-prev,
.about-swiper .swiper-button-next {
	top: 50%;
	z-index: 2;
	transform: translateY(-50%);
	transition-duration: 0.5s;
	margin: 0;
	width: 9rem;
	height: 9rem;
	border-radius: 50%;
}
.about-swiper .swiper-button-prev {
	left: auto;
	right: 18rem;
}
.about-swiper .swiper-button-next {
	right: 5rem;
}
.about-swiper .swiper-button-prev:after,
.about-swiper .swiper-button-next:after {
	content: "";
	position: absolute;
	left: 0.2rem;
	bottom: 0.3rem;
	z-index: -1;
	width: 100%;
	height: 100%;
	background: no-repeat center;
	background-size: 100%;
}
.about-swiper .swiper-button-prev:after {
	background-image: url(../img/common/slide_circle_left.svg);
}
.about-swiper .swiper-button-next:after {
	background-image: url(../img/common/slide_circle_right.svg);
}
.about-swiper .swiper-slide img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	border-radius: 2rem;
}

.top-howto {
	position: relative;
	z-index: 2;
	padding: 0 0 6.5rem;
	margin-top: 28rem;
	background: #00A23F;
	color:  #fff;
}
.top-howto:before {
	content: "";
	pointer-events: none;
	position: absolute;
	left: 0;
	bottom: 100%;
	z-index: -1;
	height: 28rem;
	width: 100%;
	background: url(../img/top/bg_howto_cloud.webp)no-repeat center top;
	background-size: auto 100%;
}

@media screen and (min-width: 1920px) {
	.top-howto:before {
		background-size: 100% 100%;
	}
}

.top-howto .inner {
	max-width: 138rem;
}

.top-howto .head-large {
	color:  #fff;
}
.top-howto .txt-swiper {
	position: absolute;
	left: 0;
	top: 32rem;
	z-index: 0;
	width: 100%;
}
.howto-flow {
	position: relative;
	padding-top: 3rem;
}
.howto-flow ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 4rem;
	position: relative;
	z-index: 2;
}
.howto-flow li {
	position: relative;
	padding: 0 1rem 3.4rem;
	background: #fff;
	border-radius: 3rem;
	border: 3px solid #F98C33;
	box-shadow: 0 0.4rem 3rem #10883C;
	text-align: center;
	aspect-ratio: 1/1;
}
.howto-flow li + li:before {
	content: "";
	position: absolute;
	left: -4.3rem;
	top: 50%;
	transform: translateY(-50%);
	border-style: solid;
	border-color: transparent transparent transparent #F98C33;
	border-width: 1.5rem 0 1.5rem 3rem;
}
.howto-flow li .step {
	position: relative;
	z-index: 2;
	margin: -2.5rem 0 2rem;
	letter-spacing: 0.1em;
	line-height: 1;
	color: #F98C33;
	font-size: 6rem;
	font-weight: 900;
}
.howto-flow li .step:before {
	content: attr(data-tit);
	position: absolute;
	left: 50%;
	top: 50%;
	z-index: -1;
	transform: translate(-50%, -50%);
	-webkit-text-stroke: 1rem #fff; 
} 
.howto-flow li .tit {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 2rem;
	line-height: 1.2;
	color: #00A23F;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: .05em;
}


.top-newoptions {
	position: relative;
	z-index: 2;
	padding-top: 100vh;
}
.top-newoptions .banner {
	position: absolute;
	left: 0;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
}
.top-newoptions .banner img {
	object-fit: cover;
	position: sticky;
	top: 0;
	width: 100%;
	height: 100vh;
}
.top-newoptions .options-wrap {
	overflow: hidden;
	position: relative;
	padding: 13rem 5rem 7rem;
	background: linear-gradient(180deg, rgba(249,249,249,0), rgba(249,249,249,1));
}
.options-wrap .bike {
	position: absolute;
	left: 9rem;
	bottom: 0;
}
.options-wrap .txt-circle {
	position: absolute;
	left: calc(50% + 35rem);
	bottom: 20rem;
	width: 40rem;
	height: 40rem;
}
.options-wrap .txt-circle:before {
	background-image: url(../img/common/txt_circle2.svg);
}
.options-wrap .box {
	position: relative;
	padding: 21.4rem 16rem 24.6rem;
	margin: 0 auto;
	max-width: 78rem;
	background: rgba(249, 249, 249, 0.9);
	border-radius: 39rem;
	box-shadow: 0 0.4rem 5.4rem rgba(0,0,0,0.15);
}

@media screen and (max-width: 900px) {
	.options-wrap .box {
		padding: 21.4rem 10rem 24.6rem;
	}
}
.options-wrap .box:before {
	content: "";
	pointer-events: none;
	position: absolute;
	left: 2.8rem;
	top: 4rem;
	width: calc(100% - 5.6rem);
	height: calc(100% - 8rem); 
	border: 3px dashed #00A23F;
	border-radius: 39rem;
}
.options-wrap .head {
	margin-bottom: 7rem;
	line-height: 1.4;
	color: #00A23F;
	font-size: 4.8rem;
	font-weight: 700;
	letter-spacing: .12em;
}

.options-wrap .txt p {
	margin-bottom: 2em;
	line-height: 2;
	font-size: 2.4rem;
	font-weight: 500;
}

@media screen and (min-width: 768px) {
	.options-wrap .txt p {
		word-break: keep-all;
	}
}

.options-wrap .btn-link2 {
	margin-top: 7rem;
}

.options-wrap .btn-link2 .btn {
	font-size: 2.6rem;
}

.top-servicearea {
	padding: 13rem 0 0;
}
.top-casestudy {
	margin: 13rem 0 0;
	padding: 10rem 0 6.8rem;
	display: flex;
	justify-content: space-evenly;
	background-color: #fefaf0;
	background-image: url(../img/top/map_trimming.webp);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: 15% center;
}
.top-casestudy h2.head-large {
	text-align: left;
}
.top-casestudy .regions-organizations {
	width: 60%;
	max-width: 1010px;
}
.top-casestudy .various-case li {
	display: inline-block;
	width: 24%;
	text-align: center;
	padding: 2rem 0;
	background: #fff;
	border: 1px solid #ccc;
	border-radius: 8px;
	margin-bottom: .5em;
	font-size: 2rem;
	font-weight: 500;
}
.top-casestudy .various-case li span {
	margin-left: 1em;
	font-weight: 400;
}
.top-casestudy p.txt {
	font-size: 2rem;
	margin-top: 2rem;
	line-height: 1.7;
}
.top-casestudy p.txt span {
	font-size: 3rem;
	font-weight: bold;
	position: relative;
	line-height: 1.6;
	z-index: 2;
	background: linear-gradient(#e99148,#e99148) left bottom no-repeat;
	background-size: 100% .3rem;
}
/*.top-casestudy p.txt span:before {
	position: absolute;
	bottom: 2px;
	left: 0;
	content:"";
	width: 100%;
	height: 3px;
	background: #e99148;
	z-index: -1;
}*/
@media screen and (max-width: 969px) {
	.top-casestudy .various-case li span {
		display: block;
		margin-left: 0;
	}
}
@media screen and (max-width: 750px) {
	.top-casestudy {
		margin: 11rem 0 0;
		padding: 8rem 0;
		display: block;
		background-size: cover;
		background-position: center center;
	}
	.top-casestudy h2.head-large {
		text-align: center;
	}
	.top-casestudy .regions-organizations {
		width: 90%;
		margin: 0 5%;
	}
	.top-casestudy .various-case {
		text-align: center;
	}
	.top-casestudy .various-case li {
		width: 49%;
		padding: .5em;
		font-size: 1.6rem;
		display: inline-flex;
		height: 7rem;
		align-items: center;
		justify-content: center;
	}

	.top-casestudy .various-case li span {
		display: inline-block;
		margin-left: 1rem;
		font-weight: 500;
	}

	.top-casestudy p.txt {
		margin-top: .5rem;
		font-size: 1.5rem;
	}

	.top-casestudy p.txt span {
		margin-bottom: 1rem;
	}
}

.top-servicearea .head {
	margin-bottom: 2rem;
	text-align: center;
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 1.6;
}
.top-servicearea .head2 {
	margin-bottom: 6rem;
	text-align: center;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.6;
}
.area-introd ul {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 2.5rem 3.2rem;
}
.area-introd li a {
	display: block;
	overflow: hidden;
	position: relative;
	padding-top: 100%;
	height: 0;
	border-radius: 1rem;
}
.area-introd li .img {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
}
.area-introd li .img img {
	object-fit: cover;
	transition-duration: 0.5s;
	width: 100%;
	height: 100%;
}
.area-introd li .info {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	transition-duration: 0.5s;
	width: 100%;
	height: 100%;
	color: #fff;
	background: rgba(0,0,0,0.2);
}
.area-introd li .area {
	line-height: 1.4;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
}
.area-introd li .place {
	display: block;
	margin-top: .8rem;
	font-size: 4rem;
	line-height: 1;
}
.area-introd li .eng {
	display: block;
	margin-top: .8rem;
	font-size: 2rem;
}
.area-introd li.note .eng:after {
	content: "※";
	display: block;
	margin-top: 1rem;
	font-size: 2.6rem;
	font-weight: 900;
	line-height: 1;
}
.top-servicearea .notes {
	margin-top: 2.5rem;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.6;
	font-weight: 500;
	font-size: 2rem;
}

.top-contact {
	padding: 16rem 0 8rem;
}
.top-contact .head {
	margin: 0 40rem 2rem 0;
	color: #fff;
	font-size: 3.2rem;
	font-weight: 700;
}
.top-contact .head .foucs {
	letter-spacing: -0.05em;
	color: #FFFB00;
	font-size: 4.8rem;
}
.top-contact .contact-display {
	position: relative;
	padding: 6rem 11rem 5rem;
	margin: 0 auto;
	max-width: 150rem;
	background: #00A23F;
	border-radius: 2rem;
	box-shadow: 0 4rem 4rem rgba(0,0,0,0.15);
}
.top-contact .contact-display:before {
	content: "";
	pointer-events: none;
	position: absolute;
	left: 1rem;
	top: 1rem;
	width: calc(100% - 2rem);
	height: calc(100% - 2rem);
	border-radius: 2rem;
	border: 2px dashed #fff;
}
.contact-display .display {
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	padding: 3.5rem 24.8rem 3.5rem 4rem;
	background: #fff;
	border-radius: 2rem;
}
.contact-display .display .links {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 25rem;
}
.contact-display .display .links .bike {
	width: 10rem;
}
.contact-display .display .btns {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 13.5rem;
}
.contact-display .display .btns a {
	display: block;
}
.contact-display .info {
	padding-left: 3rem;
	width: calc(100% - 25rem);
	line-height: 1.9;
	font-size: 2rem;
	font-weight: 700;
}
.contact-display .display .img {
	position: absolute;
	right: 1.8rem;
	bottom: -5rem;
	width: 37.3rem;
}

@media screen and (max-width: 1320px) {
	.top-howto {
		margin-top: 14.5833vw;
	}
	.top-howto:before {
		height: 14.5833vw;
		background-size: auto 18.75vw;
	}
	.howto-flow li {
		padding: 0 1vw 1.77vw;
		aspect-ratio: auto;
	}
	.howto-flow li .step {
		font-size: 4.8rem;
	}
	.howto-flow li .icon img {
		max-width: 14.9vw;
	}
	.howto-flow li .tit {
		margin-top: 1.041667vw;
		font-size: 1.8vw;
	}
	
}
@media screen and (max-width: 1200px) {
	
	.btn-golist a {
		padding: 0 5rem;
		max-width: 28rem;
	}
	
	.area-introd ul {
		grid-template-columns: repeat(4, 1fr);
	}
	
	.top-contact .contact-display {
	    padding: 2.5rem;
	    max-width: 76.8rem;
	}
	.top-contact .contact-display:before {
	    left: 0.5rem;
	    top: 0.4rem;
	    width: calc(100% - 1rem);
	    height: calc(100% - 0.8rem);
	}
	.top-contact .head {
	    margin: 0 25rem 2.5rem 0;
		line-height: 1.3;
	}
	.contact-display .display {
	    padding: 2rem 22rem 2rem 1.3rem;
	}
	.contact-display .display .links {
		width: 19rem;
	}
	.contact-display .display .links .bike {
	    width: 7.8rem;
	}
	.contact-display .display .btns {
		width: 10.6rem;
	}
	.contact-display .info {
	    padding-left: 1.5rem;
	    width: calc(100% - 19rem);
		line-height: 1.6;
	    font-size: 1.6rem;
	}
	.contact-display .display .img {
		right: -1.3rem;
		bottom: -2.5rem;
		width: 23.2rem;
	}
}
@media screen and (max-width: 1024px) {
	.area-introd ul {
		grid-template-columns: repeat(3, 1fr);
	}
}
/*** hover ***/
@media screen and (min-width: 960px) {
	
	.btn-golist a:hover {
		background-position: right 6rem center;
		box-shadow: 0 0.4rem 2.4rem rgba(55,55,55,0.15);
	}
	.green-st .btn-golist a:hover {
		background-color: #ECF7F0;
	}
	.orange-st .btn-golist a:hover {
		background-color: #FFFAEF;
	}
	
	.about-swiper .swiper-button-prev:hover,
	.about-swiper .swiper-button-next:hover,
	.about-swiper .swiper-button-prev:active,
	.about-swiper .swiper-button-next:active {
		background: #E8FDD2;
	}
	.about-swiper .swiper-button-prev:active:after,
	.about-swiper .swiper-button-next:active:after {
		left: 0;
		bottom: 0;
	}
	
	.area-introd li a:hover img {
		transform: scale(1.1,1.1);
	}
	.area-introd li a:hover .info {
		background: rgba(0,0,0,0.5);
	}
	
	.contact-display .display .links a:hover {
		opacity: 0.7;
	}
}

/* sp */
@media screen and (max-width: 750px) {
	.top-news {
	    padding: 7.7rem 0 0;
	}
	.top-news .head-large .jap {
	    font-size: 1.6rem;	
	}
	.top-news .news-type {
	    flex-direction: column;
		gap: 2rem 0;
	}
	.top-news .news-type .item {
		width: 100%;
	}
	.top-news .head-news {
	    font-size: 2.2rem;
	}
	.top-news .head-news .con {
	    padding: 1.4rem 3rem;
	}	
	.top-news .list {
	    padding: 0 0 3rem;
	}
	.top-news .list dl {
	    padding: 1.8rem 0;
	}	
	
	.top-news .green-st.item,	
	.top-news .orange-st.item {
		padding: 0;
	}	
	.top-news .green-st .list,
	.top-news .orange-st .list {
		padding: 0 2rem 3rem;
	}	
	.top-news .green-st .list dl {
	    padding-right: 0;
	}
	.top-news .orange-st .list dl {
		padding-left: 0;
	}
	
	.btn-golist {
		margin-top: 1.2rem;
	}
	.btn-golist a {
		max-width: 33rem;
	    background-position: right 5rem center;
		background-size: 2.5rem;
	}
	
	.top-about {
	    padding: 8rem 0;
	}
	.top-about .head {
	    text-align: left;
		line-height: 1.7;
	    font-size: 2.4rem;
	}
	.top-about .head .big {
		display: block;
		margin-top: 1.4rem;
		line-height: 1.5;
		font-size: 4.4rem;
	}
	
	.bike-circle {
		margin: 8rem auto 9rem;
		width: 19.8rem;
		height: 19.8rem;
	}
	.bike-circle img {
		width: 14.6rem;
	}
	.top-about .sub {
	    text-align: left;
	    line-height: 2;
		letter-spacing: 0;
		font-size: 2rem;
	}
	.top-about .sub p + p {
	    margin-top: 2em;
	}
	
	.about-swiper {
		margin-top: 7rem;
	}
	.about-swiper .swiper-slide {
	    width: 20rem;
	    height: 20rem;
	}
	.about-swiper .swiper-slide:nth-of-type(odd) {
	    margin-top: 3rem;
	}
	
	.about-swiper .slide-ctrl {
	    margin-top: 5rem;
	    padding: 0 2rem;
	}
	.about-swiper .swiper-button-prev, 
	.about-swiper .swiper-button-next {
		width: 6rem;
		height: 6rem;
	}
	.about-swiper .swiper-button-next {
		right: 2rem;
	}
	.about-swiper .swiper-button-prev {
		right: 9rem;
	}
	.about-swiper .swiper-scrollbar {
	    width: calc(100% - 15rem);
	}
	
	.top-howto {
	    padding: 0 0 8.4rem;
	    margin-top: 13.333vw;
	}
	.top-howto:before {
	    height: 13.333vw;
	    background-size: auto 20.6667vw;
	}
	.top-howto .txt-swiper {
		display: none;
	}
	.top-howto .head-large .jap {
	    font-size: 1.8rem;	
	}
	.howto-flow ul {
	    grid-template-columns: repeat(1, 1fr);
	    gap: 5rem;
	}
	.howto-flow li {
	    padding: 0 1rem 3rem;
	}
	.howto-flow li + li:before {
	    content: "";
	    position: absolute;
	    left: 50%;
	    top: -5.3rem;
	    transform: translateX(-50%);
		border-color: #F98C33 transparent transparent;
	    border-width: 2rem 1.2rem 0;
	}
	.howto-flow li .step {
		font-size: 6rem;
	}
	.howto-flow li .icon img {
		max-width: 25rem;
	}
	.howto-flow li .tit {
	    margin-top: 1.5rem;
	    font-size: 2.3rem;
	}
	
	.top-newoptions .options-wrap {
	    padding: 10rem 1rem;
	}
	.options-wrap .box {
	    position: relative;
	    padding: 14rem 3rem 12rem;
	    border-radius: 16.8rem;
	}
	.options-wrap .box:before {
	    left: 1rem;
	    top: 1rem;
	    width: calc(100% - 2rem);
	    height: calc(100% - 2rem);
	    border-radius: 16.8rem;
	}
	.options-wrap .head {
	    margin-bottom: 3rem;
	    font-size: 3.2rem;
	}
	.options-wrap .txt p {
	    margin-bottom: 2.8rem;
	    line-height: 1.6;
	    font-size: 1.8rem;
	}
	.options-wrap .btn-link2 {
		margin-top: 3rem;
	}
	.options-wrap .btn-link2 .btn {
		padding: 0 3rem;
		height: 6.5rem;
		font-size: 1.8rem;
	}
	
	.various-case + .various-case {
	    margin-top: 2rem;
	}
	.various-case li {
		padding-right: 4rem;
	    width: 22rem;
	}
	.various-case li img {
	    height: 9rem;
	}
	
	.top-servicearea {
	    padding: 8.4rem 0 0;
	}
	.top-servicearea .head {
		line-height: 1.6;
	    text-align: left;
	    font-size: 2.4rem;
	}
	.top-servicearea .head2 {
	    margin-bottom: 4rem;
		line-height: 1.6;
	    text-align: left;
	    font-size: 1.6rem;
	}
	.area-introd ul {
	    gap: 2.5rem 1.1rem;
	    grid-template-columns: repeat(2, 1fr);
	}
	.area-introd li .info {
		background: rgba(0,0,0,0.2);
	}
	.area-introd li .area {
	    font-size: 1.4rem;
	}
	.area-introd li .place {
	    margin-top: 0.25rem;
	    font-size: 2.4rem;
	}
	.area-introd li .eng {
	    margin-top: 0.25rem;
	    font-size: 1.4rem;
	}
	.area-introd li.note .eng:after {
	    margin-top: 0.4rem;
		font-size: 1.4rem;
	}
	.top-servicearea .notes {
	    margin-top: 3rem;
	    padding-left: 0;
	    text-indent: 0;
		letter-spacing: 0.04em;
	    line-height: 1.5;
	    font-size: 1.3rem;
	}
	
	.top-contact {
	    padding: 12rem 0 6rem;
	}
	.top-contact .contact-display {
		padding: 4.4rem 2rem;
		border-radius: 0;
	}
	.top-contact .contact-display:before {
		left: 1rem;
		top: 2rem;
		width: calc(100% - 2rem);
		height: calc(100% - 4rem);
	}
	.top-contact .head {
		margin: 0 1rem 1.6rem;
		line-height: 1.1;
	}
	.top-contact .info {
		margin: 0 1rem;
		padding-left: 0;
		width: auto;
		color: #fff;
		font-size: 1.4rem;
	}
	.contact-display .display {
		padding: 1rem 19.4rem 1rem 3rem;
		margin-top: 20rem;
	}
	.contact-display .display .links {
		gap: 0 2rem;
		justify-content: center;
		width: auto;
	}
	.contact-display .display .img {
		right: 1rem;
		bottom: 0;
		width: 28.5rem;
	}
	
}
@media screen and (max-width: 480px) {
	
	.contact-display .display {
		margin-top: 13.5rem;
	}
	.contact-display .display .links {
		gap: 0;
        width: 13rem;
    }
}


/* !teaser
---------------------------------------------------------- */
#teaser {
	width: 100%;
	height: 45rem;
	display: flex;
	align-items: flex-end;
	padding: 8rem 0;
	background: url(../img/common/bg_teaser.webp) left bottom no-repeat;
	background-size: cover;
	border-radius: 0 0 0 20rem;
}

#teaser .teaser-hd {
	line-height: 1.4;
	font-weight: normal;
	letter-spacing: .06em;
	color: #6C624F;
}

#teaser .teaser-hd .teaser-hd__eng {
	font-size: 7.2rem;
	display: block;
}

#teaser .teaser-hd .teaser-hd__jap {
	font-size: 2.4rem;
	display: block;
}

/* sp */
@media screen and (max-width: 750px) {
	#teaser {
		height: 30rem;
		padding: 6rem 2rem;
		background: url(../img/common/bg_teaser_sp.webp) left bottom no-repeat;
		background-size: cover;
		border-radius: 0 0 0 10rem;
	}

	#teaser .teaser-hd .teaser-hd__eng {
		font-size: 6.4rem;
		line-height: 1;
		margin-bottom: 1rem;
	}

	#teaser .teaser-hd .teaser-hd__jap {
		font-size: 1.6rem;
	}
}


/* !news
---------------------------------------------------------- */
.news-wrap {
	padding: 8rem 0 15rem;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.news-wrap .news-side {
	width: 26rem;
	position: sticky;
	top: 11rem;
	padding-top: 6rem;
}

.news-wrap .news-side .news-side__item + .news-side__item {
	margin-top: 5rem;
}

.news-wrap .news-side-hd {
	color: #10883C;
	border-bottom: .1rem solid #D9D9D9;
	padding-bottom: 2rem;
	line-height: 1.5;
	margin-bottom: 2rem;
}

.news-wrap .news-side-hd .news-side-hd__eng {
	display: block;
	font-size: 2.8rem;
	font-weight: 500;
}

.news-wrap .news-side-hd .news-side-hd__jap {
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
}


.news-wrap .news-main {
	width: calc(100% - 30rem);
}

.tags-list .tags-list__item + .tags-list__item {
	margin-top: 1rem;
}

.tags-list .tags-list__item a {
	display: inline-block;
	font-size: 1.8rem;
	line-height: 1.5;
	padding: .8rem 1.5rem;
	border: .1rem solid #D9D9D9;
	background: #fff;
	border-radius: 6.5rem;
	color: #D9D9D9;
	letter-spacing: .06em;
}

.tags-list .tags-list__item a.is-active {
	border-color: #00A23F;
	background: #00A23F;
	color: #fff;
}

.archive-select select {
	width: 100%;
	height: 5rem;
	border: .1rem solid #D9D9D9;
	border-radius: 1rem;
	padding: 0 7rem 0 3rem;
	font-size: 2rem;
	line-height: 1.5;
	color: #333333;
	background: url(../img/common/icon_select.svg) right 2.9rem center no-repeat #fff;
	cursor: pointer;
}

.category-list {
	border-bottom: .1rem solid #D9D9D9;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
	margin-bottom: 4rem;
}

.category-list .category-list__item {
	width: 100%;
	max-width: 48rem;
	margin-bottom: -.1rem;
}

.category-list .category-list__item a {
	width: 100%;
	height: 7rem;
	border: .1rem solid #D9D9D9;
	border-radius: 4rem 4rem 0 0;
	display: flex;
	align-items: center;
	padding: 0 4.5rem;
	font-size: 2.4rem;
	line-height: 1.4;
	font-weight: bold;
	letter-spacing: .08em;
	color: #333333;
}

.category-list .category-list__item a:before {
	width: 1.4rem;
	height: .2rem;
	border-radius: .1rem;
	content: '';
	margin-right: 1.2rem;
}

.category-list .category-list__item a.green-st {
	background: #ECF7F0;
}

.category-list .category-list__item a.green-st:before {
	background: #00A23F;
}

.category-list .category-list__item a.orange-st {
	background: #FFFAEF;
}

.category-list .category-list__item a.orange-st:before {
	background: #F98C33;
}

.category-list .category-list__item a.is-active {
	color: #fff;
}

.category-list .category-list__item a.is-active:before {
	width: 2.8rem;
	height: 2.8rem;
	border-radius: 100%;
	margin-right: .9rem;
	border: .6rem solid #fff;
}

.category-list .category-list__item a.green-st.is-active {
	background: #00A23F;
}

.category-list .category-list__item a.green-st.is-active:before {
	background: none;
}

.category-list .category-list__item a.orange-st.is-active {
	background: #F98C33;
}

.category-list .category-list__item a.orange-st.is-active:before {
	background: none;
}

.news-list li {
	border-bottom: 1px solid #D9D9D9;
}

.news-list li a {
	display: block;
	padding: 1.65rem 0 2.5rem;
}

.news-list li a .title {
	overflow : hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	font-size: 1.8rem;
	line-height: 1.7;
	margin-bottom: 1.15rem;
	font-weight: 500;
}

.news-list li a .box-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 1.2rem;
}

.news-list li a .date {
	font-size: 1.6rem;
	line-height: 1.375;
}

.news-list li a .tags {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1.2rem;
}

.news-list li a .tags .tags-item {
	font-size: 1.5rem;
	line-height: 1.46;
	color: #fff;
	padding: 0 1.6rem;
	display: inline-block;
	border-radius: 6.5rem;
}

.green-st .tags .tags-item {
	background: #00A23F;
}

.orange-st .tags .tags-item {
	background: #F98C33;
}

.wp-pagenavi {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin: 3.7rem auto 0;
    position: relative;
    text-align: center;
}

.wp-pagenavi .first,
.wp-pagenavi .last,
.wp-pagenavi .pages {
    display: none;
}

.wp-pagenavi a,
.wp-pagenavi span {
    border: 0;
    padding: 0;
    margin: 0;
}

.wp-pagenavi .page,
.wp-pagenavi .current,
.wp-pagenavi .extend {
    width: 5rem;
    height: 5rem;
    border-radius: 100%;
    font-size: 1.8rem;
    line-height: 1;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background: #E9ECF2;
    margin: 0 1rem;
    border: .1rem solid #333333;
    background: #fff;
    color: #333;
}

.wp-pagenavi span.current {
    color: #fff;
    background: #00A23F;
    border-color: #00A23F;
}

.wp-pagenavi .extend {
	border: 0;
	background: none;
	letter-spacing: .4em;
}

.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink {
    width: 5rem;
    height: 5rem;
    font-size: 1px;
    line-height: 1;
    display: block;
    position: relative;
}

.wp-pagenavi a.previouspostslink {
    margin-right: 5rem;
    background: url(../img/common/page_arrow_prev.svg) center center no-repeat;
    background-size: auto 100%;
}

.wp-pagenavi a.nextpostslink {
	margin-left: 5rem;
    background: url(../img/common/page_arrow_next.svg) center center no-repeat;
    background-size: auto 100%;
}

.wp-pagenavi a.previouspostslink:before,
.wp-pagenavi a.nextpostslink:before {
	width: 100%;
	height: 100%;
	border-radius: 100%;
	background: #E8FDD2;
	position: absolute;
	top: .3rem;
	content: '';
	z-index: -1;
	opacity: 0;
	transition: .3s;
}

.wp-pagenavi a.previouspostslink:before {
	left: -.2rem;
}

.wp-pagenavi a.nextpostslink:before  {
	left: .2rem;
}

/*** hover ***/
@media screen and (min-width: 960px) {
	.tags-list .tags-list__item a:hover {
		border-color: #00A23F;
		background: #00A23F;
		color: #fff;
	}

	.wp-pagenavi a.page:hover {
		background: #E8FDD2;
		border-color: #00A23F;
		color: #00A23F;
	}

	.wp-pagenavi a.previouspostslink:hover {
	    background-image: url(../img/common/page_arrow_prev_green.svg);
	}

	.wp-pagenavi a.nextpostslink:hover {
	    background-image: url(../img/common/page_arrow_next_green.svg);
	}

	.wp-pagenavi a.previouspostslink:hover:before,
	.wp-pagenavi a.nextpostslink:hover:before {
		opacity: 1;
	}
}

@media screen and (max-width: 1099px) {
	.news-wrap .news-side {
		width: 16rem;
	}

	.news-wrap .news-main {
		width: calc(100% - 20rem);
	}
}

@media screen and (max-width: 959px) {
	.news-wrap {
		flex-direction: column-reverse;
	}
	.news-wrap .news-side,
	.news-wrap .news-main {
		width: 100%;
	}

	.news-wrap .news-side {
		position: relative;
		top: 0;
	}

	.news-wrap .news-side-hd {
		display: flex;
		align-items: center;
		gap: 1rem;
	}

	.tags-list {
		display: flex;
		flex-wrap: wrap;
		gap: 1rem;
	}

	.tags-list .tags-list__item + .tags-list__item {
		margin-top: 0;
	}
}

/* sp */
@media screen and (max-width: 750px) {
	.news-wrap {
		padding: 6rem 0 5rem;
	}

	.news-wrap .news-side .news-side__item + .news-side__item {
		margin-top: 4rem;
	}

	.news-wrap .news-side-hd {
		padding-bottom: 1rem;
	}

	.archive-select select {
		width: 100%;
		height: 6.6rem;
		font-size: 2rem;
	}

	.category-list {
		padding: 0 .5rem;
		gap: 1.4rem;
		margin-bottom: 1.5rem;
	}

	.category-list .category-list__item {
		width: 50%;
	}

	.category-list .category-list__item a {
		height: 6rem;
		border-radius: 2rem 2rem 0 0;
		justify-content: center;
		padding: 0;
		font-size: 1.3rem;
		text-align: center;
	}

	.category-list .category-list__item a:before {
		display: none;
	}

	.news-list li a .title {
		-webkit-line-clamp: 2;
		margin-bottom: 1.67rem;
		font-size: 1.7rem;
	}

	.news-list li a .date {
		font-size: 1.3rem;
		line-height: 1.6923;
	}

	.wp-pagenavi .page,
	.wp-pagenavi .current,
	.wp-pagenavi .extend {
	    width: 4rem;
	    height: 4rem;
	    font-size: 1.4rem;
	    margin: 0 .5rem;
	}

	.wp-pagenavi .extend {
		letter-spacing: .3em;
	}

	.wp-pagenavi a.previouspostslink,
	.wp-pagenavi a.nextpostslink {
	    width: 4rem;
	    height: 4rem;
	}

	.wp-pagenavi a.previouspostslink {
	    margin-right: 1.2rem;
	}

	.wp-pagenavi a.nextpostslink {
		margin-left: 1.2rem;
	}

	.wp-pagenavi a.previouspostslink:before,
	.wp-pagenavi a.nextpostslink:before {
		display: none;
	}
}

.news-detail {
	padding: 8rem 0 10rem;
	margin: 0 auto;
	width: 100%;
	max-width: 98rem;
}
.news-detail .detail-title {
	padding-bottom: 3rem;
	margin-bottom: 6rem;
	border-bottom: 1px solid #D9D9D9;
}
.news-detail .detail-title h2 {
	margin-bottom: 3rem;
	letter-spacing: 0.06em;
	line-height: 1.6;
	font-size: 3.6rem;
	font-weight: 500;
}
.news-detail .detail-title .dt {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0 1rem;
    line-height: 1;
}

.news-detail .detail-title .dt .date {
	font-size: 2rem;
}

.news-detail .detail-title .dt .tag {
    padding: 0.3rem 1.6rem 0.4rem;
    border-radius: 2rem;
    color: #fff;
    font-size: 1.5rem;
}
.news-detail .detail-title.green-st .dt .tag {
	background: #00A23F;
}
.news-detail .detail-title.orange-st .dt .tag {
	background: #F98C33;
}
.news-detail .detail {
	padding-bottom: 3.5rem;
	border-bottom: 1px solid #D9D9D9;
	letter-spacing: 0.06em;
	font-size: 2rem;
}
.news-detail .detail h2 {
	padding: 1.3rem 2rem;
	margin-bottom: 2.5rem;
	background: #fff;
	border-left: 0.4rem solid #00A23F;
	letter-spacing: 0.06em;
	font-size: 3.2rem;
	font-weight: 700;
}
.news-detail .detail h3 {
	padding: 0.6rem 2rem;
	margin-bottom: 2.5rem;
	border-left: 0.4rem solid #00A23F;
	letter-spacing: 0.06em;
	font-size: 2.2rem;
	font-weight: 700;
}
.news-detail .detail h4 {
	margin-bottom: 2.5rem;
	color: #00A23F;
	font-weight: 700;
	font-size: 2rem;
}
.news-detail .detail h4:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	margin: -0.5rem 1rem 0 0;
	width: 1.2rem;
	height: 0.4rem;
	background: #00A23F;
	border-radius: 1rem;
}
.news-detail .detail p {
	margin-bottom: 2.5rem;
	line-height: 1.8;
}
.news-detail .detail ul,
.news-detail .detail figure {
	margin: 0 auto 2.5rem;
}
.news-detail .detail li {
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.7;
	letter-spacing: 0.08em;
}
.news-detail .detail li:before {
	content: "";
	display: inline-block;
	margin: 0 0.8rem 0.5rem;
	width: 0.3rem;
	height: 0.3rem;
	background: #333;
	border-radius: 50%;
}
.news-detail .detail .note,
.news-detail .detail .wp-block-quote {
	padding: 2rem;
	background: #fff;
	border-radius: 1rem;
	line-height: 1.5;
	display: block;
	margin-bottom: 2.5rem;
}
.news-detail .detail figure img {
	width: 100%;
}
.news-detail .detail .half img,
.news-detail .detail .size-medium img {
	width: 50%;
} 
.page-prev-next {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	margin: 6rem auto 0;
	max-width: 70.2rem;
}
.page-prev-next .prev {
	position: absolute;
	left: 0;
	padding-left: 7rem;
	font-size: 2rem;
}
.page-prev-next .next {
	position: absolute;
	right: 0;
	padding-right: 7rem;
	font-size: 2rem;
}
.page-prev-next .icon {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
} 
.page-prev-next .prev .icon {
	left: 0;
}
.page-prev-next .next .icon {
	right: 0;
}
.page-prev-next .icon img {
	width: 5rem;
}
.page-prev-next .icon:before {
	content: "";
	position: absolute;
	top: .3rem;
	z-index: -1;
	opacity: 0;
	transition: .3s;
	width: 100%;
	height: 100%;
	border-radius: 100%;
	background: #E8FDD2;
}
.page-prev-next .prev .icon:before {
	left: -.2rem;
}
.page-prev-next .next .icon:before {
	left: .2rem;
}
.page-prev-next .center {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28.8rem;
	height: 5.6rem;
	background: #fff;
	border-radius: 6rem;
	border: 1px solid #333333;
	font-size: 2rem;
}

.contact-wrap {
	padding: 8rem 0 10rem;
	margin: 0 auto;
	max-width: 98rem;
    font-size: 2rem;
    line-height: 1.7;
    letter-spacing: .06em;
}
.color-red {
	color: #FF0000;
}
.contact-form h3 {
	margin-bottom: 4rem;
	letter-spacing: 0.06em;
	font-size: 2.2rem;
	line-height: 1.6;
	font-weight: 500;
}
.contact-form .link {
	text-decoration: underline;
}
.contact-form table {
	margin-top: 4rem;
	width: 100%;
	font-size: 2rem;
}
.contact-form th {
	vertical-align: top;
	padding: 2rem 0;
	width: 28rem;
	text-align: left;
}
.contact-form th .must {
	margin-left: 1rem;
	color: #FF0000;
	font-weight: 700;
	font-size: 1.4rem;
}
.contact-form input[type=text],
.contact-form input[type=email],
.contact-form input[type=tel],
.contact-form select,
.contact-form textarea {
	padding: 0 1.5rem;
	width: 100%;
	height: 4.7rem;
	background: #fff;
	border: 1px solid;
	border-radius: 0.5rem;
	letter-spacing: 0.08em;
	font-size: 1em;
}
.contact-form input[type=text] {
	border-color: #B3B3B3;
}
.contact-form select {
	padding: 0 3rem 0 1.5rem;
	background: url(../img/common/icon_select.svg)no-repeat right 1.5rem center #fff;
	border-color: #333333;
}
.contact-form .half {
	width: 50%;
}
.contact-form td {
	vertical-align: top;
	padding: 1rem 0;
}
.choice-radio label {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 0 0.8rem;
	margin: 1rem 3.5rem 1rem 0;
}
.choice-radio input {
	display: inline-block;
	margin: 0;
	width: 1.6rem;
	height: 1.6rem;
	background: url(../img/common/icon_radio.svg)no-repeat center;
	background-size: 100%;
}
.choice-radio input:checked {
	background-image: url(../img/common/icon_radio_on.svg);
}
.contact-form textarea {
	padding: 1.5rem;
	height: 18rem;
}
.contact-form ::-webkit-input-placeholder {
	color: #B3B3B3;
}
.contact-form .error {
	color: #FF0000;
}
.contact-form .error input,
.contact-form input.wpcf7-not-valid ,
.contact-form select.wpcf7-not-valid  {
	border-color: #FF0000;
}
.contact-form .note-error,
.contact-form .wpcf7-not-valid-tip {
	margin-top: 0.5rem;
	color: #FF0000;
	font-size: 1.6rem;
}

.contact-form .agree {
	margin-top: 4rem;
	text-align: center;
	line-height: 2;
	font-size: 1.6rem;
}
.contact-form .agree input[type="checkbox"] {
	display: inline-block;
	margin: 0 1rem -0.4rem 0;
	width: 2rem;
	height: 2rem;
	background: url(../img/common/icon_checkbox.svg)no-repeat center;
	background-size: 100%;
}
.contact-form .agree input[type="checkbox"]:checked {
	background-image: url(../img/common/icon_checkbox_on.svg);
}

.contact-form .agree label {
	font-size: 2rem;
}

.contact-form .team-btns {
	display: flex;
	justify-content: center;
	gap: 1rem;
	margin-top: 5rem;
}
.contact-form .team-btns .btn {
	position: relative;
	width: 50%;
	max-width: 51rem;
	margin-top: 0;
}
.contact-form .team-btns .btn:after {
	content: "";
	position: absolute;
	right: 6rem;
	top: 0;
	width: 2rem;
	height: 100%;
	transition-duration: 0.5s;
	background: url(../img/common/icon_link_wh.svg) no-repeat center;
	background-size: 100%;
}
.contact-form .team-btns input {
	padding: 0 6rem;
	height: 10rem;
	width: 100%;
	border-radius: 5rem;
	border: 0;
	text-align: left;
	letter-spacing: 0.12em;
	color: #fff;
	font-weight: 700;
	font-size: 2.2rem;
}

.contact-form .team-btns input:disabled {
	background: #D9D9D9;
}

.contact-form .team-btns .wpcf7-spinner {
	position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
}

.thanks-wrap {
	padding: 8rem 0 10rem;
	margin: 0 auto;
	max-width: 98rem;
	text-align: center;
}
.thanks-wrap h2 {
	margin-bottom: 8rem;
	letter-spacing: 0.06em;
	color: #00A23F;
	font-size: 3.6rem;
	font-weight: 400;
}
.thanks-wrap .sub {
	font-weight: 700;
}
.thanks-wrap p {
	margin-bottom: 2em;
	letter-spacing: 0.08em;
	line-height: 1.8;
	font-size: 2.2rem;
}
.thanks-wrap .page-prev-next .center {
	height: 6.6rem;
}

/*** hover ***/
@media screen and (min-width: 960px) {
	.page-prev-next a:hover .icon:before {
		opacity: 1;
	}
	.page-prev-next .center:hover {
		background: #E8FDD2;
	}
	
	.contact-form .link:hover {
		text-decoration: none;
	}
	.contact-form .team-btns .btn:hover:after {
		right: 5rem;
		background-image: url(../img/common/icon_link_orange.svg)
	}
}
/* sp */
@media screen and (max-width: 750px) {
	.news-detail {
	    padding: 6rem 0 7rem;
	}
	.news-detail .detail-title {
	    padding-bottom: 3rem;
	    margin-bottom: 3rem;
	}
	.news-detail .detail-title h2 {
	    line-height: 1.5;
	    font-size: 2.6rem;
	}

	.news-detail .detail-title.green-st .dt .tag {
		font-size: 1.6rem;
	}

	.news-detail .detail {
		padding-bottom: 0.5rem;
	    font-size: 1.6rem;
	}
	.news-detail .detail h2 {
	    padding: 0.6rem 2rem;
	    font-size: 3re,;
	}
	.news-detail .detail h3 {
	    padding: 0 2rem;
	    font-size: 2.4rem;
	}

	.news-detail .detail h4 {
		font-size: 1.8rem;
	}

	.news-detail .detail .note,
	.news-detail .detail .wp-block-quote {
	    padding: 1.5rem 1rem;
	}
	
	.page-prev-next {
		margin-top: 4rem;
		padding-bottom: 8rem;
	}
	.page-prev-next .prev,
	.page-prev-next .next {
		bottom: 0;
		font-size: 1.6rem;
	}

	.page-prev-next .center {
		font-size: 1.8rem;
	}
	
	.contact-wrap {
	    padding: 11.6rem 0 5rem;
	    font-size: 1.4rem;
	    line-height: 1.5;
	    letter-spacing: .08em;
	}
	.contact-form h3 {
		line-height: 1.6;
	    font-size: 1.7rem;
	    font-weight: 400;
	}

	.contact-form table {
		font-size: 1.8rem;
	}
	.contact-form th {
		display: block;
		width: 100%;
	    padding: 0 0 0.8rem;
	    width: 100%;
	}
	.contact-form td {
		display: block;
	    padding: 0 0 3rem;
		width: 100%;
	}
	.choice-radio label {
	    gap: 0 0.8rem;
	    margin: 0 3.5rem 0.5rem 0;
	}
	.contact-form input[type=text], 
	.contact-form input[type=email], 
	.contact-form input[type=tel], 
	.contact-form select {
		height: 4.5rem;
	}

	.contact-form .half {
	    width: 80%;
	}
	.contact-form .note-error,
	.contact-form .wpcf7-not-valid-tip {
		font-size: 1.2rem;
	}
	
	.contact-form .agree {
		line-height: 1.5;
		font-size: 1.5rem;
	}
	.contact-form .agree label {
		display: inline-block;
		position: relative;
		padding-left: 3.6rem;
		margin-bottom: 1rem;
		text-align: left;
		font-size: 1.5rem;
	}
	.contact-form .agree input[type="checkbox"] {
		position: absolute;
		left: 0;
		top: 50%;
		transform: translateY(-50%);
		margin: 0;
		width: 2.4rem;
		height: 2.4rem;
	}
	.contact-form .team-btns {
		flex-wrap: wrap;
	}
	.contact-form .team-btns .btn {
		width: 100%;
	}
	.contact-form .team-btns .btn:after {
		right: 3rem;
	}
	.contact-form .team-btns input {
		padding: 0 3rem;
		height: 7rem;
		background: linear-gradient(90deg, #F98C33 0%, #ECCA6D 100%);
	}
	
	.thanks-wrap {
	    padding: 7rem 0 5rem;
	    text-align: left;
	}
	.thanks-wrap h2 {
		margin-bottom: 5rem;
		font-size: 3.2rem;
	}
	.thanks-wrap p {
	    letter-spacing: 0.06em;
	    line-height: 1.6;
	    font-size: 1.6rem;
	}
}

/* !news
---------------------------------------------------------- */
.section-wrap {
	padding: 8rem 0 15rem;
}

.table-basic {
	width: 100%;
}

.table-basic th,
.table-basic td {
	border: .1rem solid #00A23F;
	font-size: 1.8rem;
	line-height: 1.8;
	padding: 2rem;
	vertical-align: middle;
}

.table-basic th {
	background: #ECF7F0;
	width: 20rem;
}

.commercial-wrap {
	width: 100%;
	max-width: 98rem;
	margin: 0 auto;
}

/* sp */
@media screen and (max-width: 750px) {
	.section-wrap {
		padding: 6rem 0 7rem;
	}

	.table-basic,
	.table-basic tbody,
	.table-basic tr,
	.table-basic th,
	.table-basic td {
		display: block;
		width: 100%;
	}

	.table-basic {
		border-top: .1rem solid #00A23F;
	}

	.table-basic th,
	.table-basic td {
		border-top: 0;
		font-size: 1.6rem;
		padding: 1rem;
	}

	#commercial #teaser .teaser-hd .teaser-hd__eng {
		font-size: 4.5rem;
	} 
}


.privacy-policy,
.terms-of-service {
	font-size: 1.8rem;
	line-height: 1.8;
}
.privacy-policy h2,
.privacy-policy ol,
.privacy-policy p,
.terms-of-service h2,
.terms-of-service ol,
.terms-of-service ul,
.terms-of-service p {
	margin-bottom: 2rem;
}
.terms-of-service h2 {
	margin-top: 8rem;
}
.terms-of-service h2.first {
	margin-top: 0;
}

.privacy-policy ol.list-in,
.terms-of-service ol.list-in {
	margin-top: 1rem;
	margin-bottom: 1rem;
}
.privacy-policy ol li,
.terms-of-service ol li {
	list-style-type: decimal;
	margin-left: 2rem;
}
.privacy-policy ol.list-in li,
.terms-of-service ol.list-in li {
	list-style-type: decimal-leading-zero;
	margin-left: 3rem;
}
.privacy-policy ol li + li,
.terms-of-service ol li + li {
	margin-top: 1rem;
}
.privacy-policy ol.list-in li + li,
.terms-of-service ol.list-in li + li {
	list-style-type: decimal-leading-zero;
	margin-top: 0.5rem;
}
.terms-of-service ul li {
	list-style-type: disc;
	margin-left: 2rem;
}
.terms-of-service ul li + li {
	margin-top: 0.5rem;
}
.terms-of-service ol li ul {
	margin-top: 1rem;
	margin-bottom: 1rem;
}
.terms-of-service ol li ul li {
	list-style-type: none;
	margin-left: 1rem;
}
.terms-of-service ol li ul li + li {
	margin-top: 1rem;
}

.privacy-policy p.taR {
	text-align: right;
	margin-bottom: 8rem;
}
.privacy-policy h4 {
	font-weight: normal;
}
.privacy-policy table {
	width: 100%;
	margin-top: 2rem;
	margin-bottom: 2rem;
	border-bottom: .1rem solid #e0e0e0;
}
.privacy-policy table th {
	border-bottom: .2rem solid #e0e0e0;
	text-align: left;
	padding: .6rem .8rem 1rem .8rem;
}
.privacy-policy table td {
	border-top: .1rem solid #e0e0e0;
	padding: 1.2rem 1rem;
}
.privacy-policy table th,
.privacy-policy table td {
	font-size: 1.6rem;
	line-height: 1.6;
}
.privacy-policy table td.w70 {
	width: 70%;
}
.privacy-policy table td.w60 {
	width: 60%;
}

/* sp */
@media screen and (max-width: 750px) {
	.privacy-policy,
	.terms-of-service {
		font-size: 1.6rem;
	}
	.privacy-policy table th,
	.privacy-policy table td {
		font-size: 1.4rem;
		line-height: 1.5;
	}

	#privacy-policy #teaser .teaser-hd .teaser-hd__eng {
		font-size: 4.5rem;
	}
	.privacy-policy table td.w70,
	.privacy-policy table td.w60 {
		width: 50%;
	}
}


/* sp */
@media screen and (max-width: 750px) {

	#terms #teaser .teaser-hd .teaser-hd__eng {
		font-size: 4.5rem;
	} 
}

.wpcf7-list-item {
	margin: 0;
}


.anchor-area {
	position: relative;
}

.anchor-area .anchor {
	position: absolute;
	top: -11rem;
	z-index: -1;
	pointer-events: none;
}

.faq-anchor-links {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.6rem .6rem;
	margin-bottom: 8rem;
}

@media screen and (max-width: 1599px) {
	.faq-anchor-links {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media screen and (max-width: 1239px) {
	.faq-anchor-links {
		grid-template-columns: repeat(2, 1fr);
	}
}

.faq-anchor-links a {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	padding: 1.11rem 4.5rem 1.11rem 3rem;
	font-size: 2.2rem;
	line-height: 1.4;
	letter-spacing: .06em;
	border: .1rem solid #333333;
	border-radius: 4rem;
	background: url(../img/common/icon_down.svg) right 2.5rem center no-repeat;
	background-size: .8rem auto;
}

@media screen and (max-width: 900px) {
	.faq-anchor-links a {
		font-size: 2rem;
	}
}

.faq-wrap {
	width: 100%;
	max-width: 102rem;
	margin: 0 auto;
}

.faq-wrap .faq-parent + .faq-parent {
	margin-top: 7rem;
}

.faq-wrap .faq-parent .faq-parent__heading {
	position: relative;
	background: #ECF7F0;
	border-left: .4rem solid #00A23F;
	padding: .81rem 2rem .81rem 1.6rem;
	font-size: 3.2rem;
	line-height: 1.4;
	font-weight: bold;
	letter-spacing: .08em;
}

.faq-wrap .faq-parent .faq-parent__heading span {
	display: none;
}

.faq-wrap .faq-item {
	margin-top: 2rem;
	background: #fff;
	border-radius: 1.5rem;
	box-shadow: 0 .4rem 3.4rem 0 rgba(0, 0, 0, .05);
	padding: 1.5rem 2rem;
}

.faq-wrap .faq-item .faq-item__heading {
	cursor: pointer;
	position: relative;
	display: flex;
	align-items: center;
	gap: 2rem;
	font-size: 2.2rem;
	line-height: 1.5;
	font-weight: bold;
	letter-spacing: .08em;
	padding-right: 4.4rem;
}

.faq-wrap .faq-item .faq-item__heading:before {
	width: 4.5rem;
	min-width: 4.5rem;
	height: 4.5rem;
	border-radius: 100%;
	background: #00A23F;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: bold;
	color: #fff;
	content: 'Q';
}

.faq-wrap .faq-item .faq-item__heading:after {
	width: 2rem;
	height: 2rem;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	content: '';
	background: url(../img/common/icon_toggle_open.svg) right center no-repeat;
	background-size: 1.6rem auto;
}

.faq-wrap .faq-item .faq-item__heading.is-active:after {
	background-image: url(../img/common/icon_toggle_close.svg);
	background-size: 2rem auto;
}

.faq-wrap .faq-item .faq-item__body {
	position: relative;
	margin-top: 1rem;
	padding: .7rem 0 .7rem 6.5rem;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: .08em;
	display: none;
}

.faq-wrap .faq-item .faq-item__body:before {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	content: 'A';
	width: 4.5rem;
	height: 4.5rem;
	border-radius: 100%;
	border: .1rem solid #00A23F;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: bold;
	color: #00A23F;
}

.faq-wrap .faq-item .faq-item__body p + p {
	margin-top: 1.6em;
}

.faq-wrap ul {
	line-height: 1.4;
	font-size: 1.6rem;
	font-weight: bold;
	color: #8E8E8E;
	margin-top: 1rem;
}

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

	.faq-wrap .faq-parent .faq-parent__body {
		display: block !important;
	}
}

/* sp */
@media screen and (max-width: 750px) {
	.faq-anchor-links {
		display: none;
	}

	.faq-wrap .faq-parent + .faq-parent {
		margin-top: 4rem;
	}

	.faq-wrap .faq-parent .faq-parent__heading {
		padding: .81rem 4rem .81rem 1.6rem;
		font-size: 2.4rem;
		letter-spacing: .06em;
	}

	.faq-wrap .faq-parent .faq-parent__heading span {
		display: block;
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		z-index: 2;
		content: '';
		background: url(../img/common/icon_toggle_open.svg) right 1rem center no-repeat;
		background-size: 1.6rem auto;
	}

	.faq-wrap .faq-parent .faq-parent__heading span.is-active {
		background-image: url(../img/common/icon_toggle_close.svg);
		background-size: 2rem auto;
	}

	.faq-wrap .faq-parent .faq-parent__body {
		display: none;
	}

	.faq-wrap .faq-item {
		padding: 2rem 1rem;
	}

	.faq-wrap .faq-item .faq-item__heading {
		gap: 1rem;
		font-size: 1.8rem;
		padding-right: 3rem;
	}

	.faq-wrap .faq-item .faq-item__heading:before {
		width: 3.2rem;
		min-width: 3.2rem;
		height: 3.2rem;
	}

	.faq-wrap .faq-item .faq-item__body {
		margin-top: 1.5rem;
		padding: 0 0 0 4.2rem;
		font-size: 1.5rem;
	}

	.faq-wrap .faq-item .faq-item__body:before {
		width: 3.2rem;
		height: 3.2rem;
	}

	.faq-wrap ul {
		font-size: 1.2rem;
	}
}


.company-wrap .company-box + .company-box {
	margin-top: 8rem;
}

.company-wrap .company-heading {
	margin-bottom: 6rem;
	font-size: 4rem;
	line-height: 1.4;
	letter-spacing: .06em;
	font-weight: 500;
}

.company-wrap .company-body {
	padding-left: 11rem;
	font-size: 2rem;
	line-height: 1.7;
	letter-spacing: .06em;
}

@media screen and (max-width: 959px) {
	.company-wrap .company-body {
		padding-left: 5rem;
	}
}

.company-wrap .company-body p + p {
	margin-top: 1.7em;
}

.company-wrap .company-item {
	display: flex;
	align-items: flex-start;
}

.company-wrap .company-item dt {
	width: 18rem;
	font-size: 2.2rem;
	line-height: 1.4;
	letter-spacing: .06em;
	font-weight: bold;
	color: #00A23F;
	padding-right: 3rem;
}

.company-wrap .company-item dd {
	flex-grow: 1;
}

.company-wrap .company-map {
	width: 100%;
	height: 30rem;
	position: relative;
	overflow: hidden;
	margin-top: 2rem;
	border-radius: 2rem;
}

.company-wrap .company-map iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
}

.company-wrap .post-list li {
	display: flex;
	align-items: flex-start;
}

.company-wrap .post-list .post-list__title {
	min-width: 7em;
}

.company-wrap .company-item + .company-item {
	border-top: .1rem solid #D9D9D9;
	margin-top: 2.8rem;
	padding-top: 2.8rem;
}

.company-wrap .company-title {
	font-size: 3.2rem;
	line-height: 1.4;
	letter-spacing: .1em;
	font-weight: bold;
	color: #00A23F;
	margin-bottom: 4rem;
}

.company-wrap .company-sign {
	font-size: 2.2rem;
	line-height: 1.6;
	font-weight: 500;
}

/* sp */
@media screen and (max-width: 750px) {
	.company-wrap .company-box + .company-box {
		margin-top: 11rem;
	}

	.company-wrap .company-heading {
		margin-bottom: 4rem;
		font-size: 3.6rem;
	}

	.company-wrap .company-body {
		padding-left: 0;
		font-size: 1.7rem;
		line-height: 1.8;
		letter-spacing: 0;
	}

	.company-wrap .company-body p + p {
		margin-top: 1.8em;
	}

	.company-wrap .company-item {
		display: block;
		padding: 0 1rem;
	}

	.company-wrap .company-item dt {
		width: 100%;
		font-size: 1.8rem;
		padding-right: 0;
		margin-bottom: 1rem;
	}

	.company-wrap .company-item dd {
		font-size: 1.6rem;
		letter-spacing: .06em;
		line-height: 1.8;
	}

	.company-wrap .company-map {
		height: 19rem;
	}

	.company-wrap .company-title {
		font-size: 2.4rem;
		margin-bottom: 3.5rem;
	}

	.company-wrap .company-sign {
		font-size: 1.6rem;
		line-height: 1.8;
		font-weight: 400;
		letter-spacing: .06em;
	}
}


.notfound-wrap {
	padding-bottom: 10rem;
	text-align: center;
}

.notfound-wrap h2 {
	font-size: 1px;
	line-height: 1;
	margin-bottom: 6.8rem;
}

.notfound-wrap p {
	font-size: 2rem;
	line-height: 1.7;
	letter-spacing: .06em;
}

.notfound-wrap p.sub {
	font-size: 3.2rem;
	line-height: 1.4;
	letter-spacing: .08em;
	margin-bottom: 2.8rem;
}

/* sp */
@media screen and (max-width: 750px) {
	.notfound-wrap {
		padding-bottom: 8rem;
	}

	.notfound-wrap h2 {
		margin-bottom: 2.3rem;
	}

	.notfound-wrap p {
		font-size: 1.6rem;
		line-height: 1.6;
		letter-spacing: .07em;
	}

	.notfound-wrap p.sub {
		font-size: 2.8rem;
		line-height: 1.6;
		letter-spacing: .06em;
		margin-bottom: 4rem;
	}
}


/* interstreet
-----------------------------------------------------------------*/
#interstreet #loading .bg {
	background: #fff;
}
#interstreet #loading .head {
	color: #00A23F;
}

#interstreet :is(.photo-list li):after {
	border-color: #fff;
}

#interstreet #header {
	color: #fff;
}
#interstreet #header.active {
	color: #333;
}
#interstreet #header.active .header-logo .on {
	opacity: 1;
}

#interstreet #main-visual {
	padding-bottom: 26rem;
	background: #00A23F;
	color: #fff;
}
#main-visual .end-about {
	text-align: center;
}
#main-visual .end-about .sub {
	line-height: 1.8;
	font-size: 2.2rem;
	font-weight: 700;
}
#main-visual .head2 {
	margin-bottom: 5rem;
	line-height: 1.3;
	font-weight: 700;
	font-size: 3.2rem;
}
#main-visual .head2 .tit {
	display: inline-block;
	margin-bottom: 5rem;
	border-bottom: 1px solid #fff;
	font-size: 3.6rem;
}
#main-visual .head2 .foucs {
	display: block;
	font-weight: 900;
	font-size: 5rem;
}

.interstreet-news {
	position: relative;
	margin-top: -18rem;
	padding: 12rem 0 6rem;
	background: #FFFAEF;
	border-radius: 10rem 10rem 0 0;
}

.interstreet-news .inner {
	max-width: 138rem;
}

.interstreet-news .news-list li a {
    padding: 3rem 0;
}
.interstreet-news .news-list li a .title {
	margin: 1.15rem 0 0;
}
.interstreet-news .news-list li:last-child {
	border-bottom: 0;
}

.interstreet-howto {
	padding: 9rem 0 0;
}
.interstreet-howto .flow-display li {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.interstreet-howto .flow-display li + li {
	margin-top: 4rem;
}
.interstreet-howto .flow-display .icon {
	position: relative;
	padding-top: 25%;
	width: 25%;
	background: #fff;
	border-radius: 3rem;
	border: 3px solid #F98C33;
	text-align: center;
}
.interstreet-howto .flow-display .icon img {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 80%;
}
.interstreet-howto .flow-display .info {
	width: calc(75% - 11rem);
}
.interstreet-howto .flow-display .head {
	position: relative;
	padding: 1rem 2rem 1rem 10rem;
	margin-bottom: 4.2rem;
	background: #6EBE8B;
	border-radius: 5rem;
	line-height: 1.4;
	color: #fff;
	font-size: 3.2rem;
	font-weight: 700;
}
.interstreet-howto .flow-display .step {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	left: -3rem;
	top: 50%;
	transform: translateY(-50%);
	width: 9rem;
	height: 9rem;
	background: #fff;
	border: 1px solid;
	border-radius: 50%;
	color: #6EBE8B;
	font-size: 4rem;
}
.interstreet-howto .flow-display li:nth-child(2) .head {
	background: #3DAD66;
}
.interstreet-howto .flow-display li:nth-child(2) .step {
	color: #3DAD66;
}
.interstreet-howto .flow-display li:nth-child(3) .head {
	background: #10883C;
}
.interstreet-howto .flow-display li:nth-child(3) .step {
	color: #10883C;
}
.interstreet-howto .flow-display .sub {
	line-height: 1.6;
	font-size: 2.2rem;
	font-weight: 700;
}
.interstreet-howto .flow-display .note {
	margin-top: 2rem;
	line-height: 1.7;
	font-size: 2rem;
}
.interstreet-howto .applinks {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	margin-top: 2rem;
}
.interstreet-howto .applinks .bike {
	width: 10rem;
}
.interstreet-howto .applinks .btns img {
	height: 6rem;
}
.interstreet-howto .applinks .tit {
	margin-bottom: 1rem;
	line-height: 1.2;
	text-align: center;
	font-size: 1.5rem;
	font-weight: 700;
}
.interstreet-howto .applinks .btns {
	display: flex;
	gap: 0 1rem;
}

#interstreet .top-servicearea {
    padding: 10rem 0 0;
}

.interstreet-pricelist {
	padding: 10rem 0;
}
.interstreet-pricelist .head-small {
	margin-bottom: 4rem;
}
.interstreet-pricelist .price-select {
	margin-bottom: 4rem;
}
.price-select ul {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 1.3rem 2rem;
	margin: 0 auto;
	max-width: 128rem;
}
.price-select li {
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	transition-duration: 0.3s;
	height: 5.5rem;
	background: #fff;
	border: 1px solid;
	border-radius: 5rem;
	font-size: 2rem;
}
.price-select li.active {
	background: #00A23F;
	color: #fff;
}

.fee-prefecture {
	overflow: hidden;
	border-radius: 1rem;
	border: 1px solid #00A23F;
}
.fee-prefecture .prefecture {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 3rem;
	padding: 1.6rem;
	background: #00A23F;
	text-align: center;
	color: #fff;
	font-weight: 700;
	font-size: 2.2rem;
}
.fee-prefecture .prefecture .big {
	font-size: 3.2rem;
}
.fee-prefecture .td {
	padding: 5rem 11rem;
	background: #ECF7F0;
}
.fee-prefecture .mt60 {
	margin-top: 6rem;
}
.fee-prefecture .head {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 1rem;
	margin-bottom: 2rem;
	text-align: center;
	font-size: 3rem;
	font-weight: 700;
}
.fee-prefecture .head img {
	height: 2.8rem;
}
.fee-prefecture .col2 {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 4rem;
}
.fee-prefecture .col2 li {
	width: calc(50% - 2rem);
}
.fee-prefecture .col2 li.full {
	width: 100%;
}
.fee-prefecture .price-item {
	padding: 1.8rem 3rem;
	background: #fff;
	border: 1px solid #B3B3B3;
	border-radius: 0.5rem;
}
.fee-prefecture .price-item .row:after {
	content: "";
	display: block;
	clear: both;
}
.fee-prefecture .price-item .th {
	float: left;
	color: #00A23F;
	font-size: 2.4rem;
	font-weight: 700;
}
.fee-prefecture .price-item .data {
	float: right;
	line-height: 1;
	font-size: 2.4rem;
	font-weight: 700;
}
.fee-prefecture .price-item .data .num {
	color: #00A23F;
	font-size: 4.8rem;
}
.fee-prefecture .price-item .cate span {
	display: inline-block;
	padding: 0.8rem 1.5rem;
	border: 1px solid;
	border-radius: 3rem;
	line-height: 1;
	font-size: 1.8rem;
	font-weight: 700;
}
.fee-prefecture .price-item .total {
	margin-top: 2rem;
	text-align: right;
	font-size: 2rem;
}
.fee-prefecture .note {
	margin-top: 1.6rem;
	font-size: 1.8rem;
}

.fee-prefecture .col2 li.full .row {
	align-items: center;
}
.fee-prefecture .row .total {
	margin-top: 0;
	max-width: calc(100% - 24rem);
	text-align: left;
}

.price-settlement {
	padding: 4rem 11rem;
	margin-top: 4rem;
	background: #fff;
	border-radius: 1rem;
}
.price-settlement .head {
	margin-bottom: 3rem;
	letter-spacing: 0.08em;
	font-size: 3.2rem;
	font-weight: 700;
}
.price-settlement .head:before {
	content: "";
	display: inline-block;
	vertical-align: middle;
	margin-right: 1rem;
	height: 2px;
	width: 1.2rem;
	background: #00A23F;
	border-radius: 2px;
}
.settlement-methods .logos img {
	width: 100%;
}
.settlement-methods .note {
	margin-top: 1.6rem;
	text-align: center;
	font-size: 2.2rem;
	font-weight: 500;
}
.price-settlement .points {
	margin-top: 3.5rem;
}
.price-settlement .points li {
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.7;
	font-size: 2rem;
}
.price-settlement .points li + li {
	margin-top: 1.6rem;
}
.price-settlement .points li:before {
	content: "•";
	margin: 0 0.6rem;
}

@media screen and (max-width: 1400px) {
	.price-select ul {
	    gap: 1rem;
	}
	.price-select li {
		font-size: 1.6rem;
	}
	
	.fee-prefecture .td {
	    padding: 5rem;
	}
	.fee-prefecture .col2 {
	    gap: 2rem;
	}
	.fee-prefecture .col2 li {
		width: calc(50% - 1rem);
	}
	.fee-prefecture .price-item {
	    padding: 1.6rem;
	}
	.fee-prefecture .price-item .cate span {
	    padding: 0.8rem 1.5rem;
	    font-size: 1.6rem;
	}
	.fee-prefecture .price-item .data {
	    font-size: 2rem;
	}
	.fee-prefecture .price-item .data .num {
	    font-size: 3.6rem;
	}
	.fee-prefecture .price-item .total {
	    font-size: 1.6rem;
	}
	
}
/*hover*/
@media screen and (min-width: 960px){
	.price-select li:hover {
		background: #00A23F;
		color: #fff;
	}
}
@media screen and (max-width: 959px) {
	.price-select ul {
	    grid-template-columns: repeat(4, 1fr);
	}
	.fee-prefecture .td {
	    padding: 3rem;
	}
	.fee-prefecture .price-item .cate span {
	    padding: 0.5rem 1rem;
	    font-size: 1.4rem;
	}
	.fee-prefecture .price-item .data {
		font-size: 1.8rem;
	}
	.fee-prefecture .price-item .data .num {
		font-size: 3rem;
	}
	.fee-prefecture .price-item .total {
		margin-top: 1.6rem;
		font-size: 1.4rem;
	}
}
/* sp */
@media screen and (max-width: 750px) {
	#interstreet #header.active {
		color: #fff;
	}
	#interstreet #header:not(.active) .btn-menu {
		background-color: #fff;
		background-image: url(../img/common/icon_menu_gre.svg);
	}
	#interstreet #header:not(.active) .btn-menu.is-active {
		background-image: url(../img/common/icon_menu_close_gre.svg);
	}
	
	#interstreet #wrapper {
		padding-bottom: 11rem;
	}	
	
	#interstreet #main-visual {
	    padding-bottom: 30.6rem;
	}
	#main-visual .head2 {
		margin-bottom: 4rem;
		letter-spacing: -0.06em;
		font-size: 2.8rem;
	}
	#main-visual .head2 .tit {
		margin-bottom: 4rem;
	}
	#main-visual .head2 .foucs {
		margin-top: 1rem;
		font-size: 4.6rem;
	}
	#main-visual .end-about .sub {
		font-size: 2rem;
	}
	
	.interstreet-news {
	    padding: 7rem 0 4rem;
	    border-radius: 7rem 7rem 0 0;
	}
	
	.interstreet-howto {
	    padding: 8rem 0 0;
	}
	.interstreet-howto .flow-display li {
	    display: block;
	}
	.interstreet-howto .flow-display .icon {
		padding-top: 21rem;
		margin: 0 auto 2.5rem;
		width: 21rem;
	}
	.interstreet-howto .flow-display .info {
		width: auto;
	}
	.interstreet-howto .flow-display .head {
		padding: 1rem 2rem 1rem 8rem;
		margin-bottom: 2.5rem;
		border-radius: 5rem;
		letter-spacing: -0.08em;
		font-size: 2.8rem;
	}
	.interstreet-howto .flow-display .step {
		left: 0;
		width: 7rem;
		height: 7rem;
		font-size: 3.6rem;
	}
	.interstreet-howto .flow-display .sub {
	    line-height: 1.2;
		letter-spacing: 0.08em;
	    font-size: 2rem;
	}
	
	.interstreet-howto .applinks .btns img {
	    height: 4rem;
	}
	.interstreet-howto .flow-display .note {
		letter-spacing: 0.03em;
	    font-size: 1.6rem;
	}
	#interstreet .top-servicearea {
	    padding: 8rem 0 0;
	}
	
	.interstreet-pricelist {
	    padding: 8rem 0 6rem;
	}
	
	.interstreet-pricelist .price-select {
		padding: 1rem;
		background: #fff;
		border-radius: 1rem;
		box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.05);
	}
	.price-select .select {
		overflow: hidden;
        position:relative;
		border-radius: 5rem;
		border: 1px solid #fff;
	}
	.price-select .select:after {
		content: "+";
        position: absolute;
		right: 2.5rem;
		top: 1.8rem;
		color: #fff;
		font-weight: 700;
	}
    .price-select.open .select {
		border-radius: 2rem;
		border-color: #B3B3B3;
	}
    .price-select.open .select:after {
		content: "-";
	}
	.price-select .tit {
		padding: 1.8rem 4rem 1.8rem 2.5rem;
		background: #00A23F;
		color: #fff;
		font-size: 2rem;
	}
	.price-select ul {
		display: block;
		overflow-y:auto;
		transition: max-height .3s ease-out;
		width: 100%;
		max-height: 0;
		background: #fff;
		border-radius: 0 0 2rem 2rem;
	}
	.price-select.open ul {
	    transform-origin: 50% 0;
	    -webkit-animation: slide-down .5s ease-in;
	    transition: max-height .2s ease-out;
		padding: 1rem 0;
	    max-height: inherit;
	}
	@-weblit-keyframes slide-down {
	    %0{transform: scale(1,0);}
	    %25{transform: scale(1,1.2);}
	    %50{transform: scale(1,0.85);}
	    %75{transform: scale(1,1.05);}
	    %100{transform: scale(1,1);}
	}
	.price-select li {
		display: block;
		padding: 0.65rem 2rem;
		height: auto;
		background: #fff;
		border: 0;
		border-radius: 0;
		font-size: 2rem;
	}
	
	.fee-prefecture {
		margin: 0 -2rem;
		border: 0;
	}
	.fee-prefecture .prefecture {
		flex-direction: column;
	    gap: 0;
	    padding: 1rem;
	    font-size: 2rem;
	}
	.fee-prefecture .td {
		padding: 5rem 2rem;
	}
	.fee-prefecture .col2 {
		gap: 1.5rem;
	}
	.fee-prefecture .col2 li {
		width: 100%;
	}
	.fee-prefecture .head {
		font-size: 2.6rem;
	}
	.fee-prefecture .price-item .cate {
		margin-bottom: 1rem;
	}
	.fee-prefecture .price-item .cate span {
		display: block;
		padding: 0.5rem;
		text-align: center;
		letter-spacing: -0.01em;
		font-weight: 500;
	}
	
	.price-settlement {
	    padding: 4rem 2rem;
	    margin: 5rem -2rem 0;
	}
	.price-settlement .head {
	    font-size: 2.4rem;
	}
	.settlement-methods .note {
	    margin-top: 2rem;
	    font-size: 1.6rem;
	}
	.price-settlement .points li {
	    line-height: 1.3;
	    font-size: 1.7rem;
	}

}

/* about */
#about #wrapper {
	padding-top: 18rem;
}
.about-teaser {
	overflow: hidden;
	position: relative;
	padding: 45.7rem 0 16.4rem;
	background: url(../img/about/teaser.webp)no-repeat center;
	background-size: cover;
	border-radius: 20rem 20rem 0 0;
}
.about-teaser h1 {
	line-height: 1.6;
	color: #fff;
	font-size: 4.8rem;
	font-weight: 900;
}
.about-teaser .btn-link2 {
	margin-top: 4rem;
	text-align: left;
}
.btn-link2 .btn.small-st {
	padding: 0 6rem;
	height: 8.5rem;
	max-width: 48rem;
	font-size: 1.8rem;
}
.btn-link2 .small-st.orange-st {
    background: 
		linear-gradient(10deg, rgba(249, 140, 51, 0.6) 0%, rgba(252, 241, 81, 0.6) 100%),
		#F98C33;
}
.btn-link2 .small-st:before {
	right: 4rem;
}

.about-wrap {
	padding: 12rem 0 0;
	overflow: hidden;
}

.about-display .head {
	float: left;
	margin-bottom: 6rem;
}
.about-display .head .eng {
	margin-bottom: 3rem;
	line-height: 1.6;
	color: #00A23F;
	font-size: 6.4rem;
	font-weight: 500;
}
.about-display .head .jap {
	padding-left: 8rem;
	text-indent: -1.5em;
	line-height: 2.5;
	color: #6C624F;
	font-size: 3.6rem;
	font-weight: 700;
}
.about-display .img {
	float: right;
	overflow: hidden;
	margin-top: 10rem;
	width: calc(35% + 2.5rem);
	border-radius: 30rem;
	box-shadow: 0 0.4rem 2rem rgba(0,0,0,0.05);
}
.about-display .info {
	overflow: hidden;
	padding-left: 11rem;
	width: calc(65% - 4.5rem);
	line-height: 2;
	font-size: 2.4rem;
	font-weight: 500;
}
.about-display .info p + p {
	margin-top: 2.4rem;
}

.about-bike {
	overflow: hidden;
	position: relative;
	z-index: 2;
	background: linear-gradient(0deg, #EDF2EF calc(100% - 45.5rem), transparent calc(100% - 45.5rem));
}
.about-bike:before {
	content: "";
	position: absolute;
	left: 0;
	top: 31.5rem;
	width: 100%;
	height: 17.9rem;
	background: url(../img/about/bg_bike.webp)no-repeat center top;
	background-size: 100% 100%;
}

.about-cases {
	overflow: hidden;
	padding: 10rem 0 0;
}
.about-cases .cases-list {
	text-align: center;
}
.about-cases ul {
	display: inline-flex;
	justify-content: center;
	gap: 0 9.8vw;
	position: relative;
	margin: 0 auto;
	max-width: 133.6rem;
}
.about-cases ul:before,
.about-cases ul:after {
	content: "";
	position: absolute;
	bottom: 0;
	width: 32rem;
	height: 21rem;
	background: url(../img/about/img_case_circle2.webp)no-repeat center bottom;
	background-size: 100%;
}
.about-cases ul:before {
	right: 100%;
}
.about-cases ul:after {
	left: 100%;
}
.about-cases li {
	position: relative;
	z-index: 2;
	width: 30%;
	max-width: 32rem;
}
.about-cases li:after {
	content: "";
	position: absolute;
	left: calc(100% + 4.9vw);
	bottom: 0;
	transform: translateX(-50%);
	width: 9.8vw;
	height: 9.8vw;
	background: url(../img/about/img_case_circle2.webp)no-repeat center bottom;
	background-size: 100%;
}
.about-cases li:last-child:after {
	content: none;
}
.about-cases li .tit {
	margin: 0 auto 3rem;
	padding: 1.2rem 0;
	max-width: 27rem;
	background: #fff;
	border-radius: 3rem;
	text-align: center;
	line-height: 1;
	font-size: 2.2rem;
	font-weight: 500;
}
.about-cases li .img {
	position: relative;
	margin: 0 auto;
	padding: 1.6rem 1.6rem 5.4rem;
	background: url(../img/about/img_case_circle.webp)no-repeat center bottom;
	background-size: 100% 100%;
}
.about-cases li .img img {
	object-fit: cover;
	width: 100%;
	border-radius: 50%;
}

.decoration-wrap {
	position: relative;
}
.decoration-wrap .icon-bike {
	position: absolute;
	z-index: 2;
}
.decoration-wrap .icon-bike1 {
	bottom: 0;
	left: 12rem;
	width: 13.2rem;
}
.decoration-wrap .icon-bike2 {
	bottom: 0;
	right: 6.6rem;
	width: 13.2rem;
}

.about-features {
	padding: 9rem 0;
}

.about-features .inner {
	padding: 0;
	max-width: 150rem;
}

.about-features .head-small {
	margin-bottom: 5.4rem;
	padding: 0 3rem;
}
.about-features .display-list li {
	display: flex;
	align-items: center;
}
.about-features .display-list li .img {
	width: 44%;
	overflow: hidden;
}
.about-features .display-list li .img img {
	object-fit: cover;
	min-height: 40rem;
}
.about-features .display-list li .info {
	position: relative;
	padding: 4.4rem 10rem;
	width: 60%;
	background: #fff;
	box-shadow: 0 0.4rem 2rem rgba(0,0,0,0.05);
	border-radius: 30rem;
	line-height: 1.7;
	font-size: 2rem;
}
.display-list li:nth-of-type(even) {
	flex-direction: row-reverse;
}
.display-list li:nth-of-type(odd) .img {
	border-radius: 0 20rem 20rem 0;
}
.display-list li:nth-of-type(even) .img {
	border-radius: 20rem 0 0 20rem;
}
.display-list li:nth-of-type(odd) .info {
	margin-left: -10rem;
}
.display-list li:nth-of-type(even) .info {
	margin-right: -10rem;
}
.about-features .head {
	display: flex;
	align-items: center;
	gap: 0 3rem;
	position: relative;
	margin-bottom: 1.5rem;
}
.about-features .head .step {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 7.5rem;
	height: 7.5rem;
	background: linear-gradient(90deg,#35B264, #AEDA7B);
	border-radius: 50% 50% 0 50%;
	color: #fff;
	font-size: 2.6rem;
	font-weight: 900;
}
.about-features .head .jap {
	width: calc(100% - 10.5rem);
	line-height: 1.4;
	color: #00A23F;
	font-size: 3.2rem;
	font-weight: 700;
}

.about-benefits {
	padding: 10rem 0;
	background: url(../img/about/bg_benefits.webp)no-repeat center;
	background-size: cover;
}
.about-benefits .head-large {
	margin-bottom: 4rem;
	color: #fff;
}
.about-benefits .benefits-list ul {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.about-benefits .benefits-list li {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	padding-top: calc(25% - 0.6rem);
	width: 100%;
	background: #fff;
	border: 3px solid #F98C33;
	border-radius: 50%;
	box-shadow: 0 0.4rem 3rem rgba(34,144,75,0.7);
	text-align: center;
	line-height: 1.2;
	font-size: 2rem;
	font-weight: 500;
}
.about-benefits .benefits-list li:nth-of-type(1) {
	margin: 15rem -1.8rem 0 0;
}
.about-benefits .benefits-list li:nth-of-type(2) {
	margin-right: 1.8rem;
}
.about-benefits .benefits-list li:nth-of-type(3) {
	margin-left: 1.8rem;
}
.about-benefits .benefits-list li:nth-of-type(4) {
	margin: 15rem 0 0 -1.8rem;
}
.about-benefits .benefits-list .con {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}
.about-benefits .benefits-list .tit {
	margin-bottom: 1rem;
}
.about-benefits .benefits-list .icon {
	margin-bottom: 1rem;
}
.about-benefits .benefits-list .tit .jap {
	display: inline;
	background: linear-gradient(0deg, transparent 0.7rem, #FDFF92 0.7rem, #FDFF92 2rem, transparent 2rem);
	color: #F98C33;
	font-size: 3.2rem;
	font-weight: 700;
}
.decoration-wrap .icon-bike3 {
	bottom: -1.3rem;
	left: 50%;
	transform: translateX(-50%);
	width: 29.1rem;
}

.about-selectarea {
	display: flex;
	align-items: center;
	padding: 11rem 0 0;
}
.about-selectarea .img {
	overflow: hidden;
	width: 50%;
	border-radius: 0 48rem 48rem 0;
	height: 79rem;
}

.about-selectarea .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right center;
}

.about-selectarea .info {
	padding: 0 5rem 0 12.2rem;
	width: 50%;
	max-width: 81.6rem;
	line-height: 2;
	font-size: 2.4rem;
	font-weight: 500;
}
.about-selectarea .info p + p {
	margin-top: 5rem;
}
.about-selectarea .head {
	margin: 0 0 5rem -5rem;
	padding-left: 2em;
	white-space: nowrap;
	word-wrap: break-word;
	word-break:break-all;
	text-indent: -1.75em;
	line-height: 1.7;
	letter-spacing: 0.12em;
	color: #F98C33;
	font-size: 6.4rem;
	font-weight: 500;
}

.about-works {
	padding: 11rem 0;
}
.about-works .sub {
	margin-bottom: 1.6rem;
	text-align: center;
	letter-spacing: 0.12em;
	color: #F98C33;
	font-size: 4rem;
	font-weight: 700;
}
.howto-contact {
	padding: 6rem 2rem;
	background: #fff;
	border: 1px solid #D9D9D9;
	border-radius: 2rem;
}
.howto-contact .head {
	margin-bottom: 4rem;
	text-align: center;	
}
.howto-contact .head span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0 1rem;
	padding: 1.6rem 4rem;
	background: #FFFAEF;
	border-radius: 5rem;
	border: 1px solid;
	color: #F98C33;
	font-weight: 700;
	font-size: 2.4rem;
}
.howto-contact .head span:before,
.howto-contact .head span:after {
	content: "";
	display: block;
	height: 2rem;
	border-left: 2px solid;
}
.howto-contact .head span:before {
	transform: skewX(20deg);
	transform-origin: right bottom;
}
.howto-contact .head span:after {
	transform: skewX(-20deg);
	transform-origin: left bottom;
}
.about-works .howto-contact ul {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	margin: 0 auto;
	max-width: 126rem;
}
.about-works .howto-contact .title {
	display: flex;
	align-items: center;
	margin-bottom: 2.4rem;
}
.about-works .howto-contact .tit {
	position: relative;
	padding: 1.2rem 1rem 1.2rem 8rem;
	width: 100%;
	background: #6EBE8B;
	border-radius: 50rem;
	line-height: 1.6;
	color: #fff;
	font-size: 2.2rem;
	font-weight: 500;
}
.about-works .howto-contact .step {
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 7rem;
	height: 7rem;
	background: #fff;
	border: 1px solid;
	border-radius: 50%;
	color: #6EBE8B;	
	font-size: 3.6rem;
	font-weight: 700;
}
.about-works .howto-contact li:nth-of-type(2) .tit {
	background: #3DAD66;
}
.about-works .howto-contact li:nth-of-type(3) .tit {
	background: #00A23F;
}
.about-works .howto-contact li:nth-of-type(4) .tit {
	background: #10883C;
}
.about-works .howto-contact li:nth-of-type(2) .tit .step {
	color: #3DAD66;
}
.about-works .howto-contact li:nth-of-type(3) .tit .step {
	color: #00A23F;
}
.about-works .howto-contact li:nth-of-type(4) .tit .step {
	color: #10883C;
}
.about-works .howto-contact .tit2 {
	text-align: center;
	line-height: 1.3;
	font-weight: 700;
	font-size: 2.2rem;
}
.about-works .howto-contact .icon {
	position: relative;
	margin: 0 auto 2rem;
	max-width: 21rem;
	text-align: center;
}
.about-works .howto-contact .icon:after {
	content: "";
	position: absolute;
	left: 100%;
	top: 50%;
	transform: translateY(-50%);
	border-color: transparent transparent transparent #F98C33;
	border-width: 1.5rem 0 1.5rem 2.5rem ;
	border-style: solid;
}
.about-works .howto-contact li:last-child .icon:after {
	content: none;
}

.about-safety {
	padding: 6rem 0;
	background: #EDF2EF;
}
.about-safety .head-small {
	margin-bottom: 5rem;
}
.about-safety ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem;
}
.about-safety li .img {
	overflow: hidden;
	margin-bottom: 4rem;
	border-radius: 38rem;
}

.about-safety li .img img {
	width: 100%;
}

.about-safety li .tit {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	line-height: 1.4;
	color: #5B5750;
	font-size: 3.2rem;
	font-weight: 700;
}

.about-howtopay {
	padding: 11rem 0 0;
}

.advertisement-bike {
	padding: 16.7rem 0 12rem;
}
.advertisement-bike .advertisement-display {
	position: relative;
	padding: 6rem 11rem 5rem;
	margin: 0 auto;
	max-width: 150rem;
	background: #00A23F;
	border-radius: 2rem;
	box-shadow: 0 0.4rem 4rem rgba(0, 0, 0, 0.15);
	color: #fff;
}
.advertisement-bike .advertisement-display:before {
    content: "";
    pointer-events: none;
    position: absolute;
    left: 1rem;
    top: 1rem;
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    border-radius: 2rem;
    border: 2px dashed #fff;
}
.advertisement-bike .display {
	position: relative;
	padding-right: 52%;
	line-height: 1.6;
	font-size: 2rem;
	font-weight: 700;
}
.advertisement-bike .head {
	margin-bottom: 2.4rem;
	line-height: 1.2;
	color: #FFFB00;
	font-size: 6.4rem;
	font-weight: 700;
}
.advertisement-bike .display .img {
	overflow: hidden;
    position: absolute;
	right: 0;
	bottom: 0;
	width: 50%;
	max-width: 64.3rem;
	border-radius: 3rem;
}

.advertisement-bike .display .img img {
	width: 100%;
}

.advertisement-bike .btn-link2 {
	margin-top: 2.8rem;
	text-align: left;
}
.advertisement-bike .btn-link2 .btn.small-st {
	height: 7.5rem;
}
.advertisement-bike .points {
	display: flex;
	gap: 1rem 2rem;
	margin-top: 3.2rem;
}
.advertisement-bike .points li {
	position: relative;
	padding: 0.4rem 0 0.4rem 5.8rem;
	
	font-size: 2.4rem;
	font-weight: 700;
}
.advertisement-bike .points li .step {
	display: flex;
	justify-content: center;
	align-items: center;
    position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 4.8rem;
	height: 4.8rem;
	border-radius: 50% 50% 0;
	border: 1px solid;
	font-weight: 900;
}

.advertisement-bike .points .underline {
	text-decoration: underline;
}



@media screen and (max-width: 1440px) {
	.about-benefits .benefits-list li {
		font-size: 1.6rem;
	}
	.about-benefits .benefits-list li:nth-of-type(1) {
		margin-right: -1rem;
	}
	.about-benefits .benefits-list li:nth-of-type(2) {
		margin-right: 1rem;
	}
	.about-benefits .benefits-list li:nth-of-type(3) {
		margin-left: 1rem;
	}
	.about-benefits .benefits-list li:nth-of-type(4) {
		margin-left: -1rem;
	}
	.about-benefits .benefits-list .icon img {
		width: 5.6rem;
	}
	.about-benefits .benefits-list .tit .jap {
		font-size: 2.8rem;
	}
	
	.decoration-wrap .icon-bike3 {
		width: 24rem;
	}
	
	.about-selectarea .info {
		padding: 0 5rem 0 6rem;
		font-size: 2rem;
	}
	.about-selectarea .head {
		margin-bottom: 3.6rem;
		font-size: 4.8rem;
	}
	.about-selectarea .info p + p {
	    margin-top: 3.2rem;
	}
	
	.about-works .howto-contact .tit {
		padding: 1rem 1rem 1rem 6.5rem;
		font-size: 2rem;
	}
	.about-works .howto-contact .tit2 {
		font-size: 2rem;
	}
	.about-works .howto-contact .step {
		width: 5.6rem;
		height: 5.6rem;
		font-size: 3rem;
	}
	
}
@media screen and (max-width: 1280px) {
	.about-display .head {
	    margin-bottom: 4rem;
	}
	.about-display .head .jap {
		font-size: 3rem;
	}
	.about-display .info {
		font-size: 2rem;
	}
	
	.about-cases ul {
		gap: 0 8rem;
	}
	.about-cases li:after {
		right: calc(100% + 4rem);
		width: 12rem;
	}
	.about-cases li .tit {
		font-size: 1.8rem;
	}
	
	.about-features .display-list li .info {
	    padding: 4.4rem 5rem 4.4rem 8rem;
	    font-size: 1.8rem;
	}
	.about-features .head {
		gap: 0 2.5rem;
	}
	.about-features .head .step {
	    width: 6.5rem;
	    height: 6.5rem;
	    font-size: 2.4rem;
	}
	.about-features .head .jap {
	    width: calc(100% - 9rem);
	    font-size: 2.8rem;
	}
	
	.about-benefits .benefits-list li {
		font-size: 1.4rem;
	}
	.about-benefits .benefits-list li:nth-of-type(1) {
		margin-right: -2.6rem;
	}
	.about-benefits .benefits-list li:nth-of-type(4) {
		margin-left: -2.6rem;
	}
	.about-benefits .benefits-list .icon img {
		width: 4.8rem;
	}
	
	.about-works .howto-contact .tit {
		padding: 1rem 0.5rem 1rem 6rem;
		font-size: 1.8rem;
	}
	.about-works .howto-contact .step {
		width: 4.8rem;
		height: 4.8rem;
		font-size: 2.4rem;
	}
	.about-works .howto-contact .tit2 {
		font-size: 1.8rem;
	}
	
	.advertisement-bike .advertisement-display {
		padding: 2.5rem;
		max-width: 76.8rem;
	}
	.advertisement-bike .display {
		font-size: 1.6rem;
	}
	.advertisement-bike .head {
		margin-bottom: 1.6rem;
		font-size: 4rem;
	}
	.advertisement-bike .btn-link2 {
		margin-top: 1.6rem;
	}
	.advertisement-bike .btn-link2 .btn.small-st {
		padding: 0 4rem;
	    height: 5rem;
	}
	.advertisement-bike .points {
		margin-top: 2rem;
	}
	.advertisement-bike .points li {
	    padding-left: 5rem;
	    font-size: 1.8rem;
	}	
	.advertisement-bike .points li .step {
		width: 4rem;
		height: 4rem;
	}	
		
}
@media screen and (max-width: 1080px) {
	.about-benefits .benefits-list li {
		padding-top: calc(25% + 0.5rem);
	}
	.about-benefits .benefits-list li:nth-of-type(2) {
	    margin-right: 0.5rem;
	}
	.about-benefits .benefits-list li:nth-of-type(3) {
		margin-left: 0.5rem;
	}
	.about-benefits .benefits-list li:nth-of-type(1) {
		margin-right: -2.6rem;
	}
	.about-benefits .benefits-list li:nth-of-type(4) {
		margin-left: -2.6rem;
	}
	.about-benefits .benefits-list .tit,
	.about-benefits .benefits-list .icon {
	    margin-bottom: 0.6rem;
	}
	.about-benefits .benefits-list .tit .jap {
	    margin-bottom: 0.6rem;
		font-size: 2.4rem;
	}
	
	.about-selectarea .info {
		padding: 0 3rem;
		font-size: 2rem;
	}	
	.about-selectarea .head {
		margin-bottom: 3rem;
		line-height: 1.5;
		font-size: 3.6rem;
	}
	.about-selectarea .info p + p {
		margin-top: 2.4rem;
	}
	
	.about-works .howto-contact ul {
		gap: 1.6rem;
	}
	.about-works .howto-contact .icon:after {
		border-width: 1rem 0 1rem 1.5rem ;
	}
	.about-works .howto-contact .tit2 {
		font-size: 1.6rem;
	}
}
/*hover*/
@media screen and (min-width: 960px){
	.btn-link2 .orange-st:hover {
		background: #fff;
	}
	.btn-link2 .small-st:hover:before {
		right: 3rem;
	}
}
/* sp */
@media screen and (max-width: 750px) {
	#about #wrapper {
	    padding-top: 7rem;
	}
		
	.about-teaser {
	    padding: 5rem 0 0;
	    background: none;
	    border-radius: 0;
	}
	
	.about-teaser h1 {
		margin-bottom: 4rem;
		line-height: 1.4;
		color: #333;
		font-size: 3.2rem;
	}
	.about-teaser .img {
		overflow: hidden;
		margin: 0 -2rem 2rem;
		border-radius: 3rem 3rem 0 0;
	}
	.about-teaser .img img {
		object-fit: cover;
		width: 100%;
		height: 30rem;
	}
	.about-teaser .btn-link2 {
	    margin-top: 3rem;
	}
	
	.btn-link2 .btn.small-st {
	    padding: 0 3rem;
	    height: 6.5rem;
	    font-size: 1.8rem;
	}
	.btn-link2 .small-st:before {
	    right: 3rem;
	}
	
	.about-wrap {
	    padding: 8rem 0 0;
	}
	.about-display .head {
		float: none;
		margin-bottom: 3rem;
	}
	.about-display .head .eng {
	    margin-bottom: 1.4rem;
	    line-height: 1.6;
	    font-size: 2rem;
	}
	.about-display .head .jap {
	    padding-left: 1em;
	    text-indent: -1em;
	    line-height: 2.2;
	    font-size: 2.8rem;
	}
	.about-display .img {
	    float: none;
	    margin: 0 0 2rem;
	    width: auto;
	    border-radius: 0;
	    box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.05);
	}

	.about-display .img img {
		width: 100%;
	}

	.about-display .info {
	    padding-left: 0;
	    width: auto;
	    line-height: 1.6;
	}
	
	.about-bike {
	    background: linear-gradient(0deg, #EDF2EF calc(100% - 17rem), transparent calc(100% - 17rem));
	}
	.about-bike:before {
	    top: 13.8rem;
	    width: 100%;
	    height: 3.4rem;
	    background-image: url(../img/about/bg_bike_sp.webp);
	}
	
	.about-cases {
	    padding: 20rem 0 0;
	}
	.about-cases ul {
	    display: block;
	}
	.about-cases ul:before, 
	.about-cases ul:after {
		content: "none";
	}
	.about-cases li {
		padding: 0 5.333vw;
		width: auto;
		max-width: 100%;
	}
	.about-cases li:before {
		content: "";
		position: absolute;
		right: calc(100% - 5.333vw);
		bottom: 0;
		width: 25.333vw;
		height: 16vw;
		background: url(../img/about/img_case_circle2.webp) no-repeat center bottom;
		background-size: 100%;
	}
	.about-cases li:nth-of-type(even):before {
		right: auto;
		left: calc(100% - 5.333vw);
	}
	.about-cases li:after {
		bottom: -0.1333vw;
		transform: translateX(0%);
		width: 50.6667vw;
		height: 31.7333vw;
	}
	.about-cases li:last-child:after {
		content: "";
	}
	.about-cases li:nth-of-type(odd):after {
		left: auto;
		right: 0;
	}
	.about-cases li:nth-of-type(even):after {
		left: 0;
	}
	.about-cases li .tit {
		position: absolute;
		left: calc(50% - 4.6667vw);
		top: calc(50% - 2.6667vw);
		z-index: 2;
		transform: translateY(-50%);
	    margin: 0;
	    padding: 1.6vw 0;
		width: 60%;
		max-width: 48vw;
		border-radius: 5.8524vw;
		line-height: 1.6;
		font-size: 4.58vw;
	}
	.about-cases li:nth-of-type(even) .tit {
		left: auto;
		right: calc(50% - 4.6667vw);
	}
	.about-cases li .img {
	    margin: 0;
		width: 50%;
	    padding: 1.75vw 1.75vw 7vw;
	}
	.about-cases li:nth-of-type(even) .img {
		margin-left: auto;
	}
	
	.about-features {
	    padding: 11rem 0 7rem;
	}

	.about-features .inner {
		padding: 0 2rem;
	}

	.about-features .head-small {
		padding: 0;
	    margin-bottom: 5.9rem;
		text-align: left;
	}
	.about-features .display-list li {
	    display: block;
		margin: 0 -2rem;
	}
	.about-features .display-list li + li {
		margin-top: 5rem;
	}
	.about-features .display-list li .img {
		width: auto;
	}

	.about-features .display-list li .img img {
		min-height: 24rem;
	}
	.display-list li:nth-of-type(odd) .img,
	.display-list li:nth-of-type(even) .img {
	    border-radius: 0;
	}
	.about-features .display-list li .info {
		padding: 2rem;
		width: auto;
		line-height: 1.8;
		font-size: 1.6rem;
	}
	.display-list li:nth-of-type(odd) .info {
	    margin: -2rem 0 0 2rem;
		border-radius: 2rem 0 0 2rem;
	}
	.display-list li:nth-of-type(even) .info {
		margin: -2rem 2rem 0 0;
		border-radius: 0 2rem 2rem 0;
	}
	.about-features .head {
		gap: 0 1rem;
	}
	.about-features .head .step {
		width: 4.5rem;
		height: 4.5rem;
	}
	.about-features .head .jap {
		width: calc(100% - 5.5rem);
		font-size: 2.4rem;
	}
	
	.about-benefits {
	    padding: 6.8rem 0 3rem;
	}
	.benefits-list {
		padding-bottom: 16.5rem;
	}
	.about-benefits .benefits-list li:nth-of-type(1),
	.about-benefits .benefits-list li:nth-of-type(2),
	.about-benefits .benefits-list li:nth-of-type(3),
	.about-benefits .benefits-list li:nth-of-type(4) {
		margin: 0;
	}
	
	
	.decoration-wrap .icon-bike3 {
		bottom: 0;
		width: 19rem;
	}
	.about-benefits .benefits-list ul {
	    display: block;
		padding: 2.2rem 1.5rem;
		background: #fff;
		border: 3px solid #F98C33;
		border-radius: 5rem;
		box-shadow: 0 0.4rem 3rem rgba(34, 144, 75, 0.7);
	}
	.about-benefits .benefits-list li {
		padding: 2.5rem 0;
		background: none;
		border: 0;
		box-shadow: 0 0 0;
		border-radius: 0;
		text-align: left;
		line-height: 1.5;
		font-size: 1.6rem;
	}
	.about-benefits .benefits-list li + li {
		border-top: 1px dashed #DEDEDE;
	}
	.about-benefits .benefits-list .con {
	    position: static;
	    transform: translateY(0%);
	    width: 100%;
	}
	.about-benefits .benefits-list .tit {
		display: flex;
		align-items: center;
		gap: 0 1rem;
	}
	.about-benefits .benefits-list .tit .jap {
		margin: 0;
	}
	
	.about-selectarea {
	    display: block;
	    padding: 10.8rem 0 0;
	}
	.about-selectarea .img {
		margin-bottom: 2rem;
	    width: auto;
		height: 26.4rem;
	}
	.about-selectarea .img img {
		object-fit: cover;
		height: 26.4rem;
		width: 100%;
	}
	.about-selectarea .info {
        padding: 0 2rem;
	    width: auto;
		line-height: 1.6;
	}
	.about-selectarea .head {
	    margin: 0 0 4.5rem 0;
	    padding-left: 0;
	    text-indent: 0;
	    font-size: 4rem;
	}
	.about-selectarea .btn-link2 {
		margin-top: 4.7rem;
	}
	
	.about-works {
	    padding: 8rem 0;
	}
	.about-works .sub {
	    margin-bottom: 3.5rem;
		line-height: 1.4;
	    font-size: 2.4rem;
	    font-weight: 500;
	}
	.howto-contact {
	    padding: 4rem 2rem;
		margin: 0 -2rem;
	}
	.howto-contact .head {
	    margin-bottom: 2.4rem;
	}
	.howto-contact .head span {
	    padding: 1.6rem 2.8rem;
	    border-radius: 5rem;
		text-decoration: underline;
	    font-size: 1.8rem;
	}
	.about-works .howto-contact ul {
		grid-template-columns: repeat(1, 1fr);
		gap: 2.4rem;
	}
	.about-works .howto-contact .icon {
		margin-bottom: 3.6rem;
	}
	.about-works .howto-contact li:last-child .icon {
		margin-bottom: 1rem;
	}
	.about-works .howto-contact .icon:after {
		top: 100%;
		left: 50%;
		transform: translateX(-50%);
		border-width: 2.5rem 1.5rem 0 1.5rem;
		border-color: #F98C33 transparent transparent ;
	}
	
	.about-safety {
	    padding: 4rem 0;
	}
	.about-safety .head-small,
	.about-howtopay .head-small {
		text-align: left;
	}
	.about-safety ul {
	    grid-template-columns: repeat(1, 1fr);
	    gap: 4rem 0;
	}
	.about-safety li .img {
		margin-bottom: 2rem;
	}
	.about-safety li .tit {
	    font-size: 2.4rem;
	}
	
	.advertisement-bike {
	    padding: 8rem 1rem 10rem;
	}
	.advertisement-bike .advertisement-display {
		padding: 5rem 2rem 4.6rem;
	}
	.advertisement-bike .display {
	    padding-right: 0;
	    line-height: 1.7;
	    font-size: 1.8rem;
	}
	.advertisement-bike .head {
		text-align: center;
		font-size: 3.5rem;
	}
	.advertisement-bike .display .img {
	    position: static;
		margin: 0 auto 2.8rem;
	    width: auto;
		max-width: 26.5rem;
	}
	.advertisement-bike .points {
		display: block;
		margin-top: 4rem;
	}
	.advertisement-bike .points li {
		padding-left: 5.3rem;
		line-height: 1.4;
		font-size: 2rem;
	}
	.advertisement-bike .points li .step {
		width: 3.8rem;
		height: 3.8rem;
		font-size: 1.6rem;
	}
	.advertisement-bike .btn-link2 {
		margin-top: 4rem;
	}
	.advertisement-bike .btn-link2 .btn.small-st {
		height: 6.8rem;
	}
	
}

/* 基本はreCAPTCHAロゴを非表示 */
.grecaptcha-badge {
  z-index: 0;
}

/* お問い合わせページだけ表示 */
body#contact .grecaptcha-badge {
  z-index: 2;
}