@charset "utf-8";
/* CSS Document */
.titlebox{
    margin-bottom: 30px;
}
.cate2{
    background: #F8F8F8;
}
.cate3{
    border-bottom: 1px solid #DDDDDD;
}
.boxwrap1 {
  display: flex;
  align-items: flex-start;   /* 上揃え */
  gap: 80px;
  width: 100%;
  margin: 0 auto;
    max-width: 1280px;
}

/* 左：画像カラム */
.boxwrap1 .imgbox {
  flex: 0 0 320px;
  max-width: 320px;
}

.boxwrap1 .imgbox img {
  display: block;
  width: 100%;
  height: auto;
}

.boxwrap1 .txtbox {
  flex: 1;       /* ← 残ったぶん全部ここが受け取る */
  min-width: 0;  /* ← 中身長くてもはみ出さず折り返す保険 */
  /* width は書かない！ */
}

.company_b1 .company-wrap {
    max-width: 900px;
    margin: 0 auto;
    padding: 0px;
    position: relative;
}
.company_b1 .company-wrap::before {
    content: "";
    position: absolute;
    top: 0px;
    left: 30%;
    width: 1px;
    height: 100%;
    background: #AAAAAA;
}
.company_b1 .company-wrap .item {
    display: flex;
    align-items: flex-start;
    gap: 0;
    padding: 18px 0;
}
.company_b1 .company-wrap .item .label {
    flex: 0 0 33%;
    padding-right: 24px;
    line-height: 1.8;
}
.company_b1 .company-wrap .item > div {
    flex: 1;
    padding-left: 60px;
    line-height: 1.9;
    color: #374151;
}
.company_b1 .company-wrap .item:last-child {
    padding-bottom: 32px;
}
@media screen and (max-width: 576px) {
    .company_b1 .company-wrap::before {
        display: none;
    }
    .company_b1 .company-wrap .item {
        display: block;
        padding: 14px 0;
    }
    .company_b1 .company-wrap .item .label {
        flex: none;
        padding-right: 0;
        margin-bottom: 6px;
    }
    .company_b1 .company-wrap .item > div {
        padding-left: 0;
    }
}

.history_a1{
    justify-content: flex-start;
}
.history_a1 .history-list {
  position: relative;
  border-left: 2px solid #ccc;
  padding-left: 30px; /* この30pxぶんだけ中身が右にズレる */
}

.history_a1 .history-item {
  position: relative;
  margin-bottom: 30px;
  display: flex;
  align-items: flex-start;
gap: clamp(20px, 4vw, 50px);

}

/* year は普通でOK */
.history_a1 .year-wrap .year {
  white-space: nowrap;
  position: relative;
      font-family: "Zen Old Mincho", serif;
}

/* 丸は「リストの左線」基準の位置に置くイメージで調整 */
.history_a1 .history-item .year-wrap .year::before {
  content: "";
  position: absolute;
  left: calc(-30px - 8px);
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background-color: #A89778;
}


.cate1{
    max-width: 1280px;
margin: auto;
}
.cate1 .boxwrap {
  gap: 60px;
  position: relative;
  padding-bottom: 30px;
}

/* 左：テキスト側 */
.cate1 .txtbox {
  flex: 1;
  min-width: 0;
}


/* 見出しキャッチ */
.cate1 .catchcopy {
  font-size: clamp(26px, 3vw, 32px);
  line-height: 2;
  margin: 0;
}

.cate1 .catchcopy_sub {
  font-size: clamp(22px, 2.4vw, 26px);
  line-height: 2;
  margin: 0;
  position: relative;
}

/* 本文 */
.cate1 .bodytext p {
  line-height: 2;
}

/* 署名 */
.cate1 .sign {
  margin-top: 40px;
  text-align: right;
}

.cate1 .sign .role {
  margin-right: 12px;
  font-size: 14px;
}

.cate1 .imgbox {
  width: 40%;
  max-width: 420px;
  box-sizing: border-box;
}

.cate1 .imgbox img {
  width: 100%;
  height: auto;
  display: block;
}

/* スマホ対応 */
@media (max-width: 768px) {
  .cate1 .boxwrap {
    flex-direction: column;
    gap: 30px;
  }

  .cate1 .imgbox {
width: 100%; 
      max-width: 1000px;
  }

  .cate1 .sign {
    text-align: left;
  }
}



/* ---------- pagelinks_d ---------- */
.pagelinks_d{
	gap: 70px;
}
.pagelinks_d a {
  display: block;
  text-decoration: none;
  border: 1px solid #d9d9d9;
  background-color: #fff;
  padding: 14px 40px;
  min-width: 220px;             /* ボックスの横幅（お好みで） */
  box-sizing: border-box;
  transition: background 0.25s ease, border-color 0.25s ease,
              box-shadow 0.25s ease, transform 0.25s ease;
}
.pagelinks_d a > .flex{
	gap: 20px;
}

.pagelinks_d i{
	color: #433213;
	font-size: 10px;
	transition: ease 0.3s;
}
.pagelinks_d a:hover i {
    transform: translateY(3px);
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
      .boxwrap1 {
    flex-direction: column;
    gap: 40px;
  }

  .boxwrap1 .imgbox,
  .boxwrap1 .txtbox {
width: 100%;
    flex: none;
  }
    
/* ---------- pagelinks_d ---------- */


}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
/* ---------- pagelinks_d ---------- */
	.pagelinks_d{
		gap: 50px;
	}
	.pagelinks_d a > .flex{
		gap: 15px;
	}

/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
    .history_a1 .history_a1{
        width: 90%;
    }
    .history_a1 .history-item::before {
        width: 10px;
        height: 10px;
        left: -2.25em;
    }
    
/* ---------- pagelinks_d ---------- */
	.pagelinks_d{
		gap: 30px;
	}
	.pagelinks_d a > .flex{
		gap: 10px;
	}
	.pagelinks_d a > .flex .more-icon{
		width: 18px;
	}
	.pagelinks_d a > .flex .more-icon i{
		font-size: 8px;
	}
	.pagelinks_d a p{
		font-size: 16px;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

