*,
*::before,
*::after{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

a{
    text-decoration: none;
}

img{
    vertical-align: bottom;
}

ul{
    list-style: none;
}

p{
    line-height: 1.75;
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    font-size: 16px;
}

h2{
    font-size: 36px;
}

h3{
    font-size: 30px;
}

main{
    overflow: hidden;
}

.text_wbr{
    word-break: keep-all;
    /* overflow-wrap: anywhere; */
    overflow-wrap: break-word;
}

.desktop_br_prohibit{
    display: none;    
}

.mobile_br_prohibit{
    display: initial;
}

.num_wbr{
    display: inline-block;
}

.wrapper1{
    width: 85vw;
    max-width: 920px;
    margin: auto;
}

.wrapper2{
    width: 85vw;
    /* max-width: 1560px; */
    max-width: 1320px; /*20240920変更*/
    margin: auto;
}

.wrapper3{
    width: 85vw;
    max-width: 1450px;
    margin: auto;
}

.wrapper4{
    width: 85vw;
    max-width: 1500px;
    margin: auto;
}

.wrapper5{
    width: 95vw;
    max-width: 920px;
    margin: auto;
}

@font-face {
    font-family: "NotoSerifJP";
    src: url("../font/NotoSerifJP-VariableFont_wght.ttf") format("truetype");
}

:root{
    /* 100vwからスクロールバーを除外した幅の変数(javascript使用) */
    --iw: calc(100vw - var(--scrollbar-width));
}

/*------------------ ヘッダー↓ ------------------*/


.header_wrap{
    position: relative;
    display: flex;
    width: 100%;
    height: 78px;
    left: 50%;
    transform: translateX(-50%);
    overflow: hidden;
}

.header_wrap h2{
    position: relative;
    display: flex;
    width: 45%;
    height: 100%;
    transform: skewX(56deg);
    background-color: #FFF;
    align-items: end;
}
.header_wrap h2::after{
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 16px;
    z-index: 1;
    top: 0;
    left: 0;
    background-color: #D2AF3A;;
}

.header_wrap h2 img{
    width: 100%;
    max-width: 320px;
    height: auto;
    padding-bottom: 10px;
    object-fit: contain;
    transform: skewX(-56deg);
}

.header_link_outer{
    width: 55%;
    height: 100%;
    transform: skewX(56deg);
}

.header_link_wrap{
    position: relative;
    display: flex;
    width: 100%;
    height: 35px;
    margin-top: 23px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: end;
}
.header_link_wrap::after{
    position: absolute;
    display: block;
    content: "";
    width: 120%;
    height: 100%;
    z-index: -1;
    top: 0;
    left: 0;
    background-color: #000;
}

.header_link_wrap li{
    height: 100%;
    transform: skewX(-56deg);
}

.header_link_wrap li:last-of-type{
    background-color: #D2AF3A;
}

.header_link_wrap a{
    display: flex;
    height: 100%;
    color: #FFF;
    padding: 0 clamp(6px, 0.95vw + max((100vw - 1200px) * 10000, 0px), 1.66vw);
    align-items: center;
    transition: padding-bottom 0.3s ease;
}

.header_hamburger_button{
    display: none;
}
/*------------------ ヘッダー↑ ------------------*/

/*-------------------- 共有部品↓ --------------------*/

/*---------- サブページタイトル↓ ----------*/
.subpage_title{
    width: 100%;
    aspect-ratio: 1920 / 200;
}

.subpage_title + *{
    /* padding-top: min(calc(100vw * (120 / 1920)), 120px); */
    padding-top: clamp(60px, 100vw * (120 / 1920), 120px)
}

.subpage_title_wrap{
    position: relative;
    width: 100%;
    height: 100%;
    /* aspect-ratio: 1920 / 200; */
}

.subpage_title::before{
    display: block;
    content: "";
}

.subpage_engtitle_wrap,
.subpage_japtitle_wrap{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}
.subpage_japtitle_wrap{
    display: flex;
    justify-content: end;
    align-items: center;
}

.subpage_engtitle_wrap p{
    padding: 0.2em;
    font-size: min(100vw * (62.7 / 1920), 34px);
    opacity: 0.3;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}

.subpage_title_text{
    position: relative;
    width: fit-content;
    margin: auto 0 auto auto;
    padding-right: 5.1vw;
    font-size: max(calc(100vw * (48 / 1920)), 48px);
    text-align: end;
    letter-spacing: 0.2em;
}

.subpage_title_text::before{
    position: absolute;
    display: block;
    content: "";
    width: clamp(100vw * (825 / 1920), 100% + 1em, 100vw); 
    height: min(calc(var(--iw) * (10 / 1920)), 10px);
    top: 100%;
    right: 0;
    transform: skewX(59deg);
    transform-origin: top left;
    font-size: inherit;
    background-color: #000;
}

.subpage_pc_title{
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: -1;
    top: 0;
    left: 0;
    object-fit: cover;
    pointer-events: none;
}
.subpage_sp_title{
    position: absolute;
    display: none;
    width: 100%;
    height: 100%;
    z-index: -1;
    top: 0;
    left: 0;
    object-fit: cover;
    pointer-events: none;
}
/*---------- サブページタイトル↑ ----------*/

/*---------- ページ下部 お問い合わせ誘導ver2 ↓ ----------*/
#contact_info{
    margin-top: 200px;
}
#contact_info.top_contact_info{
    margin-top: 0;
}

.contact_info_wrap{
    height: auto;
    min-height: 607px;
}

.contact_info_content{
    display: flex;
    max-width: 1040px;
    margin: auto;
    padding-top: 100px;
    flex-direction: column;
    align-items: center;
}

.contact_info_content h2{
    position: relative;
    width: auto;
    margin: auto;
    text-align: center;
    font-family: "noto-sans-cjk-jp", sans-serif;
    color: #3E3A39;
    line-height: 1.5;
}

.contact_info_content h2::before{
    position: absolute;
    display: block;
    content: "";
    width: 100px;
    height: 70px;
    top: -20px;
    left: -110px;
    background-image: url("../images/contact_icon.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.contact_info_content p{
    width: 100%;
    padding-top: 1em;
    font-size: 21px;
    text-align: center;
    color: #3E3A39;
    border-top: solid 1px #3E3A39;
}

.contact_info_link{
    display: flex;
    width: 100%;
    margin-top: 40px;
}

.contact_info_link a:first-of-type{
    position: relative;
    display: flex;
    width: 50%;
    height: 363px;
    color: #3E3A39;
    transition: scale 0.2s ease-in-out;
    clip-path: polygon(44px 0, 100% 0, 100% 100%, 0 100%, 0 44px);
}

.contact_info_link a:last-of-type{
    position: relative;
    display: flex;
    width: calc(50% + 1px);
    height: 363px;
    color: #3E3A39;
    translate: -1px 0;
    transition: scale 0.2s ease-in-out;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 44px), calc(100% - 44px) 100%, 0 100%);
}

.contact_info_link .contact_info_background{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: scale 0.3s ease-in-out;
}

.contact_info_link .contact_link_wrap{
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    font-size: min(100vw * 38 / 500, 38px);
}

.contact_info_link .contact_info_text{
    display: flex;
    width: 340px;
    height: 70px;
    padding-left: 0.5em;
    background-color: #FFF;
    align-items: center
}

.contact_info_link a:first-of-type .contact_info_text{
    position: absolute;
    top: 10px;
    right: 10px;
}
.contact_info_link a:last-of-type .contact_info_text{
    position: absolute;
    top: 10px;
    left: 10px;
}

.contact_info_link a:first-of-type .contact_info_text img{
    height: 60%;
    object-fit: cover;
}
.contact_info_link a:last-of-type .contact_info_text img{
    height: 50%;
    object-fit: cover;
}

.contact_info_text p{
    display: flex;
    padding-left: 0.5em;
    align-items: center;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.15;
}
.contact_info_link a:first-of-type .contact_info_text span{
    padding-left: 0.5em;
    font-size: 14px;
}
.contact_info_link a:last-of-type .contact_info_text span{
    padding-left: 0.5em;
    font-size: 12px;
}

/*----- 下部バナー↓ -----*/
.create_banner_wrap{
    position: relative;
    display: none;
    width: 100%;
    margin-top: 80px;
}

.create_banner{
    width: 100%;
    /* height: 100%; */
    object-fit: cover;
}
.create_banner:last-of-type{
    display: none;
}

/*---------- ページ下部 お問い合わせ誘導ver2 ↑ ----------*/

/*---------- ページトップボタン↓ ----------*/
/* .page_top_button{
    display: flex;
    align-items: flex-end;
    z-index: 9999;
}

.page_top_button>p{
    font-size: 8px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    letter-spacing: 0;
    color: #000;
}

.page_top_arrow{
    position: relative;
    width: 47px;
    height: 47px;
    font-size: 30px;
    border-radius: 50%;
    color: #FFF;
    background-color: #000;
}

.page_top_arrow p{
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    font-size: 12px;
    font-weight: 700;
} */
/*---------- ページトップボタン↑ ----------*/


/*-------------------- 共有部品↑ --------------------*/











/*-------------------- トップページ↓ --------------------*/
/*---------- メインビュー↓ ----------*/
.mainview{
    position: relative;
    width: 100%;
}

.mainview_title_wrap{
    position: absolute;
    left: 60.7%;
}

.mainview_title_wrap h1{
    padding-top: 2em;
    font-size: calc(100vw * (52 / 1920));
    font-family: "NotoSerifJP", serif;
    letter-spacing: 0.1em;
    text-align: right;
}

.mainview_title_wrap h1 span{
    letter-spacing: -1em;
}

.mainview_about_wrap{
    position: absolute;
    display: flex;
    bottom: calc(100vw * (600 / 1920) * (15 / 600));
    left: 0.625vw;
    flex-wrap: wrap;
    align-items: center;
    gap: 1vw;
}

.mainview_about_wrap > div:first-of-type{
    display: flex;
    gap: 10px;
}

.mainview_about_wrap > div:first-of-type p:first-of-type{
    font-size: calc(100vw * (82 / 1920));
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}
.mainview_about_wrap > div:first-of-type p:nth-of-type(2){
    font-size: calc(100vw * (32 / 1920));
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    align-self: center;
}
.mainview_about_wrap p:last-of-type{
    position: relative;
    font-size: calc(100vw * (18 / 1920));
    font-family: "noto-sans-cjk-jp", sans-serif;
    line-height: 1.2;
}

