/*---------------------------------------------
*
* 無料相談
*　/free.html
*
---------------------------------------------*/

#kv {
  /* background-image: url("../img/free/kv.png"); */
  /* background-size: cover; */
  /* background-position: center; */
  height: 100%;
  /* display: flex; */
  /* justify-content: center; */
  /* align-items: center; */
}

#line-banner {
  background-color: rgba(255, 238, 0, 0.2);
  padding: 40px 0;
}

#line-banner a img {
  width: 80%;
  max-width: 400px;
  margin: 0 auto 40px auto;
}

#line-banner .headline {
  text-align: center;
  margin: 10px 0 18px;
}

#line-banner .headline__title {
  margin: 0 0 10px;
  font-weight: 1000;
  font-size: 22px;
  letter-spacing: 0.02em;
}

#line-banner .headline__sub {
  margin: 0;
  font-weight: 1000;
  font-size: 18px;
  letter-spacing: 0.02em;
}

#line-banner .dotted {
  display: inline-block;
  padding-bottom: 10px;
  background-image: radial-gradient(#ff2a2a 2px, transparent 2px);
  background-size: 12px 10px;
  background-repeat: repeat-x;
  background-position: left bottom;
}

#line-banner .body {
  max-width: 440px;
  /* width: 80%; */
  /* margin: 0 auto; */
  text-align: center;
  font-size: 15px;
  line-height: 2.0;
}

#line-banner .body p {
  margin: 18px 0;
}

/* bottom yellow bar */
#line-banner .bottom-bar {
  height: 10px;
  background: #ffe600;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
}

#free-text {
  background-color: rgba(255, 238, 0, 0.2);
  padding: 40px 0;
}

#free-text .speech {
  position: relative;
  /* max-width: 400px; */
  /* width: 80%; */
  margin: 0 auto 20px;
  padding: 22px 10px;
  background: #fff;
  border: 2px solid #ffe600;
  border-radius: 60px;
  text-align: center;
  font-weight: bold;
  line-height: 1.9;
}

/* 外側の三角（枠線） */
#free-text .speech::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -18px;
  transform: translateX(-50%);
  border-width: 18px 18px 0 18px;
  border-style: solid;
  border-color: #ffe600 transparent transparent transparent;
}

/* 内側の三角（背景） */
#free-text .speech::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -14px;
  transform: translateX(-50%);
  border-width: 14px 14px 0 14px;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

#free-text .speech p {
  margin: 0;
}

#free-text img {
  /* width: 80%; */
  /* max-width: 400px; */
  margin: 0 auto 20px auto;
}

#free-consultation-section {
  background-color: #FFEE00;
  padding: 10px 0 60px 0;
  position: relative;
}

#free-consultation-section .sec-title-h3{
  margin: 20px 0 !important;
}

#free-consultation-section .content h3 {
  margin: 0 auto 20px;
  text-align: center;
  font-size: 23px;
  font-weight: 900;
  letter-spacing: 0.02em;
  font-feature-settings: "palt";
}

#free-consultation-section .content .list {
  list-style: none;
  padding: 0;
  margin: 0 auto 10px auto;
  max-width: 90%;
  display: grid;
  gap: 5px;
}

#free-consultation-section .content ul.list {
  position: relative;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.65;
}

#free-consultation-section .content ul.list li {
  position: relative;
  padding-left: 20px;
}

#free-consultation-section .content ul.list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  /* 1行目の中央 */
  width: 10px;
  height: 10px;
  background: #e60012;
}

#free-consultation-section .content span {
  display: block;
  max-width: 90%;
  margin: 0 auto;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
}

/* 共通：スマホ幅の白カードを黄色背景に置く */
#xray-section,
#stance-section,
#faq-section {
  background-color: rgba(255, 238, 0, 0.2);
  padding: 24px 0 28px;
}

#xray-section .content,
#stance-section .content,
#faq-section {
  /* width: 90%;
  max-width: 400px;
  margin: 0 auto; */
  background: #fff;
}

/* 画像（上部） */
#xray-section .top-img,
#stance-section .top-img {
  width: 100%;
  display: block;
  height: auto;
}

/* 内側の余白 */
#xray-section .box,
#stance-section .box {
  padding: 18px 16px 20px;
}

/* タイトル */
#xray-section h3,
#stance-section h3 {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 900;
  line-height: 1.4;
  display: table;
  margin: 0 auto 10px;
  padding-bottom: 5px;
}

