@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');

:root {
	--base-color-blue: #171c61;
	--base-color-skyblue: #02448c;
	--base-color-red: #a3042a;
	--base-color-yellow: #896b2a;
	--base-color-yellow-2: #c17f0a;
	--tx_base-color-black: #231815;
	--font_main_sans-serif:"Noto Sans JP", sans-serif;
	--font_main_serif:"Noto Serif JP", serif;
	--font_sb_sans-serif:"ab-doramin", sans-serif;
	--font-weight-regular:400;
	--font-weight-bold:700;
	--font-weight-black:900;
	--font-size-18px:clamp(0.813rem, 0.708rem + 0.45vw, 1.125rem);/* 13px-18px */
	--font-size-24px:clamp(1rem, 0.833rem + 0.72vw, 1.5rem);/* 16px-24px */
	--font-size-28px:clamp(1.313rem, 1.167rem + 0.63vw, 1.75rem);/* 21px-28px */
	--font-size-40px:;
	--font-size-42px:clamp(1.75rem, 1.458rem + 1.26vw, 2.625rem);/* 24px-32px */
}
/*--------------------------------------------------------*/
/*リセット*/
html{margin:0px;padding:0px;border:0px;}
*{margin:0px;padding:0px;border:0px;}
body{line-height:1;}
body,h1,h2,h3,h4,h5,h6,p,span,table,a,img,dl,dt,dd,ul,li,ol,iframe,nav{
	margin:0px;
	padding:0px;	
	word-break: break-word;
	vertical-align: baseline;
	text-decoration: none;
	list-style: none;
}
* {
	border: 0;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
ol, ul{list-style:none; list-style-type:none;}
.cleartext{
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
.clearfix:after {
	visibility: hidden;
	display: block;
	content: " ";
	clear: both;
	height: 0;
}
img {
	vertical-align: bottom;
}
.mx_menu_all{margin-bottom:0px !important;min-width: initial !important;min-width: auto !important;}
.pc_ad_head{text-align:center;}
.banner_bg{margin-bottom:0px !important;}
/*--------------------------------------------------------*/
.span{
	display: inline-block;
}
small {
	line-height: 1.2em;
	font-size: min(2vw, 18px);
	display: block;
	margin-top: 3em;
	text-align: center;
}
body{
	background-color: #f5f5fa;
	text-align:center;
	font-family: var(--font_main_sans-serif);
	font-weight: normal;
	color: #4f4f51;	
}

a:link{text-decoration:none; color: #231815; text-decoration: underline;}
/* a:visited{color:#039bdd; text-decoration:none;}
a:hover{color:#000; text-decoration:none;transition-duration: 0.2s;} */
#page_all {
	/* text-align: left; */
	/* border-bottom: solid 12vw #ffffff; */
	word-wrap: break-word;
}
#right_side {
	min-width: 300px;
	padding: 10px 0px 0px 30px;
	align-self: flex-start;
}
/*--------------------------------------------------------*/
/*--パンくず--*/
#pan_box {
	background-color: #000000;
	overflow-x: auto;
	overflow-y: hidden;
}

.panlist{
	padding: 8px;
	font-size: 80%;
	line-height: 120%;
	color: #fff;
	text-align:left;
	width: max-content;
}

#pan_box a {
	color: #fff;
}
.panlist a:link{color:#fff; text-decoration:underline;}
.panlist a:visited{color:#fff; text-decoration:underline;}
.panlist a:hover{color:#fff; text-decoration:underline;}
/*--------------------------------------------------------*/
/*--SNS--*/
#sns_button_pc,
#sns_button_sp{
	text-align: center!important;
	margin: 5% 0 0 0;
    display: flex;
    gap: 1%;
    justify-content: center;
}
#sns_button img{
	width: 40px !important;
	height: 40px !important;
	margin: 0.5%;
}
#sns_button_pc img{
	height: 50px!important;
    width: 50px!important;
    margin: 0 5px!important;
}

