@charset "Shift_JIS";

/**
 -----Object/Project Style-----
 01.reset
 02.common
 03.variable
 04.header
 05.container
 06.item
 07.btn
 08.flow
 09.inquiry
 10.footer
 11.hack
 12.responsive
 ------------------------------
**/


/*** reset ***/
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  font-size: 100%;
  line-height: 1;
}

fieldset,
img {
  border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal;
}

ol,
ul {
  list-style: none;
}

table {
  margin: 0;
}

abbr,
acronym {
  border: none;
}

a {
  outline-width: 0;
}

input,
textarea {
  font-size: 120%;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  border: 0;
  margin: 0;
  padding: 0;
  background: none transparent;
  vertical-align: middle;
  font-size: inherit;
  color: inherit;
  box-sizing: content-box;
}

form {
  overflow: hidden;
}


/*** common ***/
@font-face {
  font-family: "BIZ UDPGothic", sans-serif;
  src: url("../font/BIZUDPGothic-Regular.ttf") format("truetype");
  src: url("../font/BIZUDPGothic-Bold.ttf") format("truetype");
}

body {
  font-family: 'Zen Maru Gothic', "Yu Gothic", "?¿½?¿½?¿½S?¿½V?¿½b?¿½N", YuGothic, "?¿½?¿½?¿½S?¿½V?¿½b?¿½N?¿½?¿½", "?¿½q?¿½?¿½?¿½M?¿½m?¿½p?¿½S Pro W3", "?¿½?¿½?¿½C?¿½?¿½?¿½I", sans-serif;
}

.res_pc {
  display: block;
}

.res_sp {
  display: none;
}


/*** variable ***/
:root {
  --main-bgcolor: #e60012;
  --main-bgcolor-rgb: 230, 0, 18;
  --main-bgcolor-alpha20: rgba(var(--main-bgcolor-rgb), 0.2);
  --main-bgcolor-alpha80: rgba(var(--main-bgcolor-rgb), 0.8);
  --sub-bgcolor: #00a0b8;
  --sub-bgcolor-rgb: 0, 160, 184;
  --sub-bgcolor-alpha20: rgba(var(--sub-bgcolor-rgb), 0.2);
  --sub-bgcolor-alpha80: rgba(var(--sub-bgcolor-rgb), 0.8);
  --main-fontcolor: #ffffff;
  --main-padding: 24px;
  --main-sub-padding: 48px;
  --sub-padding: 12px;
  --subsp-padding: 16px;
  --main-margin: 48px;
  --main-sub-margin: 36px;
  --sub-margin: 24px;
  --subsp-margin: 12px;
}


/*** header ***/

.header {
  margin-bottom: var(--main-margin);
}

.header .titlebox {
  margin: 0 auto;
}

.header .titlebox .titlebox_l {
  text-align: center;
  display: block;
}

.header .titlebox .titlebox_l div {
  padding-bottom: 24px;
}

ul.note {
  margin: var(--subsp-margin) 0 0 0;
}

ul.note li {
  font-size: 13px;
  text-indent: -1em;
  margin: 0 0 5px 1em;
  letter-spacing: 1px;
}

p.note {
  font-size: 13px;
  text-indent: -1em;
  margin: var(--sub-margin) var(--main-margin);
  letter-spacing: 1px;
}

/*** container ***/

#container {
  margin: 0 auto;
}


/*** item ***/

.item {
  margin: 0 auto var(--main-margin) auto;
}

.item:nth-child(odd) {
  background-color: #f8f8f8;
}

.item_inner {
  width: 990px;
  margin: 0 auto;
}

.notice_box {
  border: 1px solid var(--main-bgcolor);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 48px;
}

.notice_box li {
  text-indent: -1em;
  padding-left: 1em;
}

.title_txt {
  padding: var(--sub-padding) var(--sub-padding) var(--sub-padding) var(--main-sub-padding);
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 1px;
  text-align: center;
}

p.lead {
  padding: var(--sub-padding) var(--sub-padding) var(--sub-padding) var(--main-sub-padding);
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 1px;
  text-align: justify;
}

