/********* 第2階層 共通*********/
header{
    box-shadow: 0px 10px 30px -10px #E5E5E5;
}
#header-inner{
    padding: 17px 10px 33px;    
}

.breadcrumbs {
    margin-bottom: 102px;
    font-size: 1.4rem;
}

main.level2.page,
main.level2.single,
main.level2.cast{
    padding: 31px 0 100px;    
}

.wid1054{
    max-width: 1054px;
    margin: 0 auto;
}

@media screen and (max-width:768px) {
    #header-inner{
        padding: 10px 10px 9px;    
    }
    header h1.logo{margin-top: 0;}
    .breadcrumbs, main#event .breadcrumbs,
    main.level2.event-detail .breadcrumbs{
        margin-bottom: 42px;    
    }
    
    main.level2.page, main.level2.page#event, main.level2.single, main.level2.event-detail{
        padding: 21px 0 50px;   
    }
    .wid1054{
        max-width: 100%;
    }
    
    
    
}

/*** pagenation ***/
ul.page-numbers{display: flex;}

.pagenation {
    width: 100%;
    margin: 40px auto;
}

.nav-links{
    display: flex;
    align-items: center;
    justify-content: center;     
}

.pagenation span, .pagenation a {
    width: 39px;
    margin: 0 3px;
    padding: 10px 10px;
    display: block;
    font-size: 2.0rem;
    text-decoration: none;
    text-align: center;
    line-height: 1;
    border-radius: 50px;
    color: #D90000;  
    font-weight: 600;
}

/* ホバー時 & 現在のページ */
.pagenation a:hover,
.pagenation .current  {
    background-color: #D90000;
    color: #fff;
}

ul.page-numbers {
    display: flex;
    justify-content: center;
    margin: auto;
}
ul.page-numbers li{
    text-align: center;
    font-size: 2rem;
    margin: 0;
    line-height: 1;
}
ul.page-numbers li a {
    width: 42px;
    height: 42px;
    padding: 12px 0;
    background: #fff;
    color: #fff;
    display: block;
    border-top: 1px solid #76A4DF;
    border-left: 1px solid #76A4DF;
    border-bottom: 1px solid #76A4DF;
}
ul.page-numbers li span{
    width: 42px;
    height: 42px;  
    padding: 12px 0;    
    background: #fff;    
    color: #fff;    
    display: block;  
    font-weight: bold;    
    border-top: 1px solid #76A4DF;
    border-left: 1px solid #76A4DF;
    border-bottom: 1px solid #76A4DF;     
}
ul.page-numbers li:last-child{
    border-right: 1px solid #76A4DF;    
}


/*** service ***/
main#service section#price{
    max-width: 1100px;
    margin: 0 auto 108px;
}
main#service p.intro{
    max-width: 1100px;
    margin: 0 auto;
    padding: 5px 0;
    background: #000;
    font-size: 2.4rem;
    font-weight: 600;
    color: #fff;
    display: flex;
    align-items: center;
    letter-spacing: 5px;
    position: relative;
}
main#service p.intro:before{
    content: '';
    width: 173px;
    height: 7px;
    background: #D90000;
    display: block;
    position: absolute;
    left: -50px;
}

section#price .ttl_block{
    margin-top: 78px;
}
section#price .ttl_block h1.ttl2 {
    margin-right: 110px;
}
section#price .ttl_block p{
    width: 665px;
    font-weight: 600;
}

section#price .price_bnr {
    max-width: 1000px;
    margin: 0 auto 63px;
    padding: 31px 0 28px;    
    border: 10px solid #F4F2EE;
    display: flex;
    justify-content: center;
    align-items: center;
}
section#price .price_bnr p.ttl {
    font-size: 2.8rem;
    font-weight: 600;
    color: #E60C0C;
    letter-spacing: 2px;
}
section#price .price_bnr p.price {
    margin: 0px 40px;
    font-family: din-condensed, sans-serif;
    font-size: 11.5rem;
    line-height: 1;
    color: #000;
    font-weight: 600;
    display: flex;
    align-items: center;
    text-align: center;
}

section#price .price_bnr p.price span{
    font-size: 2.8rem;
    letter-spacing: 2px;
}
section#price .price_bnr p.price span > span{
    display: block;
    font-size: 6rem;
}
section#price .price_bnr p.memo {
    font-size: 1.6rem;
    letter-spacing: 5px;
    font-weight: 600;
}

