@charset "UTF-8";

/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */

*, :after, :before {
  border-style: solid;
  border-width: 0;
  box-sizing: border-box
}

html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  line-height: 1.15
}

body {
  margin: 0
}

main {
  display: block
}

address, blockquote, dl, figure, form, iframe, p, pre, table {
  margin: 0
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0
}

ol, ul {
  list-style: none;
  margin: 0;
  padding: 0
}

dt {
  font-weight: 700
}

dd {
  margin-left: 0
}

hr {
  border-top-width: .1rem;
  box-sizing: content-box;
  clear: both;
  color: inherit;
  height: 0;
  margin: 0;
  overflow: visible
}

pre {
  font-family: monospace, monospace;
  font-size: inherit
}

address {
  font-style: inherit
}

a {
  background-color: transparent;
  color: inherit;
  text-decoration: none
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b, strong {
  font-weight: bolder
}

code, kbd, samp {
  font-family: monospace, monospace;
  font-size: inherit
}

small {
  font-size: 80%
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

embed, iframe, img, object, svg {
  vertical-align: bottom
}

button, input, optgroup, select, textarea {
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  border-radius: 0;
  color: inherit;
  font: inherit;
  margin: 0;
  padding: 0;
  text-align: inherit;
  text-transform: inherit;
  vertical-align: middle
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  appearance: checkbox
}

[type=radio] {
  -webkit-appearance: radio;
  appearance: radio
}

[type=button], [type=reset], [type=submit], button {
  cursor: pointer
}

[type=button]:disabled, [type=reset]:disabled, [type=submit]:disabled, button:disabled {
  cursor: default
}

:-moz-focusring {
  outline: auto
}

select:disabled {
  opacity: inherit
}

fieldset, option {
  padding: 0
}

fieldset {
  margin: 0;
  min-width: 0
}

legend {
  padding: 0
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  outline-offset: -.2rem
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

label[for] {
  cursor: pointer
}

details {
  display: block
}

summary {
  display: list-item
}

[contenteditable]:focus {
  outline: auto
}

table {
  border-color: inherit
}

caption {
  text-align: left
}

td, th {
  padding: 0;
  vertical-align: top
}

th {
  font-weight: 700;
  text-align: left
}

html {
  font-size: 10px
}

body {
  color: #000;
  font-family: Noto Sans JP, sans-serif
}

picture {
  display: block
}

img {
  height: auto;
  width: 100%
}

a {
  display: block
}

span {
  display: inline-block
}

.supports,
.tanq__area{
  padding: clamp(0px, 10.5714285714vw, 7.4rem) 2rem clamp(0px, 21.5714285714vw, 15.1rem)
}

.supports__container {
  margin: 0 auto;
  max-width: 104.5rem
}

.supports__list {
  display: flex;
  flex-direction: column;
  row-gap: 14.4rem;
  margin-bottom: clamp(0px, 6.125vw, 3rem);
}

.supports__item-head {
/*  border: .4rem solid #000;*/
      font-size: 3.5rem;
  font-weight: 500;
  line-height: normal;
  padding-bottom: 1.2rem;
  padding-top: 1.6rem;
  text-align: center
}

.supports__item:first-of-type .supports__item-head {
      margin-bottom: clamp(0px, 6.125vw, 3rem);
}

.supports__item:first-of-type .supports__item-body picture {
  margin: 0 auto;
  max-width: 57.3rem
}

.supports__item:nth-of-type(2) .supports__item-head {
  margin-bottom: clamp(0px, 9.25vw, 7.4rem)
}

.supports__item:nth-of-type(2) .supports__item-body,
.supports__item:nth-of-type(4) .supports__item-body{
  -moz-column-gap: 11.8rem;
  column-gap: 11.8rem;
  display: flex;
  justify-content: center
}
.supports__item:nth-of-type(4) .supports__item-body{
    -moz-column-gap: 4rem;
  column-gap: 4rem;
}

.supports__item:nth-of-type(2) .supports__item-body picture {
  width: 100%
}

.supports__item:nth-of-type(2) .supports__item-body picture:first-of-type {
  max-width: 30.8rem
}

.supports__item:nth-of-type(2) .supports__item-body picture:last-of-type {
  max-width: 31.2rem
}
.supports__item:nth-of-type(4) .supports__item-body picture{
/*    width: 33%;*/
    width: auto;
}

@media screen and (max-width:900px) {
  .supports__item:nth-of-type(2) .supports__item-body,
  .supports__item:nth-of-type(4) .supports__item-body{
    align-items: center;
    flex-direction: column;
    row-gap: 3rem
  }
  .supports__item:nth-of-type(4) .supports__item-body picture {
        width: 72%;
    }
}

.supports__item:last-of-type .supports__item-head {
  margin-bottom: clamp(0px, 10.5vw, 4rem);
}

.supports__item:nth-child(3) .supports__item-body p {
  font-size: clamp(0px, 5vw, 2rem);
  font-weight: 500;
  line-height: normal;
  text-align: center
}

.outline {
  background-image: url(../images/outline_bg.webp);
  background-position: 50%;
  background-size: cover;
  padding: clamp(0px, 21vw, 18.9rem) 2rem
}

.outline__content {
  background-color: rgba(255, 242, 175, .56);
  border-radius: clamp(0px, 7.3333333333vw, 6.6rem);
  box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .67);
  margin: 0 auto;
  max-width: 139.4rem;
  padding-bottom: clamp(0px, 15.3333333333vw, 13.8rem);
  padding-top: clamp(0px, 11.6666666667vw, 10.5rem)
}

.outline__head {
  font-size: clamp(0px, 5.2222222222vw, 4.7rem);
  font-weight: 700;
  line-height: 1;
  margin-bottom: clamp(0px, 5.5555555556vw, 5rem);
  padding-bottom: clamp(0px, 1.2222222222vw, 1.1rem);
  position: relative;
  text-align: center
}

.outline__head:after {
  background-color: #707070;
  content: "";
  display: block;
  height: .1rem;
  left: 50%;
  position: absolute;
  top: 100%;
  transform: translateX(-50%);
  width: clamp(0px, 37.3944444444vw, 33.655rem)
}

.outline__detail {
  display: flex;
  flex-direction: column;
  font-size: clamp(0px, 4.4444444444vw, 2.5rem);
  font-weight: 700;
  line-height: 1;
  row-gap: 4rem;
  row-gap: clamp(0px, 4.4444444444vw, 4rem);
  text-align: center
}

.outline__detail a {
  text-decoration: underline;
  text-underline-offset: .5rem
}

.pleasure {
  background-image: url(../images/pleasure_bg.webp);
  background-position: 50%;
  background-size: cover;
  padding: clamp(0px, 14.8571428571vw, 10.4rem) 2rem
}

.pleasure__head {
  margin: 0 auto clamp(0px, 9.4444444444vw, 8.5rem);
  max-width: 68.4rem
}

.pleasure__list {
  -moz-column-gap: 3.75rem;
  column-gap: 3.75rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(38.8rem, 1fr));
  margin: 0 auto;
  max-width: 123.9rem;
  row-gap: 5rem
}

@media screen and (max-width:1280px) {
  .pleasure__list {
    grid-template-columns: repeat(auto-fit, minmax(25rem, 1fr));
    max-width: 81.4rem
  }
}

@media screen and (max-width:1280px) and (max-width:500px) {
  .pleasure__list {
    display: flex;
    flex-direction: column
  }
}

.pleasure__item {
  align-items: stretch;
  min-height: 54.3rem
}

@media screen and (max-width:500px) {
  .pleasure__item {
    min-height: auto
  }
}

.pleasure__item-content {
  display: flex;
  flex-direction: column;
  min-height: inherit
}

.pleasure__item-thumb {
  border: .3rem solid #1d0202;
  margin-bottom: 4.5rem
}

.pleasure__item-head {
  font-size: 2rem;
  font-weight: 700;
  line-height: normal;
  margin-bottom: 1.4rem;
  text-align: center
}

@media screen and (max-width:500px) {
  .pleasure__item-head {
    line-height: normal
  }
}

.pleasure__item-desc {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.6666666667
}

.pleasure__item-btn,
.booth__item-desc a.pleasure__item-btn{
  background-color: #fff;
  border: .1rem solid #707070;
  border-radius: 99.9rem;
  display: grid;
  font-size: 1.8rem;
  height: 5.8rem;
  margin: auto auto 0;
  max-width: 21.5rem;
  place-items: center;
  width: 100%;
}
.booth__item-desc a.pleasure__item-btn{
    margin-top: 1.5rem;
}

@media screen and (max-width:577px) {
  .pleasure__item-btn {
    margin-top: clamp(0px, 8vw, 4rem)
  }
}

.about {
  background-image: url(../images/about_bg.webp);
  background-size: cover;
  padding: clamp(0px, 13.2222222222vw, 11.9rem) 2rem clamp(0px, 19vw, 17.1rem)
}

.about__head {
  background-color: rgba(126, 206, 244, .56);
  border-radius: 99.9rem;
  box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .67);
  font-size: clamp(0px, 5.6666666667vw, 3.4rem);
  line-height: 1;
  margin: 0 auto;
  max-width: 84.3rem;
  padding-bottom: 2.8rem;
  padding-top: 2.7rem
}

