@charset "UTF-8";

body {
    margin: 0 auto;
    width: 100%;
    font-family: "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 1.6;

}


/* 共通 */
.section-title {
    text-align: center;
    padding-top: 0;
    font-size: 50px;
    font-weight: 700;
    color: #6F6EAD;
}



.section-title::after {
    content: "";
    display: block;
    width: 100px;
    height: 3px;
    background-color: #6F6EAD;
    margin: 0px auto 30px;
    /* 上下余白を統一 */
}

/* header */
header {
    display: flex;
    justify-content: space-between;
    align-items: center;

}


header h2 {
    font-size: 40px;
    font-weight: 700;
    color: #6F6EAD;
    padding-left: 38px;
    /* padding-top: 10px; */
}

header ul {
    display: flex;
    justify-content: space-between;
    gap: 60px;


}



header ul li a {
    display: flex;
    justify-content: center;
    align-items: center;
    /* 縦中央寄せ */
    font-size: 24px;
    font-weight: 400;
    color: #6F6EAD;
    text-decoration: none;
    height: 80px;
    padding: 0 40px;
    /* 横だけ調整 */


}

header ul li a span {
    position: absolute;
    right: 0;
    width: 230px;
    height: 80px;
    background-color: #6F6EAD;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;


}

header .contact {

    top: 0;
}

header ul li.contact {
    margin-left: 160px;


}

/* header終了 */


/* Top */
#top {
    position: relative;
    /* worksに合わせる */
    width: 100%;
    padding-top: 76px;
    padding-bottom: 50px;

    background-image: url(../img/fv-bg.png);
    background-position: center;
    background-size: cover;
    height: 520px;
}

.top-title-h1 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 35px;
    font-weight: 700;
    color: #6F6EAD;
    background-color: #fff;
    width: 540px;
    height: 90px;
    text-align: center;
    margin-top: 120px;
    right: 220px;
    position: absolute;
}

.top-row {
    position: absolute;
    bottom: 100px;
    right: 220px;
}

.top-col {
    display: flex;
    gap: 30px;
}

.circle {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background-color: #6F6EAD;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.circle-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    line-height: 1;
}

.sub-title {
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    margin: 0;
}

.percent {
    font-size: 34px;
    font-weight: 700;
    color: #fff;
    margin: 0;
}

.percent span {
    font-size: 74px;
    font-weight: 700;
    color: #FFD700;
}

/* top終了 */

/* service */
#service {

    width: 100%;
    /* height: 620px; */
    background-color: #F5F5F5;
    padding: 50px 0 50px;

    box-sizing: border-box;
}

.service .row {

    display: flex;
    justify-content: center;
    /* 左右中央寄せ */
    align-items: flex-start;
    /* 上揃え */
    gap: 80px;
    /* 左右のカラム間 */
    max-width: 1440px;
    /* デザイン幅に合わせる */
    margin: 0 auto;
}

.service .col-left img {
    width: 340px;
    height: 270px;
    display: block;


}


.service .col-right h3 {
    font-size: 30px;
    font-weight: 700;
    color: #000;
    margin-bottom: 15px;
}

.service .col-right h3 span {
    display: inline-block;
    color: #fff;
    border-radius: 50%;
    background-color: #FFD700;
    height: 42px;
    width: 42px;
    text-align: center;
    line-height: 42px;
    /* 中央寄せ */
    margin-right: 10px;
}

.right-1 {
    margin-bottom: 14px;

}

.service .text {
    font-size: 20px;
    line-height: 1.8;
    border-bottom: 3px solid #E4E4E4;
    padding-bottom: 10px;
    margin-bottom: 30px;
}

#works {
    width: 100%;
    /* height: 620px; */
    background-color: #D9D9D9;
    padding: 50px 0 50px;

    box-sizing: border-box;

}

.works .col {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    max-width: 1000px;
    margin: 0 auto;
    gap: 50px;
}

.works .col img {
    width: 280px;
    height: 180px;


}

#request {
    position: relative;
    width: 100%;
    background-color: rgba(111, 110, 173, 0.2);
    /* 背景だけ透過 */

    padding: 50px 0;

    box-sizing: border-box;
}


.request .container {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    width: 100%;
}

.request .row {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 50px;
}

.request .col-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.request .col-left h3 {
    font-size: 40px;
    font-weight: 700;
    color: #6F6EAD;
    margin-top: 32px;
    margin-bottom: 15px;
}

.request .col-left .heding {
    font-size: 20px;
    font-weight: 400;
    color: #000;
    gap: 18px;
    line-height: 2.0;
}

.request .col-left .heding::before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: #fff;
    flex-shrink: 0;
    margin-right: 8px;
}

.request .button {
    margin-top: 20px;
    color: #fff;
    background-color: #FFD700;
    font-size: 26px;
    font-weight: 700;
    width: 340px;
    height: 60px;
    border-radius: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    position: relative;
    margin-bottom: 40px;
    margin-right: 20px;

}

.request .button::after {
    content: "→";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    font-weight: 400;
    width: 26px;
    height: 26px;
    background-color: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFD700;
    text-shadow: none;


}

.request .col-right {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0;
}

.request .col-right img {
    width: 340px;
    height: 270px;
    padding: 0;
}

#contact {
    width: 100%;
    /* height: 620px; */
    background-color: #F5F5F5;
    padding: 50px 0 50px;

    box-sizing: border-box;
}


.contact-container {
    display: flex;
    justify-content: center;
    width: 100%;
    margin-top: 20px;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin: 0 auto;
}

.contact-form label {
    font-size: 16px;
    font-weight: 400;
    color: #333;
    margin-bottom: -10px;
    border-bottom: 1px solid #D9D9D9;
}

.contact-form input,
.contact-form textarea {
    padding: 12px 15px;
    font-size: 12px;
    border: 2px solid #ccc;
    border-radius: 10px;
    width: 400px;
    box-sizing: border-box;
    border-bottom: 1px solid #D9D9D9;
    width: 900px;
}

.contact-form textarea[name="message"] {
    height: 220px;
}

.contact-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 180px;
    height: 60px;
    background-color: #FFEB3B;
    border-radius: 50px;
    font-size: 18px;
    font-weight: 400;
    text-decoration: none;
    color: #000;
    margin: 50px auto 0;
    transition: 0.3s;
}

.contact-button:hover {
    background-color: #FFD700;
    transform: scale(1.05);
}


.footer {
    height: 160px;
    background-color: #646464;
    display: flex;
    justify-content: center;
    align-items: center;
}

.footer small {
    font-size: 16px;
    font-weight: 400;
    color: #fff;
}
