/* =========================
   ABOUT INTRO（What is FamLab8）
   ※このブロックをaboutIntro周りに“丸ごと”使う
========================= */


.aboutIntro__collageImg{ width:100%; height:auto; display:block; }
.aboutIntro__collageImg.is-sp{ display:none; }

@media (max-width: 900px){
  .aboutIntro__collageImg.is-pc{ display:none; }
  .aboutIntro__collageImg.is-sp{ display:block; }
}



.aboutIntro{
  position: relative;
  overflow: hidden; /* 画面が縮むと右画像が隠れていく */
  padding: clamp(170px, 5vw, 180px) 0 10px;
  background: #fff;
}

/* 1200px中央 */
.aboutIntro__inner{
  width: min(1200px, calc(100% - 80px));
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* 左の本文ブロック */
.aboutIntro__content{
  max-width: 720px; /* 読みやすい幅 */
  position: relative;
  z-index: 2;
}

/* 見出し */
.aboutIntro__head{ margin-bottom: 22px; }

.aboutIntro__titleMain{
  margin: 0;
  font-size: clamp(90px, 4.4vw, 100px);
  line-height: 1.05;
  letter-spacing: .02em;
  color: #0A8A3A;
  font-weight: 700;
}

.aboutIntro__titleSub{
  margin: 10px 0 0;
  font-size: 40px;
  font-weight: 700;
  color: #0A8A3A;
}

/* PC：タイトル改行させない */
@media (min-width: 901px){
  .aboutIntro__titleMain{ white-space: nowrap; }
}

/* 右の写真（PCは“右に逃がす”、SPは“タイトル下に通常表示”） */
.aboutIntro__collage{
  margin-top: 0px; /* SPでタイトル直下の余白 */
}

.aboutIntro__collage img{
  width: 85%;
  height: auto;
  display: block;
}

/* キッカー（緑ドット + 英文） */
.aboutIntro__kicker{
  margin: 40px 0 16px;
  display: inline-flex;
  align-items: top;
  gap: 10px;
  font-weight: 700;
  letter-spacing: .02em;
  color: #111;
}

.aboutIntro__kickerDot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #0A8A3A;
  flex: 0 0 10px;
}

.aboutIntro__kickerDot{
  transform: translateY(3px); /* 0〜2pxで好み調整 */
}

/* 大見出し */
.aboutIntro__lead{
  margin: 0 0 58px;
  font-size: clamp(48px, 3.3vw, 50px);
  line-height: 1.15;
  letter-spacing: .06em;
  font-weight: 600;
  color: #111;
}

/* 本文 */
.aboutIntro__body p{
  margin: 0 0 14px;
  line-height: 2.5;
  letter-spacing: .06em;
  color: #222;
}

.aboutIntro__em{
  color: #0A8A3A;
  font-weight: 800;
}

/* C：ロゴ + マップ */
.aboutIntro__brand{
  margin-top: clamp(28px, 4vw, 46px);
  display: flex;
  justify-content: center; /* “真ん中で横並び” */
  align-items: center;     /* 下揃えじゃなく中央揃え */
  gap: clamp(18px, 3vw, 40px);
}

.aboutIntro__brandLogo{
  width: clamp(160px, 18vw, 260px);
  height: auto;
  display: block;
}

.aboutIntro__brandMap{
  width: clamp(180px, 26vw, 300px);
  height: auto;
  display: block;
  opacity: .95;
}

/* =========================
   PC（>=901px）：写真を右へ逃がして“はみ出しOK”
   - Cの右に“少し余白”を挟む
   - 画面が縮むと右が隠れていく（overflow:hiddenでOK）
========================= */
@media (min-width: 901px){

  /* 右画像はabsoluteで右へ（はみ出しOK） */
  .aboutIntro__collage{
    position: absolute;
    top: clamp(90px, 9vw, 130px);
    right: -580px;                 /* ←はみ出し量（ここで調整） */
    width: 540px;
    z-index: 1;
    pointer-events: none;
    margin-top: 0;
  }

  /* Cと右画像の間に余白を作る（本文側の“右側に空き”を確保） */
  .aboutIntro__content{
    padding-right: clamp(24px, 4vw, 60px); /* ←“Cの右に少し余白” */
  }
}

