/* Common */
@media screen and (min-width:1020px) {
    .content {
        max-width: 1000px;
        margin: 0 auto;
    }
}
@media screen and (max-width:1019px) {
    .content {
        max-width: 1000px;
        padding: 0 1.25rem;
    }
}
@media screen and (min-width:769px) {
    .spver { display: none; }
    h2 {
        font-size: 2.5rem;
        margin-bottom: 3.5rem;
        line-height: 3.925rem;
    }
    section .content h2:not(:first-child) {
        margin-top: 7.5rem;
    }
    section {
        padding: 7.5rem 0 7.5rem;
    }
    section.banner {
        padding: 1.375rem 0 1rem;
    }
    section.banner .content {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
    }
    section.banner .content > .banner_txt {
        margin-right: 4.375rem;
    }
    .banner_txt p.subtitle {
        padding: 0 1.875rem 0.6875rem;
    }
}
@media screen and (max-width:768px) {
    .pcver,
    p.line_button.pcver { display: none; }
    h2 {
        font-size: 1.5rem;
        margin-bottom: 1.375rem;
    }
    section .content h2:not(:first-child) {
        margin-top: 3.5rem;
    }
    .content {
        margin: 0 auto;
        padding: 0 1.25rem;
    }
    section {
        padding: 2rem 0 2rem;
    }
    section#religion {
        padding: 2rem 0 3.5rem;
    }
    .banner_txt p.subtitle {
        padding: 0 0 0.6875rem;
        margin: 1.25rem auto 0;
    }
    .banner_txt p {
        font-weight: bold;
    }
    section.banner {
        padding: 2rem 0;
    }
}

h2 span {
    background: linear-gradient(transparent 60%, #FFF039 40%);
    font-weight: bold;
}
section.bk {
    width: 100%;
    background-color: #FFF039;
}
p.left {
    text-align: left;
}
section.banner {
    background-color: #FFD94E;
    width: 100%;
}
.banner_txt p.subtitle {
    font-size: 1.5rem;
    font-weight: bold;
    border-bottom: 1px solid #1E1E1E;
}
.banner_txt p.contact_btn {
    margin: 1.125rem auto 0.5625rem;
}
.banner_txt p.contact_btn a {
    background-color: #1E1E1E;
    color: #fff;
    padding: .6rem 2.3125rem .6875rem 1.375rem;
    text-align: center;
    position: relative;
    border-radius: 0.625rem;
    font-size: 1.125rem;
}
.banner_txt p.contact_btn a:after {
    content: "";
    background-image: url("../img/link_icon.png");
    width: 0.46875rem;
    height: 0.65625rem;
    background-size: cover;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 1.20125rem;
}
.banner_txt p {
    font-size: 0.875rem;
    letter-spacing: 0.1rem;
}
.banner_image img {
    max-width: 320px;
}

/* FV */
@media screen and (min-width:769px) {
    main.introduction_monk_page {
        margin: calc(5.6994rem + 1rem) 0 0 0;
    }
    .fv_two_col {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        padding: 3.875rem;
        max-width: 1200px;
        margin: 0 auto;
    }
    .fv_two_col > div.fv_txt {
        width: 57%;
    }
    .fv_two_col > div.fv_image {
        width: 43%;
    }
    section#section_top {
        width: 100%;
        padding: 0;
    }
    section#section_top h1 span {
        font-size: 2.421875rem;
    }
    section#section_top h1 {
        font-size: 3.364375rem;
        line-height: 1.2632;
    }
}
@media screen and (max-width:768px) {
    main.introduction_monk_page {
        margin: 4.3rem 0 0 0;
    }
    section#section_top {
        padding: 1.875rem 1.5rem 3.5rem;
    }
    section#section_top h1 span {
        font-size: 1.25rem;
        margin-bottom: .5rem;
    }
    section#section_top h1 {
        font-size: 2rem;
        line-height: 1.2632;
    }
    .fv_image {
        margin: 1.5rem auto 2.75rem;
    }
    section#section_top p {
        font-weight: bold;
    }
    p.line_button {
        margin: 2.125rem auto 0;
    }
}
section#section_top h1 span {
    display: block;
}
section#section_top div.fv_txt p {
    font-size: 1.125rem;
    font-weight: bold;
    margin: 2rem auto;
}
p.line_button {
    display: block;
    text-align: center;
}
p.line_button a {
    display: inline-block;
    background-color: #0ABF32;
    color: #fff;
    padding: 1.25rem 1.5rem;
    border-radius: 0.625rem;
    font-size: 1.5rem;
    line-height: 1.6;
    letter-spacing: 0.16rem;
}
p.line_button a span {
    font-size: .75rem;
    text-align: left;
    margin: 1rem 0 0;
    display: block;
    font-weight: 500;
}

