@charset "utf-8";
/* CSS Document */
@media all {
	#firstview h1,#access h2,
    #contents .accessbox .parking .textbox .title{
		font-family: "Zen Old Mincho", serif;
		font-weight: 600;
		font-style: normal;
	}
	#firstview .subtitle{
		font-family: "Crimson Pro", serif;
		font-optical-sizing: auto;
		font-weight: 400;
		font-style: normal;
	}
  #firstview {
    width: 100%;
    padding: 200px 0 0;
    text-align: center;
  }
  #firstview h1 {
    font-size: 2.93rem;
  }
  #firstview .subtitle {
    font-size: 1.2rem;
    padding-bottom: 130px;
  }
  .attention {
    color: #333333;
    line-height: 1.7;
    text-align: center;
    margin-top: 110px;
  }
  #access h2 {
    font-size: 1.86rem;
    padding-bottom: 1em;
  }
  #maparea {
    width: calc(100% - 40px);
    max-width: 1450px;
    margin: 0 auto;
    padding: 120px 0 50px;
    display: flex;
  }
#maparea .textbox {
  width: 100%;
  max-width: 500px;
  padding-top: 85px;
}

  #maparea .textbox dl {
    display: flex;
    flex-wrap: wrap;
    padding: 0 95px 50px 0;
  }
  #maparea .textbox dt {
    width: 9em;
    display: flex;
    align-items: center;
    padding: .5em 0 .5em .5em;
    border-bottom: 1px #050807 solid;
  }
  #maparea .textbox dd {
    width: calc(100% - 9em);
    display: flex;
    align-items: center;
    padding: .5em 0 .5em 2em;
    border-bottom: 1px #B5B5B5 solid;
  }
  #maparea .internal_links {
    width: 170px;
    margin: 0 0 1em 235px;
    border-bottom: none;
  }
  #maparea .mapbox {    
    width: 100%;
    max-width: 899px;
  }
  #maparea .mapbox iframe {
    filter: brightness(100%) grayscale(100%);
  }
  #contents {
    width: calc(100% - 40px);
    max-width: 1580px;
    margin: 0 auto;
    padding: 110px 0;
    display: flex;
  }
  #contents .category {
    width: calc(100% - 1113px);
    padding-right: 130px;
    min-width: 345px;
  }
  #contents .category .sticky {
    width: 100%;
    position: sticky;
    top: 60px;
    left: 0;
      min-width: 300px;
  }
  #contents .category a {
    display: block;
    width: 100%;
  }
  #contents .category li {
    font-size: 1.06rem;
    text-align: left;
    padding: 1.3em;
    border-bottom: solid 1px #ccc;
    position: relative;
  }
  #contents .category li:first-child {
    border-top: solid 1px #ccc;
  }
  #contents .category li::after {
    position: absolute;
    content: "";
    top: 44%;
    right: 10px;
    width: 40px;
    height: 21px;
    background: url("../common/images/icon_arrow_bk.png") no-repeat;
    background-size: 30%;
  }
  #contents .accessbox {
    width: 1113px;
  }
  #contents .accessbox h2 {
    padding-bottom: 2em;
    text-align: center;
  }
	#contents .accessbox #route{
		padding-bottom: 40px;
	}
	#contents .accessbox #route h2{
		padding-bottom: 0.5em;
	}
	#contents .accessbox #route h2 span{
		font-size: 0.5em;
	}
	#contents .accessbox #route #routeForm{
		width: fit-content;
		margin: 0 auto 1em;
	}
	#contents .accessbox #route #routeForm input{
		height: 2.5rem;
		padding: 0 1em;
	}
	#contents .accessbox #route #routeForm button{
		font-size: 0.9rem;
		background: #000;
		color: #fff;
		border-radius: 1em;
		padding: 0.1em 1em;
	}
  #contents .accessbox p {
    text-align: center;
      padding-bottom: 50px;
  }
    #contents .accessbox .internal_links{
      margin-bottom: 80px;
        
    }
  #contents .accessbox #car, #contents .accessbox #plane {
    margin-top: 120px;
  }
  #contents .accessbox dt {
    font-size: 1.33rem;
    display: block;
    padding: 2em 1em 2em 1.5em;
    cursor: pointer;
    position: relative;
  }
.accessroot {
  border-bottom: 1px solid #ccc;
}
.accessroot:first-of-type {
  border-top: 1px solid #ccc;
}