/* 1つ目のカード：青見出し */
#xray-section h3 {
  color: #0b39ff;
  /* スクショの青寄せ */
  border-bottom: 1px solid #0b39ff;
  /* display: inline-block; */
  text-align: center;
}

/* 2つ目のカード：赤見出し */
#stance-section h3.red {
  color: #ff0000;
  border-bottom: 1px solid #ff0000;
}

#stance-section .lead {
  margin: 0 0 12px;
  font-weight: 900;
  font-size: 20px;
  text-align: center;
}

/* 本文 */
#xray-section p {
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.9;
}

/* ◎の箇条書き（1つ目のカード） */
#xray-section .point {
  list-style: none;
  padding: 0;
  margin: 10px 0 10px;
  display: grid;
  gap: 6px;
}

#xray-section .point li {
  position: relative;
  padding-left: 18px;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.7;
}

#xray-section .point li::before {
  content: "◎";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 900;
}

/* 注意書き + 強調文（1つ目のカード） */
#xray-section .note {
  margin: 8px 0 10px;
  font-size: 16px;
  line-height: 1.7;
}

#xray-section .strong {
  margin: 0;
  font-size: 16px;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  /* 線の太さ */
  text-underline-offset: 4px;
  /* 文字との距離 */
  font-weight: 900;
  line-height: 1.8;
}

/* 赤アイコン付きの箇条書き（2つ目のカード） */
#stance-section .warn {
  list-style: none;
  padding: 0;
  margin: 20px 0 12px;
  display: grid;
  gap: 8px;
}

#stance-section .warn li {
  position: relative;
  padding-left: 30px;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.6;
}

/* 赤い四角 + 白い矢印っぽいマーク */
#stance-section .warn li::before {
  content: "";
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2250%22%20height%3D%2238%22%20viewBox%3D%220%200%2050%2038%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M5.14862%2037.5021L31.1279%2037.5021C33.1148%2037.5021%2035.0048%2036.6408%2036.3089%2035.1402L49.5787%2019.8767C50.1404%2019.2312%2050.1404%2018.271%2049.5787%2017.6248L36.3089%202.36055C35.0048%200.860648%2033.1148%202.89498e-06%2031.1279%202.72128e-06L5.14862%204.50099e-07C2.30527%202.01525e-07%209.84444e-05%202.30517%209.81959e-05%205.14852L9.58176e-05%2032.353C9.55689e-05%2035.197%202.30527%2037.5021%205.14862%2037.5021ZM14.7871%2010.6748L19.8346%2015.7209L24.8807%2010.6762L27.911%2013.705L22.8648%2018.7525L27.9102%2023.7979L24.8807%2026.8274L19.8346%2021.7812L14.7879%2026.8288L11.7584%2023.7979L16.8059%2018.7511L11.757%2013.705L14.7871%2010.6748Z%22%20fill%3D%22%23FF0101%22%2F%3E%3C%2Fsvg%3E') no-repeat center;
  background-size: contain;
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 25px;
  height: 18px;
}

/* 2つ目のカード本文 */
#stance-section .desc {
  margin: 0;
  font-size: 16px;
  line-height: 1.9;
}

/* FAQ */
#faq-section {
  padding: 5px 16px 18px;
}

#faq-section .faq-head {
  text-align: center;
}

#faq-section .faq-head .logo {
  width: 90px;
  height: auto;
  display: block;
  margin: 0 auto 8px;
}

#faq-section .faq-head h3 {
  margin: 0 0 10px;
  font-size: 16px;
  font-weight: 900;
}

#faq-section .faq-head .line {
  display: block;
  width: 75%;
  height: 1px;
  background: #111;
  margin: 0 auto 12px;
  opacity: 0.85;
}

#faq-section .faq {
  margin: 20px 0 0;
}

#faq-section .faq-item:last-child {
  border-bottom: none;
}

#faq-section dt,
#faq-section dd {
  display: flex;
  align-items: center;
  margin: 0;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 800;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  padding: 10px 0;
}

#faq-section dt {
  font-size: 16px;
  font-weight: 600;
}

#faq-section dd {
  font-size: 14px;
  font-weight: 600;
}

#faq-section .q,
#faq-section .a {
  font-family: "din-2014", sans-serif;
  font-size: 30px;
  margin-right: 15px;
}

#faq-section .q {
  color: #0b39ff;
}

#faq-section .a {
  color: #ff0000;
}