@charset "UTF-8";
/*===============================
色設定
================================*/
.gray1 {
  color: rgb(245, 245, 245);
}

.bg_gray1 {
  background-color: rgb(245, 245, 245);
}

.bd_gray1 {
  border-color: rgb(245, 245, 245);
}

.nav_pc.gray1 {
  border-bottom: 10px solid rgb(245, 245, 245);
}

.nav_sp.gray1 {
  border-bottom: 10px solid rgb(245, 245, 245);
}

.gray2 {
  color: rgb(220, 220, 220);
}

.bg_gray2 {
  background-color: rgb(220, 220, 220);
}

.bd_gray2 {
  border-color: rgb(220, 220, 220);
}

.nav_pc.gray2 {
  border-bottom: 10px solid rgb(220, 220, 220);
}

.nav_sp.gray2 {
  border-bottom: 10px solid rgb(220, 220, 220);
}

.gray3 {
  color: rgb(100, 100, 100);
}

.bg_gray3 {
  background-color: rgb(100, 100, 100);
}

.bd_gray3 {
  border-color: rgb(100, 100, 100);
}

.nav_pc.gray3 {
  border-bottom: 10px solid rgb(100, 100, 100);
}

.nav_sp.gray3 {
  border-bottom: 10px solid rgb(100, 100, 100);
}

.gray4 {
  color: rgb(50, 50, 50);
}

.bg_gray4 {
  background-color: rgb(50, 50, 50);
}

.bd_gray4 {
  border-color: rgb(50, 50, 50);
}

.nav_pc.gray4 {
  border-bottom: 10px solid rgb(50, 50, 50);
}

.nav_sp.gray4 {
  border-bottom: 10px solid rgb(50, 50, 50);
}

.blue1 {
  color: rgb(209, 222, 235);
}

.bg_blue1 {
  background-color: rgb(209, 222, 235);
}

.bd_blue1 {
  border-color: rgb(209, 222, 235);
}

.nav_pc.blue1 {
  border-bottom: 10px solid rgb(209, 222, 235);
}

.nav_sp.blue1 {
  border-bottom: 10px solid rgb(209, 222, 235);
}

.blue2 {
  color: rgb(147, 195, 231);
}

.bg_blue2 {
  background-color: rgb(147, 195, 231);
}

.bd_blue2 {
  border-color: rgb(147, 195, 231);
}

.nav_pc.blue2 {
  border-bottom: 10px solid rgb(147, 195, 231);
}

.nav_sp.blue2 {
  border-bottom: 10px solid rgb(147, 195, 231);
}

.blue3 {
  color: rgb(84, 163, 213);
}

.bg_blue3 {
  background-color: rgb(84, 163, 213);
}

.bd_blue3 {
  border-color: rgb(84, 163, 213);
}

.nav_pc.blue3 {
  border-bottom: 10px solid rgb(84, 163, 213);
}

.nav_sp.blue3 {
  border-bottom: 10px solid rgb(84, 163, 213);
}

.blue4 {
  color: rgb(0, 140, 201);
}

.bg_blue4 {
  background-color: rgb(0, 140, 201);
}

.bd_blue4 {
  border-color: rgb(0, 140, 201);
}

.nav_pc.blue4 {
  border-bottom: 10px solid rgb(0, 140, 201);
}

.nav_sp.blue4 {
  border-bottom: 10px solid rgb(0, 140, 201);
}

.blue4a {
  color: rgba(0, 140, 201, 0.7);
}

.bg_blue4a {
  background-color: rgba(0, 140, 201, 0.7);
}

.bd_blue4a {
  border-color: rgba(0, 140, 201, 0.7);
}

.nav_pc.blue4a {
  border-bottom: 10px solid rgba(0, 140, 201, 0.7);
}

.nav_sp.blue4a {
  border-bottom: 10px solid rgba(0, 140, 201, 0.7);
}

.blue5 {
  color: rgb(18, 120, 187);
}