.mainview_pc_img{
    width: 100%;
    pointer-events: none;
}
.mainview_sp_img{
    display: none;
    pointer-events: none;
}
/*---------- メインビュー↑ ----------*/
.top_content_wrap{
    position: relative;
}

/* .top_content_wrap::before,
#top_link::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    z-index: -9999;
    top: 0;
    left: 0;
    opacity: 0.61;
    background: url("../images/president_1.webp");
    background-size: cover;
    background-position: right;
    background-repeat: no-repeat;
    clip-path: polygon(min(20%, 384px) 0, 100% 0, 100% 100%, 0 100%);
}
#top_link::before{
    display: none;
    background-position: 80%;
    clip-path: initial;
} */

.top_background{
    position: absolute;
    display: block;
    width: 100vw;
    height: 100%;
    z-index: -9999;
    top: 0;
    left: 0;
    overflow: hidden;
    pointer-events: none;
}

.top_background .outer_image_wrap{
    width: 100%;
    height: 100%;
    opacity: 0.61;
    clip-path: polygon(min(20%, 384px) 0, 100% 0, 100% 100%, 0 100%);
    overflow: hidden;
}

.top_background .outer_image_wrap img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right;
}

#greeting{
    position: relative;
}

.greeting_wrap{
    margin-top: 32px;
    padding-top: 100px;
}

.greeting_background{
    position: relative;
    padding: 2em;
    background-color: #FFF;
}

.greeting_title_wrap{
    display: flex;
    margin-bottom: 1em;
    justify-content: space-between;
    align-items: end;
    border-bottom: solid 1px #000;
}

.greeting_title{
    position: relative;
    font-family: "NotoSerifJP", sans-serif;
    font-weight: bold;
    letter-spacing: 0.3em;
    line-height: 1.75;
}

.transparent_title_01{
    font-size: 68px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    color: #E6E6E6;
    line-height: 1;
}
.transparent_title_01 span{
    font-size: 137px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}

.greeting_text_wrap{
    position: relative;
}

.greeting_text_wrap p{
    font-size: 20px;
    font-family: "NotoSerifJP", sans-serif;
    font-weight: bold;
    letter-spacing: 0.1em;
}

.greeting_text_wrap p:nth-of-type(n+2){
    margin-top: 1.5em;
}

.greeting_text_wrap .ceo{
    display: flex;
    width: 100%;
    margin-top: 100px;
    justify-content: end;
}

.greeting_text_wrap .ceo p{
    display: inline-block;
    margin-left: auto;
    text-align: end;
}

.greeting_text_wrap .ceo p > span{
    font-size: 30px;
    font-family: ta-fuga-fude, sans-serif;
    font-weight: normal;
    line-height: 1.25;
    letter-spacing: 0.2em;
}

.greeting_text_wrap .ceo p > span > span{
    margin-right: 0.24em;
}

.greeting_text_wrap .ceo_img{
    position: absolute;
    display: flex;
    content: "";
    width: 368px;
    height: 100%;
    z-index: 1;
    left: 100%;
    bottom: 0;
    align-items: end;
}

.greeting_text_wrap .ceo_img img{
    width: 100%;
    max-width: 368px;
}

.inner_image_wrap{
    position: absolute;
    width: min(85vw - 300px, 500px);
    height: calc(min(85vw - 300px, 500px) * (622 / 1071));
    z-index: 1;
    top: calc(100% - 130px);/*100% - 100px - 1em*/
    left: min(100% - 11em - min(85vw - 300px, 500px), 0px);
    font-size: 30px;
}

.inner_image_wrap .inner_image{
    width: 100%;
    height: 100%;
    clip-path: polygon(calc((min(85vw - 300px, 500px) * (622 / 1071)) / tan(78deg)) 0, 100% 0, calc(100% - (min(85vw - 300px, 500px) * (622 / 1071)) / tan(78deg)) 100%, 0 100%);
}

.inner_image_wrap .inner_image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right;
}


@media screen and (max-width:1800px) {
    .greeting_text_wrap{
        display: flex;
        flex-wrap: wrap;
        padding-bottom: initial;
    }

    .greeting_text_wrap p{
        width: 100%;
        order: 1;
    }
    
    .greeting_text_wrap .ceo{
        order: 3;
    }

    .greeting_text_wrap .ceo_img{
        position: initial;
        width: calc(100% - max(30%, 10em));
        justify-content: center;
        order: 2;
    }
}

#top_link{
    position: relative;
    padding-top: calc(min(85vw - 300px, 500px) * (622 / 1071) - 60px);
}

#top_link > div{
    position: relative;
    padding-bottom: 40px;
}

#top_link .overline_h2_wrap{
    position: relative;
    width: 100vw;
    left: 50%;
    translate: -50% 0;
    overflow: hidden;
}

#top_link .overline_h2_wrap h2{
    position: relative;
    width: 95%;
    z-index: 2;
    margin-left: auto;
    padding-left: 2em;
    padding-bottom: 0.25em;
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-style: italic;
}

#top_link .overline_h2_wrap h2::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 0.5em;
    bottom: 0;
    left: 0;
    z-index: -10000;
    transform: skewX(-52deg);
    transform-origin: bottom;
    background-color: #FFF;
}

.top_link_list{
    display: grid;
    width: 100%;
    margin: 0 auto 35px;
    grid-template-columns: repeat(auto-fit, 700px);
    grid-auto-rows: 25px;
    grid-column-gap: 32px;
    justify-content: center;
}

.top_link_wrap{
    position: relative;
    display: flex;
    flex-direction: column;
}

.top_link_list > li {
    width: 100%;
    grid-row: span 9;
    margin-bottom: 25px;
}
.top_link_list > li.large_link{
    grid-row: span 15;
}

.top_link_list .top_links{
    position: relative;
    display: flex;
    width: 100%;
    height: 100%;
    border: solid 5px #b3b3b3;
}

.top_link_list .top_links::after{
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
    background: linear-gradient(90deg, transparent 130px, #000 180px, #000);
}

.top_link_list .top_link_image{
    width: 180px;
    height: 100%;
}

.top_link_list .top_link_image img{
    display: block;
    width: 180px;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.8);
    transition: filter 0.3s ease;
}

.top_link_list .link_content_wrap{
    display: flex;
    width: calc(100% - 180px);
    z-index: 2;
    flex-direction: column;
    color: #FFF;
}

.top_link_list .link_content_item{
    display: flex;
    width: 100%;
    height: 200px;
    justify-content: center;
}

.top_link_list .link_text_title{
    position: relative;
    width: 80%;
    margin-right: 50px;
}

.top_link_list .link_title_main,
.top_link_list .link_title_sub{
    display: flex;
    height: 50%;
}
.top_link_list .link_title_main{
    border-bottom: solid 1px #C0C0C0;
    align-items: end;
}

.top_link_list .link_title_main p{
    display: flex;
    padding-right: 0.5em;
    flex-wrap: wrap;
    align-items: center;
    font-size: 28px;
    font-weight: bold;
    letter-spacing: 0.2em;
    line-height: 1.5em;
}

.top_link_list .link_title_main p span:not(.arrow_icon){
    font-size: 0.5em;
    letter-spacing: 0.2em;
    line-height: 1.5;
    color: #808080;
}

.top_link_list .link_title_sub p{
    font-size: 16px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    color: #808080;
}

.top_link_list .link_content_item > object{
    flex: 1;
}

.top_link_list .top_other_links{
    display: flex;
    width: 100%;
    height: 100%;
    z-index: 1;
    flex-direction: column;
    align-items: center;
    color: #808080;
    font-weight: bold;
    gap: 10px 0;
}
.top_link_list .top_other_links.portfolio_link{
    width: 90%;
    margin: auto;
    flex-direction: initial;
}

.top_link_list .top_link_logo{
    height: 40px;
    object-fit: contain;
}

.top_link_list .top_other_wrap{
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px 0;
}

.top_link_list .top_other_links p{
    height: 3.5em;
    font-size: 12px;
}

.top_link_list .portfolio_view_wrap{
    display: flex;
    width: 100%;
    height: 100%;
    flex: 1;
    justify-content: right;
    align-items: center;
}

.top_link_list .portfolio_text_wrap{
    display: flex;
    justify-content: center;
    align-items: center;
}

.top_link_list .portfolio_text_wrap p{
    color: #FFF;
}


.top_link_list .portfolio_view{
    width: 80%;
    height: 80%;
    object-fit: cover;
}

.top_link_list .arrow_icon{
    width: 40px;
    height: 40px;
    border: solid 3px #FFF;
    border-radius: 50%;
}
.top_link_list .link_text_title .arrow_icon{
    position: absolute;
    top: 50%;
    left: calc(100% + 1em);
    font-size: 10px;
    translate: 0 -50%;
}
.top_link_list .top_other_links .arrow_icon{
    position: relative;
}
.top_link_list .arrow_icon::before{
    position: absolute;
    display: block;
    content: "";
    width: 45%;
    height: 3px;
    top: 50%;
    right: 30%;
    translate: 0 -50%;
    rotate: 35deg;
    transform-origin: bottom right;
    background-color: #FFF;
    border-radius: 0 2px 2px 0;
    transition: all 0.2s ease-in-out;
}
.top_link_list .arrow_icon::after{
    position: absolute;
    display: block;
    content: "";
    width: 45%;
    height: 3px;
    top: 50%;
    right: 30%;
    translate: 0 -50%;
    rotate: -35deg;
    transform-origin: top right;
    background-color: #FFF;
    border-radius: 0 2px 2px 0;
    transition: all 0.2s ease-in-out;
}
.top_link_list .top_links.active .arrow_icon:not(.other_link_arrow)::before{
    right: 30%;
    rotate: 35deg;
}
.top_link_list .top_links.active .arrow_icon:not(.other_link_arrow)::after{
    right: 30%;
    rotate: -35deg;
}


.top_link_list > li.border_title_position{
    position: relative;
    grid-row: span 1;
}

.transparent_title_02wrap{
    position: absolute;
    width: 100%;
    height: 1em;
    bottom: 0;
    margin: auto;
    font-size: 137px;
}

