@charset "utf-8";
/* CSS Document */
.tfz_koso_set.tfz_koso_ex01 .tfz_koso_txt{
    flex: 0 0 auto;
    width: auto;
}
h1.tfz_koso_heading1{
    font-size: clamp(1.25rem, 3.7vw, 40px);
}
span.tfz_koso_br{
    display: block;
}

.tfz_koso_list {
    position: relative;
    padding: 2% 3%;
    flex: 0 0 auto;
}
p.tfz_koso_list_t {
    font-size: 1rem;
    margin-bottom: 14px;
}
ul.tfz_koso_list_cont{
    grid-template-columns: repeat(1, 1fr);
}
ul.tfz_koso_list_cont li {
    margin-bottom: 4px;
}
.tfz_koso_img.tfz_koso_img-adj {
    position: absolute;
    top: 39%;
    right: 3%;
}

.tfz_koso_txt.tfz_koso_txt_adj{
    width: 100%;
}



span.tfz_koso_deco01{
    display: block;
    height: 2px;
    border-bottom: 0.5px solid transparent;
    background-image: linear-gradient(to right, #97071A 3px, transparent 2px);
    background-size: 5px 0.5px;
    background-repeat: repeat-x;
    background-position: left bottom;
  }  
ul.tfz_koso_tile_cont {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 2%;
}
ul.tfz_koso_tile_cont li {
    background-color: #FDE9DE;
    padding: 1% 5% 8% 5%;
}
p.tfz_koso_tile_t {
    font-size: 1.5rem;
    color: #AA1923;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 87px;
    line-height: calc(30/24);
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}
p.tfz_koso_tile_p {
    font-size: 0.875rem;
    margin-top: 18px;
    font-weight: 600;
}


h3.tfz_koso_heading3 {
    position: relative;
    font-size: 1.75rem;
    color: #AA1923;
    font-weight: 500;
    width: 100%;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(#97071A 1px);
    background-size: 100%;
    background-position: center;
    margin-bottom: 32px;
}
h3.tfz_koso_heading3 span {
    position: absolute;
    display: inline-block;
    background-color: #FFFFFF;
    padding-right: 3%;
    top: -21px;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}
.tfz_koso_author {
    padding-top: 32px;
}
p.tfz_koso_authorname {
    position: relative;
    padding-left: 28px;
}
p.tfz_koso_authorname::after {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    background-color: #97071A;
}
.tfz_koso_author >*:nth-last-of-type(n + 2) {
    margin-bottom: 10px;
}
.tfz_koso_author_p{
    font-size: 0.75rem;
}




@media screen and (max-width:820px){
    .tfz_koso_set.tfz_koso_ex01 .tfz_koso_txt{
        text-align: center;
        width: 100%;
    }
    span.tfz_koso_br {
        display: inline-block;
    }
    .tfz_koso_set.tfz_koso_ex01 {
        flex-wrap: wrap;
    }
    .tfz_koso_img {
        margin: 0 auto;
        text-align: center;
        width: 25%;
    }
    .tfz_koso_img.tfz_koso_img-adj{
        display: none;
    }
    .tfz_koso_list{
        max-width: 100%;
        width: 100%;
    }
    ul.tfz_koso_list_cont{
        grid-template-columns: repeat(2, 1fr);
    }
    p.tfz_koso_tile_t{
        height: clamp(3.375rem, 1.583rem + 6.67vw, 5rem);
    }
    p.tfz_koso_tile_t{
        font-size: clamp(1.125rem, 0.689rem + 1.62vw, 1.5rem);
        /* 18-24 430-800 */
    }
    p.tfz_koso_authorname{
        font-size: clamp(1rem, 0.862rem + 0.51vw, 1.125rem);
    }
}


@media screen and (max-width:640px){
    .tfz_koso_set.tfz_koso_ex01 .tfz_koso_txt,
    .tfz_koso_set.tfz_koso_ex02 .tfz_koso_txt{
        width: 100%;
    }

    .tfz_koso_author {
        padding-top: 8vh;
    }
}