@charset "UTF-8";
/*************************************************************
/ common [共通]
/************************************************************/
html {
	overflow-x: hidden;
}

body {
	min-width: 1200px;
	font-size: 15px;
	font-weight: 300;
	line-height: 1.9;
	letter-spacing: 0.05em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

@media only screen and (max-width: 750px) {
	body {
		width: 100%;
		min-width: 100%;
		font-size: 13px;
	}
}

@media only screen and (min-width: 751px) {
	.sp {
		display: none;
	}
}

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

#tpl-contents {
	margin: 0 0 100px 0;
}

@media only screen and (max-width: 750px) {
	#tpl-contents {
		margin-bottom: 10%;
	}
}

.flex-lay {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	align-items: center;
}

.flex-lay .item {
	margin: 0;
}

.btn:not(.mfp-btm-close) {
	width: 300px;
	height: 40px;
}

.btn:not(.mfp-btm-close) a {
	transition: background .3s;
}

.btn.blank-blk a {
	background-color: #fff;
}

.btn.blank-blk a::after {
	width: 12px;
	height: 9px;
	background-image: url("../img/ico-blank.png");
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	margin: auto;
}

.btn.blank-blk a:hover {
	background-color: #000;
}

@media only screen and (max-width: 750px) {
	.btn:not(.mfp-btm-close) {
		width: 100%;
		height: 50px;
	}
}

@media only screen and (max-width: 750px) {
	.btn:not(.mfp-btm-close) a {
		font-size: 13px;
	}
}

@media only screen and (max-width: 750px) {
	.btn.blank-blk a::after {
		right: 25px;
	}
}

@media only screen and (min-width: 751px) {
	.btn.blank-blk a:hover::after {
		background-image: url("../img/ico-blank_on.png");
	}
}

.ico-arrow {
	background-image: url("/oiocha/gyokuro/img/ico-arrow.png");
	background-repeat: no-repeat;
	background-position: -20px center;
	display: inline-block;
	padding-left: 40px;
	transition: .5s;
	overflow: hidden;
}

.ico-arrow:hover {
	text-decoration: none;
	padding-left: 60px;
	background-position: 0 center;
}

.fs-s {
	font-size: 12px;
}

@media only screen and (max-width: 750px) {
	.fs-s {
		font-size: 10px;
	}
}

.hv-op {
	transition: opacity .5s;
}

@media only screen and (min-width: 751px) {
	.hv-op:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}