section#price table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 1px;
}

section#price table th{
    padding: 9px 10px 8px;
    background: #E60C0C;
    color: #fff;
}

section#price table td{
    padding: 9px 10px 8px;    
    border: 1px solid #E6E0D7;
    font-size: 1.7rem;
    vertical-align: middle;
}

section#price .price_note p{
    margin-top: 32px;
    margin-bottom: 93px;    
    font-size: 1.8rem;
    line-height: 2;
}

section#price h2 {
    margin-bottom: 69px;
    padding-bottom: 29px;
    font-size: 2.4rem;
    font-weight: 600;
    color: #000;
    letter-spacing: 3px;
    line-height: 1;
    overflow: hidden;
    position: relative;
    display: inline-block;
}
section#price h2:after {
    content: '';
    display: inline-block;
    background: url(../img/ttl_bg3.png)no-repeat bottom right;
    background-size: 100% 100%;
    width: 100%;
    height: 26px;
    position: absolute;
    bottom: 0px;
    left: 0;
}

section#price .overview_block {
    display: flex;
    justify-content: space-between;
}
section#price .overview_block > div p {
    margin-top: 13px;
    display: flex;
    justify-content: center;
    line-height: 2;
}

section#case {
    max-width: 1000px;
    margin: 106px auto 0;
}
section#case article.case_block h2.ttl{
    margin-bottom: 30px;
    background: #fff;
    border: 3px solid #D44856;
    display: flex;
    align-items: center;
    border-radius: 2px;
}
section#case article.case_block h2.ttl span.ttl{
    width: 91px;
    padding-left: 15px;    
    background: url(../img/case_ttl.png)no-repeat left center;
    font-size: 4.0rem;
    font-family: din-condensed, sans-serif;
    line-height: 0.8;
    color: #fff;
}
section#case article.case_block h2.ttl span.ttl > span{
    display: block;
    font-size: 1.8rem;
    line-height: 1;
}
section#case article.case_block h2.ttl span.txt{
    width: 900px;
    padding: 0px 10px 0 15px;    
    font-size: 2.2rem;
    font-weight: 600;
}
section#case article.case_block > .txt_block{
    padding-left: 110px;        
    font-size: 1.6rem;
}
section#case article.case_block > .txt_block p{
    margin-bottom: 25px;
}

section#case article.case_block .voice_block{
    margin: 72px 0 92px;
    padding: 20px 55px 16px 50px;    
    border-radius: 20px;
    box-shadow: 0 0 15px #ccc; 
    display: flex;
    justify-content: space-between;
}

section#case article.case_block .voice_block h2.ttl2{
    margin-bottom: 16px;
    position: relative;
    display: inline-flex;    
    align-items: center;
    justify-content: space-between;
}
section#case article.case_block .voice_block h2.ttl2 .txt {
    display: inline-block;
    margin-left: 25px;
    padding-top: 15px;
    letter-spacing: 3px;
    font-size: 2.2rem;
    font-weight: 600;
    color: #D44755;
}

section#case article.case_block .voice_block h2.ttl2:after{
    content: '';
    background: url(../img/ttl_voice.png)no-repeat top;
    width: 100%;
    height: 5px;
    display: inline-block;
    position: absolute;
    bottom: 16px;
    z-index: -1;    
}
section#case article.case_block .voice_block .txt_block{
    width: 609px;
}
section#case article.case_block .voice_block .txt_block p{
    font-size: 1.6rem;
}

section#case article.case_block .voice_block .img_block{
    width: 231px;
    
}

section#advertising {
    max-width: 1100px;
    margin: 0 auto;
}

section#advertising p.intro span.logo{
    font-family: 'mono966', sans-serif;    
    font-size: 1.8rem;
}
section#advertising p.intro span.logo > span{
    color: #E60C0C;
}

section#advertising p.tac.fontL {
    margin: 50px 0 48px;
    font-size: 3.2rem;
    font-weight: 600;
    color: #3E3E3E;
    font-family: 'ヒラギノ角ゴ Std';
}

section#advertising > div{
    padding: 0 10px;
}

section#advertising > div p{
    margin-bottom: 34px;
}



