@charset "UTF-8";
/* 調整用スタイル */

main {
  background-color: rgba(0,0,0,0.30);
}
main.wrap::before {
  content: "";
  display: block;
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: -1;
  width: 100%;
  height: 100vh;
  background-image: url("../common/back_all.jpg");
  background-size: cover;
	background-position: center center;
  background-repeat: no-repeat;
}

.top_mar { margin-top: 80px; }
@media screen and (max-width: 960px) {
	.top_mar { margin-top: 50px; }
}


section {
	margin: auto;
  padding: 70px 7% 80px;
}
section.bg_color0 { 
	background-image: linear-gradient(to bottom, rgba(210,202,178,0.00) 50%, rgba(210,202,178,0.00) 100%);
	border-top: 0px #80632C solid;
}
section.bg_color { 
	background-image: linear-gradient(to bottom, rgba(0,0,0,0.10) 50%, rgba(0,0,0,0.70) 100%);
	border-top: 1px #AC8D52 solid;
}
section.bg_color2 { background-color: rgba(210,202,178,0.80);
	border-top: 1px #8E7A4E solid; }

@media screen and (max-width: 960px) {
	
  /* main.wrap::before {
    background-image: url("../common/back1sp.jpg");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
  } */
	section {
		padding: 40px 7% 50px;
	}
}

#main_vis_back { width: 100%; margin: 0 auto; margin-top: 80px; background: url("../common/main_back0.jpg") 50% 0 no-repeat; }

.top_waku {
  width : 980px;
  height : 1000px;
  position : relative;
}
.logo1 {
  background-image : url("../top_img/title_logo1.png");
  background-position : center center;
  width: 777px;
  height: 950px;
  top: 104px;
  left: 101px;
  position: absolute;
  background-repeat: no-repeat;
}

/* イントロのみ */
#intro_main1 {
 height: 0;
 padding-top: 43.72%;
/* 表示画像の高さ ÷ 表示画像の幅 × 100 */
 background: url(../introduction_img/intro_vis_pc1.jpg) 50% 0 / contain no-repeat scroll padding-box border-box transparent;
}
 
.catch_logo_size {
	margin: 0 auto;
  width: 100%; max-width: 720px;
	padding-bottom: 0px;
}
.catch_copy_size {
	margin: 0 auto;
  width: 100%; max-width: 900px;
	padding-bottom: 0px;
}
.gensaku_size {
	margin: 3rem auto;
  width: 100%; max-width: 500px;
	padding-bottom: 0px;
}
.intro_logo_size {
	margin: 0 auto;
  width: 100%; max-width: 500px;
	padding-bottom: 0px;
}
@media screen and (max-width: 960px) {
  .catch_logo_size {
    margin: 0 auto;
    width: 85%;
		padding-bottom: 0px;
  }
  .catch_copy_size {
    margin: 0 auto;
    width: 100%;
		padding-bottom: 0px;
  }
  .gensaku_size {
    margin: 2rem auto;
    width: 95%;
		padding-bottom: 0px;
  }
  .intro_logo_size {
    margin: 0 auto;
    width: 85%;
		padding-bottom: 0px;
  }
}

.catch_text1 {
  margin: 1em 0;
	text-align: center;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
  font-size: 3.0rem;
  line-height: 2.1;
  color: #CAB38E; font-weight: bold;
  letter-spacing: 0px;
}
@media screen and (max-width: 960px) {
  .catch_text1 {
    margin: 1.0em 0;
    font-size: 1.5rem;
    line-height: 2.3;
  }
}

