@charset "UTF-8";
@import "reset5.css";

html {
  min-height: 100%;
  margin: 0;
  padding: 0;
  overflow-y: scroll;/* スクロールバーの有無によるズレ対策 !!///!*/
}
body {
  min-height: 100%;
  margin: 0;
  padding: 0;
  color: #002c49;
  font-family: altivo, zen-kaku-gothic-new, sans-serif,"ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "Meiryo", "Osaka", "MS Pゴシック", "MS PGothic", Helvetica, Arial;
  background-color: #fff;
  text-align: center;
  font-size: 15px;
  font-weight: 400;
  line-height:1;
  -webkit-text-size-adjust:none;/* iPhoneとかで横向きにすると文字サイズが自動調整をやめる */
  -webkit-font-smoothing: antialiased;
}

* { word-wrap: break-word; }
img { -ms-interpolation-mode: bicubic; }

h1,h2,h3,h4,h5,h6 { font-weight: 700; font-style: normal; letter-spacing: 0.04em; font-feature-settings: "palt" 1 }
body p { line-height: 2em; letter-spacing: 0.02em; font-feature-settings: "palt" 1 }
body li { letter-spacing: 0.02em; font-feature-settings: "palt" 1 }
iframe { overflow: hidden }
strong { font-style: normal; font-weight: 700 }

/* !clearfix */
hr { display: none; }

/* リストの高さ揃える */
.list-flex { display:-webkit-box;
	display:-moz-box;
	display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.cfix { /zoom : 1; }
.cfix:after { content : ''; display : block; clear : both; }

.fltR { float: right; }
.fltL { float: left; }

/* !Links */
a, a:link, a:visited {
  color: #002c49;
  text-decoration: none;
  font-weight: 500;
}
a:hover, a:active {
  color: #999;
  text-decoration: none;
  font-weight: 500;
}

a.dotline, a.dotline:link,
a.dotline:visited {
  border-bottom: 1px dotted #333;
  text-decoration: none;
  outline: none;
}
a.dotline:active,
a.dotline:hover {
  border-bottom:none;
  text-decoration: none
}
a:hover.ovalp {
  opacity: 0.6;
}
a.arrow {
  padding-left: 15px;
  background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2019/img/link_arrow.png) left center no-repeat;
}

/* Youtubeレスポンシブ */
.iframemov {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.iframemov iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

/* カラム */
.col_4,
.incol_5,
.incol_4,
.incol_3,
.incol_2 {
  margin: 0 -10px;
  font-size: 0;
  letter-spacing: -0.4em;
  word-spacing: -1em;
}
.col_4 li,
.incol_5 li,
.incol_4 li,
.incol_3 li,
.incol_2 li {
  float: left;
}
.incol_3 ul { margin: 0 -10px }
.incol_3 li {
  width: calc(33.33% - 20px);
  margin: 0 10px 40px;
}
.col_4 ul,
.incol_4 ul {
  margin: 0 -10px
}
.incol_5 li {
  width: calc(20% - 20px);
  margin: 0 10px 20px;
}
.col_4 li,
.incol_4 li {
  width: calc(25% - 20px);
  margin: 0 10px 20px;
}
.incol_2 ul {
  margin: 0 -20px
}
.incol_2 li {
  width: calc(50% - 40px);
  margin: 0 20px 20px;
}
.col_4 li img,
.incol_5 li img,
.incol_4 li img,
.incol_3 li img,
.incol_2 li img {
  width: 100%;
  margin-bottom: 15px !important;
}
.col_4 li img.mb0,
.incol_5 li img.mb0,
.incol_4 li img.mb0,
.incol_3 li img.mb0,
.incol_2 li img.mb0 {
  width: 100%;
  margin-bottom: 0 !important;
}
.col_4 li p,
.incol_5 li p,
.incol_4 li p,
.incol_3 li p,
.incol_2 li p {
  font-size: 13px !important;
  letter-spacing: 0.02em;
  word-spacing: normal;
  display: block;
}
.incol_3 li dl {
  margin-bottom: 40px;
  font-size: 13px;
  line-height: 1.8;
  letter-spacing: 0.02em;
  word-spacing: normal;
}
.incol_3 li dt {
  margin-bottom: 5px;
  font-weight: 500;
}
.incol_3 li dd.listen:before {
  content: "試聴：";
  font-weight: 500;
  font-size: 0.88em
}
.incol_3 li dd.official:before {
  content: "関連：";
  font-weight: 500;
  font-size: 0.88em
}
.incol_3 li dd.rookie:before {
  content: "YouTube：";
  font-weight: 500;
  font-size: 0.88em
}

.container { position: relative }

#wrapper {
  position: relative;
  min-height: 1000px;
  margin: 0;
  padding: 0 0 7.166vw;
  text-align: center;
  overflow: hidden;
  background-color: #fff;
  z-index: 10;
}
.bg2025 { position: relative; width: 100%; height: 7.166vw; background: url(../img/bg2025_02.png) no-repeat bottom; background-size: contain }

#loader { position: fixed; left: 50%; top: 50vh; margin: -8px 0 0 -20px; z-index: 10000; }

#top-mv {
  position: relative;
  width: 100%;
  margin: 60px 0 0;
  background-color: #3a3a3a;
  z-index: 100;
}
#top-mv h1 { position: absolute; left: 160px; top: 80px; z-index: 10; }
#top-mv ol { position: relative; width: 100%; margin: 0 auto }
#top-mv ol li { width: 100%; height: 700px; position: absolute; left: 0; top: 0; text-align: center; display: none }
#top-mv .bullets { position: absolute; left: 50%; top: 140px; z-index: 10; margin-left: -537px }
/*#top-mv .bullets li { float: left; margin-left: 0px; cursor: pointer }*/
#top-mv .bullets li { float: left; margin-left: -7px; cursor: pointer }
#top-mv .prev { position: absolute; left: 50px; top: 50%; margin-top: -17px;  z-index: 10; cursor: pointer }
#top-mv .next { position: absolute; right: 50px; top: 50%; margin-top: -17px;  z-index: 10; cursor: pointer }

#header_bar { position: fixed; left: 0; top: 0; width: 100%; height: 60px; padding: 0 0 5px; /*border-bottom: solid 2px #0592b9;*/ text-align: center; z-index: 10000 }
#header_bar h1 { height: 60px; /*border-bottom: solid 3px #00997b; background: rgba(234,226,219,1)*/ }
#header_bar h1 img { position: relative; margin-top: 6px }
#header_bar h1 span.bg { position: absolute; left: 0; top: 0; display: block; width: 100%; height: 60px; background: rgba(230,82,42,1); z-index: 0 }
#header_bar .lang { position: absolute; right: 40px; top: 10px }
#header_bar .lang li { float: left; line-height: 40px; color: #cfb39b }
#header_bar .lang li a { display: inline-block; padding: 0 0.5em; color: #fff !important; font-weight: 600; }
#header_bar .lang li.cur a { color: #a3252a !important }

#header { position: fixed; left: 0; top: 60px; min-width: 1080px; width: 100%; height: 80px; text-align: center; z-index: 1000; }
#home #header { left: inherit; top: inherit; background: #fff }
#header .header_inner { min-width: 1075px; background-color: #fff; padding: 6px 2.4vw 0; margin: 0 auto; position: relative; }
#global_nav { text-align: left }
#global_nav li a { display: block; position: relative }

#global_nav {
  text-align: left;
  letter-spacing: 0;
}
#global_nav li[class] {
  position: relative;
  display: block;
  float: left;
  font-weight: 500;
  line-height: 1;
  color: #999
}
#global_nav li[class]>a { position: relative; padding: 24px 16px; }
#global_nav li[class]>a i { position: relative; z-index: 10 }
#global_nav li[class]>a::after { content: ""; display: block; position: absolute; left: 0; bottom: 0; width: 100%; height: 100%; background: #ece7e2; opacity: 0.5; border-radius: 24px; transition: all 0.1s; z-index: 0; transform: scale(0); mix-blend-mode: multiply }
#global_nav li[class]:hover>a::after { transform: scale(1) }
#global_nav li[class]>a:link, .lang li[class]>a:link { color: #002c49 !important; text-decoration: none  }
#global_nav li[class]>a:visited, .lang li[class]>a:visited { color: #002c49 !important; text-decoration: none }
#global_nav li[class]>a:hover, .lang li[class]>a:hover { color: #a3252a !important; text-decoration: none }
#global_nav li[class]>a:active, .lang li[class]>a:active  { color: #a3252a; text-decoration: none }

#header_sp,
#menu-sp,
#menu_sp_btn { display: none }

#home #global_nav li.current { border-bottom: none; }
#global_nav li>a:hover, #news #global_nav li>a:link { color: #a3252a; }
#news #global_nav li.nav1>a::after { transform: scale(1) }
#guide #global_nav li.nav2>a::after { transform: scale(1) }
#artist #global_nav li.nav3>a::after { transform: scale(1) }
#ticket #global_nav li.nav4>a::after { transform: scale(1) }
#access #global_nav li.nav5>a::after { transform: scale(1) }
#stage #global_nav li.nav6>a::after { transform: scale(1) }
#goods #global_nav li.nav7>a::after { transform: scale(1) }
#gallery #global_nav li.nav8>a::after { transform: scale(1) }
#attention #global_nav li.nav9>a::after { transform: scale(1) }

