@charset "utf-8";

body {
  font-size: 87.5%;
}

/* ■wrap
--------------------------------------------------- */
#wrapper {}

/* ■header
--------------------------------------------------- */
header {
  display: block;
  border-top: 10px solid #313131;
  background: #ffe100;
}

header:before {
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  background: #d60021;
  position: absolute;
}

.header_logo {
  width: 950px;
  margin: 0 auto;
  position: relative;
  top: -5px;
  text-align: center;
}

.header_logo img {
  width: 372px;
  height: 23px;
  text-align: center;
}

/* ■content
--------------------------------------------------- */
#content {
  width: 100%;
}

#content_wrap:after {
  content: "";
  display: block;
  clear: both;
}

#content_wrap {
  display: inline-block;
}

#content_wrap {
  display: block;
}

#content_wrap {
  width: 100%;
  margin: 0 auto;
}

/* wide */
#content_wrap.widearea {
  width: 100%;
  max-width: 90%;
  margin: 0 auto;
}

.widearea #main-content {
  width: 100%;
  min-width: 1000px;
  float: none;
}

.widearea #sub-content {
  display: none;
}

/* ■footer
--------------------------------------------------- */
footer {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  padding: 24px 0 28px 0;
  border-top: 4px solid #313131;
  background: #ffe100;
  font-size: 13px;
}

footer:before {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  margin: 0 0 24px 0;
  padding: 0;
  background: #d60021
}

.footer_note1 {
  display: inline-block;
  margin: 0 auto;
}

.footer_note1>li {
  padding: 0 0 0 3em;
  text-indent: -3em;
}

.footer_sponsor {
  display: inline-flex;

  align-items: center;
  margin: 18px auto 0;
  padding: 0 0 0 0;
  text-indent: 0;
}

.footer_sponsor ul {
  display: inline-flex;
}

.footer_sponsor ul li {
  margin: 0 16px 0 0;
}

.sponsor_icon {
  display: inline-block;
  width: 121px;
  margin: 0;
  padding: 0;
}

.alcohol_caution {
  display: inline-flex;
  font-size: 13px;
}

.alcohol_caution .icon {
  margin: 0 8px 0 0;
}

/* ■icon
--------------------------------------------------- */
.icon {
  display: inline-block;
}

.arrow--down,
.arrow--next,
.arrow--up,
.icon--a,
.icon--caution,
.icon--q {
  width: 28px;
  height: 41px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: 0 -333px;
}

.arrow--down,
.arrow--next,
.arrow--up,
.icon--a,
.icon--q {
  width: 38px;
  height: 38px;
  background-position: 0 -290px;
}

.arrow--down,
.arrow--next,
.arrow--up,
.icon--a {
  background-position: -43px -290px;
}

.arrow--down,
.arrow--next,
.arrow--up {
  width: 17px;
  height: 17px;
  background-position: -132px -290px;
}

.arrow--down,
.arrow--next {
  width: 19px;
  height: 19px;
  background-position: -86px -290px;
}

.arrow--next {
  width: 17px;
  height: 17px;
  background-position: -110px -290px;
}

/* ■h2
--------------------------------------------------- */
h2 {
  position: relative;
  min-width: 950px;
  margin: 0 0 25px;
  padding: 25px 0 18px;
  text-align: center;
  border-top: 4px solid #313131;
  background: #ffe100;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
}

h2:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  content: '';
  background: #d60021;
}

.sub_title {
  display: block;
  margin: 0;
  font-family: 'Century Gothic', sans-serif;
  font-size: 18px;
  color: #dc0000;
  font-weight: 300;
  line-height: 1.6;
}

/* ■main_v
--------------------------------------------------- */
section.main_v {
  min-width: 1000px;
  background: url(../img/top/bg_hero_top.png) center bottom no-repeat;
  background-size: cover;
}

h1 {
  position: relative;
  width: 950px;
  margin: 0 auto
}

h1 img {
  display: block;
  width: 763px;
  margin: 0 auto;
}

/* 2019-2020
section.main_v_2019{
  min-width:1000px;
  background:url(../img/top/bg_main_v_2019.png) center bottom;
  background-size:cover;
}
 */
section.main_v_2019 {
  min-width: 1000px;
  /*background:url(../img/top/bg_main_v_2023ff.jpg) center bottom;*/
  background: url(../img/top/bg_main_v_2019.png) center bottom;
  background-size: cover;
}

section.main_v_2019 h1 {
  position: relative;
  width: 950px;
  margin: 0 auto
}

