@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400&display=swap');

html {
	font-size: 62.5%;
	-webkit-font-smoothing: antialiased;
}
body {
	color: #06a33e;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1;
	background-color: #ffffff;
	-webkit-text-size-adjust: 100%;
	word-wrap: break-word;
	overflow-wrap: break-word;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
* {
	-webkit-tap-highlight-color: transparent;
}
a {
	color: inherit;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
p, dt, dd, li {
	word-break: break-word;
	word-wrap: normal;
}
span {
	line-height: inherit;
	font-weight: inherit;
}
img {
	width: 100%;
	height: auto;
	max-width: 100%;
	vertical-align: top;
}
button {
	cursor: pointer;
}
.ib {
	display: inline-block;
	line-height: inherit;
	font-weight: inherit;
}
.inner {
	display: block;
}
.accordionTrigger {
	cursor: pointer;
	display: block;
}
.accordionContent {
	display: none;
}
.cf:after {
	content: "";
	display: block;
	clear: both;
}
.serif {
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
}
.mode_pc,
.mode_pc_ib {
	display: none;
}
.mode_sp {
	display: block;
}
@media screen and (min-width:769px) {
	.mover {
		transition: opacity 0.2s ease-out;
		backface-visibility: hidden;
		zoom: 1;
	}
	.mover:hover {
		opacity: 0.8;
	}
	.moverContent > * {
		transition: opacity 0.2s ease-out;
		backface-visibility: hidden;
		zoom: 1;
	}
	.moverContent:hover > * {
		opacity: 0.8;
	}
	.mode_pc {
		display: block;
	}
	.mode_pc_ib {
		display: inline-block;
	}
	.mode_sp {
		display: none;
	}
}

/* loading */
html {
	width: 100%;
	height: 100%;
}
body.loading {
	overflow: hidden;
	width: 100%;
	height: 100%;
	background-color: #000000;
}
#loading {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 3000;
	background-image: url(../img/loading_blk.png);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 180px 180px;
}
#loading.load {
	animation: fade 4s linear infinite;
}
@keyframes fade {
	0% { opacity: 1; }
	50% { opacity: 0; }
	100% { opacity: 1; }
}
body.load_complete #loading {
	display: none;
}
#suntory_contents {
	transition: opacity 0.5s;
}
body.loading #suntory_contents {
	opacity: 0;
}
body.load_complete #suntory_contents {
	opacity: 1;
}
@media screen and (min-width: 769px) {
	#loading {
		background-size: 220px 220px;
	}
}

/* common */

#suntory_contents {
    background: #ccd9ce;
}

.wrapper {
	overflow: hidden;
	position: relative;
	background-color: #ffffff;
}
.content {
	position: relative;
}
.contentInner {
	margin: auto;
}
.fadeContent {
	opacity: 0;
	transition: all 0.5s ease-out;
}
.fadeContent.current {
	opacity: 1;
}
.fadeContentUp {
	transform: translateY(-50px);
}
.fadeContentUp.current {
	transform: translateY(0);
}
@media screen and (min-width:769px) {
	.wrapper {
		width: 750px;
		margin: 0 auto;
	}
	.contentInner {
		width: 100%;
		box-sizing: border-box;
	}
}

/* mainVisual */
#mainVisual .content {
}
#mainVisual .contentInner {
	width: 100%;
}
@media screen and (min-width:769px) {
	#mainVisual .content {
	}
}
/* info */
#info .content {
	background: #000000;
}
#info .content p {
	border-top: solid 1px #ffffff ;
	padding-top: 3%;
	color: #ffffff;
	line-height: 1.2;
}
@media screen and (min-width:769px) {
	#info .content p {
		line-height: 1.4;
		font-size: 16px;
	}
}

/* steps */
#steps .step {
	width: calc(690 / 750 * 100%);
	margin: 0 auto;
	padding: calc( 34/750*100%) 0 calc( 80/750*100%) 0;
}
#steps .step li {
	margin-bottom: calc( 12/750*100%);
}