.transparent_title_02{
    position: absolute;
    width: calc(92.5vw - max((85vw - 1450px) * 0.5 ,0px));
    top: 0;
    left: 0;
    padding-right: 0.5em;
    opacity: 0.24;
    font-size: 68px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    color: #FFFFFF;
    line-height: 1;
    text-align: end;
}

.transparent_title_02 span{
    font-size: 137px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}

.transparent_title_02wrap .border_width{
    display: grid;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    grid-template-columns: repeat(auto-fill, 700px);
    grid-column-gap: 32px;
    justify-content: center;
}

.transparent_title_02wrap .border_position{
    position: relative;
    width: 100%;
}

.transparent_title_02wrap .border_position::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 10px;
    top: 100%;
    left: 0;
    opacity: 0.24;
    transform: skewX(59deg);
    transform-origin: top left;
    background-color: #FFFFFF;
}

/*-------------------- トップページ↑ --------------------*/



/*-------------------- 会社情報↓ --------------------*/
.company_background{
    position: relative;
    width: 100%;
    left: 50%;
    padding-bottom: 240px;
    translate: -50% 0;
    overflow: hidden;
}
.company_background::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    z-index: -3;
    top: 0;
    left: 0;
    background: url("../images/company_img.webp");
    background-size: max(100%, 1200px);
    background-position: bottom left;
    background-repeat: no-repeat;
}

.company_list{
    display: flex;
    flex-direction: column;
    gap: 32px 0;
}

.company_list > li{
    position: relative;
    display: flex;
    min-height: 64px;
    padding: 0.5em 0 0.5em 3em;
    align-items: center;
}
.company_list > li::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    top: 0;
    z-index: -1;
    background-color: inherit;
}
.company_list > li::after{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    transform: skewX(18deg);
    /* clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 50px 100%); */
    transform-origin: top;
    background-color: #E6E6E6;
}

.transparent_title_03{
    position: absolute;
    z-index: -2;
    bottom: calc(100vw * (135 / 1920));
    left: calc(100% * (1070 / 1920));
    opacity: 0.6;
    font-size: 68px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    color: #B0CBE5;
    line-height: 1;
}
.transparent_title_03 span{
    font-size: 137px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}

@media screen and (max-width:1200px) {
    .transparent_title_03{
        left: initial;
        right: 0.5em;
    }
}

.company_list > li .company_item_wrap{
    display: flex;
    width: 100%;
    align-items: baseline;
}

.company_list > li .company_item_wrap > *{
    font-weight: bold;
    line-height: 1.75;
}
.company_list > li .company_item_wrap > p:first-of-type{    /* 修正点_池田_20250825 */
    width: 7em;
    font-size: 20px;
    font-weight: 700;
    color: #000;
}
.company_list > li .company_item_wrap > *:not(p:first-of-type){    /* 修正点_池田_20250825 */
    width: calc(100% - 7em);
    font-size: 14px;
    font-weight: 600;
    color: #333;
}

.company_list > li .company_item_numlistbox{
    display: flex;
    gap: 0 0.5em;
    align-items: center;
}

.company_list > li .company_item_numlist{
    width: 100%;
    padding-left: 3em;
    list-style: decimal;
    list-style-position: inside;
}
/*-------------------- 会社情報↑ --------------------*/



/*-------------------- 事業内容↓ --------------------*/
.service_beegle{
    font-family: 'Noto Sans JP', sans-serif;
    overflow: hidden;
}

.service_background{
    position: fixed;
    z-index: -9999;
    width: 50%;
    top: 0;
    right: 5%;
}

.service_section_title{
    font-family: 'Noto Sans JP', sans-serif;
}
.service_section_title.section_rela_title{
    margin-top: 101px;
}

.service_section_title h2{
    position: relative;
    display: flex;
    width: 100%;
    height: 90px;
    margin-left: auto;
    transform: skewX(-20deg);
    font-size: 36px;
    font-weight: bold;
    text-align: end;
    background-color: #D2AF3A;
    justify-content: end;
    align-items: end;
}

.service_section_title h2 > *{
    transform: skewX(20deg);
}

.service_section_title h2::after{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    z-index: -1;
    top: 0;
    left: calc(100% - 1px);
    background-color: #D2AF3A;
}

.service_section_title .section_title{
    position: relative;
    display: flex;
    width: 100%;
    padding-left: 30px;
    padding-right: 30px;
    align-self: center;
}

.service_section_title .section_title .rela_title_small{
    font-size: 0.75em;
}

.service_section_title .section_number{
    width: 123px;
}



.service_beegle_hp{
    position: relative;
    width: 100%;
    max-width: 1560px;
    height: auto;
    min-height: 227px;
    margin-top: 127px;
    display: flex;
    justify-content: space-between;
    overflow: hidden;
}

.service_beegle_hp:nth-of-type(2){
    margin-top: 100px;
}

.service_beegle_box{
    position: relative;
    display: flex;
    width: 50%;
    flex-direction: column;
    justify-content: space-between;
}

.service_beegle_text p{
    font-family: 'Yu Gothic';
    padding-top: 38px;
}
.service_beegle_text p:first-of-type{
    font-weight: bold;
}

.service_beegle_text{
    padding-bottom: 1em;
}

.service_beegle_hp .service_beegle_bigtext{
    position: absolute;
    z-index: 1;
    bottom: 0;
    right: calc(341px + 1em);
    font-size: min(8.54vw, 49px); /*20240920変更*/
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1.2;
    white-space: nowrap;
    text-align: right;
    color: #B3B3B3;
    filter: drop-shadow(0 0 6px #FFF)
}

.service_beegle_hp .service_beegle_bigtext.semi_small{
    font-size: min(8.54vw, 36px); /*20240920変更*/
    line-height: 1.5;
}

.service_beegle_figure{
    position: relative;
    display: flex;
    width: 50%;
    top: 0;
    right: 0;
    justify-content: right;
    align-items: end;
}

.service_beegle_figure::before{
    position: absolute;
    content: "";
    width: 100vw;
    height: 1px;
    z-index: -1;
    top: calc(100% - 1px);
    right: 0;
    background-color: #000;
}

.service_beegle_figure div{
    position: absolute;
    width: 341px;
    height: 227px;
    right: 0;
    bottom: 0;
    transform: skewX(25deg);
    transform-origin: bottom right;
    overflow: hidden;
}

.service_beegle_figure div img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: skewX(-25deg) scale(1.5);
}

.other_service_title{
    position: relative;
    display: flex;
    width: 100%;
    padding-top: 200px;
    justify-content: center;
}

.other_service_title h3{
    position: relative;
    width: fit-content;
    font-size: 36px; /*20240920変更*/
}


.transparent_title_04_wrap{
    position: absolute;
    width: var(--iw);
    z-index: -9999;
    left: 50%;
    translate: -50%;
}

.transparent_title_04{
    position: absolute;
    display: flex;
    bottom: 10px;
    left: 1%;
    opacity: 0.6;
    align-items: end;
    writing-mode: vertical-rl;
    vertical-align: bottom;
    font-size: 68px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    color: #E6E6E6;
    line-height: 1;
}
.transparent_title_04 span{
    padding-bottom: 10px;
    font-size: 137px;
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
    line-height: 1;
}

.other_service_title h3::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 100%;
    z-index: -9999;
    top: 0;
    right: 0;
    border-bottom: 1px solid #000;;
}

/*20250908変更*/
.other_list,
.other_list_item:not(:first-of-type){
    margin-top: 124px;
}

.other_list_item{
    display: flex;
    flex-direction: column;
    gap: 60px;
}

.other_list_name{
    display: flex;
    width: 100%;
    max-width: 1227px;
    justify-content: end;
}

.other_list_link{
    width: 80%;
    margin: auto;
    transition: scale 0.3s ease-in-out;
}

.other_list_link a{
    display: flex;
    width: 100%;
}
/*------------*/



.other_list_text{
    position: relative;
    display: flex;
    width: calc(100% - 382px);
    /* padding-left: 2.5em; 20241009変更 */
    flex-direction: column;
    overflow: hidden;
}
.other_list_text::before{
    position: absolute;
    content: "";
    width: 100vw;
    height: 1px;
    z-index: 1;
    top: calc(100% - 1px);
    right: calc(218px / tan(73deg));
    background-color: #000;
}

.other_list_text > p{
    position: relative;
    padding-left: 1.2em;
    padding-right: calc(218px / tan(73deg));
    font-size: 30px;
    text-align: start;
    font-weight: bold;
}

.other_list_text > p::before{
    position: absolute;
    content: '●';
    top: 0;
    left: 0;
}

.other_list_figure{
    position: relative;
    width: 382px;
    height: 218px;
    overflow: hidden;
    transform: skewX(-17deg);
    transform-origin: top right;
    align-self: end;
}

.other_list_figure img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: skewX(17deg) scale(1.5);
}

.other_list_links{
    margin-top: 10px;
    width: 100%;
}
.other_list_links img{
    width: 100%;
}

.flyer_wrap{
    display: flex;
    width: 100%;
    padding-right: calc(218px / tan(73deg));
    padding-bottom: 4px;
    flex-wrap: wrap;
    overflow: hidden;
    gap: 30px 4px;
}

.flyer_item{
    position: relative;
    display: flex;
    height: auto;
    flex: 1;
    flex-direction: column;
    justify-content: space-between;
    cursor: pointer;
}
.flyer_item::before{
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    z-index: 1;
    top: 0;
    left: 0;
    opacity: 0.2;
    transition: opacity 0.3s ease-in-out;
} 


.flyer_item::after{
    position: absolute;
    display: flex;
    content: "クリックで拡大";
    width: 10em;
    height: 2.5em;
    z-index: 2;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    justify-content: center;
    align-items: center;
    background-color: rgba(62,58,57,1);
    color: #FFF;
    font-size: 8px;
    letter-spacing: 0.1em;
    border-radius: 40px;
    transition: background-color 0.3s ease-in-out ,scale 0.3s ease-in-out;
}

.flyer_item p{
    font-size: 8px;
    font-weight: bold;
    text-align: center;
}

.flyer_item_img{
    width: 100%;
    height: auto;
    max-height: 152px;
    object-fit: cover;
}

