@charset "UTF-8";
/* layout
----------------------------- */
.co_container_box_inner {
  width: 965px;
  margin: 0 auto;
}
.contentsArea {
  width: 770px;
  margin: 0 auto;
  padding-bottom: 40px;
  float: right;
  background: #fff2a2;
  line-height: 1.5;
  text-align: center;
}
.contentsArea * {
  box-sizing: border-box;
}
.container {
  margin-top: 40px;
  padding: 0 40px;
}
/* common
----------------------------- */
.imgBlock {
  margin: 24px auto 20px;
  text-align: center;
}
.imgBlock a {
  display: block;
}
.underline {
  text-decoration: underline;
  text-underline-position: under;
  text-decoration-line: underline;
  text-decoration-skip-ink: none;
}
.indent_1em {
  padding-left: 1em;
  text-indent: -1em;
}
.contentsArea a:not(.btn, .btn_round, .icon_reload) {
  text-decoration: underline;
}
.contentsArea .red {
  color: #d00;
}
.contentsArea .orange {
  color: #ec6652;
}
.contentsArea .green {
  color: #07b63b;
}
.contentsArea .m_top {
  margin-top: 1em;
}
.contentsArea .bold {
  font-weight: bold;
}
.contentsArea a img {
  transition: all .2s;
}
.contentsArea a:hover img {
  opacity: .7;
}
.pc_hidden {
  display: none;
}
/* 共通パーツ
----------------------------- */
/* ボタン */
.contentsArea .btn {
  display: block;
  width: 84%;
  max-width: 445px;
  height: 56px;
  margin: 8px auto 0;
  border: 2px solid #0c6b33;
  border-radius: 8px;
  background: #06c755;
  box-shadow: #fff 2px 2px 0 inset, #0c6b33 3px 3px 0;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: .075em;
  line-height: 54px;
  text-align: center;
  text-decoration: none;
}
.contentsArea .btn:hover,
.contentsArea .btn:active,
.contentsArea .bnt:visited {
  color: #fff;
}
/* 丸ボタン */
.contentsArea .btn_round {
  display: block;
  position: relative;
  max-width: 350px;
  margin: 24px auto;
  padding: 8px;
  border: 2px solid #fa462e;
  border-radius: 40px;
  background: #fff;
  color: #fa462e;
  font-size: 20px;
  font-weight: bold;
  text-indent: -.5em;
  text-decoration: none;
}
.contentsArea .btn_round::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  width: 6px;
  height: 6px;
  transform: translateY(-50%) rotate(135deg);
  border-top: 2px solid #fa462e;
  border-right: 2px solid #fa462e;
}
.contentsArea .btn_round:hover,
.contentsArea .btn_round:active,
.contentsArea .btn_round:visited {
  color: #fa462e;
}
/* 両サイドに斜めライン */
.diagonal_line {
  display: inline-block;
  position: relative;
  margin-bottom: 8px;
  text-align: center;
}
.diagonal_line::before,
.diagonal_line::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  width: 1px;
  height: 90%;
  background: #fa5500;
}
.diagonal_line::before {
  left: -1em;
  transform: translateY(-50%) rotate(-20deg)
}
.diagonal_line::after {
  right: -1em;
  transform: translateY(-50%) rotate(20deg)
}
.text_lead p {
  font-size: 20px;
  font-weight: bold;
}
.text_lead .big {
  color: #fa462e;
  font-size: 30px;
  font-weight: bold;
}
/* バルーン */
.baloon {
  display: inline-block;
  position: relative;
  padding: 6px 24px 4px;
  border-radius: 32px;
  background: #fff;
  color: #333;
  font-size: .9em;
  margin-bottom: 1em;
  font-weight: bold;
}
.baloon::after {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -11px;
  left: 50%;
  width: 16px;
  height: 12px;
  transform: translateX(-50%);
  background: #fff;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}
/* マーカー */
.marker {
  background: linear-gradient(transparent 50%, #ffe100 50% 90%, transparent 90%);
}
/* header
----------------------------- */
.head_area {
  margin: 0 auto;
}
.head_area img {
  display: block;
  width: 100%;
  height: auto;
  background: #aaa;
  aspect-ratio: 12 / 5;
}
.term_text {
  padding: 8px;
  background: #16a140;
  line-height: 1.5;
}
.term_text p {
  color: #fff;
  font-size: 16px;
  text-align: center;
}
.term_text .date {
  font-size: 20px;
  font-weight: bold;
  letter-spacing: .05em;
}
/* ログイン
----------------------------- */
.login_area {
  max-width: 600px;
  margin: 32px auto 40px;
  text-align: center;
}
.login_area p {
  font-size: 18px;
}
.login_area .login_btn {
  display: flex;
  justify-content: space-between;
  margin-bottom: 24px;
}
.login_area .login_btn .btn {
  width: 46%;
  border: 2px solid #b14820;
  background: #fa462e;
  box-shadow: #fff 2px 2px 0 inset, #b14820 3px 3px 0;
}
/* LINE連携 OK
----------------------------- */
.line_OK .text_lead .big {
  font-size: 24px;
}
/* LINE連携 NG
----------------------------- */
.line_NG .reload_box {
  margin-top: 16px;
}
.line_NG .reload_box .note {
  font-size: 15px;
}
.line_NG .icon_reload {
  display: inline-block;
  margin: 8px auto;
  padding: 8px 16px;
  border: 1px solid #ccc;
  border-radius: 8px;
  background: #fff;
  color: #333;
  font-size: 16px;
  text-decoration: none;
}
.line_NG .icon_reload img {
  width: 25px;
  margin: -2px 8px 0 0;
}
.add_line_box {
  margin-top: 24px;
}
.line_NG .line_info_link {
  margin-top: 16px;
}
.line_NG .line_info_link p {
  font-size: 15px;
}
.line_NG .integrate_line {
  margin-top: 24px;
}
.line_NG .integrate_line p {
  font-size: 15px;
}
.line_NG .integrate_line .btn {
  max-width: 400px;
  height: 44px;
  margin-top: 4px;
  line-height: 46px;
}
/* バナーエリア
----------------------------- */
.banner_area .diagonal_line {
  color: #fa462e;
  font-size: 24px;
  font-weight: bold;
}
.banner_area img {
  max-width: 480px;
  height: auto;
}
/* detailArea
----------------------------- */
.detail_contents {
  overflow: hidden;
  border: 2px solid #07b63b;
  border-radius: 12px;
  background: #fff;
  color: #333;
  line-height: 1.4;
  text-align: left;
}
.detail_contents:not(:first-child) {
  margin-top: 24px;
}
.detail_contents * {
  font-size: 16px;
  line-height: 1.5;
}
.detail_title {
  padding: 8px;
  background: #07b63b;
  color: #fff;
  font-size: 24px;
  text-align: center;
}
.detail_box {
  padding: 20px;
  color: #333;
  text-align: left;
}
.detail_box a {
  text-decoration: underline;
}
.detail_box dt {
  font-weight: bold;
}
.detail_box dd + dt {
  margin-top: 1em;
}
.detail_box .bg_box {
  margin-top: .5em;
  padding: 12px 16px;
  border-radius: 8px;
  background: #fcffc0;
}
.detail_box .bg_box + .bg_box {
  margin-top: 1em;
}
/* btn_areas(sns)
----------------------------- */
.btn_areas {
  margin: 24px 40px 0;
}
/* 終了画面
----------------------------- */
.end_comment {
  padding: 80px 0;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