/* What introduction */
@media screen and (min-width:769px) {
    section#what_introduction {
        padding: 5rem 0 7.5rem;
    }
    section#what_introduction p {
        font-size: 1.125rem;
        font-weight: bold;
        margin-bottom: 3rem;
    }
}
@media screen and (max-width:768px) {
    section#what_introduction {
        padding: 2rem 0 2.5rem;
    }
    section#what_introduction p {
        font-size: 1rem;
        font-weight: bold;
        margin-bottom: 1.5rem;
    }
    section#what_introduction img {
        max-width: 240px;
    }
}
section#what_introduction img {
    max-width: 350px;
    width: 50%;
}

/* What Feature */
@media screen and (min-width:769px) {
    section#feature h2 {
        margin-bottom: 7rem;
    }
    section#feature h2::before,
    section#feature h2::after {
        content: '';
        width: 3px;
        height: 40px;
        background-color: #1E1E1E;
    }
    section#feature h2::before {
        margin-right: 30px;
        transform: rotate(-45deg)
    }
    section#feature h2::after {
        margin-left: 30px;
        transform: rotate(45deg)
    }
    .three_col {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 0 1.5625rem;
        margin-bottom: 4.25rem;
    }
    .three_col > div {
        padding: 2.875rem 1.6875rem 3.375rem;
        border: 3px solid #1E1E1E;
        border-radius: 1.25rem;
        background-color: #fff;
        position: relative;
    }
    #feature h3 {
        font-size: 1.5rem;
        margin-bottom: 1rem;
    }
    .three_col  .circle {
        display: inline-block;
        width: 3.125rem;
        height: 3.125rem;
        border-radius: 50%;
        background: #1E1E1E;
        color: #fff;
        text-align:center;
        line-height: 2.8rem;
        font-size: 2.5rem;
        position: absolute;
        top: -1.5625rem;
        left: 50%;
        transform: translateX(-50%);
    }
    #feature .box {
        border-radius: 1.25rem;
        background-color: #fff;
        padding: 2.5rem 4rem 3.5rem;
    }
    #feature .box .two_col {
        display: grid;
        grid-template-columns: 75% 25%;
        gap: 0 2.125rem;
        justify-content: space-between;
        align-items: center;
    }
}
@media screen and (max-width:768px) {
    section#feature h2 {
        margin-bottom: 2.6875rem;
    }
    section#feature h2::before,
    section#feature h2::after {
        content: '';
        width: 2px;
        height: 1.5rem;
        background-color: #1E1E1E;
        margin-bottom: -0.3rem;
    }
    section#feature h2::before {
        margin-right: 1rem;
        transform: rotate(-45deg);
    }
    section#feature h2::after {
        margin-left: 1rem;
        transform: rotate(45deg)
    }
    .three_col > div {
        padding: 2.25rem 1.6875rem;
        border: 3px solid #1E1E1E;
        border-radius: 1.25rem;
        background-color: #fff;
        position: relative;
        margin: 0 auto 2.6875rem;
    }
    #feature h3 {
        font-size: 1.3125rem;
        margin-bottom: 1rem;
    }
    .three_col  .circle {
        display: inline-block;
        width: 2.375rem;
        height: 2.375rem;
        border-radius: 50%;
        background: #1E1E1E;
        color: #fff;
        text-align:center;
        line-height: 2.2rem;
        font-size: 1.5rem;
        position: absolute;
        top: -1.1875rem;
        left: 50%;
        transform: translateX(-50%);
    }
    #feature .box {
        border-radius: 1.25rem;
        background-color: #fff;
        padding: 2rem 1.125rem;
    }
    #feature .box img {
        max-width: 200px;
        margin: 1rem auto 0;
    }
}
section#feature h2 {
    display: flex;
	justify-content: center;
	align-items: center;
}
#feature h3 {
    color: #E83828;
    font-weight: bold;
}
.three_col p {
    font-size: 1.125rem;
}

/* Religion */
@media screen and (min-width:769px) {
    p.religionm_chart {
        margin: 2.875rem auto 0;
    }
}
@media screen and (max-width:768px) {
    p.religionm_chart {
        margin: 2.875rem -1.25rem 0;
        width: 100vw;
    }
}


