@charset "UTF-8";

:root {
  --themered: #ae3923;
  --themeyellow: #f0d768;
  --themebrown: #c0a17b;
  --themewhite: #f4f5f5;

  --lightbrown: #eadfd2;
  --white: #ffffff;
  --black: #3e3a39;
  --gray: #d8d8d7;
}

/*6/16に公開
.laterkotira{
  font-size: 0;
  text-decoration: none;
  pointer-events: none;
}
.laterkotira::before{
  content: "6/19(水)公開予定";
  font-size: 11px;
  color: var(--mojiblack);
  -webkit-text-fill-color: var(--mojiblack);
}
@media screen and (min-width:1024px) {
.laterkotira::before{font-size: 14px}  
}
.laterpage{
  pointer-events: none;
  color: var(--mojiblack);
  text-decoration:none;
}
.laterpage::before{
  content: "6/16(日)に公開される";
}
.laterbtn{
  display: none;
}
#gronav{display: none!important;}
.footer_middle{display: none!important;}

6/16に公開 fin*/

p {
  text-align: justify;
}

img {
  pointer-events: none;
  width: 100%;
}

li {
  list-style: none;
}

/*詳細1ここから*/

/*Button*/
/*ここ使う*/

/*ここまで*/


/*詳細2ここから*/
/*ここ使う*/
/*pagetitleはgeneralに移行した*/

.pageTitle {
  position: relative;
  /*相対配置*/
  text-align: center;
}

.pageTitle img {
  width: 100%;
  height: 100px;
  object-fit: cover;
}

/*ここまで使う*/
.h2_booth::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--booth);
}

.h2_decoration::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--decoration);
  border-image: linear-gradient(to right bottom, var(--decoration), var(--decoration), #cf4f4f80, transparent) 1;
}

.h2_sympo::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--sympo);
  border-image: linear-gradient(to right bottom, var(--sympo), var(--sympo), #5a744480, transparent) 1;
}

.h2_field::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--field);
  border-image: linear-gradient(to right bottom, var(--field), var(--field), #e08e3680, transparent) 1;
}

.h2_indoor::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--indoor);
  border-image: linear-gradient(to right bottom, var(--indoor), var(--indoor), #415c7080, transparent) 1;
}

.h2_stage::after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  border-bottom: 3px solid var(--stage);
  border-image: linear-gradient(to right bottom, var(--stage), var(--stage), #72bfc480, transparent) 1;
}

/*詳細2ここまで*/
/*ここ使う*/
.li-round {
  color: var(--themeocean);
  margin-right: 1.5px;
}

/*ここまで*/

.li-round-gray {
  color: var(--lightgray);
}


/*ここ使う*/
.detail1Top {
  text-align: center;
  margin: 0 auto;
  background-color: #f2f2f2;
  position: relative;
  padding: 20px 20px 20px 20px;
  margin-top: 3%;
}