#global_nav li ul {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 5px;
  padding: 0;
  overflow: hidden;
  background: #267163;
  border-radius: 16px;
}
#global_nav li ul li {
  width: 200px;
  height: 0;
  -moz-transition: .2s;
  -webkit-transition: .2s;
  -o-transition: .2s;
  -ms-transition: .2s;
  transition: .2s;
}
#global_nav li.nav7 ul li { width: 240px; }
#global_nav li ul li a,
#global_nav li ul li a:link {
  line-height: 50px;
  padding-left: 16px;
  color: #FFF !important;
}
#global_nav li ul li a:hover { background: #669b91; }
#global_nav li:hover ul li {
  overflow: visible;
  height: 50px;
}
#header .lang { position: absolute; right: 80px; top: 20px }
#header .lang li { float: left; line-height: 40px; color: #999 }
#header .lang li a { display: inline-block; padding: 0 1em; font-weight: 600; }
#header .lang li.cur a { color: #002c49 !important }

#header .sns_btn { position: absolute; right: 40px; top: 20px }
#header .sns_btn li { float: left; padding: 3px }

#wrapper { text-align: center; overflow: hidden; /*border-bottom: solid #db7700 40px;*/ }
#content { margin: 0 auto 120px; }
#content .content-inner { position: relative; min-width: 1080px; max-width: 1480px; padding: 0 80px; z-index: 10 }
#content .left_column { float: left; width: 250px; padding: 0 0 40px; text-align: left; position: relative }
#content .right_column { float: right; width: calc(100% - 280px); max-width: 1024px; margin-bottom: 80px; text-align: left; line-height: 2; opacity: 0; }
#home #content { margin: 120px auto 0; }
#home #content .left_column { float: left; width: 825px }
#home #content .right_column { float: right; width: 250px }

#footer {
  position: relative;
  padding: 60px 0 12vw;
  background-color: #dbcfc4;
  z-index: 10;
  color: #002c49;
  font-size: 14px;
  background: url(../img/bg2025_01.png) no-repeat bottom #dbcfc4;
  background-size: contain
}
#footer .footer_inner { min-width: 1080px; max-width: 1280px; margin: 0 auto; padding: 0 40px; text-align: left }
#footer .footer_inner .foot_logo {
  width: 25%;
  float: left;
}
#footer .footer_inner p { color: #005848; }
#footer .footer_inner .foot_logo img { margin: 0 0 12px }
#footer .footer_inner ul { width: calc(25% - 1em); padding: 0 0 0 1em; float: left }
#footer .footer_inner ul li { line-height: 2; margin-bottom: 1em; font-weight: 500 }
#footer .footer_inner ul li ul { width: auto; margin: 0.5em 0 0 0; float: none }
#footer .footer_inner ul li ul li { margin-bottom: 0 }
#footer a:link, #footer a:visited { color: #002c49; text-decoration: none }
#footer a:hover { color: #a3252a; text-decoration: none }
#footer a:active { color: #a3252a; text-decoration: none }

#footer .footer_inner ul.sns_btn { width: auto; margin: 2em 0 0; }
#footer .footer_inner ul.sns_btn li { float: left; padding: 3px }
#footer p.copyright {
  color: #002c49;
  margin: 40px 0 0 275px;
  font-size: 12px;
}
/*プレサイト*/
.last-year { padding: 80px 0 120px; background: #f5f3f0 }
.last-year-inner { max-width: 1080px; margin: 0 auto }
#footer.pre-site { padding-bottom: 12vw }
#footer.pre-site .footer_inner { min-width: auto; max-width: 1080px; }
#footer.pre-site .footer_inner .foot_logo { width: 33.33% }
#footer .footer_inner ul.sns_btn li { padding: 3px 6px }
#footer.pre-site .footer_inner ul.sns_btn li a img {
  width: 40px;
}
#footer.pre-site  p.copyright { margin: 20px 0 0 33.33%; }

.backto { border-top: solid 2px #f5f3f0 }
.backto a { display: block; padding: 1.25em 0; font-size: 18px; font-weight: 600; letter-spacing: 0.06em; text-align: center; border-top: solid 1px #fff; transition: all 0.2s }
.backto a:hover { background: #f9f7f5; border-top: solid 1px #d9cfc5 }
.backto a span { position: relative; display: inline-block; padding-left: 52px }
.backto a span::before { content: ""; position: absolute; display: block; left: 0; top: calc(50% - 18px); width: 36px; height: 36px; background: url("../img/arw_back.png") no-repeat; background-size: contain; mix-blend-mode: multiply; transition: all 0.2s }
.backto a:hover span::before { left: -2px }

#pagetop { position: fixed; display: block; width: 60px; height: 60px; padding: 10px; background: #fff; right: 0; bottom: 0; cursor: pointer; z-index: 1000 }

/*===============================================
HOME 2020 Grid System
===============================================*/
.top-grid { position: relative; padding: 0 0 20px; margin: 0; z-index: 10; }
.top-grid h2 { margin: 1.2vw 0 0; padding: 0 }
.top-grid ul { padding: 0.6vw 1.2vw 1.2vw; /zoom : 1; }
.top-grid ul:after { content : ''; display : block; clear : both; }
.top-grid ul li { float: left }
.top-grid ul li .grid-inner { padding: 1.2vw }
.top-grid ul li a { display: block; position: relative; transition: all 0.2s }
.top-grid ul li a h2 { position: absolute; left: 4%; bottom: 4%; color: #fff; z-index: 10; text-align: left; width: 92%; line-height: 1.6; vertical-align: bottom; padding: 0; margin: 0 !important; }
.top-grid ul li a .cv { position: absolute; left: 0; top: 0; width: 100%; height: 100%; background: url(../img/top_cv01.png);background-size: cover; display: block; mix-blend-mode: multiply; z-index: 1 }
.top-grid ul li a .ph { position: relative; z-index: 0; transition: all 0.2s }
.top-grid ul li a .cate { position: absolute; left: 0; top: 0; padding: 6px; color: #fff; font-size: 10px; letter-spacing: 0; background-color: #005848; vertical-align: top; line-height: 1; z-index: 10; }
.top-grid ul li a:hover { transform: scale(1.04) }
.top-grid ul li a:hover .ph { box-shadow: 8px 8px 20px 0 #e7e7e7 }
.top-grid ul li h3 { text-align: left; font-size: 14px; padding: 20px 0 0 !important; margin: 0 !important; font-weight: 500; line-height: 1.4; }
.top-grid ul li p { text-align: left; font-size: 13px; margin-top: 0.5em; font-weight: normal }

.top-grid ul li .lang { position: relative }
.top-grid ul li .lang a { width: 36% }
.top-grid ul li .lang a.en { position: absolute; left: 50%; top: 66%; margin-left: -37% }
.top-grid ul li .lang a.cn { position: absolute; left: 50%; top: 66%; margin-left: 1% }

.top-grid ul li a .cate { font-weight: 600; background-color: #005848 }
.top-grid ul li a:hover h2 { color: #005848 }

.grid-three li { width: 33.33% }
.grid-four li { width: 20% }
.grid-five li { width: 20% }
.grid-ad li { width: 20% }
.grid-four ul li a h2 { font-size: 14px }

#top-feature { padding-top: 40px }
#top-feature ul li a:hover { margin: -12px; transform: none }
#top-feature ul li a .cate { padding: 14px; font-size: 14px; letter-spacing: 0.02em; }
#top-feature ul li a h2 { font-size: 20px }
#top-news { /*background: #dae8ee;*/ padding-top: 40px }
#top-news h2 { color: #a3252a; font-size: 36px; line-height: 1em }
#top-news h2 a { color: #a3252a; font-weight: 700 }
#top-news li h2 { color: inherit; font-size: 18px; line-height: 1.5em; letter-spacing: 0.06em; font-weight: 500; text-align: left }
#top-news li p { line-height: 1em }
#top-news li p .date { color: #999; font-size: 11px; }
#top-officialitem { /*background: #e5f5f2;*/ padding-top: 40px; }
#top-officialitem h2 { color: #87412e; font-size: 32px; line-height: 1em }
#top-officialitem li h3 { font-size: 16px; }
#top-smashinfo h2 { color: #c0481c; font-size: 32px; line-height: 1em }
#top-smashinfo h2 img { height: 32px; margin-right: 0.33em }
#top-smashinfo { padding-top: 40px; }
#top-smashinfo li h3 { font-size: 16px; }
#ad { padding: 40px 0 120px; margin: 0; }
#ad h2 { color: #ac5e27; font-size: 32px; line-height: 1em }
#ad h2 a { color: #ac5e27; font-weight: 700 }
#ad .ad-inner { width: 1075px; margin: 0 auto; }
#ad .ad-inner a { display: block }
#ad .aca { padding: 2em 0 0; }
#ad .aca p { font-size: 12px; margin-top: 1em }
#youtube { display: none; }

@media screen and (max-width: 1760px){
	.grid-three li { width: 33.33% }
	.grid-four li { width: 25% }
}


/*===============================================
第2階層
===============================================*/
#news #wrapper, #guide #wrapper, #artist #wrapper, #stage #wrapper, #ticket #wrapper, #gallery #wrapper, #gallery #wrapper, #goods #wrapper, #access #wrapper, #attention #wrapper, #global #wrapper, #fesgohan #wrapper {
  padding: 200px 0 0;
  text-align: left;
}
.sec h1 {
  margin-bottom: 1em;
  font-size: 24px;
  font-weight: 500;
}
.sec h2 {
  margin-bottom: 1em;
  font-size: 18px;
}
.sec h3 {
  margin-bottom: 1em;
  font-size: 16px;
}
.sec h4 {
  margin-bottom: 0.5em;
  font-size: 15px;
}
.sec {
  margin-bottom: 120px;
}
.sec article {
  margin-bottom: 80px;
}

#content span.date {
  display: block;
  margin: -30px 0 40px;
  color: #999;
  font-size: 11px;
}
table {
  width: 100%;
  border-top: 1px solid #DDD;
  line-height: 2;
}
table.nb {
  border-top: none;
}
table.tbl {
	width: auto
}
table th, table td {
  padding: 1em;
  border-bottom: 1px solid #DDD;
}
table th {
  font-weight: 500;
}
/*table td:last-child {
  padding: 1em 0;
}*/
table.tbl th, table.tbl td {
  padding: 1em;
	vertical-align: top
}
table.tbl td:last-child  {
  padding: 1em;
}
table ul, .note ul , .note2 ul , .note3 ul , .note-d1 ul , .note-d2 ul , .note-d3 ul {
  padding-left: 2em;
  list-style-type: square;
}
table.tb_pln {
  border: none;
}
table.tb_pln th, table.tb_pln td {
  padding: 0 2em 0 0;
  border: none;
  vertical-align: top;
}
table th.colored,
table td.colored {
  background: #EEE;
}
.note {
  padding: 20px;
  background-color: #f6f6f6;
}
.note2 {
  padding: 20px;
  background-color: #fbf4ee;
}
.note-d1 {
  padding: 20px;
  background-color: #d9e9da;
}
.note-d2 {
  padding: 20px;
  background-color: #d8dcf5;
}
.note-d3 {
  padding: 20px;
  background-color: #f7ddd5;
}
.note3 {
  padding: 20px;
  background-color: #228e39;
}
.note h3 {
  margin: 0;
}
.note2 h3 {
  margin: 0;
}
.note-d1 h3 {
  margin: 0;
}
.note-d2 h3 {
  margin: 0;
}
.noted3 h3 {
  margin: 0;
}
.note3 h3 {
  margin: 0;
}

/* 2カラムボタン */
.half_left {
  float: left;
  width: 45%;
}
.half_right {
  float: right;
  width: 45%;
}

/* サイドメニュー */
.left_column h1 {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0;
  margin-bottom: 1em;
  color: #005848;
}
#sidemenu {
  margin: 0 0 20px;
  padding: 0;
}
#sidemenu li {
  padding: 0 0 10px;
  line-height: 2;
  font-weight: 500;
}
#sidemenu li a {
  position: relative;
  display: block;
  padding-left: 1.12em;
  font-size: 15px;
}
#sidemenu li a::before {
  content: ""; display: block; position: absolute; left: 0; top: calc(50% - 5px); width: 10px; height: 10px; background: url(/2025/assets/img/arw_right_s.png) no-repeat; background-size: contain; mix-blend-mode: multiply;
}
#sidemenu li a:link {
  color: #000;
}
#sidemenu li a:hover,
#sidemenu li a:active {
  color: #999;
}