/* =========================
   SP（<=900px）：写真はタイトル下で“はみ出し”
========================= */
@media (max-width: 900px){

  .aboutIntro{
    padding: 34px 0 60px;
  }

  .aboutIntro__inner{
    width: min(1200px, calc(100% - 40px));
  }

.aboutIntro__kicker{
  margin: 45px 0 16px;
  
}	
	
	.aboutIntro__titleMain{
  margin: 50px 0 0;
  font-size: 55px;
  line-height: 1;
 
}

	.aboutIntro__titleSub{
  margin: 10px 0 0;
  font-size: 24px;
}

/* 大見出し */
.aboutIntro__lead{
  margin: 0 0 35px;
}
	
	
	
  /* SP：フル幅はみ出し */
  .aboutIntro__collage{
    position: static;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-top: 18px;
    margin-bottom: 22px;
  }
	
.aboutIntro__collage img{
  width: 100%;
	
}
	
	

  .aboutIntro__content{
    /*max-width: none;*/
	  width: 95%;
	  margin: 0 auto;
    padding-right: 0;
  }

  .aboutIntro__brand{
    gap: 8px;
  }
}


.aboutIntro__kicker{
  display: inline-flex;
  align-items: top;   /* 縦位置を中央に */
  gap: 10px;
  white-space: nowrap;   /* 折り返し禁止（段落ち防止） */
  line-height: 1;        /* 余計な高さでズレないように */
}

/* コラージュ：PC/SPの画像出し分け（強制） */
.aboutIntro__collage .aboutIntro__collageImg.is-sp{ display: none !important; }
.aboutIntro__collage .aboutIntro__collageImg.is-pc{ display: block !important; }

@media (max-width: 900px){
  .aboutIntro__collage .aboutIntro__collageImg.is-pc{ display: none !important; }
  .aboutIntro__collage .aboutIntro__collageImg.is-sp{ display: block !important; }
}


/*------------------------------------------------------------------------------------*/
/* =========================
   ABOUT HISTORY (scoped)
   - PC: green panel max 1200px
   - SP: green panel width ~95%
========================= */

.aboutHistory{
  --green: #0A8A3A;
  --white: #ffffff;
  padding: clamp(22px, 4vw, 56px) 0;
}

.aboutHistory__inner{
  width: min(1200px, calc(100% - 40px));
  margin: 0 auto;
}

.aboutHistory__panel{
  background: var(--green);
  color: var(--white);
  border-radius: clamp(56px, 7vw, 100px);
  padding: clamp(46px, 4vw, 80px)
           clamp(18px, 4vw, 60px)
           clamp(34px, 4vw, 66px);
}

/* ===== Title ===== */
/* PC：左寄せ / 1行固定 */
.aboutHistory__head{
  display: block;
  margin-bottom: clamp(58px, 2.6vw, 60px);
}

.aboutHistory__title{
  margin: 0;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 800;
  letter-spacing: .04em;
  line-height: 1.2;
  white-space: nowrap; /* PCは1行固定 */
}

.aboutHistory__titleMain,
.aboutHistory__titleSub{
  display: inline-block; /* 改行や空白の影響を受けにくく */
  vertical-align: baseline;
}

.aboutHistory__titleMain{
  font-size: clamp(22px, 2.6vw, 40px);
}

.aboutHistory__titleSub{
  margin-left: .6em;
  font-size: clamp(18px, 2.2vw, 34px);
  font-weight: 800;
  letter-spacing: .06em;
}

/* ===== Body ===== */
.aboutHistory__body{
  width: min(1000px, 100%);
  margin: 0 auto;
}

.aboutHistory__intro{
  margin: 0 0 clamp(18px, 2.4vw, 28px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 600;
  line-height: 2.0;
  letter-spacing: .06em;
  font-size: clamp(14px, 1.2vw, 16px);
}

.aboutHistory__hr{
  border: 0;
  height: 1px;
  background: rgba(255,255,255,.18);
  margin: clamp(48px, 2.6vw, 60px) 0;
}

.aboutHistory__block{ margin: 0; }

/* label（● + 太字） */
.aboutHistory__label{
  margin: 0 0 clamp(32px, 2vw, 36px);
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  letter-spacing: .04em;
  font-size: clamp(16px, 1.6vw, 22px);
}

.aboutHistory__dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #fff;
  flex: 0 0 10px;
}

/* list */
.aboutHistory__list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.aboutHistory__list li{
  position: relative;
  padding-left: 18px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: .03em;
  font-size: clamp(14px, 1.2vw, 16px);
  color: rgba(255,255,255,.9);
}

.aboutHistory__list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .85em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.35);
}

/* timeline */
.aboutHistory__timeline{
  display: grid;
  gap: 0px;
}

.aboutHistory__row{
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 10px;
  align-items: start;
}

