@charset "UTF-8";
/* event-add.css */

/* utility */
.lh15 {
  line-height: 1.5;
}
h2 span {
  font-size: 0.6em;
}
.spec-txt {
  /* font-family: 'Montserrat', sans-serif; */
  font-weight: 900;
  letter-spacing: 0.04em;
}
.yakuhan-txt { font-family: YakuHanJP, 'Lato', "Noto Sans Japanese",sans-serif;}
#wrapper.wrapper-fixed {
  position: fixed;
  width: 100%;
}

body {
  font-family: 'Lato','Noto Sans Japanese', sans-serif;
}

/* hero, prog */
#hero {
  margin-bottom: 0;
}
.event-date {
  background: #49b23e;
  color: #fff;
  font-weight: bold;
  font-size: 1.5em;
  padding: 0.5em;
  text-align: center;
}
.head-content {
  margin-bottom: 0;
}
.prog-item {
  border: 1px solid #00a73c;
}
.prog-time {
  background: #00a73c;
  color: #fff;
  font-size: 1.2em;
  font-weight: bold;
  padding: 8px;
  text-align: center;
}
.prog-info {
  color: #00a73c;
  padding: 18px;
}
.prog-ttl b,
.prog-ttl strong {
  display: block;
}
.prog-ttl strong {
  border-top: 2px solid #00a73c;
  font-size: 1.3em;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
  padding-top: 0.5em;
}
.prog-place {
  color: #000;
}
@media (max-width: 600px) {
  header {
    z-index: 11;
  }
  img {
    height: auto;
    max-width: 100%;
  }
  #form-btn, #page-top {
    z-index: 10;
  }
  .prog-contents {
    padding: 0 3vw;
  }
  .prog-item + .prog-item {
    margin-top: 30px;
  }
}
@media (min-width: 601px) {
  body { font-size: 16px;}
  .event-date {
    font-size: 40px;
    padding: 0.4em;
  }
  #prog {
    margin-top: 80px;
  }
  .prog-contents {
    display: flex;
    justify-content: space-between;
  }
  .prog-item {
    width: 325px;
  }
}


/* entry-fee */
.entry-fee-ttl {
  background: #00a73c;
  color: #fff;
  font-size: 1.2em;
  font-weight: bold;
  text-align: center;
  padding: 8px 16px 10px;
}
.entry-fee-ttl span {
  font-size: 0.8em;
}
.entry-fee-types {
  font-weight: bold;
}
.entry-fee-types span {
  background: linear-gradient(transparent 75%, #FF8B61 76%, #FF8B61 100%);
}
.entry-fee-note {
  border: 2px solid #e60012;
  border-radius: 5px;
  color: #e60012;
  font-weight: bold;
  padding: 1em;
}
@media (max-width: 600px) {
  .entry-fee {
    margin: 50px 0;
    text-align: center;
  }
  .entry-fee-ttl span {
    margin-left: 15px;
  }
  .entry-fee-types {
    font-size: 1.15em;
    font-family: YakuHanJP, 'Lato', "Noto Sans Japanese",sans-serif;
    margin: 20px 0;
  }
  .entry-fee-note {
    margin: 0 auto;
    width: 94vw;
  }
}
@media (min-width: 601px) {
  .entry-fee {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 40px auto;
  }
  .entry-fee-ttl {
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4em;
    min-height: 84px;
    padding: 0 24px;
  }
  .entry-fee-types {
    font-size: 1.6em;
    margin: 0 20px;
  }
  .entry-fee-note {
    text-align: center;
  }
}

/* member */
#member {
  margin: 60px auto 0;
}
.member-ttl-sub {
  text-align: center;
}
#member h3 {
  margin-bottom: 30px;
  color: #666;
  text-align: center;
}
.member-pos,
.member-name {
  font-weight: bold;
}
.member-name {
  margin-bottom: 0.5em;
}
.member-name strong {
  font-size: 1.4em;
}
.member-box + .member-box {
  margin-top: 40px;
}
.member-info p:last-child {
  text-align: justify;
}
@media (max-width: 600px) {
  #member h3 img {
    height: 80px;
    width: auto;
  }
  .member-info {
    padding: 20px 4vw;
  }
}
@media (min-width: 601px) {
  #member {
    margin: 104px auto 0;
    width: 960px;
  }
  #member h3 {
    font-size: 36px;
    margin-top: 16px;
    margin-bottom: 40px;
  }
  .member-box {
    display: flex;
    align-items: center;
    width: 800px;
  }
  .member-box:nth-of-type(even) {
    flex-direction: row-reverse;
    margin-left: auto;
  }
  .member-pic {
    flex: 0 256px;
  }
  .member-info {
    flex: 1;
    padding: 0 40px 28px;
  }
}