@media screen and (max-width:768px) {
    main#service section#price{margin: 0 auto 21px;}
    main#service p.intro{
        width: 90%;
        max-width: 1100px;
        padding: 5px 10px 5px 40px;
        font-size: 2rem;
        letter-spacing: 3px;
        line-height: 1.8;
    }
    main#service p.intro:before{
        width: 43px;
        left: -20px;
        top: 25px;
    }
    section#price .ttl_block{
        margin-top: 38px;
        margin-bottom: 30px;    
        display: block;
    }
    section#price .ttl_block h1.ttl2{
        margin-right: 0;
        margin-bottom: 10px;
    }
    section#price .ttl_block p{
        width: 100%;
    }
    
    section#price .price_bnr{
        margin: 0 auto 43px;
        padding: 11px 0 14px;    
        display: block;
        text-align: center;    
    }
    section#price .price_bnr p.ttl{
        font-size: 2.3rem;
    }
    section#price .price_bnr p.price{
        margin: 10px 0 0;
        justify-content: center;
        font-size: 9.0rem;
    }
    section#price .price_bnr p.price span{
        font-size: 2rem;    
    }
    section#price .price_bnr p.price span > span{font-size: 5.1rem;}
    section#price .price_bnr p.memo{
        font-size: 1.4rem;
        letter-spacing: 2px;
    }
    
    section#price table td{
        font-size: 1.4rem;    
    }
    
    section#price .price_note p{
        font-size: 1.6rem;
        margin-bottom: 43px;    
    }
    
 
    section#price h2{
        margin-bottom: 34px;
        font-size: 2rem;    
    }
    
    section#price .overview_block{
        flex-wrap: wrap;
    }
    section#price .overview_block > div{
        width: 48%;
        margin-bottom: 30px;
    }
    section#price .overview_block > div p{
        font-size: 1.4rem;
        line-height: 1.7;    
    }
    
    section#case{
        width: 96%;
        margin: 0 auto;
    }
    section#case article.case_block h2.ttl{
        margin-bottom: 15px;    
        align-items: baseline;            
    }
    section#case article.case_block h2.ttl span.ttl{
        font-size: 3.5rem;    
    }
    section#case article.case_block h2.ttl span.txt{
        width: 77%;
        padding: 0px 5px 0 10px;
        font-size: 1.8rem;
        line-height: 1.3;
    }
    section#case article.case_block > .txt_block{
        padding-left: 0;    
    }
    section#case article.case_block .voice_block{
        margin: 32px 0 52px;
        padding: 20px 15px 16px;
    }

    section#case article.case_block .voice_block .txt_block{width: 100%;}
    section#case article.case_block .voice_block h2.ttl2:after{
        bottom: 6px;    
    }
    section#case article.case_block .voice_block h2.ttl2 .txt{
        font-size: 2rem;
        margin-left: 15px;
    }
    section#case article.case_block .voice_block h2.ttl2 span.ttl {
        width: 60px;
    }
    
    section#case article.case_block .voice_block .img_block{
        width: 60%;
        max-width: 231px;
        margin: 20px auto;
    }
    
    section#advertising p.tac.fontL{
        margin: 20px 10px 25px;
        font-size: 2.2rem;    
    }
    section#advertising > div p{
        margin-bottom: 20px;
    }
}

/*** event ***/
main#event .breadcrumbs{
    margin-bottom: 74px;
}

main#event section#event-list{
    padding: 115px 0 0;    
    background: none;
}

main#event section#strenhths{
    background: none;
}

main#event section#flow{
    padding-bottom: 74px;    
    background: none;
}

p.intro {
    margin-top: 34px;
    display: flex;
    justify-content: center;
    font-weight: 600;
    line-height: 2;
}

@media screen and (max-width:768px) {
    main#event section#event-list{
        padding: 48px 0 0;    
    }
    p.intro{
        margin-top: 24px;
    }
}

section.point {
    margin-top: -86px;
    margin-bottom: 188px;    
}

.point_block {
    max-width: 1120px;
    margin: 0 auto 70px;
}

.point_block .df{
    justify-content: space-between;
    align-items: flex-end;    
}

.point_block .txt_block{
    width: 560px;    
}
.point_block h2 {
    margin-bottom: -5px;    
}
.point_block h2 span.ttl {
    margin-bottom: 21px;
    display: block;
}
.point_block h2 span.txt{
    font-size: 2.6rem;
    font-weight: 600;
    line-height: 1;
}