.about__head, .about__head-sub {
  font-weight: 700;
  text-align: center
}

.about__head-sub {
  font-size: clamp(0px, 6.6666666667vw, 4rem);
  line-height: normal;
  margin-top: clamp(0px, 9.2222222222vw, 8.3rem)
}

.about__desc {
  font-size: clamp(0px, 5vw, 2rem);
  font-weight: 700;
  line-height: 1.8;
  margin-top: clamp(0px, 5.5555555556vw, 5rem);
  text-align: center
}

.booth {
  background-image: url(../images/booth_bg.webp);
  background-position: 50%;
  background-size: cover;
  padding: clamp(0px, 14.5555555556vw, 13.1rem) 2rem clamp(0px, 20.6666666667vw, 18.6rem)
}

@media screen and (max-width:1920px) {
  .booth {
    background-position: top;
    background-repeat: repeat-y;
    background-size: contain
  }
}

.booth__head {
  margin: 0 auto 5.3rem;
  max-width: 56.2rem
}

.booth__list {
  align-items: stretch;
  -moz-column-gap: 2.2rem;
  column-gap: 2.2rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(48rem, 1fr));
  margin: 0 auto;
  max-width: 142.6rem;
  row-gap: 3.6rem
}

@media screen and (max-width:1021px) {
  .booth__list {
    display: flex;
    flex-direction: column;
    max-width: 70.2rem
  }
}

