﻿/* グリッド */
.wb-compare-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width:768px){
  .wb-compare-grid{ grid-template-columns: 1fr 1fr; }
}

/* B.セーフティ・オレンジ配色 */
.wb-compare-box{
  --alert:#e53935;   /* 赤 */
  --text:#1a1a1a;    /* 黒 */
  --muted:#6b7280;   /* グレー */
  --grad-top:#fff7ec;
  --grad-btm:#fff3e0;

  background: linear-gradient(180deg,var(--grad-top) 0%,var(--grad-btm) 100%);
  border-left: 6px solid var(--alert);
  border-radius: 12px;
  padding: 16px 18px;
  box-shadow: 0 6px 14px rgba(0,0,0,.06);
  font-family: "Yu Gothic UI","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;
}

/* 見出し（h3は黒） */
.wb-compare-title{
  margin: 0 0 6px;
  color: var(--text);
  font-size: clamp(18px,2.4vw,22px);
  font-weight: 900;
  line-height: 1.5;
  display: grid;
  /*grid-template-columns: 24px 1fr;*/
  column-gap: 8px;
  align-items: start;
  background-color:#fff4e3;
  padding-left:6px;
}

.wb-check{
  width: 22px; height: 22px;
  border: 3px solid var(--alert);
  border-radius: 4px;
  position: relative; top: 2px;
}
.wb-check::after{
  content:""; position:absolute; left:4px; top:1px;
  width:10px; height:16px;
  border-right:3px solid var(--alert);
  border-bottom:3px solid var(--alert);
  transform: rotate(45deg);
}

/* 問題と解決の色 */
.wb-problem-strong{ color: var(--alert); }
.wb-solution{
  margin: 2px 0 10px;
  font-size: clamp(16px,2.1vw,18px);
  font-weight: 800;
  color: #e53935;   /* ⇒ のテキストは赤 */
}
.wb-solution-strong{ color: var(--alert); }

/* リストは黒 */
.wb-compare-list{
  margin: 0;
  padding-left: 1.2em;
  color: var(--text);
  font-size: 15px;
}
.wb-compare-list li{ margin:.2em 0; line-height:1.7; }
.wb-compare-list small{ color: var(--muted); font-size:.92em; }

.auto-style6 {
	color: #000000;
	font-size: 15px;
	font-weight: normal;
}
.fit-p{
	max-width: 1000px;
    margin: 30px auto;
    padding: 20px;
    background: #c0ebfb;
    border: 2px solid gray;
    border-radius: 8px;
}
h2.wb-h2 {
    border-left: 6px solid #caa03a;
    background-color: #fff1b8;
    }
th {
    background: #dbebf7;
}
.auto-style7 {
	color: #4AAC9F;
}
.ppband div {
    background: #e0f1f8;
    border: 1px solid #e0e5e2;
    padding: 12px;
    border-radius: 8px;
    margin-top:1em;
}
.auto-style8 {
	color: #FFFFFF;
	font-size: x-large;
	text-align: center;
	background-color: #67AB7A;
}
.auto-style9 {
	text-align: center;
	font-size: large;
}
.auto-style10 {
	color: #00AABD;
	font-size: large;
}
.auto-style11 {
	color: #1375BC;
}
.auto-style12 {
	color: #0D9644;
}
.auto-style13 {
	color: #F7941D;
}
.auto-style14 {
	color: #238549;
}
.auto-style15 {
	background-color: #DCE9F5;
}
.auto-style16 {
	background-color: #1A237E;
}
.auto-style17 {
	font-size: 38px;
	color: #FFEB3B;
}
  .twbl-points {
    margin: 40px 0;
  }

  .twbl-points-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
  }

  .twbl-point-card {
    background: #ffffff;
    border: 1px solid #d9e4f2;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  }

  /* 画像サイズを固定しない */
  .twbl-point-card img {
    display: block;
    width: 100%;
    height: auto;
  }

  /* POINT 01 */
  .twbl-point-main {
    grid-column: 1 / -1;
    position: relative;
    border: 2px solid #d9e4f2;
    box-shadow: 0 10px 28px rgba(23, 59, 120, 0.08);
  }

  .twbl-point-main::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(90deg, #173b78 0%, #d8b24a 100%);
  }

  .twbl-point-main-inner {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 24px;
    align-items: center;
    padding: 28px;
  }

  .twbl-point-main-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .twbl-point-main-head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
  }

  .twbl-point-no {
    flex: 0 0 auto;
    font-size: 54px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0.04em;
    color: #caa03a;
  }

  .twbl-point-label {
    display: inline-block;
    background: #173b78;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    padding: 8px 14px;
    border-radius: 999px;
    margin-bottom: 8px;
  }

  .twbl-point-main-title {
    margin: 0;
    font-size: 32px;
    line-height: 1.45;
    font-weight: 700;
    color: #173b78;
  }

  .twbl-point-main-title strong {
    color: #173b78;
    background: linear-gradient(transparent 62%, #fff1b8 62%);
  }

  .twbl-point-main-text {
    margin: 0 0 18px;
    font-size: 15px;
    line-height: 1.9;
    color: #333;
  }

  .twbl-point-main-merits {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .twbl-point-main-merits span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f7fbff;
    border: 1px solid #d9e4f2;
    color: #173b78;
    font-size: 14px;
    font-weight: 700;
    padding: 10px 14px;
    border-radius: 999px;
  }

  .twbl-point-main-image {
    border-radius: 14px;
    overflow: hidden;
    background: #f7fbff;
  }

  /* POINT 02-04 */
  .twbl-point-sub {
    display: flex;
    flex-direction: column;
  }

  .twbl-point-sub-image {
    overflow: hidden;
    background: #f7fbff;
  }

  .twbl-point-sub-body {
    padding: 20px 18px 22px;
  }

  .twbl-point-sub-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
  }

  .twbl-point-sub .twbl-point-no {
    font-size: 38px;
    color: #173b78;
  }

  .twbl-point-sub .twbl-point-label {
    background: #eef4fc;
    color: #173b78;
    border: 1px solid #d9e4f2;
    margin-bottom: 6px;
  }

  .twbl-point-sub-title {
    margin: 0;
    font-size: 22px;
    line-height: 1.5;
    color: #173b78;
    font-weight: 700;
  }

  .twbl-point-sub-text {
    margin: 0;
    font-size: 14px;
    line-height: 1.85;
    color: #333;
  }

  @media (max-width: 980px) {
    .twbl-points-grid {
      grid-template-columns: 1fr;
    }

    .twbl-point-main-inner {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 640px) {
    .twbl-point-main-inner {
      padding: 22px 16px;
      gap: 18px;
    }

    .twbl-point-main-head,
    .twbl-point-sub-head {
      gap: 10px;
    }

    .twbl-point-no {
      font-size: 44px;
    }

    .twbl-point-sub .twbl-point-no {
      font-size: 32px;
    }

    .twbl-point-main-title {
      font-size: 26px;
      line-height: 1.5;
    }

    .twbl-point-sub-title {
      font-size: 20px;
    }

    .twbl-point-main-text {
      font-size: 14px;
      line-height: 1.85;
    }

    .twbl-point-main-merits span {
      width: 100%;
    }
  }
.auto-style18 {
	font-size: large;
	font-weight: bold;
	color: #f08300; /* 文字色：オレンジ */;
	line-height: 1.6;
	letter-spacing: 0.05em;
	display: inline-block; /* 文字幅に下線を合わせる */;
	padding-bottom: 0.3em;
	margin: 1.5em auto .5em auto;
}