/* time-schedule */
#time-schedule {
  margin-top: 60px;
}
.time-ttl-meta {
  font-family: YakuHanJP, 'Lato', "Noto Sans Japanese", sans-serif;
}
.time-ttl-sub,
.time-ttl-main {
  color: #00991d;
}
.time-ttl-sub {
  border-bottom: 1px solid #93bb4b;
  margin: 0.4em 0;
  padding-bottom: 0.4em;
}
.time-content-main {
  font-size: 20px;
}
.time-ttl-main b {
  font-size: 1.2em !important;
}
.time-content {
  margin-top: 1em;
}
#time-schedule dd p span {
  display: inline;
  font-weight: inherit;
  line-height: inherit;
}
.time-content p + p,
.time-content p + ul,
.time-content ul + p {
  margin-top: 10px;
}
.time-content-list li::before {
  content: '\25CF';
  color: #00991d;
}
ul.time-content-list {
  margin: 10px 0 0 !important;
  width: auto !important;
}
ul.time-content-list li {
  padding-left: 0 !important;
}
.bg-pale {
  background: #e7f3e3;
}
@media (max-width: 600px) {
  .bg-pale {
    margin: 0 !important;
    padding: 10px 4vw;
    width: 100% !important;
  }
  #time-schedule .small-txt {
    font-size: 12px !important;
    font-weight: normal;
  }
}
@media (min-width: 601px) {
  #time-schedule {
    margin-top: 104px;
    padding-bottom: 80px;
  }
  #time-schedule h3 {
    font-size: 32px;
    line-height: 56px;
    height: 56px;
  }
  #time-schedule ul.time-content-list {
    display: block;
    padding-left: 0;
  }
  #time-schedule ul.time-content-list li {
    height: inherit;
    line-height: inherit;
    margin: 0;
  }
  #time-schedule dt {
    display: flex;
    align-items: center;
    padding: 0 16px;
  }
  #time-schedule dt::after {
    transform: translateY(-100%);
  }
  #time-schedule dd {
    font-size: 1.2em;
    display: block;
    line-height: 1.5;
    padding: 20px 16px;
  }
  #time-schedule p {
    padding-top: 0 !important;
  }
  #time-schedule dd p span {
    display: inline;
    font-weight: inherit;
    line-height: inherit;
  }
  #time-schedule .border { position: relative;}
  #time-schedule .border::before {
    position: absolute;
    top: 0;
    left: 0;
    border-top: 1px solid #93bb4b;
    content: '';
    display: block;
    height: 0;
    width: 160px;
  }

  .time-ttl-sub {
    font-size: 1.3em;
    width: 70%;
  }
  .time-ttl-main {
    font-size: 1.35em;
  }
  .time-content {
    margin-top: 24px;
  }
  .time-content-main {
    font-size: 32px;
  }
  #time-schedule .small-txt {
    font-size: 15px !important;
    font-weight: normal;
  }
}

/* #part-2 */
#part-2 {
  border: 2px solid #93BB4B;
  margin: 0 auto 40px;
  padding: 30px 15px;
}
#part-2 h3 {
  font-size: 1.2em;
  margin-bottom: 0.8em;
  text-align: center;
}
#part-2 h3 span { font-size: 0.85em;}
#part-2 h3 > * { display: block;}
.part-2-item-ttl {
  color: #00991d;
  font-size: 17px;
  font-weight: bold;
  margin-bottom: 0.5em;
}
@media (max-width: 600px) {
  #part-2 {
    width: 92vw;
  }
  .part-2-item + .part-2-item {
    margin-top: 30px;
  }
}
@media (min-width: 601px) {
  #part-2 h3 { font-size: 30px;  }
  #part-2 h3 span { font-size: 0.7em;}
  #part-2 {
    margin: 0 auto 154px;
    padding: 32px;
    width: 880px;
  }
  .part-2-contents {
    display: flex;
    justify-content: space-between;
  }
  .part-2-item {
    flex: 0 48.5%;
  }
  .part-2-item-ttl {
    font-size: 18px;
  }
}