.point_block .txt_block p{
    margin-top: 18px;
    line-height: 1.5;
    font-weight: 600;
}

.point_block .img_block{
    width: 500px;
    height: 375px;
}
.point_block .img_block img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}





section#topix{
    margin-top: -40px;
}
section#topix article.list_block{
    margin-right: 34px;
    margin-bottom: 100px;
    width: 260px;
}

section#topix article.list_block .img{
    height: 180px;    
}

section#topix .moreBtn{justify-content: center;}
section#topix .moreBtn a{
    width: 265px;    
}

.page-template section#event-list{
    padding: 100px 0 0;
    background: none;
}




/*** guide ***/
section#guide{
    max-width: 1120px;
    margin: 0 auto;
}
section#guide .flow_block {
    margin-bottom: 100px;
    display: flex;
    position: relative;
    padding: 0px 35px;
    align-items: flex-start;
}

section#guide .flow_block:after{
    content: '';
    background: #D90000;
    width: 100%;
    height: 54px;
    display: block;
    position: absolute;
    bottom: 19px;
    left: 0;
}

section#guide .flow_block h2{
    height: 275px;
    padding: 40px 10px 10px;
    margin-right: 46px;
    writing-mode: vertical-rl;
    color: #3E3E3E;
    font-weight: 600;
    background: #F4F4F4;
    position: relative;
    z-index: 1;
    letter-spacing: 4px;
}
section#guide .flow_block h2:after{
    content: '';
    background: url(../img/flow_arrow.png)no-repeat;
    background-size: 100%;
    width: 50px;
    height: 48px;
    display: block;
    position: absolute;
    bottom: -44px;
    left: 0;
}
section#guide .flow_block.last h2:after{
    display: none;
}

section#guide .flow_block h2 span.sub {
    width: 56px;
    margin: 0 3px 0 2px;
    font-size: 2.4rem;
    font-family: abolition, sans-serif;
    color: #D90000;
    writing-mode: initial;
    position: absolute;
    display: inline-block;
    font-weight: 500;
    letter-spacing: 0;
    text-align: center;
    top: 0;
    left: -5px;
}

section#guide .flow_block .df {
    display: flex;
    align-items: center;
    z-index: 1;
}
section#guide .flow_block .df .img{
    width: 400px;
    max-width: 400px;
}

section#guide .flow_block .df p.txt {
    width: 565px;
    padding-left: 58px;
    letter-spacing: 2px;
}

@media screen and (max-width:768px) {
    section#guide .flow_block{
        margin-bottom: 37px;
        padding: 0px 15px;
    }
    section#guide .flow_block:after{
        height: 28px;    
        top: 133px;
        bottom: auto;
    }
    section#guide .flow_block .df{
        flex-wrap: wrap;
    }
    section#guide .flow_block h2{
        height: 195px;    
        padding: 35px 5px 10px;   
        margin-right: 26px;
    }
    section#guide .flow_block h2:after{
        width: 37px;
        height: 35px;
        bottom: -35px;
        left: 0;
    }
    section#guide .flow_block h2 span.sub{
        margin-right: 16px;
        font-size: 2rem;
        left: -11px;    
    }
    
    section#guide .flow_block p.sub{
        margin: 0;
        font-size: 2rem;
    }
    section#guide .flow_block .df .img{
        width: 100%;
    }
    section#guide .flow_block .df p.txt{
        width: 100%;
        padding-left: 10px;
        letter-spacing: 1px;
        margin-top: 10px;
    }
    
}

/*** faq ***/
body#faq h2.ttl {
    max-width: 1100px;
    margin: 0 auto 58px;
    padding: 0 0 0 50px;
    padding-bottom: 10px;
    color: #000;
    font-size: 2.6rem;
    font-weight: 600;
    position: relative;
}

body#faq h2.ttl:before{
    content: '';
    width: 10px;
    height: 50px;
    background: #000;
    display: inline-block;
    margin-right: 13px;
    font-size: 2.8rem;
    line-height: 1;
    position: absolute;
    left: 20px;
    bottom: -7px;
    z-index: 1;
}
body#faq h2.ttl:after{
    content: '';
    background: linear-gradient(90deg, rgba(255,191,191,1) 0%, rgba(229,0,0,1) 100%);
    width: 100%;
    height: 10px;
    display: block;
    position: absolute;
    left: 0;
}

