@charset "utf-8";

.section-border {
  border-bottom: .2rem #ccc dotted;
}

@media (min-width: 768px) {
  .section-border {
    border-bottom-width: .3rem;
  }
}

h4.tora {
  background-image: url(../images/icon/TTL_h4_tora.png);
  background-size: 1.5em;
}

h4.pen {
  background-image: url(../images/icon/TTL_h4_pen.png);
  background-size: 1.5em;
}

h4.zebra {
  background-image: url(../images/icon/TTL_h4_zebra.png);
  background-size: 1.5em;
}

h4.giraffe {
  background-image: url(../images/icon/TTL_h4_giraffe.png);
  background-size: 1.5em;
}

.row2 {
  margin: 1rem 0;
}

.row2 figure {
  padding: 0;
  margin: 0 0 1rem 0;
}

.row2 img {
  flex: none;
  max-width: 100%;
}

@media (min-width: 768px) {
  .row2 {
    display: flex;
    justify-content: space-between;
  }

  .row2 figure {
    margin: 0;
    padding: 0;
  }

  .row2 figure:first-child {
    margin-right: 1rem;
  }

  .row2 img#intro_view {
    width: auto;
    margin: 0;
    float: none;
  }

  .row2 img {
    height: 250px;
  }
}

.e-time {
  overflow-y: auto;
}

.e-time .e-time-inner {
  display: flex;
  min-width: 280px;
}

.e-time ul li {
  margin: 0;
  padding: 5px;
  border-color: #776340;
  border-style: solid;
  border-width: 1px;
  text-align: center;
  white-space: nowrap;
}

.e-time ul li:not(:last-child) {
  border-bottom-width: 0;
}

.e-time ul:first-child li:first-child {
  border-color: transparent;
  visibility: hidden;
}

.e-time ul:first-child li:not(:first-child) {
  background-color: #fdc87a;
  white-space: nowrap;
  font-weight: bold;
}

.e-time ul:not(:first-child) {
  width: 45%;
}

.e-time ul:not(:first-child) li {
  background-color: #fff2e1;
}

.e-time ul:not(:first-child) li:first-child {
  background-color: #fdc87a;
}

.e-time ul:not(:last-child) li {
  border-right-width: 0;
}

.e-time ul:nth-child(1) li:nth-child(2) {
  border-radius: 10px 0 0 0;
}

.e-time ul:nth-child(1) li:last-child {
  border-radius: 0 0 0 10px;
}

.e-time ul:nth-child(2) li:nth-child(1) {
  border-radius: 10px 0 0 0;
}

.e-time ul:nth-child(3) li:nth-child(1) {
  border-radius: 0 10px 0 0;
}

.e-time ul:nth-child(3) li:last-child {
  border-radius: 0 0 10px 0;
}

@media (min-width: 768px) {
  .e-time .e-time-inner {
    flex-direction: column;
    min-width: auto;
  }

  .e-time ul {
    display: flex;
  }

  .e-time ul:not(:first-child) {
    width: 100%;
  }

  .e-time ul:not(:last-child) li:last-child {
    border-bottom-width: 0;
  }

  .e-time ul:last-child li {
    border-bottom-width: 1px;
    border-right-width: 0;
  }

  .e-time ul li {
    width: 16%;
    padding: 10px;
  }

  .e-time ul li:last-child {
    border-right-width: 1px;
  }

  .e-time ul:nth-child(1) li:last-child {
    border-radius: 0 10px 0 0;
  }

  .e-time ul:nth-child(3) li:nth-child(1) {
    border-radius: 0 0 0 10px;
  }

  .e-time ul:nth-child(3) li:last-child {
    border-radius: 0 0 10px 0;
  }
}

.admission-info {
  display: flex;
  flex-direction: column;
}

.admission-info .img-box {
  display: flex;
  justify-content: space-around;
}

.admission-info .img-box img {
  height: 100px;
  flex: none;
}

@media (min-width: 768px) {
  .admission-info {
    flex-direction: row;
  }

  .admission-info .img-box {
    align-items: center;
  }

  .admission-info .img-box span {
    margin-top: auto;
  }

  .admission-info .img-box span:first-child {
    margin-right: 1rem;
  }
}

.age-fees {
  display: flex;
  align-items: flex-start;
}