#zoom_flyer{
    position: fixed;
    display: flex;
    width: 100vw;
    height: 100lvh;
    top: 0;
    left: 0;
    z-index: 50000;
    visibility: hidden;
    justify-content: center;
    align-items: flex-start;
    overflow-y: scroll;
}
#zoom_flyer.active{
    visibility: visible;
}

.zoom_flyer_wrap{
    position: relative;
    width: 85vw;
    max-width: 740px;
    height: fit-content;
    max-height: 95%;
    margin: auto;
    z-index: 1;
    scale: 1;
    overflow-y: scroll;
    filter: drop-shadow(0 0 3px #000);
}

.zoom_flyer_outer{
    display: flex;
    width: 100%;
    height: fit-content;
    max-height: 100%;
}

#zoom_flyer_image{
    width: 100%;   
}

#zoom_flyer_backbutton{
    position: fixed;
    display: flex;
    width: 2em;
    height: 2em;
    top: 0.5em;
    right: 0.5em;
    justify-content: center;
    align-items: center;
    background: rgba(0,0,0,0.7);
    border: none;
    border-radius: 50%;
    color: #FFF;
    font-size: min(4vw, 25px);
    line-height: 1;
    cursor: pointer;
}

#zoom_flyer_background{
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
    opacity: 1;
    background-color: rgba(0,0,0,0.7);
    cursor: pointer;
}

.service_link_outer{
    max-width: 920px;
    margin: 50px auto auto;
}

.service_link_outer p{
    font-size: 18px;
    font-family: "aileron", sans-serif;
    font-weight: 700;
    font-style: italic;
    text-align: center;
}
.service_link_outer p span{
    font-style: initial;
}

.service_link_beegle,
.service_link_rela{
    display: flex;
    width: 100%;
    max-width: 460px;
    height: 53px;
    margin: auto auto 64px;
    justify-content: center;
    align-items: center;
    background-color: #D2AF3A;
    clip-path: polygon(0% 0%, 100% 0%, calc(100% - 20px) 100%, 0% 100%);
}
.service_link_snow_removal{
    background: #333;
    width: 200px;
    margin: 30px auto 0;
    position: relative;
    text-align: center;
    box-shadow: 0 5px #b8cccc;
    transform: skew(-20deg);
    transition: all 0.2s ease-in-out;
}
.service_link_snow_removal a{
    display: block;
    text-decoration: none;
    color: #fff;
    font-weight: bold;
    padding: 15px 20px;
}

.service_link_beegle div{
    display: flex;
    height: 70%;
    justify-content: center;
}

.service_link_rela div{
    display: flex;
    height: 50%;
    justify-content: center;
}

.service_link_beegle div img,
.service_link_rela div img{
    width: 85%;
    height: 100%;
    object-fit: contain;
}

.service_rela_background{
    position: relative;
    width: 100%;
    overflow: hidden;
}

.service_rela_content{
    display: flex;
    flex-direction: column;
}

.service_rela_image{
    position: relative;
    width: 100%;
    height: 38.33vw; /*20240920変更*/
}

.service_rela_image > div{
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 50%;
    translate: -50% 0;
    overflow: hidden;
}

.service_rela_image > div img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.service_rela_content p{
    width: 100%;
    max-width: 920px;
    margin: 45px auto 60px;

    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    font-weight: bold;
}

/*
※※※※※※※※※※ 注意 ※※※※※※※※※※

事業内容ページのビーグルの内容部分だけ
下記のような独自のブレークポイントを持った
メディアクエリをかけています。

※※※※※※※※※※※※※※※※※※※※※※※
*/
@media screen and (max-width:1200px){
    .service_beegle_text p{
        padding-top: 16px;
    }
    .service_beegle_text{
        width: 100%;
    }
    .service_beegle_figure div{
        transform: skewX(12deg);
    }
    .service_beegle_figure div img{
        transform: skewX(-12deg) scale(1.5);
    }

    .service_beegle_hp{
        flex-direction: column;
    }

    .service_beegle_figure{
        width: 100%;
    }

    .service_beegle_text{
        padding-bottom: initial;
    }

    .service_beegle_hp .service_beegle_bigtext{
        position: initial;
        padding-right: calc(341px + (1em));
    }

    @media screen and (max-width:1024px){
        .service_beegle .left_jig,
        .service_beegle .right_jig{
            display: none;
            opacity: 0;
        }

        .service_beegle_hp{
            height: auto;
            gap: 40px 0;
            margin: 100px auto 0;
        }

        .service_beegle_box{
            width: 100%;
        }

        .service_beegle_figure{
            position: relative;
            left: 50%;
            align-items: end;
            transform: translateX(-50%);
        }

        .service_beegle_hp .service_beegle_bigtext{
            width: 50%;
            padding-right: initial;
            text-align: initial;
        }
        .service_beegle_hp .service_beegle_bigtext.semi_small{
            padding-right: initial;
            text-align: initial;
        }

        .service_beegle_figure div{
            position: initial;
            width: 50%;
            height: min(32.2vw, 300px);
            transform: skewX(25deg);
        }

        .service_beegle_figure div img{
            transform: skewX(-25deg) scale(1.5);
        }

        .other_service_title{
            padding-top: 100px;
            flex-direction: column;
        }

        .other_service_title h3{
            order: 2;
            align-self: center;
        }

        .transparent_title_04_wrap{
            position: relative;
            height: 1em;
            top: 0;
            margin-bottom: 64px;
            order: 1;
            font-size: 64px;
        }

        .transparent_title_04{
            bottom: initial;
            left: initial;
            right: 2%;
            font-size: 32px;
            writing-mode: initial;
        }

        .transparent_title_04 span{
            padding-bottom: initial;
            font-size: 64px;
        }

        .other_list{
            margin-top: 90px;
        }

        /*20250908変更*/
        .other_list_item{
            gap: 20px;
        }

        .other_list_name{
            position: relative;
            overflow: hidden;
            flex-direction: column;
        }

        .other_list_name::before{
            position: absolute;
            content: "";
            width: calc(100% - (var(--iw) * (265 / 500) + clamp(100px, var(--iw) * 0.3, 434px) / tan(65deg)));
            height: 1px;
            top: calc(100% - 1px);
            left: 0;
            background-color: #000;
        }
        /*--------------*/

        .other_list_text{
            width: 100%;
            padding-right: initial;
            justify-content: center;
        }
        .other_list_text::before{
            display: none;
        }

        .other_list_text > p{
            width: auto;
            padding-right: initial;
            padding-bottom: 1em;
            font-size: 21px;
        }

        .other_list_text p br{
            display: none;
        }

        .other_list_figure{
            position: relative;
            width: calc(var(--iw) * (265 / 500));
            height: clamp(100px, var(--iw) * 0.3, 434px);
            right: 0;
            transform: skewX(-25deg);
        }

        .other_list_figure img{
            transform: skewX(25deg) scale(1.5);
        }

        .flyer_wrap{
            padding-right: initial;
            margin-bottom: 30px;
            padding-bottom: initial;
        }
        .flyer_wrap::before{
            display: none;
        }

        .flyer_item{
            width: calc(50% - min(1vw, 10px));
            flex: initial;
        }
        .flyer_item::after{
            font-size: clamp(8px ,2vw ,16px);
        }

        .flyer_item p{
            font-size: 16px;
        }

        .flyer_item_img{
            max-height: initial;
        }
    }
}



/*-------------------- 事業内容↑ --------------------*/

/*-------------------- 制作実績↓ --------------------*/
.portfolio_wrap:nth-of-type(n+2){
    margin-top: 151px;
}

.portfolio_title{
    font-size: 30px;
    font-family:"Noto Sans CJK JP Bold";
    font-weight: bold;
    letter-spacing:0.1em;
    margin-top: 20px;
    margin-bottom: 20px;
}

.portfolio{
    position: relative;
    padding-bottom: 20px;
}

.portfolio::before{
    position: absolute;
    display: block;
    content: "";
    width: 100vw;
    height: 1px;
    z-index: -10000;
    right: 0;
    bottom: 0;
    background-color: #000;
}

.portfolio_flex{
    display: flex;
    width: 100%;
    height: auto;
}

.portfolio_empty_wrap,
.portfolio_img_wrap{
    display: block;
    width: 50%;
    height: 215px;
    overflow: hidden;
    border: solid 4px #000;
}

.portfolio_empty_wrap{
    border: none;
}

.portfolio_img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    transition: scale 0.3s ease-in-out;
}

.portfolio_text_wrap{
    position: relative;
    display: flex;
    width: 50%;
    height: auto;
    padding-left: 10px;
    flex-direction: column;
}

.portfolio_text{
    font-family:"Noto Sans CJK JP Bold";
    line-height: 2rem;
    flex-grow: 2;
}

.portfolio_viewmore{
    width: 100%;
}
.portfolio_viewmore > a{
    display: flex;
    width: 140px;
    height: 30px;
    margin-left: auto;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    font-family:"Aileron Bold Italic";
    font-size: 16px;
    color: white;
    background-color: #000;
    clip-path: polygon(0 0, 100% 0%, 88% 100%, 0% 100%);
    transition: transform 0.3s ease-in-out;
}

.portfolio_viewmore > a > span{
    font-style: italic;
}

.ichiran_outer{
    position: relative;
    width: 100%;
    height: 78px;
    margin-top: 120px;
}