/* ボタンメニュー */
.sec ul.btnmenu {
  padding: 0 !important;
  /*display: flex;*/
}
.btnmenu li {
  float: left;
  list-style: none;
  width: 33.3%;
  padding: 0 !important;
  margin: 0 !important;
}
.btnmenu.wid2 li {
  width: 50%;
}
.btnmenu li a {
  display: block;
  padding: 15px 5px;
  font-size: 13px;
  text-align: center;
  line-height: 1;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
  display: -webkit-flex;
  display: flex;
 -webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
 align-items: center; /* 縦方向中央揃え */
 -webkit-justify-content: center; /* 横方向中央揃え（Safari用） */
 justify-content: center; /* 横方向中央揃え */
}
.btnmenu li a:link { color: #FFF; }
.btnmenu li a:hover { color: #fff; background-color: #ccc !important;}
.btnmenu li a:active { color: #fff; }
.btnmenu li a:visited { color: #fff; }
#artist .btnmenu li a {
  background-color: #a9d134;
}
#guide .btnmenu {
	margin-bottom: 4em;
}
#news .btnmenu li a {
  background-color: #14385c;
}
#guide .btnmenu li a {
  background-color: #50c4b8;
}
#attention .btnmenu li a {
  background-color: #8c8c8c;
}

/* ボタンメニュー（ニュース） */
.sec ul.btnmenu_news {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  padding-left: 0;
}
.btnmenu_news li {
  flex-grow: 1;
  list-style: none;
}
.btnmenu_news li a {
  display: block;
  padding: 15px 10px;
  font-size: 13px;
  text-align: center;
  line-height: 1;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
}
.btnmenu_news li a:link { color: #FFF; }
.btnmenu_news li a:hover { color: #fff; background-color: #ccc !important;}
.btnmenu_news li a:active { color: #fff; }
.btnmenu_news li a:visited { color: #fff; }
#news .btnmenu_news li a {
  background-color: #66b0c7;
}

/* ボタンメニュー（ピックアップ） */
.sec ul.btnmenu_pickup {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  padding-left: 0;
}
.btnmenu_pickup li {
  flex-grow: 1;
  list-style: none;
  width: 33.3%;
}
.btnmenu_pickup li a {
  display: block;
  padding: 15px 10px;
  font-size: 13px;
  text-align: center;
  line-height: 1;
  border-right: 1px solid #FFF;
  border-bottom: 1px solid #FFF;
}
.btnmenu_pickup li a:link { color: #FFF; }
.btnmenu_pickup li a:hover { color: #fff; background-color: #ccc !important;}
.btnmenu_pickup li a:active { color: #fff; }
.btnmenu_pickup li a:visited { color: #fff; }
#news .btnmenu_pickup li a {
  background-color: #66b0c7;
}

/* ニュース */
#news h1.bigtit { margin-top: 1.2em }
#news #topics { padding: 0; margin: 0 0 20px; }
#news #topics li { padding: 0 0 20px; line-height: 2; list-style-type: none; font-weight: 500 }
#news .sec #topics li { font-size: 15px; }
#news #topics li .date { color: #999; font-size: 11px; margin: 0; display: block; }
#news #topics li a {
  display: block;
  letter-spacing: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
#news #topics li a:link, #home #topics li a:visited  { color: #000 }
#news #topics li a:hover { color: #999; }
#news #topics li a:active { color: #fff; }

#news #topics li.bn_btn { padding: 0; text-align: center; line-height: 2; }
#news #topics li.bn_btn a { padding: 1em 0; display: block; font-size: 15px; font-weight: 500; background-color: #005848; border-radius: 15px }
#news #topics li.bn_btn a:link, #news #topics li.bn_btn a:visited { color: #fff; }
#news #topics li.bn_btn a:hover { color: #fff; background-color: #79a199; }
#news #topics li.bn_btn a:active { color: #000; }

#news .sec #topics li { margin-bottom: 20px; border-bottom: dotted 1px #c7c7c7 }
#news .sec #topics li:last-child { margin-bottom: 0; }

.news_btn { display: block !important; text-align: center; line-height: 2; border: 2px solid #000; border-radius: 15px; overflow: hidden }
.news_btn a { padding: 1em 0; display: block; font-size: 15px; font-weight: 500 }
.news_btn a:link { color: #000 }
.news_btn a:hover { background: #000; color: #FFF }
.news_btn a:active { color: #000 }
.nvy_btn { display: block !important; text-align: center; line-height: 2; border: 2px solid #14385c; border-radius: 15px; overflow: hidden }
.nvy_btn a { padding: 1em 0; display: block; font-size: 15px; font-weight: 500 }
.nvy_btn a:link { color: #14385c }
.nvy_btn a:hover { background: #14385c; color: #FFF }
.nvy_btn a:active { color: #14385c }

#news ol li {
  margin-left: 2em;
  list-style-type: decimal;
}

.news_thumb {
  display: block;
  padding-left: 40px;
  line-height: 40px;
}
.news_thumb { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/news/img/icon_thumbup.png) no-repeat; }

.vote {
  margin-top: 15px;
  padding: 7px 0;
  background: #f6f6f6;
  text-align: center;
  -moz-transition: .2s;
  -webkit-transition: .2s;
  -o-transition: .2s;
  -ms-transition: .2s;
  transition: .2s;
}
.vote:hover {
  background: #DDD;
}

#relation_news {
  margin-top: 120px;
}
#relation_news div {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#relation_news p {
  font-size: 13px !important;
}
#relation_news p span.date { margin: 0 }
#relation_news a {
  display: block;
  width: 48%;
}
#relation_news img {
  width: 100%;
  margin-bottom: 10px;
}
#news li p .cate_fesgohan {
  padding: 5px 7px;
  color: #666666;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0;
  background-color: #dddddd;
  line-height: 1.2;
}
.pickup15 {
  margin-bottom: 100px;
  padding-left: 0 !important;
}
.pickup15 li {
  float: left;
  width: 25%;
  list-style: none;
}
a.picup15_btn {
  display: block;
  padding: 1em;
  font-size: 13px;
  text-align: center;
  line-height: 2;
}
a.picup15_btn:link { color: #FFF; }
a.picup15_btn:hover { color: #fff; background-color: #ccc; }
a.picup15_btn:active { color: #fff; }
a.picup15_btn:visited { color: #fff; }
.menu1 { background-color: #cccccc; }

/* 開催概要 */
/* FAQ */
#faq label {
  display: block;
  cursor: pointer;
}
#faq label:hover {
  color: #999;
}
#faq input {
  display: none;
}
#faq table div {
  display: none;
}
#faq table div span {
  display: block;
  margin-top: 10px;
  padding: 20px;
  background: #f2f2f2;
}
#faq table div p,
#faq table div ul {
  margin-bottom: 1em !important;
  font-size: 13px !important;
}
#faq table div p:last-child {
  margin-bottom: 0 !important;
}
#faq img {
  width: 100%;
}

.faq .faq-cont { border-top: solid 1px #ccc; }
.faq .faq-cont:last-child { border-bottom: solid 1px #ccc; }
.faq .faq-cont h2 { font-weight: 500; padding: 1em 0; margin: 0; display: block; cursor: pointer }
.faq .faq-cont h2:hover { opacity: 0.5 }
.faq .faq-cont h2 span { font-size: 24px; color: #a3252a; font-weight: bold }
.faq .faq-cont .answr { padding: 2em; background: #f7f7f7; display: none }
.faq .faq-cont .answr h3 { font-size: 15px !important; font-weight: 550; margin-bottom: 0 }
.faq .faq-cont .answr p { font-size: 14px !important }
.faq .faq-cont .answr p a:link, .faq .faq-cont .answr p a:visited { color: #a3252a }
.faq .faq-cont .answr p a:hover { color: #999 }
.faq .faq-cont .answr p:last-child { margin-bottom: 0 !important }

.sec ul.supporter {
  margin-bottom: 30px;
  padding: 0;
}
ul.supporter li {
  display: inline;
  margin: 0;
  list-style-type: none;
}
ul.supporter li img {
  width: auto !important;
  margin: 0 20px 20px 0;
}

/* アーティスト */
.artistlist {
  border: none;
  line-height: 1.8;
  letter-spacing: 0;
}
.artistlist:first-child {
	margin-bottom: 0;
}
.artistlist:first-child th {
  border: none;
}
.artistlist th {
  padding: 0 0 20px;
  text-align: center;
}
.artistlist td {
  position: relative;
  width: 33.3%;
  border-right: 1px dashed #DDD;
}
.artistlist td:last-child {
  border-right: none;
}
.artistlist td a {
  display: block;
  padding-left: 10px;
}
.artistlist td.suspension {
  background: #f2f2f2;
}
#gallery .artistlist td {
  padding-left: 10px;
}
.artistlist td.logo {
  padding: 1em 0;
  text-align: center;
}
.artistlist td.logo img {
  margin: 0;
}
.artistlist td.stage {
  margin-top: 100px !important;
  font-weight: 500;
  text-align: center;
  color: #FFF;
}
.artistlist tr:nth-child(2) {
  border-top: 1px solid #ddd;
}
.artistlist tr:last-child td {
  border-bottom: none;
}
.artistlist td.dateimg img {
  width: 100%;
  margin: 0;
}
#artist td.more {
  color: #999;
  text-align: center;
}
.artistlist td.sub { background: #CCC; }
.artistlist td#green { background: #6ea400; }
.artistlist td#white { background: #929292; }
.artistlist td#red { background: #ff3300; }
.artistlist td#heaven { background: #1ccbe3; }
.artistlist td#avalon { background: #9d1257; }
.artistlist td#mokudotei { background: #9e5c28; }
.artistlist td#orange { background: #ffa000; }
.artistlist td#palace { background: #129d89; }
.artistlist td#naeba { background: #9d9812; }
.artistlist td#day { background: #4e4ae4; }
.artistlist td#pyramid { background: #920e82; }
.artistlist td#paris { background: #022e6d; }
.artistlist td#busker { background: #004097; }
.artistlist td#cabaret { background: #cd1f32; }
.artistlist td#day { background: #4844e4; }
.artistlist td#ganban { background: #000; }
.artistlist td#galaxy { background: #3a5582; }
.artistlist td#unfairground { background: #fd0002; }
.artistlist td#anf { background: #002c71; }
.artistlist td#echo { background: #ffb343; }
/*.artistlist td#rookie { background: #129d89; }*/
.new:before {
  content: url(https://cdn.fujirockfestival.com/smash/frf/assets/2019/img/icon_new.png);
  position: absolute;
  top: 0;
  right: 0;
}
.new_thumb:before {
  content: url(https://cdn.fujirockfestival.com/smash/frf/assets/2019/img/icon_new.png);
  position: absolute;
}

#date_menu {
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 1000;
  display: none;
}
#date_menu li {
  float: left;
  width: 33.3%;
  text-align: center;
  font-weight: 500;
}
#date_menu li a {
  display: block;
  color: #FFF;
  line-height: 40px;
}
#date_menu li a span { font-size: 19px !important }
#date_menu li:nth-child(1) {
  background: #adcc3f;
}
#date_menu li:nth-child(2) {
  background: #8ba23b;
}
#date_menu li:nth-child(3) {
  background: #6f822f;
}

.timetable, timetable_sp {
  margin-bottom: 100px;
  padding-left: 0 !important;
}
.timetable:last-child { margin-bottom: 0 !important; }
.timetable li {
  float: left;
  width: 33.3%;
  list-style: none;
}
a.timetable_btn {
  display: block;
  padding: 15px;
  font-size: 13px;
  text-align: center;
  line-height: 1;
  font-weight: 600;
}
a.timetable_btn:link { color: #FFF; }
a.timetable_btn:hover { color: #fff; opacity: 0.5 }
a.timetable_btn:active { color: #fff; }
a.timetable_btn:visited { color: #fff; }
.date1 { background-color: #245749; }
.date2 { background-color: #0e2b47; }
.date3 { background-color: #d55c39; }

#artistdata article {
  width: 100%;
  margin: 0;
  text-align: left;
  font-size: 15px;
  line-height: 2;
}
#artistdata h1 {
  margin: 7%;
  line-height: 2;
}
#artistdata h1 span {
  /*margin-left: 1em;*/
  font-size: 15px;
  color: #999;
  font-weight: normal;
  display: block;
}
#artistdata dl {
  margin: 7%;
}
#artistdata dt {
  margin-bottom: .5em;
  font-weight: 500;
  font-size: 13px;
  border-bottom: 1px solid #ddd;
}
#artistdata dd {
  margin-bottom: 2em;
}
#artistdata dd.artistmov {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
#artistdata dd iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
#artistdata li {
  font-size: 13px;
}
#artistdata .goods_btn { margin: 7%; padding: 0; text-align: center; line-height: 1.2; background-color: #adcc3f; }
#artistdata .goods_btn a { padding: 15px 0; display: block; font-size: 15px; }
#artistdata .goods_btn a:link { color: #FFF; }
#artistdata .goods_btn a:hover { color: #fff; background-color: #ccc; }
#artistdata .goods_btn a:active { color: #000; }

#playlist_1, #playlist_2, #playlist_3, #playlist_4, #playlist_5, #playlist_6, #playlist_7 {
  display: block;
  padding-left: 75px;
  line-height: 60px;
}
#playlist_1 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist01_thumb.png) no-repeat; }
#playlist_2 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist02_thumb.png) no-repeat; }
#playlist_3 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist03_thumb.png) no-repeat; }
#playlist_4 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist04_thumb.png) no-repeat; }
#playlist_5 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist05_thumb.png) no-repeat; }
#playlist_6 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist06_thumb.png) no-repeat; }
#playlist_7 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2024/artist/img/playlist07_thumb.png) no-repeat; }


/* チケット */
#ticket_1, #ticket_2, #ticket_3, #ticket_4, #ticket_5, #ticket_6, #ticket_7,
#playguide_1, #playguide_2, #playguide_3, #playguide_4, #playguide_5, #playguide_6, #playguide_7, #playguide_8, #playguide_9, #playguide_10, #playguide_11, #playguide_12, #playguide_13, #playguide_14, #playguide_15, #playguide_16, #playguide_17, #playguide_18, #playguide_19, #playguide_20, #playguide_21 {
  display: block;
  padding-left: 75px;
  line-height: 60px;
}
#ticket_1 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }
#ticket_2 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }
#ticket_3 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }
#ticket_4 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }
#ticket_5 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }
#ticket_6 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }																																																																																																																																									#ticket_7 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/icon_ticket25.png) no-repeat; }																																																																																																																																							
#playguide_1 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket01_thumb.png) no-repeat; }
#playguide_2 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket02_thumb.png) no-repeat; }
#playguide_3 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket03_thumb.png) no-repeat; }
#playguide_4 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket04_thumb.png) no-repeat; }
#playguide_5 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket05_thumb.png) no-repeat; }
#playguide_6 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket06-2_thumb.png) no-repeat; }
#playguide_7 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket07_thumb.png) no-repeat; }
#playguide_8 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket08_thumb.png) no-repeat; }
#playguide_9 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket09_thumb.png) no-repeat; }
#playguide_10 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket10_thumb.png) no-repeat; }
#playguide_11 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket11_thumb.png) no-repeat; }
#playguide_12 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket12_thumb.png) no-repeat; }
#playguide_13 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket13_thumb.png) no-repeat; }
#playguide_14 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket14_thumb.png) no-repeat; }
#playguide_15 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket15_thumb.png) no-repeat; }
#playguide_16 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket16_thumb.png) no-repeat; }
#playguide_17 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket17_thumb.png) no-repeat; }
#playguide_18 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket18_thumb.png) no-repeat; }
#playguide_19 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket19_thumb.png) no-repeat; }
#playguide_20 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket20_thumb.png) no-repeat; }
#playguide_21 { background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2025/ticket/img/ticket21_thumb.png) no-repeat; }
#ticket table .price {
  color: #fb6942;
  font-weight: 500;
}
a.ticket_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #f2b425;
}
a.access_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #ef732e;
}
a.pickup_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #53b2c9;
}
a.guide_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #56c3b8;
}
a.goods_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #a76aac;
}
a.history_btn {
  display: block;
  padding: 15px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 1;
  background-color: #7c7bce;
}
a.attention_btn {
  display: block;
  padding: 1em;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  line-height: 2;
  background-color: #8c8c8c;
}																																													a.ticket_btn:link, a.access_btn:link, a.pickup_btn:link, a.guide_btn:link, a.goods_btn:link, a.history_btn:link, a.attention_btn:link { color: #fff; }
a.ticket_btn:hover, a.access_btn:hover, a.pickup_btn:hover, a.guide_btn:hover, a.goods_btn:hover, a.history_btn:hover, a.attention_btn:hover { color: #fff; background-color: #ccc; }
a.ticket_btn:active, a.access_btn:active, a.pickup_btn:active, a.guide_btn:active, a.goods_btn, a.history_btn, a.attention_btn:active { color: #fff; }
a.ticket_btn:visited, a.access_btn:visited, a.pickup_btn:visited, a.guide_btn:visited, a.goods_btn:visited, a.history_btn:visited, a.attention_btn:visited { color: #fff; }
a.global_btn {
  display: block;
  padding: 1em;
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  text-align: center;
  line-height: 2;
  background-color: #005848;
  border-radius: 15px;
}
a.global_btn:link { color: #fff; }
a.global_btn:hover { color: #fff; background-color: #669b91; }
a.global_btn:active { color: #fff; }
a.global_btn:visited { color: #fff; }

/* アクセス */
#access1 h1,#access2 h1,#access3 h1,#access4 h1 { position: relative; line-height: 48px; padding-left: 100px }
#access1 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 48px; background: url(../img/icon_access01.png); background-size: contain }
#access2 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 48px; background: url(../img/icon_access02.png); background-size: contain }
#access3 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 48px; background: url(../img/icon_access03.png); background-size: contain }
#access4 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 48px; background: url(../img/icon_access04.png); background-size: contain }
#lodge1 h1,#lodge2 h1,#lodge3 h1 { position: relative; line-height: 60px; padding-left: 100px }
#lodge1 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 60px; background: url(../img/icon_access05.png); background-size: contain }
#lodge2 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 60px; background: url(../img/icon_access06.png); background-size: contain }
#lodge3 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 60px; background: url(../img/icon_access07.png); background-size: contain }
#tour1 h1 { position: relative; line-height: 48px; padding-left: 100px }
#tour1 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 48px; background: url(../img/icon_access02.png); background-size: contain }
#tour2 h1 { position: relative; line-height: 60px; padding-left: 100px }
#tour2 h1:before { content:''; display: block; position: absolute; left: 0; top: 0; width: 80px; height: 60px; background: url(../img/icon_access06.png); background-size: contain }

/* ステージ */
#stage dl {
  float: left;
  width: calc(33% - 40px);
  margin: 0 20px;
  margin-bottom: 60px;
  line-height: 2;
}

#stage dt, #stage dd {
  position: relative;
  padding: 1em 2em 1em 0;
  border-bottom: 1px solid #DDD;
}
#stage dd a {
  display: block;
}

#stagedata article {
  width: 100%;
  margin: 0;
  text-align: left;
  font-size: 15px;
  line-height: 2;
}
#stagedata div.cfix {
  background: #000;
}
#stagedata img {
  float: left;
}
#stagedata .inner-block {
    padding: 7vw
}
#stagedata h1 {
  line-height: 2;
  margin-bottom: 7vw;
}
/*#stagedata p {
  margin: 7%;
}*/
#stagedata article .sec {
  display: none;
}
#stagedata h1.new:before {
  content: url(https://cdn.fujirockfestival.com/smash/frf/assets/2019/img/icon_new.png);
  position: relative;
  margin-right: 10px;
}


