@charset "utf-8";

[data-type="kaisya"] {
    --type-color: var(--color-kaisya);
}
[data-type="hito"] {
    --type-color: var(--color-hito);
}
[data-type="monokoto"] {
    --type-color: var(--color-monokoto);
}
[data-type="kizuna"] {
    --type-color: var(--color-kizuna);
}
[data-type="topics"] {
    --type-color: var(--color-topics);
}

/* page */
.search_wrap {
    color: #000;
}
.search_input_box {
    width:100%;
    background:#fff;
    border-radius: 9999px;
}
.search_input_box {
    display: flex;
}
.search_input_box_input_cover {
    flex:1;
}
.search_input_box_btn {
    border-radius:9999px;
    background: #B3B3B3;
    display: flex;
    justify-content: center;
    align-items: center;
}
.icon_search {
    height: auto;
}
.search_input_box_input {
    width: 100%;
    height: 100%;
    border-radius: 9999px 0 0 9999px;
    border: none;
    font-weight: 700;
    outline: none;
}
.search_input_box_input::placeholder {
    color:#CCC;
}
.search_category_list {
    flex-wrap: wrap;
    display: flex;
    justify-content: center;
}
.search_category_item_btn {
    border:2px solid var(--type-color);
    display: block;
    font-weight: 700;
    font-feature-settings: normal;
    border-radius: 9999px;
    color: var(--type-color);
    background-color: #fff;
    text-decoration: none;
}
.search_category_item_btn.is_selected {
    color: #fff;
    background-color: var(--type-color);
}
.search_sub_category_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.search_sub_category_item_btn {
    display: block;
    font-weight: 700;
    font-feature-settings: normal;
    border-radius: 9999px;
    color: #B3B3B3;
    background-color: #fff;
    cursor: pointer;
    text-decoration: none;
}
.search_sub_category_item_btn.is_selected {
    color: #fff;
    background-color: #333;
}
.filter_box {
    display: flex;
    align-items: center;
    padding:0;
    border: none;
}
.filter_box_txt {
    font-weight: 700;
    line-height: 125%;
    letter-spacing: 0;
    text-align: center;
}
.filter_box_input > input {
    text-align: center;
    width: 100%;
    border-radius: 4px;
    background:#fff;
    border:none;
    font-weight: 700;
    line-height: 125%;
    letter-spacing: 0;
}
.filter_box_input > input::placeholder {
    color: #B3B3B3;
}
.filter_box_input_txt {
    font-weight: 700;
    line-height: 125%;
    letter-spacing: 0;
    text-align: center;
}
.filter_box_btn {
    display:flex;
    justify-content: center;
    align-items: center;
    border-radius: 9999px;
    border:none;
    background:#333;
    color:#fff;
    font-weight: 700;
    line-height: 125%;
    letter-spacing: 0;
    text-align: center;
}
.search_bottom_wrap {
    display: flex;
    justify-content: space-between;
}
.sort_btn {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 9999px;
    border: none;
    background: #333;
    color: #fff;
    font-weight: 700;
    line-height: 125%;
    letter-spacing: 0;
    text-align: center;
    text-decoration: none;
}
.sort_btn_old {
    display: none;
}
.sort_btn.old .sort_btn_new {
    display: none;
}
.sort_btn.old .sort_btn_old {
    display: block;
}
@media (min-width: 641px) {
    .search_wrap {
        padding: 64rem 24rem;
    }
    .search_ttl {
        font-size: 40rem;
        text-align: center;
    }
    .search_input_box_wrap {
        margin-top: 24rem;
    }
    .search_input_box {
        height: 60rem;
    }
    .search_input_box_btn {
        width: 95rem;
        height:60rem;
        border: 4rem solid #fff;
    }
    .icon_search {
        width: 28rem;
    }
    .search_input_box_input {
        font-size: 24rem;
        padding-inline: 40rem;
    }
    .search_category_list_wrap {
        margin-top: 38rem;
    }
    .search_category_list {
        gap: 16rem;
    }
    .search_category_item_btn {
        padding: 8rem 32rem;
        font-size: 20rem;
        line-height:1.25;
    }
    .search_sub_category_list_wrap {
        margin-top: 24rem;
    }
    .search_sub_category_list {
        gap: 16rem;
    }
    .search_sub_category_item_btn {
        padding: 8rem 32rem;
        font-size: 16rem;
        line-height:1.25;
    }
    .filter_box {
        gap: 12rem;
    }
    .filter_box_txt {
        font-size: 16rem;
    }
    .filter_box_input {
        width: 76rem;
    }
    .filter_box_input > input {
        height: 32rem;
        font-size: 14rem;
        padding-inline: 10rem;
    }
    .filter_box_input_txt {
        font-size: 16rem;
        margin-inline: -4rem;
    }
    .filter_box_btn_cover {
        width: 272rem;
    }
    .filter_box_btn {
        width: 104rem;
        height:32rem;
        font-size: 14rem;
    }
    .search_bottom_wrap {
        margin-top: 40rem;
    }
    .sort_btn {
        width: 122rem;
        height: 32rem;
        font-size: 14rem;
    }
    .sort_btn_arrow {
        margin-left: 5rem;
    }
}
@media (max-width: 640px) {
    .search_wrap {
        padding: 32rem 21rem 40rem;
    }
    .search_ttl {
        font-size: 24rem;
        text-align: left;
    }
    .search_input_box_wrap {
        margin-top: 24rem;
    }
    .search_input_box {
        height: 60rem;
    }
    .search_input_box_btn {
        width: 81rem;
        height:60rem;
        border: 4rem solid #fff;
    }
    .icon_search {
        width: 22rem;
    }
    .search_input_box_input {
        font-size: 24rem;
        padding-inline: 29rem;
    }
    .search_category_list_wrap {
        margin-top: 38rem;
    }
    .search_category_list {
        gap: 8rem;
    }
    .search_category_item_btn {
        padding: 8rem 32rem;
        font-size: 14rem;
        line-height: 1.25;
    }
    .search_sub_category_list_wrap {
        margin-top: 16rem;
    }
    .search_sub_category_list {
        gap: 8rem;
    }
    .search_sub_category_item_btn {
        padding: 4rem 16rem;
        font-size: 14rem;
        line-height:1.25;
    }
    .filter_box {
        gap: 10rem;
        justify-content: space-between;
    }
    .filter_box_txt {
        font-size: 14rem;
    }
    .filter_box_input {
        width: 66rem;
    }
    .filter_box_input > input {
        height: 28rem;
        font-size: 12rem;
        padding-inline: 10rem;
    }
    .filter_box_input_txt {
        font-size: 14rem;
        margin-inline: -4rem;
    }
    .filter_box_btn {
        width: 91rem;
        height: 28rem;
        font-size: 12rem;
    }
    .search_bottom_wrap {
        margin-top: 56rem;
        flex-direction: column;
        gap: 16rem;
    }
    .sort_btn_wrap {
        align-self: end;
    }
    .sort_btn {
        width: 102rem;
        height: 28rem;
        font-size: 12rem;
    }
    .sort_btn_arrow {
        margin-left: 5rem;
    }
}