.item h2 {
  color: var(--main-bgcolor);
  font-size: 40px;
  font-weight: bold;
  margin-top: 75px;
  padding: var(--sub-padding);
  display: inline-block;
}

.item h2:before {
  width: 41px;
  height: 41px;
  content: "";
  left: -25px;
  position: relative;
  top: 7px;
  display: inline-block;
  background: url(../img/icn_1.png);
  background-size: contain;
  background-repeat: no-repeat;
}

.item h2 span {
  border-bottom: 2px dotted var(--main-bgcolor);
}

.item h3 {
  color: var(--main-bgcolor);
  font-size: 28px;
  font-weight: bold;
  padding: var(--sub-padding);
  display: inline-block;
  margin: var(--sub-margin) 0 0 34px;
}

.item h3 span {
  border-bottom: 2px dotted var(--main-bgcolor);
}

/*dosam*/
.item.dosam {
  margin: 0 auto 0 auto;
}

.item.dosam h2 {
  color: var(--sub-bgcolor);
  font-size: 40px;
  font-weight: bold;
  padding: var(--sub-padding);
  display: inline-block;
  margin: var(--sub-margin) 0 0 0;
}

.item.dosam h2:before {
  width: 41px;
  height: 41px;
  content: "";
  left: -25px;
  position: relative;
  top: 7px;
  display: inline-block;
  background: url(../img/icn_2.png);
  background-size: contain;
  background-repeat: no-repeat;
}

.item.dosam h2 span {
  border-bottom: 2px dotted var(--sub-bgcolor);
}

.item.dosam h3 {
  color: #ffffff;
  background-color: var(--sub-bgcolor);
  font-size: 28px;
  font-weight: bold;
  padding: var(--sub-padding);
  display: block;
  margin: var(--main-margin) var(--main-margin);
  text-align: center;
}

.item.dosam h3 span {
  border-bottom: none;
}

.item.dosam table.compensation {
  width: 710px;
  border-collapse: collapse;
  border-spacing: 0;
  margin: var(--sub-margin) auto 0 auto;
}

.item.dosam table.compensation tr {
  background-color: #def0f1;
}

.item.dosam table.compensation tr:nth-child(even) {
  background-color: #bce0e3;
}

.item.dosam table.compensation th,
.item.dosam table.compensation td {
  padding: var(--sub-padding);
}

.item.dosam table.compensation th {
  vertical-align: top;
  font-size: 14px;
  width: 25%;
  border-right: 2px solid #ffffff;
  font-weight: bold;
}

.item.dosam table.compensation td {
  vertical-align: top;
  font-size: 14px;
}

.item.dosam table.compensation td ul.note {
  margin: 0 0 0 0;
}

.item.dosam table.compensation td ul.note li {
  font-size: 12px;
}

.item.dosam table.case {
  width: 710px;
  border-spacing: 2px;
  margin: var(--sub-margin) auto 45px auto;
}

.item.dosam table.case tr {
  background-color: #ffffff;
}

.item.dosam table.case th,
.item.dosam table.case td {
  padding: var(--sub-padding);
}

.item.dosam table.case th {
  background-color: #cccccc;
  vertical-align: top;
  font-size: 14px;
  width: 33%;
  font-weight: bold;
}

.item.dosam table.case td {
  border-right: 2px solid #ffffff;
  vertical-align: top;
  font-size: 14px;
  text-align: center;
}

.item.dosam table.case td:last-child {
  text-align: right;
}

.item.dosam table.case td b {
  font-size: 15px;
}

ul.service {
  width: 710px;
  display: flex;
  margin: 0 auto;
}

ul.service li img {
  width: 100%;
}