section.main_v_2019 h1 img {
  display: block;
  width: 764px;
  margin: 0 auto;
}

/* ■navarea
--------------------------------------------------- */
section.navarea {
  width: 100%;
  min-width: 1000px;
  margin: 0 auto;
  padding: 0px;
  position: relative;
}

@media screen and (max-width:1000px) {
  section.navarea {
    margin: 0 25px;
    margin: 0;
  }

  .g-nav {
    margin: 0 25px !important;

  }
}

.g-nav_link:after,
footer:before,
header:before {
  position: absolute;
  top: 0;
  left: 0;
  content: ''
}

.nav {
  background: #000
}

.g-nav {
  display: table;
  width: 950px;
  margin: 0 auto;
  padding: 8px 0
}

.g-nav_item {
  display: table-cell;
  width: 238px;
  padding-right: 7px
}

.g-nav_item+.g-nav_item {
  padding-left: 7px;
  border-left: 1px solid #444
}

.g-nav_link {
  position: relative;
  display: block;
  width: 225px;
  height: 53px;
  text-indent: -9999px;
  border-radius: 4px
}

.g-nav_link:after {
  display: block
}

.g-nav_link:not(.is-off):hover {
  text-decoration: none;
  background: #ffe700;
  background: linear-gradient(to bottom, #ffe700 0%, #f18e00 100%)
}

.g-nav_beer:after,
.g-nav_top:after {
  width: 225px;
  height: 53px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: 0 -58px;
}

.g-nav_beer:after {
  background-position: -230px -174px
}

.g-nav_access:after,
.g-nav_beer.is-off:after,
.g-nav_enjoy.is-off:after,
.g-nav_enjoy:after {
  width: 225px;
  height: 53px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: -230px -58px;
}

.g-nav_access:after,
.g-nav_beer.is-off:after,
.g-nav_enjoy.is-off:after {
  background-position: 0 -116px
}

.g-nav_beer.is-off:after,
.g-nav_enjoy.is-off:after {
  background-position: 0 -232px
}

.g-nav_enjoy.is-off:after {
  background-position: -230px -116px
}

.g-nav .is-on,
.g-nav .is-on:hover {
  text-decoration: none;
  background: #fbcb00
}

.g-nav_beer.is-on:after,
.g-nav_beer:hover:after,
.g-nav_top.is-on:after,
.g-nav_top:hover:after {
  width: 225px;
  height: 53px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: 0 -174px;
}

.g-nav_beer.is-on:after,
.g-nav_beer:hover:after {
  background-position: -230px -232px
}

.g-nav_access.is-on:after,
.g-nav_access:hover:after,
.g-nav_enjoy.is-on:after,
.g-nav_enjoy:hover:after {
  width: 225px;
  height: 53px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: 0 0;
}

.g-nav_access.is-on:after,
.g-nav_access:hover:after {
  background-position: -230px 0
}

.l-nav {
  min-width: 950px;
  background: #ddd
}

.l-nav_wrapper {
  width: 950px;
  margin: 0 auto
}

.l-nav_list {
  display: table;
  margin: 0 auto;
  border-spacing: 10px;
  border-collapse: separate
}

.l-nav_list+.l-nav_list {
  margin-top: -6px
}

.l-nav_item {
  display: table-cell;
  width: 152px;
  height: 52px;
  padding: 6px 8px;
  vertical-align: middle;
  border-radius: 4px;
  background: #fff;
}
.l-nav_item.no_list {
    display: table-cell;
    border-radius: none;
    border-radius: 4px;
    background: none !important;
}

.l-nav_item--top {
  width: 258px;
  width: 350px;
}

.l-nav_item--enjoy {
  width: 109px
}

.l-nav_link {
  line-height: 1.4;
  position: relative;
  display: block
}

.brand_nav-item>a:hover .brand_nav-txt,
.l-nav_link:hover .l-nav_text {
  text-decoration: underline
}

.l-nav a.l-nav_link,
.l-nav a.l-nav_link:link {
  color: #313131
}

.l-nav_text {
  display: inline-block;
  margin-left: 24px;
  font-size: 15px;
}

.l-nav .icon {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto 0
}

/* TOPgnav他ページリンク消し　aをspanに変更する
0 -174px ?
-230px -232px

-230px -174px beer
0 -116px akusesu
-230px -58px enjoy


0 -232px beer hover
-230px -116px enjoy hover
*/
/* 準備中用gnav */
span.g-nav_link:not(.is-off):hover {
  text-decoration: none;
  background: #ffe700;
  background: #000;
}

span.g-nav_beer.is-on:after,
span.g-nav_beer:hover:after {
  background-position: -230px -174px;
}

span.g-nav_enjoy.is-on:after,
span.g-nav_enjoy:hover:after {
  width: 225px;
  height: 53px;
  background-image: url(../img/sprite-img_2023_03.png);
  background-position: -230px -58px;
}

span.g-nav_access.is-on:after,
span.g-nav_access:hover:after {
  background-position: 0 -116px
}

/* ■whatsfest
--------------------------------------------------- */
section.whatsfest {
  width: 950px;
  margin: 0 auto 50px;
  padding: 0 25px;
  border-radius: 8px;
  background-color: #fff;
}

@media screen and (max-width:1000px) {
  section.whatsfest {
    margin: 0 25px 50px;
  }
}

/* ■aboutfest
--------------------------------------------------- */
section.aboutfest {
  width: 950px;
  margin: 0 auto 50px;
  padding: 0 25px;
  border-radius: 8px;
  background-color: #fff;
}

@media screen and (max-width:1000px) {
  section.aboutfest {
    margin: 0 25px 50px;
  }
}

.section_img {
  display: table;
  margin: 0 auto;
  padding-top: 25px;
}

.section_img-item {
  display: table-cell;
  width: 308px;
  padding: 0 0px 0 24px;
}

.section_img-item:first-child {
  width: 284px;
  padding: 0 0 0 0;
}

.section_text {
  margin: 0 0 0 0;
  padding: 25px 0;
  font-size: 15px;
}

.section_text p {
  margin: 0 0 0 0;
}

.section_text p+p {
  margin: 0 0 0 0;
  padding-top: 20px;
}

.section_text .text-indent {
  margin: 0 0 0 15px;
  text-indent: -15px;
}

/* ■cooperation 2025-08 
--------------------------------------------------- */
section.cooperation {
  display: flex;
  flex-wrap:wrap;
  align-items:center;

  width: 950px;
  margin: 0 auto 50px;
  padding:25px;
  border-radius: 8px;
  background-color: #fff;
}

@media screen and (max-width:1000px) {
  section.cooperation {
    margin: 0 25px 50px;
  padding:3% 3%;
  }
}


section.cooperation h3{
  order: 1;
  width:40%;
  margin-left:5%;
}
.cooperation_content{
  width:55%;
}
section.cooperation h3 a:hover{
  opacity: 0.6;
}

section.cooperation h4{
  margin:0 0 0.35em;
  font-size: 23px;
  font-weight: 700;
  color:#b31e24;
}
.prevent_date {
  display: flex;
  flex-wrap:wrap;
  margin:0 0 0.5em;

}
.prevent_date dt{
  width:5em;
  margin:0 0 0.5em;
  padding:0.5em 1em;
  border-radius:4px;
  background-color:#b31e24 ;
  color:#fff;
  text-align:justify;
text-align-last:justify;

}
.prevent_date dd{
  width:calc(100% - 5em);
  margin:0 0 0.5em;
  padding:0.5em 1em;
  color:#b31e24 ;
  font-weight: 700;
}
.prevent_content{
  margin:0 0 1em;
}

.waiwaiwain_overview{
  order:2;
  width:100%;
  margin:1em 0 0 0;
  padding:1.25em;
  border: 1px solid #76171d ; 
  border: 1px solid #b31e24 ; 
  border-radius: 10px; 
}
/*
.waiwaiwain_overview{
  order:2;
  width:100%;
  margin:0em 0 0 0;
  padding:0em;
  border: 1px solid #76171d ; 
  border: 1px solid #b31e24 ; 
  border: 1px solid #888 ; 
  border: none;
  border-radius: 10px; 
}
  */

.waiwaiwain_info{
  display: flex;
  flex-wrap:wrap;
  width:100%;
}
.waiwaiwain_info dt{
  width: 5em;
  padding:0 0em 0 1em;
  position: relative;
  text-align:justify;
text-align-last:justify;
}
.waiwaiwain_info dt:after{
  content:"■";
  position: absolute;
  left:0;
}
.waiwaiwain_info dd{
  width: calc(100% - 5em);
  text-indent: -1em;
  padding-left: 1em;
}
.waiwaiwain_info dd:before{
  content:"：";
}
.waiwaiwain_sitelink{
  margin:0.5em 0 0 0;
}
.waiwaiwain_sitelink a{
  text-decoration: underline;
  color:#b31e24 ;
}
.waiwaiwain_sitelink a:hover{
  text-decoration: underline;
  color:#b31e24 ;
  opacity: 0.6;
}

/* ■event
--------------------------------------------------- */
section.eventinfo {
  width: 950px;
  margin: 0 auto 50px;
  border-radius: 8px;
  background-color: #fff;
}

@media screen and (max-width:1000px) {
  section.eventinfo {
    margin: 0 25px 50px;
  }
}

.sectionwrap {}

/* eventitem */
.eventitem:after {
  content: "";
  display: block;
  clear: both;
}

.eventitem {
  display: inline-block;
}

.eventitem {
  display: block;
}

.eventitem {
  width: 924px;
  margin: 0 auto;
  padding-top: 25px;
}

.eventitem li {
  width: 308px;
  margin: 0 0 25px;
  padding: 0 12px;
  float: left;
}

.eventitem li a {
  display: block;
}

.eventitem li a:hover {
  color: #313131;
  text-decoration: underline;
}

.section_img-title {
  font-size: 18px;
  font-weight: 700;
  margin: 10px 0 5px;
  color: #313131
}

.section_img-title .icon {
  margin-right: 5px;
  vertical-align: middle
}

.section_img-txt {
  margin: 0 0 0 0;
  font-size: 14px;
  color: #313131;
}

/* official */
.official {
  overflow: hidden;
  padding: 25px;
}

.official_timeline {
  float: left;
  width: 438px
}

.official_timeline+.official_timeline {
  margin-left: 24px
}

.inner_title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 16px;
  color: #000
}

