@charset "UTF-8";
#access_fv {
}
#access_sec01 {
    padding: 4vw 0 11vw;
    color: #fff;
}
#access_sec01 .toptxt {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: space-between;
    align-items: flex-start;
}
#access_sec01 .toptxt h2 {
    font-size: 1.6em;
    line-height: 170%;
}
#access_sec01 .toptxt p {
    margin-top: 0.7vw;
}
#access_sec01 .toptxt p span {
    display: block;
    font-size: 1.38em;
}
#access_sec01 .toptxt p a {
    border-bottom: 1px solid #fff;
    color: #fff;
    width: 12.3vw;
    display: block;
    margin: 0 0 0 auto;
    font-size: 1.4em;
    margin-top: 0.45vw;
    padding-bottom: 0.14vw;
    position: relative;
    z-index: 0;
}
#access_sec01 .toptxt p a::before,
#access_sec01 .toptxt p a::after {
    content: "";
    position: absolute;
    border: 1px solid #fff;
    background-color: #000;
    width: 1.7vw;
    height: 1vw;
}
#access_sec01 .toptxt p a::before {
    right: 0.45vw;
    top: 0.4vw;
    z-index: -1;
}
#access_sec01 .toptxt p a::after {
    right: 0.85vw;
    top: 0.75vw;
    z-index: -2;
}
#access_sec01 .map {
    margin-top: 3.5vw;
}
#access_sec01 .map iframe {
    width: 100%;
    height: 35.75vw;
    filter: grayscale(1);
}
#access_sec01 .flex {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: space-between;
    align-items: center;
    margin-top: 7.6vw;
}
#access_sec01 .flex .txt {
    width: 47.7%;
}
#access_sec01 .flex .txt h3 {
    font-size: 1.6em;
    font-weight: 500;
}
#access_sec01 .flex .txt p {
    font-size: 1.16em;
    margin-top: 1.5vw;
    line-height: 163%;
}
#access_sec01 .flex .txt small {
    font-size: 0.873em;
    display: block;
}
#access_sec01 .flex .txt span {
    padding-right: 0.9vw;
    position: relative;
    z-index: 0;
}
#access_sec01 .flex .txt span::before {
    content: "";
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 30%;
    bottom: 0;
    left: 0;
}
#access_sec01 .flex .txt span.b::before {
    background-color: #006972;
}
#access_sec01 .flex .txt span.r::before {
    background-color: #721e00;
}
#access_sec01 .flex .txt span.g::before {
    background-color: #007200;
}
#access_sec01 .flex .img {
    width: 52.3%;
}
@media screen and (max-width:1300px) {
}
@media screen and (max-width:900px) {
}
@media screen and (max-width:768px) {
#access_sec01 {
    padding: 7vw 0 20vw;
}
#access_sec01 .toptxt h2 {
    font-size: 1.4em;
    width: 100%;
}
#access_sec01 .toptxt p {
    margin-top: 4.7vw;
    width: 100%;
}
#access_sec01 .toptxt p a {
    width: 38.3vw;
    margin: 0 auto 0 0;
    margin-top: 2.45vw;
}
#access_sec01 .toptxt p a::before, #access_sec01 .toptxt p a::after {
    width: 4.7vw;
    height: 3vw;
}
#access_sec01 .toptxt p a::after {
    right: 1.85vw;
    top: 1.15vw;
}
#access_sec01 .map {
    margin-top: 7.5vw;
}
#access_sec01 .map iframe {
    height: 75.75vw;
}
#access_sec01 .flex {
    margin-top: 12.6vw;
}
#access_sec01 .flex .txt {
    width: 100%;
}
#access_sec01 .flex .img {
    width: 100%;
    margin-top: 5vw;
}
#access_sec01 .flex .txt h3 {
    font-size: 1.5em;
}
#access_sec01 .flex .txt p {
    margin-top: 3.5vw;
    line-height: 183%;
}
}