ul.category {
  width: 710px;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

ul.category li {
  width: 116px;
  height: 95px;
  margin: 10px 30px 10px 0px;
  border: 1px solid #e6e6e6;
  float: left;
  display: inline-block;
  position: relative;
  background-color: #ffffff;
}

ul.category li:nth-child(5n) {
  margin: 10px 0px 10px 0px;
}

ul.category li p {
  position: absolute;
  top: 0;
  width: 100%;
  height: auto;
  min-height: 45px;
  background-image: none;
  background-size: 360px 1080px !important;
  overflow: hidden;
  margin: 20px auto 0px auto;
}

ul.category .icon_travel {
  background: url("../img/marker_ctgy_icons.png") 35px -628px;
}

ul.category .icon_entame {
  background: url("../img/marker_ctgy_icons.png") 35px -45px;
}

ul.category .icon_beauty {
  background: url("../img/marker_ctgy_icons.png") 35px -137px;
}

ul.category .icon_bridal {
  background: url("../img/marker_ctgy_icons.png") 35px -88px;
}

ul.category .icon_seikatu {
  background: url("../img/marker_ctgy_icons.png") 35x -180px;
}

ul.category .icon_gourmet {
  background: url("../img/marker_ctgy_icons.png") 35px -225px;
}

ul.category .icon_sports {
  background: url("../img/marker_ctgy_icons.png") 35px -269px;
}

ul.category .icon_car {
  background: url("../img/marker_ctgy_icons.png") 35px -314px;
}

ul.category .icon_housing {
  background: url("../img/marker_ctgy_icons.png") 35px -361px;
}

ul.category .icon_ikuji {
  background: url("../img/marker_ctgy_icons.png") 35px -404px;
}

ul.category .icon_manabu {
  background: url("../img/marker_ctgy_icons.png") 35px -449px;
}

ul.category .icon_health {
  background: url("../img/marker_ctgy_icons.png") 35px -494px;
}

ul.category .icon_kaigo {
  background: url("../img/marker_ctgy_icons.png") 35px -540px;
}

ul.category .icon_shopping {
  background: url("../img/marker_ctgy_icons.png") 35px -585px;
}

ul.category .icon_benefit {
  background: url("../img/marker_ctgy_icons.png") 35px -676px;
}

ul.category .icon_oiwai {
  background: url("../img/marker_ctgy_icons.png") 35px -719px;
}

ul.category .icon_energy {
  background: url("../img/marker_ctgy_icons.png") 35px -764px;
}

ul.category .icon_pet {
  background: url("../img/marker_ctgy_icons.png") 35px -808px;
}

ul.category .icon_point {
  background: url("../img/marker_ctgy_icons.png") 35px -854px;
}

ul.category li span.icon_det {
  display: block;
  width: 116px;
  height: 95px;
}

ul.category li span.icon_det span {
  position: absolute;
  bottom: 5px;
  right: 0;
  left: 0;
  text-align: center;
  font-size: 11.5px;
  line-height: 1.2;
}

.pht {
  text-align: center;
  margin: var(--sub-margin) auto;
}

/*** btn ***/

.btn a {
  display: block;
  text-align: center;
  font-size: 16px;
  letter-spacing: 1px;
  padding: var(--sub-padding);
  font-weight: bold;
  border-radius: 4px;
  color: var(--main-fontcolor);
  text-decoration: none;
}

/* プラン別ページへのリンクボタン */
.link-plan .btn a {
  background-color: var(--main-bgcolor);
  font-size: 18px;
}

/* プラン別ページへのリンクボタン：ホバー */
.link-plan .btn a:hover {
  background-color: var(--main-bgcolor-alpha80);
  transition: ease all .2s;
}

.btn a.firstReg {
  background-color: var(--main-bgcolor);
  font-size: 18px;
}

.btn a.firstReg:hover {
  background-color: var(--main-bgcolor-alpha80);
  transition: ease all .2s;
}

.btn a.secondReg {
  background-color: var(--sub-bgcolor);
  font-size: 18px;
}

.btn a.secondReg:hover {
  background-color: var(--sub-bgcolor-alpha80);
  transition: ease all .2s;
}

.btn a.videoLink {
  width: 360px;
  margin: 0 auto;
  color: #000000;
  background-color: #ffe100;
}

.btn a.videoLink:hover {
  background-color: rgba(255, 225, 0, 0.8);
  transition: ease all .2s;
}

.btn a.pointLink {
  width: 360px;
  margin: 0 auto;
  color: #fff;
  background-color: #072985;
}

.btn a.pointLink:hover {
  background-color: #0b3ab9;
  transition: ease all .2s;
}


/*** flow ***/
.flow {
  text-align: left;
  margin: 45px 15px;
  padding: 0 15px;
}

.flow h4 {
  color: #ffffff;
  border-bottom: none;
  display: table-cell;
  vertical-align: middle;
  width: 160px;
  padding: 15px;
  background-color: var(--sub-bgcolor);
  font-size: 120%;
  font-weight: normal;
  text-align: center;
}

.flow dl {
  margin: 15px;
}

.flow dl dt {
  font-weight: bold;
}

.flow dl dt b {
  display: inline-block;
  width: 20px;
  height: 20px;
  font-size: 12px;
  margin: 0 5px 0 0;
  font-weight: normal;
  border-radius: 60px;
  background-color: var(--sub-bgcolor);
  color: #ffffff;
  line-height: 20px;
  text-align: center;
}

.flow dl dd {
  margin: 0 0 10px 25px;
  font-size: 90%;
}

.flow dl dd span {
  text-indent: -1em;
  margin: 0 0 0 1em;
  display: block;
  font-size: 85%;
}

.inq_div {
  display: flex;
}

.flow .inq {
  width: 50%;
  margin: 15px 15px 15px 0;
  padding: 15px;
  text-align: center;
}

.flow .inq:last-child {
  margin: 15px 0 15px 0;
}

.flow .inq p {
  text-align: center;
  font-weight: bold;
  color: #333333;
}

.flow .inq a {
  background-color: #a8aaad;
  color: #ffffff;
  padding: 5px 15px;
  display: block;
  border-radius: 60px;
  text-decoration: none;
  text-align: center;
  font-size: 14px;
  width: 235px;
  margin: 0 auto;
  height: 42px;
  line-height: 2.8;
}

.flow .inq ul.notes {
  clear: both;
  display: block;
  margin: 5px 0 0 0;
}

.flow .inq ul.notes li {
  text-indent: -1em;
  margin: 0 0 0 1em;
  font-size: 12px;
  line-height: 1.2;
}

.flow_inquiry {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 60px;
  margin: var(--main-margin);
  padding: 0 var(--main-padding);
  font-size: 14px;
}

.flow_inquiry .inquiry_box {
  text-align: center;
}

.flow_inquiry .inquiry_box h5 {
  color: var(--sub-bgcolor);
  padding: var(--sub-padding);
  border-bottom: 2px solid var(--sub-bgcolor);
  font-size: 15px;
  font-weight: bold;
}

.flow_inquiry .inquiry_box address {
  font-size: 24px;
  font-weight: bold;
  margin: 10px 10px 5px 10px;
  display: inline-block;
}

.flow_inquiry .inquiry_box address span {
  display: block;
  font-size: 13px;
  font-weight: normal;
}

.flow_image{
  padding: var(--sub-padding);
}



/*** inquiry ***/
.inquiry {
  margin: var(--sub-margin) var(--main-margin);
  padding: var(--sub-padding);
  font-size: 14px;
}

.inquiry h5 {
  font-size: 24px;
  font-weight: bold;
  color: var(--sub-bgcolor);
  padding: var(--sub-padding);
  margin: 0 0 0 0;
  border-bottom: 2px solid var(--sub-bgcolor);
  display: inline-block;
}

.inquiry dl dd.note {
  text-indent: -1em;
  margin: 0 0 0 1em;
  font-size: 12px;
  line-height: 1.4;
}

.inquiry .inquiry_bs dl,
.inquiry .inquiry_mec-c dl {
  margin: var(--sub-margin);
}

.inquiry .inquiry_bs dl {
  background-color: #efefef;
  padding: var(--main-padding);
}

.inquiry .inquiry_bs dl dt {
  font-size: 20px;
  font-weight: bold;
}

.inquiry .inquiry_mec-c dl dt {
  font-size: 18px;
  font-weight: bold;
}

.inquiry .inquiry_bs dl dd address {
  font-size: 24px;
  font-weight: bold;
  margin: 0;
  display: inline-block;
}

.inquiry .inquiry_mec-c dl dd address {
  font-size: 20px;
  font-weight: bold;
  margin: 0;
  display: inline-block;
}

.inquiry_mec-c h5 {
  font-size: 20px;
}

/*** footer ***/

.footer {
  font-size: 12px;
  text-align: center;
  color: #333333;
  padding: var(--sub-padding);
}

p.footer_lead {
  font-size: 18px;
}

.footer ul.footer_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 60px;
}

