@charset "UTF-8";

body {
    font-weight: 400;
}

/* 橋梁（陸橋・高架下）の鳥害対策
----------------------------*/
.page-id-8933 #sec_2 h3.normal_hl {
    margin-top: 6.5rem;
}

.page-id-8933 #sec_2 .button_style_2 {
    margin-top: 2.2rem;
}

.page-id-8933 #sec_2 .image_col {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    column-gap: 3.6rem;
    row-gap: 2rem;
    margin: 3.6rem 0;
}

.page-id-8933 #sec_2 .image_col img {
    width: calc(50% - 1.8rem);
}


/* 鳩対策商品
----------------------------*/
.product_list_flex {
    display: flex;
    flex-wrap: wrap;
    column-gap: 4rem;
    row-gap: 8rem;
    margin-top: 6rem;
}

.product_list_flex .item {
    width: calc(50% - 2rem);
    background-color: #fff;
    border: 1px solid #d6d6d6;
    padding-bottom: 2.8rem;
}

.product_list_flex .item .thumb {
    margin-bottom: 3rem;
    overflow: hidden;
}

.product_list_flex .item .thumb img {
    transition: transform .5s;
}

.product_list_flex .item .thumb:hover img {
    transform: scale(1.04);
}

.product_list_flex .item .link {
    font-size: 2.3rem;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 1.8rem;
    padding: 0 2rem;
    column-gap: 1.4rem;
}

