
/* =========================
blog
========================= */


.blog_item{
width:100%;
margin:0.5rem auto 2rem auto;
padding:1rem 0 2.5rem 0;
overflow:hidden;
}

/* =========================
TOP TEXT
========================= */
.hero_absolute_small{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%, -50%);
z-index:3;
width:100%;
padding:0 1rem;
text-align:center;
box-sizing:border-box;
}
.hero_absolute_small .english span,
.hero_absolute_small h1 span{
display:inline-block;
vertical-align:top;
opacity:0;
animation-duration:.7s;
animation-timing-function:ease;
animation-fill-mode:forwards;
}
.hero_absolute_small h1,
.hero_absolute_small h1 span{
font-size:1.5rem;
letter-spacing:.08em;
line-height:1.5;
color:white;
text-align:center;
margin-top:0.1rem;
}

.hero_absolute_small .english,
.hero_absolute_small p span{
font-size:.95rem;
letter-spacing:.16em;
line-height:1.6;
color:white;
text-align:center;
}

.hero_absolute_small em{
display:block;
margin-top:.8rem;
font-size:.9rem;
letter-spacing:.16em;
line-height:1.4;
color:white;
text-align:center;
}
.hero_absolute_small em span{
letter-spacing:.13em;
}



/*  blog_detail TOP文字 */
.hero_absolute_detail{
position:absolute;
top:8%;
bottom:8%;
left:3%;
right:3%; /* 追加 */
z-index:3;
width:auto; /* 100%をやめる */

padding:3.5rem 2.5rem 0;
box-sizing:border-box;
}
.hero_absolute_detail::before{
content:"";
position:absolute;
inset:0;
border-left:1px solid rgba(199,178,153,.9);
border-top:1px solid rgba(199,178,153,.55);
border-bottom:1px solid rgba(199,178,153,.55);
border-right:0px solid rgba(199,178,153,.9);
transform:scaleY(0);
transform-origin:bottom;
animation:frameGrowY 1.4s cubic-bezier(.22,.61,.36,1) forwards;
}
.hero_absolute_detail::after{
content:"";
position:absolute;
right:0;
bottom:0;
width:55px;
height:55px;
border-right:1px solid rgba(199,178,153,.55);
border-bottom:1px solid rgba(199,178,153,.55);
}
@keyframes frameGrowY{
to{
transform:scaleY(1);
}
}

@keyframes frameGrowX{
to{
transform:translateY(-50%) scaleX(1);
}
}
.hero_absolute_detail .english span,
.hero_absolute_detail h1 span{
display:inline-block;
vertical-align:top;
opacity:0;
animation-duration:.7s;
animation-timing-function:ease;
animation-fill-mode:forwards;
}
.hero_absolute_detail h1,
.hero_absolute_detail h1 span{
font-size:1.7rem;
letter-spacing:.08em;
line-height:1.3;
color:white;
margin-top:0rem;
}

.hero_absolute_detail .english,
.hero_absolute_detail p span{
font-size:.95rem;
letter-spacing:.16em;
line-height:1.6;
color:white;
padding-left:0.1rem;
}

.hero_absolute_detail em{
display:inline-block;
margin-top:0rem;
font-size:1rem;
letter-spacing:1em;
line-height:1.4;
color:white;
background:rgba(153,134,117,0.5);
padding:0.3rem 0.1rem 0.1rem 0.2rem;

}
.hero_absolute_detail em span{
letter-spacing:.22em;
}


/* gold line */
.hero_line2{
display:block;
width:60px;
height:1px;
margin:0 0 0.8rem 0.2rem;
background:linear-gradient(
90deg,
rgba(255,230,140,.95) 0%,
rgba(230,190,70,.7) 35%,
rgba(230,190,70,.25) 70%,
rgba(230,190,70,0) 100%
);
box-shadow:none;
transform:scaleX(0);
transform-origin:left center;
animation:expandLine 2s ease forwards;
animation-delay:.3s;
}