.footer ul.footer_list li a {
  display: inline-block;
  color: #333333;
  padding: 8px 0;
  text-decoration: underline;
}

.footer ul.footer_list li a:hover {
  color: var(--main-bgcolor);
}

.payment_title {
  padding: 0.5rem 2rem;
  color: #fff;
  background-color: var(--main-bgcolor);
  font-size: 18px;
  font-weight: bold;
  position: relative;
}

.payment_title::before {
  position: absolute;
  content: '';
  left: -2px;
  top: -2px;
  width: 0;
  height: 0;
  border: none;
  border-left: solid 25px #f8f8f8;
  border-bottom: solid 50px transparent;
}

.payment_title::after {
  position: absolute;
  content: '';
  right: -3px;
  top: -7px;
  width: 0;
  height: 0;
  border: none;
  border-left: solid 25px transparent;
  border-bottom: solid 50px #f8f8f8;
}

.item_inner .payment_title::before {
  border-left: solid 25px #ffffff;
}

.item_inner .payment_title::after {
  border-bottom: solid 50px #ffffff;
}

.red_box {
  padding-top: 8px;
  font-weight: bold;
  color: var(--main-bgcolor);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.red_big {
  font-size: 24px;
  margin-right: 20px;
}

.red_big_price {
  font-size: 28px;
}

.red_middle {
  font-size: 18px;
}

.red_border {
  border: 1px solid var(--main-bgcolor);
  padding: 0 1rem;
  margin-left: 20px;
}

.red_small {
  font-size: 16px;
}

.red_xsmall {
  font-size: 14px;
}

.payment_txt_right {
  font-size: 14px;
  text-align: right;
  border-bottom: 2px dotted;
  padding-bottom: 6px;
  margin-bottom: 6px;
  font-weight: bold;
}

.black_big {
  font-size: 16px;
  margin-right: 20px;
}

.black_txt {
  font-size: 14px;
  font-weight: bold;
  margin-bottom: var(--main-margin);
}

.payment_notice {
  font-size: 13px;
  color: #000000;
}

.two_col_div {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-bottom: 75px;
}

.two_col_div a {
  text-decoration: none;
  transition: all 0.5s ease 0s;
}

.two_col_div a:hover {
  opacity: 0.6;
}

.two_col_div01 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  max-width: 710px;
  margin: 24px auto 0;
}