.booth__item {
  background-color: #fff;
  border: .4rem solid #707070;
  min-height: 81.4rem;
  padding: 3.5rem 2rem 5rem
}

@media screen and (max-width:1021px) {
  .booth__item {
    min-height: auto
  }
}

.booth__item-content {
  height: inherit;
  margin: 0 auto;
  max-width: 58.8rem;
  min-height: inherit
}

.booth__item-company {
  font-size: clamp(0px, 5vw, 2rem);
  font-weight: 700;
  line-height: 1;
  margin-bottom: clamp(0px, 5.8333333333vw, 3.5rem)
}

.booth__item-thumb {
  margin-bottom: 3.1rem
}

.booth__item-head {
  font-size: clamp(0px, 5.4545454545vw, 3rem);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.6rem;
  min-height: 7.2rem
}

.booth__item-head span {
  font-size: 2.6rem
}

@media screen and (max-width:1021px) {
  .booth__item-head {
    min-height: auto
  }
}

.booth__item-desc {
    font-size: clamp(0px, 5vw, 1.5rem);
    font-weight: 700;
    line-height: 1.8;
    word-break: break-all
}

.booth__item-desc a {
  color: #0019ff;
  display: inline-block;
  word-break: break-all
}

.booth__item-desc .emphasis {
  color: red
}

.kv {
  background-image: url(../images/kv_bg.webp);
  background-position: 50%;
  background-size: cover;
  margin-top: clamp(0px, 13vw, 11.7rem);
  padding: clamp(0px, 10.5714285714vw, 7.4rem) 2rem clamp(0px, 6.1428571429vw, 4.3rem)
}