/* term */
#term {
}
#term .content {
	overflow: hidden;
	background-color: #ccd9ce;
}
#term .contentInner {
    width: calc(708 / 768 * 100%);
    margin: auto;
	padding-top: calc(31 / 768 * 100%);
}
#term .box {
	background-color: #ffffff;
	margin: 0 0 calc(80 / 708 * 100%) 0;
	padding: calc(43 / 708 * 100%) calc(40 / 708 * 100%) calc(36 / 708 * 100%) calc(40 / 708 * 100%);
	border-radius: 6px;
}
#term .box .boxInner {
	overflow: auto;
	height: 55.5vh;
	padding: 0 calc(10 / 628 * 100%) 0 0;
	-webkit-overflow-scrolling: touch;
	min-height: 300px;
}
#term .applyTitle {
    text-align: center;
    font-size: 15px;
    line-height: 24px;
    font-weight: 700;
    margin: 0 auto 30px auto;
}
#term .box .intro {
	color: #06a33e;
	line-height: 1.5;
	letter-spacing: -0.075em;
	padding: 0 0 calc(50 / 618 * 100%) 0;
}
#term .box .row {
	color: #06a33e;
}
#term .box .row .boxHead {
	color: #ffffff;
	font-weight: 700;
	text-align: center;
	background-color: #c59f47;
	margin: 0 0 calc(20 / 618 * 100%) 0;
	padding: calc(10 / 618 * 100%) 0 calc(15 / 618 * 100%) 0;
	border-radius: 4px;
}
#term .box .row .boxCont {
	margin: 0 0 calc(40 / 618 * 100%) 0;
}
#term .box .row .boxCont li {
	line-height: 1.5;
	text-indent: -1em;
	padding: 0 0 0 1em;
}
#term .box .row .boxCont li.products_name {
	line-height: 1.5;
	text-indent: 0;
	padding: 0 0 0 0;
}

#term .box .row .boxCont a {
	text-decoration: underline;
}
#term .box .row .boxCont a.mail {
	text-decoration: none;
}
#term .box .row .boxCont .mb {
	margin: 0 0 calc(10 / 618 * 100%) 0;
}
#term .box .row .boxCont .bold {
	font-weight: 700;
}
#term .box .row .boxCont .large {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.5;
}
#term .bt_area {
	padding-bottom: calc(70 / 750 * 100%);
}
#term p {
	line-height: 1.4;
}
#term p.read {
	margin-bottom: 1em;
}
#term ul.list {
	margin-bottom: 1em;
}


@media screen and (min-width: 769px) {
	#term .contentInner {
		width: 100%;
		max-width: 960px;
	}
	#term .box {
		margin: 0 0 calc(61 / 960 * 100%) 0;
		padding: calc(35 / 960 * 100%) calc(40 / 960 * 100%) calc(36 / 960 * 100%) calc(40 / 960 * 100%);
		border-radius: 5px;
		border-top-left-radius: 0;
		border-top-right-radius: 0;
	}
	#term .box .boxInner {
/* 		height: 46.6vh; */
		padding: 0;
	}
	#term .box .intro {
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.73;
		padding: 0 0 calc(33 / 880 * 100%) 0;
	}
	#term .box .row {
	}
	#term .box .row .boxHead {
		font-size: 18px;
		font-size: 1.8rem;
		font-weight: 700;
		margin: 0 0 calc(25 / 883 * 100%) 0;
		padding: calc(6 / 883 * 100%) 0 calc(10 / 883 * 100%) 0;
	}
	#term .box .row .boxCont {
		margin: 0 0 calc(40 / 883 * 100%) 0;
	}
	#term .box .row .boxCont p {
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.73;
	}
	#term .box .row .boxCont li {
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.73;
	}
	#term .box .row .boxCont .mb {
		margin: 0 0 calc(10 / 883 * 100%) 0;
	}
	#term .box .row .boxCont .bold {
		font-weight: 700;
	}
	#term .box .row .boxCont .large {
		font-size: 20px;
		font-size: 2.0rem;
		line-height: 1.73;
	}
	#term .box .row .boxCont .note {
		font-size: 12px;
		font-size: 1.2rem;
		line-height: 1.73;
	}
}


@media screen and (min-width:769px) {
	#term .title {
		padding: 0 0 0 0;
	}
	#term .contentInner {
		padding-top: 0;
	}
	#term .box {
		border-top-left-radius: 0;
		border-top-right-radius: 0;
	}
	#term .applyTitle {
	    text-align: center;
	    font-size: 18px;
	    line-height: 24px;
	}
	.bt_area a {
		display: block;
		width: 400px;
		margin: 0 auto !important;		
	}
}
