@charset "UTF-8";
/* CSS Document */
@import url("deco.css");
/*@import url("anime.css");*/
@import url("https://fonts.googleapis.com/css?family=Poppins");
/*=====================================

	0.  Common(共通)

=====================================*/
* {
	margin: 0;
	padding: 0;
}
html {
	background: #ab2827;
	font-size: 62.5%; /*1remを16pxに設定*/
	font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-feature-settings: "palt";
	letter-spacing: 0.9px;
	color: #333;
	line-height: 1.7;
}
body {
	font-size: 16px;
}
/*1remを16pxに設定*/
/* IEだけに適応 */
_:lang(x)::-ms-backdrop, .selector {
	font-family: "Segoe UI", Meiryo, sans-serif;
}
html {
	overflow-y: scroll;
	overflow-x: hidden;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}
html {
	scroll-behavior: smooth;
}
footer {
	/* width: 100%; */
	padding: 2rem;
	background: #222;
	color: #fff;
	font-size: 0.1rem;
	text-align: center;
}
footer .company {
	font-size: 1.4rem;
	text-align: center;
	padding: 2rem 0;
}
footer .company a {
	color: #FFF;
	text-decoration: underline;
}
footer .company a:hover {
	color: red;
	text-decoration: underline;
}
footer .company a:active {
	color: #fff000;
}
footer .ftlogo {
	max-width: 1000px;
	margin: 0 auto;
}
footer .ftlogo img {
	width: 150px;
	padding-bottom: 20px;
}
.ftsns {
	margin: 0 auto;
	width: 100%;
}
.ftsns img {
	width: 60px;
	padding: 10px;
}
/*0-1 LINK設定
================================*/
a {
	color: red;
	text-decoration: none;
}
a:hover {
	color: red;
	text-decoration: none;
}
a:active {
	color: #fff000;
}
/*0-2 タグ基本設定
================================*/
ul, ol {
	list-style: none;
	margin: 0;
}
ul {
	padding: 0;
}
img {
	-ms-interpolation-mode: bicubic;
	border: 0;
	vertical-align: middle;
}
h1, h2, h3, h4, h5, h6, dl dt dd, li > ul, li > ol {
	margin: auto;
	padding: 0;
}
/*0-3 clearfix設定
================================*/
.clearfix {
	zoom: 1px;
}
.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	line-height: 0;
	visibility: hidden;
}
/*0-4 表示切り替え設定
================================*/
.pcarea {
	display: block;
}
.sparea {
	display: none;
}
@media screen and (max-width: 800px) {
	.pcarea {
		display: none;
	}
	.sparea {
		display: block;
	}
}
/*0-5 装飾・行間
================================*/
b, strong, .bold {
	font-weight: 700;
}
.center {
	text-align: center;
}
.small {
	font-size: 11px;
}
.bule {
	color: #0087da;
}
.red {
	color: crimson;
}
.bg_red {
	background: url("../images/bg_20th_red.jpg") repeat-y center;
	background-size: contain;
	/* background: #a97001; */
}
/* 選択時に文字色を変更する*/ ::selection {
	background: yellow;
	color: red;
}
/* for Firefox */ ::-moz-selection {
	background: yellow;
	color: red;
}
/*画像をレスポンシブに */
.imgres_top {
	width: auto;
}
@media screen and (max-width:768px) {
	.imgres_top {
		width: 60%;
	}
}
@media screen and (max-width:425px) {
	.imgres_top {
		width: 80%;
	}
}
.imgres {
	width: auto;
}
@media screen and (max-width:768px) {
	.imgres {
		width: 100%;
	}
}
@media screen and (max-width:425px) {
	.imgres {
		width: 100%;
	}
}
/*0-6 フォント
================================*/
.a-otf-ryumin { /*リュウミン */
	font-family: a-otf-ryumin-pr6n, serif;
	font-weight: 300;
	font-style: normal;
}
.a-centurygothic { /* センチュリーゴシック */
	font-family: century-gothic, sans-serif;
	font-weight: 400;
	font-style: normal;
}
.ta-rb { /* TA-ルビ */
	font-family: ta-rb, sans-serif;
	font-weight: 400;
	font-style: normal;
}
.ab-tombo_bold { /* AB Tombo Bold */
	font-family: ab-tombo-bold, sans-serif;
	font-weight: 400;
	font-style: normal;
}
/*0-7 テキスト配置
================================*/
.left {
	text-align: left;
}
.center {
	text-align: center;
}
.right {
	text-align: right;
}
/*0-8 youtube
================================*/
.youtube {
	width: 60%;
	aspect-ratio: 16 / 9;
	margin: 0 auto;
}
.youtube iframe {
	width: 100%;
	height: 100%;
}
.youtube_modal {
	width: 100%;
	aspect-ratio: 16 / 9;
	margin: 0 auto;
}
.youtube_modal iframe {
	width: 100%;
	height: 100%;
}
@media screen and (max-width:768px) {
	.youtube {
		width: 100%;
		aspect-ratio: 16 / 9;
		margin: 0 auto;
	}
	.youtube iframe {
		width: 100%;
		height: 100%;
	}
}
@media screen and (max-width:425px) {
	.youtube {
		width: 100%;
		aspect-ratio: 16 / 9;
		margin: 0 auto;
	}
	.youtube iframe {
		width: 100%;
		height: 100%;
	}
}
/*0-9 twitter
================================*/
.twitter_wrap {
	margin: 5rem auto 0;
	width: 100%;
	max-width: 80%;
	border: 1px #666 solid;
}
.twitter_wrap iframe {
	width: 100% !important;
}
#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 14px;
	line-height: 1;
	z-index: 99;
}
#page-top a {
	background: rgb(35 35 35 / 90%);
	text-decoration: none;
	color: #fff;
	width: 39px;
	padding: 18px 5px;
	text-align: center;
	display: block;
	border-radius: 90px;
	opacity: 1;
	transition: all .3s ease;
}
#page-top a:hover {
	text-decoration: none;
	opacity: .5;
}
/*-------------------------------------------------------
loading画面
------------------------------------------------------- */
/* Loading背景画面設定　*/
#splash {
	/*fixedで全面に固定*/
	position: fixed;
	z-index: 999;
	width: 100%;
	height: 100%;
	background: rgba(125, 97, 42, 1.00);
	text-align: center;
	color: #fff;
	font-size: 2rem;
}
/*-------------------------------------------------------
ナヴィゲーション navigation
------------------------------------------------------- */
.button_container {
	position: fixed;
	top: 5%;
	right: 2%;
	height: 30px;
	width: 50px;
	cursor: pointer;
	z-index: 100;
	transition: opacity 0.25s ease;
}
.button_container:hover {
	opacity: 0.7;
}
.button_container.active .top {
	transform: translateY(11px) translateX(0) rotate(45deg);
	background: #FFF;
}
.button_container.active .middle {
	opacity: 0;
	background: #FFF;
}
.button_container.active .bottom {
	transform: translateY(-11px) translateX(0) rotate(-45deg);
	background: #FFF;
}
.button_container span {
	background: #333;
	border: none;
	height: 5px;
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transition: all 0.35s ease;
	cursor: pointer;
}
.button_container span:nth-of-type(2) {
	top: 11px;
}
.button_container span:nth-of-type(3) {
	top: 22px;
}
.overlay {
	position: fixed;
	background: #9f1515;
	top: 0;
	left: 0;
	width: 100%;
	height: 0%;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.35s, visibility 0.35s, height 0.35s;
	overflow: hidden;
}
.overlay.open {
	opacity: 0.9;
	visibility: visible;
	height: 100%;
	z-index: 2;
}
.overlay.open li {
	-webkit-animation: fadeInRight 0.5s ease forwards;
	animation: fadeInRight 0.5s ease forwards;
	-webkit-animation-delay: 0.35s;
	animation-delay: 0.35s;
}
.overlay.open li:nth-of-type(2) {
	-webkit-animation-delay: 0.4s;
	animation-delay: 0.4s;
}
.overlay.open li:nth-of-type(3) {
	-webkit-animation-delay: 0.45s;
	animation-delay: 0.45s;
}
.overlay.open li:nth-of-type(4) {
	-webkit-animation-delay: 0.5s;
	animation-delay: 0.5s;
}
.overlay nav {
	position: relative;
	height: 70%;
	top: 50%;
	transform: translateY(-50%);
	font-size: 50px;
	font-family: "Vollkorn", serif;
	font-weight: 400;
	text-align: center;
}
.overlay ul {
	list-style: none;
	padding: 0;
	margin: 0 auto;
	display: inline-block;
	position: relative;
	height: 100%;
}
.overlay ul li {
	display: block;
	height: 25%;
	height: calc(100% / 4);
	min-height: 50px;
	position: relative;
	opacity: 0;
}
.overlay ul li a {
	display: block;
	position: relative;
	color: #FFF;
	text-decoration: none;
	overflow: hidden;
}
.overlay ul li a:hover:after, .overlay ul li a:focus:after, .overlay ul li a:active:after {
	width: 100%;
}
.overlay ul li a:after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 0%;
	transform: translateX(-50%);
	height: 3px;
	background: #FFF;
	transition: 0.35s;
}
@-webkit-keyframes fadeInRight {
	0% {
		opacity: 0;
		left: 20%;
	}
	100% {
		opacity: 1;
		left: 0;
	}
}
@keyframes fadeInRight {
	0% {
		opacity: 0;
		left: 20%;
	}
	100% {
		opacity: 1;
		left: 0;
	}
}
/*-------------------------------------------------------
　トップコンテンツ　背景
------------------------------------------------------- */
.containerParent {
	width: 100%;
	height: 100vh;
	max-height: 990px;
	position: relative;
}
.lightGray {
	width: 100%;
	height: 1000px;
	/* background: linear-gradient(to bottom, rgb(255 255 255 / 40%) 0%, rgb(233 173 173 / 0%) 50%, #ab2727 100%, rgb(171 38 39) 100%); */
	position: absolute;
	z-index: -9998;
}
.container {
	overflow: hidden;
	max-height: 1000px;
	width: 100%;
	position: absolute;
	z-index: -9999;
}
.container-background {
	perspective: 4000px;
	margin-top: -3000px;
	height: 4500px;
}
.sliding-background {
	height: 15000px;
	width: 18500px;
	background-image: url("../images/bg_20th.jpg");
	background-repeat: repeat;
	animation: slide 70s linear infinite;
	position: absolute;
	left: -1500px;
}
@keyframes slide {
	0% {
		transform: translate3d(0, 0px, 0) rotateX(45deg);
	}
	100% {
		transform: translate3d(0, -1238px, -1238px) rotateX(45deg);
	}
}
/*-------------------------------------------------------
　トップコンテンツ　中身
------------------------------------------------------- */
.hd_contents {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	text-align: center;
	z-index: 1;
}
.hd_contents_outer {
	position: relative;
	top: 470px;
}
.hd_contents_inner {
	position: relative;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
}
/* マウス型スクロールアイコン */
.scroll-downs {
	position: relative;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: 5rem auto 0 auto;
	width: 34px;
	height: 55px;
}
.mousey {
	width: 3px;
	padding: 10px 15px;
	height: 35px;
	border: 2px solid #b93131;
	border-radius: 25px;
	opacity: 0.75;
	box-sizing: content-box;
	background: #FFF;
}
.scroller {
	width: 3px;
	height: 10px;
	border-radius: 25%;
	background-color: #b93131;
	animation-name: scroll;
	animation-duration: 2.2s;
	animation-timing-function: cubic-bezier(.15, .41, .69, .94);
	animation-iteration-count: infinite;
}
@keyframes scroll {
	0% {
		opacity: 0;
	}
	10% {
		transform: translateY(0);
		opacity: 1;
	}
	100% {
		transform: translateY(15px);
		opacity: 0;
	}
}
/*-------------------------------------------------------
　トップ見出し　中身
------------------------------------------------------- */
.intro {
	width: 100%;
	margin: 0 auto;
	padding: 10rem 0 22rem 0;
	position: relative;
	top: 0;
	overflow: hidden;
}
.intro::before { /*斜め背景 */
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: #ab2827;
	transform: skewY(-5deg) translateY(-90px);
}
.intro_wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	color: #FFFFFF;
	line-height: 2;
	letter-spacing: 2px;
	z-index: 1;
	position: relative;
}
.intro p {
	width: 80%;
	margin: 5rem auto 0 auto;
	line-height: 4rem;
}
.intro h3 {
	font-size: 7rem;
	font-weight: 100;
}
.intro h4 {
	font-size: 2.5rem;
	font-weight: 100;
	padding-bottom: 2rem;
}
/*-------------------------------------------------------
 section
------------------------------------------------------- */
.about {
	width: 100%;
	background: #FFF;
}
.about_wrap {
	/*position: relative;
     width: 100%; 
    top: -265px;*/
	margin: -200px auto 0 auto;
	padding: 25rem 0 15rem 0;
	background-image:
		radial-gradient(#ffd800 30%, transparent 30%);
	background-size: 10px 10px;
	z-index: -9998;
}
.about_inner {
	max-width: 1000px;
	border: #ffd800 12px solid;
	border-radius: 10px;
	background: #FFFFFF;
	padding: 5rem 5rem;
	margin: 0 auto;
}
.about_inner h3 {
	font-size: 5rem;
	text-align: center;
}
.about_inner h4 {
	text-align: center;
}
.about_inner h5 {
	font-size: 2rem;
	text-align: center;
	line-height: 3;
}
.about_inner p {
	margin: 0 auto;
	padding: 2rem 0;
	width: 90%;
}
.about_loop_inner {}
.about_loop {}
.about_linkbtn_wrap {
	margin: 4rem auto;
	text-align: center;
}
.about_linkbtn {
	color: #333;
	background: #ffd800;
	border: #000 5px dotted;
	padding: 2rem;
	text-align: center;
	font-size: 2.6rem;
	font-weight: 700;
}
.about_linkbtn:hover {
	color: #333;
	background: #ff9900;
}
/*-------------------------------------------------------
 message
------------------------------------------------------- */
.message {
	width: 100%;
	margin: 0 auto;
	padding: 10rem 0;
	position: relative;
	top: 0;
	overflow: hidden;
}
.message_wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 0;
	text-align: center;
	color: #333;
	line-height: 2;
	letter-spacing: 2px;
	background: #FFFFFF;
	border-radius: 3rem;
}
.message_innner {
	position: relative;
	top: 0;
}
.message_innner h3 {
	font-size: 5rem;
	font-family: a-otf-ryumin-pr6n, serif;
	text-align: center;
}
.message_innner h4 {
	font-size: 1.8rem;
	font-family: century-gothic, sans-serif;
	text-align: center;
}
.message_innner p {
	margin: 0 auto;
	padding: 2rem;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.8;
	max-width: 940px;
}
.message_youtube {
	width: 100%;
	margin: 3rem auto 0 auto;
}
.message_linkbtn_wrap {
	margin: 6rem auto;
	text-align: center;
	background: #ba0f1d;
	color: #FFF;
}
.message_linkbtn_wrap a {
	color: #FFF;
}
.message_linkbtn {
	/* width: 50%; */
	color: #FFF;
	padding: 2rem 3rem;
	margin: 6rem auto;
	text-align: center;
	font-size: 4rem;
	font-weight: 700;
}
/* お祝いの言葉　リスト　*/
.message_list {
	width: 100%;
	/* max-width: 1200px; */
	margin: 1rem auto;
}
.message_list .innner {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.message_list .innner .mlist {
	width: 23%;
	padding: 1rem;
}
.message_list .innner .mlist p {
	padding: 1rem;
}
.message_list .innner .mlist p img {
	width: 100%;
}
.message_list_modalwindow {}
.message_list_modalwindow h2 {
	background: #c40100;
	color: #FFF;
	padding: 0.5rem 0;
	margin: 0 0 1rem 0;
}
.message_list_modalwindow h3 {
	padding: 1rem 0;
	margin: 0 auto;
}
.message_list_modalwindow_imgarea {
	margin: 1rem auto;
}
.message_list_modalwindow_imgarea img {
	width: 100%;
}
.message_list_modalwindow_textarea {
	line-height: 1.8;
	text-align: left;
	background: #fff5ce;
	padding: 2rem;
	border-radius: 1rem;
}
/*-------------------------------------------------------
 history
------------------------------------------------------- */
.history {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	position: relative;
	top: 0;
	overflow: hidden;
}
.history_wrap {
	max-width: 1200px;
	margin: 0 auto 10rem auto;
	padding: 0;
	text-align: center;
	color: #333333;
	line-height: 2;
	letter-spacing: 2px;
	background: #FFF;
	border-radius: 3rem;
}
.history_innner {
	position: relative;
	top: 0;
	padding: 0 0 3rem 0;
}
.history_innner h3 {
	font-size: 5rem;
	font-family: a-otf-ryumin-pr6n, serif;
	text-align: center;
}
.history_innner h4 {
	font-size: 1.8rem;
	font-family: century-gothic, sans-serif;
	text-align: center;
}
.history_innner p {
	margin: 2rem 0;
}
.history_innner_hashtag {
	border: 1px #fff solid;
	padding: 1rem;
	margin: 0 auto;
	font-size: 5rem;
	text-align: center;
	width: 60%;
	max-width: 650px;
	background: #FFF;
	color: #ab2827;
	line-height: 1.6;
}
.history_innner_hashtag span {
	font-size: 1.2rem;
	line-height: 1.6;
}
.history_imagearea {
	display: flex;
	padding: 2rem;
	justify-content: space-around;
	flex-wrap: nowrap;
	align-items: center;
}
.history_linkbtn_area {
	display: flex;
	width: 80%;
	justify-content: space-evenly;
	flex-wrap: nowrap;
	align-items: center;
}
.history_timeline {
	width: 90%;
	margin: 0 auto;
	padding: 10rem 0 22rem 0;
	position: relative;
	top: 0;
	overflow: hidden;
	background-color: #ab2827;
}
.history_timeline_wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
	/* text-align: center; */
	color: #FFFFFF;
	line-height: 2;
	letter-spacing: 2px;
	z-index: 1;
	position: relative;
	/* border-bottom: 2px solid #FFFFFF; */
}
.history_timeline p {
	width: 90%;
	margin: 0 auto;
	/* line-height: 4rem; */
	padding: 2rem 0;
}
.history_timeline h3 {
	font-size: 7rem;
	font-weight: 100;
}
.history_timeline h4 {
	font-size: 5vw;
	font-weight: 500;
	padding-bottom: 2rem;
}
.history_timeline h5 {
	font-size: 3vw;
	font-weight: 500;
	padding-bottom: 2rem;
}
.horizontal-list {
	display: flex;
	margin: 1rem auto 10rem auto;
	overflow-x: auto;
	white-space: nowrap;
	-webkit-overflow-scrolling: touch;
	justify-content: space-around;
	align-items: flex-start;
	flex-wrap: nowrap;
	flex-direction: row;
}
.horizontal-list ul {
	width: 90%;
}
.horizontal-list .item {
	list-style: none;
	display: inline-block;
	width: 32%;
	margin: 0 2rem;
}
.horizontal-list .scroll {
	border: 1px solid #9f1515;
	background: #9f1515;
	font-size: 12px;
	height: fit-content;
	margin: 0 auto;
	overflow: auto;
	width: 100%;
}
.horizontal-list .scroll::-webkit-scrollbar {
	width: 7px;
}
.horizontal-list .scroll::-webkit-scrollbar-thumb {
	background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #9f1515), to(#9f1515));
	background: linear-gradient(to bottom, #ca2f2f 50%, #ca2f2f);
	border-radius: 5px;
}
.horizontal-list .scroll::-webkit-scrollbar-track {
	background: #e57373;
}
/*-------------------------------------------------------
 campaign
------------------------------------------------------- */
.campaign {
	width: 100%;
	background: #ab2827;
	margin: 0 auto;
	padding: 10rem 0;
	position: relative;
	top: 0;
	overflow: hidden;
}
.campaign_wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	color: #FFFFFF;
	line-height: 2;
	letter-spacing: 2px;
}
.campaign_innner {
	position: relative;
	top: 0;
}
.campaign_innner h3 {
	font-size: 5rem;
	font-family: a-otf-ryumin-pr6n, serif;
	text-align: center;
}
.campaign_innner h4 {
	font-size: 1.8rem;
	font-family: century-gothic, sans-serif;
	text-align: center;
	margin-bottom: 5rem;
}
.campaign_innner p {
	margin: 2rem 0;
}
.campaign_flow {
	background: #FFF;
	border-radius: 10px;
	max-width: 1000px;
	margin: 5rem auto;
	padding: 5rem;
	color: #333;
}
.campaign_flow h1 {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.8;
}
.campaign_rule {}
.campaign_rule dl {
	text-align: left;
	font-weight: 700;
}
.campaign_rule dt {
	text-align: left;
}
.campaign_rule dd {
	text-align: left;
	font-weight: normal;
	margin-bottom: 2rem;
}
.campaign_regulation ul, ol {
	text-align: left;
	/*背景色*/
	padding: 0.5em 0.5em 0.5em 2em; /*ボックス内の余白*/
}
.campaign_regulation ul li, ol li {
	color: #555;
	list-style: disc;
	text-align: left;
	font-weight: normal;
	font-size: 1.5rem;
	line-height: 1.2; /*文の行高*/
	padding: 0.5em 0; /*前後の文との余白*/
}
.campaign_regulation a {
	color: chocolate;
	text-decoration: underline;
}
.campaign_bnrarea {
	/* padding-bottom: 5rem; */
}
.campaign_bnrarea img {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}
.arrow {
	margin: 3rem auto;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 60px 75px 0 75px;
	border-color: #a97001 transparent transparent transparent;
}
.ribbon {
	width: 30%;
	display: inline-block;
	position: relative;
	height: 64px;
	line-height: 60px;
	text-align: center;
	margin: 0 0 3rem 0;
	padding: 7px 0;
	font-size: 2.8rem; /*フォントサイズ*/
	background: #f00; /*背景色*/
	color: #FFF; /*文字色*/
	box-sizing: border-box;
}
.ribbon h3 {
	margin: 0;
	padding: 0 30px;
	border-top: solid 2px #f9c700; /*上の破線*/
	border-bottom: solid 2px #f9c700; /*下の破線*/
	line-height: 45px;
	font-family: a-otf-ryumin-pr6n, serif;
	font-weight: 700;
	font-style: normal;
}
.ribbon:before, .ribbon:after {
	position: absolute;
	content: '';
	width: 0px;
	height: 0px;
	z-index: 1;
}
.ribbon:before {
	/*左端の山形*/
	top: 0;
	left: 0;
	border-width: 30px 0px 30px 15px;
	border-color: transparent transparent transparent #fff;
	border-style: solid;
}
.ribbon:after {
	/*右端の山形*/
	top: 0;
	right: 0;
	border-width: 30px 15px 30px 0px;
	border-color: transparent #fff transparent transparent;
	border-style: solid;
}
.ribbon_en {
	width: 50%;
	display: inline-block;
	position: relative;
	height: 64px;
	line-height: 60px;
	text-align: center;
	margin: 0 0 3rem 0;
	padding: 7px 0;
	font-size: 2.8rem; /*フォントサイズ*/
	background: #f00; /*背景色*/
	color: #FFF; /*文字色*/
	box-sizing: border-box;
}
.ribbon_en h3 {
	margin: 0;
	padding: 0 30px;
	border-top: solid 2px #f9c700; /*上の破線*/
	border-bottom: solid 2px #f9c700; /*下の破線*/
	line-height: 45px;
	font-family: a-otf-ryumin-pr6n, serif;
	font-weight: 700;
	font-style: normal;
}
.ribbon_en:before, .ribbon_en:after {
	position: absolute;
	content: '';
	width: 0px;
	height: 0px;
	z-index: 1;
}
.ribbon_en:before {
	/*左端の山形*/
	top: 0;
	left: 0;
	border-width: 30px 0px 30px 15px;
	border-color: transparent transparent transparent #fff;
	border-style: solid;
}
.ribbon_en:after {
	/*右端の山形*/
	top: 0;
	right: 0;
	border-width: 30px 15px 30px 0px;
	border-color: transparent #fff transparent transparent;
	border-style: solid;
}
.campaign_step {
	margin: 3rem auto;
}
.campaign_step_inner {
	margin: 0 auto 2rem auto;
	padding: 1rem 0 3rem 0;
	border: 1px solid #a97001;
}
.campaign_step h3 {
	width: 25%;
	background: #a97001;
	margin: 1rem auto;
	padding: 0.3rem 0;
	color: #fff;
	border-radius: 0.5rem;
}
.campaign_step_inner_textarea {
	font-weight: 700;
	padding: 2rem;
	font-size: 3rem;
}
.campaign_btn {
	margin: 1rem auto;
	text-align: center;
}
.campaign_btn a {
	color: #FFF;
}
.campaign_btn_twi {
	margin: 1rem auto;
	width: 40%;
	padding: 1rem 2rem;
	background: #1B80D0;
	color: #FFF;
	border: 2px solid #1b80d0;
	border-radius: 3rem;
	font-size: 2.8rem;
}
.campaign_btn_insta {
	margin: 1rem auto;
	width: 42%;
	padding: 1rem 2rem;
	background: #DA07A5;
	color: #FFF;
	border: 2px solid #DA07A5;
	border-radius: 3rem;
	font-size: 2.8rem;
}
/* タブレット用レイアウト 768px以上の範囲に収めるデザインはこの中に記述 ipad縦を想定しています。 */
@media screen and (max-width: 768px) {
	/*===ここから===========================================================================================================*/
	/*-------------------------------------------------------
     トップコンテンツ　中身
    ------------------------------------------------------- */
	.hd_contents {
		width: 100%;
		max-width: 1200px;
		margin: 0 auto;
		text-align: center;
		z-index: 1;
	}
	.hd_contents_outer {
		position: relative;
		top: 470px;
	}
	.hd_contents_inner {
		position: relative;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
	}
	/*-------------------------------------------------------
     トップ見出し　中身
    ------------------------------------------------------- */
	.intro {
		width: 100%;
		margin: 0 auto;
		padding: 8rem 0 22rem 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.intro::before { /*斜め背景 */
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		background-color: #ab2827;
		transform: skewY(-5deg) translateY(-90px);
	}
	.intro_wrap {
		max-width: 1200px;
		margin: 0 auto;
		padding: 0;
		text-align: center;
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 2px;
		z-index: 2;
		position: relative;
	}
	.intro p {
		width: 90%;
		margin: 0 auto;
		line-height: 3.6rem;
	}
	.intro h3 {
		font-size: 5rem;
		font-weight: 100;
	}
	.intro h4 {
		font-size: 2.5rem;
		font-weight: 100;
		padding-bottom: 2rem;
	}
	/*-------------------------------------------------------
     section
    ------------------------------------------------------- */
	.about {
		width: 100%;
	}
	.about_wrap {
		/*position: relative;
     width: 100%; 
    top: -265px;*/
		margin: -240px auto 0 auto;
		padding: 28rem 0 10rem 0;
		background-image:
			radial-gradient(#ffd800 30%, transparent 30%);
		background-size: 10px 10px;
		z-index: -9998;
	}
	.about_inner {
		width: 70%;
		border: #ffd800 12px solid;
		border-radius: 10px;
		background: #FFFFFF;
		padding: 5rem 5rem;
		margin: 0 auto;
	}
	.about_inner h3 {
		font-size: 4rem;
		text-align: center;
	}
	.about_inner h4 {
		text-align: center;
	}
	.about_inner h5 {
		font-size: 1.6rem;
		text-align: center;
		line-height: 2;
	}
	.about_inner p {
		margin: 0 auto;
		padding: 0;
		width: 90%;
	}
	.about_linkbtn_wrap {
		margin: 4rem auto;
		text-align: center;
	}
	.about_linkbtn {
		color: #333;
		background: #ffd800;
		border: #000 5px dotted;
		padding: 2rem 3.2rem;
		text-align: center;
		font-size: 2rem;
		font-weight: 700;
	}
	.about_linkbtn:hover {
		color: #333;
		background: #ff9900;
	}
	/*-------------------------------------------------------
     message
    ------------------------------------------------------- */
	.message {
		width: 100%;
		margin: 0 auto;
		padding: 10rem 0 0 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.message_wrap {
		max-width: 90%;
		margin: 0 auto;
		padding: 0;
		text-align: center;
		color: #333;
		line-height: 2;
		letter-spacing: 2px;
	}
	.message_innner {
		position: relative;
		top: 0;
	}
	.message_innner h3 {
		font-size: 4.5rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
	}
	.message_innner h4 {
		font-size: 1.8rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.message_innner p {
		margin: 0 auto;
		line-height: 1.6;
		padding: 2rem;
		font-size: 1.8rem;
	}
	.message_youtube {
		width: 100%;
		margin: 3rem auto 0 auto;
	}
	.message_linkbtn_wrap {
		margin: 6rem auto;
		text-align: center;
	}
	.message_linkbtn {
		width: 90%;
		/* color: #000; */
		/* background: #f9b800; */
		/* border: #000 1px solid; */
		padding: 2rem;
		margin: 3rem auto;
		text-align: center;
		font-size: 2.3rem;
		font-weight: 700;
	}
	/* お祝いの言葉　リスト　*/
	.message_list {
		width: 90%;
		margin: 0 auto;
		padding: 0 0 2rem 0;
	}
	.message_list .innner {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}
	.message_list .innner .mlist {
		width: 27%;
		padding: 1rem;
	}
	.message_list .innner .mlist p {
		padding: 0.5rem 1rem;
	}
	.message_list .innner .mlist p img {
		width: 100%;
	}
	/*-------------------------------------------------------
	 history
	------------------------------------------------------- */
	.history {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.history_wrap {
		max-width: 1200px;
		margin: 0 auto 10rem auto;
		padding: 5rem 0 10rem 0;
		text-align: center;
		color: #333333;
		line-height: 2;
		letter-spacing: 2px;
		background: #FFF;
		border-radius: 3rem;
	}
	.history_innner {
		position: relative;
		top: 0;
		padding: 0 0 3rem 0;
	}
	.history_innner h3 {
		font-size: 5rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
	}
	.history_innner h4 {
		font-size: 1.8rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.history_innner p {
		margin: 2rem 0;
	}
	.history_innner_hashtag {
		border: 1px #fff solid;
		padding: 1rem;
		margin: 0 auto;
		font-size: 5rem;
		text-align: center;
		width: 60%;
		max-width: 650px;
		background: #FFF;
		color: #ab2827;
		line-height: 1.6;
	}
	.history_innner_hashtag span {
		font-size: 1.2rem;
		line-height: 1.6;
	}
	.history_imagearea {
		display: flex;
		padding: 2rem;
		justify-content: space-around;
		flex-wrap: nowrap;
		align-items: center;
	}
	.history_linkbtn_area {
		display: flex;
		width: 80%;
		justify-content: space-evenly;
		flex-wrap: nowrap;
		align-items: center;
	}
	.history_timeline {
		width: 90%;
		margin: 0 auto;
		padding: 10rem 0 22rem 0;
		position: relative;
		top: 0;
		overflow: hidden;
		background-color: #ab2827;
	}
	.history_timeline_wrap {
		margin: 0 auto;
		padding: 0;
		/* text-align: center; */
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 2px;
		z-index: 1;
		position: relative;
		/* border-bottom: 2px solid #FFFFFF; */
	}
	.history_timeline p {
		width: 100%;
		margin: 0 auto;
		/* line-height: 4rem; */
		padding: 2rem 0;
	}
	.history_timeline h3 {
		font-size: 4rem;
		font-weight: 100;
	}
	.history_timeline h4 {
		font-size: 5vw;
		font-weight: 500;
		padding-bottom: 2rem;
	}
	.history_timeline h5 {
		font-size: 3vw;
		font-weight: 500;
		padding-bottom: 2rem;
	}
	.horizontal-list {
		display: flex;
		margin: 1rem auto 10rem auto;
		overflow-x: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
		flex-direction: row;
		justify-content: space-around;
		align-items: flex-start;
		flex-wrap: nowrap;
	}
	.horizontal-list ul {
		width: 100%;
	}
	.horizontal-list .item {
		list-style: none;
		display: inline-block;
		width: 45%;
		margin: 0 1rem;
	}
	.horizontal-list .scroll {
		border: 1px solid #9f1515;
		background: #9f1515;
		font-size: 12px;
		height: fit-content;
		margin: 0 auto;
		overflow: auto;
		width: 100%;
	}
	.horizontal-list .scroll::-webkit-scrollbar {
		width: 7px;
	}
	.horizontal-list .scroll::-webkit-scrollbar-thumb {
		background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #9f1515), to(#9f1515));
		background: linear-gradient(to bottom, #ca2f2f 50%, #ca2f2f);
		border-radius: 5px;
	}
	.horizontal-list .scroll::-webkit-scrollbar-track {
		background: #e57373;
	}
	/*-------------------------------------------------------
     campaign
    ------------------------------------------------------- */
	.campaign {
		width: 100%;
		background: #ab2827;
		margin: 0 auto;
		padding: 10rem 0 5rem auto;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.campaign_wrap {
		max-width: 1200px;
		margin: 0 auto;
		padding: 0;
		text-align: center;
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 1;
	}
	.campaign_innner_in {
		width: 100%;
		background: #FFF;
		margin: 0 auto;
		padding: 1rem 0;
		color: #333;
		border-radius: 1rem;
	}
	.campaign_innner {
		position: relative;
		top: 0;
	}
	.campaign_innner h3 {
		font-size: 4.5rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
	}
	.campaign_innner h4 {
		font-size: 1.8rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.campaign_innner p {
		margin: 2rem 0;
	}
	.campaign_flow {
		background: #FFF;
		border-radius: 10px;
		width: 80%;
		margin: 0 auto 5rem auto;
		padding: 2rem;
		color: #333;
	}
	.campaign_flow h1 {
		font-size: 1.8rem;
		font-weight: 700;
		line-height: 1.8;
	}
	.campaign_rule {}
	.campaign_rule dl {
		text-align: left;
		font-weight: 700;
	}
	.campaign_rule dt {
		text-align: left;
	}
	.campaign_rule dd {
		text-align: left;
		font-weight: normal;
		margin-bottom: 2rem;
	}
	.campaign_regulation h3 {
		font-size: 1.6rem;
	}
	.campaign_regulation ul, ol {
		text-align: left;
		/*背景色*/
		padding: 1rem 1rem 1rem 2rem; /*ボックス内の余白*/
	}
	.campaign_regulation ul li, ol li {
		color: #555;
		list-style: disc;
		text-align: left;
		font-weight: normal;
		font-size: 1rem;
		line-height: 1.2; /*文の行高*/
		padding: 0.5em 0; /*前後の文との余白*/
	}
	.campaign_regulation a {
		color: chocolate;
		text-decoration: underline;
	}
	.campaign_bnrarea {
		padding-bottom: 5rem;
	}
	.campaign_bnrarea img {
		width: 85%;
	}
	.arrow {
		margin: 3rem auto;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 60px 75px 0 75px;
		border-color: #a97001 transparent transparent transparent;
	}
	.ribbon {
		width: 30%;
		display: inline-block;
		position: relative;
		height: 64px;
		line-height: 60px;
		text-align: center;
		margin: 0 0 3rem 0;
		padding: 7px 0;
		font-size: 1.4rem; /*フォントサイズ*/
		background: #f00; /*背景色*/
		color: #FFF; /*文字色*/
		box-sizing: border-box;
	}
	.ribbon h3 {
		margin: 0;
		padding: 0 30px;
		border-top: solid 2px #f9c700; /*上の破線*/
		border-bottom: solid 2px #f9c700; /*下の破線*/
		line-height: 45px;
		font-family: a-otf-ryumin-pr6n, serif;
		font-weight: 700;
		font-style: normal;
	}
	.ribbon:before, .ribbon:after {
		position: absolute;
		content: '';
		width: 0px;
		height: 0px;
		z-index: 1;
	}
	.ribbon:before {
		/*左端の山形*/
		top: 0;
		left: 0;
		border-width: 30px 0px 30px 15px;
		border-color: transparent transparent transparent #fff;
		border-style: solid;
	}
	.ribbon:after {
		/*右端の山形*/
		top: 0;
		right: 0;
		border-width: 30px 15px 30px 0px;
		border-color: transparent #fff transparent transparent;
		border-style: solid;
	}
	.ribbon_en {
		width: 100%;
		display: inline-block;
		position: relative;
		height: 64px;
		line-height: 35px;
		text-align: center;
		margin: 0 0 2rem 0;
		padding: 7px 0;
		font-size: 1.4rem; /*フォントサイズ*/
		background: #f00; /*背景色*/
		color: #FFF; /*文字色*/
		box-sizing: border-box;
	}
	.ribbon_en h3 {
		margin: 0;
		padding: 0px 15px;
		border-top: solid 2px #f9c700; /*上の破線*/
		border-bottom: solid 2px #f9c700; /*下の破線*/
		line-height: 45px;
		font-family: a-otf-ryumin-pr6n, serif;
		font-weight: 700;
		font-style: normal;
	}
	.ribbon_en:before, .ribbon_en:after {
		position: absolute;
		content: '';
		width: 0px;
		height: 0px;
		z-index: 1;
	}
	.ribbon_en:before {
		/*左端の山形*/
		top: 0;
		left: 0;
		border-width: 30px 0px 30px 15px;
		border-color: transparent transparent transparent #fff;
		border-style: solid;
	}
	.ribbon_en:after {
		/*右端の山形*/
		top: 0;
		right: 0;
		border-width: 30px 15px 30px 0px;
		border-color: transparent #fff transparent transparent;
		border-style: solid;
	}
	.campaign_step {
		margin: 3rem auto;
	}
	.campaign_step_inner {
		margin: 0 auto 2rem auto;
		padding: 1rem 0 2rem 0;
		border: 1px solid #a97001;
	}
	.campaign_step h3 {
		width: 25%;
		background: #a97001;
		margin: 1rem auto;
		padding: 0.3rem 0;
		color: #fff;
		border-radius: 0.5rem;
	}
	.campaign_step_inner_textarea {
		font-weight: 700;
		padding: 1rem;
		font-size: 2rem;
	}
	.campaign_btn {
		margin: 1rem auto;
	}
	.campaign_btn_twi {
		width: 90%;
		padding: 1rem;
		background: #1B80D0;
		color: #FFF;
		border: 2px solid #1b80d0;
		font-size: 2rem;
	}
	.campaign_btn_twi:hover {
		color: #1B80D0;
		background: #ffffff;
		border: 2px solid #1b80d0;
	}
	.campaign_btn_insta {
		width: 90%;
		padding: 1rem;
		background: #DA07A5;
		color: #FFF;
		border: 2px solid #DA07A5;
		font-size: 2rem;
	}
	.campaign_btn_insta:hover {
		color: #DA07A5;
		background: #ffffff;
		border: 2px solid #DA07A5;
	}
}
/* スマホ用レイアウト 425px以下の範囲に収めるデザインはこの中に記述 iphoneを想定しています。 */
@media screen and (max-width:425px) {
	/*===ここから===========================================================================================================*/
	body {
		font-size: 1.6rem;
	}
	/*0-9 twitter
  ================================*/
	.twitter_wrap {
		margin: 0 auto;
		width: 100%;
		max-width: 85%;
		border: 1px #666 solid;
	}
	.twitter_wrap iframe {
		width: 100% !important;
	}
	footer {
		width: 100%;
		padding: 2rem 0;
		background: #222;
		color: #fff;
		font-size: 1.4rem;
		text-align: center;
	}
	footer .company {
		font-size: 1.4rem;
		text-align: center;
		padding: 2rem 0;
	}
	footer .company a {
		color: #FFF;
		text-decoration: underline;
	}
	footer .company a:hover {
		color: red;
		text-decoration: underline;
	}
	footer .company a:active {
		color: #fff000;
	}
	footer .ftlogo {
		max-width: 1000px;
		margin: 0 auto;
	}
	footer .ftlogo img {
		width: 150px;
		padding-bottom: 20px;
	}
	.ftsns {
		margin: 0 auto;
		width: 100%;
	}
	.ftsns img {
		width: 40px;
		padding: 10px;
	}
	/*-------------------------------------------------------
    ナヴィゲーション navigation
    ------------------------------------------------------- */
	.button_container {
		position: fixed;
		top: 5%;
		right: 2%;
		height: 30px;
		width: 50px;
		cursor: pointer;
		z-index: 100;
		transition: opacity 0.25s ease;
	}
	.button_container:hover {
		opacity: 0.7;
	}
	.button_container.active .top {
		transform: translateY(11px) translateX(0) rotate(45deg);
		background: #FFF;
	}
	.button_container.active .middle {
		opacity: 0;
		background: #FFF;
	}
	.button_container.active .bottom {
		transform: translateY(-11px) translateX(0) rotate(-45deg);
		background: #FFF;
	}
	.button_container span {
		background: #dfff3b;
		border: none;
		height: 5px;
		width: 100%;
		position: absolute;
		top: 0;
		left: 0;
		transition: all 0.35s ease;
		cursor: pointer;
	}
	.button_container span:nth-of-type(2) {
		top: 11px;
	}
	.button_container span:nth-of-type(3) {
		top: 22px;
	}
	.overlay {
		position: fixed;
		background: #9f1515;
		top: 0;
		left: 0;
		width: 100%;
		height: 0%;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.35s, visibility 0.35s, height 0.35s;
		overflow: hidden;
	}
	.overlay.open {
		opacity: 0.8;
		visibility: visible;
		height: 100%;
		z-index: 2;
	}
	.overlay.open li {
		-webkit-animation: fadeInRight 0.5s ease forwards;
		animation: fadeInRight 0.5s ease forwards;
		-webkit-animation-delay: 0.35s;
		animation-delay: 0.35s;
	}
	.overlay.open li:nth-of-type(2) {
		-webkit-animation-delay: 0.4s;
		animation-delay: 0.4s;
	}
	.overlay.open li:nth-of-type(3) {
		-webkit-animation-delay: 0.45s;
		animation-delay: 0.45s;
	}
	.overlay.open li:nth-of-type(4) {
		-webkit-animation-delay: 0.5s;
		animation-delay: 0.5s;
	}
	.overlay nav {
		position: relative;
		height: 70%;
		top: 50%;
		transform: translateY(-50%);
		font-size: 25px;
		font-family: "Vollkorn", serif;
		font-weight: 400;
		text-align: center;
	}
	.overlay ul {
		list-style: none;
		padding: 0;
		margin: 0 auto;
		display: inline-block;
		position: relative;
		height: 100%;
	}
	.overlay ul li {
		display: block;
		height: 25%;
		height: calc(100% /);
		min-height: 50px;
		position: relative;
		opacity: 0;
	}
	.overlay ul li a {
		display: block;
		position: relative;
		color: #FFF;
		text-decoration: none;
		overflow: hidden;
	}
	.overlay ul li a:hover:after, .overlay ul li a:focus:after, .overlay ul li a:active:after {
		width: 100%;
	}
	.overlay ul li a:after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 50%;
		width: 0%;
		transform: translateX(-50%);
		height: 3px;
		background: #FFF;
		transition: 0.35s;
	}
	@-webkit-keyframes fadeInRight {
		0% {
			opacity: 0;
			left: 20%;
		}
		100% {
			opacity: 1;
			left: 0;
		}
	}
	@keyframes fadeInRight {
		0% {
			opacity: 0;
			left: 20%;
		}
		100% {
			opacity: 1;
			left: 0;
		}
	}
	/*-------------------------------------------------------
     トップコンテンツ　中身
    ------------------------------------------------------- */
	.hd_contents {
		width: 100%;
		max-width: 1200px;
		margin: 0 auto;
		text-align: center;
		z-index: 1;
	}
	.hd_contents_outer {
		position: relative;
		top: 35rem;
	}
	.hd_contents_inner {
		position: relative;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%);
	}
	/*-------------------------------------------------------
     トップ見出し　中身
    ------------------------------------------------------- */
	.intro {
		width: 100%;
		margin: 0 auto;
		padding: 8rem 0 18rem 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.intro::before { /*斜め背景 */
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		background-color: #ab2827;
		transform: skewY(-5deg) translateY(-90px);
	}
	.intro_wrap {
		max-width: 1200px;
		margin: 0 auto;
		padding: 0 1rem;
		text-align: center;
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 2px;
		z-index: 1;
		position: relative;
	}
	.intro p {
		width: 90%;
		margin: 2rem auto;
		font-size: 1.2rem;
		line-height: 2.6rem;
	}
	.intro h3 {
		font-size: 2.8rem;
		font-weight: 100;
	}
	.intro h4 {
		font-size: 1.8rem;
		font-weight: 100;
		padding-bottom: 0rem;
	}
	/*-------------------------------------------------------
     section
    ------------------------------------------------------- */
	.about {
		width: 100%;
		background: #FFF;
	}
	.about_wrap {
		/*position: relative;
     width: 100%; 
    top: -265px;*/
		margin: -190px auto 0 auto;
		padding: 18rem 0 5rem 0;
		background-image:
			radial-gradient(#ffd800 30%, transparent 30%);
		background-size: 10px 10px;
		z-index: -9998;
	}
	.about_inner {
		width: 80%;
		border: #FFD807 5px solid;
		border-radius: 5px;
		background: #FFFFFF;
		padding: 1rem;
		margin: 0 auto;
	}
	.about_inner h3 {
		font-size: 2rem;
		text-align: center;
	}
	.about_inner h4 {
		text-align: center;
	}
	.about_inner h5 {
		font-size: 1.2rem;
		text-align: left;
		line-height: 1.6;
		margin: 2rem auto;
	}
	.about_inner p {
		margin: 0 auto;
		padding: 0;
		width: 90%;
		font-size: 0.8rem;
		line-height: 1.6;
	}
	.about_linkbtn_wrap {
		margin: 2rem auto;
		text-align: center;
	}
	.about_linkbtn {
		color: #333;
		background: #ffd800;
		border: #000 2px dotted;
		padding: 1rem;
		text-align: center;
		font-size: 1.4rem;
		font-weight: 700;
		width: 90%;
	}
	.about_linkbtn:hover {
		color: #333;
		background: #ff9900;
	}
	/*-------------------------------------------------------
     message
    ------------------------------------------------------- */
	.message {
		width: 100%;
		margin: 0 auto;
		padding: 5rem 0 0 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.message_wrap {
		max-width: 90%;
		margin: 0 auto;
		padding: 3rem 0;
		text-align: center;
		color: #333;
		line-height: 2;
		letter-spacing: 2px;
		border-radius: 1rem;
	}
	.message_innner {
		position: relative;
		top: 0;
	}
	.message_innner h3 {
		font-size: 2rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
		font-weight: 700;
	}
	.message_innner h4 {
		font-size: 1rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.message_innner p {
		margin: 0 auto;
		line-height: 1.6;
		padding: 2rem 0;
		font-size: 1.4rem;
		width: 90%;
	}
	.message_youtube {
		width: 100%;
		margin: 3rem auto 0 auto;
	}
	.message_linkbtn_wrap {
		margin: 6rem auto;
		text-align: center;
	}
	.message_linkbtn {
		color: #FFF;
		/* background: #ba0f1d; */
		padding: 2rem 1rem;
		margin: 3rem auto;
		text-align: center;
		font-size: 1.6rem;
		font-weight: 700;
		width: 100%;
	}
	/* お祝いの言葉　リスト　*/
	.message_list {
		width: 100%;
		margin: 0 auto;
		padding: 0 0 2rem 0;
	}
	.message_list .innner {
		width: 100%;
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-around;
	}
	.message_list .innner .mlist {
		width: 40%;
		padding: 1rem;
	}
	.message_list .innner .mlist p {
		padding: 0 0 1rem 0;
		line-height: 1.2;
		font-size: 1.2rem;
		text-align: center;
	}
	.message_list .innner .mlist p img {
		width: 100%;
	}
	/*-------------------------------------------------------
	 history
	------------------------------------------------------- */
	.history {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.history_wrap {
		max-width: 1200px;
		width: 90%;
		margin: 5rem auto 10rem auto;
		padding: 0rem 0 10rem 0;
		text-align: center;
		color: #333333;
		line-height: 2;
		letter-spacing: 2px;
		background: #FFF;
		border-radius: 1rem;
	}
	.history_innner {
		position: relative;
		top: 0;
		padding: 3rem 0;
	}
	.history_innner h3 {
		font-size: 2rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
	}
	.history_innner h4 {
		font-size: 1.8rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.history_innner p {
		margin: 2rem 0;
	}
	.history_innner_hashtag {
		border: 1px #fff solid;
		padding: 1rem;
		margin: 0 auto;
		font-size: 2rem;
		text-align: center;
		width: 60%;
		max-width: 650px;
		background: #FFF;
		color: #ab2827;
		line-height: 1.6;
	}
	.history_innner_hashtag span {
		font-size: 1.2rem;
		line-height: 1.6;
	}
	.history_imagearea {
		display: flex;
		padding: 2rem;
		justify-content: space-around;
		flex-wrap: nowrap;
		align-items: center;
		flex-direction: column;
	}
	.history_linkbtn_area {
		display: flex;
		width: 80%;
		justify-content: space-evenly;
		flex-wrap: nowrap;
		align-items: center;
		flex-direction: column;
	}
	.history_timeline {
		width: 90%;
		margin: 0 auto;
		padding: 10rem 0 22rem 0;
		position: relative;
		top: 0;
		overflow: hidden;
		background-color: #ab2827;
	}
	.history_timeline_wrap {
		margin: 0 auto;
		padding: 0;
		/* text-align: center; */
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 2px;
		z-index: 1;
		position: relative;
		/* border-bottom: 2px solid #FFFFFF; */
	}
	.history_timeline p {
		width: 100%;
		margin: 0 auto;
		/* line-height: 4rem; */
		padding: 2rem 0;
		font-size: 1.4rem;
	}
	.history_timeline h3 {
		font-size: 2.8rem;
		font-weight: 100;
	}
	.history_timeline h4 {
		font-size: 10vw;
		font-weight: 500;
		padding-bottom: 0rem;
		text-align: center;
	}
	.history_timeline h5 {
		font-size: 7vw;
		font-weight: 500;
		padding-bottom: 2rem;
	}
	.horizontal-list {
		display: flex;
		margin: 1rem auto 10rem auto;
		overflow-x: auto;
		white-space: nowrap;
		-webkit-overflow-scrolling: touch;
		justify-content: flex-start;
		align-items: flex-start;
	}
	.horizontal-list ul {
		width: 100%;
	}
	.horizontal-list .item {
		list-style: none;
		display: inline-block;
		width: 100%;
		margin: 0 1rem;
	}
	.horizontal-list .scroll {
		border: 1px solid #9f1515;
		background: #9f1515;
		font-size: 12px;
		height: fit-content;
		margin: 0 auto;
		overflow: auto;
		width: 93%;
	}
	.horizontal-list .scroll::-webkit-scrollbar {
		width: 7px;
	}
	.horizontal-list .scroll::-webkit-scrollbar-thumb {
		background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, #9f1515), to(#9f1515));
		background: linear-gradient(to bottom, #ca2f2f 50%, #ca2f2f);
		border-radius: 5px;
	}
	.horizontal-list .scroll::-webkit-scrollbar-track {
		background: #e57373;
	}
	/*-------------------------------------------------------
     campaign
    ------------------------------------------------------- */
	.campaign {
		width: 100%;
		background: #ab2827;
		margin: 0 auto;
		padding: 10rem 0 5rem auto;
		position: relative;
		top: 0;
		overflow: hidden;
	}
	.campaign_wrap {
		max-width: 90%;
		margin: 0 auto;
		padding: 0;
		text-align: center;
		color: #FFFFFF;
		line-height: 2;
		letter-spacing: 1;
	}
	.campaign_innner {
		position: relative;
		top: 0;
	}
	.campaign_innner h3 {
		font-size: 2rem;
		font-family: a-otf-ryumin-pr6n, serif;
		text-align: center;
	}
	.campaign_innner h4 {
		font-size: 1.6rem;
		font-family: century-gothic, sans-serif;
		text-align: center;
	}
	.campaign_innner p {
		margin: 2rem 0;
	}
	.campaign_flow {
		background: #FFF;
		border-radius: 3px;
		width: 90%;
		margin: 4rem auto 0 auto;
		padding: 0;
		color: #333;
	}
	.campaign_flow h1 {
		font-size: 1.4rem;
		font-weight: normal;
		line-height: 1.6;
		text-align: left;
		padding: 0;
	}
	.campaign_rule {
		line-height: 1.4;
		font-size: 1.4rem;
		letter-spacing: 1px;
		padding: 2rem 0 0 0;
	}
	.campaign_rule dl {
		text-align: left;
		font-weight: 700;
	}
	.campaign_rule dt {
		text-align: left;
	}
	.campaign_rule dd {
		text-align: left;
		font-weight: normal;
		margin-bottom: 2rem;
	}
	.campaign_regulation p {
		font-size: 1rem;
		line-height: 2;
	}
	.campaign_regulation h3, h4 {
		font-size: 1.4rem;
	}
	.campaign_regulation ul, ol {
		text-align: left;
		/*背景色*/
		padding: 1rem 1rem 1rem 2rem; /*ボックス内の余白*/
	}
	.campaign_regulation ul li, ol li {
		color: #555;
		list-style: disc;
		text-align: left;
		font-weight: normal;
		font-size: 1rem;
		line-height: 1.2; /*文の行高*/
		padding: 0.5em 0; /*前後の文との余白*/
	}
	.campaign_regulation a {
		color: chocolate;
		text-decoration: underline;
	}
	.campaign_bnrarea {
		padding-bottom: 0;
	}
	.campaign_bnrarea img {
		width: 85%;
	}
	.arrow {
		margin: 1rem auto;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 33px 35px 0 35px;
		border-color: #a97001 transparent transparent transparent;
	}
	.ribbon {
		width: 90%;
		display: inline-block;
		position: relative;
		height: 56px;
		line-height: 60px;
		text-align: center;
		margin: 0 0 2rem 0;
		padding: 7px 0;
		font-size: 1.8rem; /*フォントサイズ*/
		background: #f00; /*背景色*/
		color: #FFF; /*文字色*/
		box-sizing: border-box;
	}
	.ribbon h3 {
		margin: 0;
		padding: 0 30px;
		border-top: solid 2px #f9c700; /*上の破線*/
		border-bottom: solid 2px #f9c700; /*下の破線*/
		line-height: 39px;
		font-family: a-otf-ryumin-pr6n, serif;
		font-weight: 700;
		font-style: normal;
		font-size: 1.6rem;
	}
	.ribbon:before, .ribbon:after {
		position: absolute;
		content: '';
		width: 0px;
		height: 0px;
		z-index: 1;
	}
	.ribbon:before {
		/*左端の山形*/
		top: 0;
		left: 0;
		border-width: 30px 0px 30px 15px;
		border-color: transparent transparent transparent #fff;
		border-style: solid;
	}
	.ribbon:after {
		/*右端の山形*/
		top: 0;
		right: 0;
		border-width: 30px 15px 30px 0px;
		border-color: transparent #fff transparent transparent;
		border-style: solid;
	}
	.ribbon_en {
		width: 100%;
		display: inline-block;
		position: relative;
		height: 64px;
		line-height: 35px;
		text-align: center;
		margin: 0 0 2rem 0;
		padding: 7px 0;
		font-size: 1.4rem; /*フォントサイズ*/
		background: #f00; /*背景色*/
		color: #FFF; /*文字色*/
		box-sizing: border-box;
	}
	.ribbon_en h3 {
		margin: 0;
		padding: 0px 15px;
		border-top: solid 2px #f9c700; /*上の破線*/
		border-bottom: solid 2px #f9c700; /*下の破線*/
		line-height: 45px;
		font-family: a-otf-ryumin-pr6n, serif;
		font-weight: 700;
		font-style: normal;
	}
	.ribbon_en:before, .ribbon_en:after {
		position: absolute;
		content: '';
		width: 0px;
		height: 0px;
		z-index: 1;
	}
	.ribbon_en:before {
		/*左端の山形*/
		top: 0;
		left: 0;
		border-width: 30px 0px 30px 15px;
		border-color: transparent transparent transparent #fff;
		border-style: solid;
	}
	.ribbon_en:after {
		/*右端の山形*/
		top: 0;
		right: 0;
		border-width: 30px 15px 30px 0px;
		border-color: transparent #fff transparent transparent;
		border-style: solid;
	}
	.campaign_step {
		margin: 3rem auto;
	}
	.campaign_step_inner {
		margin: 0 auto 2rem auto;
		padding: 1rem 0 2rem 0;
		border: 1px solid #a97001;
	}
	.campaign_step_inner p img {
		width: 80%;
	}
	.campaign_step h3 {
		width: 80%;
		background: #a97001;
		margin: 1rem auto;
		padding: 0.3rem 0;
		color: #fff;
		border-radius: 0.5rem;
		font-size: 2rem;
	}
	.campaign_step_inner_textarea {
		font-weight: normal;
		font-size: 1.4rem;
		text-align: left;
	}
	.campaign_btn {
		margin: 1rem auto;
		width: 90%;
	}
	.campaign_btn a {
		color: #FFF;
		font-size: 1.6rem;
	}
	.campaign_btn_twi {
		padding: 0.8rem;
		background: #1B80D0;
		color: #FFF;
		border: 2px solid #1b80d0;
		border-radius: 1rem;
		margin-bottom: 1.5rem;
		width: 90%;
	}
	.campaign_btn_twi:hover {
		color: #FFF;
		background: #1B80D0;
		border: 2px solid #1b80d0;
	}
	.campaign_btn_insta {
		padding: 0.8rem;
		background: #DA07A5;
		color: #FFF;
		border: 2px solid #DA07A5;
		border-radius: 1rem;
		width: 90%;
	}
	.campaign_btn_insta:hover {
		color: #FFF;
		background: #DA07A5;
		border: 2px solid #DA07A5;
	}
}