.detail1Top div {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.detail1TopTitle {
  font-size: 20px;
  background: linear-gradient(transparent 90%, var(--themeocean) 80%);
  display: inline-block;
}

/*ここまで*/

.moreButton {
  --btn-color: var(--booth);
  /* boothは黄色で視認性が低いため、テキストのみ暗くする */
  --btn-text-color: color-mix(in srgb, var(--booth) 40%, black);
  font-family: "Zen Kaku Gothic New";
  color: var(--btn-text-color);
  border: 1.5px solid var(--btn-color);
  border-radius: 0px;
  background: color-mix(in srgb, var(--btn-color) 10%, transparent);
  box-shadow: 2px 2px 0px #ffffff00;
  position: relative;
  transition: all 0.3s ease 0s;
  padding: 10px 30px;
}

.moreButton_sympo {
  --btn-color: var(--sympo);
  --btn-text-color: var(--sympo);
}

.moreButton_decoration {
  --btn-color: var(--decoration);
  --btn-text-color: var(--decoration);
}

.moreButton:hover {
  background: color-mix(in srgb, var(--btn-color) 25%, transparent);
  border-color: var(--btn-color);
  transition: 0.3s;
}

/* moreButtonを含むdivは .linkwrap div:hover の opacity:0.5 を上書き */
.linkwrap div:has(> .moreButton):hover {
  opacity: 1;
}


.kochira {
  margin-left: 8px;
  width: 5px;
  height: 5px;
  font-size: 23px;
  font-weight: 800;
  position: relative;
  z-index: 2;
}

.kochira.kochira::before,
.kochira.kochira::after {
  content: "";
  display: block;
  width: 13px;
  height: 2px;
  background-color: var(--btn-color);
  position: absolute;
}

moreButtonでは、ホバーしても矢印をボタン色のままにする
.moreButton:hover .kochira::before,
.moreButton:hover .kochira::after,
.moreButton .kochira:hover::before,
.moreButton .kochira:hover::after {
  background-color: var(--btn-color);
}

.kochira::before {
  transform: rotate(45deg);
  top: -1.4px;
}

.kochira::after {
  transform: rotate(-45deg);
  bottom: -4px;
}


/*個別ページfin*/

/* 表 */

th,
td {
  border: solid 2px var(--gray);
  padding: 10px;
  text-align: center;
}

th {
  background-color: var(--themeocean);
  color: var(--white);
}

table {
  border-collapse: collapse;
  width: 100%;
}

/*
.img_azumaya {
  float: right;
  width: 40%;
  max-width: 250px;
  border-radius: 50%;
  margin: 10px 0 20px 20px;
}

.about_detail1Top {
  margin-top: 20px;
}



*/
/*
.galleryWrap {
  font-size: 0;
  margin: 0 0 0 0;
  padding: 10px 0 0 0;
}

.gallery_card {
  display: inline-block;
  text-align: center;
  width: -webkit-calc((99.9% - 20px - 4px)/2);
  width: calc((99.9% - 20px - 4px)/2);
  background-color: var(--white);
  border: 1px dashed var(--gray);
  margin-bottom: 20px;
}

.gallery_card p {
  font-size: 11px;
  padding: 0 10px 10px 10px;
}

.gallery_card img {
  width: -webkit-calc(99.9% - 20px);
  width: calc(99.9% - 20px);
  margin: 10px auto;
}
*/


/*アコーディオンメニュー*/
/*contents*/
/*ここ使う*/
.q_box {
  margin: auto;
  position: relative;
  cursor: pointer;
  border: solid 2px var(--thememix);
  padding: 10px 7% 10px 3%;
  display: flex;
  align-items: center;
  /*    display: block;*/
  font-size: 1.1em;
}

.a_box {
  padding: 2% 2% 5% 2%;
  margin: auto;
  display: block;
  background-color: #fff;
}

.question {
  display: none;
}

.qa {
  position: relative;
  margin-bottom: 1em;
}

.q_box,
.faqcontent {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s;
}

.q_box::after,
.q_box::before {
  content: "";
  position: absolute;
  right: 1em;
  width: 2px;
  height: 0.75em;
  background-color: var(--thememix);
  transition: all 0.3s;
}

.q_box::after {
  transform: rotate(90deg);
}

.faqcontent {
  max-height: 0;
  overflow: hidden;
}

.faqcontent p {
  margin: auto;
}

.question:checked+.q_box+.faqcontent {
  max-height: 1800px;
  transition: all 1.5s;
}

.question:checked+.q_box::before {
  transform: rotate(90deg) !important;
}

/*ここまで*/
/*アコーディオンメニューfin*/

/*企画形態別ページのcss*/
.style_header {
  padding: 15px;
  margin: 0 auto;
}

.style_header p {
  font-size: 17px;
  letter-spacing: 2px;
  color: var(--white);
  padding: 0;
  text-align: center;
  font-weight: 500;
}

.booth_header {
  background-color: var(--booth)
}

.field_header {
  background-color: var(--field)
}

.indoor_header {
  background-color: var(--indoor)
}

.stage_header {
  background-color: var(--stage)
}

.sympo_header {
  background-color: var(--sympo)
}

.decoration_header {
  background-color: var(--decoration)
}

.linkwrap {
  margin-top: 5%;
}

.linkwrap div {
  display: flex;
  justify-content: center;
}

.linkwrap div:hover {
  opacity: 0.5;
}

.linkwrap a {
  display: flex;
  position: relative;
  font-weight: bold;
  z-index: 2;
  align-items: center;
  font-size: 13px;
}

.triangle {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 9px solid var(--themevintage);
  border-right: 0;
  transform: translateY(-35%);
  margin-top: 10.5px;
  margin-left: 2px;
}

.triangle_booth {
  border-left: 9px solid var(--booth);
  margin: 16px 0px 0px 4px;
  filter: drop-shadow(1px 2px 3px rgba(0, 0, 0, 0.5));
}

.triangle_sympo {
  border-left: 9px solid var(--sympo);
}

.triangle_decoration {
  border-left: 9px solid var(--decoration);
}

.materials_link {
  width: calc(96%-15px);
  background-color: var(--white);
  padding: 10px 2%;
  margin: 18px 0;
  box-shadow: 1px 2px 3px #3e3a3957;
  position: relative;
  transition: all 0.3s ease 0s;
  align-content: center;
  display: flex;
  align-content: space-evenly;
  flex-direction: column;
  align-items: center;
}

.materials_link a {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.materials_link p {
  text-align: center;
  color: var(--black);
  font-size: 1.1em;
}

.materials_link:hover {
  box-shadow: none;
  top: 1px;
  left: 1px;
  transition: 0.2s;
}

.materials_name {
  font-family: 'Zen Kaku Gothic New';
  font-weight: 600;
  font-size: 13px;
}

.booth_link {
  border: 3px solid var(--booth)
}

.field_link {
  border: 3px solid var(--field)
}

.indoor_link {
  border: 3px solid var(--indoor)
}

.stage_link {
  border: 3px solid var(--stage)
}

.sympo_link {
  border: 3px solid var(--sympo)
}

.decoration_link {
  border: 3px solid var(--decoration)
}

.booth_form_link {
  border-left: 15px solid var(--booth)
}

.field_form_link {
  border-left: 15px solid var(--field)
}

.indoor_form_link {
  border-left: 15px solid var(--indoor)
}

.stage_form_link {
  border-left: 15px solid var(--stage)
}

.sympo_form_link {
  border-left: 15px solid var(--sympo)
}

.decoration_form_link {
  border-left: 15px solid var(--decoration)
}

.form_link {
  width: calc(96%-15px);
  background-color: var(--themewhite);
  padding: 5px 2%;
  margin: 10px 0;
  position: relative;
  transition: all 0.3s ease 0s;
}

.form_link a {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.form_link:hover {
  opacity: 0.5;
}

.required {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  padding: 3px;
  vertical-align: middle;
  margin: 4px 0px;
  background-color: var(--themered);
  color: var(--white);
}

.form_name {
  font-family: "Zen Kaku Gothic New";
  font-size: 14px;
  font-weight: 600;
  display: inline-block;
  vertical-align: middle;
}

.line {
  margin: 3px;
  border: 1px dashed #b6b6b6;
  width: 85%;
}

.materials_link p.hitokoto {
  font-weight: 400;
  font-size: 10px;
}

.form_note.date {
  font-size: 13px !important;
  color: var(--decoration) !important;
}

@media screen and (min-width: 1024px) {
  .materials_link p.hitokoto {
    font-size: 12px;
  }
}

/*企画形態別ページfin*/

/*企画形態選択ページ*/
.select_header {
  padding: 5px;
  background-color: var(--themevintage);
}

.select_header p {
  font-size: 15px;
  text-align: center;
  padding: 10px 0px;
  margin: 0 auto;
  color: var(--white);
}

.category-wrap {
  margin-top: 30px;
  display: flex;
  flex-wrap: wrap;
  column-gap: 20px;
  row-gap: 20px;
}

.category-wrap p {
  text-align: center;
  padding: 0;
  line-height: 1.5em;
}

.category {
  width: calc((100% - 20px) / 2);
  box-sizing: border-box;
  padding: 10px;
}

.category:hover>p {
  color: var(--white);
}

.category_booth {
  border: 1px solid var(--booth);
}

.category_booth:hover {
  background-color: var(--booth);
}

.category_booth p {
  color: var(--booth);
}

.category_sympo {
  border: 1px solid var(--sympo);
}

.category_sympo:hover {
  background-color: var(--sympo);
}

.category_sympo p {
  color: var(--sympo);
}

.category_indoor {
  border: 1px solid var(--indoor);
}

.category_indoor:hover {
  background-color: var(--indoor);
}

.category_indoor p {
  color: var(--indoor);
}

.category_stage {
  border: 1px solid var(--stage);
}

.category_stage:hover {
  background-color: var(--stage);
}

.category_stage p {
  color: var(--stage);
}

.category_field {
  border: 1px solid var(--field);
}

.category_field:hover {
  background-color: var(--field);
}

.category_field p {
  color: var(--field);
}

.category_decoration {
  border: 1px solid var(--decoration);
}

.category_decoration:hover {
  background-color: var(--decoration);
}

.category_decoration p {
  color: var(--decoration);
}


.category-name1 {
  font-size: 18px;
  font-weight: 500;
}

.category-name2 {
  font-size: 14px;
}

/*企画形態選択ページfin*/

/*faq*/
.pagelink {
  text-decoration: underline;
  text-decoration-color: var(--themeocean);
  color: var(--themeocean);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  font-weight: 400;
  word-break: break-all;
}

/*404ページ*/
.error_contents {
  width: 95%;
  text-align: center;
  margin: 0 auto;
  padding: 10px;
  background-color: var(--themeocean)
}

.error_first {
  color: var(--themewhite);
  font-size: 16px;
  text-align: center;
}

.error_second {
  color: var(--themewhite);
  font-size: 12px;
  text-align: center;
}

/*404ページfin*/

/*企画形態を知る特有css*/

/* PC版 */

@media screen and (min-width: 1024px) {
  h2 {
    font-size: 20px;
  }

  h3 {
    font-size: 17px;
  }

  /*詳細2*/
  .pageTitle img {
    height: 174px;
  }

  .gallery_card {
    display: inline-block;
    text-align: center;
    width: -webkit-calc((99.9% - 40px - 6px)/3);
    width: calc((99.9% - 40px - 6px) / 3);
    background-color: var(--white);
    border: 1px dashed var(--gray);
    margin-bottom: 20px;
  }

  .ekakiuta {
    width: 150px;
  }

  .themePicture {
    width: 50%;
    margin: 0 auto;
  }

  .forpc {
    display: flex;
    width: 100%;
    gap: 5%;
  }

  /*ここ使う*/
  .komidashi {
    font-size: 16px;
  }

  /*ここまで*/
  /*個別ページのみ*/
  .checkpoint {
    top: 16%;
    left: 28%;
    z-index: 20;
  }

  /*個別ページのみfin*/
}