.two_col_div01 img {
  max-width: 100%;
}

.tel_icon img {
  width: 18px;
  padding-right: 8px;
}

.service_box {
  position: relative;
  border: 2px solid var(--main-bgcolor);
  border-radius: 8px;
  background-color: #fdeef4;
  text-align: center;
  padding: 8px 32px;
}

.service_box::after {
  content: '';
  position: absolute;
  border: 35px solid transparent;
  border-top: 35px solid transparent;
  border-right: 0px solid transparent;
  border-left: 35px solid var(--main-bgcolor);
  z-index: 0;
  transform: rotate(90deg);
  left: 227px;
}

.insurance_box {
  position: relative;
  border: 2px solid #00aabc;
  border-radius: 8px;
  text-align: center;
  padding: 8px 32px;
  background-color: #e8f6fd;
}

.insurance_box::after {
  content: '';
  position: absolute;
  border: 35px solid transparent;
  border-top: 35px solid transparent;
  border-right: 0px solid transparent;
  border-left: 35px solid #00aabc;
  z-index: 0;
  transform: rotate(90deg);
  left: 227px;
}

.icon-plus {
  width: 60px;
  height: 60px;
  position: absolute;
  padding: 0px;
  border-radius: 50%;
  top: -30px;
}

.icon-plus:before,
.icon-plus:after {
  content: "";
  position: absolute;
  top: 25px;
  left: 11px;
  width: 39px;
  height: 10px;
  background-color: var(--main-fontcolor);
}

