.c_maintitle {
  background: url("../images/access/maintitle_bg.jpg") no-repeat center center;
  background-size: cover; }

section + section {
  margin-top: 7.0rem; }

.hours .ttl {
  text-align: center;
  font-size: 3.0rem;
  color: #E7902C;
  font-weight: bold;
  border-bottom: 1px solid #E7902C;
  padding-bottom: .5rem;
  margin-bottom: 2.0rem;
  line-height: 1.5; }
.hours .time {
  font-size: 4.0rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.75;
  margin-bottom: 4.0rem; }
.hours .table table {
  width: 50.0rem;
  margin: 0 auto;
  border-collapse: collapse;
  border-spacing: 0; }
  @media (max-width: 769px) {
    .hours .table table {
      width: 100%; } }
  .hours .table table th {
    border: .1rem solid #666;
    text-align: center;
    padding: 1.0rem; }
  .hours .table table td {
    border: .1rem solid #666;
    text-align: center;
    padding: 1.0rem; }
  .hours .table table thead th {
    background-color: #E7902C;
    color: #fff; }
  .hours .table table tbody th {
    background-color: #FFF6EE; }

.access .map iframe {
  width: 100%;
  height: 40.0rem; }
.access address {
  margin-top: 1.5rem;
  font-style: normal;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: right; }
  @media (max-width: 769px) {
    .access address {
      font-size: 1.4rem; } }

.reserve .ttl {
  text-align: center;
  font-size: 3.0rem;
  color: #E7902C;
  font-weight: bold;
  border-bottom: 1px solid #E7902C;
  padding-bottom: .5rem;
  margin-bottom: 2.0rem;
  line-height: 1.5; }
.reserve .tel {
  font-size: 4.0rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.75;
  margin-bottom: 4.0rem; }
.reserve .web {
  max-width: 40.0rem;
  margin: 0 auto;
  width: 100%; }
  @media (max-width: 769px) {
    .reserve .web {
      width: 100%; } }
  .reserve .web a {
    display: block;
    background-color: #e7902c;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    height: 13.5rem;
    font-size: 2.4rem;
    color: #fff;
    letter-spacing: 0.2em;
    border-bottom-left-radius: 1.0rem;
    border-top-right-radius: 1.0rem;
    position: relative;
    border: .1rem solid #e7902c;
    transition: 0.3s; }
    @media (max-width: 769px) {
      .reserve .web a {
        height: 27.380952380952383vw;
        font-size: 5.714285714285714vw; } }
    .reserve .web a img {
      width: 18.75%;
      margin-bottom: 1.5rem; }
    .reserve .web a::after {
      position: absolute;
      content: "";
      bottom: .3rem;
      right: .3rem;
      display: inline-block;
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 0 15px 15px;
      border-color: transparent transparent #ffffff transparent; }
    .reserve .web a:hover {
      background-color: #fff;
      border-color: #898989;
      color: #3e3a39; }
      .reserve .web a:hover::after {
        border-color: transparent transparent #898989 transparent; }