.bg_blue5 {
  background-color: rgb(18, 120, 187);
}

.bd_blue5 {
  border-color: rgb(18, 120, 187);
}

.nav_pc.blue5 {
  border-bottom: 10px solid rgb(18, 120, 187);
}

.nav_sp.blue5 {
  border-bottom: 10px solid rgb(18, 120, 187);
}

.pink1 {
  color: rgb(240, 210, 220);
}

.bg_pink1 {
  background-color: rgb(240, 210, 220);
}

.bd_pink1 {
  border-color: rgb(240, 210, 220);
}

.nav_pc.pink1 {
  border-bottom: 10px solid rgb(240, 210, 220);
}

.nav_sp.pink1 {
  border-bottom: 10px solid rgb(240, 210, 220);
}

.pink2 {
  color: rgb(230, 140, 160);
}

.bg_pink2 {
  background-color: rgb(230, 140, 160);
}

.bd_pink2 {
  border-color: rgb(230, 140, 160);
}

.nav_pc.pink2 {
  border-bottom: 10px solid rgb(230, 140, 160);
}

.nav_sp.pink2 {
  border-bottom: 10px solid rgb(230, 140, 160);
}

.pink2a {
  color: rgba(230, 140, 160, 0.7);
}

.bg_pink2a {
  background-color: rgba(230, 140, 160, 0.7);
}

.bd_pink2a {
  border-color: rgba(230, 140, 160, 0.7);
}

.nav_pc.pink2a {
  border-bottom: 10px solid rgba(230, 140, 160, 0.7);
}

.nav_sp.pink2a {
  border-bottom: 10px solid rgba(230, 140, 160, 0.7);
}

.yellow1 {
  color: rgb(235, 225, 135);
}

.bg_yellow1 {
  background-color: rgb(235, 225, 135);
}

.bd_yellow1 {
  border-color: rgb(235, 225, 135);
}

.nav_pc.yellow1 {
  border-bottom: 10px solid rgb(235, 225, 135);
}

.nav_sp.yellow1 {
  border-bottom: 10px solid rgb(235, 225, 135);
}

.yellow2 {
  color: rgb(220, 170, 0);
}

.bg_yellow2 {
  background-color: rgb(220, 170, 0);
}

.bd_yellow2 {
  border-color: rgb(220, 170, 0);
}

.nav_pc.yellow2 {
  border-bottom: 10px solid rgb(220, 170, 0);
}

.nav_sp.yellow2 {
  border-bottom: 10px solid rgb(220, 170, 0);
}

.yellow2a {
  color: rgba(220, 170, 0, 0.7);
}

.bg_yellow2a {
  background-color: rgba(220, 170, 0, 0.7);
}

.bd_yellow2a {
  border-color: rgba(220, 170, 0, 0.7);
}

.nav_pc.yellow2a {
  border-bottom: 10px solid rgba(220, 170, 0, 0.7);
}

.nav_sp.yellow2a {
  border-bottom: 10px solid rgba(220, 170, 0, 0.7);
}

.bg_art1 {
  background-color: mediumseagreen;
}

.bga_art1 {
  background-color: rgba(60, 179, 113, 0.8);
}

.bg_art2 {
  background-color: royalblue;
}

.bga_art2 {
  background-color: rgba(65, 105, 225, 0.8);
}

.bg_hit1 {
  background-color: orange;
}

.bga_hit1 {
  background-color: rgba(255, 165, 0, 0.8);
}

.bg_hit2 {
  background-color: mediumorchid;
}

.bga_hit2 {
  background-color: rgba(186, 85, 211, 0.8);
}

.bg_life1 {
  background-color: cadetblue;
}

.bga_life1 {
  background-color: rgba(95, 158, 160, 0.8);
}

.bg_life2 {
  background-color: yellowgreen;
}

.bga_life2 {
  background-color: rgba(154, 205, 50, 0.8);
}

.bg_para1 {
  background-color: crimson;
}