body#faq .faq_wrap{
    max-width: 954px;
    margin: 0 auto 85px;
}
body#faq .faq_wrap dl{
    margin: 0 auto 31px;
}

@media screen and (max-width:768px) {
    body#faq h2.ttl{
        margin: 0 auto 34px;
        padding: 0 0 5px 30px;    
        font-size: 2.0rem;
    }
    body#faq h2.ttl:before{
        width: 8px;
        height: 40px;
        margin-right: 5px;
        left: 10px;    
    }
}


/*** company ***/
.company_block dl {
    max-width: 1005px;
    margin: 0 auto 74px;
    display: flex;
    align-items: center;
    font-weight: 600;
    position: relative;    
}
.company_block dl:after{
    content: '';
    background: #fff;
    border: 1px solid #F7B4B4;
    display: block;
    width: 1000px;
    height: 1px;
    position: absolute;
    bottom: 6px;
    left: 5px;
} 

.company_block dt {
    width: 200px;
    background: #E92B2B;
    padding: 1px 0 7px;
    letter-spacing: 3px;
    color: #fff;
    text-align: center;
    font-size: 2.0rem;
}
.company_block dd {
    padding: 1px 0 7px 60px;
    letter-spacing: 3px;
}

#company .company_map {
    margin: 120px auto 6px;
    width: 1076px;
    height: 504px;
}

@media screen and (max-width:768px) {
    .company_block dl{
        margin-bottom: 12px;    
    }
    .company_block dl:after{
        width: 94%;
        max-width: 847px;
        left: 10px;    
    }
    .company_block dt{
        width: 30%;
        max-width: 168px;
        height: 56px;
        padding: 10px 0 0;
        letter-spacing: 0px;
        font-size: 1.6rem;   
    }    
    .company_block dd {
        width: 70%;
        height: 56px;
        padding: 1px 10px 0 10px;
        display: flex;
        align-items: center;  
        font-size: 1.6rem;
        letter-spacing: 1px;
        line-height: 1.1;
    }
    
    #company .company_map{
        width: 100%;
        max-width: 820px;
        height: 380px;
        margin: 45px auto 0;    
    }
}



/*** お問い合わせ ***/
main#privacy-policy h2 {
    margin-bottom: 6px;
    font-weight: 600;
}
main#privacy-policy p{
    margin: 0 auto 36px;
}

section#terms{
    padding-top: 162px;   
}
section#terms ol{
    margin-top: 10px;    
    margin-bottom: 36px;
}
section#terms ol li {
    margin-bottom: 6px;   
    padding-left: 1em;
    text-indent: -1em;
}

@media screen and (max-width: 768px){

    main#privacy-policy h2{
        font-size: 1.6rem;        
    }
    
    section#terms{padding-top: 40px;}
    section#terms h1 {
        font-size: 1.4rem;
    }
}


/*** お問い合わせ ***/
main#contact h1.ttl2{
    margin-bottom: 43px;    
}


div.wpcf7{
    max-width: 899px;
    margin: 61px auto;
}

div.wpcf7 dl dt{
    margin-bottom: 26px;
    font-size: 2rem;
    font-weight: 600;
    display: flex;
    align-items: center;   
}
div.wpcf7 dl dt span{
    width: 48px; */
    display: inline-block;
    font-size: 1.6rem;
    line-height: 1;
    color: #FF0000;
}

div.wpcf7 dl dd{
    margin-bottom: 46px;
}
div.wpcf7 dl dd p {
    margin: 19px 0 6px;
}

.wpcf7-list-item{
    margin: 0 1em 3px 0;
}

div.wpcf7 dl dd input[type="text"],
div.wpcf7 dl dd input[type="email"],
div.wpcf7 dl dd input[type="url"],
div.wpcf7 dl dd textarea,
div.wpcf7 dl dd select{
    width: 100%;
    padding: 10px 15px 10px;
    background: #FFF4F4;
    border: 1px solid #F0F0E1;
    border-radius: 8px;
    font-size: 1.8rem;
}

div.wpcf7 dl dd textarea {   
    height: 290px;
}