/* =========================
blog sort
========================= */
.blog_count{
display:grid;
grid-template-columns:1fr auto;
justify-content:center;
align-items:center;
padding:0rem 0.7rem;
}
.blog_count h2{
text-align:left;
font-size:1.2rem;
display:block;
color:#a0a0a0;
margin-bottom:-0.2rem;
}
.blog_sort{
display:flex;
justify-content:flex-end;
align-items:center;
gap:1.4rem;
position:relative;
margin:-0.5rem 0.5rem 0rem 0;
}

.blog_sort li a{
position:relative;
display:inline-block;
font-size:1.3rem;
letter-spacing:.08em;
color:#777;
padding:.2rem 0;
transition:.25s;
}

.blog_sort li.on a{
color:#111;
}

.blog_sort li.on a::after{
content:'';
position:absolute;
left:0;
bottom:-1px;

width:100%;
height:1px;

background:#c7b299;
}

.blog_sort li a:hover{
opacity:.7;
}

.blog_ul{
margin-top:1.2rem;
}

/* =========================
staff all display
========================= */
.blog_list_ul{
display:grid;
grid-template-columns: repeat(4,1fr);
gap:12px 8px;
align-items:stretch;
justify-content:center;
text-align:center;
margin:1.5rem auto 4rem;
}

.blog_list_name{
background:width;
padding:0.3rem;
display:flex;
align-items:start;
flex-wrap:wrap;
justify-content:center;
min-height:37px;
}
.blog_list_name h3{
display:inline-block;
font-size:1rem;
font-weight:bold;
letter-spacing:0.02rem;
color:#7a6853;
text-align:left;
}
.blog_list_name span{
width:100%;
margin:0.2rem 0 0 0;
display:block;
font-size:0.8rem;
text-align:right;
letter-spacing:0.02rem;
color:#7f654b;
}


/* =========================
profile link
========================= */

.blog_margin{
margin:2rem 0 0.2rem 0;
}





/* =========================
blog top
========================= */

.hero_top_blog{
position:relative;
width:100%;
height:230px;
overflow:hidden;
background:black;
}

.hero_bg_blog{
position:absolute;
inset:0;
overflow:hidden;
}

/* 白枠 */

/* 黒グラデ */
.hero_bg_blog::after{
content:'';
position:absolute;
inset:0;
z-index:1;

background:
linear-gradient(
90deg,
rgba(0,0,0,.58) 0%,
rgba(0,0,0,.45) 25%,
rgba(0,0,0,.12) 100%
);
}

.hero_img_blog{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
z-index:0;
object-fit:cover;
object-position:center center;
transform:scale(1.12);
}




/* =========================
blog detail
========================= */

.blog_item_detail{
width:100%;
margin:0.8rem auto 2rem auto;
padding:1.2rem 0 2.5rem 0;
overflow:hidden;
}
.blog_detail_top{
width:94%;
margin:auto;
}
.blog_detail{
width:94%;
margin:1.5rem auto;
overflow:hidden;
border:1px solid #f2ece7;
}
.blog_detail_img{
border-radius:3px;
padding:0 2rem 0rem 2rem;
}
.blog_detail_img img{
width:100%;
}
.blog_detail_img p{
text-align:center;
font-size:1rem;
letter-spacing:0.2em;
display:block;
color:#7a6853;
text-align:center;
padding:1.5rem 0rem 1.2rem;
}
.blog_detail_name{
text-align:center;
font-size:1.6rem;
letter-spacing:0.08em;
margin:1.5rem 0 0.7rem;
display:block;
color:#998675;
text-align:center;
}
.blog_detail_meta span{
font-size:1.2rem;
letter-spacing:0.17em;
display:block;
margin:2rem 0 1.5rem 0;
color:#998675;
}
.blog_detail_meta h2{
display:block;
font-size:1.7rem;
line-height:1.6;
letter-spacing:.04em;
margin-bottom:0rem;
color:#998675;
font-weight:bold;
position:relative;
z-index:2;
}
.blog_detail_meta p{
margin-top:2rem;
display:block;
font-size:1.35rem;
line-height:1.8;
letter-spacing:.06em;
position:relative;
z-index:2;
}
.blog_detail_body{
position:relative;
padding-bottom:3.2rem;
}
.profile_absolute{
position:absolute;
right:-5px;
top:5px;
z-index:1;
}
.profile_absolute img{
width:108px;
opacity:0.28;
}
.blog_detail_meta{
width:100%;
display:block;
padding:0 2.5rem 0rem 2.6rem;
}
/* next backナビ */
.blog_nav{
display:flex;
justify-content:center;
gap:1.3rem;
width:94%;
margin:2.3rem auto 0rem;
}