/* タイトル */
.title {
  margin: 10px 0 40px 0;
	text-align: center;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
  letter-spacing: 1px;
  background: -webkit-linear-gradient(top, #c9a67e 50%, #7d5c04 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 3.8rem;
  line-height: 1;
  font-weight: bold;
}
@media screen and (max-width: 960px) {
  .title {
    font-size: 2.6rem;
    margin: 10px 0 25px 0;
  }
}

/* STORYタイトル */
.story_title {
  font-size: 2.8rem;
  line-height: 1;
	text-align: center;
  color: #F3F3F3; font-weight: bold;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
  letter-spacing: 0px;
  background: -webkit-linear-gradient(top, #a37e39 0%, #80632C 50%, #80632C 51%, #a37e39 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 960px) {
  .story_title {
    font-size: 2.4rem;
    margin: 10px 0 10px 0;
  }
}
.midashi_title1 {
	font-family: 'Oswald', sans-serif;
	color: #FBE697;
	font-size: 3.5rem; font-weight: bold;
  display: inline;
  padding: 2px 4rem 5px;
  background: linear-gradient(transparent 0%, #e83828 0%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

@media screen and (max-width: 960px) {
  /* タイトル */
  .midashi_title1 {
    font-size: 2.4rem;
		padding: 1px 3rem 3px;
  }
}

/* テキストエリア */
.text__area {
	margin: 0 auto;
	width: 100%; max-width: 1100px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
}

.text__area_cast {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
  display: flex;
  justify-content: flex-end;
}

@media screen and (max-width: 960px) {
  .text__area {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
  }

  .text__area_cast {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.8;
  }
}

/* タイトル */
.sub_title1 {
  font-size: 2.4rem; font-weight: bold;
	padding: 0.2rem 0 0.8rem 2.4rem;
	margin-top: 50px;
	margin-bottom: 25px;
  letter-spacing: 0px;
  background: -webkit-linear-gradient(top, #a37e39 0%, #80632C 50%, #80632C 51%, #a37e39 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	border-left: 6px #AC8D50 solid;
	border-bottom: 1px #AC8D50 solid;
}
.sub_title3 {
  font-size: 1.7rem;
	padding: 0px 0px 0px 0px;
	font-weight: bold; color: #D9B68E;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
  letter-spacing: 1px;
}

@media screen and (max-width: 960px) {
  .sub_title1 {
    font-size: 1.8rem;
		padding: 0.1rem 0 0.6rem 1.7rem;
		margin-top: 30px;
		margin-bottom: 18px;
  }
  .sub_title3 {
    font-size: 19px;
		padding: 0px 0px 0px 0px;
  }
}

.text_line01 {
	font-size: 22px; text-align: left;
	color: #FFFFFF; font-weight: bold;
	border-left: 8px solid #ff10bf;
	width: 100%; max-width: 880px; margin: 0 auto;
	margin-top: 55px;
	margin-bottom: 20px;
	padding: 10px 0px 10px 22px;
	background-image: linear-gradient(to right, rgba(69,19,93,0.50) 35%, rgba(69,19,93,0.00) 100%);
}
@media screen and (max-width: 960px) {
	.text_line01 {
    font-size: 16px;
    border-left: 7px solid #ff10bf;
    width: 100%; mmargin: 0 auto;
		margin-top: 15px;
		margin-bottom: 15px;
    padding: 5px 0px 5px 20px;
	}
}

/* movie */
.movie-wrap {
	position: relative;
	padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
	height: 0;
	overflow: hidden;
	background: rgba(255,255,255,0.13);
	border: 1px solid #7C6D54;
	border-image: linear-gradient(to right, #c9a67e, #9c6c26);
	border-image-slice: 1;
}
 
.movie-wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.mov_text_right {
	text-align: right; width: 100%; margin: 0 auto; margin: 0.5rem 0 2rem 0; }

/* movie */
.mov_table1 {
	width: 100%; margin: 0 auto;
	padding: 0px 0px 0px 0px; }

.td_mov { width: 48%; border: 1px #A4965C solid; padding: 9px;
	background-color: rgba(0,0,0,0.50); }
.td_mov_sp { width: 4%; }
.mov_text {
	text-align: center;
	padding: 8px; }
.linkup a{ display: block; }

.td_photo { width: 48%; }

/* ## Rollover set ## */
a:hover.movie_lo { 
    opacity: 0.8; 
    filter: alpha(opacity=80); 
    -moz-opacity: 0.8; }

/*sp*/
@media screen and (max-width: 700px) {
	
	.td_mov { width: 48.5%; padding: 5px; }
	.td_mov_sp { width: 3%; }
	.mov_text {
		text-align: center;
		padding: 6px; }
	.td_photo { width: 48.5%; }
}


/* 2カラムから1カラム */
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}
table th.left {
  width: 30%;
  background-color: rgba(38,6,27,0.00);
  border: 0px solid #d8a563;
  box-sizing: border-box;
  padding: 0px;
  vertical-align: middle;
  font-weight: bold;
  text-align: center;
}
table td.right {
  background-color: rgba(38,6,27,0.0);
  border: 0px solid #ccc;
  box-sizing: border-box;
  vertical-align: top;
  text-align: left;
}
.right_text1 {
  padding: 0px 0px 0px 20px;
}
@media all and (max-width: 960px) {
  table th.left, table td.right {
    display: block;
    width: 100%;
    border-bottom: none;
  }
  .right_text1 {
    padding: 1em 0px 0px 0px;
  }
}

/* イントロ */
.intro_box1 {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
	margin-bottom: 30px;
	padding: 30px 0px 35px 0px;
	background-color: rgba(255,255,255,0.80);
	opacity: 1.0;
	border: 1px #A4965C solid;
  border-radius: 1.3rem;
}
.box2 {
	width: 100%; max-width: 850px;
	margin: 0 auto;
	margin-bottom: 40px;
	padding: 30px 0px 35px 0px;
	background-color: rgba(44,33,12,0.55);
  color: #FFFFFF;
	border: 1px #817A5D solid;
  border-radius: 1.2rem;
}
.box_kado {
	width: 100%; max-width: 850px;
	margin: 0 auto;
	margin-bottom: 40px;
	padding: 30px 0px 35px 0px;
  background:
		linear-gradient(135deg, transparent 15px, rgba(0,0,0,0.25) 0) top left, /*重なり順番1*/
    linear-gradient(-135deg, transparent 15px, rgba(0,0,0,0.25) 0) top right, /*重なり順番2*/
		linear-gradient(-45deg, transparent 15px, rgba(0,0,0,0.25) 0) bottom right, /*重なり順番3*/
    linear-gradient(45deg, transparent 15px, rgba(0,0,0,0.25) 0) bottom left; /*重なり順番4*/
	background-size: 50% 50%;
  background-repeat: no-repeat;
}
.box_text1 {
	text-align: left; width: 91%; max-width: 900px; margin: 0 auto;
}

@media screen and (max-width: 960px) {
  .intro_box1 {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.7;
		margin-bottom: 10px;
    padding: 2.0rem 0px;
  }
	.box2 {
    width: 100%;
    margin: 0 auto;
    margin-bottom: 20px;
    padding: 20px 0px 20px 0px;
  }
	.box_text1 {
    text-align: left; width: 88%; margin: 0 auto; }
}

/* news 2 */
.info_box {
	border: solid 0px;
	width: 100%; max-width: 1100px; height: 380px; overflow: auto;
	margin: 0 auto;
  margin-top: 0px;
	margin-bottom: 0px;
}

.news-item {
  display: flex;
  align-items: flex-start;
  position: relative;
  padding-left: 120px; /* 日付分のスペース */
	border-bottom: 1px #5E5445 solid;
}

/* 日付 */
.divdate {
  position: absolute;
	font-family: "Calistoga", serif;
  left: 0px;
	top: 50%;
	transform: translateY(-50%);
  width: 120px;
  text-align: left;
  color: #f2e0cb;
	line-height: 1.45;
}

/* 縦線 */
.news-item::before {
  content: "";
  position: absolute;
  left: 90px; /* 日付の右端あたり */
  top: 2.2rem;
  bottom: 2.2rem;
  width: 1px;
  background: #f2e0cb;
}

/* 内容 */
.divinfo {
  flex: 1;
	padding: 2.2rem 10px 2.2rem 10px;
  color: #f2e0cb;
}
.divinfo a{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent:-999px;
}
.divinfo:hover{
  color: #D58460;
  background-color: rgba(20,11,3,0.50);
}

/* スマホ表示（幅960px以下） */
@media (max-width: 960px) {
  .info_box {
    width: 100%; height: 380px; overflow: auto;
		margin-bottom: 25px;
  }
  .news-item {
    display: block;
    padding-left: 0;
		padding-top: 3rem;
  }

  .divdate {
    position: static;
    width: auto;
    text-align: left;
		padding-top: 0rem;
		top: 0rem;
    margin-bottom: 0.0rem;
  }

  .news-item::before {
    display: none;
  }

  .divinfo {
    padding: 0.0rem 10px 1.5rem 0px;
  }
}

.tic_0text {
  padding: 13rem 0px;
	text-align: center;
}

/* チケットbox */
.tic_box1 {
	margin: 0 auto;
	width: 100%; max-width: 900px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.9;
	margin-bottom: 30px;
	padding: 30px 0px 35px 0px;
	background-color: rgba(0,0,0,0.40);
	opacity: 1.0;
	border: 1px #767264 solid;
  border-radius: 1.3rem;
}

@media screen and (max-width: 960px) {
  /* news */
  .tic_box1 {
    width: 100%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.7;
		margin-bottom: 20px;
    padding: 1.8rem 0px;
  }
}

/* グッズカラム　2カラムから1カラム */
.goods_box {
	width: 100%; max-width: 980px;
  margin: 0 auto;
	padding-bottom: 0px;
  display: flex;
  flex-wrap: wrap;
}
.goods--l {
  width: 380px;
}
.goods--r {
  width: calc(100% - 380px);
  padding: 0 0 0 0px;
}

.goods_img { text-align: left; width: 380px;
	border: 1px #CAB672 solid; }

.goods_text1 {
  text-align: left; width: 100%; margin-top: 0rem; padding-left: 20px; }
.goods_text2 {
  text-align: left; width: 100%; }

@media screen and (max-width: 960px) {
  .goods_box {
    width: 100%;
  }
  .goods--l,
  .goods_img {
    width: 100%;
		text-align: center;
    margin: 0 auto;
  }
  .goods--r {
    width: 100%;
    margin: 0 auto;
  }
  .goods_text1 {
    text-align: left; width: 100%; margin-top: 1.3rem; padding-left: 0px; }
  .goods_text2 {
    text-align: left; width: 100%; margin-top: 1.3rem; }
}

/* ご案内 */
.guid_text_line_a {
	border-left: 8px solid rgba(219,88,29,0.55);
	margin: 7px 0px 0px 0.5em;
	padding: 0px 0px 0px 0.5em;
}


/* テキスト関連 */
small {
  font-size: 0.85em;
	line-height: 1.6;
}

.title_font1 {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
  letter-spacing: 0px;
  background: -webkit-linear-gradient(top, #a37e39 0%, #80632C 50%, #80632C 51%, #a37e39 95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.midashi_text1 { color: #a37e39; font-weight: bold; text-shadow: 0px 0px 0px rgba(255,209,0,1.00); }
.midashi_text2 { color: #D9B68E; font-weight: bold; text-shadow: 0px 0px 0px rgba(255,209,0,1.00); }
.midashi_text3 { color: #06355a; font-weight: bold; }
.midashi_text4 { 
	font-size: 1.8rem;
	font-weight: bold; color: #D9B68E; }


.moji_spacing { letter-spacing: -2.5px; }
.moji_tume1 { letter-spacing: -1px; }
.moji_ake1 { letter-spacing: 1px; }

.text_arrow { color: #C67800; font-weight: bold; }
.text_arrow2 { color: #FAB448; font-weight: bold; }

.text1em {
	padding-left: 1em;
  text-indent: -1em; }

.text1em_all {
	padding-left: 1em; }

.text_yellow1 { color: #E5D6AB; font-weight: bold; }
.text_orange1 { color: #FF4700; font-weight: bold; }
.text_white1 { color: #FFFFFF; font-weight: bold; }
.text_white2 { color: #FFFFFF; }

.text_background {
	color: #ffffff;
  display: inline;
  padding: 12px 25px;
  background: linear-gradient(transparent 0%, #000000 0%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.text_background2 {
	font-family: 'Oswald', sans-serif;
	color: #ffffff;
	font-size: 4.5rem; font-weight: bold;
  display: inline;
  padding: 7px 3rem;
  background: linear-gradient(transparent 50%, #e83828 100%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.main_text_right {
	text-align: right; width: 100%; margin: 0 auto; margin: 0.5rem 0 2rem 0; }

.mincho {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "MS P明朝", "MS明朝", serif;
  transform: rotate(.03deg);
}

/* 未訪問 */
a:link { color: #06355A; text-decoration: none; }
/* 訪問済み */
a:visited { color: #06355A; text-decoration: none;; }
/* カーソルが上に乗った状態 */
a:hover { color: #D04C1C; text-decoration: underline; }


/* flyer */
.flyer_box1 {
	margin: 0 auto;
	width: 100%; max-width: 770px;
	padding-bottom: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.flyer_sp { width: 30px; }
.flyer_photo { width: 370px;
	border: 1px #5F5839 solid; }

/* GALLERY */
.gallery_box1 {
	margin: 0 auto;
	width: 100%; max-width: 900px;
	padding-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.gallery_sp { width: 30px; }
.gallery_photo { width: 435px;
	border: 1px #a37e39 solid; }
.gallery_photo2 { width: 100%;
	border: 1px #a37e39 solid; }

@media screen and (max-width: 960px) {
  .gallery_box1 {
    width: 100%;
    padding-bottom: 1rem;
  }
  .gallery_sp { width: 5rem; }
  .gallery_photo { width: 100%; }
  .gallery_photo2 { width: 100%; }
}


/* footer
------------------------------------------------------------*/
footer {
  border-top: 1px #8E7A4E solid;
	background-color: rgba(0,0,0,0.85); }
footer #ticket_btn {
  position: fixed;
  left: 20px;
  bottom: 20px;
  line-height: 0;
}
footer #ticket_btn img {
  width: 100%;
}
footer #footer_items {
  padding: 35px 7% 50px;
  margin: 0 auto;
  text-align: center;
  font-size: 1.4rem;
  font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  letter-spacing: 0.0rem;
}

.copyright1 { font-size: 1.5rem; color: #D9B68E; }
.copyright2 {
	padding: 7px 0px 0px 0px;
  font-size: 1.3rem; color: #C6A279; }

@media screen and (max-width: 960px) {
  footer #ticket_btn {
    position: fixed;
    left: 10px;
    bottom: 10px;
  }
  footer #ticket_btn img {
		width: 60%;
  }
  footer #footer_items {
    padding: 2.5em 5% 2.2em;
  }
  .copyright1 { font-size: 1.2rem; }
  .copyright2 {
    padding: 7px 0px 0px 0px;
    font-size: 1.0rem; }
}

*, *:before, *:after {
    box-sizing: border-box;
}
.col_2 {
  margin: 0 auto;
  width: 250px;
  display: flex;
  flex-wrap: wrap;
}
.col_2 > *{
  width: calc( 50% - 2% ) ;
  margin-right: 12px;
  margin-bottom: 12px;
}
.col_2 > *:nth-child(2n){
  margin-right: auto;
}
.logo_life {
  margin: 2rem 0 0 0;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .col_2{
    margin: 0 auto;
    width: 50%;
    display: flex;
    flex-wrap: wrap;
  }
  .logo_life {
    width: 100%;
  }
}


/* TOPへ戻る NEW!
------------------------------------------------------------*/
.pagetop {
  position: fixed;
	right: 17px;
  bottom: 17px;
  margin: 0;
  transition: .2s;
  opacity: 1;
  visibility: visible;
}
.pagetop a {
  position: relative;
  display: flex;
  width: 62px;
  height: 62px;
  justify-content: center;
  transition: opacity .6s ease;
  align-items: center;
  text-decoration: none;
  font-size: 34px;
  border-radius: 100%;
	background-color: rgba(37,24,9,0.85);
  color: #C6A279;
	border: 1px #625747 solid;
}
.pagetop a:hover {
    opacity: 0.7;
}

.snsicon {
  position: fixed;
	right: 17px;
  bottom: 91px;
  transition: .2s;
  opacity: 1;
  visibility: visible;
}
.snsicon a {
  position: relative;
  display: flex;
  width: 62px;
  height: 62px;
  justify-content: center;
  transition: opacity .6s ease;
  align-items: center;
  text-decoration: none;
  border-radius: 100%;
	background-color: rgba(37,24,9,0.85);
  color: #C6A279;
	border: 1px #625747 solid;
}
.snsicon a:hover {
    opacity: 0.7;
}

#snsicon {
  /* display: none; */
  position: fixed;
  right: 17px;
  bottom: 100px;
  line-height: 0;
  border-radius: 100%;
	border: 1px #000000 solid;
}
.snssize {
  width: 31px;
	margin: 0 auto;
	text-align: center;
}

@media screen and (max-width: 960px) {
  .pagetop {
    right: 14px;
    bottom: 14px;
  }
	.pagetop a {
		width: 42px;
    height: 42px;
		font-size: 30px;
	}
	
  .snsicon {
    right: 14px;
    bottom: 63px;
  }
	.snsicon a {
		width: 42px;
    height: 42px;
	}

  #snsicon {
    /* display: none; */
    position: fixed;
    right: 14px;
    bottom: 65px;
    line-height: 0;
		z-index: 2;
  }
  .snssize {
    width: 22px;
  }
}

.img100per { width: 100%; }
.img90per { width: 90%; }
.img80per { width: 80%; }
.img70per { width: 70%; }
.img60per { width: 60%; }
.img50per { width: 50%; }
.img40per { width: 40%; }

.big0 { font-size: 1.6rem; font-weight: bold; }
.big1 { font-size: 2.0rem; font-weight: bold; }
.big2 { font-size: 2.4rem; font-weight: bold; }
.big3 { font-size: 3.4rem; font-weight: bold; }
.big4 { font-size: 4.5rem; font-weight: bold; }

.small1 { font-size: 90%; }
.small2 { font-size: 80%; }
.small3 { font-size: 70%; }

.mar_t5 { margin-top: 5px; }
.mar_t10 { margin-top: 10px; }
.mar_t15 { margin-top: 15px; }
.mar_t20 { margin-top: 20px; }
.mar_t25 { margin-top: 25px; }
.mar_t30 { margin-top: 30px; }
.mar_t40 { margin-top: 40px; }
.mar_t45 { margin-top: 45px; }
.mar_t50 { margin-top: 50px; }
.mar_t60 { margin-top: 60px; }
.mar_t70 { margin-top: 70px; }
.mar_t80 { margin-top: 80px; }
.mar_t90 { margin-top: 90px; }
.mar_t100 { margin-top: 100px; }
.mar_t120 { margin-top: 120px; }

.mar_b70 { margin-bottom: 70px; }
.mar_b80 { margin-bottom: 80px; }
.mar_b90 { margin-bottom: 90px; }
.mar_b100 { margin-bottom: 100px; }

@media screen and (max-width: 960px) {
  .big0 { font-size: 1.5rem; }
  .big1 { font-size: 1.7rem; }
  .big2 { font-size: 2.0rem; }
  .big3 { font-size: 2.3rem; }
  .big4 { font-size: 3.7rem; }

  .mar_t10 { margin-top: 8px; }
  .mar_t15 { margin-top: 13px; }
  .mar_t20 { margin-top: 16px; }
  .mar_t25 { margin-top: 20px; }
  .mar_t30 { margin-top: 22px; }
  .mar_t40 { margin-top: 25px; }
  .mar_t45 { margin-top: 28px; }
  .mar_t50 { margin-top: 32px; }
  .mar_t60 { margin-top: 38px; }
  .mar_t70 { margin-top: 40px; }
  .mar_t80 { margin-top: 55px; }
  .mar_t90 { margin-top: 65px; }
  .mar_t100 { margin-top: 75px; }
  .mar_t120 { margin-top: 90px; }

  .mar_b70 { margin-bottom: 40px; }
  .mar_b80 { margin-bottom: 55px; }
  .mar_b90 { margin-bottom: 65px; }
  .mar_b100 { margin-bottom: 75px; }
}