#sns_button_sp img{
	height: 50px!important;
    width: 50px!important;
    margin: 0 5px!important;
}
#sns_button{
text-align: center;
padding-bottom: 10%;
}
/*--------------------------------------------------------*/
/*--フッター--*/
#footer{margin:0 auto;padding:1px 0 10px; padding:1%; line-height:200%;text-align:center;}
.mx_copyright{ color:#09397a; line-height:1.5; }
.mx_copyright a:link,
.mx_copyright a:visited{ color:#09397a; text-decoration:none; }
.mx_copyright a:hover{ color:#ffffff; text-decoration:underline; }
/*-----------------------------------*/
/*-- 緊急テキスト ----------------------*/
#rp_textbox .txt_text{
border: rgb(255 255 255 / 50%) solid 0.25em;
border-radius: 0.5em;
background: rgba(255,255,255,0.6);
margin: 20px auto;
padding: 8px;
line-height: 1.6em;
text-align: left;
max-width: 960px;
width: 90%;
}
#rp_textbox .pop_text{
-webkit-border-radius: 2px;-moz-border-radius: 2px;border-radius: 2px;
border: #c9c9c9 solid 1px;
font-size:0.9em;
line-height:1.5em;
margin:0 auto;
padding:20px;
text-align:left;
max-width: 900px;
word-break: break-all;
width:75%;
}
#rp_textbox .pop_text .popup_title{
border-bottom: #999 dotted 1px;
font-size:1.1em;
line-height:1.5em;
font-weight:bold;
margin:0 0 15px 0;
padding-bottom:5px;
text-align:center;
width:100%;
}
#rp_textbox .eme_img {
display: block;
text-align: center;
width: 100%;
}
#rp_textbox .eme_img img{
margin: 0 auto 10px;
max-width: 100%;
}
#rp_textbox a{
color:#d00;
text-decoration:underline;
}
.txt_title {
border-left: solid 0.5em #333333;
font-weight: bold;
font-size: 1.2em;
text-align: left;
padding: 0.3em;
margin-bottom: 0.5em;
}
/* loader */
#loader {
    background: #124983;
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 100;
}

/*背景*/
.loader,
.loader:before,
.loader:after {
    background: #f0ac1b;
    -webkit-animation: load1 1s infinite ease-in-out;
    animation: load1 1s infinite ease-in-out;
    height: 4em;
    width: 1em;
    top: 50%;
}

.loader {
    color: #fff;
    text-indent: -9999em;
    margin: auto;
    position: relative;
    font-size: 11px;
    -webkit-transform: translateZ(0);
    -ms-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-animation-delay: -0.16s;
    animation-delay: -0.16s;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.loader:before,
.loader:after {
    position: absolute;
    top: 0;
    content: '';
}

.loader:before {
    left: -1.5em;
    -webkit-animation-delay: -0.32s;
    animation-delay: -0.32s;
}

.loader:after {
    left: 1.5em;
}

@-webkit-keyframes load1 {

    0%,
    80%,
    100% {
        box-shadow: 0 0;
        height: 4em;
    }

    40% {
        box-shadow: 0 -2em;
        height: 5em;
    }
}

@keyframes load1 {

    0%,
    80%,
    100% {
        box-shadow: 0 0;
        height: 4em;
    }

    40% {
        box-shadow: 0 -2em;
        height: 5em;
    }
}
/*-----------------------------------*/
/*google翻訳*/
.skiptranslate.goog-te-gadget,
a.goog-logo-link,.goog-logo-link:link{color:#09397a;text-align:center;}
/*-----------------
共通
------------------*/
.fonts-sans-serif {
	font-family: var(--font_main_sans-serif);
}
.fonts-serif {
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-bold);
}
.font-sbfont {
	font-family: var(--font_sb_sans-serif);
}

.fs-xs {
	font-size: clamp(0.875rem, 0.795rem + 0.36vw, 1.125rem);/* 14-18px */
}

body {
	color: var(--tx_base-color-black);
}

.pcOnly {
	display: block;
}
.spOnly {
	display: contents;
}
.pconly {
	display: block;
}
.sponly {
	display: none;
}
@media screen and (max-width: 800px){
	.pcOnly {
		display: contents;
	}
	.spOnly {
		display: block;
	}
	.pconly {
		display: none;
	}
	.sponly {
		display: block;
	}
}

.wrap {
    width: min(95%, 1110px);
	margin: auto;
}
.wrap #right_side {
    padding-top: 0;
}
.wrap .left_side {
    width: min(calc(100% - 320px), 980px);
	background-color: #000000;
	height: 600px;
}