.product_list_flex .item .link:after {
    content: "";
    min-width: .74em;
    min-height: .74em;
    background-image: url(../img/common/arrow_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

.product_list_flex .item p {
    padding: 0 2rem;
}

.product_list_flex .item .link:hover {
    color: #ac1d28;
}

@media (max-width: 767px) {
    .product_list_flex {
        row-gap: 5rem;
    }

    .product_list_flex .item {
        width: 100%;
    }

    .product_list_flex .item .link {
        font-size: 2rem;
    }
}


/* 鳩対策商品 下層
----------------------------*/
.product_content .side_R dl:not([class]) dt {
    border-bottom: 2px solid #000;
    width: 15rem;
}

.product_content .side_R dl:not([class]) dd {
    border-bottom: 2px solid #e9e9e9;
    width: calc(100% - 15rem);
}

.page-id-12284 .page_content .col4:not(:last-child) {
    margin-bottom: 3rem;
}

.page-id-12284 .page_content h4:not([class]):not(:first-child) {
    margin-top: 6rem;
}

.page-id-12284 .page_content dl:not([class]) dd,
.page-id-12284 .page_content dl:not([class]) dt {
    padding: 1.5rem 2rem;
}



/* 理念・スローガン・ビジョン
----------------------------*/
.page-id-18894 .page_key {
    height: auto;
    max-height: initial;
    display: block;
}

.page-id-18894 .page_key .page_thumbnail img {
    object-position: 50% bottom;
}

.page-id-18894 .page_key .page_key_inner {
    padding: 11rem 0 18rem;
}

.page-id-18894 .page_key .page_key_content {
    padding: 12rem 0 51rem;
    color: #fff;
    text-align: center;
}

.page-id-18894 .page_key .page_key_content>.lead {
    font-size: 3.5rem;
    font-weight: 700;
    line-height: 1.65;
    margin-bottom: 2.5rem;
}

.page-id-18894 .page_key .page_key_content>.text {
    font-size: 1.8rem;
    line-height: 1.78;
    margin-bottom: 5.6rem;
}

.page-id-18894 .page_key .page_key_content .point_col {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 4rem;
    row-gap: 2.4rem;
    margin-bottom: 4.8rem;
}

.page-id-18894 .page_key .page_key_content .point_col .item {
    width: calc((100% - 8rem) / 3);
    border: 2px solid #fff;
    padding: 2rem 3.6rem 3.6rem;
}

.page-id-18894 .page_key .page_key_content .point_col .item .num {
    font-size: 2rem;
    margin-bottom: .6rem;
}

.page-id-18894 .page_key .page_key_content .point_col .item .text {
    font-size: 1.9rem;
    font-weight: 700;
    line-height: 1.68;
}

.page-id-18894 .page_key .page_key_content .endtext {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.6;
}

.page-id-18894 .slogan_lead {
    font-size: 2.5rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 5.6rem;
}

.page-id-18894 .slogan_lead .em {
    font-size: 3.5rem;
}

.page-id-18894 .slogan_lead span:not([class]) {
    display: inline-block;
}

.page-id-18894 .slogan_col {
    display: flex;
    flex-wrap: wrap;
    column-gap: 4rem;
    row-gap: 3rem;
    justify-content: center;
    margin: 5.6rem 0 4.7rem;
}

.page-id-18894 .slogan_col>div {
    width: calc((100% - 8rem) / 3);
    background-color: #f3f4ff;
    padding: 2.4rem 4rem 2rem;
    text-align: center;
}

.page-id-18894 .slogan_col .lead {
    font-size: 2.4rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 1.8rem;
}

.page-id-18894 .slogan_col .text {
    font-size: 1.8rem;
    font-weight: 500;
}

.page-id-18894 .mission_box {
    color: #fff;
    padding: 11rem 0;
    background-image: url(../img/philosophy/mission.webp);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    margin-bottom: 6rem;
}

.page-id-18894 .mission_box .lead {
    font-size: 2rem;
    margin-bottom: 1.4rem;
    font-family: "Noto Serif JP", serif;
    font-weight: 500;
}

.page-id-18894 .mission_box .text {
    font-size: 3rem;
    line-height: 1.7;
    font-weight: 500;
}

.page-id-18894 .mission_box .lead,
.page-id-18894 .mission_box .text {
    padding-left: 45%;
}

.page-id-18894 .mission_col {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    column-gap: 6rem;
    row-gap: 4rem;
}

.page-id-18894 .mission_list {
    width: 58rem;
    background-color: #f3f4ff;
    padding: 4rem 4rem 5rem 3rem;
    counter-reset: ol 0;
}

.page-id-18894 .mission_list li {
    position: relative;
    font-size: 2rem;
    font-weight: 500;
    padding-left: 1.8em;
}

.page-id-18894 .mission_list li+li {
    margin-top: 2.4rem;
}

.page-id-18894 .mission_list li:before {
    counter-increment: ol 1;
    content: counter(ol, decimal-leading-zero);
    font-weight: 700;
    color: #1f2774;
    position: absolute;
    left: 0;
    top: 0;
}

.page-id-18894 .mission_text {
    width: calc(100% - 64rem);
    font-size: 2rem;
    line-height: 1.9;
}

.page-id-18894 .mission_text p+p {
    margin-top: 3rem;
}

.page-id-18894 .mission_text .bold {
    font-weight: 700;
    font-size: 1.25em;
}

.page-id-18894 .mission_text .medium {
    font-weight: 500;
}

.page-id-18894 .mission_text span:not([class]) {
    display: inline-block;
}

@media (max-width: 767px) {
    .page-id-18894 .page_key .page_key_inner {
        padding: 7rem 0;
    }

    .page-id-18894 .page_key .page_key_content {
        padding: 3rem 0 20rem;
    }

    .page-id-18894 .page_key .page_key_content>.lead {
        font-size: clamp(1.4rem,4vw,3rem);
    }

    .page-id-18894 .page_key .page_key_content>.text {
        font-size: 1.5rem;
        text-align: left;
    }

    .page-id-18894 .page_key .page_key_content .point_col .item {
        width: 100%;
        padding: 1rem 2rem 2rem;
    }

    .page-id-18894 .page_key .page_key_content .point_col .item .text {
        font-size: 1.6rem;
    }

    .page-id-18894 .page_key .page_key_content .endtext {
        font-size: 1.6rem;
    }

    .page-id-18894 .slogan_lead {
        font-size: 1.6rem;
    }

    .page-id-18894 .slogan_lead .em {
        font-size: 2rem;
    }

    .page-id-18894 .slogan_col>div {
        width: 100%;
        padding: 2rem;
    }

    .page-id-18894 .slogan_col .lead {
        font-size: 2rem;
    }

    .page-id-18894 .slogan_col .text {
        font-size: 1.6rem;
    }

    .page-id-18894 .mission_box {
        padding: 4rem 1rem;
    }

    .page-id-18894 .mission_box .lead,
    .page-id-18894 .mission_box .text {
        padding-left: 16%;
    }

    .page-id-18894 .mission_box .lead {
        font-size: 1.6rem;
    }

    .page-id-18894 .mission_box .text {
        font-size: 1.8rem;
    }

    .page-id-18894 .mission_list {
        width: 100%;
        padding: 3rem 1.5rem;
    }

    .page-id-18894 .mission_list li {
        font-size: 1.6rem;
    }

    .page-id-18894 .mission_text {
        width: 100%;
        font-size: 1.6rem;
    }
}


/* 会社概要
----------------------------*/
.page-id-18900 .wrapper .inner {
    margin-left: auto;
    width: 1340px;
    max-width: calc(100% - 4rem);
}

.page-id-18900 #sec_1 .inner {
    display: flex;
    justify-content: space-between;
    align-items: start;
    column-gap: 3rem;
    row-gap: 4rem;
}

.page-id-18900 #sec_1 .logo_side img {
    width: 31rem;
}

.page-id-18900 #sec_1 .table_side {
    width: 87.5rem;
    max-width: 100%;
}

.page-id-18900 #sec_1 .table_side dt {
    width: 14rem;
}

.page-id-18900 #sec_1 .table_side dd {
    width: calc(100% - 14rem);
    line-height: 2;
}

.page-id-18900 #sec_2 .inner {
    display: flex;
    align-items: start;
    column-gap: 10rem;
}