.age-fees span {
  color: #f00;
  font-weight: bold;
}

.age-fees img {
  flex: none;
  width: 100px;
  margin-left: 10px;
}

@media (min-width: 769px) {
  .age-fees span {
    font-size: 1.125rem;
  }

  .age-fees img {
    margin-top: -40px;
  }
}

.age-price-table {
  overflow-x: auto;
  margin-bottom: 1rem;
  border: 1px solid #999;
  border-radius: 10px;
}

.age-price-table table {
  min-width: 850px;
}

.age-price-table th {
  width: 25%;
  padding: 10px 5px;
  border: 1px solid #999;
  border-collapse: collapse;
  text-align: center;
  vertical-align: middle;
  font-size: 0.9rem;
}

.age-price-table th:nth-child(1) {
  background-color: #f7d368;
}

.age-price-table th:nth-child(2) {
  background-color: #a4c98b;
}

.age-price-table th:nth-child(3) {
  background-color: #8aa3d1;
}

.age-price-table th:nth-child(4) {
  background-color: #ecac82;
}

.age-price-table td {
  padding: 5px;
  border: 1px solid #999;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.age-price-table td:nth-child(1) {
  background-color: #fbefca;
}

.age-price-table td:nth-child(2) {
  background-color: #dfecd7;
}

.age-price-table td:nth-child(3) {
  background-color: #d7dfef;
}

.age-price-table td:nth-child(4) {
  background-color: #fae2d4;
}

.age-price-table td.center {
  text-align: center;
  vertical-align: middle;
}