.bga_para1 {
  background-color: rgba(220, 20, 60, 0.8);
}

.bg_para2 {
  background-color: deepskyblue;
}

.bga_para2 {
  background-color: rgba(0, 191, 255, 0.8);
}

.bg_work1 {
  background-color: goldenrod;
}

.bga_work1 {
  background-color: rgba(218, 165, 32, 0.8);
}

.bg_work2 {
  background-color: tomato;
}

.bga_work2 {
  background-color: rgba(255, 99, 71, 0.8);
}

.bg_work3 {
  background-color: mediumturquoise;
}

.bga_work3 {
  background-color: rgba(72, 209, 204, 0.8);
}

.bg_work4 {
  background-color: firebrick;
}

.bga_work4 {
  background-color: rgba(178, 34, 34, 0.8);
}

.bg_work5 {
  background-color: peru;
}

.bga_work5 {
  background-color: rgba(205, 133, 63, 0.8);
}

.bg_para3 {
  background-color: dodgerblue;
}

.bga_para3 {
  background-color: rgba(30, 144, 255, 0.8);
}

.bg_life3 {
  background-color: mediumseagreen;
}

.bga_life3 {
  background-color: rgba(60, 179, 113, 0.8);
}

.bg_hit3 {
  background-color: saddlebrown;
}

.bga_hit3 {
  background-color: rgba(139, 69, 19, 0.8);
}

.bg_work6 {
  background-color: midnightblue;
}

.bga_work6 {
  background-color: rgba(25, 25, 112, 0.8);
}

.bg_life4 {
  background-color: teal;
}

.bga_life4 {
  background-color: rgba(0, 128, 128, 0.8);
}

.bg_hit4 {
  background-color: plum;
}

.bga_hit4 {
  background-color: rgba(221, 160, 221, 0.8);
}

.bg_work7 {
  background-color: indigo;
}

.bga_work7 {
  background-color: rgba(75, 0, 130, 0.8);
}

.bg_para4 {
  background-color: navy;
}

.bga_para4 {
  background-color: rgba(0, 0, 128, 0.8);
}

.bg_life5 {
  background-color: #0c5b97;
}

.bga_life5 {
  background-color: rgba(12, 91, 151, 0.8);
}

.bg_para5 {
  background-color: darkkhaki;
}

.bga_para5 {
  background-color: rgba(189, 183, 107, 0.8);
}

.bg_work8 {
  background-color: seagreen;
}

.bga_work8 {
  background-color: rgba(46, 139, 87, 0.8);
}

.bg_life6 {
  background-color: #333333;
}

.bga_life6 {
  background-color: rgba(51, 51, 51, 0.8);
}

.bg_life7 {
  background-color: forestgreen;
}

.bga_life7 {
  background-color: rgba(34, 139, 34, 0.8);
}

.bg_work9 {
  background-color: goldenrod;
}

.bga_work9 {
  background-color: rgba(218, 165, 32, 0.8);
}

.bg_work10 {
  background-color: darkturquoise;
}

.bga_work10 {
  background-color: rgba(0, 206, 209, 0.8);
}

.bg_life8 {
  background-color: steelblue;
}

.bga_life8 {
  background-color: rgba(70, 130, 180, 0.8);
}

/*===============================
メディアクエリ
================================*/
/*===============================
入力省略
================================*/
.bnr .type .inryo {
  background-color: rgb(40, 208, 220);
}

#type_inryo:checked ~ label {
  border-bottom: 5px solid rgb(40, 208, 220);
}

.all_booth .type .inryo {
  background-color: rgb(40, 208, 220);
}

.bnr .type .kakou {
  background-color: rgb(212, 98, 23);
}

#type_kakou:checked ~ label {
  border-bottom: 5px solid rgb(212, 98, 23);
}

.all_booth .type .kakou {
  background-color: rgb(212, 98, 23);
}

.bnr .type .kashi {
  background-color: rgb(245, 86, 197);
}