.page-id-18900 #sec_2 .img_side {
    width: 36rem;
    display: flex;
    flex-direction: column;
    row-gap: 2.5rem;
}

.page-id-18900 #sec_2 .history_side {
    width: calc(100% - 46rem);
    position: relative;
}

.page-id-18900 #sec_2 .history_side:before {
    content: "";
    position: absolute;
    left: 0;
    top: 2rem;
    bottom: 1rem;
    width: 1px;
    background-color: #1f2774;
}

.page-id-18900 #sec_2 .history_side .normal {
    display: flex;
    align-items: start;
    column-gap: 1em;
    padding-left: 1.4rem;
    position: relative;
}

.page-id-18900 #sec_2 .history_side .normal .date {
    white-space: nowrap;
}

.page-id-18900 #sec_2 .history_side .normal:before {
    content: "";
    position: absolute;
    left: -3px;
    top: .8rem;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background-color: #1f2774;
    z-index: +2;
}

.page-id-18900 #sec_2 .history_side .pick {
    font-size: 1.8rem;
    font-weight: 500;
    padding-left: 2rem;
    position: relative;
}

.page-id-18900 #sec_2 .history_side .pick span {
    display: inline-block;
    padding: .5rem 3rem .5rem 1.4rem;
    background-color: #f3f4ff;
    position: relative;
}

.page-id-18900 #sec_2 .history_side .pick span:before {
    content: "";
    position: absolute;
    top: 0;
    right: calc(100% - .1px);
    height: 0;
    width: 0;
    border-style:solid;
    border-width: 18.5px 11px 18.5px 0;
    border-color: transparent #F3F4FF transparent transparent;
}

.page-id-18900 #sec_2 .history_side .pick:before {
    content: "";
    position: absolute;
    left: -5px;
    top: 1.2rem;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background-color: #1f2774;
    z-index: +2;
}

.page-id-18900 #sec_2 .history_side .normal:last-child:after {
    content: "";
    position: absolute;
    top: .9rem;
    left: -1px;
    bottom: 0;
    width: 3px;
    z-index: +1;
    background-color: #fff;
}

.page-id-18900 #sec_2 .history_side .normal+.normal {
    margin-top: 2.7rem;
}

.page-id-18900 #sec_2 .history_side .pick+.normal {
    margin-top: 1.8rem;
}

.page-id-18900 #sec_2 .history_side .normal+.pick {
    margin-top: 2.3rem;
}

.page-id-18900 #sec_2 .history_side .pick+.pick {
    margin-top: 1.5rem;
}

.page-id-18900 #sec_3 .parentline_hl:after {
    content: initial;
}

@media (max-width: 767px) {
    .page-id-18900 .wrapper .inner {
        margin: 0 auto;
        max-width: calc(100% - 2rem);
    }

    .page-id-18900 #sec_1 .inner {
        flex-wrap: wrap;
    }

    .page-id-18900 #sec_2 .inner {
        flex-wrap: wrap;
        row-gap: 4rem;
    }

    .page-id-18900 #sec_2 .img_side {
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        column-gap: 2rem;
        row-gap: 1.5rem;
    }

    .page-id-18900 #sec_2 .img_side img {
        width: calc(50% - 1rem);
    }

    .page-id-18900 #sec_2 .history_side {
        width: 100%;
    }

    .page-id-18900 #sec_2 .history_side .pick span {
        font-size: 1.6rem;
    }
}


/* 建築・設計事務所の皆さまへ
----------------------------*/
.page-id-866 .advice_text {
    font-size: 2.2rem;
    text-align: center;
    line-height: 1.5;
    margin-top: 3.6rem;
}

.page-id-866 .advice_text strong {
    font-weight: 600;
    color: #333;
}

.page-id-866 .buttons_col_2 {
    row-gap: 14px;
}

.page-id-866 .buttons_col_2 .button_style_1 {
    width: 100%;
    font-weight: 500;
}

.page-id-866 .buttons_col_2 .button_style_1:after {
    transform: rotate(135deg);
}

.page-id-866 .buttons_col_2 .button_style_1 strong {
    font-weight: 700;
    text-decoration: underline;
}

.page-id-866 #sec_03 .btn {
    width: 37rem;
    max-width: 100%;
    margin-left: auto;
    font-size: 1.6rem;
    font-weight: 700;
    padding: 2rem;
    color: #fff;
    background-color: #1f2774;
    border-radius: 5px;
    position: relative;
}

.page-id-866 #sec_03 .btn:after {
    content: "";
    position: absolute;
    width: .8rem;
    height: .8rem;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    top: 0;
    right: 2.5rem;
    bottom: 0;
    margin: auto 0;
}

.page-id-866 #sec_03 .btn:hover {
    background-color: #ac1d28;
}

@media (max-width: 767px) {
    .page-id-866 .advice_text {
        font-size: 1.6rem;
        text-align: left;
    }
}


