@charset "utf-8";
/*********************************************************************
 *
 *  For ALL
 *
*********************************************************************/


@media print,
screen and (min-width: 768px) {

	/* navP */
	/* --------------------------------------------------------------------------- */
	#navP {
		display: none;
	}


	/* section */
	/* --------------------------------------------------------------------------- */
	section>.inner {
		position: relative;
		margin-left: auto;
		margin-right: auto;
		width: 980px;
	}

	section.wide>.inner {
		width: 100%;
	}

	/* pagination single */
	/* --------------------------------------------------------------------------- */
	#pagination.single {
		display: table;
		margin-bottom: 0;
		margin-left: auto;
		margin-right: auto;
	}

	#pagination.single ul {
		display: table;
		width: 680px;
	}

	#pagination.single ul li {
		display: table-cell;
		width: 33.33%;
	}

	#pagination.single ul li a {
		color: #000;
		line-height: 30px;
		transition: 0.3s ease;
	}

	#pagination.single ul li a:hover {
		opacity: 0.6;
	}

	#pagination.single .prev,
	#pagination.single .next {
		position: relative;
		display: block;
		border: 1px solid transparent;
	}

	#pagination.single .prev {
		padding-left: 40px;
		text-align: left;
	}

	#pagination.single .next {
		padding-right: 40px;
		text-align: right;
	}

	#pagination.single .prev::before,
	#pagination.single .next::before {
		content: "";
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		display: block;
		width: 30px;
		height: 30px;
		background-position: center center;
		background-color: #000;
		background-size: auto 30px;
	}

	#pagination.single .prev::before {
		left: 0;
		background-image: url(../img/ico/pagination_prev.svg);
	}

	#pagination.single .next::before {
		right: 0;
		background-image: url(../img/ico/pagination_next.svg);
	}

	#pagination.single .back {
		display: block;
		text-align: center;
		border: 1px solid #000;
	}

	#pagination.single .back span {
		position: relative;
		padding-left: 35px;
	}

	#pagination.single .back span::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		display: block;
		width: 30px;
		height: 30px;
		background-image: url(../img/ico/pagination_back.svg);
		background-position: center center;
		background-size: auto 30px;
	}

}

/* min-width: 768px */

@media screen and (max-width: 767px) {

	/* navP */
	/* --------------------------------------------------------------------------- */
	#navP {
		margin-top: 50px;
	}

	#navP .list {
		margin: 0 5%;
	}

	#navP .list li {
		margin-bottom: 8px;
	}

	#navP .list li:last-child {
		margin-bottom: 0;
	}

	#navP .list li.current {
		display: none;
	}

	#navP .list li a {
		position: relative;
		display: block;
		font-size: 1.6rem;
		text-align: center;
		line-height: 45px;
		font-weight: 600;
		border: 1px solid #000;
		background-color: #FFF;
	}

	#navP .list li a::after {
		content: "";
		position: absolute;
		width: 4px;
		height: 4px;
		right: 10px;
		top: 50%;
		transform: translateY(-50%) rotate(45deg);
		border-top: 1px solid #000;
		border-right: 1px solid #000;
	}

	/* section */
	/* --------------------------------------------------------------------------- */
	section>.inner {
		position: relative;
	}

	section.wide>.inner {}

	/* pagination single */
	/* --------------------------------------------------------------------------- */
	#pagination.single {
		margin: 0 20px 50px;
	}

	#pagination.single ul {
		position: relative;
		width: 100%;
		height: 70px;
	}

	#pagination.single ul li {
		position: absolute;
		width: 50%;
	}

	#pagination.single ul li:nth-child(1) {
		left: 0;
		bottom: 0;
	}

	#pagination.single ul li:nth-child(2) {
		left: 50%;
		top: 0;
		transform: translateX(-50%);
	}

	#pagination.single ul li:nth-child(3) {
		right: 0;
		bottom: 0;
	}

	#pagination.single ul li a {
		color: #000;
		font-size: 1.1rem;
		line-height: 30px;
	}

	#pagination.single .prev,
	#pagination.single .next {
		position: relative;
		display: block;
		border: 1px solid transparent;
	}

	#pagination.single .prev {
		padding-left: 35px;
		text-align: left;
	}

	#pagination.single .next {
		padding-right: 35px;
		text-align: right;
	}

	#pagination.single .prev::before,
	#pagination.single .next::before {
		content: "";
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		display: block;
		width: 30px;
		height: 30px;
		background-position: center center;
		background-color: #000;
		background-size: auto 30px;
	}

	#pagination.single .prev::before {
		left: 0;
		background-image: url(../img/ico/pagination_prev.svg);
	}

	#pagination.single .next::before {
		right: 0;
		background-image: url(../img/ico/pagination_next.svg);
	}

	#pagination.single .back {
		display: block;
		text-align: center;
		border: 1px solid #000;
	}

	#pagination.single .back span {
		position: relative;
		padding-left: 35px;
	}

	#pagination.single .back span::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		display: block;
		width: 30px;
		height: 30px;
		background-image: url(../img/ico/pagination_back.svg);
		background-position: center center;
		background-size: auto 30px;
	}

}

/* max-width: 767px */


.gift_banner {
	width: 750px;
	margin: 40px auto 0;
}

.gift_explanation {
	width: 550px;
    margin: 10px auto 0;
    letter-spacing: 0.05em;
    line-height: 1.8;
}

.gift_explanation.big {
	width: 100%;
	font-size: 2rem;
	text-align: center;
	position: relative;
	bottom: -60px;
}

.gift_explanation.center {
	text-align: center;
}

.gift_explanation.borderB::after {
	content: "";
	display: block;
	margin: 50px auto 0;
	width: 120px;
	height: 1px;
	background: #000;
}

.gift_explanation.big.borderB {
	bottom: 0;
}

@media print, screen and (min-width: 768px) {
	.gift_banner a {
		transition: opacity 0.3s;
	}

	.gift_banner a:hover {
		opacity: 0.6;
	}
}

@media screen and (max-width: 767px) {
	.gift_banner {
		width: 90%;
		margin: 25px auto 0;
	}
	
	.gift_explanation {
		width: 90%;
	}

	.gift_explanation.big {
		width: 90%;
		font-size: 1.6rem;
		bottom: 0;
	}

	.gift_explanation.borderB::after {
		content: "";
		display: block;
		margin: 20px auto 0;
		width: 60px;
		height: 1px;
		background: #000;
	}
}