@charset "utf-8";
/* 法人概要 */

.g_navi_menu .gnav04 a::after {
opacity: 1;
}

/*　アンカーボタン
-------------------------------------------------*/

.anchor_btn_wrap {
max-width: 1050px;
width: 100%;
margin: 0 auto;
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap;
margin-bottom: 100px;
}

@media all and (max-width : 1024px ){
.anchor_btn_wrap {
padding: 0 20px;
margin-bottom: 50px;
}
}

.anchor_btn_wrap .anchor_btn {
width: calc(33.33333% - 40px / 3);
margin-right: 20px;
}
.anchor_btn_wrap .anchor_btn:nth-child(3) {
margin-right: 0px;
}
.anchor_btn_wrap .anchor_btn a {
width: 100%;
position: relative;
display: block;
background: #fff;
border: 1px solid #ccc;
text-align: center;
padding: 1rem 0 2rem 0;
transition: all 0.5s;
}
.anchor_btn_wrap .anchor_btn a:hover {
background: #272A2F;
color: #fff;
border: 1px solid #272A2F;
transition: all 0.5s;
}
.anchor_btn_wrap .anchor_btn a .anchor_txt {
display: block;
font-size: 1.4rem;
font-weight: 600;
}

@media all and (max-width : 820px ){
.anchor_btn_wrap .anchor_btn a .anchor_txt {
font-size: 1.2rem;
}
}

.anchor_btn_wrap .anchor_btn a:after {
content: '›';
position: absolute;
bottom: 4px;
left: 50%;
color: #000;
font-family: Georgia, "Times New Roman", Times, "serif";
font-weight: 400;
font-style: normal;
font-size: 2.2rem;
line-height: 0.6;
transform: translate(-50%, 0) rotate(90deg);
}
.anchor_btn_wrap .anchor_btn a:hover::after {
color: #fff;
}

@media all and (max-width : 767px ){
.anchor_btn_wrap .anchor_btn a {
padding: 0.5rem 0 1rem 0;
}
.anchor_btn_wrap .anchor_btn a .anchor_txt {
font-size: 1.0rem;
letter-spacing: 0;
}
.anchor_btn_wrap .anchor_btn a:after {
bottom: 3px;
font-size: 1.4rem;
}
.anchor_btn_wrap {
margin-bottom: 40px;
padding: 0 10px;
}
.anchor_btn_wrap .anchor_btn {
width: calc(33.33333% - 20px / 3);
margin-right: 10px;
}
}


/*-------------------------------------------------
運営組織について
-------------------------------------------------*/

.sec_profile {
margin-bottom: 100px;
}
.sec_profile .box_m,
.sec_history .box_m,
.sec_access .box_m {
display: flex;
justify-content: space-between;
}
.box_right {
width: 71.43%;
}
.profile_box {
width: 100%;
padding: 30px 10px 30px 25px;
border-bottom: solid 1px #ddd;
display: flex;
justify-content: flex-start;
align-items: center;
}
.profile_box:last-of-type {
border-bottom: none;
}
.profile_main_title {
font-size: 1.5rem;
width: 20%;
font-weight: 700;
letter-spacing: 0.1em;
display: block;
}
.profile_box .profile_txt {
width: 80%;
font-size: 1.5rem;
line-height: 160%;
}
.profile_box .profile_txt a {
text-decoration: underline;
color: #003D79;
}
.profile_box .profile_txt a:hover {
text-decoration: none;
}
.service_list li {
font-size: 1.5rem;
padding: 5px 0px 5px 20px;
background-image: url("../img/common/icon_nakaguro.svg");
background-repeat: no-repeat;
background-position: left center;
}

@media all and (max-width : 1024px ){
.sec_title_box .sec_title_jp {
font-size: 2.0rem;
}
.profile_main_title {
font-size: 1.4rem;
width: 25%;
}
.profile_box .profile_txt {
width: 75%;
font-size: 1.4rem;
}
}

@media all and (max-width : 820px ){
.sec_profile .box_m,
.sec_history .box_m,
.sec_access .box_m {
display: flex;
flex-direction: column;
}
.box_right {
width: 100%;
}
}

@media all and (max-width : 767px ){
.sec_profile {
margin-bottom: 20px;
}
.sec_title_box .sec_title_jp {
font-size: 1.5rem;
}
.profile_box {
padding: 20px 10px 20px 15px;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: flex-start;
}
.profile_main_title {
font-size: 1.3rem;
width: 100%;
margin-bottom: 10px;
}
.profile_box .profile_txt {
width: 100%;
font-size: 1.2rem;
}
.service_list li {
font-size: 1.2rem;
padding: 3px 0px 3px 18px;
background-position: left 3px;
letter-spacing: 0.05em;
}
}

/*-------------------------------------------------
沿革
-------------------------------------------------*/