/* お客様の声（イエローカード）
----------------------------*/
.page-id-13265 .ycard_lead {
    display: flex;
    flex-wrap: wrap;
}

.page-id-13265 .ycard_lead .text_side {
    width: 64%;
    background-color: #fff27d;
    padding: 3.8rem 0 4.2rem 8rem;
}

.page-id-13265 .ycard_lead .text_side .lead {
    font-size: 6rem;
    font-weight: 700;
    margin-bottom: .5rem;
}

.page-id-13265 .ycard_lead .text_side .text {
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 1.4;
}

.page-id-13265 .ycard_lead .text_side .btn {
    width: 100%;
    max-width: 45rem;
    font-size: 1.6rem;
    font-weight: 700;
    color: #1f2774;
    background-color: #fff;
    padding: 2rem 3.5rem;
    border-radius: 5px;
    margin-top: 2.4rem;
    background-image: url(../img/common/arrow_06.svg);
    background-repeat: no-repeat;
    background-size: 1em;
    background-position: right 1.68em center;
}

.page-id-13265 .ycard_lead .text_side .btn:hover {
    background-color: #1f2774;
    color: #fff;
    background-image: url(../img/common/arrow_04.svg);
}

.page-id-13265 .ycard_lead .img_side {
    width: 36%;
    position: relative;
}

.page-id-13265 .ycard_lead .img_side img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.page-id-13265 .ycard_block {
    padding: 4.6rem 0 5.3rem;
    border-bottom: 1px solid #bebebe;
}

.page-id-13265 .ycol_1 {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    column-gap: 6rem;
    row-gap: 4rem;
    margin-bottom: 4.6rem;
}

.page-id-13265 .ycol_1 .img_side {
    width: 28rem;
}

.page-id-13265 .ycol_1 .img_side img {
    height: 21rem;
    object-fit: cover;
}

.page-id-13265 .ycol_1 .text_side {
    width: calc(100% - 34rem);
    background-color: #fff27d;
    border-radius: 10px;
    position: relative;
    padding: 3rem 5rem 4rem;
}

.page-id-13265 .ycol_1 .text_side .ttl {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: .5rem;
}

.page-id-13265 .ycol_1 .text_side .from {
    font-size: 1.4rem;
    font-weight: 500;
}

.page-id-13265 .ycol_1 .text_side .text {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 2;
    padding-top: 1.2rem;
    margin-top: 1.6rem;
    border-top: 1px solid #9c9c9c;
}

.page-id-13265 .ycol_1 .text_side:before {
    content: "";
    position: absolute;
    width:0;
    height:0;
    border-style:solid;
    border-width: 12.5px 12px 12.5px 0;
    border-color: transparent #fff27d transparent transparent;
    right: 100%;
    top: calc(50% - 12.5px);
}

.page-id-13265 .ycol_2 {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: row-reverse;
    column-gap: 3rem;
    justify-content: center;
    row-gap: 2rem;
}

.page-id-13265 .ycol_2 .img_side {
    width: 9rem;
}

.page-id-13265 .ycol_2 .img_side img {
    border-radius: 100px;
    border: 1px solid #bebebe;
}

.page-id-13265 .ycol_2 .text_side {
    width: calc(100% - 12rem);
    background-color: #f5f5f5;
    padding: 3rem 5rem 3.4rem;
    border-radius: 10px;
    position: relative;
}

.page-id-13265 .ycol_2 .text_side .lead {
    font-size: 2rem;
    font-weight: 700;
    color: #1f2774;
    padding-left: 2em;
    margin-bottom: 1.8rem;
    background-image: url(../img/common/manager_icon.svg);
    background-repeat: no-repeat;
    background-size: 1.2em;
    background-position: left center;
}

.page-id-13265 .ycol_2 .text_side .text {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 2;
    margin-bottom: 1.6rem;
}

.page-id-13265 .ycol_2 .text_side:after {
    content: "";
    width:0;
    height:0;
    border-style:solid;
    border-width: 12.5px 0 12.5px 12px;
    border-color: transparent transparent transparent #F5F5F5;
    position: absolute;
    left: 100%;
    top: calc(50% - 12.5px);
}

.page-id-13265 .ycol_2 .text_side .name {
    font-size: 1.5rem;
    font-weight: 700;
}

.page-id-13265 .ycol_2 .text_side .name a {
    color: #326fcb;
    text-decoration: underline;
}

.page-id-13265 .ycol_2 .text_side .name a:hover {
    text-decoration: none;
    opacity: .6;
}