.accessbox h2 + .accessroot {
  border-top: 1px solid #ccc;
}
  #contents .accessbox dt::before {
    position: absolute;
    content: "";
    display: block;
    width: 1.3em;
    height: 1.3em;
    top: 25px;
    left: 13px;
    background: url("images/Q.webp") no-repeat;
    background-size: contain;
    background-position: center;
  }
  #contents .accessbox .active {
    border-bottom: none;
  }
  #contents .accessbox dt::after {
    position: absolute;
    content: "+";
    width: auto;
    height: auto;
    top: 50%;
    right: 23px;
    transform: translateY(-50%);
    font-size: 24px;
    color: #2E2D2A;
    transition: .3s;
  }
  #contents .accessbox dd {
    display: none;
    padding: 1.5em 1em;
    position: relative;
  }
  #contents .accessbox .active::after {
    content: "";
    width: 12px;
    height: 1px;
    right: 30px;
    background-color: #2E2D2A;
    transform: translateY(-50%) rotate(-180deg);
  }
  #contents .accessbox .parking {
    width: calc(100% - 40px);
    max-width: 900px;
    margin: 60px auto 0;
    display: flex;
    padding: 30px 40px;
    background-color: #E0DBD4;
  }
  #contents .accessbox .parking .textbox {
    width: 55%;
      display: flex;
    flex-direction: column;
    justify-content: center;
  }
  #contents .accessbox .parking .image {
    width: 45%;
  }
  #contents .accessbox .parking .textbox .title {
    font-size: 1.45rem;
    padding-bottom: 1em;
    text-align: left;
  }
  #contents .accessbox .parking .textbox .text {
    text-align: left;
  }
  @media (max-width: 1024px) {}
  @media (max-width: 767px) {
    .attention {
      margin-top: 50px;
    }
    #maparea {
      padding: 5px 0;
      flex-direction: column;
    }
    #maparea .textbox {
      width: 100%;
      padding-top: 70px;
    }
    #maparea .textbox dl {
      padding: 0 0 50px 0;
    }
    #maparea .textbox dt {
      width: 8em;
    }
    #maparea .textbox dd {
      width: calc(100% - 8em);
    }
    #maparea .mapbox {
      width: 100%;
    }
    #contents {
      padding: 50px 0;
      flex-direction: column;
    }
    #contents .category {
      width: 100%;
      padding: 0;
      min-width: 0;
      padding-bottom: 80px;
    }
    #contents .category li::after {
      top: 38%;
      background: url("../common/images/icon_arrow_down_b_bk.png") no-repeat;
    }
    #contents .accessbox {
      width: 100%;
    }
    #maparea .internal_links {
      margin: 0 auto 40px;
}
	  #contents .accessbox h2 {
		  padding-bottom: 1em;
	  }
	  #contents .accessbox #car{
		  margin-top: 80px;
	  }
    #contents .accessbox .active::after {
      right: 0;
    }
    #contents .accessbox dt::after {
      right: 5px;
    }
    #contents .accessbox .parking {
      width: 100%;
      margin: 0 auto;
      flex-direction: column;
    }
    #contents .accessbox .parking .textbox {
      width: 100%;
    }
    #contents .accessbox .parking .image {
      width: 100%;
    }
    #contents .accessbox .parking .textbox .text {
      padding-bottom: 1em;
    }
    .pd {
      display: none;
    }
  }
  @media screen and (min-width: 768px) and (max-width: 1024px) {
    .attention {
      margin-top: 50px;
    }
    #maparea {
      padding: 5px 0;
      flex-direction: column;
    }
    #maparea .textbox {
      width: 100%;
      padding-top: 70px;
        margin: 0 auto;
    }
    #maparea .textbox dl {
      padding: 0 0 50px 0;
    }
    #maparea .textbox dt {
      width: 8em;
    }
    #maparea .textbox dd {
      width: calc(100% - 8em);
    }
    #maparea .mapbox {
      width: 100%;   
      margin: 0 auto;
    }#maparea .internal_links {
    margin: 0 auto 20px;
}
    #contents {
      padding: 50px 0;
      flex-direction: column;
    }
    #contents .category {
      width: 100%;
      padding: 0;
      margin-bottom: 80px;
    }
    #contents .category .sticky {
      display: flex;
      justify-content: space-around;
    }
    #contents .category li {
      width: calc(100% / 4);
      margin: 0 10px;
    }
    #contents .category li:first-child {
      border-top: none;
    }
    #contents .category li::after {
      top: 38%;
      background: url("../common/images/icon_arrow_down_b_bk.png") no-repeat;
      right: -14px;
    background-size: 30%;
    }
    #contents .accessbox {
      width: 100%;
    }
  }
}
@media screen and (min-width: 1025px) {
  .pd {
    display: none
  }
}