﻿
/* all */
.wrap{overflow: hidden;}
body{
    font-size: 16px;
    line-height: 2;
    font-family: '繝偵Λ繧ｮ繝手ｧ偵ざ ProN W3', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif!important;
}

/* color */
:root{
    --color1: #008DD4;
    --color2: #cdcdcd;
    /* --color3: #175287; */
    --color4: #E6E6E6;
	--black: #343434;
	--red: #d32020;
}

body, .txt_color_nomal, .hvr_txt_color_nomal:hover{color: var(--black);}
.linkStyle{transition: 0.5s;color: var(--black);}
.linkStyle:hover{opacity: 0.7;}

.txt_white, .hvr_txt_white:hover{color: white;}
.txt_red, .hvr_txt_red:hover{color: var(--red);}
.txt_gray, .hvr_txt_gray:hover{color: #ccc}
.txt_color1, .hvr_txt_color1:hover{color: var(--color1)} /* メインカラー */
.txt_color2, .hvr_txt_color2:hover{color: var(--color2)} /* サブカラー */
.txt_color3, .hvr_txt_color3:hover{color: var(--color3)} /* アクセントカラー1 */
.txt_color4, .hvr_txt_color4:hover{color: var(--color4)} /* アクセントカラー2 */

/* background-color */
.bg_white, .hvr_bg_white:hover{background-color: white} /* 白背景 */
.bg_black, .hvr_bg_black:hover{background-color: var(--black)} /* 黒背景 */
.bg_gray, .hvr_bg_gray:hover{background-color: #ccc}
.bg_color1, .hvr_bg_color1:hover{background-color: var(--color1)} /* メインカラー */
.bg_color2, .hvr_bg_color2:hover{background-color: var(--color2)} /* サブカラー */
.bg_color3, .hvr_bg_color3:hover{background-color: var(--color3)} /* アクセントカラー1 */
.bg_color4, .hvr_bg_color4:hover{background-color: var(--color4)} /* アクセントカラー2 */
.bg_color_clear, .hvr_bg_color_clear:hover{background-color: transparent!important}
.bg_grad{background-image: linear-gradient(to right, var(--color1), var(--color3));}

/* border-color ※!important */
.border_white, .hvr_border_white:hover{border-color: white}
.border_black, .hvr_border_black:hover{border-color: var(--black)}
.border_gray, .hvr_border_gray:hover{border-color: #ccc}
.border_color1, .hvr_border_color1:hover{border-color: var(--color1)}
.border_color2, .hvr_border_color2:hover{border-color: var(--color2)}
.border_color3, .hvr_border_color3:hover{border-color: var(--color3)}
.border_color4, .hvr_border_color4:hover{border-color: var(--color4)}


/* TOP Blogタブ切り替え -----------------------------------------------------------*/
#top_blog .tab {
  display: flex;
  flex-wrap: wrap;
}
#top_blog .tab li a {
  display: block;
  background: var(--color4);;
  margin: 0 2px;
  padding: 5px 20px;
  color: var(--black);
}
#top_blog .tab li.active a {
  background: #fff;
  color: var(--color1);
  font-weight: bold;
}

/* コンテンツエリア */
#top_blog .area {
  display: none;
  opacity: 0;
  background: rgba(255,255,255,0.8);
  padding: 20px 3%;
}
#top_blog .area.is-active {
  display: block;
  animation: displayAnime 0.5s forwards;
}

/* フェードインアニメーション */
@keyframes displayAnime {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* TOP Blog -----------------------------------------------------------*/
#top_blog{
    /* transform: translateY(-70%);*/
    margin-top: -10%;
}
#top_blog .con_box .top_blog_title{
    box-sizing: border-box;
    width: 100%;
    margin: 0 auto 5px;
    position: relative;
}
#top_blog .con_box .top_blog_title h2{
    font-size: 110%;
}
#top_blog .con_box .top_blog_title p{
    font-size: 70%;
    letter-spacing: 1.5px;
}
#top_blog .con_box .top_blog_title:before{
    content: "";
    position: absolute;
    height: 100%;
    width: 5px;
    background-color: var(--color1);
    background-color: var(--color1);
    left: calc(-3% - 2px);
}
#top_blog .blogListPattern_item a{
    font-size: 85%;
    padding: 5px 10px;
    border-color: var(--color2);
}
#top_blog .blogListPattern_item:last-child a{
    border-bottom: none;
}

#top_blog .con_box .more{
    padding: 0px 0 6px;
    transition: all 0.3s;
    font-size: 90%;
}
#top_blog .con_box .more i,#top_blog .con_box .more span{
    color: var(--color1);
}
#top_blog .con_box .more:hover{
    opacity: 0.6;
}


/* TOP Blog （1366px以下）環境の設-------------------*/
@media screen and (max-width: 1366px){
#top_blog{margin-top: -16%;}

}
/* TOP Blog （1143px以下）環境の設-------------------*/
@media screen and (max-width: 1143px){
#top_blog{margin-top: -10%;}

}

/* TOP Blog タブレット用（780px以下）環境の設-------------------*/
@media screen and (max-width: 768px){
#top_blog{margin-top: -20%;}

}