@media (max-width: 767px) {
    .page-id-13265 .ycard_lead .text_side {
        width: 100%;
        padding: 3rem 2rem 4rem;
    }

    .page-id-13265 .ycard_lead .img_side {
        width: 100%;
    }

    .page-id-13265 .ycard_lead .img_side img {
        position: initial;
    }

    .page-id-13265 .ycard_lead .text_side .lead {
        font-size: 3rem;
    }

    .page-id-13265 .ycard_lead .text_side .text {
        font-size: 1.8rem;
    }

    .page-id-13265 .ycard_lead .text_side .btn {
        padding: 1.6rem 2.4rem;
    }

    .page-id-13265 .ycol_1 .img_side {
        width: 100%;
    }

    .page-id-13265 .ycol_1 .text_side {
        width: 100%;
        padding: 3rem 2rem 4rem;
    }

    .page-id-13265 .ycol_1 .text_side:before {
        content: initial;
    }

    .page-id-13265 .ycol_1 .text_side .ttl {
        font-size: 1.8rem;
    }

    .page-id-13265 .ycol_2 .text_side {
        width: 100%;
        padding: 3rem 2rem 4rem;
    }
}


/* 認定加盟店募集
----------------------------*/
.page-id-16530 #sec_1 .q_lead {
    font-size: 3.5rem;
    font-weight: 900;
    text-align: center;
    color: #1f2774;
    margin-bottom: 1.2rem;
}

.page-id-16530 #sec_1 .q_lead+.q_arrow {
    width: 8.6rem;
    margin: 0 auto 2.8rem;
}

.page-id-16530 #sec_1 .a_box {
    padding: 3.8rem 2rem 3.2rem;
    text-align: center;
    background-color: #ffe2e2;
    color: #cf0000;
}

.page-id-16530 #sec_1 .a_box .sub {
    font-size: 2rem;
    line-height: 1.5;
    font-weight: 900;
}

.page-id-16530 #sec_1 .a_box .main {
    font-size: 3.5rem;
    line-height: 1.5;
    font-weight: 900;
}

.page-id-16530 #sec_1 .a_box .main span {
    background: linear-gradient(transparent 70%, #fff 70%);
}

.page-id-16530 #sec_1 .a_box .logo {
    width: 36.8rem;
    margin: 3.2rem auto 0;
}

.page-id-16530 #sec_3 .col3 {
    justify-content: center;
}

.page-id-16530 #sec_3 img {
    margin: 0;
}

.page-id-16530 #sec_3 .textbox {
    background-color: #f3f4ff;
    padding: 2.8rem 3rem 3.3rem;
}

.page-id-16530 #sec_3 .lead {
    font-size: 2rem;
    display: flex;
    align-items: start;
    justify-content: start;
    column-gap: .6em;
    margin-bottom: 1.3rem;
    color: #1f2774;
}

.page-id-16530 #sec_3 .lead .num {
    font-family: "Noto Serif JP", serif;
    font-size: 1.1em;
    font-weight: 500;
    line-height: 1.4;
}

.page-id-16530 #sec_3 .lead .main {
    font-weight: 700;
    line-height: 1.5;
}

.page-id-16530 #sec_3 .text {
    font-size: 1.5rem;
    font-weight: 500;
}

.page-id-16530 #sec_4 .store_list {
    display: flex;
    flex-wrap: wrap;
    column-gap: 4.6rem;
    row-gap: 3rem;
}

.page-id-16530 #sec_4 .store_list .item {
    width: calc(50% - 2.3rem);
    background-color: #f3f4ff;
    padding: 2.6rem 3.5rem 3rem;
    position: relative;
    transition: .3s;
}

.page-id-16530 #sec_4 .store_list .item:hover {
    background-color: #FaFbFF
}

.page-id-16530 #sec_4 .store_list .lead {
    font-size: 2rem;
    font-weight: 700;
    color: #1f2774;
    margin-bottom: 1rem;
}

.page-id-16530 #sec_4 .store_list .text {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5;
    position: relative;
    z-index: +1;
    pointer-events: none;
}

.page-id-16530 #sec_4 .store_list .text a {
    font-weight: 500;
    color: #333;
    pointer-events: initial;
}

.page-id-16530 #sec_4 .store_list .text a:hover {
    opacity: .6;
    text-decoration: none;
}

.page-id-16530 #sec_4 .store_list .item:after {
    content: "";
    position: absolute;
    width: 1.6rem;
    height: 1.6rem;
    right: 0;
    bottom: 0;
    background: linear-gradient(315deg,rgba(31, 39, 116, 1) 50%, rgba(31, 39, 116, 0) 50%);
}

.page-id-16530 .button_style_3 {
    margin-top: 7rem !important;
}

.page-id-16530 #sec_4 .store_list .lead:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media (max-width: 767px) {
    .page-id-16530 #sec_1 .q_lead {
        font-size: 2.4rem;
        margin-top: 4rem;
    }

    .page-id-16530 #sec_1 .a_box .main {
        font-size: 2.4rem;
    }

    .page-id-16530 #sec_4 .store_list .item {
        width: 100%;
    }
}


/* 加盟店募集
----------------------------*/
.page-id-894 #sec_1 ol {
    font-weight: 700;
}