/* グッズ */
#goods li img {
  position: relative;
  margin: 0 0 10px;
}
#goods li h3 {
  font-weight: 500;
  margin: 0 0 10px;
  line-height: 1.8;
}
#goods li p .cate {
  padding: 5px 7px;
  color: #fff;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0;
  background-color: #b264b0;
  line-height: 1.2;
}
#goods li h3 {
  font-size: 13px;
  letter-spacing: 0.08em;
}
#goods li p.sub {
  font-size: 11px;
  color: #999;
  letter-spacing: 0.08em;
}
#goods li p.sub:before {
  content: "– ";
}


/* ヒストリー */
#instaWrapper {
  position: relative;
  width: 100%;
  padding: 100% 0 0 0;
}
#instaWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#gallery_info { margin-top: 2.4em }
#gallery_info table {
  float: left;
  width: 66%;
}
#gallery_info p {
  float: left;
  width: 66%;
}
#poster {
  float: right;
  width: calc(33% - 50px);
  margin-left: 50px;
}
#poster img {
  width: 100%;
}


/* 注意事項 */
#attention #local_nav { position: relative; height: 53px }
#attention #local_nav ul { position: absolute; right: 0; top: 0 }


/*===============================================
2021 General 
===============================================*/
.sec ul {
  padding-left: 1.2em;
}
.sec ul li {
  padding: 0.25em 0
}
.sec ul.sq {
  padding-left: 1.2em;
  list-style-type: square;
}
.sec ul.sq li {
	padding: 0.25em 0
}
.sec ul.cir {
  padding-left: 1.2em;
  list-style-type: circle;
}
.sec ul.cir li {
	padding: 0.25em 0
}
.sec ul li.circle,
.sec ul li.asterisk,
.sec ul li.asterisk_ {
  list-style-type: none;
}
.sec ul li.circle:before {
  content: "● ";
  margin-left: -1.2em;
}
.sec ul li.asterisk:before {
  content: "※ ";
  margin-left: -1.2em;
}
.sec ul li.asterisk_:before {
  content: "* ";
  margin-left: -1em;
}
.ind { padding-left: 1.2em; }
.ind_ { padding-left: 1.2em; text-indent: -1.2em }
.sec ol { margin-left: 2em }
.sec ol li { list-style-type: decimal }