div.wpcf7 p.acceptance span.wpcf7-list-item {
    margin: 34px 0 80px;
    display: flex;
    justify-content: center;
    font-size: 2.0rem;
    font-weight: 700;
    font-style: normal;    
}
div.wpcf7 p.acceptance span.wpcf7-list-item a{
    color: #005FAC;
    border-bottom: 1px solid #005FAC;
}

div.wpcf7 .submitBtn{
    width: 428px;
    margin: 0 auto;
    position: relative;    
}
div.wpcf7 input[type="submit"]{
    width: 100%;
    padding: 21px 0 22px;
    background: #D90000;
    font-size: 1.8rem;
    font-weight: 700;
    color: #fff;
    text-align: center;
    letter-spacing: 2px;
    border-radius: 8px;
    border-bottom: 4px solid #FFCFBF;
}
div.wpcf7 .submitBtn:after {
    content: '';
    background: url(../img/icon_arrow.webp)no-repeat;
    background-size: 100%;
    width: 10px;
    height: 22px;
    display: block;
    filter: invert(99%) sepia(99%) saturate(2%) hue-rotate(268deg) brightness(108%) contrast(100%);
    position: absolute;
    top: 26px;
    right: 23px;
}

placeholder::{color: #CCCCCC;}


@media screen and (max-width: 768px){
    div.wpcf7{margin: 31px auto 0;}
    div.wpcf7 dl dt{
        margin-bottom: 6px;
        font-size: 1.6rem;    
    }
    div.wpcf7 dl dt span{
        font-size: 1.4rem;    
    }
    
    div.wpcf7 dl dd {margin-bottom: 20px;}
    div.wpcf7 dl dd input[type="text"], div.wpcf7 dl dd input[type="email"], div.wpcf7 dl dd textarea{
        padding: 10px 10px 12px;    
        font-size: 1.6rem;
    }
    
    div.wpcf7 dd.ml{
        margin-left: 10px;
    }
    div.wpcf7 dd.checkbox span.wpcf7-list-item{
        width: 100%;
    }
    div.wpcf7 dd.checkbox span.wpcf7-list-item.last{
        width: 100%;
    }
    div.wpcf7 input.wpcf7-form-control.wpcf7-text.etc{
        width: 90%;    
        position: relative;
        top: 0;
        left: 20px;
    }
        
    div.wpcf7 p.acceptance span.wpcf7-list-item{
        margin: 26px 0 31px;
        font-size: 1.6rem;
    }
    
    div.wpcf7 .submitBtn{
        width: 80%;
        max-width: 428px;
    }
    
    div.wpcf7 input[type="submit"]{
        padding: 11px 0 12px;
        font-size: 1.8rem;
    }
    div.wpcf7 .submitBtn:before{border-bottom: 60px solid #FFAD39;}
    div.wpcf7 .submitBtn:after{
        width: 10px;
        height: 18px;
        top: 15px;
    }
    
}


/*** アーカイブ一覧 ***/
main#news h1.ttl2{
    margin-bottom: 74px;
}


section.twoColumn{
    max-width: 1108px;
    margin: 0 auto 125px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.left_Column{
    width: 758px;
}

#archive_block {
    display: flex;
    flex-wrap: wrap;
}

article.list_block{
    width: 320px;
    margin-right: 59px;
    margin-bottom: 59px;
}
article.list_block .img {
    width: 100%;
    height: 221px;
}

article.list_block .img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

article.list_block p.cate {
    font-size: 1.4rem;
}
article.list_block p.cate a {
    background: #D90000;
    color: #fff;
    padding: 6px;
}
article.list_block time.day{
    color: #D90000;
    font-weight: 600;}
article.list_block .date {
    margin-top: -12px;
    margin-left: 10px;
}

article.list_block h2 {
    margin: 10px;
    font-size: 1.6rem;
    line-height: 1.5;
}

@media screen and (max-width:768px) {
    main#news h1.ttl2{
        margin-bottom: 38px;    
    }
    
    section.twoColumn{
        margin: 0 auto 50px;    
        display: block;
    }
    .left_Column{width: 100%;}
    
    #archive_block{
        justify-content: space-between;
    }
    
    article.list_block{
        width: 48%;
        margin: 0 0 30px;    
    }
    
    article.list_block p.cate{font-size: 1.2rem;}
    article.list_block time.day{font-size: 1.4rem;}
    article.list_block .img{height: 130px;}
    article.list_block h2{
        margin: 5px 10px;
        font-size: 1.4rem;
    }
 
    
}

