@charset "utf-8";

/*======================================================================

　旅する光の切り絵展
　
	[01] 基本・レイアウト
	[02] メインビジュアル
	[03] 開催概要
	[04] チケット情報
	[05] お知らせ
	[06] グッズ
    [07] SNS
	[99] メディアクエリ

======================================================================*/


/*------------------------------------------------

	[01] 基本・レイアウト

------------------------------------------------*/

/*@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);*/
@import url(//fonts.googleapis.com/earlyaccess/sawarabimincho.css);

html { /*font-size:62.5%;*/ /*10px scroll-behavior: smooth;*/ }
.sitemap_box { /*font-size: 160%;*/ }
#wrapper { font-family: 'Sawarabi Mincho', 'Lato', 'Noto Sans JP', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif; width: 100%; padding: 0; background: #000; font-size: 1.8rem; /*line-height: 1.8;*/ }
.container { border: 1px solid #222; }
.wrapper { display: flex; width: 100%; margin: 0 auto; justify-content: space-between; }

.box_cnt { width: 92%; max-width: 1280px; margin: 0 auto; }

div.box_nav {width: 100%; position: sticky; display: flex; margin:0; padding: 0; top: 0/*39px*/; z-index: 999;}
div.bg_nav {/*width: 92%; max-width: 960px;*/ margin: 0 auto; padding: 20px 0; border-radius: 4px;}
/*#fix_nav {z-index: 0;}*/
#fix_nav {position: inherit;}

/* Flex Box
---------------------------------*/
.flb { display: flex; flex-wrap: wrap; /*justify-content:center;*/ width: 100%; /*max-width: 1000px;*/ margin: 0 auto; }

a.no_link {color: #fff; text-decoration: none; background: rgba(184,184,184,0.9) !important; pointer-events: none; border-radius: 4px;}

.nav a.no_link {text-decoration: none; background: none !important; pointer-events: none; opacity: 0.5;}
.footNav a.no_link {text-decoration: none; background: none !important; pointer-events: none; opacity: 0.5;}



/* フェード
---------------------------------*/
.scrollin { opacity: 0; transition: all .4s ease; }
.scrollin.show { opacity: 1; transform: none; }
.scr_lr { transform: translate(-1rem, 0); }
.scr_rl { transform: translate(1rem, 0); }
.scr_fadein { transform: translate(0, 0px); }
.scr_up1 { transform: translate(0, 1rem); transition: 0.8s 0s ease; }
.scr_up2 { transform: translate(0, 1rem); transition: 0.8s 0.2s ease; }
.scr_up3 { transform: translate(0, 1rem); transition: 0.8s 0.4s ease; }
.scr_up4 { transform: translate(0, 1rem); transition: 0.8s 0.6s ease; }
.scr_up5 { transform: translate(0, 1rem); transition: 0.8s 0.8s ease; }
.scr_up6 { transform: translate(0, 1rem); transition: 0.8s 1.0s ease; }
.scr_down { transform: translate(0, -1rem); }
.scr_scaleUp { transform: scale(.5); }
.scr_scaleDown { transform: scale(1.5); }
.scr_rotateL { transform: rotate(1rem); }
.scr_rotateR { transform: rotate(1rem); }


.footNav { width: 100%; /*margin: auto;*/ text-align: center; }
.footNav li { display: inline-block; position: relative; margin-right: 30px; font-size: 1rem; font-weight: 600; color: #3f3f3f; vertical-align: -webkit-baseline-middle; }
.footNav li:last-child { margin-right: 0px; }
.footNav li a { color: #fff; text-decoration: none; }
.footNav li a:hover { color: #ccc; }
.footNav li:after { content: ""; display: block; width: 2px; height: 16px; background: #fff; position: absolute; top: 0px; right: -19px; /*-webkit-transform: rotate(30deg); transform: rotate(30deg);*/ }
.footNav li:last-child:after { content: unset; }


/* フッタ
---------------------------------*/
#foot_area_nav { width: 90%; margin: 0 auto; }
#foot_area_nav .area_nav { background: rgba(255,255,255,1); }
footer#common_foot { position: relative; z-index: 99; margin: 0; }


/* リンク
---------------------------------*/
a { /*color: #de7000;*/ -webkit-transition: 0.5s ease-in-out; transition: 0.5s ease-in-out;}
a:link		{}
a:visited	{}
a:hover		{text-decoration:none; opacity:0.7;}
a:active	{text-decoration:none;}




/* 見出し
---------------------------------*/
/*#gintama_top h3 { width: 100%; margin: 60px auto; text-align: center; }
#gintama_top h3 img { width: 100%; max-width: 338px;}*/
#gintama_top h3 { width: 96%; margin: 0 auto 30px; padding: 0 0 14px; font-size: 1.875rem; font-weight: 600; text-align: center; /*border-bottom: 4px solid rgba(255, 243, 63, 1.0);*/ }
#gintama_top #box_mci h3 { border-bottom: none; }
#gintama_top h3 img { width: 100%; max-width: 300px; padding: 0; }
h4 { width: 100%; margin: 20px auto; text-align: center; }
h5 { margin: 0 0 .5em; padding: .5em 1em; font-size: 0.875rem; font-weight: 600; color: #000; background: rgba(255, 255, 255, 1); border-radius: 6px 6px 0 0; }



/* 脚注
---------------------------------*/
ul.notice { width: 92%; margin: 0 auto 3em; }
ul.notice li { list-style: none; margin: 0 0 6px; padding-left: 1em; font-size: 0.875rem; line-height: 1.6; text-indent: -1em; color: #ebf2a6; }
.tb_res ul.notice { width: 100%; margin: 0; }
.tb_res ul.notice li { list-style: none; margin: 0 0 6px; /*padding-left: 1em;*/ font-size: 0.875rem; line-height: 1.6; text-indent: -1em; color: #ebf2a6; }

p span.att { /*padding-left: 1em;*/ font-size: 1.4rem; line-height: 1.3; text-indent: -1em; color: #ebf2a6; }
p span.light { font-weight: 300; }


/* 共通
---------------------------------*/
#bg_twinkle_star { position: fixed; width: 100%; height: 100%; background: url(/gintama20th/images/bg.jpg); background-size: cover; background-position: bottom; }
#twinkle_star { position: fixed; width: 100%; height: 100%; }
.star { background-color: white; position: relative; border-radius: 50%; animation-name: twinkle; animation-iteration-count: infinite; }
@keyframes twinkle { 50% { transform: scale(0.2); } } 



/* ハンバーガーメニュー
---------------------------------*/
.inr_nav {position: relative; -webkit-text-size-adjust: none; /*font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", 'Noto Sans JP', sans-serif; font-style: italic;*/ z-index: 999;}
#navbtn {position: inherit;/*position: fixed; top: 57px; right: 0px;*/ margin: 0; padding: 0 9px; outline: none; border: 4px solid #a9931a; background: /*rgba(25,71,186,0.9)*/rgba(0,0,0,0.9); width: 50px; height: 50px; cursor: pointer; z-index: 9;}
#navbtn::before, #navbtn::after{content : ''; display: block; height: 1px; background: #a9931a; transform: translateY(10px); transition: 0.3s ease-in-out;}
#navbtn::before{transform: translateY(-10px); box-shadow: 0 10px #a9931a;}

.open #navbtn {z-index: 100; background: none;}
.open #navbtn::before{transform: rotate(-45deg); box-shadow: none; background: #a9931a;}
.open #navbtn::after{transform: rotate(45deg); box-shadow: none; background: #a9931a;}
.open .nav{visibility: visible; opacity: 1;}

.nav{position: fixed; top: 0; left: 0; width: 100%; height: 100vh;  background: rgba(0,0,0,0.9); color: #fff; display: flex; justify-content: center; /*align-items: center;*/ visibility: hidden; opacity: 0; transition: 0.5s ease-in-out; z-index: 8;}
.nav ul {list-style: none; text-align: center; margin-top: 120px; }
.nav ul li {font-size: 1.4rem; font-weight: 500; color: #fff;}
.nav ul li.no_link {opacity: 0.5;}
.nav li:not(:last-child) {margin-bottom: 20px;}
.nav li a {color: #fff; text-decoration: none;}
a.anchor {display: block; position: relative; top: -80px; visibility: hidden;}

@media screen and (min-width: 769px) {
#navbtn { display: none; }
.nav ul li img {width: 80%; filter: brightness(0) invert(1);}

}



@media screen and (max-width: 768px) {
.nav ul li img {width: 70%; filter: brightness(0) invert(1);}

}


@media screen and (max-width: 480px) {
a.anchor {display: block; position: relative; top: -80px; visibility: hidden;}
/*#outline{display: block; padding-top: 140px; margin-top: -140px;}*/
}



/*------------------------------------------------

	[02] メインビジュアル

------------------------------------------------*/
#gintama_top { padding: 0 0 60px; }
#gintama_top:before { content: ""; display: block; height: 140px; margin-top: -140px; visibility: hidden; }
.main { display: flex; width: 100%; margin-bottom: 60px;  background: url(/gintama20th/images/bg_main.png) #fff; }
.inr_main { width: 100%; max-width: 1000px; margin: auto; }
.main img { width: 100%; }

/*#box_intro { padding: 0 0 60px; }
#box_intro:before { content: ""; display: block; height: 140px; margin-top: -140px; visibility: hidden; }
#box_intro .inr_box { width: 94%; max-width: 1000px; margin: 0 auto; }
#box_intro .inr_box p.txt_stg { margin: 0 auto 20px; font-size: 1.6rem; font-weight: 600; color: #ebf3a4; text-align: center; }
#box_intro .inr_box p.txt { margin: 0 auto 20px; font-size: 1.125rem; color: #fff; }*/


/*------------------------------------------------

	[03] 開催概要

------------------------------------------------*/
#box_outline { padding: 60px 0 0; }
#box_outline:before { content: ""; display: block; height: 140px; margin-top: -140px; visibility: hidden; }
#box_outline .inr_box { width: 94%; max-width: 1000px; margin: 0 auto; }


/* テーブル
---------------------------------*/
.tb_res, .tb_res td, .tb_res th { border-collapse: collapse; }
.tb_res td, .tb_res th { border-bottom: 1px solid rgba(255, 255, 255, .3); }
.tb_res tr:last-child td, .tb_res tr:last-child th { border-bottom: none; }
.tb_res { width: 96%; max-width: 960px; margin: 10px auto 20px; font-size: 1.0625rem; line-height: 2; color: #fff; }
/*.tb_res th { width: 18%; padding: 8px 0 8px 2%; text-align: left; vertical-align: top; font-weight: 600; }*/
.tb_res th { width: 20%; padding: 8px 0 8px 2%; text-align: left; vertical-align: top; font-weight: 600; }
.tb_res th span { white-space: nowrap; }
/*.tb_res td { width: 78%; padding: 8px 2% 8px 0; text-align: left; }*/
.tb_res td { width: 80.5%; padding: 8px 1.5% 8px 0; text-align: left; }
.tb_res td span { vertical-align: baseline; }
.tb_res th img { margin: 5px 10px; }
.tb_res iframe { width: 100%; margin: 20px 0; }
.tb_res span.stg { font-wight: 500; color: #ebf2a6; }
.tb_res span.img_bnr { display: block; width: 100%; max-width: 120px; }
.tb_res span.img_bnr img { width: 100%; }


/* お問い合わせ
---------------------------------*/
#box_contact  { padding: 60px 0 0; }
#box_contact h4 { color: #fff; text-align: center; }
#box_contact p { color: #fff; text-align: center; font-size: 1.2rem; }
#box_contact ul { text-align: center; }




/*------------------------------------------------

	[04] チケット情報

------------------------------------------------*/
#box_ticket { margin: 0 auto; }
#box_ticket .inr_box { width: 96%; max-width: 1000px; margin: 0 auto 60px; }
/*#box_ticket .flb { width: 96%; max-width: 960px; margin: 0 auto; }
#box_ticket .flb > div { width: 46%; margin: 0 2% 40px; }*/
#box_ticket .flb > div { width: 100%; margin: 0 0 40px; background: rgba(255, 255, 255, 0.2); border-radius: 10px; }
#box_ticket .flb > div p { margin: 0 0 40px; font-size: 1.6rem; line-height: 1.6; }
#box_ticket .flb > div p span { font-size: 2.1rem; font-weight: 600; color: #be1c10; vertical-align: baseline; }
#box_ticket .intro p { margin: 0 6px 0.3em; color: #fff; }

#box_window .flb { width: calc(96% - 40px); max-width: 960px; margin: 0 auto 60px; padding: 10px 20px 0; background: rgba(255, 255, 255, 0.2); border-radius: 10px; }
#box_window .flb > div { width: calc(100% / 3 - 40px); margin: 0 20px 30px; background: rgba(255, 255, 255, 0.8); border-radius: 6px; }
.logo_window { width: 100%; text-align: center; }
.logo_window img { width: 100%; max-width: 200px; margin: .5em auto 1em; }

#box_window .flb p { padding: 0 1em .5em; font-size: 1.0rem; }

.code { font-family: 'Oswald', sans-serif; font-size: 2.1rem; font-weight: 600; color: #2653c4; vertical-align: middle; }
.code_name { margin: 0 .7em 0 0; padding: 0px 10px 2px; color: #fff; vertical-align: middle; background: #2653c4; border-radius: 4px; }
#box_window .btn_buy { margin: 0 auto .5em; }
#box_window .btn_buy a {display: block; width: calc(70% - 24px); margin: 0px auto; padding: 3px 10px; font-size: 1.0rem; line-height: 1.6; letter-spacing: 1px; color: #fff; text-align: center; text-decoration: none; background: #2653c4; border-radius: 999px; transition: 0.3s; }
#box_window .btn_buy a:hover { opacity: .6; }
#box_window .btn_buy.nolink a { pointer-events: none; background: #333; }

/*.btn_buy a span{font-size: 1.2rem;}*/
.att { color: #be1c10; font-size: 1.4rem; font-weight: 600; text-align: center; }

.tb_ticket, .tb_ticket td, .tb_ticket th { border-collapse: collapse; border-bottom: 1px solid rgba(255, 255, 255, .3); }
.tb_ticket { width: 96%; margin: 1% 2% 3%; font-size: 1.4rem; line-height: 1.6; }
.tb_ticket th { width: 34%; padding: 6px 8px 5px; vertical-align: middle; font-size: 1.0rem; font-weight: normal; color: #fff; white-space: nowrap; /*background: #faf2df;*/ }
.tb_ticket td {padding: 5px 10px; color: #fff; /*background: #fff;*/ vertical-align: middle; }
.tb_ticket .price { font-size: 1.0rem; font-weight: 500; }
.tb_ticket .price span { margin-right: .1em; font-family: 'Oswald', sans-serif; font-size: 2.4rem; font-weight: 500; color: #ebf2a6; vertical-align: baseline; }
.tb_ticket td ul { margin: 0; }


/*------------------------------------------------

	[05] お知らせ

------------------------------------------------*/
#box_news { padding: 0 0 60px; }
#box_news:before { content: ""; display: block; height: 140px; margin-top: -140px; visibility: hidden; }
#box_news .inr_box { width: 94%; max-width: 1000px; margin: 0 auto; }
#box_news a, #box_news label { display: block; color: #fff; transition: 0.7s; text-decoration: none; }
#box_news a:hover, #box_news label:hover { background: #222; }
#box_news a:last-child, #box_news label:last-child { border-bottom: none; }
#box_news ul { width: 96%; max-width: 960px; margin: 0 auto; }
#box_news li { padding: .5em 0; font-size: 1.125rem; }
#box_news li span.date { width: 18%; padding: 0 0% 0 2%; /*margin: 0 0% 0 2%;*/ color: #ebf3a4; }
#box_news li span.title { width: 78%; padding: 0 2% 0 0%; /*margin: 0 2% 0 0%;*/ }


/*------------------------------------------------

	[06] グッズ

------------------------------------------------*/


/*------------------------------------------------

	[07] アクセス

------------------------------------------------*/
#box_access { padding: 0 0 60px; }
#box_access:before { content: ""; display: block; height: 140px; margin-top: -140px; visibility: hidden; }
#box_access .inr_box { width: 94%; max-width: 1000px; margin: 0 auto; }
#box_access .inr_box p.txt_stg { margin: 0 auto 20px; font-size: 1.6rem; font-weight: 600; color: #ebf3a4; text-align: center; }
#box_access .inr_box p.txt { margin: 0 auto 20px; font-size: 1.125rem; color: #fff;  text-align: center; }
#box_access .inr_box iframe { width: 100%; margin: 20px 0; }

/*------------------------------------------------

	[08] SNS

------------------------------------------------*/
#box_sns .inr_box { width: 100%; max-width: 800px; margin: 0 auto; }
#box_sns .flb { justify-content: center; }
#box_sns .flb > div { width: calc(100% / 2 - 20px); max-width: 200px; margin: 0 10px; padding: 0; text-align: center; line-height: 1; background: rgba(255, 255, 255, 1); -webkit-transition: 0.3s ease-in-out; transition: 0.3s ease-in-out; }
#box_sns #link_site.flb > div { width: calc(100% / 1 - 0px); max-width: 320px; margin: 0 0 20px; padding: 0; text-align: center; line-height: 1; background: rgba(0, 0, 0, .8);  -webkit-transition: 0.3s ease-in-out; transition: 0.3s ease-in-out; border: 4px solid #a09233; }
#box_sns .flb > div a { display: block; width: 98%; padding: 12px 1%; text-align: center; text-decoration: none; transition: 0.3s; }
#box_sns .flb > div:hover { opacity: .7; }
#box_sns .flb > div img { width: 100%; max-width: 280px; vertical-align: middle; }










/*------------------------------------------------

	[99] メディアクエリ

------------------------------------------------*/
@media screen and (min-width: 769px) {

/* [01] 基本・レイアウト
----------------------------*/




/* [02] メインビジュアル
---------------------------------*/
.header { display: flex; width: 96%; max-width: 960px; height: 50px; margin: 0 auto; }
#gintama_top { position: relative; padding-bottom: 30px; }
#gintama_top div.bg_nav { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100%; }
div.box_nav { width: 100%; position: sticky; display: flex; margin:0; padding: 0; top: 0; z-index: 999; }
div.bg_nav { margin: 0 auto; padding: 20px 0; border-radius: 4px; }
#fix_nav { position: inherit; }
.main { position: relative; margin-bottom: 100px; }

.area_nav { display: flex; width: 100%; margin: 0; border-radius: 6px; background: rgba(160,146,51,0.9); }
.btn_sns { width: 50px; height: 50px; margin: 0 2% 0 0; background: rgba(0, 0, 0, 0.9); border-radius: 999px; /*display: grid; place-items: center;*/ }
.btn_sns a { display: inline-block; width: 50px; text-align: center; text-decoration: none; }
.btn_sns a img { width: 60%; max-width: 26px; vertical-align: middle; filter: brightness(0) invert(1); }
.btn_mp {width: 16%; max-width: 120px; margin: 0 1% 0 0; font-size: 1.4rem; font-weight: 300; line-height: 1.3; text-align: center; display: grid; place-items: center;}
.btn_mp a {color: #fff; text-decoration: none; border-radius: 4px; background: rgba(231,0,18,0.9);}


/* [03] 開催概要
---------------------------------*/

/* [04] チケット情報
---------------------------------*/

/* [05] お知らせ
---------------------------------*/

/* [06] グッズ
---------------------------------*/

/* [07] アクセス
---------------------------------*/

/* [08] SNS
---------------------------------*/


}


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

/* [01] 基本・レイアウト
---------------------------------*/
#wrapper { /*min-width:200px; padding: 8px 0 0;*/ }

.vpc{display: none;}
.vsp{display: inherit;}


/* 見出し */



.header { display: flex; width: 96%; height: 50px; margin: 0 auto; justify-content: right; }
#gintama_top { position: relative; }
#gintama_top div.bg_nav {position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100%;}
div.box_nav {width: 100%; position: sticky; display: flex; margin:0; padding: 0; top: 0; z-index: 999;}
div.bg_nav { margin: 0 auto; padding: 20px 0; border-radius: 4px;}
#fix_nav {position: inherit;}
.main {position: relative;}

.area_nav { display: none; }
.btn_sns { width: 50px; height: 50px; margin: 0 2% 0 0; background: rgba(255, 255, 255, 0.9); border-radius: 999px; /*display: grid; place-items: center;*/ }
/* 最新のsafari用*/
_::-webkit-full-page-media, _:future, :root .btn_sns { margin: 10px 2% 0 0; }
/* 古いsafari用*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
	::i-block-chrome, .btn_sns { margin: 10px 2% 0 0; }
}
.btn_sns a { display: inline-block; width: 50px; text-align: center; text-decoration: none; }
.btn_sns a img { width: 60%; max-width: 26px; vertical-align: middle; filter: brightness(0) invert(1); }





/* [02] メインビジュアル
---------------------------------*/
#box_intro .inr_box p.txt_stg { font-size: 1.25rem; }
#box_intro .inr_box p.txt { font-size: 1.0rem; line-height: 1.6; }


/* [03] 開催概要
---------------------------------*/
/* テーブル */
.tb_res { width: 100%; margin: 0% auto; }
.tb_res { border: none; }
.tb_res th { display: block; width: 94%; margin: 3% 0 0; padding: 6px 3%; border: none; color: #000; border-radius: 4px; background: #fff; }
.tb_res td { display: list-item; width: 94%; margin: 0 3% ; padding: 6px 0; border: none !important; list-style: none; font-size: 1.0rem; line-height: 1.6; }
.tb_res span.img_bnr { width: 100%; max-width: 160px; }

/* [04] チケット情報
---------------------------------*/
#box_window .flb { width: calc(96% - 0px); margin: 0 auto 30px; padding: 10px 0px 0; }
#box_window .flb > div { width: calc(100% / 2 - 20px); margin: 0 10px 20px; }

/* [05] お知らせ
---------------------------------*/
#box_news ul { width: 96%; }
#box_news li span.date { width: 100%; margin: 0; padding: 0; font-size: 1.0rem; line-height: 1.6; }
#box_news li span.title { width: 100%; margin: 0; padding: 0; font-size: 1.0rem; line-height: 1.6; }


/* [06] グッズ
---------------------------------*/

/* [07] アクセス
---------------------------------*/
#box_access .inr_box p.txt_stg { font-size: 1.4rem; }
#box_access .inr_box p.txt { font-size: 1.05rem; }


/* [08] SNS
---------------------------------*/


}


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

/* [01] 基本・レイアウト
---------------------------------*/

/* [02] メインビジュアル
---------------------------------*/

/* [03] 開催概要
---------------------------------*/

/* [04] チケット情報
---------------------------------*/
#box_window .flb { width: calc(96% - 20px); margin: 0 auto 30px; padding: 10px 10px 0; }
#box_window .flb > div { width: calc(100% / 1 - 20px); margin: 0 10px 30px; }

/* [05] お知らせ
---------------------------------*/

/* [06] グッズ
---------------------------------*/

/* [07] アクセス
---------------------------------*/

/* [08] SNS
---------------------------------*/





}