.sec table.pln { border: none }
.sec table.pln th { font-style: normal; padding: 0.25em 1.2em; min-width: 1em; border: none; white-space: nowrap; vertical-align: top }
.sec table.pln td { font-style: normal; padding: 0.25em 1.2em; border: none; }

.txtC { text-align: center !important }
.txtL { text-align: left !important }
.txtR { text-align: right !important }

.mt-0, .mt0 { margin-top: 0 !important }
.mt-05 { margin-top: 0.5em !important }
.mt-1 { margin-top: 1em !important }
.mt-2 { margin-top: 2em !important }
.mt-3 { margin-top: 3em !important }
.mt-4 { margin-top: 4em !important }
.mt-5 { margin-top: 5em !important }
.mt-6 { margin-top: 6em !important }
.mt-8 { margin-top: 8em !important }
.mt-10 { margin-top: 10em !important }
.mt-12 { margin-top: 12em !important }
.mb-0, .mb0 { margin-bottom: 0 !important }
.mb-05 { margin-bottom: 0.5em !important }
.mb-1 { margin-bottom: 1em !important }
.mb-2 { margin-bottom: 2em !important }
.mb-3 { margin-bottom: 3em !important }
.mb-4 { margin-bottom: 4em !important }
.mb-5 { margin-bottom: 5em !important }
.mb-6 { margin-bottom: 6em !important }
.mb-8 { margin-bottom: 8em !important }
.mb-10 { margin-bottom: 10em !important }
.mb-12 { margin-bottom: 12em !important }

