@charset "utf-8";
.process { margin-top: 70px; }
.process h1 { text-align: center; margin-bottom: 80px; }
.process ul { display: flex; }
.process ul li { display: flex; flex-direction: column; align-items: center; width: 33%; }
.process ul li> span { display: flex; justify-content: center; align-items: center; width: 150px; aspect-ratio: 1/1; border-radius: 50%; background: #17347D; margin-bottom: 45px; }
.process ul li span i { color: #fff; font-size: 90px; }
.process ul :first-child span i { margin-top: 8px; }
.process ul li div { position: relative; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; width: 100%; padding: 54px 0; height: 320px; }
.process ul li div::before { position: absolute;  content: ""; width: 120%; height: 100%; clip-path: polygon(0% 0%, 85% 0%, 100% 50%, 85% 100%, 0% 100%); }
.process ul :first-child div::before { top: 50%; left: 0; transform: translateY(-50%); background: #fefefe; z-index: -1; }
.process ul :nth-child(2) div::before { top: 50%; left: 50%; transform: translate(-50%,-50%); background: #F3F5F9; z-index: -2; }
.process ul :last-child div::before { top: 50%; right: 0; transform: translateY(-50%); background: #DCE1EC; z-index: -3; }
.process ul li div> span { display: block; font-size: 24px; font-weight: 300; line-height: 1.5em; color: #666; text-decoration: underline; margin-bottom: 10px; }
.process ul li div h2 { color: #666; margin-bottom: 30px; }
.process ul li div h2 span { font-weight: 700; color: #17347D; }

.counsel { background: #FCFCFC; }
.counsel h1 { text-align: center; margin-bottom: 20px; }
.counsel h1 span { font-weight: 800; color: #17347D;  }
.counsel p { text-align: center; margin-bottom: 60px; padding: 0 20px; }

.banner { position: relative; width: 100%; height: 400px; background: url(../img/sub3/image1.jpg) no-repeat center/cover; backdrop-filter: blur(3px); }
.banner::after { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2); }
.banner ul { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: flex; align-items: center; background: #F3F5F9; z-index: 1; padding: 40px 0; width: 37.5%; border-radius: 20px; }
.banner ul li { display: flex; flex-direction: column; align-items: center; width: 50%; }
.banner ul> :first-child { border-right: 1px solid #999; }
.banner ul li div { display: flex; align-items: center; margin-bottom: 20px; }
.banner ul li div span { display: flex; justify-content: center; align-items: center; width: 40px; height: 40px; border-radius: 50%; background: rgba(153, 153, 153, 0.15); margin-right: 20px; }
.banner ul li div span i { font-size: 24px; color: #333; }
.banner ul li div span svg { width: 24px; height: 24px;color: #333; }
.banner ul li div p { font-size: 24px; font-weight: 600;}
.banner ul li a { display: block; font-size: 20px;  }
.banner ul> :first-child> :nth-child(2) { margin-bottom: 10px; }
.banner ul li> p { font-size: 20px; }

@media screen and (max-width: 1440px) {
    .banner ul { width: 45%; }
}

@media screen and (max-width: 1024px) {
    .process ul li> span { width: 120px; }
    .process ul li span i { font-size: 60px; }
    .process ul li div { height: 280px; }
    .process ul li div::before { width: 112%; }
    .process ul li div span { font-size: 20px; }

    .banner ul { width: 70%; padding: 30px 0; }
    .banner ul li a { font-size: 18px; }
    .banner ul li> p { font-size: 18px; }
}

@media screen and (max-width: 840px) {
    .process { margin: 0; }
    .process h1 { margin-bottom: 50px; }
    .process ul { flex-direction: column; }
    .process ul li { position: relative; width: 100%; }
    .process ul> :not(:last-child) { margin-bottom: 40px; }
    .process ul li> span { width: 100px; margin-bottom: 30px; }
    .process ul li div { height: auto;}
    .process ul li div::before { width: 60%; clip-path: polygon(0% 0%, 90% 0%, 100% 50%, 90% 100%, 0% 100%); }
    .process ul :first-child div::before { left: 50%; transform: translate(-50%,-50%); background: #fcfcfc;}
    .process ul :last-child div::before { right: 50%; transform: translate(50%, -50%); }
    .process ul li div h2 { margin-bottom: 20px; }
    .process ul li div p { padding: 0 20px; }

    .banner ul li div { margin-bottom: 15px; }
    .banner ul li div span { margin-right: 15px; }
    .banner ul li div p { font-size: 20px; }
}

@media screen and (max-width: 600px) {
    .process { margin-top: 50px; }
    .process ul li span i { font-size: 45px; }
    .process ul li div { padding: 30px 20px; height: 230px; }
    .process ul li div::before { width: 100%; }
    .process ul li div p { padding: 0; }

    .banner ul { flex-direction: column; padding: 30px 20px; }
    .banner ul li { width: 100%;  }
    .banner ul> :first-child { border: none; border-bottom: 1px solid #999; padding-bottom: 20px; margin-bottom: 20px; }
    .banner ul li a { font-size: 16px; }
    .banner ul li> p { font-size: 16px; }
}