.age-price-table td .f-div {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.age-price-table td .f-div .p-list {
  margin: 0 0 0 0.8125rem;
  text-indent: -0.8125rem;
  font-size: 0.8125rem;
}

.age-price-table .small-text {
  font-size: 0.8125rem;
}

.age-price-table tr :first-child {
  border-left-width: 0;
}

.age-price-table tr :last-child {
  border-right-width: 0;
}

.age-price-table tbody tr:last-child td {
  border-bottom-width: 0;
}

.age-price-table th {
  border-top-width: 0;
}

.age-price-table td[rowspan] {
  border-bottom-width: 0;
}

.age-price-table .radius-topleft {
  border-top-left-radius: 10px;
}

.age-price-table .radius-bottomleft {
  border-bottom-left-radius: 10px;
}

.age-price-table .radius-topright {
  border-top-right-radius: 10px;
}

.age-price-table .radius-bottomright {
  border-bottom-right-radius: 10px;
}

.t-box-adult {
  display: inline-block;
  background-color: #7030a0;
  padding: 5px 15px;
  border-radius: 5px;
  font-weight: bold;
  font-size: 1.25rem;
  color: #fff;
}

.t-box-child-a {
  display: inline-block;
  background-color: #ff9933;
  padding: 5px 15px;
  border-radius: 5px;
  font-size: 1.25rem;
  font-weight: bold;
  color: #fff;
}

.t-box-child-b {
  display: inline-block;
  background-color: #cc0066;
  padding: 5px 15px;
  border-radius: 5px;
  font-size: 1.25rem;
  font-weight: bold;
  color: #fff;
}

.t-box-da {
  display: inline-block;
  background-color: #00b050;
  padding: 5px 15px;
  border-radius: 5px;
  font-weight: bold;
  color: #fff;
}

.t-box-caregiver {
  display: inline-block;
  background-color: #00b0f0;
  padding: 5px 15px;
  border-radius: 5px;
  font-weight: bold;
  font-size: 1.25rem;
  color: #fff;
}

.t-box-da i,
.t-box-caregiver i {
  font-style: normal;
  font-size: 1.25rem;
}

.note-list {
  list-style: none;
  counter-reset: note;
  margin: 0 0 1rem 0;
  padding: 0;
}

.note-list li {
  counter-increment: note;
  margin-left: 1.75rem;
  position: relative;
}

.note-list li::before {
  content: "(*" counter(note) ")";
  position: absolute;
  left: -1.75rem;
}

.ticket-cancel img {
  max-width: 100%;
}

@media (min-width: 769px) {
  .ticket-cancel {
    display: flex;
    align-items: flex-end;
  }

  .ticket-cancel p {
    width: 60%;
    margin: 0 0 2rem 1rem;
  }
}

/* Bootstrap like */
.text-caution {
  color: #f00;
}

.span-underline {
  text-decoration: underline;
}

.mx-0 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.my-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.ms-0 {
  margin-left: 0 !important;
}

.me-0 {
  margin-right: 0 !important;
}

.px-0 {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.py-0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.pt-0 {
  padding-top: 0 !important;
}

.pb-0 {
  padding-bottom: 0 !important;
}

.ps-0 {
  padding-left: 0 !important;
}

.pe-0 {
  padding-right: 0 !important;
}

.mx-1 {
  margin-left: 0.25rem !important;
  margin-right: 0.25rem !important;
}

.my-1 {
  margin-top: 0.25rem !important;
  margin-bottom: 0.25rem !important;
}

.mt-1 {
  margin-top: 0.25rem !important;
}

.mb-1 {
  margin-bottom: 0.25rem !important;
}

.ms-1 {
  margin-left: 0.25rem !important;
}

.me-1 {
  margin-right: 0.25rem !important;
}

.px-1 {
  padding-left: 0.25rem !important;
  padding-right: 0.25rem !important;
}

.py-1 {
  padding-top: 0.25rem !important;
  padding-bottom: 0.25rem !important;
}

.pt-1 {
  padding-top: 0.25rem !important;
}

.pb-1 {
  padding-bottom: 0.25rem !important;
}

.ps-1 {
  padding-left: 0.25rem !important;
}

.pe-1 {
  padding-right: 0.25rem !important;
}

.mx-2 {
  margin-left: 0.5rem !important;
  margin-right: 0.5rem !important;
}

.my-2 {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}

.mt-2 {
  margin-top: 0.5rem !important;
}

.mb-2 {
  margin-bottom: 0.5rem !important;
}

.ms-2 {
  margin-left: 0.5rem !important;
}

.me-2 {
  margin-right: 0.5rem !important;
}

.px-2 {
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

.py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

.pt-2 {
  padding-top: 0.5rem !important;
}

.pb-2 {
  padding-bottom: 0.5rem !important;
}

.ps-2 {
  padding-left: 0.5rem !important;
}

.pe-2 {
  padding-right: 0.5rem !important;
}

.mx-3 {
  margin-left: 1rem !important;
  margin-right: 1rem !important;
}

.my-3 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.mt-3 {
  margin-top: 1rem !important;
}

.mb-3 {
  margin-bottom: 1rem !important;
}

.ms-3 {
  margin-left: 1rem !important;
}

.me-3 {
  margin-right: 1rem !important;
}

.px-3 {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.py-3 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.pt-3 {
  padding-top: 1rem !important;
}

.pb-3 {
  padding-bottom: 1rem !important;
}

.ps-3 {
  padding-left: 1rem !important;
}

.pe-3 {
  padding-right: 1rem !important;
}

.mx-4 {
  margin-left: 1.5rem !important;
  margin-right: 1.5rem !important;
}

.my-4 {
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}

.mt-4 {
  margin-top: 1.5rem !important;
}

.mb-4 {
  margin-bottom: 1.5rem !important;
}

.ms-4 {
  margin-left: 1.5rem !important;
}

.me-4 {
  margin-right: 1.5rem !important;
}

.px-4 {
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}

.py-4 {
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
}

.pt-4 {
  padding-top: 1.5rem !important;
}

.pb-4 {
  padding-bottom: 1.5rem !important;
}

.ps-4 {
  padding-left: 1.5rem !important;
}

.pe-4 {
  padding-right: 1.5rem !important;
}

.mx-5 {
  margin-left: 3rem !important;
  margin-right: 3rem !important;
}

.my-5 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.mt-5 {
  margin-top: 3rem !important;
}

.mb-5 {
  margin-bottom: 3rem !important;
}

.ms-5 {
  margin-left: 3rem !important;
}

.me-5 {
  margin-right: 3rem !important;
}

.px-5 {
  padding-left: 3rem !important;
  padding-right: 3rem !important;
}

.py-5 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.pt-5 {
  padding-top: 3rem !important;
}

.pb-5 {
  padding-bottom: 3rem !important;
}

.ps-5 {
  padding-left: 3rem !important;
}

.pe-5 {
  padding-right: 3rem !important;
}

.mt-auto {
  margin-top: auto !important;
}