.page-id-894 .button_style_3 {
    margin-top: 7rem !important;
}


/* 各種パートナー制度のご案内
----------------------------*/
.page-id-19071 .front_text {
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
}

.page-id-19071 #sec_1 .align_right {
    margin-top: 1em;
}

.page-id-19071 #sec_2 .box {
    background-color: #f3f4ff;
    padding: 4rem 6rem 4.5rem 5rem;
    display: flex;
    align-items: center;
    column-gap: 5rem;
    color: #1f2774;
}

.page-id-19071 #sec_2 .box+.box {
    margin-top: 2rem;
}

.page-id-19071 #sec_2 .box .side_L {
    width: 29rem;
}

.page-id-19071 #sec_2 .box .side_R {
    width: calc(100% - 34rem);
}

.page-id-19071 #sec_2 .box .side_L .lead {
    font-family: "Noto Serif JP", serif;
    font-size: 3.2rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 1.8rem;
}

.page-id-19071 #sec_2 .box .side_L .lead .lar {
    font-size: 1.5em;
    color: #ac1d28;
}

.page-id-19071 #sec_2 .box .side_L .lead .mid {
    font-size: 1.125em;
}

.page-id-19071 #sec_2 .box .side_L .copy {
    font-family: "Noto Serif JP", serif;
    font-size: 2.2rem;
    font-weight: 800;
    text-align: center;
    line-height: 1.4;
}

.page-id-19071 #sec_2 .box .side_L .text {
    font-weight: 500;
    line-height: 1.5;
}

.page-id-19071 #sec_2 .box .side_R .num_box {
    background-color: #fff;
    padding: 1.5rem 2rem;
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.5;
    display: flex;
    align-items: start;
    column-gap: 2rem;
}

.page-id-19071 #sec_2 .box .side_R .num_box:not(:last-child) {
    margin-bottom: 1.5rem;
}

.page-id-19071 #sec_2 .box .side_R .num_box .num {
    font-family: "Noto Serif JP", serif;
    font-size: .91em;
    font-weight: 500;
    line-height: 1.65;
}

.page-id-19071 #sec_2 .box .side_R .text {
    padding: 0 2rem;
    font-weight: 500;
}

.page-id-19071 #sec_2 .box+p {
    margin-top: 4rem;
}

.page-id-19071 #sec_3 .link_col_general .lead {
    display: flex; 
    align-items: center;
    min-height: 8.4rem;
    padding: 1.3rem 3.6rem;
}

.page-id-19071 #sec_3 .link_col_general+p {
    margin-top: 3rem;
}

@media (max-width: 767px) {
    .page-id-19071 #sec_2 .box {
        flex-wrap: wrap;
        row-gap: 3rem;
        padding: 3rem 2rem 4rem;
    }

    .page-id-19071 #sec_2 .box .side_L {
        width: 100%;
    }

    .page-id-19071 #sec_2 .box .side_R {
        width: 100%;
    }

    .page-id-19071 #sec_2 .box .side_R .text {
        padding: 0;
    }

    .page-id-19071 #sec_2 .box .side_R .num_box {
        padding: 1.5rem;
        column-gap: 1rem;
        font-size: 1.6rem;
    }

    .page-id-19071 #sec_3 .link_col_general .lead {
        padding: 1.3rem 4rem 1.3rem 1.5rem;
        min-height: 0;
        font-size: 1.6rem;
    }
}


/* 品質・安全への取り組み
----------------------------*/
.page-id-19098 #sec_1 .box {
    display: flex;
    flex-wrap: wrap;
}

.page-id-19098 #sec_1 .box .image_side {
    width: 33%;
    object-fit: cover;
    margin: 0;
}

.page-id-19098 #sec_1 .box .text_side {
    width: 67%;
    color: #fff;
    background-color: #1f2774;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 3rem 8rem 3rem 7.3rem;
    font-family: "Noto Serif JP", serif;
}

.page-id-19098 #sec_1 .box .text_side .lead {
    font-size: 1.6rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
}

.page-id-19098 #sec_1 .box .text_side .lead:after {
    content: "";
    height: 1px;
    background-color: #fff;
    flex-grow: 1;
    margin-left: 1.1rem;
}

.page-id-19098 #sec_1 .box .text_side .text {
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.6;
}

.page-id-19098 #sec_3 .lead {
    font-size: 2rem;
    font-weight: 800;
    margin-bottom: 8rem;
}

.page-id-19098 #sec_3 .col2:not(:last-child) {
    margin-bottom: 4rem;
}

@media (max-width: 767px) {
    .page-id-19098 #sec_1 .box .image_side {
        width: 100%;
        height: 50vw;
    }

    .page-id-19098 #sec_1 .box .text_side {
        width: 100%;
        padding: 3rem 2rem;
    }

    .page-id-19098 #sec_1 .box .text_side .text {
        font-size: 2rem;
    }

    .page-id-19098 #sec_3 .lead {
        font-size: 1.8rem;
    }
}