/* TOP Blog ここからスマホ用（750px以下）環境の設定-------------------*/
@media screen and (max-width: 667px){
    #top_blog{
        z-index: 3;
    }
    #top_blog .top_blog_wrap{
        margin-top: -80px;
    }
    #top_blog .con_box{
        width: 100%;
    }
    /* #top_blog .con_box .top_blog_title:before{
        height: 5px;
        width: 150px;
        left: 50%;
        transform: translate(-50%, 0);
        top: -20px;
    } */
    #top_blog .con_box .top_blog_title{
        padding: 0;
    }
    #top_blog .con_box .top_blog_title h2,#top_blog .con_box .top_blog_title p{
        margin: 0 auto;
        text-align: center;
    }
    
    #top_blog .con_box .more{}
}
/* Blogページャー -----------------------------------------------------------*/
#blog_page .blog_pager li a.txt_color_nomal{
    color: var(--black);
    padding: 10px 20px;
}
#blog_page .blog_pager li a.active{
    background-color: var(--color2);
    border-color: var(--color4);
}


/* Blogページ -----------------------------------------------------------*/

.all_blog_link{
    display: block;
    width: fit-content;
    margin-top: 20px;
}

#blog_page .blog_body{
    width: 100%!important;
}
#blog_cate2 .blog_sub,#blog_cate3 .blog_sub{display: none;}

#blog_page .cate_title.border_grad {
    border-left: solid 10px var(--color1);
}

.cate_list a {
    font-size: min(3.7vw, 22px);
    background: #fff;
    color: var(--color1);
    letter-spacing: 0.3em;
    text-align: center;
    border: 1.5px solid var(--color1);
    transition-duration: 0.3s;
}
.cate_list a:hover {
    color: #fff;
    background: var(--color1);
}

/*Allの時にカテゴリ表示*/
#blog_cate2 .blogCate,#blog_cate3 .blogCate{display: none;}
#blog_cate1 .blogListDate{width: 18% !important;}
#blog_cate1 .blogCate{
    width: 10% !important;
    margin-right: 2%;
    box-sizing: border-box;
    font-size: 80%;
    padding: 3px 0;
    text-align: center;
    border-radius: 20px;
    /* border: 1px solid var(--color4); */
    background-color: var(--color4);
}
#blog_cate1 .blogListTitle{width: 70% !important;}

/* プレスリリースのとき */
#blog_cate1 .blogCate.press{
    /* border: 1px solid #d0d9e1; */
    background-color: #deeeff;
    color: #165675;
}

/* お知らせのとき */
#blog_cate1 .blogCate.news{}

/* Blogページ タブレット用（780px以下）環境の設定-------------------*/
@media screen and (max-width: 768px){
    #blog_cate1 .blogListDate{
        width: 30%!important;
        font-size: 70%;
    }
    #blog_cate1 .blogCate{
        width: 20% !important;
        margin: 0% 0% 0% 50%;
    }
    #blog_cate1 .blogListTitle{width: 100%!important;}
}


/* Blogページ ここからスマホ用（750px以下）環境の設定-------------------*/
@media screen and (max-width: 667px){
    
    #blog_page .cate_title.border_grad{}
    #blog_page .blogListDate{
        font-size: 80%;
        opacity: 0.6;
    }
    
    #blog_cate1 .blogListDate{width: 50%!important;}
    #blog_cate1 .blogCate{
        width: 36% !important;
        margin: 0% 0% 0% 14%;
        font-size: 60%;
    }
}


/* ▼お問い合わせフォーム▼ */
.check_wrap .visually-hidden {
    display: none;
}
.check_wrap label {
    cursor: pointer;
}
.radio_wrap label::before, .radio_wrap label::after, .check_wrap label::before, .check_wrap label::after {
    content: "";
    display: block;
    position: absolute;
}
.check_wrap label::before {
    transform: translateY(-50%);
    top: 50%;
    border: none;
    background-color: var(--color4);
    width: 20px;
    height: 20px;
    left: 0;
    transition: 0.2s;
    border-radius: 2px;
}
.check_wrap.custom input:checked + label::before {
    background-color: var(--color1);
    border-color: var(--color1);
}
.check_wrap label::after {
    opacity: 0;
    width: 10px;
    height: 5px;
    left: 5px;
    transition: 0.2s;
    border-left: solid 2px #fff;
    border-bottom: solid 2px #fff;
    top: 6px;
    transform: translateY(-50%) rotate(-45deg);
}
.check_wrap.custom label::after {
    top: calc(50% - 2px);
}
.radio_wrap input:checked + label::after, .check_wrap input:checked + label::after {
    opacity: 1;
}

#form_box input, textarea#content {
    padding: 9px 12px;
    width: 100%;
    font-size: 1.6rem;
    /* color: #d0d0d0; */
    border: 1px solid var(--color1);
}
select#inquiry{
    padding: 9px 12px;
    width: 100%;
    font-size: 1.6rem;
    /* color: #d0d0d0; */
    border: 1px solid var(--color1);
}
/* ▲お問い合わせフォームここまで▲ */

/* 崩れ調整 */
#primary{text-align: center;}
#primary #blog_page, #primary .blogList1{text-align: left;}

/* （1294px以下）-------------------*/
@media screen and (max-width: 1294px){
.container {max-width: 1280px;min-width: auto;}

}

/* 2025.08.12追加-------------------*/
#header .header-nav{
    justify-content: flex-end;
}