.trim-img {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.trim-img img {
	display: none;
}

/*************************************************************
/ header
/************************************************************/
.top-header {
	height: 80px;
	padding: 0 20px;
}

@media only screen and (max-width: 750px) {
	.top-header {
		height: 50px;
		padding: 0 15px;
	}
}

@media only screen and (max-width: 750px) {
	.top-header .logo img {
		width: 63px;
		vertical-align: middle;
	}
	.top-header .logo-center img {
		width: 130px;
		vertical-align: middle;
	}
}

@media only screen and (max-width: 750px) {
	.top-header .logo-ocha img {
		width: 70px;
	}
}

/*************************************************************
/ kv
/************************************************************/
/*************************************************************
/ hero [メインビジュアル]
/************************************************************/
.hero {
	width: 100%;
	position: relative;
	background-color: #fff;
	overflow: hidden;
	min-height: 680px;
}

@media only screen and (max-width: 750px) {
	.hero {
		z-index: 0;
		min-height: auto;
	}
}

@media only screen and (min-width: 751px) {
	.hero {
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: space-between;
		justify-content: space-between;
		-webkit-align-items: center;
		align-items: center;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
	}
}

.hero .img-block {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.hero .img-block .img-item {
	width: 100%;
	height: 100%;
	background-position: center top;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
}

.hero .img-block .img-item .img {
	width: 100%;
	height: 100%;
	transform: scale(1.1);
}

.hero .img-block .img-item .img img {
	display: none;
}

.hero .slide {
	width: 487px;
	height: 487px;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}

@media only screen and (max-width: 750px) {
	.hero .slide {
		width: 100%;
		height: auto;
		position: static;
	}
}

.hero .main-logo {
	position: absolute;
	top: 0;
	left: 6%;
	bottom: 0;
	right: 0;
	margin: auto;
	transition: 2s;
	z-index: 3;
	opacity: 0;
}

@media only screen and (max-width: 750px) {
	.hero .main-logo {
		width: 70%;
		position: relative;
		margin-top: 13%;
	}
}

.hero .main-logo.active {
	opacity: 1;
}

@media only screen and (max-width: 750px) {
	.hero .main-logo img {
		width: 100%;
	}
}

.hero .catch {
	position: absolute;
	z-index: 2;
	top: 50%;
	right: 5%;
	left: auto;
	width: 200px;
	height: 452px;
	margin-top: -226px;
	clip: rect(0, 200px, 0, 0);
	transition: clip .7s linear, opacity 3s;
}

@media only screen and (max-width: 750px) {
	.hero .catch {
		clip: rect(0, 750px, 0, 0);
		opacity: 0;
		transition: 1s;
		width: 60%;
		top: 0;
		left: 4%;
		right: auto;
		margin-top: 13%;
		height: auto;
		position: relative;
	}
}

.hero .catch.active {
	clip: rect(0, 200px, 452px, 0);
}

@media only screen and (max-width: 750px) {
	.hero .catch.active {
		clip: rect(0, 750px, 180px, 0);
		opacity: 1;
	}
}

@media only screen and (max-width: 750px) {
	.hero .catch img {
		width: 100%;
	}
}

.hero .frame {
	position: absolute;
	z-index: 2;
	top: auto;
	bottom: 5%;
	left: 5%;
	right: auto;
	width: 366px;
	height: 214px;
	opacity: 0;
	transition: 1s;
}

@media screen and (max-width: 750px) {
	.hero .frame {
		width: 50%;
		height: auto;
		left: 0;
		bottom: 0;
		margin-top: 8%;
		position: relative;
	}
}

.hero .frame.active {
	opacity: 1;
}

@media screen and (max-width: 750px) {
	.hero .frame img {
		width: 100%;
	}
}

.hero .bg-block {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	opacity: 0;
	transition: 1s;
	background-color: rgba(255, 0, 0, 0.1);
}

.hero .bg-block.active {
	opacity: 1;
}

.hero .bg-block .hero-player-wrap {
	position: absolute;
	margin: auto;
	top: -5000px;
	bottom: -5000px;
	left: -5000px;
	right: -5000px;
}

.hero .bg-block .hero-player-wrap-cover {
	position: absolute;
	left: 0;
	height: 0;
	width: 100%;
	height: 100%;
}

.hero .ico-scroll {
	height: 50px;
	width: 100%;
	position: absolute;
	bottom: 0px;
	z-index: 10;
}

.hero .ico-scroll span {
	background: #fff;
	display: inline-block;
	width: 1px;
	height: 0;
	position: absolute;
	left: 50%;
	transition: 1s;
}

@media only screen and (max-width: 750px) {
	.hero .bg-block {
		background-image: url("../img/mv_bg_sp.jpg") !important;
		background-position: center 3%;
		background-size: contain;
		background-color: #7e9e3a;
	}
}

.ico-scroll.active span {
	-webkit-animation: barTrans 2s infinite;
	animation: barTrans 2s infinite;
}

@keyframes barTrans {
	0% {
		height: 0;
		transform: translateY(0);
	}
	50% {
		height: 100%;
		transform: translateY(0);
	}
	100% {
		transform: translateY(100px);
	}
}

/* mainvisual
----------------------------------------*/
.sec-mainvisual {
	width: 100%;
	position: relative;
	padding-bottom: 50%;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual {
		height: 100.13333vw;
	}
}

body.sp .sec-mainvisual {
	height: 100.13333vw;
}

.sec-mainvisual .main-title {
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
}

.sec-mainvisual .mainvisual {
	position: absolute;
	width: 100%;
	height: 100%;
	background-image: url("../img/mainvisual.jpg");
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .mainvisual {
		background-image: url("../img/mainvisual-sp.jpg");
	}
}

.sec-mainvisual .player-wrapper.hidden {
	display: none;
}

.sec-mainvisual .mainvisual-player {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: 0;
	height: 100%;
	pointer-events: none;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .mainvisual-player {
		display: none;
	}
}

body.sp .sec-mainvisual .mainvisual-player {
	display: none;
}

.sec-mainvisual .mainvisual-player.hidden {
	display: none;
}

.sec-mainvisual .mainvisual-movie-btn-pc {
	position: absolute;
	right: 20px;
	bottom: 20px;
}

@media screen and (min-width: 751px) {
	.sec-mainvisual .mainvisual-movie-btn-pc {
		transition: opacity 0.3s ease-out;
	}
	.sec-mainvisual .mainvisual-movie-btn-pc:hover {
		opacity: 0.7;
	}
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .mainvisual-movie-btn-pc {
		display: none;
	}
}

body.sp .sec-mainvisual .mainvisual-movie-btn-pc {
	display: none;
}

.sec-mainvisual .mainvisual-movie-btn-sp {
	display: none;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .mainvisual-movie-btn-sp {
		display: block;
		width: 100%;
		height: 56.26667vw;
	}
}

body.sp .sec-mainvisual .mainvisual-movie-btn-sp {
	display: block;
	width: 100%;
	height: 56.26667vw;
}

.sec-mainvisual .mainvisual-package {
	position: absolute;
	width: 210px;
	right: 30px;
	bottom: 0;
	display: none;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .mainvisual-package {
		width: 18.93333vw;
		right: 4vw;
		display: block;
	}
}

.sec-mainvisual .note {
	position: absolute;
	left: 20px;
	bottom: -30px;
	display: none;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .note {
		left: 4vw;
		bottom: -8vw;
		display: block;
	}
}

.sec-mainvisual .note p {
	color: #333;
	margin-left: 1em;
	text-indent: -1em;
	line-height: 1.5em;
}

@media screen and (min-width: 751px) {
	.sec-mainvisual .note p {
		font-size: 10px;
	}
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .note p {
		font-size: 16px;
		font-size: 2.13333vw;
	}
}

.sec-mainvisual .scroll-sign {
	position: fixed;
	left: 0;
	right: 0;
	margin: auto;
	font-size: 14px;
	color: #777;
	letter-spacing: 1px;
	width: 70px;
	height: 70px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	text-align: center;
	transition: opacity 0.5s;
	pointer-events: none;
}

.sec-mainvisual .scroll-sign.hide {
	opacity: 0;
}

.sec-mainvisual .scroll-sign span {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: block;
	width: 100%;
	line-height: 1em;
	margin: 0 auto 0;
}

.sec-mainvisual .scroll-sign:after {
	content: '';
	position: absolute;
	display: block;
	width: 1px;
	height: 50px;
	top: 20px;
	left: 0;
	right: 0;
	margin: auto;
	background-color: #777;
}

.sec-mainvisual .scroll-sign.active:after {
	animation-name: scroll-line;
	animation-duration: 2.0s;
	animation-iteration-count: infinite;
}

@media screen and (max-width: 750px) {
	.sec-mainvisual .scroll-sign {
		display: none;
	}
}

@keyframes scroll-line {
	0% {
		transform-origin: center top;
		transform: scale(1, 0);
	}
	45% {
		transform-origin: center top;
		transform: scale(1, 1);
	}
	55% {
		transform-origin: center bottom;
		transform: scale(1, 1);
	}
	100% {
		transform-origin: center bottom;
		transform: scale(1, 0);
	}
}

.movie-btn {
	position: relative;
	display: block;
}

.movie-btn > span {
	display: block;
}

.movie-btn > div {
	position: absolute;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.movie-btn > div:after {
	content: '';
	width: 70px;
	height: 70px;
	background-image: url("../img/movie-btn.png");
	background-repeat: no-repeat;
	background-size: cover;
}

@media screen and (max-width: 750px) {
	.movie-btn > div:after {
		width: 13.33333vw;
		height: 13.33333vw;
	}
}

@media screen and (min-width: 751px) {
	.movie-btn > span {
		transition: opacity 0.3s ease-out;
	}
	.movie-btn > div {
		transition: transform 0.3s ease-out;
	}
	.movie-btn:hover > span {
		opacity: 0.8;
	}
	.movie-btn:hover > div {
		transform: scale(1.05);
	}
}

/*************************************************************
/ .section
/************************************************************/
.section {
	width: 1200px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 100px;
}

@media only screen and (max-width: 750px) {
	.section {
		width: 100%;
		margin-top: 60px;
	}
}

.over-box-parts {
	width: 200%;
	position: absolute;
	bottom: 0;
}

@media only screen and (max-width: 750px) {
	.over-box-parts {
		display: none;
	}
}

/*************************************************************
/ .sec-chaxun
/************************************************************/
@media only screen and (max-width: 750px) {
	.sec-chaxun {
		padding: 0 25px;
	}
}

.sec-chaxun .sec-ttl {
	font-size: 32px;
	color: #2a9e45;
	text-align: center;
	font-weight: bold;
	margin-bottom: 20px;
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .sec-ttl {
		font-size: 28px;
		margin-bottom: 15px;
	}
}

.sec-chaxun .sec-des {
	font-size: 18px;
	text-align: center;
	margin-bottom: 40px;
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .sec-des {
		font-size: 16px;
		margin-bottom: 35px;
	}
}

.sec-chaxun .accordion-contents {
	width: 750px;
	margin: 0 auto;
	background: #f2f7ed;
	padding: 25px;
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .accordion-contents {
		padding: 15px;
		width: auto;
	}
}

.sec-chaxun .accordion-contents .ttl {
	text-align: center;
}

.sec-chaxun .accordion-contents .ttl span {
	font-size: 18px;
	margin-bottom: 5px;
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .accordion-contents .ttl span {
		font-size: 16px;
		margin-bottom: 10px;
	}
	.sec-chaxun .accordion-contents .ttl span:after {
		content: "";
		display: inline-block;
		width: 11px;
		height: 11px;
		margin-left: 8px;
		background: url("../img/arrow_b.png") no-repeat;
		background-size: 11px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .accordion-contents .ttl.close span:after {
		background: url("../img/arrow_r.png") no-repeat;
		background-size: 11px;
	}
}

.sec-chaxun .accordion-contents .accordion-block {
	font-size: 14px;
	text-align: center;
}

@media only screen and (max-width: 750px) {
	.sec-chaxun .accordion-contents .accordion-block {
		font-size: 12px;
		padding-top: 5px;
		display: none;
	}
}

/*************************************************************
/ .sec-chajin
/************************************************************/
.sec-chajin {
	position: relative;
}

.sec-chajin .sec-ttl {
	position: relative;
	text-align: center;
}

.sec-chajin .sec-ttl .img {
	background: url("../img/ttl_01.png") no-repeat;
	width: 400px;
	height: 400px;
	display: block;
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

.sec-chajin .sec-ttl .img img {
	width: auto;
}

@media screen and (max-width: 750px) {
	.sec-chajin .sec-ttl .img img {
		width: 5.86667vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-chajin .sec-ttl .img {
		width: 60vw;
		height: 60vw;
		margin: 0 auto;
	}
}

.sec-chajin .sec-content {
	margin-top: -100px;
	margin-left: 100px;
	margin-right: -100px;
	padding: 200px 100px;
	height: 708px;
	box-sizing: border-box;
	background: url("../img/sec-chajin-bg.jpg") no-repeat;
}

.sec-chajin .sec-des {
	position: absolute;
	top: 120px;
	left: 450px;
	font-size: 18px;
	line-height: 2;
}

.sec-chajin .sec-des span.text {
	position: absolute;
	top: -13px;
	left: 22px;
	font-size: 10px;
	color: #000;
}

@media screen and (max-width: 750px) {
	.sec-chajin .sec-des span.text {
		width: 30%;
		top: -6%;
		color: #fff;
	}
}

.sec-chajin .sec-des span.text q {
	display: inline-block;
}

.sec-chajin .sec-des span.text q:nth-child(2) {
	margin-left: 7px;
}

@media screen and (max-width: 750px) {
	.sec-chajin .sec-des span.text q:nth-child(2) {
		margin-left: 5px;
	}
}

.sec-chajin .sec-des span.text q:nth-child(3) {
	margin-left: 21px;
}

@media screen and (max-width: 750px) {
	.sec-chajin .sec-des span.text q:nth-child(3) {
		margin-left: 14px;
	}
}

.sec-chajin .flow-list.flex-lay {
	flex-wrap: wrap;
	align-items: normal;
	position: absolute;
	right: 6%;
}

@media screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay {
		right: 0;
	}
}

.sec-chajin .flow-list.flex-lay li {
	width: 24px;
	color: #fff;
	font-size: 24px;
	line-height: 1.2;
	margin: 0 15px;
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li {
		width: 16px;
		font-size: 16px;
		margin: 0 2%;
	}
}

@media screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li:first-child {
		display: block;
		width: 100%;
		text-align: center;
		margin-bottom: 15%;
	}
	.sec-chajin .flow-list.flex-lay li:first-child span {
		font-size: 30px;
		width: 30px;
		display: inline-block;
	}
}

.sec-chajin .flow-list.flex-lay li:last-child {
	font-size: 50px;
	margin-top: -40px;
}

.sec-chajin .flow-list.flex-lay li.li1 {
	margin-right: 50px;
}

@media screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li.li1 {
		margin-right: 8%;
	}
}

.sec-chajin .flow-list.flex-lay li.li2 {
	margin-top: -35px;
}

@media screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li.li2 {
		margin-top: -20px;
	}
}

.sec-chajin .flow-list.flex-lay li.li2 b {
	margin: 5px 0;
}

.sec-chajin .flow-list.flex-lay li b {
	display: block;
	font-weight: normal;
}

.sec-chajin .over-box-parts {
	left: 50%;
	margin-left: 700px;
	background: #000;
}

@media only screen and (max-width: 750px) {
	.sec-chajin .sec-ttl {
		text-align: center;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .sec-ttl img {
		width: 225px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .sec-content {
		width: 100%;
		margin-top: -113px;
		margin-left: 0;
		margin-right: 0;
		display: block;
		padding: 150px 25px 100px;
		background: url("../img/sec-chajin-bg_sp.jpg") no-repeat bottom center;
		height: auto;
		background-size: 100%;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .sec-des {
		position: relative;
		font-size: 32px;
		font-size: 4.26667vw;
		line-height: 1.7;
		color: #fff;
		left: 0;
		top: 0;
		margin-bottom: 10%;
		padding-bottom: 10%;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .ttl {
		text-align: center;
		border-top: solid 1px #000;
		border-bottom: solid 1px #000;
		padding: 15px 0;
		margin-top: 40px;
		margin-bottom: 25px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .ttl img {
		width: 130px;
		vertical-align: middle;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay {
		width: 70%;
		margin: 0 auto;
		position: static;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li + li::before {
		display: none;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li::after {
		position: static;
		width: 30px;
		height: 69px;
		background-image: url("../img/arrow_sp.png");
		background-size: contain;
		margin: 20px auto;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li .month {
		margin-bottom: 25px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li .month img {
		width: 100%;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li .figure img {
		width: 100%;
	}
}

@media only screen and (max-width: 750px) {
	.sec-chajin .flow-list.flex-lay li .txt {
		padding: 0;
	}
}

/*************************************************************
/ sec-kuchikirimacha
/************************************************************/
.sec-kuchikirimacha {
	position: relative;
}

.sec-kuchikirimacha .sec-ttl {
	position: relative;
}

.sec-kuchikirimacha .sec-ttl .img {
	background: url("../img/ttl_01.png") no-repeat;
	width: 400px;
	height: 400px;
	margin-left: auto;
	display: block;
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

.sec-kuchikirimacha .sec-ttl .img img {
	width: 150px;
}

@media screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-ttl .img img {
		width: 29.33333vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-ttl .img {
		width: 60vw;
		height: 60vw;
		margin: 0 auto;
	}
}

.sec-kuchikirimacha .sec-content {
	width: 1000px;
	margin-top: -100px;
	margin-left: -100px;
	padding: 100px 100px 100px 100px;
	background-color: #f2f7ed;
	align-items: center;
}

.sec-kuchikirimacha .sec-des {
	position: absolute;
	top: 70px;
	left: 0;
	font-size: 18px;
	line-height: 2.1;
}

.sec-kuchikirimacha .sec-des span.text {
	position: absolute;
	top: -13px;
	left: 22px;
	font-size: 10px;
	color: #000;
}

@media screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-des span.text {
		width: 30%;
		top: -6%;
	}
}

.sec-kuchikirimacha .sec-des span.text q {
	display: inline-block;
}

.sec-kuchikirimacha .sec-des span.text q:nth-child(2) {
	margin-left: 7px;
}

@media screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-des span.text q:nth-child(2) {
		margin-left: 5px;
	}
}

.sec-kuchikirimacha .sec-des span.text q:nth-child(3) {
	margin-left: 21px;
}

@media screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-des span.text q:nth-child(3) {
		margin-left: 14px;
	}
}

.sec-kuchikirimacha .movie-item img {
	width: 100%;
}

.sec-kuchikirimacha .movie-item .cap {
	text-align: center;
	margin-top: 20px;
}

.sec-kuchikirimacha .over-box-parts {
	right: 50%;
	margin-right: 700px;
	background-color: #f2f7ed;
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-ttl {
		text-align: center;
	}
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-ttl img {
		width: 225px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-content {
		width: 100%;
		margin-top: -113px;
		margin-left: 0;
		margin-right: 0;
		display: block;
		padding: 150px 25px 40px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .sec-des {
		position: relative;
		font-size: 32px;
		font-size: 4.26667vw;
		line-height: 1.7;
		top: 0;
	}
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .movie-item {
		margin-top: 40px;
	}
}

@media only screen and (max-width: 750px) {
	.sec-kuchikirimacha .movie-item .cap {
		text-align: center;
		margin-top: 10px;
	}
}

/*************************************************************
/ lineup-ttl-block
/************************************************************/
.lineup-ttl-block {
	margin-top: 100px;
	margin-bottom: 180px;
	height: 411px;
	background: url("../img/bg_blue.jpg") no-repeat top center;
	background-size: cover;
	position: relative;
	overflow: hidden;
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

.lineup-ttl-block .ttl span {
	display: block;
	font-size: 36px;
	color: #fff;
	width: 36px;
	line-height: 1.2;
}

@media only screen and (max-width: 750px) {
	.lineup-ttl-block .ttl span {
		font-size: 45px;
		font-size: 6vw;
		width: 6vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-ttl-block {
		height: auto;
		padding: 20vw 0;
		margin-top: 13.33333vw;
		margin-bottom: 0;
		background-size: cover;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-ttl-block .ttl img {
		width: 175px;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-ttl-block .bottle-img {
		width: 270px;
		bottom: 10px;
		top: auto;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-ttl-block .obj {
		width: 540px;
		left: auto;
		right: 50%;
		margin-right: -170px;
		margin-top: -300px;
	}
}

/*************************************************************
/ lineup-item
/************************************************************/
.lineup-item {
	margin-top: 100px;
	position: relative;
}

.lineup-item .figure {
	position: absolute;
}

.lineup-item .figure.figure01 {
	top: -80px;
	left: 190px;
}

@media screen and (max-width: 750px) {
	.lineup-item .figure.figure01 img {
		width: 22.93333vw;
	}
}

.lineup-item .figure.figure02 {
	top: -40px;
	right: 180px;
}

@media screen and (max-width: 750px) {
	.lineup-item .figure.figure02 img {
		width: 40vw;
	}
}

.lineup-item .figure.figure03 {
	top: -25px;
	left: 145px;
}

@media screen and (max-width: 750px) {
	.lineup-item .figure.figure03 img {
		width: 40%;
	}
}

.lineup-item .figure.figure04 {
	top: -25px;
	right: 140px;
}

@media screen and (max-width: 750px) {
	.lineup-item .figure.figure04 img {
		width: 45%;
	}
}

.lineup-item .item-content {
	width: 1100px;
	background-color: #f2f7ed;
	padding-top: 80px;
	padding-bottom: 90px;
}

.lineup-item .item-content .type {
	font-size: 16px;
	margin-bottom: 30px;
}

.lineup-item .item-content .type::before {
	content: '';
	display: inline-block;
	height: 44px;
	background-position: center;
	background-repeat: no-repeat;
	vertical-align: middle;
	margin-right: 10px;
}

.lineup-item .item-content .name {
	font-size: 26px;
	color: #b29500;
	border-bottom: solid 1px #d2d4d9;
	padding-bottom: 20px;
	margin-bottom: 20px;
}

.lineup-item .item-content .btn.bottle-bottom {
	position: absolute;
}

.lineup-item.right .item-content {
	margin-right: -100px;
	margin-left: 200px;
	padding-right: 200px;
	padding-left: 400px;
	padding-bottom: 180px;
}

.lineup-item.left .item-content {
	margin-left: -200px;
	padding-right: 400px;
	padding-left: 200px;
}

.lineup-item.item-01 .item-content .type01::before {
	background-image: url("../img/ico-bottle.png");
	vertical-align: -13px;
	width: 17px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-01 .item-content .type01::before {
		background-image: url("../img/ico-bottle_sp.png");
		background-size: 13px;
		width: 13px;
	}
}

.lineup-item.item-01 .item-content .type03::before {
	background-image: url("../img/ico-tea.png");
	width: 31px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-01 .item-content .type03::before {
		background-image: url("../img/ico-tea_sp.png");
		background-size: 22px;
		width: 22px;
	}
}

.lineup-item.item-01 .item-content .type04::before {
	background-image: url("../img/ico-leaf.png");
	vertical-align: -16px;
	width: 28px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-01 .item-content .type04::before {
		background-image: url("../img/ico-leaf_sp.png");
		background-size: 22px;
		width: 22px;
	}
}

.lineup-item.item-01 .item-content .btn.bottle-bottom01 {
	left: 138px;
	top: 445px;
}

.lineup-item.item-01 .item-content .btn.bottle-bottom03 {
	left: 138px;
	top: 445px;
}

.lineup-item.item-01 .over-box-parts {
	left: 50%;
	margin-left: 700px;
	background-color: #f2f7ed;
}

.lineup-item.item-02 .item-content .type02::before {
	background-image: url("../img/ico-bottle.png");
	vertical-align: -13px;
	width: 17px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-02 .item-content .type02::before {
		background-image: url("../img/ico-bottle_sp.png");
		background-size: 13px;
		width: 13px;
	}
}

.lineup-item.item-02 .item-content .type03::before {
	background-image: url("../img/ico-tea.png");
	width: 31px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-02 .item-content .type03::before {
		background-image: url("../img/ico-tea_sp.png");
		background-size: 22px;
		width: 22px;
	}
}

.lineup-item.item-02 .item-content .type04::before {
	background-image: url("../img/ico-leaf.png");
	vertical-align: -16px;
	width: 28px;
}

@media screen and (max-width: 750px) {
	.lineup-item.item-02 .item-content .type04::before {
		background-image: url("../img/ico-leaf_sp.png");
		background-size: 22px;
		width: 22px;
	}
}

.lineup-item.item-02 .item-content .btn.bottle-bottom02 {
	right: 180px;
	bottom: 40px;
}

.lineup-item.item-02 .item-content .btn.bottle-bottom04 {
	right: 110px;
	bottom: 40px;
}

.lineup-item.item-02 .over-box-parts {
	right: 50%;
	margin-right: 700px;
	background-color: #f2f7ed;
}

.lineup-item.item-03 .figure {
	top: -110px;
	left: 170px;
}

.lineup-item.item-03 .item-content .type::before {
	background-image: url("../img/ico-tea.png");
	vertical-align: -16px;
	width: 31px;
}

.lineup-item.item-03 .item-content .btn.bottle-bottom {
	left: 138px;
	bottom: 100px;
}

.lineup-item.item-03 .over-box-parts {
	left: 50%;
	margin-left: 700px;
	background-color: #f0f2f7;
}

@media only screen and (max-width: 750px) {
	.lineup-item {
		margin-top: 6.66667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .figure {
		position: static;
		text-align: center;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .item-content {
		width: 100%;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .item-content .type {
		font-size: 24px;
		font-size: 3.2vw;
		margin-bottom: 2.66667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .item-content .type::before {
		width: 4.26667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .item-content .name {
		font-size: 40px;
		font-size: 5.33333vw;
		padding-bottom: 5.33333vw;
		margin-bottom: 5.33333vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item .item-content .btn.bottle-bottom {
		position: static;
		margin-top: 2.66667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.right .item-content {
		margin-right: 0;
		margin-left: 0;
		padding: 20vw 6.66667vw 6.66667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.left .item-content {
		margin-right: 0;
		margin-left: 0;
		padding: 17.33333vw 6.66667vw 6.66667vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.item-01 .item-content {
		margin-top: -18vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.item-02 .item-content {
		margin-top: -16vw;
		padding-top: 17.33333vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.item-03 .figure img {
		width: 110px;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.item-03 .item-content {
		margin-top: -80px;
		padding-top: 100px;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-item.item-03 .item-content .type::before {
		background-size: 23px;
		width: 23px;
		vertical-align: middle;
		background-image: url("../img/ico-tea_sp.png");
	}
}

.lineup-link-block {
	border-top: solid 1px #d2d4d9;
	margin-top: 25px;
	text-align: center;
}

.lineup-link-block .btn {
	margin: 20px auto 0;
}

.lineup-link-block02 {
	border-top: none;
	border-bottom: solid 1px #d2d4d9;
	margin-top: 50px;
	padding-bottom: 60px;
	text-align: center;
}

@media screen and (max-width: 750px) {
	.lineup-link-block02 {
		width: 86.66667vw;
		padding-bottom: 13.33333vw;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-link-block {
		text-align: center;
		margin-top: 6.66667vw;
	}
}

@media only screen and (max-width: 374px) {
	.lineup-link-block {
		font-size: 26px;
		font-size: 3.46667vw;
	}
}

.lineup-movie {
	position: relative;
}

.lineup-movie .sec-ttl {
	position: relative;
}

.lineup-movie .sec-ttl .img {
	background: url("../img/ttl_01.png") no-repeat;
	width: 400px;
	height: 400px;
	margin-left: auto;
	display: block;
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

.lineup-movie .sec-ttl .img img {
	width: 35px;
}

@media screen and (max-width: 750px) {
	.lineup-movie .sec-ttl .img img {
		width: 5.6vw;
	}
}

@media screen and (max-width: 750px) {
	.lineup-movie .sec-ttl .img {
		width: 60vw;
		height: 60vw;
		margin: 0 auto;
	}
}

.lineup-movie .sec-content {
	width: 1000px;
	margin-top: -300px;
	margin-left: -100px;
	padding: 100px 150px 50px 100px;
	background-color: #f2f7ed;
	align-items: center;
}

.lineup-movie .movie-item:first-child {
	margin-bottom: 50px;
}

@media only screen and (max-width: 750px) {
	.lineup-movie .movie-item:first-child {
		margin-bottom: 10vw;
	}
}

.lineup-movie .movie-item img {
	width: 100%;
}

.lineup-movie .movie-item .cap {
	text-align: center;
	margin-top: 20px;
}

.lineup-movie .over-box-parts {
	right: 50%;
	margin-right: 700px;
	background-color: #f2f7ed;
}

@media only screen and (max-width: 750px) {
	.lineup-movie .sec-ttl {
		text-align: center;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-movie .sec-ttl img {
		width: 225px;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-movie .sec-content {
		width: 100%;
		margin-top: -113px;
		margin-left: 0;
		margin-right: 0;
		display: block;
		padding: 150px 25px 40px;
	}
}

@media only screen and (max-width: 750px) {
	.lineup-movie .movie-item .cap {
		text-align: center;
		margin-top: 10px;
	}
}

/*************************************************************
/ page-top
/************************************************************/
.page-footer {
	position: relative;
	z-index: 5;
	background-color: #f2f2f2;
}

.page-footer > .inner {
	width: 1200px;
	margin: 0 auto 0;
}

.page-footer > .inner.flex-lay {
	align-items: center;
	justify-content: space-between;
}

.page-footer .link-block ul li {
	display: inline-block;
	vertical-align: middle;
}

.page-footer .link-block ul li + li {
	margin-left: 15px;
	padding-left: 15px;
	position: relative;
}

.page-footer .link-block ul li + li::before {
	content: '';
	display: inline-block;
	vertical-align: middle;
	width: 1px;
	height: 10px;
	background-color: #777;
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}

.page-footer .link-block ul li a {
	font-size: 1.2rem;
	display: block;
}

.page-footer .link-block ul li a img {
	vertical-align: -3px;
}

.page-footer .page-top {
	text-align: center;
	width: 76px;
	height: 76px;
}

.page-footer .page-top a {
	display: block;
	width: 100%;
	height: 100%;
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	justify-content: center;
	transition: .5s;
}

.page-footer .copy {
	font-size: 0.9rem;
}

@media only screen and (max-width: 750px) {
	.page-footer > .inner {
		width: 100%;
		margin-top: 0;
		padding: 40px 15px 30px;
		background: #F7F7F8;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer > .inner.flex-lay {
		display: block;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .link-block ul li {
		display: block;
		width: 100%;
		max-width: 400px;
		height: 50px;
		line-height: 50px;
		margin: 0 auto;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .link-block ul li + li {
		margin-left: auto;
		padding-left: 0;
		margin-top: 10px;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .link-block ul li + li::before {
		display: none;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .link-block ul li a {
		text-align: center;
		width: 100%;
		height: 100%;
		background: #fff;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .link-block ul li a .logo {
		width: 85px;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .page-top {
		margin-top: 10px;
		margin-bottom: 10px;
		margin-left: auto;
		margin-right: auto;
	}
}

@media only screen and (min-width: 751px) {
	.page-footer .page-top a:hover {
		background-color: #fff;
	}
}

@media only screen and (max-width: 750px) {
	.page-footer .copy {
		text-align: center;
	}
}

.ico-blank::after {
	content: '';
	display: inline-block;
	width: 12px;
	height: 9px;
	background-image: url("../img/ico-blank.png");
	margin-left: 5px;
}

/*************************************************************
/ ローディングアニメーション
/************************************************************/
.loadlayer {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	z-index: 100;
}

.loadlayer .mask {
	width: 1px;
	height: 70px;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	overflow: hidden;
}

.loadlayer .mask span {
	display: block;
	width: 100%;
	height: 100%;
	background-color: #017f02;
}

.loading-bar {
	-webkit-animation: loadbar 1.3s infinite;
	animation: loadbar 1.3s infinite;
}

@keyframes loadbar {
	0% {
		height: 0;
		transform: translateY(0);
	}
	50% {
		height: 100%;
		transform: translateY(0);
	}
	100% {
		transform: translateY(70px);
	}
}

.ad-wrap {
	text-align: center;
	background: #000 url("../img/ad-imgbg.png") no-repeat right top;
	background-size: contain;
}

@media screen and (max-width: 750px) {
	.ad-wrap {
		background: #000;
	}
}

.ad-wrap img {
	width: auto;
}

@media screen and (max-width: 750px) {
	.ad-wrap img {
		width: 100%;
	}
}

/*# sourceMappingURL=style.css.map */

/*# sourceMappingURL=style.css.map */
