/*---------- タイトル ----------*/
.about-section {
    width: 100%;
    height: 100%;
    background-image: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.3)),url(../images/guideline_top.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    margin-top: 80px;
    color: #fff;
}
.about-title{
    max-width: 1360px;
    padding: 90px 40px;
    margin: 0 auto;
}
span.section-en_title {
    color: #fff;
}
span.section-en_title::after{
    background: #fff;
}
p.about-section__text {
    padding: 0 20px;
    font-size: 18px;
}
@media screen and (max-width: 1260px) {
    .about-section {
        margin-top: 75px;
    }
    p.about-section__text {
        padding: 0 15px;
    }
}
@media screen and (max-width: 760px) {
    p.about-section__text {
        font-size: 16px;
    }
    .about-title {
        padding: 45px 30px;
    }
}
@media screen and (max-width: 450px) {
    .about-title {
        padding: 30px 20px;
    }
    h2.section-title {
        padding-bottom: 10px;
    }
    p.about-section__text {
        padding: 0 5px;
    }
}

/*---------- セクションタイトル ----------*/
h4.a-section-title {
    font-size: 28px;
    border-left: 4px solid var(--main-color);
    padding-left: 10px;
    margin-bottom: 45px;
    position: relative;
}
h4.a-section-title::after {
    content: "";
    position: absolute;
    bottom: -15px;
    border-bottom: 2px dotted #9BA0AC;
    width: 100%;
    left: 0;
}
@media screen and (max-width: 1260px) {
    h4.a-section-title {
        font-size: 24px;
    }
}
@media screen and (max-width: 760px) {
    h4.a-section-title {
        font-size: 22px;
        margin-bottom: 30px;
    }
    h4.a-section-title::after {
        bottom: -10px;
    }
}

/*---------- 企業理念 ----------*/
.philosophy-section {
    margin: 100px auto;
}
.philosophy-content {
    padding: 0 20px;
}
p.philosophy-main {
    font-size: 24px;
    font-weight: 600;
    padding-bottom: 10px;
}
p.philosophy-text {
    font-weight: 500;
    line-height: 2.3;
    padding: 0 10px;
}
/*スライダー*/
.loop-slider {
    margin: 30px auto;
    overflow: hidden;
    width: 100%;
}
.philosophy-images {
    display: flex;
    gap: 15px;
    width: max-content;
    margin-left: 15px;
}
.loop-slider-inner {
    display: flex;
    width: max-content;
}
.philosophy-image img {
    width: 375px;
    height: auto;
    display: block;
}
@media screen and (max-width: 1260px) {
    p.philosophy-main {
        font-size: 22px;
    }
    p.philosophy-text {
        line-height: 2;
        padding: 0px 5px;
    }
}
@media screen and (max-width: 760px) {
    p.philosophy-main {
        font-size: 20px;
    }
    p.philosophy-text {
        line-height: 1.8;
    }
}
@media screen and (max-width: 450px) {
    .philosophy-content {
        padding: 0 10px;
    }
}

/*---------- ７つの心得 ----------*/
p.mindset-intro {
    padding: 0 20px;
    font-weight: 500;
}
ul.mindset-list {
    padding: 50px 30px;
    display: flex;
    flex-direction: column;
    gap: 30px;
}
li.mindset-item {
    border-bottom: 2px dotted #becae1;
    padding: 0 20px 20px;
    display: flex;
    gap: 30px;
}
p.mindset-title {
    font-size: 18px;
    width: 180px;
    font-weight: 600;
    color: var(--main-color);
}
ul.mindset-detail-list {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
li.mindset-detail {
    position: relative;
    padding-left: 1em;
}
li.mindset-detail::after {
    content: "";
    position: absolute;
    width: 7px;
    height: 7px;
    background: var(--main-color);
    border-radius: 50%;
    left: 0;
    top: 8px;
}
@media screen and (max-width: 1260px) {  
    ul.mindset-list {
        padding: 30px 15px;
    }
    p.mindset-title {
        width: 120px;
    }
}
@media screen and (max-width: 910px) {
    li.mindset-item {
        flex-direction: column;
        gap: 15px;
    }
}
@media screen and (max-width: 450px) {
    p.mindset-intro {
        padding: 0 10px;
    }
    ul.mindset-list {
        gap: 20px;
    }
    li.mindset-item {
        padding: 0 10px 10px;
        gap: 10px;
    }
    li.mindset-detail::after {
        width: 5px;
        height: 5px;
        left: 4px;
        top: 8px;
    }
}

/*---------- 会社情報 ----------*/
.company-info__item {
    display: flex;
    border-bottom: 2px solid #eee;
}
.company-info {
    margin: 25px auto;
    padding: 0 30px;
}
dt.company-info__term {
    font-size: 18px;
    font-weight: 500;
    position: relative;
    max-width: 230px;
    width: 100%;
    padding: 25px 0 20px 25px;
}
dt.company-info__term::after {
    content: "";
    max-width: 230px;
    width: 100%;
    background: var(--main-color);
    height: 2px;
    position: absolute;
    left: 0;
    bottom: -2px;
}
dd.company-info__desc {
    padding: 25px 25px 20px 45px;
}
.factory-item__map iframe {
    border-radius: 20px;
    margin: 10px 0 20px;
}
a.company-info__tel {
    color: var(--main-color);
    text-decoration: underline;
}
@media screen and (max-width: 768px) {
    .company-info__item {
        display: flex;
        border-bottom: 2px solid #eee;
        flex-direction: column;
    }
    dt.company-info__term {
        padding: 25px 0 15px 10px;
    }
    dt.company-info__term,
    dt.company-info__term::after {
        max-width: 100%;
    }
    dd.company-info__desc {
        padding: 25px 15px 20px;
    }
}
@media screen and (max-width: 450px) {
    .company-info {
        padding: 0px 10px;
    }
    dt.company-info__term {
        padding: 20px 0 10px 10px;
        font-size: 16px;
    }
    dd.company-info__desc {
        padding: 25px 10px 15px;
    }
}