.blog_nav_item{
width:35%;
max-width:200px;
}
.blog_nav_inner{
width:100%;
background:white;
overflow:hidden;
padding:0.5rem;
transition:.25s ease;
border-radius:6px;
}
.blog_nav_inner:hover{
transform:translateY(-3px);
box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.blog_nav a{
display:block;
width:100%;

}

.blog_nav img{
width:100%;
height:100px;
object-fit:cover;
display:block;
object-position:center center;
}
.blog_nav span{
font-size:1.1rem;
letter-spacing:0.13em;
display:block;
text-align:center;
line-height:1.7;
padding:.6rem 0rem 0rem 0;
min-height:30px;
color:#998675;
font-weight:bold;
}
.blog_nav em{
font-size:1.05rem;
letter-spacing:0.17em;
display:block;
text-align:center;
line-height:1.3;
padding:0 0 0.3rem 0rem;
color:#998675;
}

/* ページリンク*/
.blog_detail_links{
width:94%;
display:grid;
gap:14px;
margin:3rem auto 0.5rem;
}
.detail_link{
position:relative;
display:flex;
flex-direction:column;
gap:.45rem;
padding:1.2rem 1.5rem;
text-decoration:none;
overflow:hidden;
transition:.25s ease;
border:1px solid #e5dacf;
background:white;
}

.detail_link::before{
content:"";
position:absolute;
left:0;
bottom:0;
width:0%;
height:1px;
transition:.35s ease;
}

.detail_link:hover{
transform:translateY(-2px);
}

.detail_link:hover::before{
width:100%;
}

.detail_link .english{
font-size:0.9rem;
letter-spacing:.24em;
color:#7c6755;
}

.detail_link span{
font-size:1.2rem;
letter-spacing:.08em;
line-height:1.5;
color:#968477;
font-weight:bold;
}
/* ブログ矢印アイコン*/
.next_icon::after{
content:"";
position:absolute;
right:3px;
top:51%;
width:6px;
height:6px;
border-top:1px solid #c7b299;
border-right:1px solid #c7b299;
transform:translateY(-50%) rotate(45deg);
}
.prev_icon::before{
content:"";
position:absolute;
left:0;
top:51%;
width:6px;
height:6px;
border-top:1px solid #c7b299;
border-left:1px solid #c7b299;
transform:translateY(-50%) rotate(-45deg);
}


.next_icon_detail{
position:relative;
display:block;
}

.next_icon_detail::after{
content:"";
position:absolute;
right:0;
top:-25%;
width:6px;
height:6px;
margin-right:4%;
border-top:1px solid #c7b299;
border-right:1px solid #c7b299;
transform:translateY(-50%) rotate(45deg);
}
.prev_icon_detail{
position:relative;
display:block;

}

.prev_icon_detail::before{
content:"";
position:absolute;
left:0;
top:-25%;
margin-left:4%;
width:6px;
height:6px;
border-top:1px solid #c7b299;
border-left:1px solid #c7b299;
transform:translateY(-50%) rotate(-45deg);
}
/* =========================
tablet〜pcc
========================= */

@media (min-width:768px){


.blog_list_ul{
display:grid;
grid-template-columns: repeat(6,1fr);
}
.staff_padding{
display:flex;
align-items:start;
justify-content:center;
max-width:900px;
width:96%;
margin:auto;
flex-wrap:wrap;
}
.staff_padding_left{
width:45%;
padding-bottom:2%;
}
.staff_padding_right{
width:55%;
padding:2% 0% 2% 1%;
}
.blog_detail_meta p{
font-size:1.25rem;
}
.blog_detail_links{
grid-template-columns:repeat(2, 1fr);
}


}