.ichiran_outer .ichiran{
    position: absolute;
    display: flex;
    width: 100vw;
    height: 100%;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.ichiran_outer .ichiran a{
    display: flex;
    width: calc(100% * 0.5 + 8em * 0.5 + 25px + 14px);
    height: 100%;
    padding-right: 50px;
    justify-content: end;
    align-items: center;
    font-size: 30px;
    font-family:"Noto Sans CJK JP Bold";
    letter-spacing: 0.1em;
    color:white;
    background-color: #000;
    clip-path: polygon(0 0, 100% 0%, calc(100% - (78px / tan(63deg))) 100%, 0% 100%);
    transform: translateX(-7px);
    transition: transform 0.3s ease-in-out;
}

/*---------- 制作実績 一覧ページ↓ ----------*/
.portfolio_listpage_wrap{ /* 250115修正odani 中身を↓のプロパティに移動*/
    width: 100%;
}

.portfolio_listpage_wrap .portfolio_wrap{ /* 250115修正odani */
    width: 100%; 
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 108px 0;
}

.portfolio_listpage_wrap .post_item{ /* 250115追加odani */
    width: 48%;
    display: flex;
}

.portfolio_listpage_wrap .portfolio_wrap:nth-of-type(n+2){
    margin-top: 0;
}

.portfolio_listpage_wrap .portfolio_flex{
    flex-direction: column;
}

.portfolio_listpage_wrap .portfolio_empty_wrap,
.portfolio_listpage_wrap .portfolio_img_wrap{
    width: 100%;
    /* height: auto;
    max-height: 215px; */
}

.portfolio_listpage_wrap .portfolio_img{
    width: 100%;
}

.portfolio_listpage_wrap .portfolio::before{
    display: none;
}

.portfolio_listpage_wrap .portfolio_text_wrap{
    width: 100%;
    padding-left: 0;
}

.portfolio_listpage_wrap .portfolio_title{
    font-size: 25px;
    margin-bottom: 20px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.portfolio_listpage_wrap .portfolio_text{
    margin-bottom: 30px;
}

.portfolio_listpage_wrap .portfolio_viewmore > a{
    margin-left: initial;
}

/*---------- 制作実績 一覧ページ↑ ----------*/

/*---------- 制作実績 個別ページ↓ ----------*/

.portfolio_article_title{
    font-family:"Noto Sans CJK JP Bold";
    font-weight: bold;
    letter-spacing:0.1em;
    margin-top: 50px;
    margin-bottom: 50px;
}

.portfolio_article_imgbox{
    width: 100%;
    height: auto;
    overflow: hidden;
    border: solid clamp(10px, 3vw, 25px) #000;
}

.portfolio_article_img{
    display: block;
    width: 100%;
    height: auto; /* 250114追加odani */
    transition: scale 0.3s ease-in-out, filter 0.3s ease-in-out;
}

.text_flex{
    display: flex;
    width: 100%;
    height: auto;
    border-bottom: 1px solid black;
    margin-top: 28px;
    overflow: hidden;
}

.text_title{
    position: relative;
    display: flex;
    width: 234px;
    align-items: center;
}
.text_title::before{
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    transform: skewX(-43deg);
    transform-origin: top;
    background-color: #000;
}

.text_title > p{
    width: 100%;
    padding-left: 5px;
    color: white;
    font-family: "Noto Sans CJK JP Bold";
    font-weight: bold;
}

.text_flex > p{
    width: calc(100% - 234px);
    font-family: "Noto Sans CJK JP Bold";
    font-weight: bold;
}

.text_bikou > p{
    margin-top: 40px;
    font-family: "Noto Sans CJK JP Bold";
    line-height: 2.125em;
}

.link_flex{
    display: flex;
    width: 100%;
    margin: 0 auto;
    margin-bottom: 156px;
    margin-top: 83px;
    justify-content: space-around;
    align-items: center;
}

.link_left{
    width: 90%;
    max-width: 325px;
    height: 41px;
    background-color: #3E3A39;
    clip-path: polygon(0 0, 100% 0%, 100% 100%, 5% 100%);
    text-align: center;
    transition: transform 0.3s ease-in-out;
}

.link_right{
    display: flex;
    width: 90%;
    max-width: 325px;
    height: 41px;
    background-color: #D2AF3A;
    clip-path: polygon(0 0, 100% 0%, 95% 100%, 0% 100%);
    text-align: center;
    transition: transform 0.3s ease-in-out;
}

.link_left > a,
.link_right > a{
    width: 100%;
    cursor: pointer;
}

.link_left > a > p{
    height: 100%;
    color: white;
    font-size:21px;
    font-family:"Noto Sans CJK JP Bold";
    transition: all 0.3s ease-out;
}

.link_right > a > p{
    height: 100%;
    color: #3E3A39;
    font-size:21px;
    font-family:"Noto Sans CJK JP Bold";
    transition: all 0.3s ease-out;
}

/* モーダルウィンドウ */
html.stop_active,
body.stop_active{
    overflow: hidden;
}

.custom_modal_img{
    display: block;
}

#custom_modal_button{
    display: block;
    border: none;
    cursor: pointer;
}

#custom_modal_window{
    position: fixed;
    display: block;
    width: 100vw;
    height: 100vh;
    z-index: 15000;
    top: 0;
    left: 0;
    overflow: hidden;
    visibility: hidden;
    background-color: transparent;
    transition: visibility 0.2s ease-in-out, background-color 0.2s ease-in-out;
}
#custom_modal_window.active{
    visibility: visible;
}

.custom_modal_wrap{
    position: absolute;
    display: flex;
    width: 80%;
    height: auto;
    /* height: calc(100% - 200px);
    max-height: 80%; */
    z-index: 2;
    top: 50%;
    left: 50%;
    opacity: 0;
    translate: -50% -50%;
    align-items: center;
    transition: opacity 0.2s ease-in-out;
}
#custom_modal_window.active .custom_modal_wrap{
    opacity: 1;
}

.custom_modal_scroll{
    width: 100%;
    height: fit-content;
    max-height: 100%;
    z-index: 1;
    overflow: auto;
}

.custom_modal_image{
    width: 100%;
    object-fit: cover;
    scale: 0.7;
    transition: scale 0.2s ease-in-out;
}
#custom_modal_window.active .custom_modal_image{
    scale: 1;
}

.custom_modal_background{
    position: absolute;
    width: 100dvw;
    height: 100vh;
    z-index: 0;
    top: 50%;
    left: 50%;
    opacity: 0;
    translate: -50% -50%;
    border: none;
    background-color: #000;
    transition: opacity 0.2s ease-out;
}
#custom_modal_window.active .custom_modal_background{
    opacity: 0.8;
}
/*---------- 制作実績 個別ページ↑ ----------*/
/*-------------------- 制作実績↑ --------------------*/

/*-------------------- 沿革↓ --------------------*/
.history_wrap{
    position: relative;
    width: 100%;
}

.history_wrap::before{
    position: absolute;
    display: block;
    content: "";
    width: 1px;
    height: 100%;
    z-index: -10000;
    top: 0;
    left: 30px;
    background-color: #000;
}

.history_list_wrap{
    display: flex;
    padding-bottom: 72px;
    flex-direction: column;
    gap: 36px 0;
}

.history_list_wrap:last-of-type{
    padding-bottom: 0;
}

.history_year{
    display: flex;
    width: 100%;
    height: 63px;
    padding-left: 1.2em;
    align-items: center;
    background-color: #000;
    color: #FFF;
    clip-path: polygon(0 0, 100% 0%, calc(100% - (63px / tan(63deg))) 100%, 0% 100%);
}

.history_year p{
    font-size: 30px;
    line-height: 1;
}

.history_year p > span{
    padding-right: 0.2em;
    font-size: 30px; /*20240920変更*/
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
}

.history_event_wrap{
    display: flex;
    width: 100%;
    flex-wrap: wrap;
}

.history_month{
    width: 75px;
}

.history_month > div{ /* 20260124修正 */
    width: 62px;
    height: 62px;
    border-radius: 50%;
    background-color: #3E3A39;
    position: relative;
}

.history_month p{ /* 20260124修正 */
    font-size: 18px;
    color: #FFF;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    text-align: center;
    width: 100%;
    letter-spacing: 0;
}

.history_month p > span{ /* 20260124修正 */
    padding-right: 0.1em;
    font-size: 30px; /*20240920変更*/
    font-family: "aileron", sans-serif;
    font-weight: bold;
    font-style: italic;
}

.history_event{
    width: calc(100% - 75px);
    padding-top: 20px;
    font-family: 'Yu Gothic';
    line-height: 1.375;
    letter-spacing: 0.1em;
}
/*-------------------- 沿革↑ --------------------*/

/*-------------------- お問い合わせ↓ --------------------*/
#contact_confirm{
    margin-top: 120px;
}

.contact_form_wrap{
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: center;
    gap: 78px 0;
}

.contact_form_contents{
    display: flex;
    width: 100%;
}

.contact_contents_name{
    width: 36%;
    padding-right: 20px;
    border-right: solid 1px #000;
}

.contact_contents_name p{
    display: inline-block;
    padding-right: 0.5em;
    letter-spacing: 0.2em;
}

.contact_form_contents.required_contents .contact_contents_name::after{
    display: inline-block;
    content: "必須";
    margin-left: 0.6em;
    padding: 0 0.6em;
    background-color: #751721;
    color: #FFF;
    letter-spacing: 0.2em;
    line-height: 1.75;
}

.contact_form_contents > *:not(.contact_contents_name){
    width: calc(64% - 20px);
    margin-left: 20px;
}

.contact_form_contents input,
.contact_form_contents select,
.contact_form_contents textarea{
    width: 100%;
    padding: 0.2em 0.8em;
    word-break: break-all;
}

.contact_form_contents .select_contents{
    position: relative;
}

.contact_form_contents .select_contents::before{
    position: absolute;
    display: flex;
    content: "▼";
    width: 1em;
    height: 100%;
    top: 0;
    right: 0.5em;
    font-size: 16px;
    align-items: center;
    pointer-events: none;
}

.contact_form_contents select{
    width: 100%;
    height: 100%;
    font-weight: bold;
    /* color: rgba(0,0,0,0.4); */
    color: #000;
    appearance: none;
}
/* 
.contact_form_contents select.checked_select{
    color: rgba(0,0,0,1);
} */

.contact_form_contents option{
    background-color: #D2AF3A;
    border-top: 1px solid #000;
    font-weight: bold;
    color: rgba(0,0,0,1);
}

.contact_form_button{
    display: flex;
    gap: 47px 53px;
}

.contact_form_button input,
.contact_form_button button{
    width: 150px;
    height: 45px;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.2em;
    border-radius: 22.5px; /*20240920変更*/
    cursor: pointer;
}
.contact_form_button .form_button_black{
    background-color: #000;
    color: #FFF;
    border: solid 1px #000;
}
.contact_form_button .form_button_yellow{
    background-color: #D2AF3A;
    color: #3E3A39;
    border: solid 1px #D2AF3A;
}

.contact_finish_wrap{
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    font-weight: bold;
}

.contact_finish_wrap img{
    width: 100%;
    max-width: 200px;
}

.contact_finish_wrap .contact_form_button{
    margin-top: 16px;
}