.wrap .left_side img {
	width: 100%;
}

@media screen and (max-width:980px) {
    /* #header {
        min-height: 80px;
    } */
    #page_all {
        overflow-x: hidden;
    }
    #pan_box {
        overflow-x: scroll;
    }
    .wrap {
        width: 95%;
    }
    .wrap .left_side {
        width: 100%;
    }
    .wrap #right_side {
        display: none;
    }

}


/* -----------------
.toparea
---------------- */
.toparea img {
	width: 100%;
}

.date {
background-color: var(--base-color-blue);
}

.date_box img {
	width: 100%;
}

.date_box a {
	display: block;
	width: 100%;
}

.date_unit {
	display: inline-flex;
	text-align: center;
	margin: auto;
	background: 
	url(../img/parts_date_left.png) left 140% / contain no-repeat,
	url(../img/parts_date_right.png) right 140% / contain no-repeat;
	display: block;
	padding: 1% 5% 2%;
	max-width: 1400px;
	background-size: auto;
}


@media screen and (max-width:1024px) {
.date_unit {
    background: 
	url(../img/parts_date_left.png) -5% 140% / contain no-repeat,
	url(../img/parts_date_right.png) 105% 140% / contain no-repeat;
	}
.date_unit {
	padding: 1% 1% 2%;
}
}

@media screen and (max-width:600px) {
	.date_unit {
        padding: 3% 1% 4%;
    }
}

.date_box {	
	display: inline-flex;
}

.button_top-tickets a {
    background: var(--base-color-red);
	border: 3px solid #dfa626;
    border-radius: 3px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 330px;
    padding: 10px 25px;
    color: #fff;
    line-height: 3;
    text-decoration: none;
    text-align: center;
    transition: 0.3s ease-in-out;
    font-weight: 500;
	border-radius: 50px;
	margin-top: 1%;
	box-shadow: 0px 10px 10px -6px rgb(0 0 0 / 30%);
}
.button_top-tickets a:hover {
    background: #cd0606;
    color: #FFF;
}
.button_top-tickets a:after {
    content: '';
    width: 5px;
    height: 5px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: rotate(134deg) translateY(35%);
    position: absolute;
    top: 50%;
    right: 20px;
    border-radius: 1px;
    transition: 0.3s ease-in-out;
}
.button_top-ti｛ckets a:hover:after {
    border-color: #FFF;
}

@media screen and (max-width:600px) {
	.button_top-tickets a {
		max-width: 240px;
        padding: 0px 10px;
		border: 2px solid #dfa626;
	}
	.button_top-tickets a:after {
    right: 10px;
	}
}

.bg {
	background-image: url(../img/parts_bg.png);
	background-attachment: fixed;
}

.bg2 {
	background-image: url(../img/parts_bg2.jpg);
	background-attachment: fixed;
}

.bg3 {
	background-color: #000a5b;
}

.kv{
	max-width: 1700px;
    margin: auto;
}
.song_unit,
.detail_unit,
.cast_unit {
	padding-bottom: min(8vw, 4em);
}
.song_tx {
	display: flex;
    background: #f9f2e699;
    margin-top: 3%;
    border-radius: 10px;
    padding: 3%;
    line-height: normal;
    gap: 3%;
    justify-content: center;
}

@media screen and (max-width:600px) {
.bg {
	background-size: 12%;
}
.bg2 {
	background-size: 80%;
}
}