.inner_title:before {
  display: inline-block;
  content: '■';
  color: #ffe100
}

.official_timeline.insta_code {
  clear: both;
  margin-top: 40px;
  margin-left: 0;
}

/* ■pagetop
--------------------------------------------------- */
section.pagetop {
  width: 950px;
  margin: 0 auto;
  padding: 0px;
}

@media screen and (max-width:1000px) {
  section.pagetop {
    margin: 0 25px;
  }
}

.totop {
  font-size: 16px;
  margin: 18px auto;
  text-align: right
}

.totop .icon {
  margin-right: 5px;
  vertical-align: middle
}

/* ■endinfo
--------------------------------------------------- */
.end-info {
  padding: 30px 0;
  background: #f8efdb;
}

.end-info__txt {
  font-size: 24px;
  font-weight: 700;
  width: 950px;
  margin: 0 auto;
  text-align: center;
  color: #f10000;
}

/* ■mmenu用
--------------------------------------------------- */
/* スライドメニュー */
nav:not(.mm-menu) {
  display: none;
}

.mm-menu {
  background: #eee;
  border-color: #FFF;
  color: #888;
}

.hover-item:hover {
  opacity: 0.6;
}

.mm-menu .mm-navbar a,
.mm-menu .mm-navbar>* {
  color: rgba(0, 0, 0, .3);
}