/********* sidebar *********/
#sidebar {
    width: 30%;
    max-width: 300px;
    margin: -109px -11px;    
    padding-bottom: 14px;
    background: #F4F2EE;
}
#sidebar h2.ttl2{
    margin: -31px 0 6px 12px;
    font-family: 'mono966', sans-serif;
    font-size: 3.6rem;
    line-height: 1;
    letter-spacing: 9px;
    color: #000;   
}

#sidebar h3 {
    margin-left: 18px;
    margin-bottom: 14px;
    font-size: 1.6rem;
    font-weight: 600;
}

aside#search {
    width: 235px;
    margin: 0px 10px 21px;
    position: relative;
}
.wp-block-search__inside-wrapper{
    -webkit-appearance: initial;
    appearance: none;
    flex-grow: 1;
    margin-left: 0;
    margin-right: 0;
    min-width: 3rem;
    text-decoration: unset!important;
    padding: 4px 5px 4px 15px!important;
    box-shadow: 0 0 8px 2px #e8e8eb;
    border-radius: 50px;
    border: 1px solid #CAF4FB;
    font-size: 1.6rem;
    background: #fff;    
}

button.wp-block-search__button.has-icon.wp-element-button{
    border: none;
    width: 60px;
    height: 32px;
    background: none;
}
button.wp-block-search__button.has-icon.wp-element-button:before {
    content: '';
    background: url(../img/icon_search.png)no-repeat;
    width: 26px;
    height: 26px;
    display: block;
    position: absolute;
    top: 8px;
    right: 10px;
}

.wp-block-search__button svg{
    display: none;
}

#sidebar ul.list {
    margin-left: 18px;
}
#sidebar ul.list li{margin-bottom: 10px;}
#sidebar ul.list li a {
    font-size: 1.6rem;
    color: #D90000;
    font-weight: 600;
}

#sidebar ul.list2{
    margin: -4px 60px 18px 18px;    
}

#sidebar ul.list2 li{
    padding: 3px 0 4px;
    border-bottom: 2px solid #EEE;
}
#sidebar ul.list2 li:last-child{border-bottom: none;}
#sidebar ul.list2 li a {
    font-size: 1.6rem;
    padding: 3px 0;
}

#sidebar .bnr {
    width: 280px;
    margin: 0 auto 40px;    
    position: relative;
}
#sidebar .bnr a{
    background: linear-gradient(90deg, rgba(218,3,3,1) 0%, rgba(255,191,191,1) 100%);
    padding: 8px 10px 0px;
    width: 100%;
    display: block;
    font-size: 1.6rem;
    color: #fff;
}
#sidebar .bnr span{
    display: block;
    color: #FEBABA;
    font-family: abolition, sans-serif;
    font-size: 2.4rem;
    letter-spacing: 3px;
    line-height: 1;
}

#sidebar .bnr a:after {
    content: '';
    background: url(../img/icon_arrow.webp)no-repeat;
    background-size: 100%;
    margin-left: 16px;
    width: 14px;
    height: 26px;
    display: block;
    filter: invert(99%) sepia(99%) saturate(2%) hue-rotate(268deg) brightness(108%) contrast(100%);
    position: absolute;
    top: 20px;
    right: 10px;
}

#sidebar article.list_block{
    width: 260px;
    margin: 0 auto 39px;
}

#sidebar article.list_block .img{
    height: 180px;
}

#sidebar .moreBtn2{
    width: 260px; 
    margin: 0 auto;
    text-align: right;}
#sidebar .moreBtn2 a{
    color: #D90000;
    font-weight: 600;
    border-bottom: 1px solid #D90000;
    
}
#sidebar .moreBtn2 a:after{
    content: '>';
    display: inline-block;
    margin-left: 5px;
}

@media screen and (max-width:768px) {
    #sidebar{
        width: 100%;
        max-width: 100%;
        margin: 100px auto 0;
        padding: 10px 0 10px;     
    }
    
    #sidebar aside.news{
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;    
    }
    
    #sidebar article.list_block{
        width: 48%;
        margin: 0 auto 28px;
    }
    #sidebar article.list_block .img{
        height: 110px;
    }
    
    #sidebar .moreBtn2{
        width: 96%;    
    }

}