#type_kashi:checked ~ label {
  border-bottom: 5px solid rgb(245, 86, 197);
}

.all_booth .type .kashi {
  background-color: rgb(245, 86, 197);
}

.bnr .type .sakumotsu {
  background-color: rgb(0, 199, 106);
}

#type_sakumotsu:checked ~ label {
  border-bottom: 5px solid rgb(0, 199, 106);
}

.all_booth .type .sakumotsu {
  background-color: rgb(0, 199, 106);
}

.bnr .type .zakka {
  background-color: rgb(140, 120, 230);
}

#type_zakka:checked ~ label {
  border-bottom: 5px solid rgb(140, 120, 230);
}

.all_booth .type .zakka {
  background-color: rgb(140, 120, 230);
}

.bnr .type .pan {
  background-color: rgb(150, 103, 41);
}

#type_pan:checked ~ label {
  border-bottom: 5px solid rgb(150, 103, 41);
}

.all_booth .type .pan {
  background-color: rgb(150, 103, 41);
}

.bnr .type .bento {
  background-color: rgb(233, 48, 48);
}

#type_bento:checked ~ label {
  border-bottom: 5px solid rgb(233, 48, 48);
}

.all_booth .type .bento {
  background-color: rgb(233, 48, 48);
}

.bnr .type .sozai {
  background-color: rgb(9, 159, 84);
}

#type_sozai:checked ~ label {
  border-bottom: 5px solid rgb(9, 159, 84);
}

.all_booth .type .sozai {
  background-color: rgb(9, 159, 84);
}

.bnr .type .art {
  background-color: rgb(132, 57, 190);
}

#type_art:checked ~ label {
  border-bottom: 5px solid rgb(132, 57, 190);
}

.all_booth .type .art {
  background-color: rgb(132, 57, 190);
}

.bnr .type .sports {
  background-color: rgb(48, 139, 224);
}

#type_sports:checked ~ label {
  border-bottom: 5px solid rgb(48, 139, 224);
}

.all_booth .type .sports {
  background-color: rgb(48, 139, 224);
}

.bnr .type .fukushoku {
  background-color: rgb(44, 135, 41);
}

#type_fukushoku:checked ~ label {
  border-bottom: 5px solid rgb(44, 135, 41);
}

.all_booth .type .fukushoku {
  background-color: rgb(44, 135, 41);
}

.bnr .type .interior {
  background-color: rgb(224, 133, 48);
}

#type_interior:checked ~ label {
  border-bottom: 5px solid rgb(224, 133, 48);
}

.all_booth .type .interior {
  background-color: rgb(224, 133, 48);
}

.bnr .type .nichiyouhin {
  background-color: rgb(224, 48, 192);
}

#type_nichiyouhin:checked ~ label {
  border-bottom: 5px solid rgb(224, 48, 192);
}

.all_booth .type .nichiyouhin {
  background-color: rgb(224, 48, 192);
}

.bnr .type .other {
  background-color: rgb(160, 160, 160);
}

#type_other:checked ~ label {
  border-bottom: 5px solid rgb(160, 160, 160);
}

.all_booth .type .other {
  background-color: rgb(160, 160, 160);
}

.bnr .area {
  background-color: #fff;
}