/* -------
nav
------- */
.nav_item a {
	position: relative;
	display: inline-block;
}

.nav_item a img {
	width: 100%;
}

.nav_item p {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	margin: 0;
	color: cornsilk;
	white-space: nowrap;
	font-size: clamp(0.875rem, 0.674rem + 0.89vw, 1.5rem);
	pointer-events: none;
	letter-spacing: .05rem;
}

nav ul {
	display: flex;
	gap: 2%;
    justify-content: center;
    max-width: 1000px;
    margin: auto;
	padding: 3% .5rem;
}

@media screen and (max-width:600px) {
	
nav ul {
	width: 80%;
}
}
/* ----------
当日楽曲リスト
---------- */
h2 {
	padding: min(4vw, 1em) 0 min(4vw, 1em);
}

h2 img {
    height: min(30vw, 8em);
}

iframe {
	width: 100%;
}

/* -----枠----- */
.top img {
	width: 100%;
}

.top {
    margin-bottom: -2px;
}
.center img {
	width: 100%;
}
.bottom img {
	width: 100%;
}

.bottom {
	margin-top: -2px;
}

.center {
	position: relative;
	background: url(../img/li_center.png) center repeat-y;
	background-size: 100% auto;
	padding: 3% 8%;
}

@media screen and (max-width:600px) {
.center {
	padding: 3% 5%;
	}
}

/* ----------
開催概要
---------- */

.ribbon9 {
  display: grid;
  position: relative;
  height: 45px;
  text-align: center;
  box-sizing: border-box;
  margin-bottom: 6%;
}
.ribbon9:before {/*左側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -10px;
  left: -35px;
  z-index: -2;
  border: 20px solid #9b6302;
  border-left-color: transparent;/*山形に切り抜き*/
      z-index: revert-layer;
}

.ribbon9:after {/*右側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -10px;
  right: -35px;
  z-index: -2;
  border: 20px solid #9b6302;
  border-right-color: transparent;/*山形に切り抜き*/
	z-index: revert-layer;
	
}

.ribbon9 h5 {
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 0 20px;
  line-height: 45px;
  font-size: 18px;
  color: #FFF;
  background: #a36700;/*真ん中の背景色*/
  z-index: 2;
}
.ribbon9 h5:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-right: solid 15px #cfa42d;/*左の折り返し部分*/
}
.ribbon9 h5:after {
  position: absolute;
  content: '';
  top: 100%;
  right: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-left: solid 15px #cfa42d;/*右の折り返し部分*/
  z-index: 1;
}


@media screen and (max-width: 600px) {
    .kanagawa, .oosaka {
        margin-bottom: 10%;
        width: 90%;
        text-align: center;
        margin: 0 auto 10%;
    }
	.ribbon9:before {
    content: '';
    position: absolute;
    width: 0;
    bottom: -10px;
    left: -25px;
    z-index: -2;
    border: 20px solid #b58023;
    border-left-color: transparent;
    z-index: revert-layer;
	}
	.ribbon9:after {
		right: -25px;
		width: 0px;
	}
	.song_tx {
    display: block;
	}
}


.event_box {
	padding-bottom: 40px;
}

.event_box:last-child {
	padding-bottom: 0;
}

.event_item {
	display: flex;
	border-bottom: 1px solid var(--base-color-yellow);	
	align-items: flex-start;
	gap: 5%;
	padding: 0em 0.3em 1.2em;
	margin: 2.5% auto 0%;
	max-width: 900px;	
}

.event_item:last-child {
	border: none;
}

.event_item dt {
	display: inline;
	background: #454981;
	color: #fff;
	padding: 0.2em 0.4em 0.2em;
	border-radius: 4px;
	width: 180px;	
	line-height: 1.4;
	white-space: nowrap;
	flex: .5;
	font-size: clamp(0.875rem, 0.795rem + 0.36vw, 1.125rem);
}

.event_item dd {
	flex: 2;
	font-size: clamp(1rem, 0.674rem + 0.89vw, 1.5rem);/* 16px-24px */
	text-align: left;
	line-height: 1.5;	
}