.contact_error_message{
    font-weight: bold;
    color: #751721;
}

/* 20250802追加 */
.contact_input_width{
    width: 100%;
}

.wpcf7-spinner{
    display: none;
}

.wpcf7-not-valid-tip{
    position: absolute;
}

.wpcf7-select option:first-child {
  color: gray;
}

/*-------------------- お問い合わせ↑ --------------------*/

/*-------------------- アーカイブ↓250116追加odani -------------------- */
.portfolio_viewmore>.more_button_archive{
    width: 200px;
}
/*-------------------- アーカイブ↑ -------------------- */


/*-------------------- フッター↓ --------------------*/


/* footer{
    position: relative;
    color: #3E3A39;
}

.footer_wrap{
    width: 95%;
    max-width: 1764px;
    margin: 40px auto 0;
    border-top: 1px solid #3E3A39;

}

.footer_upper{
    display: flex;
    margin-top: 20px;
    flex-direction: row;
    justify-content: space-between;
    letter-spacing: 0.2em;
}

.footer_address{
    width: 49%;
    font-size: 16px;
    font-family: 'Meiryo UI', sans-serif;
}

.footer_address > p,
.footer_address > div{
    padding: 14px 0;
    letter-spacing: 0.2em;
    color: #3E3A39;
    font-weight: bold;
}

.footer_beegle{
    display: block;
    width: clamp(300px, (100vw - 920px) * 10000, 430px);
}

.footer_logo{
    width: clamp(17.6em, (100vw - 920px) * 10000 ,25.2em);
    height: auto;
}

.footer_beegle p{
    width: 100%;
}

.footer_map_link{
    width: 100%;
    max-width: 160px;
}

.tel_outer{
    display: grid;
    gap: 0 1em;
    grid-template-columns: repeat(auto-fill, 15em);
}

.tel_outer > a,
.tel_outer > p{
    line-height: 1.75;
    font-size: 16px;
    color: #3E3A39;
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.footer_upper_list{
    width: 49%;
}

.footer_upper_list ul{
    display: grid;
    width: 100%;
    margin-top: 76px;
    grid-template-columns: repeat(auto-fill, minmax(9em, 10em));
    gap: 3em 0;
    justify-content: center;
    font-size: 16px;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 600;
}

.footer_upper_list li{
    position: relative;
    padding-left: 1.2em;
}

.footer_upper_list a{
    color: #3E3A39;
}

.footer_under{
    display: flex;
    width: 100%;
    max-width: 1764px;
    margin: auto;
    margin-top: 54px;
    letter-spacing: 0.2em;
    flex-direction: row;
    justify-content: space-between;
}

.footer_under_links{
    display: flex;
    width: 100%;
    margin: auto;
    justify-content: space-between;
    align-items: flex-start;
    gap: 30px;
}

.footer_under_links > a{
    width: -moz-fit-content;
    width: fit-content;
    width: 100%;
}

.footer_under_links>a img{
    width: 100%;
    height: 100%;
    max-height: 220px;
    object-fit: cover;
}

.footer_under_sns{
    display: flex;
    width: 100%;
    gap: 0 60px;
}

.footer_under_sns > a img{
    width: 100%;
    max-width: 41px;
    max-height: 41px;
}

.top_button_wrap{
    position: absolute;
    display: flex;
    width: auto;
    bottom: 0;
    right: 1%;
    justify-content: flex-end;
}

.footer_copyright{
    margin-bottom: 30px;
    font-size: 12px;
    text-align: center;
} */
/*-------------------- フッター↑ --------------------*/








/*-------------------- ブレークポイント 834px ↓ --------------------*/