/* article_list */
.article_list,
.article_list > li {
	border-image-slice: 33%;
	border-image-repeat: repeat;
}
.kaisya .article_list_link {
    background-color: var(--color-kaisya);
}
.hito .article_list_link {
    background-color: var(--color-hito);
}
.monokoto .article_list_link {
    background-color: var(--color-monokoto);
}
.kizuna .article_list_link {
    background-color: var(--color-kizuna);
}
.topics .article_list_link {
    background-color: var(--color-topics);
}
.article_list_link {
    text-decoration: none;
    color: #fff;
    display: block;
    position: relative;
    z-index: 10;
}
.article_list_link.new::after {
    content: 'NEW';
    font-weight: 700;
    line-height: 1;
    color: #ffff00;
    background-color: var(--color-kaisya);
    position: absolute;
}
.article_list_img_wrap {
    border: 2px solid #fff;
}
.article_list_img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.article_list_category_wrap {
    display: none;
    gap: 8rem;
}
.article_list_category,
.article_list_category_sub {
    font-weight: 700;
    line-height: 1.7;
    letter-spacing: 0.04em;
    border: 1px solid #fff;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}
.article_list_category_sub {
    background-color: #fff;
}
.kaisya .article_list_category_sub {
    color: var(--color-kaisya);
}
.hito .article_list_category_sub {
    color: var(--color-hito);
}
.monokoto .article_list_category_sub {
    color: var(--color-monokoto);
}
.kizuna .article_list_category_sub {
    color: var(--color-kizuna);
}
.topics .article_list_category_sub {
    color: var(--color-topics);
}
.article_list_first .article_list_category_wrap {
    display: flex;
}
.article_list_ttl {
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: 0.08em;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
}
.article_list_first .article_list_ttl {
    line-height: 1.5;
}
.article_list_txt {
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: 0.04em;
    display: none;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}
.article_list_first .article_list_txt {
    display: -webkit-box;
}
.article_list_date {
    font-weight: 500;
}
.article_list_tag {
    font-weight: 500;
    display: none;
}
.article_list_first .article_list_tag {
    display: flex;
    flex-wrap: wrap;
}
.article_list_tag > li::before {
    content: '#';
    margin-right: 0.1em;
}


.article_list > li {
    position: relative;
}
/* 初期表示数 */
.article_list > li:nth-child(n + 19) {
    display: none;
}
.article_list > li::before {
    content: '';
    background: no-repeat 50% / cover;
    display: block;
    position: absolute;
}
.category {
	border-image-slice: 33%;
	border-image-repeat: repeat;
}
.article_list_first .article_list_category_wrap {
    display: flex;
}
@media (min-width: 641px) {
    .article_list > li {
        border-image-source: url(../img/common/line_pc.svg);
        border-image-width: 32rem 32rem 0 0;
    }
    .article_list > li:nth-child(3n) {
        border-image-width: 32rem 0 0 0;
    }

    .article_list > li::before {
        width: 200rem;
        height: 200rem;
        background-image: url(../img/common/article_list_dec.png);
        top: -100rem;
        left: -100rem;
    }

    .article_list > li:is(:nth-child(18n + 1), :nth-child(18n + 2), :nth-child(18n + 3))::before {
        content: none;
    }

    .article_list > li:nth-child(3n + 4)::before {
        background-image: url(../img/common/article_list_dec_l.png);
    }
    .article_list > li:nth-child(3n + 6):not(:nth-child(18n + 3))::after {
        content: '';
        width: 200rem;
        height: 200rem;
        background: url(../img/common/article_list_dec_r.png) no-repeat 50% / cover;
        display: block;
        position: absolute;
        top: -100rem;
        right: -100rem;
    }
    .article_list_dummy {
        background: url(../img/common/article_list_item_1.svg) no-repeat 50% / 378rem;
    }
    .article_list_dummy + .article_list_dummy {
        background-image: url(../img/common/article_list_item_2.svg);
    }
    .article_list {
        display: flex;
        flex-wrap: wrap;
        border-image-source: url(../img/common/line_pc.svg);
        border-image-width: 0 0 32rem 0;
    }
    .article_list > li {
        width: calc(100% / 3);
        padding: 24rem;
    }
    .article_list_link {
        min-height: 316rem;
        padding: 16rem;
        border-radius: 16rem;
    }
    .article_list_link.new::after {
        padding: 2rem 6rem 4rem 6rem;
        font-size: 24rem;
        border: 2px solid #fff;
        top: 8rem;
        left: 8rem;
    }
    .article_list_img_wrap {
        width: 346rem;
        height: 195rem;
        overflow: hidden;
    }
    .article_list_ttl {
        margin-top: 16rem;
        font-size: 16rem;
        -webkit-line-clamp: 2;
    }
    .article_list_first .article_list_ttl {
        -webkit-line-clamp: 3;
    }
    .article_list_date {
        margin-top: 16rem;
        font-size: 12rem;
    }

    .article_list > li.article_list_first {
        width: 100%;
    }
    .article_list_first .article_list_link {
        display: flex;
    }
    .article_list_first .article_list_img_wrap {
        width: 813rem;
        height: 453rem;
    }
    .article_list_first .article_list_inner {
        width: 387rem;
        padding: 40rem 24rem 40rem 36rem;
    }
    .article_list_category,
    .article_list_category_sub {
        padding: 4rem 8rem;
        font-size: 12rem;
        border-radius: 4rem;
    }
    .article_list_first .article_list_ttl {
        margin-top: 24rem;
        font-size: 24rem;
    }
    .article_list_txt {
        margin-top: 4rem;
        font-size: 14rem;
    }
    .article_list_first .article_list_date {
        margin-top: 24rem;
        font-size: 14rem;
    }
    .article_list_tag {
        margin-top: 8rem;
        font-size: 12rem;
        gap: 8rem;
    }

    .category {
        border-image-source: url(../img/common/line_pc.svg);
        border-image-width: 32rem 0 0;
    }
    .article_list_category_wrap {
        display: none;
        gap: 8rem;
    }
}
@media (max-width: 640px) {
    .article_list > li {
        padding: 16rem;
        border-image-source: url(../img/common/line_sp.svg);
        border-image-width: 16rem 0 0;
    }
    .article_list > li:not(:nth-child(18n + 1)):before {
        width: 200rem;
        height: 200rem;
        background: url(../img/common/article_list_dec_sp.png) no-repeat 50% / cover;
        top: -100rem;
    }
    .article_list > li + li:nth-child(odd):before {
        left: -100rem;
    }
    .article_list > li + li:nth-child(even):before {
        right: -100rem;
    }
    .article_list > li:nth-child(1):before,
    .article_list > li:nth-child(18n + 14):before {
        content: none;
    }
    .article_list_link {
        min-height: 286rem;
        padding: 16rem;
        border-radius: 16rem;
    }
    .article_list_link.new::after {
        padding: 1rem 4rem 2rem 4rem;
        font-size: 14rem;
        border: 1px solid #fff;
        top: 8rem;
        left: 8rem;
    }
    .article_list_img_wrap {
        width: 312rem;
        height: 165rem;
    }
    .article_list_ttl {
        margin-top: 16rem;
        font-size: 16rem;
        -webkit-line-clamp: 2;
    }
    .article_list_date {
        margin-top: 16rem;
        font-size: 12rem;
    }

    .article_list_category,
    .article_list_category_sub {
        margin-top: 16rem;
        padding: 2rem 8rem;
        font-size: 12rem;
        border-radius: 4rem;
    }
    .article_list_first .article_list_ttl {
        margin-top: 20rem;
        font-size: 18rem;
    }
    .article_list_txt {
        margin-top: 4rem;
        font-size: 14rem;
    }
    .article_list_first .article_list_date {
        margin-top: 18rem;
        font-size: 14rem;
    }
    .article_list_tag {
        margin-top: 16rem;
        font-size: 10rem;
        gap: 8rem;
    }

    .category {
        border-image-slice: 33%;
        border-image-repeat: repeat;
        border-image-source: url(../img/common/line_sp.svg);
        border-image-width: 16rem 0 0;
    }
}
@media (min-width: 641px) {
    @media (hover:hover) {
        a.article_list_link:hover {
            opacity: 1;
        }
        .article_list_img {
            transition: scale 0.5s;
        }
        .article_list_link:hover .article_list_img {
            scale: 1.1;
        }
        .article_list_inner {
            transition: opacity 0.5s;
        }
        .article_list_link:hover .article_list_inner {
            opacity: 0.7;
        }
    }
}

/* paginator */
.paginator_list {
    display: flex;
    align-items: center;
    justify-content: center;
}
.paginator_list > li.is_hide {
    visibility: hidden;
}
.paginator_list > li.active {
    pointer-events: none;
}
.paginator_list > li.active .paginator_list_link {
    background-color: #E60012;
}
.paginator_list_link {
    text-decoration: none;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 50%;
    background-color: #ccc;
    display: flex;
    align-items: center;
    justify-content: center;
}
.paginator_list_arrow {
    display: block;
}
.paginator_list_arrow_prev {
    rotate: 180deg;
}
.paginator_list_arrow_svg {
    fill: #E60012;
}
@media (min-width: 641px) {
    .paginator_list {
        gap: 16rem;
        padding-block: 24rem;
    }
    .paginator_list_link {
        width: 40rem;
        height: 40rem;
        font-size: 14rem;
    }
    .paginator_list_arrow_svg {
        width: 18rem;
    }
}
@media (max-width: 640px) {
    .paginator_list {
        gap: 8rem;
        border-image-slice: 33%;
        border-image-repeat: repeat;
        border-image-source: url(../img/common/line_sp.svg);
        border-image-width: 16rem 0 0;
        padding-block: 16rem;
    }
    .paginator_list_link {
        width: 40rem;
        height: 40rem;
        font-size: 14rem;
    }
    .paginator_list_arrow_svg {
        width: 18rem;
        padding: 11rem 10rem;
        box-sizing: content-box;
    }
}
@media (min-width: 641px) {
    @media (hover:hover) {
        a.paginator_list_link {
            transition: background-color 0.5s;
        }
        a.paginator_list_link:hover {
            opacity: 1;
        }
        .kaisya .paginator_list_link:hover {
            background-color: var(--color-kaisya);
        }
        .hito .paginator_list_link:hover {
            background-color: var(--color-hito);
        }
        .monokoto .paginator_list_link:hover {
            background-color: var(--color-monokoto);
        }
        .kizuna .paginator_list_link:hover {
            background-color: var(--color-kizuna);
        }
        .topics .paginator_list_link:hover {
            background-color: var(--color-topics);
        }

        .paginator_list_arrow_path,
        .paginator_list_arrow_over path {
            transition: fill 0.5s;
        }
        a.paginator_list_arrow:hover,
        a.paginator_list_arrow_over:hover {
            opacity: 1;
        }
        .paginator_list_arrow:hover .paginator_list_arrow_path,
        .paginator_list_arrow_over:hover path {
            fill: #ccc;
        }
    }
}
.article_list_link {
    background-color: var(--type-color);
}
.kaisya {
    --type-color: var(--color-kaisya);
}
.hito {
    --type-color: var(--color-hito);
}
.monokoto {
    --type-color: var(--color-monokoto);
}
.kizuna {
    --type-color: var(--color-kizuna);
}
.topics {
    --type-color: var(--color-topics);
}