.menu-btn {
  display: none;
}

header {
  height: 34px;
  position: absolute;
  width: 100%;
  min-width: 1000px;
  top: 0;
  left: 0;
}

#content {
  padding-top: 34px !important;
}


/* ■2020開催中止のお知らせ
--------------------------------------------------- */
.info_discontinued {
  padding: 40px 9% 60px;
}

.info_discontinued_tit {
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  color: #d65b00;
  padding: 0 0 0.5em;
  border-bottom: 1px dotted #888;
}

/* ■2022新型コロナウイルス感染拡大防止
--------------------------------------------------- */

#top_info {
  width: 950px;
  margin: 50px auto 50px;
  text-align: center;
}

#top_info div {
  display: inline-flex;
  flex-direction: column;
  margin: 0px auto;
  padding: 70px 75px;
  background: #fff;
  text-align: left;
}

#top_info div p {
  display: inline-block;
  width: 44em;
}

#top_info div p.top_info_tit {
  width: 36em;
  padding: 0 0 0.5em 0;
  font-size: 17px;
  color: #639eda;
  letter-spacing: .02em;
  border-bottom: 1px solid #639eda;
}

.top_info_link {
  margin: .5em 0 0;
}

.top_info_link a {
  display: block;
  color: #fff;
  background: #639eda;
  border-radius: 6px;
  text-align: center;
  font-size: 14px;
  line-height: 3em;


}

.top_info_link a:hover {
  opacity: 0.6;
}

.top_info_link a span.material-icons {
  margin-left: .2em;
  vertical-align: -6px;
}