/* STEP */
@media screen and (min-width:769px) {
    .step dl {
        margin-bottom: 3.5rem;
        align-items: center;
    }
    .step dl dt {
        position: relative;
        width: 6.75rem;
    }
    .step dl dt p {
        display: inline-block;
        width: 6.75rem;
        height: 6.75rem;
        border-radius: 50%;
        border: 1px solid #FF8A00;
        background: #fff;
        color: #FF8A00;
        text-align:center;
        line-height: 2.5rem;
        font-size: 3.2575rem;
        font-weight: bold;
    }
    .step dl dt p span {
        display: block;
        font-size: 1.174375rem;
        line-height: 1.5rem;
        margin-top: 1rem;
    }
    .step dl dd {
        position: relative;
        width: calc(100% - 9.25rem);
    }
    section#step h3 {
        font-size: 1.5rem;
        font-weight: bold;
    }
    .step dl dt:after {
        content: "";
        width: 1px;
        background: #989898;
        position: absolute;
        display: inline-block;
        bottom: -3.5rem;
        left: 50%;
        transform: translateX(-50%);
        height: 3.5rem;
    }
}
@media screen and (max-width:768px) {
    section#step {
        padding: 3.5rem 0;
    }
    .step dl {
        margin-bottom: 1.8125rem;
        align-items: flex-start;
        position: relative;
    }
    .step dl:before {
        content: "";
        width: 1px;
        background: #989898;
        position: absolute;
        display: inline-block;
        bottom: -3rem;
        left: 2.09375rem;
        height: 100%;
    }
    .step dl:last-child::before {
        content: none;
    }
    .step dl dt {
        position: relative;
        width: 4.1875rem;
    }
    .step dl dt p {
        display: inline-block;
        width: 4.1875rem;
        height: 4.1875rem;
        border-radius: 50%;
        border: 1px solid #FF8A00;
        background: #fff;
        color: #FF8A00;
        text-align:center;
        line-height: 1.5rem;
        font-size: 1.75rem;
        font-weight: bold;
        position: relative;
        z-index: 1;
    }
    .step dl dt p span {
        display: block;
        font-size: 1rem;
        line-height: 1.5rem;
        margin-top: .4rem;
    }
    .step dl dd {
        position: relative;
        width: calc(100% - 5.1875rem);
    }
    section#step h3 {
        font-size: 1.125rem;
        font-weight: bold;
    }
}
.step dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    position: relative;
}
.step dl:last-child {
    margin-bottom: 0;
}
.step dl dt,
.step dl dd {
    text-align: left;
}
.step dl:last-child dt:after {
    content: none;
}
.step dl dd p {
    font-size: 0.9375rem;
    line-height: 1.5625rem;
}

/* FAQ */
@media screen and (min-width:769px) {
    .faq dl dt,
    .faq dl dd {
        padding: 0.90625rem 0.90625rem 0.90625rem 7.6625rem;
    }
    .faq dl dt:before,
    .faq dl dd:before {
        left: 3.5625rem;
    }
}
@media screen and (max-width:768px) {
    .faq dl dt,
    .faq dl dd {
        padding: 0.6875rem 1.375rem 0.6875rem 4.5rem;
        line-height: 2.05rem;
    }
    .faq dl dt:before,
    .faq dl dd:before {
        left: 1rem;
    }
}
.faq dl {
    margin: 0 auto 1.5rem;
}
.faq dl:last-child {
    margin: 0 auto;
}
.faq dl dt,
.faq dl dd {
    display: block;
    width: 100%;
    text-align: left;
}
.faq dl dt {
    background-color: #FFD94E;
    border-top-left-radius: 0.625rem;
    border-top-right-radius: 0.625rem;
    position: relative;
    font-weight: bold;
}
.faq dl dt:before {
    content: "Q";
    display: inline-block;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: #fff;
    text-align:center;
    line-height: 2.5rem;
    font-weight: bold;
    position: absolute;
}
.faq dl dd {
    border: 1px solid #FFD94E;
    border-bottom-left-radius: 0.625rem;
    border-bottom-right-radius: 0.625rem;
    position: relative;
}
.faq dl dd:before {
    content: "A";
    display: inline-block;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: #FFD94E;
    text-align:center;
    line-height: 2.5rem;
    font-weight: bold;
    position: absolute;
}