.aboutHistory__date{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  letter-spacing: .04em;
  font-size: 16px;
  color: #fff;
  white-space: nowrap;
  line-height: 2.0;
}

.aboutHistory__text{
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: .06em;
  font-size: clamp(14px, 1.2vw, 16px);
  color: rgba(255,255,255,.9);
}

/* =========================
   SP
========================= */
@media (max-width: 900px){
  .aboutHistory__inner{
    width: 95%;
  }

  .aboutHistory__panel{
    border-radius: 42px;
    padding: 42px 36px 8px;
  }

  /* SP：中央 / 2行 */
  .aboutHistory__head{
    display: grid;
    place-items: center;
    margin-bottom: 20px;
  }

  .aboutHistory__title{
    text-align: center;
    white-space: normal; /* SPは折り返しOK */
  }

  .aboutHistory__titleSub{
    display: block;
    margin-left: 0;
    margin-top: 8px;
  }

  .aboutHistory__body{
    width: 100%;
  }

  .aboutHistory__row{
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .aboutHistory__date{
    font-size: 16px;
    font-weight: 400;
  }

  .aboutHistory__hr{
    margin: 32px 0;
  }
}



/*/////////////////////////////////////////////////////*/
/* =====================================================
   ABOUT PILLARS (整理版)
   - Intro（図がある導入）
   - Cards（3つのカード）
===================================================== */

/* ===== 共通：inner ===== */
.aboutPillars__inner{
  width: min(1200px, calc(100% - 40px));
  margin: 0 auto;
}

/* =====================================================
   Intro
===================================================== */
.aboutPillarsIntro{
  background: #E6F1E9;
  border-radius: clamp(44px, 6vw, 100px) clamp(44px, 6vw, 100px) 0 0;
  padding: clamp(140px, 6vw, 160px) 0 clamp(56px, 6vw, 90px);
}

/* Introだけ少し狭く */
.aboutPillarsIntro .aboutPillars__inner{
  width: min(1100px, calc(100% - 40px));
}

/* aboutIntro__head を使うけど、このエリア用に余白だけ調整 */
.aboutPillars__head{
  margin-bottom: clamp(26px, 3vw, 46px);
}

/* 本文 */
.aboutPillars__body{
  margin-top: clamp(18px, 2.5vw, 28px);
}

.aboutPillars__text{
  margin: 0;
  line-height: 2.0;
  letter-spacing: .06em;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(14px, 1.2vw, 16px);
  color: #111;
}

/* イラスト */
.aboutPillars__figure{
  margin: clamp(34px, 4vw, 56px) 0 0;
}

.aboutPillars__img{
  width: 100%;
  height: auto;
  display: block;
  max-width: 1200px;
  margin: 0 auto;
}

/* デフォルトmarginの事故防止（Introだけ） */
.aboutPillarsIntro h3,
.aboutPillarsIntro figure{
  margin: 0;
}

/* =====================================================
   Cards
===================================================== */
.aboutPillars{
  background: #E6F1E9;
  padding: clamp(40px, 6vw, 80px) 0;
  border-radius: 100px 100px 0 0;
}
.aboutPillarsCards{
	background: #E6F1E9;
}

/* ここだけが grid & gap */
.aboutPillarsCards__grid{
  display: grid;
  gap: clamp(8px, 3vw, 18px);
	
	
}

/* closing text */
.aboutPillars__closing{
  margin: clamp(6px, 1.8vw, 16px) 20px 0;
  font-size: clamp(16px, 1.8vw, 20px);
  line-height: 1.6;
  letter-spacing: .05em;
  color: rgba(0,0,0,.72);
  font-weight: 600;
}

/* ===== Card base ===== */
.pillarCard{
  --accent: #0B67A6;
  --accentDark: #07588D;
  --line: rgba(11, 103, 166, .25);

  background: #fff;
  border-radius: clamp(42px, 6vw, 90px);
  overflow: hidden;
  box-shadow: 0 10px 26px rgba(0,0,0,.04);
}

/* color variations */
.pillarCard.is-1{
  --accent: #006AAF;
  --accentDark: #006AAF;
  --line: rgba(11, 103, 166, .25);
}
.pillarCard.is-2{
  --accent: #008B2C;
  --accentDark: #008B2C;
  --line: rgba(10, 127, 58, .22);
}
.pillarCard.is-3{
  --accent: #CB4612;
  --accentDark: #CB4612;
  --line: rgba(199, 84, 29, .22);
}

/* header (color band) */
.pillarCard__header{
  background: var(--accent);
  color: #fff;
  padding: clamp(48px, 3.2vw, 58px) clamp(80px, 3vw, 100px);
}

.pillarCard__headRow{
  display: flex;
  align-items: center;
  gap: 16px;
}

.pillarCard__titles{ min-width: 0; }

.pillarCard__title{
  margin: 20px 0 0 0;
  font-size: clamp(38px, 4vw, 56px);
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.15;
  font-family: "M PLUS 1", sans-serif;
}

.pillarCard__sub{
  margin: clamp(8px, 2vw, 18px) 0 0;
  font-size: clamp(16px, 2vw, 24px);
  font-weight: 600;
  letter-spacing: .05em;
  opacity: .95;
  font-family: "M PLUS 1", sans-serif;
}

.pillarCard__lead{
  margin: clamp(5px, 1.5vw, 18px) 0 0;
  font-size: clamp(16px, 2.2vw, 18px);
  line-height: 1.5;
  letter-spacing: .05em;
  color: rgba(255,255,255,.92);
}

/* ===== badge（1の柱）※重複まとめ ===== */
.pillarCard__badge{
  flex: 0 0 auto;
  width: 100px;
  height: 100px;
  border-radius: 999px;
  background: #fff;
  color: var(--accentDark);

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  padding: 0;
  line-height: 1;
}

.pillarCard__badgeNum{
  display: block;
  margin: 0;
  font-weight: 700;
  font-size: 55px;
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  transform: translateY(7px);
}

.pillarCard__badgeTxt{
  display: block;
  margin: 0;
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  letter-spacing: .08em;
  white-space: nowrap;
  font-family: "Noto Sans JP", sans-serif;
  transform: translateY(-7px);
}

/* body */
.pillarCard__body{
  padding: clamp(48px, 3.2vw, 58px) clamp(80px, 3vw, 100px);
	
}

.pillarCard__dl{
  margin: 0;
  padding: 0;
  display: grid;
}

.pillarCard__row{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 22px;
  padding: clamp(16px, 2vw, 18px) 0;
  border-top: 1px solid var(--line);
}
.pillarCard__row:first-child{
  border-top: 0;
  padding-top: 0;
}

.pillarCard__dt{
  margin: 0;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--accentDark);
  font-size: clamp(18px, 1.15vw, 20px);
  line-height: 1.5;
	 font-family: "Noto Sans JP", sans-serif;
}