/*===============================
地図
================================*/
.map {
  max-width: 600px;
  width: 90%;
  margin: 0 auto;
  margin: 30px auto;
}
.map > div {
  position: relative;
}
.map > div .button {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.map > div .button {
  width: 20%;
  right: auto;
  bottom: auto;
}
.map > div .button:hover > .tooltip {
  visibility: visible;
  opacity: 1;
}
.map > div .button .tooltip {
  visibility: hidden;
  text-align: center;
  position: absolute;
  z-index: 1;
  opacity: 0;
  transition: opacity 500ms;
  width: 400%;
  top: 50%;
  left: 110%;
  transform: translateY(-50%);
}
.map > div .button .tooltip > .text {
  background-color: rgb(84, 163, 213);
  color: #fff;
  border-radius: 6px;
  font-size: 0.8em;
  line-height: 1.5;
  text-align: justify;
  display: inline-block;
}
.map > div .button .tooltip > .text::after {
  content: "";
  position: absolute;
  top: calc(50% - 5px);
  left: 0;
  margin-left: -18px;
  border-width: 10px;
  border-style: solid;
  border-color: transparent rgb(84, 163, 213) transparent transparent;
}
.map > div .button .tooltip > .text li {
  margin: 10px;
}
.map > div .button .tooltip > .text li span {
  background-color: #fff;
  color: rgb(0, 140, 201);
  padding: 3px 5px;
  border-radius: 4px;
  font-weight: bold;
  vertical-align: text-bottom;
}

/*===============================
種別で絞り込み
================================*/
#js-filter {
  width: 100%;
  text-align: center;
  color: #fff;
  background-color: rgb(100, 100, 100);
  padding: 10px 0;
  overflow: hidden;
}
#js-filter.fixed {
  position: fixed;
  top: 0;
  z-index: 1;
}
#js-filter > div {
  position: relative;
  border-bottom: solid 2px rgb(50, 50, 50);
}
#js-filter > div > p, #js-filter > div > button, #js-filter > div > label {
  display: inline-block;
  vertical-align: middle;
}
#js-filter > div:before, #js-filter > div:after {
  content: "";
  position: absolute;
  top: 100%;
  left: calc(50% + 143px);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
#js-filter > div:before {
  border: solid 10px transparent;
  border-top: solid 10px rgb(50, 50, 50);
}
#js-filter > div:after {
  border: solid 12px transparent;
  border-top: solid 12px rgb(100, 100, 100);
  margin-top: -5px;
}
#js-filter > div:has(.acd-check:checked):before {
  border: none;
  border-bottom: solid 12px rgb(50, 50, 50);
  border-top: initial;
  margin-top: -10px;
}
#js-filter > div:has(.acd-check:checked):after {
  border: none;
  border-bottom: solid 14px rgb(100, 100, 100);
  border-top: initial;
  margin-top: -7px;
}
#js-filter p {
  font-size: 1.2em;
  padding-right: 10px;
}
#js-filter button {
  cursor: pointer;
  border-radius: 100vh;
  padding: 0 10px;
  border: none;
}
#js-filter input {
  border: 0;
  height: 1px;
  width: 1px;
  margin: -1px;
}
#js-filter input + label {
  cursor: pointer;
  opacity: 0.5;
  margin: 0 5px;
}
#js-filter input:checked + label {
  opacity: 1;
}
#js-filter input:focus-visible + label {
  outline: solid;
}
#js-filter ul {
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 5px;
}
#js-filter ul li {
  line-height: 2em;
}
#js-filter .acd-label {
  border: none;
  color: #fff;
  opacity: 1;
}
#js-filter .acd-label::after {
  content: "＋";
}
#js-filter .acd-content {
  height: 0;
  opacity: 0;
  visibility: hidden;
}
#js-filter .acd-check:checked + .acd-label + .acd-content {
  height: auto;
  opacity: 1;
  visibility: visible;
}
#js-filter .acd-check:checked + .acd-label::after {
  content: "ー";
}

@media screen and (max-width: 560px) {
  #js-filter ul {
    padding-right: 70px;
  }
}
/*===============================
検索
================================*/
.search_container {
  width: 100%;
}
.search_container input {
  margin: 30px auto;
  width: 250px; /* Full-width */
  font-size: 1em; /* Increase font-size */
  padding: 10px; /* Add some padding */
  border: 1px solid #ddd; /* Add a grey border */
  margin-bottom: 12px; /* Add some space below the input */
  border-radius: 10px;
  display: block;
}

/*===============================
ブース出展者
================================*/
.provider_content {
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
}
.provider_content ul::after {
  content: "";
  display: block;
  width: 30%;
  height: 0;
}
.provider_content li {
  width: 30%;
  margin: 20px 0;
}