@media screen and (max-width:834px){
    h2{
        font-size: 24px;
    }
    
    h3{
        font-size: 21px;
    }

    .desktop_br_prohibit{
        display: initial;    
    }

    .text_wbr.mobile_wbr_prohibit{
        word-break: initial;
        overflow-wrap: initial;
    }

    .wbr_prohibit{
        display: none;
    }
    
    /*-------------------- ヘッダー↓ --------------------*/
    .header_wrap{
        z-index: 10001;
        left: initial;
        transform: initial;
        overflow: initial;
    }

    .header_link_outer{
        position: fixed;
        width: 100vw;
        height: 100vh;
        top: 0;
        left: 0;
        z-index: 1;
        opacity: 0.85;
        overflow: hidden;
        translate: -100vw 0;
        transform: skewX(0deg);
        background-color: #000;
    }
    .header_link_outer.active{
        translate: initial;
        transition: translate 0.1s ease-in-out;
    }

    .header_link_outer nav{
        height: 100%;
        max-height: 600px;
    }

    .header_wrap h2{
        width: min(75%, 100% - 80px);
        padding-left: 1vw;
        transform: skewX(0deg);
        align-items: center;
    }
    .header_wrap h2::after{
        display: none;
    }

    .header_wrap h2 img{
        padding-bottom: 0;
        transform: skewX(0deg);
    }

    .header_link_wrap{
        height: 100%;
        margin-top: initial;
        padding-top: 80px;
        flex-direction: column;
        flex-wrap: initial;
        align-items: initial;
        justify-content: initial;
    }
    .header_link_wrap::after{
        display: none;
    }

    .header_link_wrap li{
        display: flex;
        justify-content: end;
        transform: skewX(0deg);
    }

    .header_link_wrap li:last-of-type{
        background-color: transparent;
    }

    .header_link_wrap a{
        position: relative;
        width: fit-content;
        height: fit-content;
        padding: 0;
        font-family: "noto-sans-cjk-jp", sans-serif;
        font-size: 24px;
        font-weight: 700;
        letter-spacing: 0.2em;
        translate: -100vw 0;
    }
    .header_link_wrap a::after{
        position: absolute;
        display: block;
        content: "";
        width: 100vw;
        height: 2px;
        bottom: 0;
        right: 0;
        background-color: #FFF;
    }

    .header_link_outer.anime .header_link_wrap a{
        transition: translate 0.1s ease-in-out;
    }

    .header_hamburger_button{
        position: fixed;
        display: flex;
        width: 60px;
        height: 60px;
        top: 10px;
        right: 10px;
        z-index: 10001;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        background-color: #000;
        border-radius: 50%;
        cursor: pointer;
        transition: background-color 0.3s ease-in-out;
    }

    .header_hamburger_button.active{
        background-color: #FFF;
    }

    .hamburger_line_wrap{
        position: relative;
        width: 23px;
        height: 23px;
    }

    .hamburger_line_wrap .hamburger_line{
        position: absolute;
        display: block;
        height: 2px;
        width: 23px;
        transform: translateY(-50%);
        background-color: #FFF;
        transition: top 0.3s ease-in-out, transform 0.1s ease-in-out, opacity 0.3s ease-in-out, background-color 0.3s ease-in-out;
    }
    .header_hamburger_button.active .hamburger_line_wrap .hamburger_line{
        background-color: #000;
    }

    .hamburger_line_wrap .hamburger_line:nth-of-type(1){
        top: 20%;
    }
    .header_hamburger_button.active .hamburger_line_wrap .hamburger_line:nth-of-type(1){
        top: 50%;
        transform: translateY(-50%) rotate(45deg);
        transition: top 0.1s ease-in-out, transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
    }

    .hamburger_line_wrap .hamburger_line:nth-of-type(2){
        top: 50%;
    }
    .header_hamburger_button.active .hamburger_line_wrap .hamburger_line:nth-of-type(2){
        opacity: 0;
    }

    .hamburger_line_wrap .hamburger_line:nth-of-type(3){
        top: 80%;
    }
    .header_hamburger_button.active .hamburger_line_wrap .hamburger_line:nth-of-type(3){
        top: 50%;
        transform: translateY(-50%) rotate(-45deg);
        transition: top 0.1s ease-in-out, transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
    }

    .header_hamburger_button p{
        font-size: 14px;
        font-family: "aileron", sans-serif;
        font-weight: bold;
        font-style: italic;
        color: #FFF;
        transition: color 0.1s ease-in-out;
    }

    .header_hamburger_button.active p{
        color: #000;
    }
    /*-------------------- ヘッダー↑ --------------------*/

    /*-------------------- 共通部品↓ --------------------*/
    /*---------- ジグザグ背景↓ ----------*/
    .jag_absolute{
        /* margin-top: 143px; */
        margin-top: 72px; /*20240930変更*/
    }
    /*---------- ジグザグ背景↑ ----------*/
    
    /*---------- サブページタイトル↓ ----------*/
    .subpage_title{
        max-height: 120px;
        aspect-ratio: 834 / 200;
    }

    .subpage_engtitle_wrap p{
        font-size: min(100vw * (26.5 / 500), 34px);
        padding: initial;
        padding-top: calc(100% * (2 / 500));
        padding-left: calc(100% * (3 / 500));
    }

    .subpage_title_text{
        width: max(40%, 8em);
        margin: initial;
        padding-top: calc(25% * (57 / 500));
        padding-left: 0.3em;
        padding-right: initial;
        right: 0;
        font-size: 30px;
        text-align: left;
    }

    .subpage_title_text::before{
        width: 100%;
    }

    .subpage_pc_title{
        display: none;
    }
    .subpage_sp_title{
        display: initial;
    }
    /*---------- サブページタイトル↑ ----------*/


    /*---------- ページ下部 お問い合わせ誘導↓ ----------*/

    /*----- バナー本体↓ -----*/
    .contact_info_wrap{
        min-height: initial;
    }

    .contact_info_content{
        padding-top: 30px;
    }

    .contact_info_content h2{
        font-size: 24px;
        padding-left: 43px;
    }

    .contact_info_content h2::before{
        width: 43px;
        height: 29px;
        top: 0;
        left: 0;
    }

    .contact_info_content p{
        font-size: 12px;
    }

    .contact_info_link{
        flex-direction: column;
    }

    .contact_info_link a:first-of-type,
    .contact_info_link a:last-of-type{
        width: 100%;
        height: calc(85vw * (213.11 / 440));
        transform-origin: initial;
    }

    .contact_info_link a:last-of-type{
        translate: 0 -1px;
    }

    .contact_info_link a:first-of-type .contact_info_text,
    .contact_info_link a:last-of-type .contact_info_text{
        position: absolute;
        width: 238px;
        height: 49px;
        top: 50%;
        right: 0;
        translate: 0 -100%;
    }
    .contact_info_link a:last-of-type .contact_info_text{
        left: initial;
    }

    .contact_info_text p{
        font-size: 16px;
    }

    .contact_info_link a:first-of-type .contact_info_text span{
        font-size: 10px;
    }

    .contact_info_link a:last-of-type .contact_info_text span{
        font-size: 8px;
    }

    /*----- バナー本体↑ -----*/
    /*----- バナー下部↓ -----*/
    .create_banner_wrap{
        height: 100%;
    }
    .create_banner:first-of-type{
        display: none;
    }
    .create_banner:last-of-type{
        display: initial;
    }
    /*----- バナー下部↑ -----*/

    /*---------- ページ下部 お問い合わせ誘導↑ ----------*/

    /*---------- 左右の背景↓ ----------*/
    .left_jig,
    .right_jig{
        display: none;
        opacity: 0;
    }
    /*---------- 左右の背景↑ ----------*/

    /*---------- ページトップボタン↓ ----------*/
    .page_top_button{
        position: fixed;
        right: 10%;
        bottom: 5%;
        flex-direction: column;
        align-items: center;
        visibility: hidden;
        opacity: 0;
    }

    .page_top_button>p{
        order: 2;
    }
    /*---------- ページトップボタン↑ ----------*/

    /*-------------------- 共通部品↑ --------------------*/



    /*-------------------- トップページ↓ --------------------*/
    /*---------- メインビュー↓ ----------*/
    .mainview_title_wrap{
        width: 100%;
        left: initial;
    }

    .mainview_title_wrap h1{
        padding-top: 1.5em;
        font-size: max(100vw * (52 / 834), 28px);
    }

    .mainview_title_wrap h1 span{
        letter-spacing: -0.2em;
    }

    .mainview_about_wrap{
        bottom: calc(100vw * (600 / 1920) * (32 / 696));
    }

    .mainview_about_wrap > div:first-of-type p:first-of-type{
        font-size: max(100vw * (52 / 834), 28px);
    }
    .mainview_about_wrap > div:first-of-type p:nth-of-type(2){
        font-size: max(100vw * (21 / 834), 12px);
    }
    .mainview_about_wrap > p:last-of-type{
        font-size: max(100vw * (11 / 834), 8px);
    }

    
    .mainview_pc_img{
        display: none;
    }
    .mainview_sp_img{
        display: initial;
        width: 100%;
    }
    /*---------- メインビュー↑ ----------*/
    .top_content_wrap::before{
        display: none;
    }

    .greeting_wrap{
        margin-top: initial;
        padding-top: initial;
    }

    .greeting_background{
        padding: 4em 0 0;
    }

    .greeting_title{
        font-size: 24px;
    }

    .greeting_text_wrap p{
        font-size: initial;
    }

    .greeting_text_wrap .ceo{
        margin-top: 1em;
        padding-bottom: calc(58.09vw * (177 / 304) / 2);
    }

    .transparent_title_01{
        font-size: 32px;
    }
    .transparent_title_01 span{
        font-size: 64px;
    }

    .inner_image_wrap{
        width: 58.09vw;
        height: calc(58.09vw * (177 / 304));
        top: calc(100% - calc(58.09vw * (177 / 304) / 2));
        right: initial;
        left: -10vw;
    }

    .inner_image_wrap .inner_image{
        clip-path: polygon(calc((58.09vw * (177 / 304)) / tan(73deg)) 0, 100% 0, calc(100% - (58.09vw * (177 / 304)) / tan(73deg)) 100%, 0 100%);
    }

    #top_link{
        padding-top: calc(58.09vw * (177 / 304) / 2 + 10px);
    }
    #top_link::before{
        display: block;
    }

    #top_link > div{
        padding-bottom: 60px;
    }
    
    .top_link_wrap > nav{
        order: 2;
    }

    .top_link_list{
        display: flex;
        width: min(85vw, 700px);
        flex-direction: column;
        gap: min(calc(85vw * 25 / 700), 25px) 0;   
    }

    .top_link_list > li{
        height: min(calc(85vw * 200 / 700), 200px);
        margin-bottom: min(calc(85vw * 25 / 700), 25px);
    }

    .top_link_list > li:last-of-type{
        margin-bottom: 0;
    }

    .top_link_list > li.large_link{
        height: min(45vw, 350px);
    }

    .top_link_list > li.border_title_position{
        display: none;
    }

    .top_link_list .top_links{
        border-width: min(calc(85vw * 5 / 700), 5px);
    }

    .top_link_list .top_links::after{
        background: #000;
    }

    .top_link_list .top_link_image{
        display: none;
    }

    .top_link_list .link_title_main p{
        font-size: min(calc(85vw * 28 / 700), 28px);
    }

    .top_link_list .link_title_sub p{
        font-size: min(calc(85vw * 16 / 700), 16px);
    }

    .top_link_list .arrow_icon{
        width: min(calc(85vw * 40 / 700), 40px);
        height: min(calc(85vw * 40 / 700), 40px);
        border-width: min(calc(85vw * 3 / 700), 3px);
    }

    .top_link_list .link_text_title{
        margin-right: min(calc(85vw * 50 / 700), 50px);
    }

    .top_link_list .link_text_title .arrow_icon{
        font-size: min(calc(85vw * 10 / 700), 10px);
    }

    .top_link_list .arrow_icon::before,
    .top_link_list .arrow_icon::after{
        height: min(calc(85vw * 3 / 700), 3px);
        border-radius: 0 min(calc(85vw * 2 / 700), 2px) min(calc(85vw * 2 / 700), 2px) 0;
    }

    .top_link_list .link_content_wrap{
        width: 100%;
    }

    .top_link_list .link_content_item{
        padding: 0 min(calc(85vw * 20 / 700), 20px);
    }

    .top_link_list .top_other_links,
    .top_link_list .top_other_wrap{
        gap: min(calc(85vw * 10 / 700), 10px);
    }

    .top_link_list .top_link_logo{
        height: min(calc(85vw * 40 / 700), 40px);
    }

    .top_link_list .top_other_links p{
        font-size: min(calc(85vw * 12 / 700), 12px);
    }

    .top_link_list .portfolio_view_wrap{
        width: 100%;
        flex: initial;
        justify-content: center;
    }

    .transparent_title_02wrap{
        bottom: 100%;
        font-size: 64px;
    }

    .transparent_title_02{
        opacity: 0.31;
        color: #000;
        font-size: 32px;
    }
    .transparent_title_02 span{
        font-size: 64px;
    }

    .transparent_title_02wrap .border_position::before{
        display: none;
    }

    .home_top_jig::before,
    .home_top_jig::after,
    .home_bottom_jig::before,
    .home_bottom_jig::after{
        display: none;
    }

    .zoom_flyer_wrap{
        max-width: 640px;
        max-height: calc(95% - 80px);
        margin-top: 80px;
    }
    /*-------------------- トップページ↑ --------------------*/

    /*-------------------- 会社概要↓ --------------------*/
    .company_background{
        margin: 0 auto auto;
        padding-bottom: 120px;
    }
    .company_background::before{
        background-size: 150%;
        background-position: 0 calc(100% - 64px);
    }

    .company_list{
        gap: 32px 0;
    }

    .company_list > li{
        height: 100%;
        min-height: 64px;
        padding: 0.5em 0 0.5em 2em;
    }

    .company_list > li::after{
        clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 25px 100%);
        transform: skewX(0deg);
    }

    .company_list > li .company_item_wrap{
        flex-direction: column;
        gap: 0.5em;
    }

    .company_list > li .company_item_wrap > p:first-of-type{    /* 修正点_池田_20250825 */
        width: 100%;
        font-size: 18px;
    }

    .company_list > li .company_item_wrap > *:not(p:first-of-type){    /* 修正点_池田_20250825 */
        width: 100%;
        font-size: 13px;
    }

    .company_list > li .company_item_numlist{
        padding-left: 1em;
    }

    .transparent_title_03{
        font-size: 32px;
    }
    .transparent_title_03 span{
        font-size: 64px;
    }
    /*-------------------- 会社概要↑ --------------------*/

    /*-------------------- 事業内容↓ --------------------*/
    .service_background{
        display: none;
    }

    .service_section_title.section_rela_title{
        margin-top: 30px;
    }
    
    .service_section_title h2{
        font-size: clamp(20px, 5vw, 30px);
    }

    .service_beegle_hp .service_beegle_bigtext{
        font-size: 48px;
    }

    .service_beegle_hp .service_beegle_bigtext.semi_small{
        font-size: 26px;
    }
    
    .service_section_title .section_title{
        width: calc(100% - 52px);
        font-size: 24px;
        padding-left: initial;
        padding-right: initial;
    }

    .service_section_title .section_number{
        width: 83px;
    }
    

    .other_service_title{
        line-height: 1.75;
        border-bottom: 1px solid #000;
    }

    .other_service_title h3{
        font-size: 24px;
        letter-spacing: 0.1em;
    }
    .other_service_title h3::before{
        display: none;
    }

    .other_list_link{
        width: 100%;
    }

    .service_link_outer p{
        font-size: 18px;
        line-height: 1.5;
    }

    .service_rela_background::before{
        display: none;
    }

    .service_rela_image{
        order: 2;
    }

    .service_rela_content p{
        position: relative;
        margin: auto;
        padding: 60px 0;
        order: 1;
        font-size: 18px;
    }
    /*-------------------- 事業内容↑ --------------------*/

    /*-------------------- 制作実績↓ --------------------*/
    .portfolio_wrap:nth-of-type(n+2){
        margin-top: 100px;
    }

    .portfolio_title{
        font-size: 23px;
    }
    
    .portfolio::before{
        width: 100%;
    }
    
    .portfolio_flex{
        flex-direction: column;
    }

    .portfolio_empty_wrap,
    .portfolio_img_wrap{
        width: 100%;
        height: auto;
    }

    .portfolio_img,
    .portfolio_text_wrap{
        width: 100%;
        margin: 10px auto 0;
        padding-left: 0;
    }
    .portfolio_img{
        height: initial;
    }

    .portfolio_text{
        width: 100%;
    }

    .portfolio_viewmore{
        margin-top: auto;
        width: 100%;
    }

    .ichiran_outer{
        height: 51px;
        margin-top: 93px;
    }

    .ichiran_outer .ichiran a{
        width: calc(100% * 0.5 + 8em * 0.5 + 15px + 14px);
        padding-right: 30px;
        font-size: 26px;
        clip-path: polygon(0 0, 100% 0%, calc(100% - (51px / tan(63deg))) 100%, 0% 100%);
    }

    /*---------- 制作実績 個別ページ↓ ----------*/
    .text_flex{
        flex-direction: column;
    }

    .text_flex > p{
        width: 100%;
        padding: 0.5em calc(1em + 5px) 0;
    }

    .link_flex{
        flex-direction: column;
        margin-bottom: 120px;
        gap: 52px 0;
    }
    /* モーダルウィンドウ */
    .custom_modal_wrap{
        width: 100%;
    }
    /*---------- 制作実績 個別ページ↑ ----------*/


    /*---------- 制作実績 一覧ページ↓ ----------*/
    .portfolio_listpage_wrap .portfolio_wrap{
        width: 100%;
        gap: 54px 0;
    }

    .portfolio_listpage_wrap .post_item{
        width: 100%;
    }

    .portfolio_listpage_wrap .portfolio_empty_wrap,
    .portfolio_listpage_wrap .portfolio_img_wrap{
        max-height: initial;
    }

    .portfolio_listpage_wrap .portfolio_text_wrap{
        flex-direction: column;
    }
    /*---------- 制作実績 一覧ページ↑ ----------*/

    /*-------------------- 制作実績↑ --------------------*/

    /*-------------------- 沿革↓ --------------------*/
    .history_wrap::before{
        left: 23px;
    }

    .history_list_wrap{
        padding-bottom: 48px;
        gap: 24px 0;
    }

    .history_year{
        height: 39px;
        padding-left: 0.6em;
        clip-path: polygon(0 0, 100% 0%, calc(100% - (39px / tan(63deg))) 100%, 0% 100%);
    }

    .history_year p{
        font-size: 22px;
    }
    
    .history_year p > span{
        padding-right: 0.2em;
        font-size: 24px;
    }

    .history_month{
        width: 55px;
    }

    .history_month > div{
        width: 45px;
        height: 45px;
    }

    .history_month p{
        font-size: 10px;
    }

    .history_month p > span{
        font-size: 20px;
    }

    .history_event{
        width: calc(100% - 55px);
        padding-top: 10px; /*20240920変更*/
    }
    /*-------------------- 沿革↑ --------------------*/

    /*-------------------- お問い合わせ↓ --------------------*/
    .contact_form_wrap{
        gap: 40px 0;
    }

    .contact_form_contents{
        flex-wrap: wrap;
        gap: 22px 0;
    }

    .contact_form_contents > *:not(.contact_contents_name){
        width: 100%;
        margin-left: initial;
    }

    .contact_contents_name{
        width: 100%;
        border-right: initial;
    }

    /*-------------------- お問い合わせ↑ --------------------*/


    /*-------------------- フッター↓ --------------------*/
    /* .footer_wrap{
        border-top: none;
    }

    .footer_upper{
        width: 100%;
        margin: auto;
        flex-direction: column;
        border-top: 1px solid #3E3A39;
    }

    .footer_address{
        display: flex;
        width: 100%;
        order: 2;
        flex-direction: column;
    }

    .footer_address > p,
    .footer_address > div{
        padding: 25px 0;
    }

    .footer_beegle{
        width: 100%;
        max-width: clamp(300px, (100vw - 500px) * 10000, 430px);
    }

    .footer_logo{
        width: 25.2em;
        height: auto;
    }

    .tel_outer{
        display: flex;
        flex-wrap: wrap;
    }

    .footer_upper_list{
        width: 100%;
        order: 1;
    }

    .footer_upper_list ul{
        margin: 44px 0;
        font-size: clamp(14px ,3.6vw ,28px);
        grid-template-columns: repeat(auto-fill, 7.5em);
    }

    .footer_upper_list li{
        padding-left: 0;
    }

    .footer_under_sns{
        gap: min(10vw ,60px);
    }

    .footer_under{
        margin-top: 60px;
        flex-direction: column;
    }

    .footer_under_links{
        flex-direction: column;
    }

    .footer_under_links > a img{
        max-height: initial;
    }

    .footer_copyright{
        width: 84%;
        margin: 0 auto;
        padding: 30px 0;
    } */

    /*-------------------- フッター↑ --------------------*/
    /*-------------------- ブレークポイント 834px ↑ --------------------*/

    /*-------------------- ブレークポイント 500px ↓ --------------------*/
    @media screen and (max-width:500px){   
        .mobile_br_prohibit{
            display: none;
        }

        .text_wbr_mobile{
            word-break: keep-all;
            overflow-wrap: break-word;
        }

        /* トップページ↓ */
        .greeting_title{
            line-height: 1.5;
        }

        .transparent_title_01{
            font-size: 22px;
        }
        .transparent_title_01 span{
            font-size: 44px;
        }

        .transparent_title_02wrap{
            font-size: 44px;
        }

        .transparent_title_02{
            font-size: 22px;
        }
        .transparent_title_02 span{
            font-size: 44px;
        }
        /* トップページ↑ */
        
        /* 事業内容 ↓ */
        .service_rela_content p::before{
            transform: translateX(-50%) skewX(12deg);
        }
        /* 事業内容 ↑ */

        /* お問い合わせ */
        .contact_form_button{
            flex-direction: column;
        }

        /* フッター↓ */
        /* .footer_under_sns>a{
            width: 48px;
        }

        .footer_logo{
            width: calc(100% - 0.4em);
            max-width: 17.6em;
        } */

        /* .footer_upper{
            border-top: none;
        }
        
        .footer_under_sns>a{
            width: 48px;
        }

        .footer_logo{
            width: calc(100% - 0.4em);
            max-width: 17.6em;
        }

        .footer_upper_list ul{
            grid-template-columns: repeat(auto-fill, 100%);
            justify-content: flex-start;
            gap: 0;
            border-top: 1px solid #B0CBE5;
        }

        .footer_upper_list li{
            border-bottom: 1px solid #B0CBE5;
        }

        .footer_upper_list a{
            display: flex;
            flex-direction: row;
            justify-content: space-between;
            align-items: center;
            color: #003783;
            padding: 1.5em 1em;
        }

        .footer_upper_list a::after{
            content: "\02192";
            width: 1.5em;
            line-height: 1.5em;
            color: white;
            text-align: center;
            text-indent: 15%;
            background-color: #003783;
            border-radius: 1.5em;
        } */
        /* フッター↑ */
    }
    /*-------------------- ブレークポイント 500px ↑ --------------------*/
}