.pillarCard__dd{ margin: 0; min-width: 0; }

.pillarCard__catch{
  margin: 0 0 6px;
  font-weight: 600;
  letter-spacing: .04em;
  color: rgba(0,0,0,.82);
  font-size: clamp(16px, 1.15vw, 20px);
  line-height: 1.6;
	 font-family: "Noto Sans JP", sans-serif;
}

.pillarCard__desc{
  margin: 0;
  color: rgba(0,0,0,.68);
  font-size: clamp(15px, 1.05vw, 16px);
  line-height: 1.9;
  letter-spacing: .05em;
	 font-family: "Noto Sans JP", sans-serif;
}

.pillarCard__note{
  margin: clamp(18px, 2.6vw, 22px) 0 0;
  padding-top: clamp(14px, 2vw, 18px);
  border-top: 1px solid var(--line);
  color: rgba(0,0,0,.70);
  font-size: clamp(13px, 1.05vw, 15px);
  line-height: 2.0;
  letter-spacing: .05em;
}

/* =====================================================
   SP
===================================================== */
@media (max-width: 900px){

  /* Intro */
  .aboutPillarsIntro .aboutPillars__inner{ width: 88%; }
	
.aboutPillarsIntro{
  padding: clamp(50px, 6vw, 60px) 0 clamp(50px, 6vw, 70px);
}
	
	.pillarCard__header{
  background: var(--accent);
  color: #fff;
  padding: clamp(20px, 3.2vw, 24px) clamp(32px, 3vw, 36px);
}
	
.pillarCard__body{
  padding: clamp(28px, 3.2vw, 32px) clamp(32px, 3vw, 36px);
}

	
  .aboutPillars__text{ line-height: 1.9; }

  /* Cards */
  .aboutPillars{ padding: 48px 0 64px; }
  .aboutPillarsCards .aboutPillars__inner{ width: 95%; }

  .pillarCard__badge{ width: 78px; height: 78px; }
  .pillarCard__badgeNum{ font-size: 32px; transform: translateY(5px); }
  .pillarCard__badgeTxt{ font-size: 12px; transform: translateY(-5px); }

  .pillarCard__headRow{ gap: 14px; }

  .pillarCard__row{
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 14px 0;
  }
  .pillarCard__dt br{ display: none; }
}