@media screen and (max-width: 800px) {
  .provider_content li {
    width: 47.5%;
    margin: 20px 0;
  }
}
@media screen and (max-width: 560px) {
  .provider_content li {
    width: 100%;
    margin: 20px 0;
  }
}
.bnr {
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
  height: 100%;
}
.bnr .type span {
  display: inline-block;
  padding: 5px;
  color: #fff;
  border-radius: 5px 5px 0 0;
  margin-right: 5px;
  font-size: 0.8em;
}
.bnr .images {
  position: relative;
  min-height: 0%;
}
.bnr .images .area {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.bnr .images .area {
  color: rgb(50, 50, 50);
  padding: 5px;
  bottom: auto;
  left: auto;
}
.bnr .texts {
  background-color: rgb(235, 225, 135);
  border-radius: 0 0 10px 10px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  flex: 1 0 auto;
}
.bnr .texts h3 {
  color: rgb(100, 100, 100);
  padding-bottom: 5px;
  line-height: 1.2;
}
.bnr .texts p {
  position: relative;
  color: rgb(50, 50, 50);
  font-size: 0.8em;
  line-height: 1.2;
  text-align: justify;
  height: 3.4em;
}

/*===============================
ポップアップ
================================*/
.modal-inner figure {
  width: 50%;
  padding: 0 20px 20px 0;
}
.modal-inner figure img {
  height: 100%;
  object-fit: cover;
  font-family: "object-fit: cover;";
}
.modal-inner .info1 {
  width: 50%;
}
.modal-inner .info1 dl {
  padding-bottom: 10px;
}
.modal-inner dl,
.modal-inner dt,
.modal-inner dd {
  text-align: left;
}
.modal-inner dd {
  float: none;
  margin-left: 5em;
  margin-bottom: 1em;
  line-height: 1.5;
}
.modal-inner .data.name {
  font-weight: bold;
  font-size: 1.2em;
  color: rgb(100, 100, 100);
  margin-left: 4.2em;
  line-height: 1.1;
}
.modal-inner a {
  background-color: rgb(0, 140, 201);
  color: #fff;
  border-radius: 5px;
  padding: 2px 5px 0 5px;
}
.modal-inner .info2 div {
  text-align: right;
}
.modal-inner .info2 div a {
  display: inline-block;
}

@media screen and (max-width: 560px) {
  .modal-inner .flex {
    flex-direction: column;
  }
  .modal-inner figure {
    padding-right: 0;
  }
  .modal-inner figure,
  .modal-inner .info1 {
    width: 100%;
  }
}
.modal-num {
  display: block;
  position: absolute;
  top: -20px;
  z-index: 12;
  font-size: 1rem;
  color: #fff;
}

/*===============================
全地域ブース出展者
================================*/
.all_booth {
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
}
.all_booth h2 {
  text-align: center;
  color: rgb(100, 100, 100);
  font-size: 1.2em;
  padding: 2% 0;
  line-height: 1.3;
}
.all_booth ul {
  font-size: 0.7em;
  background-color: rgb(209, 222, 235);
  background-color: #fff;
  border: solid 1px rgb(209, 222, 235);
}
.all_booth ul li {
  border-bottom: solid 1px rgb(209, 222, 235);
  padding: 5px 0;
  line-height: 1.3;
  align-items: center;
}
.all_booth ul li > * {
  padding: 0 5px;
}
.all_booth ul li > *:not(:last-child) {
  border-right: solid 1px rgb(209, 222, 235);
}
.all_booth ul li:nth-child(even) {
  background-color: #f4f1dd;
}
.all_booth .area {
  width: 10%;
  border-right: solid 1px rgb(209, 222, 235);
}
.all_booth .name {
  width: 20%;
}
.all_booth .info {
  width: 50%;
}
.all_booth .type {
  width: 20%;
  color: #fff;
}
.all_booth .type span {
  padding: 4px;
  border-radius: 5px;
  margin-right: 5px;
}