/* 問い合わせフォーム
----------------------------*/
.form_content {
    display: flex;
    align-items: start;
    flex-wrap: wrap;
    column-gap: 8rem;
    margin-top: 4rem;
}

.confirm_wrap,
.thanks_wrap,
.wpcf7-response-output,
.form_wrap .wpcf7-spinner {
    display: none;
}

.form_content #form_left {
    width: calc(100% - 66rem);
}

.form_content #form_left+div {
    width: 58rem;
}

.form_content #form_left h1.hl {
    font-size: 3.5rem;
    font-weight: 800;
    margin-bottom: 2.8rem;
}

.form_content #form_left .text_1 {
    font-size: 1.6rem;
    line-height: 2;
}

.form_content #form_left .text_1+.text_1 {
    margin-top: 2.6rem;
}


.form_content #form_left .text_1 .required {
    display: inline-block;
    font-size: 1.2rem;
    color: #ac1d28;
    line-height: 1.5;
    padding: .4rem .6rem;
    margin: 0 .8em 0 0;
    border: 1px solid #ac1d28;
}

.form_content #form_left .text_1 a {
    display: inline;
}

.form_content #form_left .text_1 a:hover {
    color: #004CB3;
}

.form_content #form_left h2.lead {
    font-size: 2.4rem;
    font-weight: 700;
    margin: 7rem 0 2rem;
}

.form_content #form_left .text_2 {
    font-size: 1.6rem;
    line-height: 1.625;
}

.form_content #form_left .text_2+.text_2 {
    margin-top: 1.625em;
}

.form_content #form_left .btn {
    width: 29rem;
    padding: 1.9rem;
    max-width: 100%;
    border-radius: 10px;
    background-color: #fff;
    border: 2px solid #1f2774;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
    color: #1f2774;
    margin-top: 4.4rem;
}

.form_content #form_left .btn:hover {
    background-color: #1f2774;
    color: #fff;
}

.form_wrap {
    background-color: #F3F4FF;
    padding: 3.7rem 3.5rem 5rem 2.4rem;
}

.form_wrap input[type="text"],
.form_wrap input[type="email"],
.form_wrap input[type="tel"],
.form_wrap textarea {
    width: 100%;
    line-height: 1.5;
    padding: 1rem 1.5rem;
    background-color: #fff;
    border: none;
    vertical-align: middle;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-size: 1.6rem;
}

.form_wrap input.wpcf7-not-valid[type="text"],
.form_wrap input.wpcf7-not-valid[type="email"],
.form_wrap input.wpcf7-not-valid[type="tel"] {
    border: 1px solid #ac1d28;
}

.form_wrap .table_contact .item:not(:last-child) {
    padding-bottom: 2rem;
    border-bottom: 1px solid #aeb5f3;
    margin-bottom: 1.6rem;
}