@media screen and (max-width:600px) {
	.event_item {
	display: block;
	text-align: left;
	}
	.event_item dd {
	margin-top: 2%;
	}
	.event_item dt {
	margin-bottom: 2%;
	}
	.kanagawa, .oosaka {
    margin-bottom: 8%;
	}
	.event_item {
    padding: 0 0 .5em;
	}
	.event_item dt {
    display: block;
	width: 100%;
    text-align: center;
	}
	.event_item {
		border-bottom: none;
	}
}

h3 {
	color: var(--base-color-yellow-2);
	font-size: clamp(1.5rem, 1.219rem + 1.25vw, 2.375rem);/* 28px-38px */	
	padding-bottom: 3%;
}


/* ======================
MC
====================== */

.mc_unit {
	display: flex;
	justify-content: center;
	gap: 3%;	
}
.mc_unit,
.artist_unit,
.caution_tx {
	margin-bottom: 5%;
}

.mc_unit li {
	width: calc((100% - 30%) / 2);
	text-align: center;
}

.mc_unit .mc_name {
	font-size: clamp(0.875rem, 0.674rem + 0.89vw, 1.5rem);/* 16px-24px */
	color: var(--base-color-yellow);
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-bold);
	padding: 5% 0;
}



.mc_unit .yob {
	font-size: clamp(0.75rem, 0.67rem + 0.36vw, 1rem);
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-bold);
	color: var(--base-color-yellow);
}

.mc_img {
	overflow: hidden;
}

.mc_img img {
	width: 100%;
	display: block;
}
.tx-s {
	font-family: clamp(0.875rem, 0.835rem + 0.18vw, 1rem);/* 14-16px */
}

@media screen and (max-width:600px) {
	.mc_unit li {
    width: calc(100% / 2);
	}
	h3 {
	padding-bottom: 5%;
	}
	
}


/* ======================
MUSICIAN
====================== */
.artist_unit,
.musician_unit {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px 3%;	
}

.artist_unit li,
.musician_unit li {
	text-align: center;
}

.musician_img {
	overflow: hidden;
}

.musician_img img {
	width: 100%;
	display: block;
}


.artist_unit .musician_name,
.musician_unit .musician_name {
	font-size: clamp(0.875rem, 0.674rem + 0.89vw, 1.5rem);/* 16px-24px */
	color: var(--tx_base-color-black);
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-bold);
	padding: 5% 0;
	line-height: 1.3;
}

.artist_unit .yob,
.musician_unit .yob {
	font-size: clamp(0.75rem, 0.67rem + 0.36vw, 1rem);
	font-family: var(--font_main_serif);
	font-weight: var(--font-weight-bold);
	color: var(--tx_base-color-black);
}

.cast_mc, .cast_artist,.cast_musician {
    margin-bottom: 6%;
}

.staff_name {
font-family: var(--font_main_serif);
font-weight: var(--font-weight-bold);
font-size: clamp(0.875rem, 0.674rem + 0.89vw, 1.5rem);/* 14px-24px */
line-height: min(4.5vh, 1.6em);
}

.caution_tx {
	font-size: clamp(0.813rem, 0.672rem + 0.63vw, 1.25rem);
}

@media screen and (max-width:600px) {
	.artist_unit,
	.musician_unit {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 3%;
	}

	.staff_name {
	text-align: left;
	}
}
/* ----------
チケット
--------- */

.ticket_ttl {
    background-color: var(--tx_base-color-black);
    color: #fff;
    font-size: clamp(1rem, 0.92rem + 0.36vw, 1.25rem);/* 16px-20px */
    font-weight: var(--font-weight-bold);
    padding: 0.5em 0.8em;
	text-align: left;
	margin-bottom: 1%;
}

.ticket_list dt {
	font-size: clamp(1rem, 0.92rem + 0.36vw, 1.25rem);/* 16px-20px */
	font-weight: var(--font-weight-bold);
	border-bottom: 1px solid var(--tx_base-color-black);
	text-align: left;
	padding: 1%;
	line-height: 1.3;
}