/* ☆250708 プライバシーポリシー追加分 */
.contact_top_text{
    text-align: center;
}

.contact_form_wrap{
    gap: 0;
}

.contact_form_contents{
    margin-bottom: 78px;
}

.contact_form_contents.input_page{
    margin-bottom: 0;
}

.contact_form_button.input_page{
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.last_child{
    margin-bottom: 78px;
}

.privacy_text{
    margin: 50px 0 150px 0;
}

.privacy_text > span{
    display: block;
    margin-top: 50px;
}

ol.privacy_text{
    line-height: 1.75;
    margin-left: 1em;
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

ol.privacy_text > li{
    margin: 50px 0;
}

#section_privacy_policy .section_number > img{
    width: 100%;
}

.priv_area{
    width: fit-content;
    font-size: 12px;
    font-family: 'Noto Sans', sans-serif;
    font-weight: 600;
    letter-spacing: 0.075em;
    margin: 30px auto;
}

.button_privacy_policy {
    color: #0071BC;
}

.priv_nolink {
    color: #727171;
}


@media (hover: hover){
    /*-------------------- ヘッダー↓ --------------------*/
    .header_link_wrap a:hover{
        padding-bottom: 5px;
    }
    /*-------------------- ヘッダー↑ --------------------*/
    /*-------------------- 共有部品↓ --------------------*/
    /*---------- ページ下部 お問い合わせ誘導ver2 ↓ ----------*/
    .contact_info_link a:hover .contact_info_background{
        scale: 1.05;
    }
    /*-------------------- 共有部品↑ --------------------*/
    /*-------------------- トップページ↓ --------------------*/
    .top_link_list .top_links:hover .top_link_image img{
        filter: brightness(1);
    }

    .top_link_list .top_links:hover .arrow_icon:not(.other_link_arrow)::before,
    .top_link_list .top_other_links:hover .other_link_arrow::before{
        right: 22%;
        rotate: 20deg; 
    }
    .top_link_list .top_links:hover .arrow_icon:not(.other_link_arrow)::after,
    .top_link_list .top_other_links:hover .other_link_arrow::after{
        right: 22%;
        rotate: -20deg;
    }
    /*-------------------- トップページ↑ --------------------*/
    /*-------------------- 事業内容↓ --------------------*/
    .flyer_item:hover::before{
        opacity: 0.5;
    }

    .flyer_item:hover::after{
        scale: 1.1;
        background-color: rgba(62,58,57,0.5);
    }

    .service_link_snow_removal:hover{
        box-shadow: none;
        transform: skew(-20deg) translateY(5px);
    }

    .other_list_link:hover{
        scale: 1.05;
    }
    /*-------------------- 事業内容↑ --------------------*/
    /*-------------------- 制作実績↓ --------------------*/
    .portfolio_img_wrap:hover .portfolio_img{
        scale: 1.05;
    }

    .portfolio_viewmore > a:hover{
        transform: translateX(7px);
    }

    .ichiran_outer .ichiran a:hover{
        transform: translateX(0px);
    }
    /*---------- 制作実績 個別ページ↓ ----------*/
    .portfolio_article_img:hover{
        scale: 1.05;
        transform-origin: center;
        filter: brightness(1.1);
    }

    .link_left:hover{
        transform: translateX(-7px);
    }

    .link_right:hover{
        transform: translateX(7px);
    }
    /*---------- 制作実績 個別ページ↑ ----------*/
    /*-------------------- 制作実績↑ --------------------*/

    @media screen and (max-width:834px){
        /*-------------------- ヘッダー --------------------*/
        .header_link_wrap a:hover{
            padding-bottom: 0;
        }
    }
}