.form_wrap .table_contact dt {
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.form_wrap .table_contact dt.required:after {
    content: "\5FC5\9808";
    font-size: 0.833em;
    font-weight: 400;
    color: #ac1d28;
    display: inline-block;
    padding: .4rem .7rem;
    border: 1px solid #ac1d28;
    margin-left: 1.5rem;
}

.form_wrap .table_contact .wpcf7-form-control-wrap+.wpcf7-form-control-wrap {
    display: inline-block;
    margin-top: 1rem;
}

.form_wrap .wpcf7-form-control.wpcf7-radio,
.form_wrap .wpcf7-form-control.wpcf7-checkbox {
    display: flex;
    flex-wrap: wrap;
    row-gap: 1.5rem;
    column-gap: 2rem;
    padding-left: 2rem;
}

.form_wrap .wpcf7-form-control.wpcf7-radio .wpcf7-list-item,
.form_wrap .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item {
    margin: 0;
    font-weight: 700;
}

.form_wrap .wpcf7-form-control.wpcf7-radio .wpcf7-list-item label,
.form_wrap .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label {
    display: flex;
    align-items: center;
}

.form_wrap .wpcf7-form-control.wpcf7-radio input,
.form_wrap .wpcf7-form-control.wpcf7-checkbox input {
    transform: scale(1.2);
    margin-right: .5rem;
    margin-top: .2rem;
}

.form_wrap .p-postal-code[name="address-zip1-1"],
.form_wrap .p-postal-code[name="address-zip2-1"] {
    width: 10rem;
}

.form_wrap .p-postal-code[name="address-zip1-2"],
.form_wrap .p-postal-code[name="address-zip2-2"] {
    width: 13rem;
    margin-right: 2rem;
}

.form_wrap .address_yubin .hyphen {
    display: inline-block;
    margin: 0 1rem;
}

.form_wrap .address_yubin {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    row-gap: 1rem;
}

.form_wrap .address_yubin .wpcf7-not-valid-tip {
    display: none;
}

.form_wrap .address_yubin .postal-search {
    font-size: 1.4rem;
    font-weight: 700;
    color: #1f2774;
    background-color: #f3f4ff;
    border: 2px solid #1f2774;
    border-radius: 100px;
    padding: 1.2rem 2.6rem;
    cursor: pointer;
    transition: .2s;
}

.form_wrap .address_yubin .postal-search:hover {
    background-color: #1f2774;
    color: #fff;
}

.form_wrap .address_region {
    margin-bottom: 1.5rem;
}

.form_wrap .address_region .select_arrow {
    display: inline-block;
    position: relative;
}

.form_wrap .address_region .select_arrow:after {
    content: "";
    position: absolute;
    top: calc(50% - .5rem);
    right: 1.6rem;
    z-index: +1;
    width: 0;
    height: 0;
    border-style :solid;
    border-width: 1rem .7rem 0 .7rem;
    border-color: #004CB3 transparent transparent transparent;
}

.form_wrap .address_region select {
    width: 26.6rem;
    height: 4.4rem;
    padding: 0 1.5rem;
    border: none;
    font-size: 1.6rem;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.form_wrap dl {
    margin-bottom: 5rem;
}

.form_wrap .policy_consent {
    text-align: center;
}

.form_wrap .policy_consent .wpcf7-list-item {
    display: block;
    width: 100%;
    margin: 1.5rem 0 0;
    font-weight: 700;
}

.form_wrap .policy_consent .wpcf7-list-item input {
    transform: scale(1.5);
    margin-right: .5rem;
}

.form_wrap .submit_btn {
    margin-top: 4rem;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    row-gap: 2rem;
    column-gap: 2rem;
}

.form_wrap .submit_btn .back_button {
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
    color: #fff;
    width: 20rem;
    max-width: 100%;
    border-radius: 100px;
    padding: 2rem 1rem;
    background-color: #9c9c9c;
    border: 2px solid #9c9c9c;
    transition: .3s;
    cursor: pointer;
}

.form_wrap .submit_btn .back_button:hover {
    background-color: #f3f4ff;
    color: #9c9c9c;
}

.form_wrap .submit_btn .confirm_button {
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
    color: #fff;
    width: 20rem;
    max-width: 100%;
    border-radius: 100px;
    padding: 2rem 1rem;
    background-color: #ac1d28;
    border: 2px solid #ac1d28;
    transition: .3s;
    cursor: pointer;
}

.form_wrap .submit_btn .confirm_button:hover {
    background-color: #f3f4ff;
    color: #ac1d28;
}

/*確認ボタン*/
.form_wrap .submit_btn #confirm-btn {
    width: 40rem;
    padding: 2.9rem 1rem;
}

.form_wrap .submit_btn #confirm-btn:disabled {
    color: #fff;
    background-color: #9c9c9c;
    border-color: #9c9c9c;
    cursor: initial;
}

.form_wrap .radio_text {
    margin: 1rem 0;
    padding-left: 2rem;
}

.form_wrap .radio_text:last-child {
    margin-bottom: 0;
}

.form_wrap dd>p:not(:first-child) {
    margin-top: .5rem;
}

.form_wrap h2.hl {
    font-size: 2.4rem;
    margin-bottom: 2rem;
    color: #1f2774;
    text-align: center;
}

@media (max-width: 767px) {
    .form_content {
        row-gap: 4rem;
    }

    .form_content #form_left {
        width: 100%;
    }

    .form_content #form_left+div {
        width: 100%;
    }

    .form_content #form_left .btn {
        width: 100%;
    }

    .form_content #form_left h1.hl {
        font-size: 2.6rem;
    }

    .form_content #form_left h2.lead {
        font-size: 2rem;
        margin-top: 5rem;
    }

    .form_wrap {
        padding: 3rem 2rem 4rem;
    }

    .form_wrap .p-postal-code[name="address-zip1-1"],
    .form_wrap .p-postal-code[name="address-zip2-1"] {
        width: 8rem;
    }

    .form_wrap .p-postal-code[name="address-zip1-2"],
    .form_wrap .p-postal-code[name="address-zip2-2"] {
        width: 10rem;
    }
}



#toc_fixed {
    position: fixed;
    right: 4rem;
    bottom: 4rem;
    background-color: #1f2774;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 500;
    width: 7rem;
    height: 7rem;
    text-align: center;
    border-radius: 50%;
    padding: 3.4rem 0 0;
    z-index: 100;
}

#toc_fixed:before,
#toc_fixed:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 2.4rem;
    height: 3px;
    background-color: #fff;
}

#toc_fixed:before {
    top: 1.9rem;
}

#toc_fixed:after {
    top: 2.7rem;
}

#toc_fixed:hover {
    background-color: #ac1d28;
}

@media (max-width: 767px) {
    #toc_fixed {
        right: 2rem;
        bottom: 2rem;
    }
}