.ticket_list dd {
	text-align: left;
	font-size: clamp(0.813rem, 0.672rem + 0.63vw, 1.25rem);
	padding: 1%;
	line-height: 1.3;
}

.ticket_btn {
	list-style-type: none;
    display: flex;
    flex-wrap: wrap;
    gap: 1em 0;
    justify-content: space-between;
	padding: 1em 0 2em;
}
.ticket_btn:last-child {
	padding: 1em 0;
}

.ticket_btn li {
	flex-basis: calc(50% - 0.5em);
}

.ticket_btn li a {
	color: #fff;
    list-style: none;
    background-color: brown;
    padding: 3% 5%;
    border-radius: 50px;
    display: block;
    width: 100%;
    height: auto;
	text-decoration: none;
	justify-content: space-between;
    align-items: center;
    display: flex;
	font-size: clamp(0.875rem, 0.754rem + 0.54vw, 1.25rem);
}

.ticket_btn li a:hover {
    background: #cd0606;
    color: #FFF;
	transition: .3s;
}

.ticket_btn li a img {
	width: 16px;
}


@media screen and (max-width:600px) {
	.ticket_btn li a {
	padding: 4% 8%;
	}
	.ticket_btn li a {
	    margin-bottom: 3%;
	}
	.ticket_btn {
    display: block;
    }
}
/* --------
モーダル
-------- */
/*モーダルを開くボタン*/
.modal-open {
    display: flex;
    font-weight: bold;
    color: #fff;
    cursor: pointer;
}
/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,80%);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
}
/*モーダル本体の擬似要素の指定*/
.modal-container:before{
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}
/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active{
  opacity: 1;
  visibility: visible;
}
/*モーダル枠の指定*/
.modal-body{
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 600px;
  width: 90%;
}
/*モーダルを閉じるボタンの指定*/
.modal-close{
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -40px;
  right: -40px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #fff;
  cursor: pointer;
}
/*モーダル内のコンテンツの指定*/
.modal-content{
  background: #fff;
  text-align: left;
  padding: 30px;
	border-radius: 10px;
}

.modal-content p {
	line-height: 1.5;
	font-size: clamp(0.875rem, 0.835rem + 0.18vw, 1rem);/* 14-16px */
}


.musician_img {
	overflow: hidden;
	cursor: pointer;
	/* background-color: #000000; */
}

.musician_img img,
.mc_img img {
	width: 100%;
	display: block;
	transition: transform .3s ease, opacity .3s ease;
}

.musician_img:hover img,
.mc_img:hover img {
	/* transform: scale(1.05); */
	/* opacity: .85; */
	cursor: default;
}

/* ---------------
トップに戻るボタン
--------------- */
#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 14px;
    line-height: 1;
    z-index: 99;
}

#page-top a {
    background: var(--tx_base-color-black);
    text-decoration: none;
    color: #fff;
    padding: 30px 19px 20px;
    text-align: center;
    display: block;
    border-radius: 10px;
    opacity: 0.9;
    transition: all .3s ease;
    font-weight: var(--font-weight-regular);
}

#page-top a::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 10px;
    left: 50%;
    width: 11px;
    height: 11px;
    background: url(../img/ico.png) no-repeat center left;
    background-size: contain;
    -webkit-transform: rotate(-90deg) translate(0, -50%);
    transform: rotate(-90deg) translate(0, -50%);
    -webkit-transform-origin: center;
    transform-origin: center;
	color: #fff;
}
/* ---------------
フェードアップ
--------------- */
.fade-in {
	opacity: 0;
	transition: opacity .8s ease;
}

.fade-in-inner {
	transform: translateY(30px);
	transition: transform .8s cubic-bezier(0.4,0,0.2,1);
}

.fade-in.is-visible {
	opacity: 1;
}

.fade-in.is-visible .fade-in-inner {
	transform: translateY(0);
}