.icon-plus:after {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.service_box .icon-plus {
  background-color: var(--main-bgcolor);
  left: -30px;
}

.insurance_box .icon-plus {
  background-color: #00aabc;
  left: -30px;
}

.item_title {
  font-size: 40px;
  font-weight: bold;
  border-bottom: 3px dotted var(--main-bgcolor);
  margin-bottom: 16px;
}

.service_box .item_title {
  color: var(--main-bgcolor);
}

.insurance_box .item_title {
  color: #00aabc;
  border-bottom: unset;
  margin-bottom: 0px;
  margin-left: 33px;
}

.insurance_box .item_subtitle {
  border-bottom: 3px dotted #00aabc;
  font-size: 32px;
  font-weight: bold;
  text-align: right;
  color: #00aabc;
}

.item_inner_txt {
  font-size: 20px;
  font-weight: bold;
}

.service_box .item_inner_txt {
  color: var(--main-bgcolor);
}

.insurance_box .item_inner_txt {
  color: #00aabc;
}

/* 蛍光ペン風 */
.item_inner_txt>span.border {
  font-size: 32px;
  background: linear-gradient(transparent 40%, #fff101 0%);
}

.service_list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  max-width: 710px;
  margin: 16px auto 0;
  gap: 16px;
}

.service_list img {
  max-width: 100%;
}

.point_service01 {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 928px;
  margin: 0 auto;
  gap: 16px;
}

.point_service01>.img_container {
  box-shadow: 0 1px 0.5rem rgba(31, 32, 33, 0.2);
  border-radius: 8px;
  padding: 8px;
}

.point_service01>.img_container>img {
  height: 250px;
  max-height: fit-content;
  object-fit: contain;
}

.point_service02 img {
  max-width: 100%;
}

.title_family {
  margin: 48px 0 24px 0;
}

.title_family img {
  max-width: 100%;
}

.point_service02 {
  display: flex;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  margin: 0;
  justify-content: center;
  align-items: flex-end;
  gap: 16px;
}

.grid_item {
  text-align: center;
  padding-right: 16px;
  border-right: 2px dotted #00aabc;
}

.grid_item:last-child {
  border-right: none;
  padding-right: 0px;
}

.two_col_flex {
  display: flex;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
  margin-top: 24px;
}

.insurance_subtitle {
  font-size: 28px;
  font-weight: bold;
  color: var(--sub-bgcolor);
  text-align: center;
  margin: var(--main-padding);
}

.qa_contents {
  margin: 80px 45px 0;
}

.qa_title {
  margin-bottom: 24px;
}

.q_icon,
.a_icon {
  padding: 8px;
  color: var(--main-fontcolor);
  font-weight: bold;
  border-radius: 50%;
  width: 15px;
  height: 15px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-right: 16px;
}

.q_icon {
  background-color: #0166b3;
}

.a_icon {
  background-color: #f0597c;
  position: absolute;
  left: -47px;
}

.q_item {
  color: #0166b3;
  font-weight: bold;
  padding-bottom: 8px;
}

.a_item {
  color: #f0597c;
  font-weight: bold;
  position: relative;
  margin-left: 47px;
}

.a_item:not(:last-child) {
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: 2px dotted #000000;
}

.tokuten_title {
  display: inline-block;
  position: absolute;
  height: 53px;
  line-height: 53px;
  text-align: center;
  padding: 5px 0;
  font-size: 18px;
  background: #f0597c;
  color: #FFF;
  box-sizing: border-box;
  left: -7px;
  top: 44px;
}

.tokuten_title h3 {
  margin: 0 8px 0 4px;
  padding: 0 12px 0 0px;
  border-top: dashed 2px #FFF;
  border-bottom: dashed 2px #FFF;
  line-height: 40px;
  color: #fff;
  font-size: 24px;
}

.tokuten_title:after {
  position: absolute;
  content: '';
  z-index: 1;
  top: 0;
  right: 0;
  width: 0px;
  height: 0px;
  border-width: 27px 16px 30px 0px;
  border-color: transparent #e8f6fd transparent transparent;
  border-style: solid;
}

.kaden img {
  max-width: 100%;
}

.more_banner {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 24px;
}

.more_banner a:hover {
  opacity: 0.8;
}

.more_banner img {
  width: 100%;
}

.category a {
  color: #000000;
}

.category a:hover {
  opacity: 0.8;
  color: #000000;
}

.category a:active {
  color: #000000;
}

.info_txt {
  font-size: 28px;
  color: var(--main-bgcolor);
  font-weight: bold;
  text-align: center;
}

.ins_company {
  font-size: 20px;
  font-weight: bold;
}

.notice_box02 {
  font-size: 16px;
  max-width: 695px;
  width: 100%;
  margin: 0 auto;
}

.notice_box02 li {
  text-indent: -1em;
  padding-left: 1em;
}

/*** hack ***/


/*** responsive ***/
@media(max-width:599px) {
  * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
  }

  html,
  body {
    margin: 0;
    padding: 0;
    width: 100%;
  }

  body {
    margin: 0;
    padding: 0;
  }

  .res_pc {
    display: none !important;
  }

  .res_sp {
    display: block;
  }

  .header {
    height: auto;
    position: static;
  }

  .header .titlebox {
    display: block;
    position: static;
  }

  .header .titlebox .titlebox_l {
    display: block;
    padding: var(--sub-padding);
  }

  .header .titlebox .titlebox_l img {
    width: 100%;
  }

  .header .titlebox .titlebox_l div {
    padding-bottom: 0px;
  }

  .btn a.videoLink {
    width: auto;
    margin: 0 0 8px 0;
    color: #000000;
    background-color: #ffe100;
  }

  .btn a.pointLink {
    width: auto;
    margin: 0 0 8px 0;
    color: #fff;
    background-color: #072985;
  }

  .header .titlebox .btn_box {
    display: block;
    padding: 0;
    margin: var(--sub-margin);
    text-align: center;
  }

  .header .titlebox .btn_box .box {
    margin: 0;
  }

  .item_inner {
    width: auto;
  }

  .item_inner img {
    width: 100%;
  }

  ul.note li {
    text-align: left;
    font-size: 12px;
    letter-spacing: 0;
  }

  .top_pht {
    padding: 0 var(--sub-padding);
  }

  .top_pht img {
    width: 50%;
  }

  .item h2 {
    font-size: 28px;
    display: block;
  }

  .title_txt {
    padding: var(--sub-padding);
    text-align: left;
  }

  p.lead {
    padding: var(--sub-padding) 0;
    font-size: 14px;
    line-height: 1.4;
  }

  ul.service {
    width: auto;
    display: block;
  }

  ul.service li {
    text-align: center;
  }

  ul.service li img {
    width: auto;
  }

  ul.category {
    width: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
  }

  ul.category li {
    width: 100px;
    height: auto;
    margin: 0;
  }

  ul.category li:nth-child(5n) {
    margin: 0;
  }

  ul.category li:nth-child(3n) {
    margin: 0;
  }

  ul.category li span.icon_det {
    width: 108px;
  }

  .item h3 {
    font-size: 22px;
    margin: var(--sub-margin) 0 0 0;
    padding: 0px;
  }

  .item h3 span img {
    width: 68px;
  }

  .pht {
    margin: var(--sub-margin);
  }

  .item.dosam table.compensation,
  .item.dosam table.case {
    width: auto;
    margin: var(--sub-margin) 8px;
  }

  .item.dosam table.compensation tr {
    background-color: unset !important;
  }

  .item.dosam table.compensation tr:nth-child(even) {
    background-color: unset !important;
  }

  .item.dosam table.compensation th {
    display: block;
    width: 100%;
    background-color: #bce0e3;
  }

  .item.dosam table.compensation td {
    display: block;
    width: 100%;
  }

  .item.dosam h2 {
    line-height: 1.3;
    margin: 0;
  }

  .item.dosam h3 {
    margin: var(--sub-margin) 0 0 0;
  }

  .inq_div {
    display: block;
  }

  .flow .inq {
    width: 100%;
  }

  .flow .inq a {
    line-height: 2.2;
  }

  .inquiry {
    margin: 0 auto var(--sub-margin) auto;
  }

  .inquiry .inquiry_box {
    margin: 0 auto var(--sub-margin) auto;
  }

  .footer ul.footer_list {
    gap: 25px;
  }

  .red_box {
    display: block;
  }

  .red_big {
    margin-right: 0px;
  }

  .payment_txt_right {
    text-align: left;
    padding-top: 20px;
  }

  .payment_notice {
    text-align: left;
  }

  .two_col_div,
  .two_col_div01 {
    grid-template-columns: unset;
    gap: 56px;
  }

  .service_box,
  .insurance_box {
    padding: 8px 16px;
  }

  .service_box::after {
    left: 39vw;
  }

  .insurance_box::after {
    left: 39vw;
  }

  .service_box .icon-plus {
    left: -13px;
  }

  .insurance_box .icon-plus {
    left: -13px;
  }

  .item_title {
    font-size: 32px;
  }

  .insurance_box .item_subtitle {
    font-size: 24px;
  }

  .item_inner_txt {
    font-size: 18px;
  }

  .service_box .item_inner_txt span,
  .insurance_box .item_inner_txt span {
    font-size: 28px;
  }

  .item {
    padding: 0 16px;
  }

  .qa_contents {
    margin: 45px 0px;
    font-size: 14px;
  }

  .payment_title {
    padding: 0.5rem 1.3rem;
  }

  .q_icon,
  .a_icon {
    width: 24px;
    height: 24px;
  }

  .a_item {
    margin-left: 41px;
  }

  .a_icon {
    left: -41px;
  }

  .item h2:before {
    left: -7px;
  }

  .point_service01 {
    grid-template-columns: unset;
    margin: 0px;
  }

  .point_service02 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  .grid_item {
    padding-right: 0px;
    border-right: none;
  }

  .grid_item:first-child {
    grid-column: 1/3;
    text-align: center;
  }

  .item.dosam h2:before {
    left: -7px;
  }

  .flow {
    margin: 45px 0px;
    padding: 0px;
  }

  .flow_inquiry {
    margin: var(--main-margin) 0px;
    padding: 0px;
  }

  .inquiry .inquiry_bs dl,
  .inquiry .inquiry_mec-c dl {
    margin: var(--sub-margin) 0px;
  }

  .tokuten_title {
    height: 40px;
    line-height: 40px;
    top: 36px;
  }

  .tokuten_title h3 {
    font-size: 16px;
    margin: 0 8px 0 4px;
    padding: 0 12px 0 0;
    line-height: 26px;
  }

  .tokuten_title:after {
    border-width: 20px 13px 23px 0px;
  }

  .insurance_box .item_title {
    margin-left: 10px;
  }

  .service_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .insurance_subtitle {
    margin: var(--sub-padding);
  }

  .two_col_flex {
    font-size: 14px;
  }

  .two_col_flex img {
    max-width: 20%;
  }

  .tel_icon img {
    width: 25px;
  }

  .category a:hover {
    opacity: unset;
  }

  .ins_company {
    margin: 10px 0 0;
  }

  .notice_box02 {
    font-size: 14px;
    text-align: left;
    padding: 0 16px;
  }
}