.kv picture {
  box-shadow: 0 .3rem .6rem rgba(0, 0, 0, .16);
  margin: 0 auto;
  max-width: 144rem
}

.footer {
  background-color: #f9f1e0;
  padding: clamp(0px, 20.1111111111vw, 18.1rem) 2rem clamp(0px, 31.3333333333vw, 28.2rem)
}

.footer__container {
  margin: 0 auto;
  max-width: 139.4rem
}

.footer__list {
  display: flex;
  flex-direction: column;
  row-gap: clamp(0px, 13.2222222222vw, 11.9rem)
}

.footer__item {
  border-radius: clamp(0px, 7.3333333333vw, 6.6rem);
  box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .67);
  width: 80%;
  margin-right: auto;
  margin-left: auto
}

.footer__item--mustard {
  background-color: rgba(252, 199, 93, .56)
}
.footer__item--gray{
    background-color: rgba(35, 25, 22, .56);
    color: #fff;
    margin-top: 80px;
}

.footer__item--avocado {
  background-color: rgba(122, 191, 172, .56)
}

.footer__item:first-of-type {
  padding-bottom: clamp(0px, 7.1111111111vw, 6.4rem);
  padding-top: clamp(0px, 7.8888888889vw, 7.1rem)
}

.footer__item:last-of-type {
  padding-bottom: clamp(0px, 10.8888888889vw, 9.8rem);
  padding-top: clamp(0px, 7.3333333333vw, 6.6rem)
}

.footer__item-head {
  font-size: clamp(0px, 6.7142857143vw, 4.7rem);
  font-weight: 700;
  line-height: 1;
  margin-bottom: clamp(0px, 6.2857142857vw, 4.4rem);
  padding-bottom: clamp(0px, 4.2857142857vw, 3rem);
  position: relative;
  text-align: center
}

.footer__item-head:before {
  background-color: #707070;
  bottom: 0;
  content: "";
  display: block;
  height: .1rem;
  left: 50%;
  max-width: 33.655rem;
  position: absolute;
  transform: translateX(-50%);
  width: clamp(0px, 37.3944444444vw, 33.655rem)
}
.tanq__area .footer__item-head:before {
  background-color: #fff;
  bottom: 0;
  content: "";
  display: block;
  height: .1rem;
  left: 50%;
  max-width: 33.655rem;
  position: absolute;
  transform: translateX(-50%);
  width: clamp(0px, 37.3944444444vw, 33.655rem)
}
.footer__item-head--notice:after {
  color: #fd5d5d;
  content: "※出場順";
  font-size: clamp(0px, 4vw, 2rem);
  left: 50%;
  position: absolute;
  top: 100%;
  transform: translate(-50%, 80%)
}

.footer__item-detail {
    display: flex;
    flex-direction: column;
        font-size: clamp(0px, 5vw, 2rem);
    font-weight: 700;
    line-height: 2;
    row-gap: clamp(0px, 4.4444444444vw, 2rem);
    text-align: center;
}

.divider {
  height: 4.3rem
}

.divider--yellow {
  background-color: #fff7d2
}

.u-md--hidden {
  display: block
}
.tanq__area .about__head-sub small{
    font-size: 80%;
    color: #FD5D5D;
    display: inline-block;
    margin-top: 32px
}
.footer__box{
    background: #C5DEED;
    padding: 16px;
}
.footer__box div{
    display: flex;
    gap: 24px;
    justify-content: center;
}
.footer__box img{
    width: 48px;
}
.footer__box p{
    margin-top: 24px;
    font-size: clamp(0px, 5vw, 1.5rem);
    line-height: 1.8;
    text-align: center;
}
@media screen and (max-width:768px) {
  .u-md--hidden {
    display: none
  }

    .footer__item {
      width: 100%;
    }
}

.u-md--block {
  display: none
}

@media screen and (max-width:768px) {
  .u-md--block {
    display: block
  }
  .supports__item:nth-of-type(4) .supports__item-body picture{
      width: 100% !important;
  }
  .supports__item-body > a,
  .supports__item-body > picture{
      width: 60% !important;
      margin: auto;
  }
}