/* access-contents */
#access {
  line-height: inherit;
  text-align: left;
}
#access a { color: #00991D;}
#access a:hover { text-decoration: none;}
#access a i { margin-left: 0.5em;}
#access .head-txt {
  text-align: center;
  margin-bottom: 30px;
}
#access p:not(.head-txt) { font-size: inherit;}
.access-ttl {
  font-size: 1.1em !important;
  font-weight: bold;
}
#access p + p {
  margin-top: 0.8em !important;
}
@media (max-width: 600px) {
  #access {
    margin-top: 20px;
  }
  .access-map {
    height: 62.5vw;
    margin: 15px 0;
    width: 100%;
  }
  .access-item + .access-item {
    margin-top: 30px;
  }
  .access-item > *:not(.access-map) {
    padding: 0 4vw;
  }
}
@media (min-width: 601px) {
  #access .head-txt {
    margin-bottom: 32px;
  }
  .access-contents {
    display: flex;
    justify-content: space-between;
  }
  .access-item {
    flex: 0 48%;
  }
  .access-map {
    margin: 15px 0;
    height: 320px;
    width: 100%;
  }
  .access-item p:last-child {
    font-size: 14px !important;
  }
  .form-btn-wrap { margin-bottom: 0;}
}

/* archive */
#archive {
  margin-bottom: 96px;
}
#archive a {
  border: 3px solid #00991d;
  border-radius: 8px;
  color: #00991d;
  display: block;
  font-size: 1.2em;
  font-weight: bold;
  margin: 0 auto;
  padding: 16px;
  text-align: center;
  text-decoration: none;
  width: 86vw;
}
@media (max-width: 600px) {
  #archive a { margin-top: 40px;}
}
@media (min-width: 601px) {
  #archive a {
    font-size: 28px;
    transition: background-color .4s ease;
    width: 520px;
  }
  #archive a:hover {
    background-color: #00991d;
    color: #fff;
  }
}

.form-btn {
  color: #fff;
  font-size: 1.2em;
  font-weight: bold;
  text-decoration: none !important;
}
.form-btn.no-shadow { box-shadow: none !important;}
@media (min-width: 601px) {
  .form-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 28px;
    line-height: 1;
    height: 80px;
    padding: 0 !important;
  }
}


.common-note {
  margin: 0.8em auto 0;
  width: 92vw;
}
.btn-modal {
  background: #e7f3e3;
  border: 3px solid #00991d;
  border-radius: 8px;
  color: #00991d;
  cursor: pointer;
  font-size: 1.2em;
  font-weight: bold;
  margin: 40px auto 0;
  padding: 16px;
  text-align: center;
  width: 92vw;
}
#overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,0.6);
  display: none;
  overflow: auto;
  z-index: 20;
}
#buffet {
  position: relative;
  top: 80px;
  display: none;
  box-shadow: 0 2px 10px rgba(0,0,0,0.7);
  z-index: 20;
}
#close-btn {
  display: none;
  z-index: 20;
}

@media (max-width: 600px) {
  .common-note {
    font-size: 14px;
  }
  #close-btn {
    position: fixed;
    top: 0;
    right: 0;
    background: #00a73c;
    color: #fff;
    font-size: 20px;
    padding: 10px;
    text-align: center;
    width: 55px;
  }
}
@media (min-width: 601px) {
  .common-note {
    width: 1024px;
  }
  .btn-modal {
    margin-top: 64px;
    margin-bottom: 64px;
    transition: background-color .4s ease;
    width: 640px;
  }
  .btn-modal:hover {
    background-color: #00991d;
    color: #fff;
  }
  .btn-modal i {
    margin-left: 0.65em;
  }

  #buffet {
    /* position: absolute; */
    top: 40px;
    margin: 0 auto;
    width: 640px;
  }

  #close-btn {
    position: fixed;
    top: 24px;
    right: 24px;
    cursor: pointer;
    height: 80px;
    transition: opacity .4s ease;
    width: 80px;
  }
  #close-btn span {
    position: absolute;
    top: 40px;
    background: #fff;
    border-radius: 2px;
    display: block;
    height: 4px;
    width: 80px;
  }
  #close-btn span:first-of-type {
    transform: rotate(-45deg);
  }
  #close-btn span:last-of-type {
    transform: rotate(45deg);
  }
  #close-btn:hover {
    opacity: 0.7;
  }

}

/* 49b23e 00a73c */
