@charset "UTF-8";
.panel_item h3 {
    font-size: 32px;
    text-align: center;
    color: var(--blue);
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-bottom: 30px;
}

.image img {
  cursor: pointer;
}

.modal {
  display: none;
  position: fixed;   /* ← ここ重要！ */
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100vw;      /* 全画面に広げる */
  height: 100vh;     /* 全画面に広げる */
  background: rgba(0,0,0,0.8);
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.modal-content {
  max-width: 80%;
  max-height: 80%;
  border-radius: 10px;
  transform: scale(0.7);
  transition: transform 0.3s ease;
}
.modal.show .modal-content {
  transform: scale(1);
}
.close {
  position: absolute;
  top: 20px;
  right: 30px;
  color: #fff;
  font-size: 40px;
  cursor: pointer;
}
#caption {
  margin-top: 10px;
  color: #fff;
  text-align: center;
}


/*---------------------------

tab_area

---------------------------*/
.tab_area{
   padding:130px 0 0; 
    }
.tab_area .tab_wrap{
   
    }
.tab_area .tab_list {
    line-height: 1;
    display: flex;
    }
.tab_area .tab_item {
    padding: 8px 0;
    background: linear-gradient(220deg, #020A5F 0%, #1F51C4 75%);
    color:white;
    text-align: center;
    cursor: pointer;
    /*transition: .4s ease-in-out;*/
    font-size: 16px;
    margin-bottom:-1px;
    font-weight: 600;
    width:25%;
    line-height: 1.2em;
    
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    }

    .tab_area .tab_item a {
      display: block;
      width: 100%;
    }
.tab_area .tab_item img {
  width: 100px;
  margin: 0 auto;
}

.tab_area .tab_text {
  margin-top: 0.3em;
  font-size: 15px;
  line-height: 1.5;
  font-weight: 400;

}
/* タブをクリックした時 ホバーした時 */
/*.tab_item:hover, */.tab_area .tab_item.active {
    background: white;
    border: 1px solid;
    /* border-color: var(--blue) var(--blue) #ffffff; */
    color: var(--blue);
}

/* パネル */
.tab_area .panel_list {
    
}
.tab_area .panel_item {
  display: none;
}
.tab_area .panel_item.active {
  display: block;
  animation: panel-show .9s ease-in-out forwards;
}
/* パネル切り替えのアニメーション */
@keyframes panel-show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}



.tab_area ul {
  
}
.tab_area ul li {
  position: relative;
  color:#fff;
  /*background: linear-gradient(220deg, #020A5F 0%, #1F51C4 75%);*/
  display: flex;
  color: var(--blue);
  margin-top:80px;
  justify-content: space-between;
}


.tab_area ul li .image_area{
  width: 57%;
}
.tab_area ul li .image{
  
}
.gradient-line {
  height: 6px;         /* 線の太さ */
  width: 100%;         /* 横幅いっぱい */
  background: linear-gradient(
    to right,
    var(--blue) 0%,        /* 青 */
    var(--blue) 33%,       /* 途中まで青 */
    #cccccc 33%,       /* ここで切り替え */
    #cccccc 100%       /* 残りはグレー */
  );
    margin-top: -2px;
    z-index: 10;
    position: relative;
}


.tab_area ul li .text_area{
  width: 37%;
}
.tab_area ul li .text_area .title{
    font-size: 26px;
    line-height: 1.2em;
    font-weight: 600;
    margin-bottom: 10px; 
}
.tab_area ul li .text_area .title span{
    font-size: 14px;
    display: block;
    font-family: var(--sub-font);
    color:#8E8B40;
}

.tab_area ul li .text_area .text{
  line-height: 1.6em;
  color: #000;
    margin-bottom:20px;
}


.tab_area ul li .text_area .tag{
  font-size: 14px;
}
.tab_area ul li .text_area .tag .tag_title{
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 8px;

  display: flex;
  align-items: center;
  color: #16347c; /* 文字色（青例） */
}
.tab_area ul li .text_area .tag .tag_title::after {
  content: "";
  flex: 1;
  height: 1px;              /* 線の太さ */
  background: #ccc;         /* 線の色 */
  margin-left: 0.5em;       /* 文字との間隔 */
}
.tab_area ul li .text_area .tag .tag_list{
    margin-bottom:15px;
    line-height: 1.6em;
}
.tab_area ul li .text_area .tag .tag_list span.red{
   color:#CB0003;
}

@media (max-width: 1280px) {
.tab_area .tab_item {
    padding: 5px;
}

}
@media (max-width: 768px) {
.tab_area {
    padding: 80px 0 0;
}
.tab_area .tab_list {
    display: flex;
    /* flex-wrap: wrap; */
}
.tab_area .tab_item {
    border:1px solid var(--blue);
    width:50%;
}

.tab_area .tab_item img {
  width: 80px;
}

.tab_area .tab_text {
  margin-top: 0.7em;
  font-size: 12px;
}

.tab_area .tab_text span {
  display: block;
}




.tab_area .tab_item.active {
    border:1px solid var(--blue);
}
.tab_area .tab_item:nth-child(1){
   
}
.tab_area .tab_item:nth-child(2){
    border-left:none;
}
.tab_area .tab_item:nth-child(3){
   
}
.tab_area .tab_item:nth-child(4){
    border-left:none;
}
.tab_area .tab_item:nth-child(5){
    
}

.tab_area .panel_list {
    
}
.tab_area ul li {
    flex-direction: column;
    margin-top: 50px;
}

.tab_area ul li .image_area {
    width: 100%;
     margin-bottom: 25px;
}
.tab_area ul li .text_area {
    width: 100%;
}
.tab_area ul li .image_area img {
    width: 100%;
}
.tab_area ul li .text_area .title {
    font-size: 18px;
}
}
@media (max-width: 599px) {
.tab_area {
    padding: 70px 0 0;
    }
.tab_area .panel_list {
   
    }
.tab_area .tab_item {
    font-size: 13px;
    justify-content: flex-start;
    }
.tab_area ul {
   
    }
}

/*---------------------------

normal_area

---------------------------*/
.normal_area{
   
    }
@media (max-width: 1280px) {

}
@media (max-width: 1024px) {

}
@media (max-width: 768px) {

}
@media (max-width: 599px) {


}

.panel_item table{
    margin-top:50px;
}
.panel_item td{
    padding-left:10px;
    border: 1px solid #707070;
}
.panel_item table td.category{
    font-weight: 600;
    color:var(--white);
    background: var(--blue);
    text-align: center;
    padding:0;
    width:180px;
    }
.panel_item table td.category2{
    font-weight: 600;
    color:var(--blue);
    width:160px;
    }

@media (max-width: 768px) {
.panel_item table td.category{
    width: 150px;
    }
.panel_item table td.category2{
    width: 140px;
    }


}
@media (max-width: 599px) {
.panel_item table td.category {
    width: 80px;
    }
.panel_item table td.category2 {
    width: 100px;
    }
.panel_item td {
    padding: 4px;
    padding-left: 6px;
}

}
    