.pbox { padding: 1.2em; background: #f7f7f7 }
.pbox.bg1 { background: #dcf0f4 }
.pbox.bg2 { background: #dcf3f1 }
.pbox.bg3 { background: #eff5d9 }
.pbox.bg4 { background: #fcf0d3 }
.pbox.bg5 { background: #fce3d5 }
.pbox.bg6 { background: #f5dde4 }
.pbox.bg7 { background: #f0e0ef }
.pbox.bg8 { background: #e5e5f5 }
.pbox.bg9 { background: #e8e8e8 }
.pbox.bg25be { background: #f0eae6 }
.pbox.bg25or { background: #fbedeb }
																																																																																																																																																																																														
.tc1 { color: #4eb2ca }
.tc2 { color: #50c4b8 }
.tc3 { color: #adcc3f }
.tc4 { color: #f2b425 }
.tc5 { color: #ef732e }
.tc6 { color: #50c4b8 }
.tc7 { color: #a76aac }
.tc8 { color: #7d7dcc }
.tc9 { color: #8c8c8c }

.ts-9 { font-size: 9px !important; }
.ts-10 { font-size: 10px !important; }
.ts-11 { font-size: 11px !important; }
.ts-12 { font-size: 12px !important; }
.ts-13 { font-size: 13px !important; }
.ts-14 { font-size: 14px !important; }
.ts-15 { font-size: 15px !important; }
.ts-16 { font-size: 16px !important; }
.ts-18 { font-size: 18px !important; }
.ts-20 { font-size: 20px !important; }
.ts-24 { font-size: 24px !important; }
.ts-larger { font-size: 1.12em !important }
.ts-smaller { font-size: 0.88em !important }
.ts-smallest { font-size: 11px !important }
.uline { text-decoration: underline }

/*===============================================
2021 COVID Guideline
===============================================*/
.gl-menu li a { min-height: 18px !important }
h2.bb-2 { border-bottom: solid 2px #e66604; padding-bottom: 0.66em }
.bg21-tit { padding: 2em; color: #fff; background: #ff5a2d }
.bg21 { padding: 2em 2em 4em; background: url(../img/bg21.jpg) center; background-size: cover }
.rc-wrap { padding: 2em; background: rgba(247, 245, 233, 0.9); border-radius: 20px }
.guideline p a:link, .guideline p a:visited { color: #50c4b8 }
.guideline p a:hover { color: #999 }
.guideline span.ts-larger { font-family: ryo-gothic-plusn, sans-serif;
font-weight: 500;
font-style: normal; }
.sec ul.ico li { padding-left: 220px; position: relative; min-height: 200px }
.sec ul.ico li li { padding-left: 0; min-height: inherit }
.sec ul.ico li img.icon { position: absolute; left: -1.2em; top: 0.25em; width: 200px; border-radius: 20px }
.sec ul.ico li .ts-larger { font-weight: bold; color: #ef9936 }

.bl-menu li a { min-height: 18px !important }


/*===============================================
2021 Photo Gallery
===============================================*/
.photo-gallery { margin: -10px -10px 0; }
.photo-gallery li { width: 25%; float:left; }
.photo-gallery li .pg-inner { padding: 10px; }
.photo-gallery li .pg-inner a { overflow: hidden; display: block; font-size: 0; background: #f7f7f7; border: solid #7d7dcc; border-width: 0 1px 1px 0; border-radius: 5px }
.photo-gallery li .pg-inner a img { vertical-align: bottom; margin: 0 }
#lay { position: fixed; left: 0; top: 0; width: 100%; height: 100%; background: rgba(255,255,255,0.9); text-align: center; z-index: 10002; display: none }
#lay .photo {  }
#lay .next { position: absolute; right: 30px; top: 50%; margin-top: -30px }
#lay .prev { position: absolute; left: 30px; top: 50%; margin-top: -30px }
#lay .close { position: absolute; right: 30px; top: 30px; }
#lay h3 { position: absolute; left: 30px; bottom: 30px; font-size: 16px; line-height: 1; padding: 0.3em; background: #fff; font-style: italic; font-weight: 500 }
#lay .img-num { position: absolute; right: 30px; bottom: 30px; font-size: 22px; font-style: italic; letter-spacing:0.24em; }
#lay .img-num span { font-size: 32px; font-weight: 500 }

.qr { text-align: left; padding: 0 1em 1em; }
.qr span { width: 160px; display: inline-block; padding: 0 0 1em; line-height: 2em }

/*===============================================
2023
===============================================*/
.msg { position: relative; background: #decfc2; margin: 0 -10px }
.msg .msg-head { position: absolute; left: 0; top: 0; z-index: 0 }
.msg .msg-foot { position: absolute; left: 0; bottom: 0; z-index: 0 }
.msg-inner { position: relative; padding: 260px 0; text-align: center; z-index: 10 }
.msg-inner .logoset { width: 60%; margin: 4em auto 2em }
.msg p { font-size: 18px; line-height: 2em; font-weight: 600; }
#content .right .msg h3 { font-size: 24px; line-height: 2em; margin: 0 0 40px; border-left: none; padding-left: 0; text-align: center }

figure a { position: relative; display: block }
h2.step { font-size: 22px; line-height: 50px }
ul.bd-b { margin-left: -1em; margin-bottom: 2em; }
ul.bd-b > li { padding: 1em; border-bottom: dotted 2px #231816 }
.bl-23 { color: #a3252a }
.or-23 { color: #d97145 }
.gl-23 { color: #4f8d50 }
.rbox { padding: 2em; border-radius: 1em; background: #dcf0f4 }

.days { z-index: 100 }
.artist-list li { opacity: 0; transition: all 0.2s }
.artist-list li.loaded { opacity: 1; }
.artist-list li a { position: relative }
.artist-list li p { line-height: 1.5em; margin-bottom: 1em !important  }

.pointing { position: relative; display: inline-block; padding-left: 2em }
.pointing:before { content: ""; position: absolute; left: 0; top: 4px; display: block; width: 20px; height: 20px; background: url(https://cdn.fujirockfestival.com/smash/frf/assets/2023/news/img/ico_pointintg.png) no-repeat; background-size: contain }
img.wid2 { width: 50% }
img.wid3 { width: 33.33% }

.imagemap img { width: 100% }

/*2023.05.30 artistlist table調整*/
/*#artist table.artistlist { margin-bottom: 2em !important }*/

/*===============================================
2024
===============================================*/
.tit-stg { padding: 0.66em; background: #9d1257; color: #fff; margin-bottom: 2em }
.tit-stg#green { background: #6ea400; }
.tit-stg#white { background: #929292; }
.tit-stg#red { background: #ff3300; }
.tit-stg#heaven { background: #1ccbe3; }
.tit-stg#avalon { background: #9d1257; }
.tit-stg#mokudotei { background: #9e5c28; }
.tit-stg#orange { background: #ffa000; }
.tit-stg#palace { background: #129d89; }
.tit-stg#naeba { background: #9d9812; }
.tit-stg#day { background: #4e4ae4; }
.tit-stg#pyramid { background: #920e82; }
.tit-stg#paris { background: #022e6d; }
.tit-stg#busker { background: #004097; }
.tit-stg#cabaret { background: #cd1f32; }
.tit-stg#ganban { background: #000; }
.tit-stg#galaxy { background: #3a5582; }
.tit-stg#unfairground { background: #fd0002; }
.tit-stg#anf { background: #002c71; }
.tit-stg h3 { display: inline; font-weight: 600; line-height: 1.5em; margin-bottom: 0 }
.tit-stg span { display: inline-block; margin: 0 0 0 1em }
.tit-stg-sub { padding: 0.66em; background: #CCC; color: #fff; margin-bottom: 2em }
.tit-clm-three { margin: 0 -10px }
.tit-clm-three div.tit-clm { float: left; width: calc(33.33% - 20px); margin: 0 10px }
.and-more { padding-bottom: 2em; text-align: center; font-weight: bold }
td p.and-more { padding-bottom: 0; margin-bottom: 0 !important }


.pc-n { display: none }
.sp-n { display: table-cell}
.pc-none { display: none !important }
.sp-none { display: block !important }







/*===============================================
画面の横幅が768pxまで
===============================================*/
@media screen and (max-width: 768px){


body { font-size: 13px; line-height: 1; letter-spacing: 0.08em; }
body, html {
  min-width: auto;
}
body p { line-height: 1.8; }

.nw { white-space: normal; }
.half_left, .half_right {
  float: none;
  width: auto;
}
.half_right { margin-top: 1em; }

.col_4,
.incol_5,
.incol_4,
.incol_3,
.incol_2 {
	margin: 0 -10px;	
}
.incol_5 {
	margin: 0 -5px;	
}
.col_4 ul,
.incol_4 ul,
.incol_3 ul,
.incol_2 ul {
	margin: 0 -10px;	
}
.incol_5 li {
  width: calc(25% - 10px);
  margin: 0 5px 10px;
}
.incol_5.sp_3 li {
  width: calc(33.33% - 10px);
  margin: 0 5px 10px;
}
.col_4 li,
.incol_4 li,
.incol_3 li,
.incol_3 li:nth-child(3n),
.incol_2 li {
  width: calc(50% - 20px);
  margin: 0 10px 10px;
}
/*スマホのみ1列*/
.incol_2.sp_1 li {
  width: calc(100% - 20px);
  margin: 0 10px 10px;
}
/*.col_4 li:nth-child(2n),
.incol_4 li:nth-child(2n),
.incol_3 li:nth-child(2n),
.incol_2 li:nth-child(2n) {
  margin-right: 0;
}*/
.incol_4.sp_4 { margin: 0 -5px !important }
.incol_4.sp_4 li {
  width: calc(25% - 10px);
  margin-left: 5px;
  margin-right: 5px;
}
.incol_4.sp_3 li, .incol_3.sp_3 li {
  width: calc(33% - 10px);
  margin-left: 5px;
  margin-right: 5px;
}
.incol_5.sp_5 li {
  width: calc(20% - 10px);
  margin-left: 5px;
  margin-right: 5px;
}

#wrapper { min-height: 600px; text-align: center; padding-bottom: 8vw; overflow: hidden; z-index: 0 }
.bg2025 { width: 100%; height: 10vw; background: url(../img/bg2025_02.png) no-repeat bottom left; background-size: cover }
#top-mv .h_link {
  right: 10px;
  top: 60px;
}
#top-mv { width: 100%; padding: 0; margin: 50px 0 0; background-color: #3a3a3a; }
#top-mv h1 { display: none }
#top-mv ol { position: relative; width: 100%; margin: 0 auto }
#top-mv ol li { width: 100%; overflow: hidden }

#header_bar { width: 100%; height: 50px; padding: 0 0 5px; /*border-bottom: solid 2px #0592b9;*/ text-align: left; z-index: 1001 }
#header_bar h1 { height: 50px; /*border-bottom: solid 3px #00997b;*/ }
#header_bar h1 img { width: 232px; height: auto; margin: 6px 10px 0 }
#header_bar h1 span.bg { height: 50px }
#header_bar .lang { position: absolute; right: 55px; top: 5px }
#header_bar .lang li:first-child { display: none }
#header_bar .lang li a { display: inline-block; padding: 0 0.33em; font-weight: 600; }


#header { display: none; }
#header_sp { display: block; width: 100%; height: 52px; position: absolute; left: 0; top: 0; z-index: 1000; }
#header_sp h1 { float: left; padding: 12px 0 0 10px; margin: 0 !important; }
#menu_sp_btn { display: block; position: fixed; right: 0; top: -2px; width: 52px; height: 52px; display: block; cursor: pointer; z-index: 2000; }
#menu_sp_btn span { position: absolute; width: 26px; height: 2px; background: #fff; }
#menu_sp_btn span.ln1 { left: 13px; top: 20px; }
#menu_sp_btn span.ln2 { left: 13px; top: 26px; }
#menu_sp_btn span.ln3 { left: 13px; top: 32px; }
#menu-sp {
  position: fixed;
  display: block;
  left: 100%;
  top: 0;
  width: 66.66%;
  height: 100vh;
  background: #005848;
  text-align: left;
  font-size: 13px;
  line-height: 2;
  padding-bottom: 60px;
  overflow-y: scroll;
  z-index: 1001;
}
#menu-sp>ul {
  padding: 10px 20px;
}
#menu-sp ul.gnav li {
  display: block;
  width: 100%;
}
#menu-sp ul.gnav>li {
  padding: 0.5em 0;
	border-bottom: 1px solid #c7c7c7 !important;
}
#menu-sp ul a {
  display: block;
  padding: 0.33em 0;
  font-weight: 500;
}
#menu-sp a, #menu-sp a:link, #menu-sp a:visited {
  color: #FFF !important;
}
#menu-sp li>ul {
  width: 100%;
  margin-left: 1em;
  font-size: 13px;
  /*display: none;*/
}
#menu-sp .lang { padding: 10px 20px 0 !important }
#menu-sp .lang li { display: inline-block; line-height: 40px; color: #fff; padding-bottom: 0; border: none; }
#menu-sp .lang li a { display: inline-block; padding: 0 1em; font-weight: 600; }
#menu-sp .lang li.cur a { color: #acacac !important }
#menu-sp .sns_btn { padding: 10px 20px 0 !important }
#menu-sp .sns_btn li { display: inline-block; padding: 3px; border: none; }
#menu-sp .sns_btn li a { padding: 0; }

#content { width: auto; margin: 0 auto 50px; padding: 68px 10px 0 }
#home #content { margin: 0 auto 50px; padding: 20px 5px }
#content .content-inner { min-width: inherit; max-width: inherit; padding: 0 }
#content .left_column { float: none; width: 100%; padding: 0; display: none }
#content .right_column { float: none; width: calc(100% - 20px); padding: 10px; margin-bottom: 0;  }

.left_column h1,
.left_column #sidemenu {
  display: none;
}

#top_news li h3 span:after {
  content: "\A";
  white-space: pre;
  line-height: 2.4;
}

#foot_pic { position: relative; display: block }

#footer { padding: 20px 0 20vw; background: url(../img/bg2025_01_sp.png) no-repeat bottom #dbcfc4; background-size: contain }
#footer .footer_inner { width: auto; min-width: inherit; max-width: inherit; padding: 0 20px; }
#footer .footer_inner .foot_logo { display: none }
#footer .footer_inner ul { display: none; width: auto; margin: 0; float: none }
#footer .footer_inner ul li a { margin: 0 0 5px }
#footer .footer_inner ul li { margin: 0 0 10px }
#footer .footer_inner ul li ul { display: none }
#footer .footer_inner ul li li a { margin: 0 }
#footer .footer_inner ul li.current ul { display: block }

#footer .footer_inner ul.sns_btn {
  display: block;
}
#footer .footer_inner ul.sns_btn li { padding: 3px 6px }
#footer .footer_inner ul.sns_btn li a img {
  width: 40px;
}

#footer p.copyright { width: 100%; margin: 30px 0 0; font-size: 10px; }
    
/*プレサイト*/
.last-year { padding: 40px 0 60px; }
.last-year-inner { max-width: inherit; padding: 0 20px }
.last-year .yt iframe { width: 100%; height: calc((100vw - 40px) * 0.5625)}
#footer.pre-site { padding-bottom: 20vw }
#footer.pre-site p.copyright { margin: 30px 0 0; font-size: 10px; }

.backto a { font-size: 16px; letter-spacing: 0.05em }
    
#pagetop { width: 40px; height: 40px; padding: 0; }

/*===============================================
HOME 2020 Grid System
===============================================*/
.top-grid { padding: 0; margin: 0 0 20px; }
.top-grid h2 { margin: 10px 0 !important; padding: 0 }
.top-grid h2 img { height: 13px }
.top-grid ul { padding: 0 5px }
.top-grid ul li .grid-inner { padding: 10px 5px 5px }
.top-grid ul li a h2 {  }
.top-grid ul li a .cat {  }
.top-grid ul li h3 { text-align: left; font-size: 13px; padding: 10px 0 0 !important; font-weight: 500 }
.top-grid ul li p { text-align: left; font-size: 12px; padding: 0 !important; margin-top: 10px !important; font-weight: normal }

#top-news ul li a .cv { display: none }

.grid-three li { width: 100% }
.grid-four li { width: 50% }
.grid-five li { width: 33.33% }
.grid-ad li { width: 20% }
.grid-four ul li a h2 { font-size: 13px }

#top-feature { padding-top: 10px }
#top-feature li, #top-news li { width: 50% }
#top-feature ul li a .cate { padding: 10px; font-size: 10px; }
#top-feature ul li a h2 { font-size: 16px; line-height: 1.25em }
#top-news { padding-top: 20px }
#top-news li h2 { font-size: 14px; margin-bottom: 0; }
#top-news li p { margin-top: -0.5em !important }
#top-news h2, #top-officialitem h2, #top-smashinfo h2, #ad h2 { font-size: 20px; }
#top-officialitem { padding: 20px 0; margin-bottom: 0 }
#top-smashinfo { padding: 20px 0; margin-bottom: 0 }
#top-smashinfo h2 img { height: 20px; }
#ad { padding: 0 0 80px }
#ad .ad-inner { width: auto; padding: 0 15px }
#ad a.fltL, #ad a.fltR { width: 100%; margin: 0 0 10px; }
#ad a.fltL img, #ad a.fltR img { width: 100%; height: auto }
#ad .aca img { width: 140px }
#ad .aca p { font-size: 11px; }



/*===============================================
第2階層
===============================================*/
body {
  font-size: 13px;
}
body #wrapper { padding: 0 !important }

.sec h1 {
  margin-bottom: 1em;
  font-size: 18px;
}
.sec h2 {
  font-size: 16px;
}
.sec h3 {
  font-size: 14px;
}
.sec h4 {
  font-size: 13px;
}
#content span.date {
  margin: -20px 0 40px;
}
.sec {
  margin-bottom: 60px;
}
.sec article {
  margin-bottom: 40px;
}
#artistdata article { font-size: 13px; }
#artistdata h1 span { font-size: 13px; }
/*table.artistlist {
  margin-bottom: 40px;
}*/
table th, table td { padding: 1em 1em 1em 0; }
.artistlist th {
  padding: 0;
}
.note { padding: 10px; }
#access iframe { width: 100%; height: 170px }
#ticket_1, #ticket_2, #ticket_3, #ticket_4, #ticket_5, #ticket_6, #ticket_7,
#playguide_1, #playguide_2, #playguide_3, #playguide_4, #playguide_5, #playguide_6, #playguide_7, #playguide_8, #playguide_9, #playguide_10, #playguide_11, #playguide_12, #playguide_13, #playguide_14, #playguide_15, #playguide_16, #playguide_17, #playguide_18, #playguide_19, #playguide_20, #playguide_21 {
  /* padding-left: 0; */
  /* line-height: 2; */
  /* background: none; */
  padding-left: 35px;
  line-height: 30px;
  background-size: 30px;
}
.news_btn a { font-size: 14px; }

#news .locnav h1 { margin-top: 0 !important }
#news #content .left_column { display: block; background: #f7f7f7; width: auto; margin: 0; padding: 20px 20px 0; border-radius: 1.6vw; }
#news #content .left_column.pu { display: none }
#news #topics { padding-bottom: 30px; }
#relation_news {
  margin-top: 60px;
}

#news .sec img,
#guide .sec img,
#gallery .sec img {
  width: 100%; height: auto
}
#news #pickup_news li { float: left; width: 250px; margin: 0 15px 0 10px; padding: 0 0 20px }
#guide .sec iframe,
#news .sec iframe {
  width: 100%;
  height: 170px;
}
#playguide1 th img, #playguide2 th img, #playguide2 th img { width: 60px; height: 60px }

.artistlist td { white-space: normal; word-break: break-all !important; border-right:none; }
#ticket table.tk th { white-space: normal; word-break: break-all !important; min-width: 120px }
#ticket table.tk td { white-space: normal; word-break: break-all !important }
.list_pg td { width: auto; }

#stage dl {
  width: 100%;
}

#gallery_info table {
  float: none;
  width: auto;
}
#poster {
  float: none;
  width: calc(100% - 40px);
  margin: 0;
}
#poster img {
  width: 100%;
  margin: -30px 0 60px;
}

.faq .faq-cont h2 { padding: 0.66em 0; }
.faq .faq-cont .answr { padding: 1em; }
.faq .faq-cont .answr h3 { font-size: 13px !important; }
.faq .faq-cont .answr p { font-size: 12px !important }

.timetable li {
	  float: none;
	  width: 100%;
	}

	#date_menu { display: block }
	
/* アクセス */
#access1 h1,#access2 h1,#access3 h1,#access4 h1 { line-height: 30px; padding-left: 60px }
#access1 
    :before { width: 48px; height: 30px; }
#access2 h1:before { width: 48px; height: 30px; }
#access3 h1:before { width: 48px; height: 30px; }
#access4 h1:before { width: 48px; height: 30px; }
#lodge1 h1,#lodge2 h1,#lodge3 h1 { line-height: 45px; padding-left: 60px }
#lodge1 h1:before { width: 48px; height: 36px; }
#lodge2 h1:before { width: 48px; height: 36px; }
#lodge3 h1:before { width: 48px; height: 36px; }
#tour1 h1 { line-height: 30px; padding-left: 60px }
#tour1 h1:before { width: 48px; height: 30px; }
#tour2 h1 { line-height: 36px; padding-left: 60px }
#tour2 h1:before { width: 48px; height: 36px; }

.ts-smallest { font-size: 9px !important }

/*===============================================
2021 COVID Guideline
===============================================*/
.gl-menu li a { font-size: 12px; min-height: 24px !important }
.gl-menu li:nth-child(7) a, .gl-menu li:nth-child(8) a, .gl-menu li:nth-child(9) a { min-height: 34px !important }
.bg21-tit { padding: 1.5em }
.bg21 { padding: 1.5em 1.5em 4em; }
.rc-wrap { padding: 1em; border-radius: 12px }
.sec ul.ico li { padding-left: 0; position: relative; min-height: inherit }
.sec ul.ico li img.icon { position: relative; left: -1.2em; top: inherit; width: 180px !important; border-radius: 16px; display: block; margin: 10px }
.sec ul.ico li .ts-larger { margin-top: -2em }

.bl-menu li a { font-size: 12px; min-height: 24px !important }
.bl-menu li:nth-child(1) a, .bl-menu li:nth-child(2) a, .bl-menu li:nth-child(3) a { min-height: 34px !important }
	
/*===============================================
2021 Photo Gallery
===============================================*/
.photo-gallery { margin: -10px -15px 0; }
.photo-gallery li { width: 33.33%; float:left; }
.photo-gallery li .pg-inner { padding: 10px; }
.photo-gallery li .pg-inner a { overflow: hidden; display: block; font-size: 0; background: #f7f7f7; border: solid #7d7dcc; border-width: 0 1px 1px 0; border-radius: 5px }
.photo-gallery li .pg-inner a img { vertical-align: bottom; margin: 0 }
#lay { position: fixed; left: 0; top: 0; width: 100%; height: 100%; background: rgba(255,255,255,0.9); text-align: center; z-index: 10002; display: none }
#lay .photo {  }
#lay .next { position: absolute; right: 0; top: 85%; margin-top: -30px }
#lay .prev { position: absolute; left: 0; top: 85%; margin-top: -30px }
#lay .close { position: absolute; right: 0; top: 0; }
#lay h3 { position: absolute; left: 20px; bottom: 20px; font-size: 14px; line-height: 1.2em; background: #f7f7f7; font-style: italic; font-weight: 500 }
#lay .img-num { position: absolute; right: 20px; bottom: 20px; font-size: 18px; font-style: italic; letter-spacing:0.24em; }
#lay .img-num span { font-size: 26px; font-weight: 500 }


/*===============================================
2022 
===============================================*/

.locnav { background: #f5f3f0; margin: -1em -10px 10px; padding: 0 10px; border-top: solid 2px #96b0aa }
.locnav.active { padding: 0 10px 1em; }
.locnav h1 { position: relative; font-size: 16px; font-weight: bolder; color: #005848; padding: 1em 0 }
.locnav h1.toggle::after { content: ""; position: absolute; display: block; right: 0; top: 0.75em; width: 20px; height: 20px; background: url("../img/ico_plus.png") no-repeat; background-size: contain; }
.locnav.active h1.toggle::after { content: ""; position: absolute; display: block; right: 0; top: 0.75em; width: 20px; height: 20px; background: url("../img/ico_minus.png") no-repeat; background-size: contain; }
/*.locnav #sidemenu { overflow-x: auto; white-space: nowrap; overflow-scrolling: touch; -webkit-overflow-scrolling: touch; margin-top: -1em; }
.locnav #sidemenu li { display: block; margin-right: 1em }
.locnav #sidemenu li a { font-size: 13px }*/
.locnav #sidemenu { position: relative; padding: 1em; background: #fff; border-radius: 16px; margin: 0; display: none }
.locnav #sidemenu li { display: block; margin-right: 0 }
.locnav #sidemenu li:last-child { padding: 0 }
.locnav #sidemenu li a { font-size: 13px }
/*2022.04.01 artistlist table調整*/
table.artistlist th.date { padding-bottom: 20px }
/*table.artistlist th.date:first-child { padding-bottom: 0 }*/


/*===============================================
2023 
===============================================*/
.msg { margin: 0 }
.msg-inner { padding: 42vw 1.5em; }
.msg-inner .logoset { width: 60%; margin: 3em auto 1.5em }
.msg p { font-size: 14px !important; text-align: left !important }
#content .right .msg h3 { font-size: 20px; margin: 0 0 20px; }
.artist-list li p { line-height: 1.4em; margin-bottom: 1em !important  }

h2.step { font-size: 18px; line-height: 32px }
h2.step img { width: auto !important; height: 32px !important }


/*===============================================
2024
===============================================*/
.tit-stg { margin-bottom: 1.5em }
.tit-stg h3 { line-height: 1.33em; }
.tit-stg span { line-height: 1em; }
.tit-stg-sub { margin-bottom: 1.5em }
.artist-list li p.tss { font-size: 10px !important }
.tit-clm-three { margin: 0 -5px }
.tit-clm-three div.tit-clm { width: calc(33.33% - 10px); margin: 0 5px }
.tit-clm-three div.tit-clm h4 { line-height: 1.33 }


img.wid2 { width: 100% !important }
img.wid3 { width: 50% !important }

.pc-n { display: inherit }
.sp-n { display: none }
.pc-none { display: block !important }
.sp-none { display: none !important }

.ts-smaller-sp { font-size: 10px !important }
}

/* HTML: <div class="loader"></div> */
.loader {
  width: 40px;
  aspect-ratio: 4;
  --_g: no-repeat radial-gradient(circle closest-side,rgba(230,82,42,1) 90%,#0000);
  background: 
    var(--_g) 0%   50%,
    var(--_g) 50%  50%,
    var(--_g) 100% 50%;
  background-size: calc(100%/3) 100%;
  animation: l7 1s infinite linear;
}
@keyframes l7 {
    33%{background-size:calc(100%/3) 0%  ,calc(100%/3) 100%,calc(100%/3) 100%}
    50%{background-size:calc(100%/3) 100%,calc(100%/3) 0%  ,calc(100%/3) 100%}
    66%{background-size:calc(100%/3) 100%,calc(100%/3) 100%,calc(100%/3) 0%  }
}

strong { font-weight: bold !important }

#stage .right_column, #news .right_column.cs { min-height: 100vh }
#ticket-badge { position: fixed; right: 10px; bottom: 100px; z-index: 1000 }
#ticket-badge a { display: block; cursor: pointer; transition: all 0.2s }
#ticket-badge a:hover { transform: scale(1.08) }
@media screen and (max-width: 768px){
  #stage .right_column, #news .right_column.cs { min-height: 75vh }
  #ticket-badge { right: 5px; bottom: 45px; }
  #ticket-badge a img { width: 90px }
}