.sec_history {
background: #fff;
padding: 80px 0 100px;
}
.history_box_wrap {
max-width: 900px;
width: 100%;
margin-top: 10px;
}

@media all and (max-width : 1100px ){
.history_box_wrap {
max-width: 750px;
}
}

@media all and (max-width : 980px ){
.sec_history {
flex-direction: column;
}
.history_box_wrap {
margin-left: 50px;
margin-top: 10px
}
}

@media all and (max-width : 820px ){
.sec_chronology .box_wrap {
display: flex;
justify-content: space-between;
align-items: flex-start;
flex-direction: column;
}
.history_box_wrap {
max-width: 700px;
margin-left: 30px;
}
}

.flow_box_wrap {
display: flex;
justify-content: space-between;
align-items: flex-start;
position: relative;
}
.flow_box_wrap::before {
content: "";
width: 1px;
height: 100%;
background: #d2d5dc;
position: absolute;
top: 0;
}
.flow_box_wrap:first-child::before {
height: calc(100% - 10px);
top: 10px;
}
.flow_box_wrap:last-child::before {
height: 10px;
}
.flow_box_wrap::after {
content: "";
width: 15px;
height: 15px;
background: #8E7742;
border-radius: 50%;
position: absolute;
top: 10px;
margin-left: -7px;
}
.flow_box {
width: 100%;
margin-bottom: 70px;
line-height: 1.9;
display: flex;
justify-content: flex-start;
align-items: flex-start;
padding-left: 50px;
}

@media all and (max-width : 820px ){

.flow_box {
margin-bottom: 50px;
padding-left: 40px;
}
}

.flow_box_wrap:last-child .flow_box {
margin-bottom: 0;
}
.numb_wrap {
max-width: 95px;
white-space: nowrap;
}
.numb {
font-family: "Oswald", serif;
font-weight: 400;
font-size: 2.8rem;
line-height: 100%;
margin-bottom: 8px;
color: #272A2F;
letter-spacing: 0.1em;
}
.numb_jp {
font-size: 1.1rem;
line-height: 100%;
letter-spacing: 0.1em;
display: block;
}

@media all and (max-width : 820px ){
.numb {
font-size: 2.8rem;
}
.numb_jp {
font-size: 1.1rem;
}
}

.history_txt {
font-size: 1.5rem;
margin-left: 70px;
display: block;
}

@media all and (max-width : 1100px ){
.history_txt {
font-size: 1.4rem;
margin-left: 50px;
}
}

@media all and (max-width : 820px ){
.history_txt {
margin-left: 35px;
}
}
@media all and (max-width : 767px ){
.sec_history {
padding: 40px 0 50px;
}
.history_box_wrap {
max-width: 840px;
width: 100%;
margin-top: 0px;
margin-left: 15px;
}
.flow_box_wrap {
display: flex;
justify-content: space-between;
align-items: flex-start;
position: relative;
}
.flow_box_wrap::before {
content: "";
width: 1px;
height: 100%;
background: #d2d5dc;
position: absolute;
top: 0;
left: -1px;
}
.flow_box_wrap:first-child::before {
height: calc(100% - 10px);
top: 10px;
}

.flow_box_wrap::after {
content: "";
width: 12px;
height: 12px;
border-radius: 50%;
position: absolute;
top: 6px;
margin-left: -7px;
}
.flow_box {
width: 100%;
margin-bottom: 30px;
line-height: 1.9;
display: flex;
justify-content: flex-start;
align-items: flex-start;
padding-left: 25px;
flex-direction: column;
}
.numb {
font-size: 2.2rem;
}
.numb_jp {
font-size: 1.0rem;
margin-left: 2px;
}
.numb_wrap {
margin-bottom: 15px;
}
.history_txt {
font-size: 1.2rem;
margin-left: 0px;
padding-right: 10px;
}
}


/*-------------------------------------------------
sec_access
-------------------------------------------------*/

.sec_access {
padding: 80px 0 20px;
}
.gmap {
height: 0;
overflow: hidden;
padding-bottom: 41.43%;
position: relative;
}
.gmap iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}
.gmap_wrap {
padding: 2px;
border: solid 1px #ddd;
margin-bottom: 25px;
}
.access_title {
font-size: 1.6rem;
font-weight: 700;
letter-spacing: 0.1em;
line-height: 100%;
margin-bottom: 15px;
display: block;
}
.address_txt {
font-size: 1.5rem;
font-weight: 400;
margin-left: 10px;
}

@media all and (max-width : 767px ){
.sec_access {
padding: 40px 0 0px;
}
.gmap_wrap {
margin-bottom: 15px;
}
.access_title {
font-size: 1.3rem;
line-height: 140%;
margin-bottom: 10px;
}
.address_txt {
font-size: 1.2rem;
}
}