@charset "UTF-8";
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  cursor: pointer;
  color: #0f172a;
}
a:hover {
  cursor: pointer;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-weight: 700;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

*:after,
*:before,
a,
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
button,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
input,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
textarea,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  scroll-padding-top: 100px;
  scroll-behavior: smooth;
  -webkit-scroll-padding-top: 100px;
}
@media (max-width: 700px) {
  html {
    scroll-padding-top: 60px;
  }
}

body {
  position: relative;
  width: calc(100vw - (100vw - 100%));
  min-width: 300px;
  -webkit-text-size-adjust: 100%;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1.5;
  color: #0f172a;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
  letter-spacing: 0;
  font-size: 16px;
}
@media (max-width: 700px) {
  body {
    font-size: 16px;
  }
}
body.no_scroll {
  overflow: hidden !important;
}

/* html,
body {
	scrollbar-width: none;
	-ms-overflow-style: none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar {
	width: 0;
	height: 0;
	display: none;
} */
* :focus:not(:focus-visible) {
  outline: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400;
}

li {
  list-style-type: none;
}

a {
  text-decoration: none;
  color: #0f172a;
  transition: 0.3s;
}

img {
  border: 0;
  vertical-align: middle;
  max-width: 100%;
  height: auto;
}

address,
em,
i {
  font-style: normal;
}

button,
input,
select,
textarea {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  border: 0;
  margin: 0;
  padding: 0;
  background: none;
  vertical-align: middle;
  font-size: inherit;
  color: #0f172a;
  font-family: "Noto Sans JP", sans-serif;
}

input::-webkit-input-placeholder {
  color: #bfbfbf;
}

input:-ms-input-placeholder {
  color: #bfbfbf;
}

input::-moz-placeholder {
  color: #bfbfbf;
}

sup {
  position: relative;
  top: -0.7em;
  font-size: 70%;
}

a[href^="tel:"].tel_disable {
  pointer-events: none;
  text-decoration: none;
}

img[src$=".svg"] {
  width: 100%;
}

.mt0 {
  margin-top: 0px !important;
}

.mr0 {
  margin-right: 0px !important;
}

.ml0 {
  margin-left: 0px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pr0 {
  padding-right: 0px !important;
}

.pl0 {
  padding-left: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.mt1 {
  margin-top: 1px !important;
}

.mr1 {
  margin-right: 1px !important;
}

.ml1 {
  margin-left: 1px !important;
}

.mb1 {
  margin-bottom: 1px !important;
}

.pt1 {
  padding-top: 1px !important;
}

.pr1 {
  padding-right: 1px !important;
}

.pl1 {
  padding-left: 1px !important;
}

.pb1 {
  padding-bottom: 1px !important;
}

.mt2 {
  margin-top: 2px !important;
}

.mr2 {
  margin-right: 2px !important;
}

.ml2 {
  margin-left: 2px !important;
}

.mb2 {
  margin-bottom: 2px !important;
}

.pt2 {
  padding-top: 2px !important;
}

.pr2 {
  padding-right: 2px !important;
}

.pl2 {
  padding-left: 2px !important;
}

.pb2 {
  padding-bottom: 2px !important;
}

.mt3 {
  margin-top: 3px !important;
}

.mr3 {
  margin-right: 3px !important;
}

.ml3 {
  margin-left: 3px !important;
}

.mb3 {
  margin-bottom: 3px !important;
}

.pt3 {
  padding-top: 3px !important;
}

.pr3 {
  padding-right: 3px !important;
}

.pl3 {
  padding-left: 3px !important;
}

.pb3 {
  padding-bottom: 3px !important;
}

.mt4 {
  margin-top: 4px !important;
}

.mr4 {
  margin-right: 4px !important;
}

.ml4 {
  margin-left: 4px !important;
}

.mb4 {
  margin-bottom: 4px !important;
}

.pt4 {
  padding-top: 4px !important;
}

.pr4 {
  padding-right: 4px !important;
}

.pl4 {
  padding-left: 4px !important;
}

.pb4 {
  padding-bottom: 4px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.ml5 {
  margin-left: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pr5 {
  padding-right: 5px !important;
}

.pl5 {
  padding-left: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.mt6 {
  margin-top: 6px !important;
}

.mr6 {
  margin-right: 6px !important;
}

.ml6 {
  margin-left: 6px !important;
}

.mb6 {
  margin-bottom: 6px !important;
}

.pt6 {
  padding-top: 6px !important;
}

.pr6 {
  padding-right: 6px !important;
}

.pl6 {
  padding-left: 6px !important;
}

.pb6 {
  padding-bottom: 6px !important;
}

.mt7 {
  margin-top: 7px !important;
}

.mr7 {
  margin-right: 7px !important;
}

.ml7 {
  margin-left: 7px !important;
}

.mb7 {
  margin-bottom: 7px !important;
}

.pt7 {
  padding-top: 7px !important;
}

.pr7 {
  padding-right: 7px !important;
}

.pl7 {
  padding-left: 7px !important;
}

.pb7 {
  padding-bottom: 7px !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mr8 {
  margin-right: 8px !important;
}

.ml8 {
  margin-left: 8px !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.pt8 {
  padding-top: 8px !important;
}

.pr8 {
  padding-right: 8px !important;
}

.pl8 {
  padding-left: 8px !important;
}

.pb8 {
  padding-bottom: 8px !important;
}

.mt9 {
  margin-top: 9px !important;
}

.mr9 {
  margin-right: 9px !important;
}

.ml9 {
  margin-left: 9px !important;
}

.mb9 {
  margin-bottom: 9px !important;
}

.pt9 {
  padding-top: 9px !important;
}

.pr9 {
  padding-right: 9px !important;
}

.pl9 {
  padding-left: 9px !important;
}

.pb9 {
  padding-bottom: 9px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pr35 {
  padding-right: 35px !important;
}

.pl35 {
  padding-left: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.ml45 {
  margin-left: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pr45 {
  padding-right: 45px !important;
}

.pl45 {
  padding-left: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.mt55 {
  margin-top: 55px !important;
}

.mr55 {
  margin-right: 55px !important;
}

.ml55 {
  margin-left: 55px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.pt55 {
  padding-top: 55px !important;
}

.pr55 {
  padding-right: 55px !important;
}

.pl55 {
  padding-left: 55px !important;
}

.pb55 {
  padding-bottom: 55px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mr60 {
  margin-right: 60px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pr60 {
  padding-right: 60px !important;
}

.pl60 {
  padding-left: 60px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.mt65 {
  margin-top: 65px !important;
}

.mr65 {
  margin-right: 65px !important;
}

.ml65 {
  margin-left: 65px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.pt65 {
  padding-top: 65px !important;
}

.pr65 {
  padding-right: 65px !important;
}

.pl65 {
  padding-left: 65px !important;
}

.pb65 {
  padding-bottom: 65px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mr70 {
  margin-right: 70px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pr70 {
  padding-right: 70px !important;
}

.pl70 {
  padding-left: 70px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.mt75 {
  margin-top: 75px !important;
}

.mr75 {
  margin-right: 75px !important;
}

.ml75 {
  margin-left: 75px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.pt75 {
  padding-top: 75px !important;
}

.pr75 {
  padding-right: 75px !important;
}

.pl75 {
  padding-left: 75px !important;
}

.pb75 {
  padding-bottom: 75px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mr80 {
  margin-right: 80px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pr80 {
  padding-right: 80px !important;
}

.pl80 {
  padding-left: 80px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.mt85 {
  margin-top: 85px !important;
}

.mr85 {
  margin-right: 85px !important;
}

.ml85 {
  margin-left: 85px !important;
}

.mb85 {
  margin-bottom: 85px !important;
}

.pt85 {
  padding-top: 85px !important;
}

.pr85 {
  padding-right: 85px !important;
}

.pl85 {
  padding-left: 85px !important;
}

.pb85 {
  padding-bottom: 85px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mr90 {
  margin-right: 90px !important;
}

.ml90 {
  margin-left: 90px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pr90 {
  padding-right: 90px !important;
}

.pl90 {
  padding-left: 90px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.mt95 {
  margin-top: 95px !important;
}

.mr95 {
  margin-right: 95px !important;
}

.ml95 {
  margin-left: 95px !important;
}

.mb95 {
  margin-bottom: 95px !important;
}

.pt95 {
  padding-top: 95px !important;
}

.pr95 {
  padding-right: 95px !important;
}

.pl95 {
  padding-left: 95px !important;
}

.pb95 {
  padding-bottom: 95px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mr100 {
  margin-right: 100px !important;
}

.ml100 {
  margin-left: 100px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pr100 {
  padding-right: 100px !important;
}

.pl100 {
  padding-left: 100px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

.mt105 {
  margin-top: 105px !important;
}

.mr105 {
  margin-right: 105px !important;
}

.ml105 {
  margin-left: 105px !important;
}

.mb105 {
  margin-bottom: 105px !important;
}

.pt105 {
  padding-top: 105px !important;
}

.pr105 {
  padding-right: 105px !important;
}

.pl105 {
  padding-left: 105px !important;
}

.pb105 {
  padding-bottom: 105px !important;
}

.mt110 {
  margin-top: 110px !important;
}

.mr110 {
  margin-right: 110px !important;
}

.ml110 {
  margin-left: 110px !important;
}

.mb110 {
  margin-bottom: 110px !important;
}

.pt110 {
  padding-top: 110px !important;
}

.pr110 {
  padding-right: 110px !important;
}

.pl110 {
  padding-left: 110px !important;
}

.pb110 {
  padding-bottom: 110px !important;
}

.mt115 {
  margin-top: 115px !important;
}

.mr115 {
  margin-right: 115px !important;
}

.ml115 {
  margin-left: 115px !important;
}

.mb115 {
  margin-bottom: 115px !important;
}

.pt115 {
  padding-top: 115px !important;
}

.pr115 {
  padding-right: 115px !important;
}

.pl115 {
  padding-left: 115px !important;
}

.pb115 {
  padding-bottom: 115px !important;
}

.mt120 {
  margin-top: 120px !important;
}

.mr120 {
  margin-right: 120px !important;
}

.ml120 {
  margin-left: 120px !important;
}

.mb120 {
  margin-bottom: 120px !important;
}

.pt120 {
  padding-top: 120px !important;
}

.pr120 {
  padding-right: 120px !important;
}

.pl120 {
  padding-left: 120px !important;
}

.pb120 {
  padding-bottom: 120px !important;
}

.mt125 {
  margin-top: 125px !important;
}

.mr125 {
  margin-right: 125px !important;
}

.ml125 {
  margin-left: 125px !important;
}

.mb125 {
  margin-bottom: 125px !important;
}

.pt125 {
  padding-top: 125px !important;
}

.pr125 {
  padding-right: 125px !important;
}

.pl125 {
  padding-left: 125px !important;
}

.pb125 {
  padding-bottom: 125px !important;
}

.mt130 {
  margin-top: 130px !important;
}

.mr130 {
  margin-right: 130px !important;
}

.ml130 {
  margin-left: 130px !important;
}

.mb130 {
  margin-bottom: 130px !important;
}

.pt130 {
  padding-top: 130px !important;
}

.pr130 {
  padding-right: 130px !important;
}

.pl130 {
  padding-left: 130px !important;
}

.pb130 {
  padding-bottom: 130px !important;
}

.mt135 {
  margin-top: 135px !important;
}

.mr135 {
  margin-right: 135px !important;
}

.ml135 {
  margin-left: 135px !important;
}

.mb135 {
  margin-bottom: 135px !important;
}

.pt135 {
  padding-top: 135px !important;
}

.pr135 {
  padding-right: 135px !important;
}

.pl135 {
  padding-left: 135px !important;
}

.pb135 {
  padding-bottom: 135px !important;
}

.mt140 {
  margin-top: 140px !important;
}

.mr140 {
  margin-right: 140px !important;
}

.ml140 {
  margin-left: 140px !important;
}

.mb140 {
  margin-bottom: 140px !important;
}

.pt140 {
  padding-top: 140px !important;
}

.pr140 {
  padding-right: 140px !important;
}

.pl140 {
  padding-left: 140px !important;
}

.pb140 {
  padding-bottom: 140px !important;
}

.mt145 {
  margin-top: 145px !important;
}

.mr145 {
  margin-right: 145px !important;
}

.ml145 {
  margin-left: 145px !important;
}

.mb145 {
  margin-bottom: 145px !important;
}

.pt145 {
  padding-top: 145px !important;
}

.pr145 {
  padding-right: 145px !important;
}

.pl145 {
  padding-left: 145px !important;
}

.pb145 {
  padding-bottom: 145px !important;
}

.mt150 {
  margin-top: 150px !important;
}

.mr150 {
  margin-right: 150px !important;
}

.ml150 {
  margin-left: 150px !important;
}

.mb150 {
  margin-bottom: 150px !important;
}

.pt150 {
  padding-top: 150px !important;
}

.pr150 {
  padding-right: 150px !important;
}

.pl150 {
  padding-left: 150px !important;
}

.pb150 {
  padding-bottom: 150px !important;
}

.mt155 {
  margin-top: 155px !important;
}

.mr155 {
  margin-right: 155px !important;
}

.ml155 {
  margin-left: 155px !important;
}

.mb155 {
  margin-bottom: 155px !important;
}

.pt155 {
  padding-top: 155px !important;
}

.pr155 {
  padding-right: 155px !important;
}

.pl155 {
  padding-left: 155px !important;
}

.pb155 {
  padding-bottom: 155px !important;
}

.mt160 {
  margin-top: 160px !important;
}

.mr160 {
  margin-right: 160px !important;
}

.ml160 {
  margin-left: 160px !important;
}

.mb160 {
  margin-bottom: 160px !important;
}

.pt160 {
  padding-top: 160px !important;
}

.pr160 {
  padding-right: 160px !important;
}

.pl160 {
  padding-left: 160px !important;
}

.pb160 {
  padding-bottom: 160px !important;
}

.mt165 {
  margin-top: 165px !important;
}

.mr165 {
  margin-right: 165px !important;
}

.ml165 {
  margin-left: 165px !important;
}

.mb165 {
  margin-bottom: 165px !important;
}

.pt165 {
  padding-top: 165px !important;
}

.pr165 {
  padding-right: 165px !important;
}

.pl165 {
  padding-left: 165px !important;
}

.pb165 {
  padding-bottom: 165px !important;
}

.mt170 {
  margin-top: 170px !important;
}

.mr170 {
  margin-right: 170px !important;
}

.ml170 {
  margin-left: 170px !important;
}

.mb170 {
  margin-bottom: 170px !important;
}

.pt170 {
  padding-top: 170px !important;
}

.pr170 {
  padding-right: 170px !important;
}

.pl170 {
  padding-left: 170px !important;
}

.pb170 {
  padding-bottom: 170px !important;
}

.mt175 {
  margin-top: 175px !important;
}

.mr175 {
  margin-right: 175px !important;
}

.ml175 {
  margin-left: 175px !important;
}

.mb175 {
  margin-bottom: 175px !important;
}

.pt175 {
  padding-top: 175px !important;
}

.pr175 {
  padding-right: 175px !important;
}

.pl175 {
  padding-left: 175px !important;
}

.pb175 {
  padding-bottom: 175px !important;
}

.mt180 {
  margin-top: 180px !important;
}

.mr180 {
  margin-right: 180px !important;
}

.ml180 {
  margin-left: 180px !important;
}

.mb180 {
  margin-bottom: 180px !important;
}

.pt180 {
  padding-top: 180px !important;
}

.pr180 {
  padding-right: 180px !important;
}

.pl180 {
  padding-left: 180px !important;
}

.pb180 {
  padding-bottom: 180px !important;
}

.mt185 {
  margin-top: 185px !important;
}

.mr185 {
  margin-right: 185px !important;
}

.ml185 {
  margin-left: 185px !important;
}

.mb185 {
  margin-bottom: 185px !important;
}

.pt185 {
  padding-top: 185px !important;
}

.pr185 {
  padding-right: 185px !important;
}

.pl185 {
  padding-left: 185px !important;
}

.pb185 {
  padding-bottom: 185px !important;
}

.mt190 {
  margin-top: 190px !important;
}

.mr190 {
  margin-right: 190px !important;
}

.ml190 {
  margin-left: 190px !important;
}

.mb190 {
  margin-bottom: 190px !important;
}

.pt190 {
  padding-top: 190px !important;
}

.pr190 {
  padding-right: 190px !important;
}

.pl190 {
  padding-left: 190px !important;
}

.pb190 {
  padding-bottom: 190px !important;
}

.mt195 {
  margin-top: 195px !important;
}

.mr195 {
  margin-right: 195px !important;
}

.ml195 {
  margin-left: 195px !important;
}

.mb195 {
  margin-bottom: 195px !important;
}

.pt195 {
  padding-top: 195px !important;
}

.pr195 {
  padding-right: 195px !important;
}

.pl195 {
  padding-left: 195px !important;
}

.pb195 {
  padding-bottom: 195px !important;
}

.mt200 {
  margin-top: 200px !important;
}

.mr200 {
  margin-right: 200px !important;
}

.ml200 {
  margin-left: 200px !important;
}

.mb200 {
  margin-bottom: 200px !important;
}

.pt200 {
  padding-top: 200px !important;
}

.pr200 {
  padding-right: 200px !important;
}

.pl200 {
  padding-left: 200px !important;
}

.pb200 {
  padding-bottom: 200px !important;
}

@media (max-width: 700px) {
  .mb0_sp {
    margin-bottom: 0px !important;
  }
  .mb1_sp {
    margin-bottom: 1px !important;
  }
  .mb2_sp {
    margin-bottom: 2px !important;
  }
  .mb3_sp {
    margin-bottom: 3px !important;
  }
  .mb4_sp {
    margin-bottom: 4px !important;
  }
  .mb5_sp {
    margin-bottom: 5px !important;
  }
  .mb6_sp {
    margin-bottom: 6px !important;
  }
  .mb7_sp {
    margin-bottom: 7px !important;
  }
  .mb8_sp {
    margin-bottom: 8px !important;
  }
  .mb9_sp {
    margin-bottom: 9px !important;
  }
  .mb10_sp {
    margin-bottom: 10px !important;
  }
  .mb15_sp {
    margin-bottom: 15px !important;
  }
  .mb20_sp {
    margin-bottom: 20px !important;
  }
  .mb25_sp {
    margin-bottom: 25px !important;
  }
  .mb30_sp {
    margin-bottom: 30px !important;
  }
  .mb35_sp {
    margin-bottom: 35px !important;
  }
  .mb40_sp {
    margin-bottom: 40px !important;
  }
  .mb45_sp {
    margin-bottom: 45px !important;
  }
  .mb50_sp {
    margin-bottom: 50px !important;
  }
  .mb55_sp {
    margin-bottom: 55px !important;
  }
  .mb60_sp {
    margin-bottom: 60px !important;
  }
  .mb65_sp {
    margin-bottom: 65px !important;
  }
  .mb70_sp {
    margin-bottom: 70px !important;
  }
  .mb75_sp {
    margin-bottom: 75px !important;
  }
  .mb80_sp {
    margin-bottom: 80px !important;
  }
  .mb85_sp {
    margin-bottom: 85px !important;
  }
  .mb90_sp {
    margin-bottom: 90px !important;
  }
  .mb95_sp {
    margin-bottom: 95px !important;
  }
  .mb100_sp {
    margin-bottom: 100px !important;
  }
  .mb105_sp {
    margin-bottom: 105px !important;
  }
  .mb110_sp {
    margin-bottom: 110px !important;
  }
  .mb115_sp {
    margin-bottom: 115px !important;
  }
  .mb120_sp {
    margin-bottom: 120px !important;
  }
  .mb125_sp {
    margin-bottom: 125px !important;
  }
  .mb130_sp {
    margin-bottom: 130px !important;
  }
  .mb135_sp {
    margin-bottom: 135px !important;
  }
  .mb140_sp {
    margin-bottom: 140px !important;
  }
  .mb145_sp {
    margin-bottom: 145px !important;
  }
  .mb150_sp {
    margin-bottom: 150px !important;
  }
  .mb155_sp {
    margin-bottom: 155px !important;
  }
  .mb160_sp {
    margin-bottom: 160px !important;
  }
  .mb165_sp {
    margin-bottom: 165px !important;
  }
  .mb170_sp {
    margin-bottom: 170px !important;
  }
  .mb175_sp {
    margin-bottom: 175px !important;
  }
  .mb180_sp {
    margin-bottom: 180px !important;
  }
  .mb185_sp {
    margin-bottom: 185px !important;
  }
  .mb190_sp {
    margin-bottom: 190px !important;
  }
  .mb195_sp {
    margin-bottom: 195px !important;
  }
  .mb200_sp {
    margin-bottom: 200px !important;
  }
  .mt0_sp {
    margin-top: 0px !important;
  }
  .mt1_sp {
    margin-top: 1px !important;
  }
  .mt2_sp {
    margin-top: 2px !important;
  }
  .mt3_sp {
    margin-top: 3px !important;
  }
  .mt4_sp {
    margin-top: 4px !important;
  }
  .mt5_sp {
    margin-top: 5px !important;
  }
  .mt6_sp {
    margin-top: 6px !important;
  }
  .mt7_sp {
    margin-top: 7px !important;
  }
  .mt8_sp {
    margin-top: 8px !important;
  }
  .mt9_sp {
    margin-top: 9px !important;
  }
  .mt10_sp {
    margin-top: 10px !important;
  }
  .mt15_sp {
    margin-top: 15px !important;
  }
  .mt20_sp {
    margin-top: 20px !important;
  }
  .mt25_sp {
    margin-top: 25px !important;
  }
  .mt30_sp {
    margin-top: 30px !important;
  }
  .mt35_sp {
    margin-top: 35px !important;
  }
  .mt40_sp {
    margin-top: 40px !important;
  }
  .mt45_sp {
    margin-top: 45px !important;
  }
  .mt50_sp {
    margin-top: 50px !important;
  }
  .mt55_sp {
    margin-top: 55px !important;
  }
  .mt60_sp {
    margin-top: 60px !important;
  }
  .mt65_sp {
    margin-top: 65px !important;
  }
  .mt70_sp {
    margin-top: 70px !important;
  }
  .mt75_sp {
    margin-top: 75px !important;
  }
  .mt80_sp {
    margin-top: 80px !important;
  }
  .mt85_sp {
    margin-top: 85px !important;
  }
  .mt90_sp {
    margin-top: 90px !important;
  }
  .mt95_sp {
    margin-top: 95px !important;
  }
  .mt100_sp {
    margin-top: 100px !important;
  }
  .mt105_sp {
    margin-top: 105px !important;
  }
  .mt110_sp {
    margin-top: 110px !important;
  }
  .mt115_sp {
    margin-top: 115px !important;
  }
  .mt120_sp {
    margin-top: 120px !important;
  }
  .mt125_sp {
    margin-top: 125px !important;
  }
  .mt130_sp {
    margin-top: 130px !important;
  }
  .mt135_sp {
    margin-top: 135px !important;
  }
  .mt140_sp {
    margin-top: 140px !important;
  }
  .mt145_sp {
    margin-top: 145px !important;
  }
  .mt150_sp {
    margin-top: 150px !important;
  }
  .mt155_sp {
    margin-top: 155px !important;
  }
  .mt160_sp {
    margin-top: 160px !important;
  }
  .mt165_sp {
    margin-top: 165px !important;
  }
  .mt170_sp {
    margin-top: 170px !important;
  }
  .mt175_sp {
    margin-top: 175px !important;
  }
  .mt180_sp {
    margin-top: 180px !important;
  }
  .mt185_sp {
    margin-top: 185px !important;
  }
  .mt190_sp {
    margin-top: 190px !important;
  }
  .mt195_sp {
    margin-top: 195px !important;
  }
  .mt200_sp {
    margin-top: 200px !important;
  }
}
.header {
  width: 100%;
  transition: 0.5s ease-in-out;
  position: sticky;
  top: 0;
  z-index: 10;
}
.header .header_inner {
  background: #fff;
  margin: 0;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 0 clamp(20px, 2vw, 60px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .header .header_inner {
    padding: 0 0 0 min(30px, 2vw);
  }
}
@media (max-width: 900px) {
  .header .header_inner {
    padding: 0 0 0 20px;
  }
}
.header .header_nav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
@media (min-width: 1441px) {
  .header .header_nav {
    width: 59%;
  }
}
.header .logoarea {
  position: relative;
  z-index: 11;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 20px 0;
}
@media (min-width: 1441px) {
  .header .logoarea {
    width: 33%;
  }
}
@media (max-width: 1730px) {
  .header .logoarea {
    flex-direction: column;
    gap: 0;
    padding: 0;
    width: auto;
  }
}
.header .logoarea img {
  max-width: 360px;
  height: auto;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .header .logoarea img {
    max-width: 270px;
  }
}
@media (min-width: 751px) and (max-width: 1000px) {
  .header .logoarea img {
    max-width: 200px;
  }
}
@media (max-width: 900px) {
  .header .logoarea img {
    max-width: 180px;
  }
}
.header .logoarea a {
  display: block;
}
.header .logoarea a:hover img {
  opacity: 0.8;
}
.header .logoarea span {
  display: block;
  font-size: clamp(10px, 1vw, 16px);
}
@media (max-width: 1730px) {
  .header .logoarea span {
    padding-left: 3.5em;
    text-align: center;
  }
}
.header .hamburger {
  display: none;
}
@media (max-width: 900px) {
  .header .hamburger {
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    min-width: 60px;
    height: 60px;
    top: 0;
    right: 0;
    z-index: 10;
    background: #3957a6;
    padding: 9px;
  }
}
.header .hamburger .hamburger__line {
  position: relative;
  width: 24px;
  height: 1px;
  background: #fff;
  display: block;
}
.header .hamburger .hamburger__line::before, .header .hamburger .hamburger__line::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 1px;
  transition: transform 0.3s;
  background: #fff;
}
.header .hamburger .hamburger__line::before {
  top: -8px;
}
.header .hamburger .hamburger__line::after {
  bottom: -8px;
}
.header .hamburger[aria-expanded=true] .hamburger__line {
  background: transparent;
}
.header .hamburger[aria-expanded=true] .hamburger__line::before {
  top: 0;
  transform: rotate(45deg);
}
.header .hamburger[aria-expanded=true] .hamburger__line::after {
  top: 0;
  transform: rotate(-45deg);
}
@media (min-width: 701px) {
  .header .globalnav {
    display: block !important;
  }
}
@media (max-width: 900px) {
  .header .globalnav {
    position: absolute;
    top: 60px;
    right: 0;
    width: 100%;
    height: calc(100dvh - 60px);
    background: #3957a6;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
    scrollbar-width: none;
    z-index: 8;
    transition: transform 0.5s ease-in-out;
    opacity: 0;
    visibility: hidden;
  }
}
.header .globalnav.active {
  opacity: 1;
  visibility: visible;
  transition: 0.5s ease-out;
}
@media (max-width: 900px) {
  .header .globalnav .globalnav__inner {
    padding: 0 20px 150px;
  }
}
.header .globalnav .gnav {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: min(40px, 2vw);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .header .globalnav .gnav {
    gap: 15px;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav {
    flex-direction: column;
    justify-content: flex-start;
    align-items: inherit;
    gap: 0;
  }
}
.header .globalnav .gnav li {
  position: relative;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li {
    border-bottom: 1px solid #fff;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li:has(.open) {
    border-bottom: none;
  }
}
.header .globalnav .gnav li a {
  font-size: clamp(12px, 1.3vw, 16px);
  padding: 38px 0;
  display: block;
  text-align: center;
  font-weight: bold;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li a {
    font-weight: 400;
    text-align: left;
    padding: 20px 0;
    color: #fff;
    font-size: 16px;
    position: relative;
  }
}
.header .globalnav .gnav li a:hover {
  color: #3957a6;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li a:hover {
    color: #fff;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li a::before {
    position: absolute;
    content: "";
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    transform: rotate(-45deg);
    width: 12px;
    height: 12px;
    margin: auto;
    inset: 0 10px 0 auto;
  }
}
.header .globalnav .gnav li.toppage {
  display: none;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li.toppage {
    display: block;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li.h_btn {
    display: none;
  }
}
.header .globalnav .gnav li.h_btn a {
  color: #fff;
  background: #f97316;
  padding: 38px clamp(20px, 3.7vw, 72px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .header .globalnav .gnav li.h_btn a {
    padding: 38px clamp(10px, 2vw, 30px);
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li.h_btn a {
    padding: 20px 0;
    text-align: center;
    margin-top: 24px;
  }
}
.header .globalnav .gnav li.h_btn a:hover {
  background: #d75800;
}
.header .globalnav .gnav li.h_btn a::before {
  display: none;
}
.header .globalnav .gnav li .has_child {
  font-size: clamp(12px, 1.3vw, 16px);
  padding: 38px 0;
  display: block;
  text-align: center;
  font-weight: bold;
  cursor: pointer;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child {
    font-weight: 400;
    text-align: left;
    padding: 20px 0;
    color: #fff;
    font-size: 16px;
    width: 100%;
    position: relative;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child::before, .header .globalnav .gnav li .has_child::after {
    position: absolute;
    content: "";
    background: #fff;
    width: 16px;
    height: 1px;
    margin: auto;
    inset: 0 6px 0 auto;
    transition: 0.3s;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child::after {
    transform: rotate(90deg);
  }
}
.header .globalnav .gnav li .has_child.open {
  position: relative;
}
.header .globalnav .gnav li .has_child.open::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 100%;
  height: 5px;
  bottom: 0;
  left: 0;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child.open::before {
    background: #fff;
    width: 16px;
    height: 1px;
    margin: auto;
    inset: 0 6px 0 auto;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child.open::after {
    transform: rotate(0deg);
  }
}
.header .globalnav .gnav li .has_child:hover {
  color: #3957a6;
}
@media (max-width: 900px) {
  .header .globalnav .gnav li .has_child:hover {
    color: #fff;
  }
}
@media (min-width: 1441px) {
  .header .globalnav .gnav li.r_side .child_menu {
    left: auto;
    right: 0;
  }
}
@media (min-width: 901px) and (max-width: 1440px) {
  .header .globalnav .gnav li.r_side .child_menu {
    left: auto;
    right: 0;
  }
}
.header .globalnav .gnav .child_menu {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@media (min-width: 1441px) {
  .header .globalnav .gnav .child_menu {
    position: absolute;
    width: 100%;
    left: 0;
    top: 100%;
    min-width: 240px;
  }
}
@media (min-width: 901px) and (max-width: 1440px) {
  .header .globalnav .gnav .child_menu {
    position: absolute;
    width: 100%;
    left: 0;
    top: 100%;
    min-width: 240px;
  }
}
.header .globalnav .gnav .child_menu.is_open {
  pointer-events: auto;
  z-index: 1;
  opacity: 1;
  visibility: visible;
}
@media (max-width: 900px) {
  .header .globalnav .gnav .child_menu ul li {
    border-bottom: none;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav .child_menu ul li:not(:last-of-type) a {
    border-bottom: 1px solid #cbd5e1;
  }
}
.header .globalnav .gnav .child_menu ul li a {
  padding: 0;
  text-align: left;
  font-weight: 400;
  padding: 16px 20px;
  background: #fff;
  border: 1px solid #cbd5e1;
}
@media (max-width: 900px) {
  .header .globalnav .gnav .child_menu ul li a {
    color: #0f172a;
    background: #f1f5f9;
    border: none;
    padding: 9px 20px;
  }
}
@media (max-width: 900px) {
  .header .globalnav .gnav .child_menu ul li a::before {
    display: none;
  }
}
.header .globalnav .gnav .child_menu ul li a:hover {
  background: #f1f5f9;
}
.header .globalnav .gnav .child_menu ul li + li a {
  border-top: none;
}
.header .globalnav .trivia_link a {
  background: #fff;
  display: block;
  position: relative;
  font-size: min(16px, 4.6vw);
  color: #0f172a;
  line-height: 60px;
  padding-left: 59px;
  width: 100%;
  margin-top: 32px;
}
@media (max-width: 900px) {
  .header .globalnav .trivia_link a {
    max-width: 400px;
    margin: 32px auto;
  }
}
.header .globalnav .trivia_link a::before, .header .globalnav .trivia_link a::after {
  content: "";
  position: absolute;
  margin: auto;
}
.header .globalnav .trivia_link a::before {
  width: 40px;
  height: 40px;
  background: #f1f5f9;
  inset: 0 auto 0 10px;
  border-radius: 50%;
}
.header .globalnav .trivia_link a::after {
  background: url(../img/top/car_icon.svg) no-repeat center center/contain;
  width: 24px;
  height: 24px;
  inset: 0 auto 0 18px;
  z-index: 1;
}
.header .globalnav .cta_link {
  display: none;
}
@media (max-width: 900px) {
  .header .globalnav .cta_link {
    display: block;
    margin-top: 32px;
    background: #f97316;
    border: 2px solid #fff;
    border-radius: 10px;
    padding: 16px 20px;
    max-width: 400px;
    margin: 0 auto;
  }
}
@media (max-width: 374px) {
  .header .globalnav .cta_link {
    padding: 15px;
  }
}
.header .globalnav .cta_link .bg {
  background: #fff;
  border-radius: 50px;
}
.header .globalnav .cta_link .bg p {
  text-align: center;
  font-weight: bold;
  font-size: clamp(16px, 2.2vw, 25px);
  line-height: 40px;
}
@media (max-width: 700px) {
  .header .globalnav .cta_link .bg p {
    line-height: 30px;
  }
}
.header .globalnav .cta_link .bg p span {
  font-size: 120%;
  color: #4cc764;
}
@media (max-width: 700px) {
  .header .globalnav .cta_link .bg p span {
    font-size: 16px;
  }
}
.header .globalnav .cta_link .tel {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 5px;
}
@media (max-width: 374px) {
  .header .globalnav .cta_link .tel {
    flex-direction: column;
  }
}
.header .globalnav .cta_link .tel a {
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: min(6vw, 26px);
  color: #fff;
  position: relative;
  padding-left: 32px;
}
.header .globalnav .cta_link .tel a::before {
  content: "";
  position: absolute;
  background: url("../img/icon/icon_phone.svg") no-repeat center center/contain;
  width: 24px;
  height: 24px;
  inset: 0 auto 0 0;
  margin: auto;
  filter: brightness(0) invert(1);
}
.header .globalnav .cta_link .tel span {
  color: #fff;
  font-size: 12px;
}
@media (max-width: 374px) {
  .header .globalnav .cta_link .tel span {
    font-size: 10px;
  }
}

footer {
  padding-bottom: 89px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  footer {
    padding-bottom: 79px;
  }
}
@media (max-width: 900px) {
  footer {
    padding-bottom: 58px;
  }
}
@media (max-width: 700px) {
  footer {
    padding-bottom: 50px;
  }
}
footer .footer_top {
  background: #f1f5f9;
  padding: 26px 0;
}
footer .footer_top ul {
  display: flex;
  justify-content: flex-end;
  gap: 65px;
  width: 96%;
  margin: 0 auto;
  max-width: 1390px;
}
@media (max-width: 700px) {
  footer .footer_top ul {
    width: 94%;
    flex-direction: column;
    gap: 10px;
  }
}
footer .footer_main {
  padding: 110px 0 65px;
}
@media (min-width: 901px) and (max-width: 1440px) {
  footer .footer_main {
    padding: 50px 0;
  }
}
@media (max-width: 900px) {
  footer .footer_main {
    padding: 35px 0;
  }
}
footer .footer_main .sec_inner {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}
@media (max-width: 900px) {
  footer .footer_main .sec_inner {
    flex-direction: column;
    gap: 30px;
  }
}
@media (min-width: 1441px) {
  footer .f_info_area {
    width: 35%;
  }
}
@media (max-width: 900px) {
  footer .f_info_area {
    text-align: center;
  }
}
footer .f_info_area .logoarea {
  margin: 20px 0 50px;
}
@media (max-width: 700px) {
  footer .f_info_area .logoarea {
    text-align: center;
    margin: 0 0 30px;
  }
}
footer .f_info_area .logoarea img {
  max-width: 360px;
}
@media (max-width: 700px) {
  footer .f_info_area .logoarea img {
    max-width: 260px;
  }
}
footer .f_info_area .name {
  font-size: clamp(16px, 2vw, 20px);
  margin-bottom: 20px;
}
@media (max-width: 700px) {
  footer .f_info_area .name {
    font-size: min(16px, 4vw);
  }
}
footer .f_info_area .name span {
  font-size: 80%;
}
footer .f_info_area .address a {
  color: #0f172a;
}
@media (max-width: 700px) {
  footer .f_info_area .address {
    font-size: min(16px, 4vw);
  }
}
footer .footer_nav {
  display: none;
}
@media (min-width: 1441px) {
  footer .footer_nav {
    max-width: 980px;
    width: 65%;
    display: grid;
    gap: 30px 120px;
  }
}
@media (min-width: 901px) {
  footer .footer_nav {
    max-width: 980px;
    width: 65%;
    display: grid;
    gap: 30px;
  }
}
footer .footer_nav .top_link {
  font-weight: 600;
}
@media (min-width: 1441px) {
  footer .footer_nav .top_link {
    grid-area: 1/1/3/2;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .top_link {
    grid-area: 1/1/2/2;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav01 {
    grid-area: 1/2/2/3;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav01 {
    grid-area: 2/1/3/2;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav02 {
    grid-area: 1/3/2/4;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav02 {
    grid-area: 2/2/3/3;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav03 {
    grid-area: 1/4/2/5;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav03 {
    grid-area: 2/3/3/4;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav04 {
    grid-area: 2/2/3/3;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav04 {
    grid-area: 3/1/4/2;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav05 {
    grid-area: 2/3/3/4;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav05 {
    grid-area: 3/2/4/3;
  }
}
@media (min-width: 1441px) {
  footer .footer_nav .nav06 {
    grid-area: 2/4/3/5;
  }
}
@media (min-width: 901px) {
  footer .footer_nav .nav06 {
    grid-area: 3/3/4/4;
  }
}
footer .footer_nav .f_nav a {
  line-height: 2.5;
  display: block;
  transition: all 0.3s ease;
}
footer .footer_nav .f_nav a:hover {
  color: #3957a6;
}
footer .footer_bottom {
  background: #cbd5e1;
  padding: 30px 0;
}
@media (max-width: 700px) {
  footer .footer_bottom {
    padding: 20px 0;
  }
}
footer .footer_bottom .copy {
  text-align: center;
}

footer + .ti-widget,
footer ~ .ti-widget {
  display: none !important;
}

aside.flow_content {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 7;
}
aside.flow_content .flow_content_inner {
  background: #3957a6;
  width: 96%;
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 26px;
  border-radius: 20px 20px 0 0;
  border: 2px solid #fff;
  border-bottom: none;
}
@media (min-width: 701px) and (max-width: 1440px) {
  aside.flow_content .flow_content_inner {
    justify-content: center;
    gap: 20px;
    padding: 9px;
    border-radius: 10px 10px 0 0;
    width: 90%;
  }
}
@media (max-width: 900px) {
  aside.flow_content .flow_content_inner {
    max-width: calc(100% - 150px);
  }
}
@media (max-width: 700px) {
  aside.flow_content .flow_content_inner {
    gap: 10px;
    padding: 9px;
    width: 100%;
    border-radius: 10px 10px 0 0;
    max-width: 100%;
    justify-content: center;
  }
}
aside.flow_content .accent {
  background: #ffd52b;
  border-radius: 50px;
  padding: 10px 30px;
  font-weight: bold;
  font-size: clamp(16px, 1.8vw, 20px);
}
@media (max-width: 900px) {
  aside.flow_content .accent {
    display: none;
  }
}
aside.flow_content .tel.tabpc {
  position: relative;
  padding-left: 2.5em;
  color: #fff;
}
aside.flow_content .tel.tabpc::before {
  content: "";
  position: absolute;
  background: url("../img/icon/icon_phone_white.svg") no-repeat center center/contain;
  width: 32px;
  height: 32px;
  inset: auto auto 0 0;
  margin: auto;
  filter: brightness(0) invert(1);
}
aside.flow_content .tel.tabpc span {
  display: block;
  font-size: clamp(12px, 1.2vw, 14px);
  margin-bottom: 2px;
}
aside.flow_content .tel.tabpc a {
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: clamp(20px, 2.8vw, 32px);
  color: #fff;
  line-height: 1;
}
@media (max-width: 700px) {
  aside.flow_content .tel.sp a {
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    color: #3957a6;
    border-radius: 200px;
    height: 32px;
    width: 110px;
    font-weight: bold;
    font-size: 15px;
    text-align: center;
    line-height: 1;
    position: relative;
    padding-left: 26px;
    letter-spacing: 0;
  }
}
@media (max-width: 700px) {
  aside.flow_content .tel.sp a::before {
    background: #fff;
    content: "";
    position: absolute;
    background: url("../img/icon/icon_phone_c.svg") no-repeat center center/contain;
    width: 24px;
    height: 24px;
    inset: 0 auto 0 4px;
    margin: auto;
  }
}
@media (max-width: 700px) {
  aside.flow_content .tel.sp a small {
    background: #fff;
    display: block;
    font-size: 8px;
    font-weight: normal;
  }
}
aside.flow_content .line_mail_btns {
  gap: 20px;
  margin: 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  aside.flow_content .line_mail_btns {
    gap: 15px;
  }
}
@media (max-width: 700px) {
  aside.flow_content .line_mail_btns {
    gap: 10px;
  }
}
aside.flow_content .line_mail_btns a {
  font-size: clamp(16px, 1.8vw, 20px);
  border-width: 2px;
  width: 160px;
  line-height: 52px;
  padding-left: 1em;
}
@media (min-width: 701px) and (max-width: 1440px) {
  aside.flow_content .line_mail_btns a {
    line-height: 42px;
  }
}
@media (max-width: 700px) {
  aside.flow_content .line_mail_btns a {
    font-size: min(15px, 3.5vw);
    line-height: 30px;
    border-width: 1px;
    width: 25.6vw;
  }
}
aside.flow_content .line_mail_btns a::before {
  width: 40px;
  height: 40px;
}
@media (max-width: 700px) {
  aside.flow_content .line_mail_btns a::before {
    width: 24px;
    height: 24px;
  }
}
aside.flow_content .line_mail_btns a.mail {
  background: #f97316;
  color: #fff;
}
@media (max-width: 700px) {
  aside.flow_content .line_mail_btns a.mail {
    background: #fff;
    color: #f97316;
    padding-left: 15px;
  }
}
aside.flow_content .line_mail_btns a.mail::before {
  background: url("../img/icon/icon_mail.svg") no-repeat center center/contain;
}
@media (max-width: 700px) {
  aside.flow_content .line_mail_btns a.mail::before {
    background: url("../img/icon/icon_mail_orange.svg") no-repeat center center/contain;
  }
}
aside.flow_content .line_mail_btns a.mail:hover {
  background: #d75800;
}

.jiko_header {
  aspect-ratio: 192/48;
  background: url("../img/jiko_common/mv@2x.webp") no-repeat center center/cover;
  display: flex;
  align-items: center;
}
@media (max-width: 700px) {
  .jiko_header {
    background: url("../img/jiko_common/mv_sp@3x.webp") no-repeat center center/cover;
    aspect-ratio: 39/18;
  }
}
.jiko_header .header_inner {
  display: inline-block;
}
@media (min-width: 701px) {
  .jiko_header .header_inner {
    padding: 20px;
    background: #fff;
  }
}
.jiko_header .header_inner > div {
  display: flex;
  align-items: center;
  gap: 48px;
}
@media (max-width: 700px) {
  .jiko_header .header_inner > div {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}
@media (max-width: 700px) {
  .jiko_header .logoarea {
    padding: 5px 10px 5px min(4vw, 20px);
    background: #fff;
  }
}
.jiko_header .logoarea img {
  max-width: 360px;
}
@media (max-width: 700px) {
  .jiko_header .logoarea img {
    max-width: 206px;
  }
}
.jiko_header .jiko_h1 {
  font-size: clamp(20px, 3vw, 56px);
  font-weight: bold;
  position: relative;
  letter-spacing: 0.05em;
}
@media (max-width: 700px) {
  .jiko_header .jiko_h1 {
    padding: 10px 5px;
    background: #fff;
    font-size: 23px;
  }
}
@media (min-width: 701px) {
  .jiko_header .jiko_h1::before {
    position: absolute;
    content: "";
    background: #3957a6;
    width: 1px;
    height: 80px;
    margin: auto;
    inset: 0 auto 0 -24px;
  }
}

#index main {
  overflow: hidden;
}
#index .sec_mv {
  background: url("../img/top/mv_bg@2x.webp") no-repeat center center/cover;
  padding: 100px 0 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv {
    padding: 50px 0 0;
  }
}
@media (max-width: 700px) {
  #index .sec_mv {
    padding: 10px 0;
    background: url("../img/top/mv_bg@3x.webp") no-repeat center center/cover;
  }
}
#index .sec_mv .mv_inner {
  display: flex;
  align-items: flex-end;
  max-width: 1663px;
  width: 98%;
  margin: 0 auto;
}
@media (min-width: 1441px) {
  #index .sec_mv .mv_inner {
    transform: translateX(32px);
  }
}
@media (max-width: 900px) {
  #index .sec_mv .mv_inner {
    position: relative;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .mv_inner {
    flex-direction: column;
    width: 100%;
    align-items: center;
  }
}
#index .sec_mv .txt_area {
  padding-bottom: 50px;
  width: 68%;
}
@media (max-width: 900px) {
  #index .sec_mv .txt_area {
    width: 58%;
    padding-top: 120px;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .txt_area {
    width: 90%;
    margin: 0 auto;
    padding-bottom: 15px;
    padding-top: 0;
  }
}
#index .sec_mv .sp {
  margin: -96px 0 0;
  position: relative;
}
#index .sec_mv .img_area {
  width: 32%;
}
@media (max-width: 900px) {
  #index .sec_mv .img_area {
    width: 42%;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .img_area {
    width: 100%;
    margin-top: -80px;
  }
}
#index .sec_mv .img_area figure {
  position: relative;
}
@media (max-width: 700px) {
  #index .sec_mv .img_area figure {
    width: 70.7vw;
    margin: 0 6px 0 auto;
    max-width: 400px;
  }
}
#index .sec_mv .img_area figure figcaption {
  position: absolute;
  color: #fff;
  bottom: 15px;
  right: 30px;
  font-size: clamp(14px, 1.6vw, 20px);
}
@media (max-width: 700px) {
  #index .sec_mv .img_area figure figcaption {
    color: #0f172a;
    left: -50px;
    right: inherit;
    bottom: inherit;
    top: 130px;
  }
}
#index .sec_mv .hero {
  font-weight: bold;
  font-size: clamp(18px, 2.2vw, 40px);
  margin-bottom: 40px;
}
@media (max-width: 900px) {
  #index .sec_mv .hero {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    width: 100%;
    text-align: center;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .hero {
    font-size: min(28px, 5vw);
    margin-bottom: 30px;
    position: relative;
    text-align: left;
  }
}
#index .sec_mv .hero strong {
  display: block;
  font-size: clamp(22px, 3.4vw, 56px);
  font-weight: bold;
}
@media (min-width: 701px) {
  #index .sec_mv .hero strong {
    margin-left: 5px;
  }
}
#index .sec_mv .hero strong span {
  font-size: clamp(36px, 4.2vw, 80px);
}
@media (max-width: 700px) {
  #index .sec_mv .hero strong span {
    display: block;
  }
}
#index .sec_mv .mv_mail_btn {
  background: #f97316;
  border: 2px solid #fff;
  border-radius: 10px;
  padding: 20px 25px;
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  max-width: 720px;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.15);
}
@media (min-width: 1441px) {
  #index .sec_mv .mv_mail_btn {
    padding: 20px 60px 10px 30px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .mv_mail_btn {
    padding: 20px 60px 20px 20px;
  }
}
@media (max-width: 900px) {
  #index .sec_mv .mv_mail_btn {
    padding: 20px 50px 20px 20px;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn {
    width: 89.7vw;
    display: block;
    padding: 15px 20px 10px;
    margin: 0 auto;
  }
}
@media (min-width: 701px) {
  #index .sec_mv .mv_mail_btn::after {
    position: absolute;
    content: "";
    border-right: 1.5px solid #fff;
    border-bottom: 1.5px solid #fff;
    transform: rotate(-45deg);
    width: 26px;
    height: 26px;
    margin: auto;
    inset: 0 40px 0 auto;
  }
}
@media (max-width: 900px) {
  #index .sec_mv .mv_mail_btn::after {
    inset: 0 20px 0 auto;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn.tabpc {
    display: none;
  }
}
#index .sec_mv .mv_mail_btn i {
  width: 80px;
  height: 80px;
}
@media (max-width: 900px) {
  #index .sec_mv .mv_mail_btn i {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn i {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 360px) {
  #index .sec_mv .mv_mail_btn i {
    width: 40px;
    height: 40px;
  }
}
#index .sec_mv .mv_mail_btn .txtarea {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: calc(100% - 100px - 46px);
}
@media (max-width: 900px) {
  #index .sec_mv .mv_mail_btn .txtarea {
    width: 100%;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn .txtarea {
    flex-direction: row;
    width: 100%;
    align-items: center;
    justify-content: center;
    margin-top: 7px;
    gap: 15px;
  }
}
#index .sec_mv .mv_mail_btn .bg {
  background: #fff;
  border-radius: 50px;
}
#index .sec_mv .mv_mail_btn .bg p {
  text-align: center;
  font-weight: bold;
  font-size: clamp(16px, 2.2vw, 25px);
  line-height: 40px;
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn .bg p {
    line-height: 30px;
  }
}
#index .sec_mv .mv_mail_btn .bg p span {
  font-size: 120%;
  color: #4cc764;
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn .bg p span {
    font-size: 16px;
  }
}
#index .sec_mv .mv_mail_btn .ttl {
  font-size: clamp(22px, 3vw, 40px);
  font-weight: bold;
  text-align: center;
  color: #fff;
}
@media (max-width: 700px) {
  #index .sec_mv .mv_mail_btn .ttl {
    font-size: min(24px, 5.8vw);
  }
}
#index .sec_mv .mv_mail_btn:hover {
  opacity: 0.8;
}
#index .sec_mv .check {
  position: relative;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .check {
    margin-bottom: 35px;
  }
}
@media (min-width: 1441px) {
  #index .sec_mv .check {
    display: flex;
    align-items: baseline;
    gap: 57px;
    margin-bottom: 65px;
  }
}
#index .sec_mv .check::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 200%;
  top: -15%;
  right: 0;
  height: 130%;
  clip-path: polygon(0 0, 100% 0%, 98.7% 100%, 0% 100%);
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .check::before {
    clip-path: polygon(0 0, 100% 0%, 96.7% 100%, 0% 100%);
    height: 130%;
    top: -25%;
  }
}
@media (min-width: 1400px) and (max-width: 1700px) {
  #index .sec_mv .check::before {
    right: -5%;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .check::before {
    height: 140%;
    top: -30%;
    right: -2%;
    clip-path: polygon(0 0, 100% 0%, 95.7% 100%, 0% 100%);
  }
}
#index .sec_mv .check li {
  color: #fff;
  font-size: clamp(24px, 2.4vw, 40px);
  position: relative;
  padding-left: 67px;
  font-weight: bold;
  letter-spacing: -0.02em;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .check li {
    padding-left: 57px;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .check li {
    padding-left: 27px;
    font-size: min(20px, 4.6vw);
  }
}
#index .sec_mv .check li::before {
  position: absolute;
  content: "";
  background: url("../img/top/mv_check_icon.svg") no-repeat center center/contain;
  width: 64px;
  height: 58px;
  inset: 0 auto 0 0;
  margin: auto;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .check li::before {
    width: 48px;
    height: 44px;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .check li::before {
    width: 24px;
    height: 21px;
    background: url("../img/top/mv_check_icon_sp.svg") no-repeat center center/contain;
  }
}
@media (max-width: 1440px) {
  #index .sec_mv .check li + li {
    margin-top: 5px;
  }
}
#index .sec_mv .check li strong {
  font-size: clamp(28px, 3.4vw, 56px);
  font-weight: bold;
}
#index .sec_mv .check li strong.en {
  font-size: clamp(50px, 6.2vw, 75px);
  line-height: 1.2;
  line-height: 0.2;
}
@media (min-width: 1441px) {
  #index .sec_mv .check li:first-of-type::before {
    inset: -6px auto auto 0;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_mv .check li:first-of-type::before {
    inset: -9px auto auto 0;
  }
}
@media (max-width: 900px) {
  #index .sec_mv .check li:first-of-type::before {
    inset: -12px auto auto 0;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .check li:first-of-type::before {
    inset: 0 auto 0 0;
  }
}
#index .sec_mv .check li:last-of-type::before {
  /*  @include mq(tab) {
      inset: -9px auto auto 0;
  } */
}
@media (max-width: 900px) {
  #index .sec_mv .check li:last-of-type::before {
    inset: -7px auto auto 0;
  }
}
@media (max-width: 700px) {
  #index .sec_mv .check li:last-of-type::before {
    inset: 0 auto 0 0;
  }
}
#index .sec_mv .note {
  margin-top: 40px;
}
@media (max-width: 700px) {
  #index .sec_mv .note {
    margin: 10px;
  }
}
#index .sec_mv .comment {
  font-size: clamp(16px, 1.8vw, 32px);
  line-height: 1.2;
  margin-bottom: 20px;
  font-weight: bold;
}
@media (max-width: 700px) {
  #index .sec_mv .comment {
    font-size: min(20px, 6vw);
    text-shadow: 2px 0 0 #fff, -2px 0 0 #fff, 0 2px 0 #fff, 0 -2px 0 #fff, 2px 2px 0 #fff, -2px 2px 0 #fff, -2px -2px 0 #fff, 2px -2px 0 #fff;
    margin: 30px 0 0;
  }
}
#index .sec_mv .comment strong {
  font-size: clamp(24px, 3.2vw, 48px);
  font-family: "Roboto", sans-serif;
}
#index .sec_news {
  padding: 25px 0;
  position: relative;
}
@media (max-width: 700px) {
  #index .sec_news {
    padding: 15px 0;
  }
}
#index .sec_news .sec_inner {
  max-width: 1440px;
}
@media (min-width: 701px) {
  #index .sec_news .sec_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
  }
}
@media (min-width: 701px) {
  #index .sec_news .news_block {
    display: flex;
    align-items: center;
    width: calc(100% - 140px);
  }
}
#index .sec_news .news_block .swiper-wrapper {
  align-items: center;
}
#index .sec_news .news_block dt {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}
@media (min-width: 701px) {
  #index .sec_news .news_block dt {
    width: 137px;
    border-right: 1px solid #3957a6;
    margin-bottom: 0;
  }
}
#index .sec_news .news_block dd {
  width: auto;
}
@media (min-width: 701px) {
  #index .sec_news .news_block dd {
    padding-left: min(2vw, 40px);
    width: calc(100% - 137px - min(2vw, 40px));
  }
}
#index .sec_news .news_block dd .newsList_item a {
  display: flex;
  gap: 40px;
  align-items: center;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_news .news_block dd .newsList_item a {
    gap: 20px;
  }
}
@media (max-width: 700px) {
  #index .sec_news .news_block dd .newsList_item a {
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0;
  }
}
#index .sec_news .news_block dd .newsList_item a time {
  font-size: clamp(16px, 1.6vw, 18px);
  min-width: 103px;
}
#index .sec_news .news_block dd .newsList_item a .newsList_ttl {
  font-size: clamp(16px, 1.6vw, 18px);
  text-decoration: underline;
  transition: 0.3s;
  width: auto;
  text-underline-offset: 3px;
}
#index .sec_news .news_block dd .newsList_item a .newsList_ttl:hover {
  text-decoration: none;
}
@media (max-width: 700px) {
  #index .sec_news .txt_link {
    position: absolute;
    top: 15px;
    right: 20px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_merit .hukidashi_ttl {
    margin-bottom: 40px;
  }
}
#index .sec_free_consultation {
  padding: 120px 0 0;
  background: url("../img/top/free_consultation_bg@2x.webp") no-repeat center center/cover;
  position: relative;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_free_consultation {
    padding: 60px 0 0;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation {
    padding: 50px 0;
  }
}
#index .sec_free_consultation::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(38, 64, 133, 0.85);
  z-index: 0;
}
#index .sec_free_consultation .free_inner {
  width: 100%;
  position: relative;
  z-index: 1;
}
@media (min-width: 701px) {
  #index .sec_free_consultation .free_inner {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto auto;
    gap: 0;
  }
}
#index .sec_free_consultation .free_inner .grid01 {
  border-bottom: 1px solid #f1f5f9;
  padding-bottom: 80px;
}
@media (min-width: 701px) {
  #index .sec_free_consultation .free_inner .grid01 {
    grid-area: 1/1/2/3;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation .free_inner .grid01 {
    padding: 0 4vw 40px;
  }
}
#index .sec_free_consultation .free_inner .grid02 {
  padding: 80px 78px 130px 0;
}
@media (min-width: 701px) {
  #index .sec_free_consultation .free_inner .grid02 {
    grid-area: 2/1/3/2;
    border-right: 1px solid #f1f5f9;
    margin: 0 0 0 auto;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_free_consultation .free_inner .grid02 {
    padding: 60px 5%;
    width: 100%;
    margin: 0 auto;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation .free_inner .grid02 {
    border-bottom: 1px solid #f1f5f9;
    padding: 40px 4vw;
  }
}
#index .sec_free_consultation .free_inner .grid03 {
  padding: 80px 0 130px 78px;
}
@media (min-width: 701px) {
  #index .sec_free_consultation .free_inner .grid03 {
    grid-area: 2/2/3/3;
    margin: 0 auto 0 0;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_free_consultation .free_inner .grid03 {
    padding: 60px 5%;
    width: 100%;
    margin: 0 auto;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation .free_inner .grid03 {
    padding: 40px 4vw;
  }
}
#index .sec_free_consultation .free_ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  font-size: clamp(26px, 3vw, 46px);
  font-weight: bold;
  text-align: center;
  margin-bottom: 30px;
  color: #fff;
}
@media (max-width: 700px) {
  #index .sec_free_consultation .free_ttl {
    gap: 20px;
  }
}
#index .sec_free_consultation .free_ttl i {
  width: 120px;
  height: 120px;
}
@media (max-width: 700px) {
  #index .sec_free_consultation .free_ttl i {
    width: 80px;
    height: 80px;
  }
}
#index .sec_free_consultation .check_list {
  display: flex;
  justify-content: center;
  gap: 95px;
  align-items: center;
  width: 96%;
  margin: 0 auto 40px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_free_consultation .check_list {
    margin: 0 auto 40px;
    width: 90%;
    gap: 40px;
  }
}
@media (max-width: 900px) {
  #index .sec_free_consultation .check_list {
    justify-content: center;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation .check_list {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 20px 0;
  }
}
#index .sec_free_consultation .check_list li {
  position: relative;
  font-size: clamp(20px, 2vw, 32px);
  font-weight: bold;
  color: #fff;
  padding-left: 40px;
}
@media (max-width: 900px) {
  #index .sec_free_consultation .check_list li {
    flex: 1 0 auto;
  }
}
#index .sec_free_consultation .check_list li::before {
  position: absolute;
  content: "";
  background: url("../img/icon/icon_check.svg") no-repeat center center/contain;
  width: 35px;
  height: 35px;
  inset: 0 auto 0 0;
  margin: auto;
}
#index .sec_free_consultation .check_list li span {
  text-decoration: underline #ffd52b 2px;
  text-underline-offset: 8px;
}
#index .sec_free_consultation .txt_center {
  text-align: center;
  font-size: clamp(16px, 1.8vw, 24px);
  color: #fff;
  margin-bottom: 45px;
}
#index .sec_free_consultation .txt_border_wrap {
  text-align: center;
  margin-bottom: 60px;
}
#index .sec_free_consultation .txt_border_wrap .txt_border {
  border: 1px solid #fff;
  padding: 15px 20px;
  display: inline-block;
  font-size: clamp(18px, 2vw, 32px);
  font-weight: bold;
  color: #fff;
  width: 98%;
  max-width: 1200px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_free_consultation .common_btn {
    max-width: 560px;
    width: 100%;
  }
}
@media (min-width: 1441px) {
  #index .sec_free_consultation .common_btn {
    width: 560px;
  }
}
@media (max-width: 700px) {
  #index .sec_free_consultation .common_btn {
    max-width: 400px;
  }
}
#index .sec_introduction {
  padding: 110px 0 120px;
  position: relative;
}
@media (max-width: 700px) {
  #index .sec_introduction {
    padding: 50px 0;
  }
}
#index .sec_introduction .sec_inner {
  display: flex;
  align-items: center;
  margin: 0 0 0 auto;
  max-width: 1759px;
}
@media (max-width: 700px) {
  #index .sec_introduction .sec_inner {
    flex-direction: column;
    margin: 0 auto;
    gap: 30px;
  }
}
@media (min-width: 701px) {
  #index .sec_introduction .sec_inner .txt_area {
    width: 45%;
    padding-right: 80px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_introduction .sec_inner .txt_area {
    padding-right: 40px;
  }
}
#index .sec_introduction .sec_inner figure {
  aspect-ratio: 3/2;
}
@media (min-width: 701px) {
  #index .sec_introduction .sec_inner figure {
    width: 55%;
  }
}
#index .sec_introduction .sec_inner figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#index .sec_introduction .introduction_ttl {
  font-size: clamp(28px, 3vw, 48px);
  margin-bottom: 20px;
}
#index .sec_introduction .introduction_catch {
  font-size: clamp(20px, 2vw, 32px);
}
#index .sec_introduction p:not(.introduction_catch) {
  margin: 30px 0;
  font-size: clamp(16px, 1.6vw, 24px);
}
@media (max-width: 700px) {
  #index .sec_introduction .common_btn.tabpc {
    display: none;
  }
}
@media (min-width: 701px) {
  #index .sec_introduction .common_btn.sp {
    display: none;
  }
}
#index .sec_top_choosing {
  padding: 114px 0;
}
@media (max-width: 700px) {
  #index .sec_top_choosing {
    padding: 50px 0;
  }
}
#index .sec_top_choosing .hukidashi_ttl {
  margin-bottom: 40px;
}
#index .sec_top_choosing .choosing_cards {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 60px;
}
@media (max-width: 700px) {
  #index .sec_top_choosing .choosing_cards {
    margin: 0 auto 30px;
    gap: 7px;
  }
}
#index .sec_top_choosing .choosing_cards .card {
  flex: 0 0 calc(20% - 8px);
  background: #fff;
  border: 1px solid #cbd5e1;
}
@media (max-width: 900px) {
  #index .sec_top_choosing .choosing_cards .card {
    flex: 0 0 calc(33.3333333333% - 8px);
  }
}
@media (max-width: 700px) {
  #index .sec_top_choosing .choosing_cards .card {
    flex: 0 0 calc(50% - 8px);
  }
}
#index .sec_top_choosing .choosing_cards figure {
  aspect-ratio: 3/2;
}
#index .sec_top_choosing .choosing_cards figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#index .sec_top_choosing .choosing_cards .choosing_ttl {
  font-size: clamp(16px, 2vw, 32px);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin: 10px 0;
}
#index .sec_top_choosing .choosing_cards .choosing_ttl .en {
  font-size: clamp(28px, 3.2vw, 45px);
  line-height: 1.2;
}
#index .sec_top_choosing .choosing_cards p:not(.choosing_ttl) {
  font-size: clamp(16px, 2vw, 20px);
  text-align: center;
  padding-bottom: 40px;
}
@media (max-width: 700px) {
  #index .sec_top_choosing .choosing_cards p:not(.choosing_ttl) {
    padding: 0 10px 10px;
    text-align: left;
  }
}
#index .sec_what {
  padding: 105px 0 115px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_what {
    padding: 105px 0 85px;
  }
}
@media (max-width: 700px) {
  #index .sec_what {
    padding: 105px 0 60px;
  }
}
#index .sec_what.deco::after {
  z-index: -1;
}
#index .sec_what .smile_man {
  text-align: center;
  font-weight: bold;
  font-size: clamp(22px, 2.4vw, 48px);
  position: relative;
  padding-bottom: 100px;
  margin-bottom: 15px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_what .smile_man {
    padding-bottom: 50px;
  }
}
@media (max-width: 700px) {
  #index .sec_what .smile_man {
    padding-bottom: 70px;
  }
}
#index .sec_what .smile_man::before {
  content: "";
  position: absolute;
  width: 100%;
  max-width: 1200px;
  height: 100px;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  background: url("../img/top/polygon.png") no-repeat center center/contain;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_what .smile_man::before {
    width: 50%;
    height: 50%;
  }
}
#index .sec_what .smile_man::after {
  position: absolute;
  content: "";
  background: url("../img/top/smile_man@2x.webp") no-repeat center center/contain;
  width: 272px;
  height: 305px;
  right: 40px;
  bottom: -40px;
  z-index: 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_what .smile_man::after {
    width: 200px;
    height: 224px;
  }
}
@media (max-width: 900px) {
  #index .sec_what .smile_man::after {
    width: 140px;
    height: 156px;
    right: 20px;
  }
}
@media (max-width: 700px) {
  #index .sec_what .smile_man::after {
    width: 100px;
    height: 112px;
  }
}
#index .sec_what .what_link {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto 125px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_what .what_link {
    margin: 0 auto 85px;
  }
}
@media (max-width: 700px) {
  #index .sec_what .what_link {
    margin: 0 auto 60px;
  }
}
#index .sec_what .what_link li {
  width: 100%;
}
@media (min-width: 701px) {
  #index .sec_what .what_link li {
    width: 50%;
  }
}
#index .sec_what .what_link li a {
  display: block;
  padding: 38px 120px 38px 60px;
  position: relative;
  background: #f1f5f9;
  border: 1px solid #cbd5e1;
  width: 100%;
  height: 100%;
}
@media (max-width: 700px) {
  #index .sec_what .what_link li a {
    padding: 20px 50px 20px 20px;
  }
}
#index .sec_what .what_link li a::before {
  content: "";
  position: absolute;
  border-right: 1px solid #0f172a;
  border-bottom: 1px solid #0f172a;
  transform: rotate(-45deg);
  width: 26px;
  height: 26px;
  margin: auto;
  inset: 0 45px 0 auto;
}
@media (max-width: 700px) {
  #index .sec_what .what_link li a::before {
    width: 16px;
    height: 16px;
    inset: 0 25px 0 auto;
  }
}
#index .sec_what .what_link li a:hover {
  background: #cbd5e1;
}
#index .sec_what .what_link li .ttl {
  font-size: clamp(20px, 2vw, 24px);
  font-weight: 600;
}
#index .sec_what .what_link li .txt {
  font-size: clamp(16px, 2vw, 20px);
  margin-top: 15px;
}
@media (min-width: 701px) {
  #index .sec_what .what_link li:nth-child(2n) a {
    border-left: none;
  }
}
@media (min-width: 701px) {
  #index .sec_what .what_link li:nth-child(n+3) a {
    border-top: none;
  }
}
@media (max-width: 700px) {
  #index .sec_what .what_link li:nth-child(n+2) a {
    border-top: none;
  }
}
#index .sec_trivia {
  padding: 140px 0 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_trivia {
    padding: 80px 0 40px;
  }
}
@media (max-width: 700px) {
  #index .sec_trivia {
    padding: 70px 0 40px;
  }
}
#index .sec_trivia h2 {
  display: flex;
  flex-direction: column;
  gap: 30px;
  justify-content: center;
  align-items: center;
  margin-bottom: 50px;
  font-weight: bold;
  font-size: clamp(24px, 3vw, 48px);
}
@media (max-width: 700px) {
  #index .sec_trivia h2 {
    gap: 15px;
    margin-bottom: 30px;
  }
}
#index .sec_trivia h2 i {
  width: 80px;
  height: auto;
}
#index .sec_trivia h3 {
  text-align: center;
  font-size: clamp(20px, 2.2vw, 30px);
  margin-bottom: 50px;
}
@media (max-width: 700px) {
  #index .sec_trivia h3 {
    margin-bottom: 30px;
  }
}
#index .sec_trivia .common_btn {
  margin-bottom: 40px;
  max-width: 560px;
}
#index .sec_trivia .trivia_list {
  display: flex;
  flex-wrap: wrap;
  gap: 25px 50px;
  margin-bottom: 110px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_trivia .trivia_list {
    gap: 15px 0;
    justify-content: space-between;
  }
}
@media (max-width: 700px) {
  #index .sec_trivia .trivia_list {
    gap: 15px 0;
    margin-bottom: 60px;
    justify-content: space-between;
  }
}
#index .sec_trivia .trivia_list li {
  flex: 0 0 48.5%;
}
@media (min-width: 1441px) {
  #index .sec_trivia .trivia_list li {
    flex: 1 0 30%;
  }
}
#index .sec_trivia .trivia_list a {
  display: block;
  background: #fff;
  border: 1px solid #cbd5e1;
  position: relative;
  text-align: center;
  padding: 22.5px 40px;
  font-weight: 600;
  font-size: clamp(16px, 1.6vw, 22px);
}
@media (max-width: 700px) {
  #index .sec_trivia .trivia_list a {
    padding: 18px 30px 18px 18px;
  }
}
#index .sec_trivia .trivia_list a::before {
  position: absolute;
  content: "";
  border-right: 1px solid #3957a6;
  border-bottom: 1px solid #3957a6;
  transform: rotate(-45deg);
  width: 16px;
  height: 16px;
  margin: auto;
  inset: 0 40px 0 auto;
}
@media (max-width: 700px) {
  #index .sec_trivia .trivia_list a::before {
    width: 10px;
    height: 10px;
    inset: 0 20px 0 auto;
  }
}
#index .sec_trivia .trivia_list a:hover {
  background: #f1f5f9;
}
#index .sec_trivia .news_wrap {
  margin-bottom: 60px;
}
@media (min-width: 701px) {
  #index .sec_trivia .news_wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 40px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #index .sec_trivia .news_wrap {
    gap: 25px;
  }
}
@media (max-width: 700px) {
  #index .sec_trivia .news_wrap .blog_item + .blog_item {
    margin-top: 20px;
  }
}

#info .single_block .tag_wrap {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 20px;
  gap: 0 10px;
  flex-wrap: wrap;
}
#info .single_block .tag_wrap a {
  display: block;
  color: #3957a6;
  font-size: 16px;
}
#info .single_block .tag_wrap a:hover {
  color: #0f172a;
}
#info .single_block .info_top {
  background: #f1f5f9;
  padding: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_top {
    padding: 30px;
  }
}
@media (max-width: 700px) {
  #info .single_block .info_top {
    padding: 20px 4vw;
  }
}
#info .single_block .info_detail {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 80px;
  gap: 10px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_detail {
    margin-bottom: 40px;
  }
}
@media (max-width: 700px) {
  #info .single_block .info_detail {
    margin-bottom: 20px;
  }
}
#info .single_block .info_detail div {
  display: flex;
  align-items: baseline;
  gap: 20px;
}
@media (min-width: 701px) {
  #info .single_block .info_detail div {
    width: 49%;
  }
}
#info .single_block .info_detail dt {
  background: #0f172a;
  color: #fff;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 20px);
  min-width: 160px;
  font-weight: bold;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_detail dt {
    min-width: 120px;
  }
}
@media (max-width: 700px) {
  #info .single_block .info_detail dt {
    min-width: 120px;
  }
}
#info .single_block .info_detail dd {
  font-size: clamp(16px, 1.6vw, 20px);
  width: calc(100% - 95px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_detail dd {
    width: calc(100% - 74px);
  }
}
@media (max-width: 700px) {
  #info .single_block .info_detail dd {
    width: calc(100% - 68px);
  }
}
#info .single_block .info_result {
  border: 10px solid #cbd5e1;
  padding: 10px;
  display: flex;
  gap: 0 60px;
  background: #fff;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_result {
    gap: 0 40px;
  }
}
@media (max-width: 700px) {
  #info .single_block .info_result {
    flex-direction: column;
    gap: 0 30px;
  }
}
#info .single_block .info_result .info_result_ttl {
  background: #3957a6;
  color: #fff;
  text-align: center;
  width: min(240px, 20vw);
  position: relative;
  font-size: clamp(20px, 2vw, 24px);
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 700px) {
  #info .single_block .info_result .info_result_ttl {
    width: 100%;
    padding: 15px;
  }
}
#info .single_block .info_result .info_result_ttl::before {
  position: absolute;
  content: "";
  width: 30px;
  height: 60px;
  background-color: #3957a6;
  clip-path: polygon(30px 50%, 0% 0%, 0% 60px);
  margin: auto;
  inset: 0 -29px 0 auto;
}
@media (max-width: 700px) {
  #info .single_block .info_result .info_result_ttl::before {
    width: 50px;
    height: 20px;
    inset: auto 0 -19px 0;
    clip-path: polygon(50% 20px, 0% 0%, 50px 0%);
  }
}
#info .single_block .info_result .info_result_txt {
  width: calc(100% - 300px);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: bold;
  padding: 30px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .info_result .info_result_txt {
    width: calc(100% - 250px);
  }
}
@media (max-width: 700px) {
  #info .single_block .info_result .info_result_txt {
    padding: 30px 0 0;
    width: 100%;
    text-align: center;
  }
}
#info .single_block .info_point {
  margin-top: 80px;
}
@media (max-width: 700px) {
  #info .single_block .info_point {
    margin-top: 30px;
  }
}
#info .single_block .info_point .info_point_ttl {
  background: #3957a6;
  color: #fff;
  text-align: center;
  font-size: clamp(20px, 2vw, 24px);
  padding: 12px 0;
  font-weight: bold;
  border-radius: 10px 10px 0 0;
}
#info .single_block .info_point .info_point_txt {
  background: #fff;
  padding: 40px min(8vw, 160px);
}
@media (max-width: 700px) {
  #info .single_block .info_point .info_point_txt {
    padding: 20px min(4vw, 30px);
  }
}
#info .single_block .info_point .info_point_txt ul li {
  list-style-type: disc;
  margin-left: 1.5em;
  font-weight: 500;
  font-size: clamp(16px, 1.8vw, 20px);
}
#info .single_block .info_point .info_point_txt ul li + li {
  margin-top: 0.7em;
}
#info .single_block .mv_mail_btn {
  background: #f97316;
  border: 2px solid #fff;
  border-radius: 10px;
  padding: 20px 25px;
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  max-width: 720px;
  margin: 0 auto 120px;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.15);
}
@media (min-width: 1441px) {
  #info .single_block .mv_mail_btn {
    padding: 20px 60px 10px 30px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  #info .single_block .mv_mail_btn {
    padding: 20px 60px 20px 20px;
  }
}
@media (max-width: 900px) {
  #info .single_block .mv_mail_btn {
    padding: 20px 50px 20px 20px;
  }
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn {
    width: 89.7vw;
    display: block;
    padding: 15px 20px 10px;
    margin: 0 auto 60px;
  }
}
@media (min-width: 701px) {
  #info .single_block .mv_mail_btn::after {
    position: absolute;
    content: "";
    border-right: 1.5px solid #fff;
    border-bottom: 1.5px solid #fff;
    transform: rotate(-45deg);
    width: 26px;
    height: 26px;
    margin: auto;
    inset: 0 40px 0 auto;
  }
}
@media (max-width: 900px) {
  #info .single_block .mv_mail_btn::after {
    inset: 0 20px 0 auto;
  }
}
#info .single_block .mv_mail_btn i {
  width: 80px;
  height: 80px;
}
@media (max-width: 900px) {
  #info .single_block .mv_mail_btn i {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn i {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 360px) {
  #info .single_block .mv_mail_btn i {
    width: 40px;
    height: 40px;
  }
}
#info .single_block .mv_mail_btn .txtarea {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: calc(100% - 100px - 46px);
}
@media (max-width: 900px) {
  #info .single_block .mv_mail_btn .txtarea {
    width: 100%;
  }
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn .txtarea {
    flex-direction: row;
    width: 100%;
    align-items: center;
    justify-content: center;
    margin-top: 7px;
    gap: 15px;
  }
}
#info .single_block .mv_mail_btn .bg {
  background: #fff;
  border-radius: 50px;
}
#info .single_block .mv_mail_btn .bg p {
  text-align: center;
  font-weight: bold;
  font-size: clamp(16px, 2.2vw, 25px);
  line-height: 40px;
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn .bg p {
    line-height: 30px;
  }
}
#info .single_block .mv_mail_btn .bg p span {
  font-size: 120%;
  color: #4cc764;
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn .bg p span {
    font-size: 16px;
  }
}
#info .single_block .mv_mail_btn .ttl {
  font-size: clamp(22px, 3vw, 40px);
  font-weight: bold;
  text-align: center;
  color: #fff;
}
@media (max-width: 700px) {
  #info .single_block .mv_mail_btn .ttl {
    font-size: min(24px, 5.8vw);
  }
}
#info .single_block .mv_mail_btn:hover {
  opacity: 0.8;
}

#privacypolicy main {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #privacypolicy main {
    padding-bottom: 80px;
  }
}
@media (max-width: 700px) {
  #privacypolicy main {
    padding-bottom: 60px;
  }
}
#privacypolicy .sec_pp + .sec_pp {
  margin-top: 80px;
}
@media (max-width: 700px) {
  #privacypolicy .sec_pp + .sec_pp {
    margin-top: 40px;
  }
}
#privacypolicy .sec_pp .base_table {
  max-width: 1040px;
  margin: 20px auto 20px 0;
  border-top: 1px solid #cbd5e1;
}
#privacypolicy .sec_pp .disc_list {
  margin: 15px 0;
}
#privacypolicy .sec_pp .disc_list li {
  font-size: clamp(16px, 1.8vw, 20px);
}
#privacypolicy .sec_pp .disc_list li::marker {
  font-size: clamp(16px, 1.8vw, 20px);
}
#privacypolicy .sec_pp .disc_list li + li {
  margin-top: 10px;
}
@media (min-width: 701px) {
  #privacypolicy .sec_pp a[href^="tel:"] {
    color: #0f172a;
    text-decoration: none;
  }
}
#privacypolicy .sec_pp .list_number {
  margin: 15px 0 15px 1.5em;
}
#privacypolicy .sec_pp .list_number li {
  font-size: clamp(16px, 1.8vw, 20px);
}
#privacypolicy .sec_pp .list_number li + li {
  margin-top: 10px;
}
#privacypolicy .sec_pp p {
  font-size: clamp(16px, 1.8vw, 20px);
}

#news .archivePage:not(:has(.pagenavi)) {
  margin-bottom: 140px;
}
#news .archivePage .newsList .newsList_item:first-of-type a {
  border-top: 1px solid #f1f5f9;
}
#news .archivePage .newsList .newsList_item:first-of-type a::after {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 130px;
  height: 1px;
  margin: auto;
  inset: -1px auto auto 0;
}
#news .archivePage .newsList .newsList_item a {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  padding: 25px 0;
  border-bottom: 1px solid #f1f5f9;
  position: relative;
}
@media (max-width: 700px) {
  #news .archivePage .newsList .newsList_item a {
    flex-wrap: wrap;
    gap: 5px;
    padding: 15px 0;
  }
}
#news .archivePage .newsList .newsList_item a::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 130px;
  height: 1px;
  margin: auto;
  inset: auto auto -1px 0;
}
#news .archivePage .newsList .newsList_item a:hover {
  background: rgba(241, 245, 249, 0.2);
}
#news .archivePage .newsList time {
  font-size: clamp(16px, 1.6vw, 18px);
  white-space: nowrap;
}
#news .archivePage .newsList .news_cate {
  background: #e5eef3;
  font-size: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  min-width: 150px;
  min-height: 30px;
}
#news .archivePage .newsList .newsList_ttl {
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 500;
  /* overflow: hidden;
  text-overflow: ellipsis;
  @include mq(tab_pc) {
      white-space: nowrap;
  } */
}
@media (max-width: 700px) {
  #news .archivePage .newsList .newsList_ttl {
    width: 100%;
  }
}

@media (min-width: 1441px) {
  #legal-advice .breadcrumb {
    margin-bottom: 100px;
  }
}
#legal-advice .sec_merit .merit_comment {
  font-size: clamp(18px, 1.8vw, 32px);
  margin-bottom: 40px;
}
#legal-advice .sec_merit .merit_comment mark {
  background: linear-gradient(transparent 70%, rgba(255, 213, 43, 0.5) 30%);
}
#legal-advice .sec_info .example02 {
  margin-top: 150px;
}
@media (max-width: 700px) {
  #legal-advice .sec_info .example02 {
    margin-top: 70px;
  }
}
#legal-advice .sec_info .example02 .example {
  background: url("../img/legal-advice/bg_example02@2x.webp") no-repeat center bottom/contain;
}
@media (max-width: 700px) {
  #legal-advice .sec_info .example02 .example {
    background: none;
  }
}
#legal-advice .sec_info .example {
  background: url("../img/legal-advice/bg_example01@2x.webp") no-repeat center center/contain;
  position: relative;
  aspect-ratio: 160/27;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 60px;
}
@media (max-width: 700px) {
  #legal-advice .sec_info .example {
    text-align: center;
    background: none;
    aspect-ratio: inherit;
    margin-bottom: 0;
    flex-direction: column;
  }
}
#legal-advice .sec_info .example span {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  font-size: clamp(16px, 2vw, 32px);
  background: #3957a6;
  color: #ffd52b;
  text-align: center;
  padding: 0 35px;
  border: 1px solid #cbd5e1;
  line-height: 80px;
  z-index: 1;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #legal-advice .sec_info .example span {
    line-height: 60px;
    top: -30px;
  }
}
@media (max-width: 700px) {
  #legal-advice .sec_info .example span {
    line-height: 36px;
    padding: 0 22px;
    top: -18px;
    white-space: nowrap;
  }
}
#legal-advice .sec_info .example h3 {
  color: #fff;
  text-align: center;
  font-size: clamp(22px, 3.2vw, 40px);
  padding-top: 30px;
}
@media (max-width: 700px) {
  #legal-advice .sec_info .example h3 {
    padding: 30px 10px 10px;
    text-align: center;
    width: 100%;
    background: #3957a6;
  }
}

.jiko_common .jiko_header {
  margin-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .jiko_common .jiko_header {
    margin-bottom: 80px;
  }
}
@media (max-width: 700px) {
  .jiko_common .jiko_header {
    margin-bottom: 60px;
  }
}
.jiko_common .sec_merit .merit_comment {
  font-size: clamp(18px, 1.8vw, 32px);
  margin-bottom: 40px;
}
.jiko_common .sec_merit .merit_comment mark {
  background: linear-gradient(transparent 70%, rgba(255, 213, 43, 0.5) 30%);
}
.jiko_common .sec_preparation .preparation_subttl {
  font-size: clamp(16px, 2vw, 32px);
}
.jiko_common .sec_preparation .border_box {
  border: 10px solid #cbd5e1;
  padding: 50px;
  margin: 80px auto 0;
  width: 90%;
  max-width: 880px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .jiko_common .sec_preparation .border_box {
    padding: 30px;
  }
}
@media (max-width: 700px) {
  .jiko_common .sec_preparation .border_box {
    border-width: 5px;
    margin: 30px auto 0;
    width: 100%;
    padding: 20px;
  }
}
.jiko_common .sec_preparation .border_box p {
  font-size: clamp(16px, 1.6vw, 20px);
}
@media (max-width: 700px) {
  .jiko_common .sec_preparation .border_box a[href^="tel:"] {
    color: #3957a6;
    text-decoration: underline;
  }
}
.jiko_common .sec_company {
  padding: 120px 0;
}
@media (max-width: 700px) {
  .jiko_common .sec_company {
    padding: 60px 0;
  }
}
.jiko_common .sec_company .gmap {
  aspect-ratio: 5/2;
}
@media (max-width: 700px) {
  .jiko_common .sec_company .gmap {
    aspect-ratio: 7/8;
  }
}
.jiko_common .sec_company .gmap iframe {
  width: 100%;
  height: 100%;
}
.jiko_common .sec_company .map_detail {
  margin: 30px auto 120px;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 700px) {
  .jiko_common .sec_company .map_detail {
    margin: 20px 0;
    padding: 0;
  }
}
@media (max-width: 700px) {
  .jiko_common .sec_company .map_detail {
    flex-direction: column;
    gap: 20px;
    margin: 20px auto 60px;
  }
}
.jiko_common .sec_company .introduction {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: min(80px, 5vw);
}
@media (max-width: 700px) {
  .jiko_common .sec_company .introduction {
    flex-direction: column;
    align-items: center;
  }
}
@media (max-width: 700px) {
  .jiko_common .sec_company .introduction figure {
    max-width: 200px;
  }
}
.jiko_common .sec_company .introduction .txt_area .type {
  font-size: clamp(16px, 1.6vw, 20px);
}
.jiko_common .sec_company .introduction .txt_area .name {
  font-size: clamp(16px, 1.6vw, 24px);
}
.jiko_common .sec_company .introduction .txt_area .career {
  font-size: clamp(16px, 1.6vw, 20px);
}
.jiko_common .sec_police {
  padding: 120px 0;
}
@media (max-width: 700px) {
  .jiko_common .sec_police {
    padding: 60px 0;
  }
}
.jiko_common .sec_police .hukidashi_ttl span::after {
  display: none;
}
@media (min-width: 701px) {
  .jiko_common .sec_police .base_table .tel a {
    color: #0f172a;
    text-decoration: none;
  }
}
@media (max-width: 700px) {
  .jiko_common .sec_police .base_table colgroup,
  .jiko_common .sec_police .base_table thead {
    display: none;
  }
  .jiko_common .sec_police .base_table tbody tr {
    display: flex;
    flex-wrap: wrap;
  }
  .jiko_common .sec_police .base_table tbody tr > th {
    width: 40%;
    position: relative;
    padding-top: 50px;
  }
  .jiko_common .sec_police .base_table tbody tr > th::before {
    position: absolute;
    content: "警察署名";
    color: #fff;
    background: #3957a6;
    text-align: center;
    font-size: 16px;
    width: 100%;
    line-height: 40px;
    top: 0;
    left: 0;
    font-weight: bold;
  }
  .jiko_common .sec_police .base_table tbody tr > th + td {
    width: 60%;
    position: relative;
    padding-top: 50px;
  }
  .jiko_common .sec_police .base_table tbody tr > th + td::before {
    position: absolute;
    content: "住所・TEL";
    color: #fff;
    background: #3957a6;
    text-align: center;
    font-size: 16px;
    width: 100%;
    line-height: 40px;
    top: 0;
    left: 0;
    font-weight: bold;
  }
  .jiko_common .sec_police .base_table tbody tr td {
    width: 100%;
    position: relative;
    padding-top: 50px;
  }
  .jiko_common .sec_police .base_table tbody tr td::before {
    position: absolute;
    content: "交通事故管轄区域";
    color: #fff;
    background: #3957a6;
    text-align: center;
    font-size: 16px;
    width: 100%;
    line-height: 40px;
    top: 0;
    left: 0;
    font-weight: bold;
  }
}
.jiko_common footer .footer_main {
  padding: 70px 0;
}
@media (max-width: 700px) {
  .jiko_common footer .footer_main {
    padding: 30px 0;
  }
}
.jiko_common footer .footer_main .logoarea {
  text-align: center;
}
.jiko_common footer .footer_main .sec_inner {
  justify-content: center;
  align-items: center;
}
.jiko_common footer .footer_main .address,
.jiko_common footer .footer_main .name {
  text-align: center;
}

@media (min-width: 1441px) {
  #workers-accident .breadcrumb {
    margin-bottom: 100px;
  }
}
#workers-accident .sec_intro .hukidashi_ttl {
  display: block;
}
#workers-accident .sec_case {
  padding: 105px 0 120px;
}
@media (max-width: 700px) {
  #workers-accident .sec_case {
    padding: 60px 0;
  }
}
#workers-accident .sec_case .case_block {
  border-radius: 10px;
}
#workers-accident .sec_case .case_block + .case_block {
  margin-top: 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #workers-accident .sec_case .case_block + .case_block {
    margin-top: 40px;
  }
}
@media (max-width: 700px) {
  #workers-accident .sec_case .case_block + .case_block {
    margin-top: 20px;
  }
}
#workers-accident .sec_case .case_block .case_head {
  background: #3957a6;
  border-radius: 10px 10px 0 0;
  padding: 20px 0;
}
#workers-accident .sec_case .case_block .case_head h3 {
  color: #fff;
  font-size: clamp(20px, 2.4vw, 40px);
  text-align: center;
}
#workers-accident .sec_case .case_block .case_head h3 small {
  font-size: 83%;
}
#workers-accident .sec_case .case_block .case_body {
  background: #fff;
  padding: 40px 0;
  border-radius: 0 0 10px 10px;
}
@media (max-width: 700px) {
  #workers-accident .sec_case .case_block .case_body {
    padding: 20px 10px;
  }
}
#workers-accident .sec_case .case_block .case_body .in {
  display: flex;
  justify-content: center;
  position: relative;
  margin-bottom: 110px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #workers-accident .sec_case .case_block .case_body .in {
    margin-bottom: 90px;
  }
}
@media (max-width: 700px) {
  #workers-accident .sec_case .case_block .case_body .in {
    margin-bottom: 60px;
  }
}
#workers-accident .sec_case .case_block .case_body .in::before {
  position: absolute;
  content: "";
  width: 120px;
  height: 60px;
  background-color: #cbd5e1;
  clip-path: polygon(50% 60px, 0% 0%, 120px 0%);
  margin: auto;
  inset: auto 0 -80px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #workers-accident .sec_case .case_block .case_body .in::before {
    width: 100px;
    height: 50px;
    inset: auto 0 -70px 0;
    clip-path: polygon(50% 50px, 0% 0%, 100px 0%);
  }
}
@media (max-width: 700px) {
  #workers-accident .sec_case .case_block .case_body .in::before {
    width: 80px;
    height: 40px;
    inset: auto 0 -50px 0;
    clip-path: polygon(50% 40px, 0% 0%, 80px 0%);
  }
}
#workers-accident .sec_case .case_block .case_body .in .dot_list li {
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 500;
}
#workers-accident .sec_case .case_block .case_body p:not(.center_ttl) {
  max-width: 1200px;
  width: 96%;
  margin: 0 auto;
  text-align: center;
  font-size: clamp(16px, 2vw, 22px);
}
@media (max-width: 700px) {
  #workers-accident .sec_case .case_block .case_body p:not(.center_ttl) {
    text-align: left;
  }
}
@media (min-width: 701px) {
  #workers-accident .sec_info .catch {
    text-align: center;
  }
}
#workers-accident .sec_merit {
  margin-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #workers-accident .sec_merit {
    margin-bottom: 60px;
  }
}
@media (max-width: 700px) {
  #workers-accident .sec_merit {
    margin-bottom: 40px;
  }
}
#workers-accident .sec_merit .merit_comment {
  font-size: clamp(18px, 1.8vw, 32px);
  margin-bottom: 40px;
}
#workers-accident .sec_merit .merit_comment mark {
  background: linear-gradient(transparent 70%, rgba(255, 213, 43, 0.5) 30%);
}
#workers-accident .sec_choosing {
  padding: 114px 0;
}
@media (max-width: 700px) {
  #workers-accident .sec_choosing {
    padding: 50px 0;
  }
}
#workers-accident .sec_choosing .common_btn {
  display: none;
}
#workers-accident .sec_preparation .smooth_body {
  display: flex;
  justify-content: center;
}

@media (min-width: 1441px) {
  #fatal-accident-advice .breadcrumb {
    margin-bottom: 100px;
  }
}
#fatal-accident-advice .sec_merit .merit_comment {
  font-size: clamp(18px, 1.8vw, 32px);
  margin-bottom: 40px;
}
#fatal-accident-advice .sec_merit .merit_comment mark {
  background: linear-gradient(transparent 70%, rgba(255, 213, 43, 0.5) 30%);
}
#fatal-accident-advice .sec_intro {
  padding-bottom: 0;
}

#lawyer-merits .sec_merit {
  padding: 0 0 100px;
}
@media (max-width: 1440px) {
  #lawyer-merits .sec_merit {
    padding: 0;
  }
}
#lawyer-merits .sec_merit ul li {
  padding: 0;
}
#lawyer-merits .sec_merit ul li a {
  padding: 5px 25px 50px;
  display: block;
  background: #f1f5f9;
  position: relative;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .sec_merit ul li a {
    padding: 5px 10px 30px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit ul li a {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 5px 20px 30px;
  }
}
#lawyer-merits .sec_merit ul li a::before {
  content: "";
  position: absolute;
  border-right: 1px solid #3957a6;
  border-bottom: 1px solid #3957a6;
  transform: rotate(45deg);
  width: 1em;
  height: 1em;
  margin: auto;
  inset: auto 0 20px 0;
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit ul li a::before {
    inset: auto 0 10px 0;
  }
}
#lawyer-merits .sec_merit ul li a:hover {
  background: rgba(57, 87, 166, 0.1);
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .sec_merit_detail .hukidashi_ttl {
    margin-bottom: 40px;
  }
}
#lawyer-merits .sec_merit_detail .hukidashi_ttl span {
  color: #3957a6;
  font-weight: bold;
  font-family: "Roboto", sans-serif;
  font-style: italic;
}
#lawyer-merits .sec_merit_detail .hukidashi_ttl span i {
  font-size: 200%;
  font-style: italic;
  line-height: 1.2;
}
#lawyer-merits .sec_merit_detail .dl_block_wrap {
  display: flex;
  justify-content: space-between;
  margin-bottom: 120px;
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .dl_block_wrap {
    margin-bottom: 60px;
    flex-direction: column;
    gap: 10px;
  }
}
#lawyer-merits .sec_merit_detail .dl_block dt {
  font-size: clamp(20px, 2vw, 28px);
  padding: 20px;
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .dl_block dt {
    padding: 10px;
  }
}
#lawyer-merits .sec_merit_detail .dl_block dd {
  height: calc(100% - 80px);
  display: flex;
  align-items: center;
  gap: 24px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .sec_merit_detail .dl_block dd {
    gap: 0;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .dl_block dd {
    height: auto;
    flex-direction: column;
    gap: 5px;
  }
}
#lawyer-merits .sec_merit_detail .dl_block dd .dot_list li {
  font-size: clamp(16px, 1.6vw, 22px);
}
#lawyer-merits .sec_merit_detail .dl_block dd .dot_list li + li {
  margin-top: 1em;
}
@media (min-width: 701px) {
  #lawyer-merits .sec_merit_detail .dl_block.before {
    width: 36%;
  }
}
#lawyer-merits .sec_merit_detail .dl_block.before dt {
  background: #0f172a;
}
#lawyer-merits .sec_merit_detail .dl_block.before dd figure {
  width: 50px;
}
@media (min-width: 701px) {
  #lawyer-merits .sec_merit_detail .dl_block.before dd figure {
    width: 134px;
  }
}
#lawyer-merits .sec_merit_detail .dl_block.before dd .txt_area {
  width: calc(100% - 50px);
}
@media (min-width: 1441px) {
  #lawyer-merits .sec_merit_detail .dl_block.before dd .txt_area {
    width: calc(100% - 134px - 24px);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .dl_block.before dd .txt_area {
    width: 100%;
  }
}
@media (min-width: 701px) {
  #lawyer-merits .sec_merit_detail .dl_block.after {
    width: 50%;
  }
}
#lawyer-merits .sec_merit_detail .dl_block.after dt {
  background: #3957a6;
}
#lawyer-merits .sec_merit_detail .dl_block.after dd {
  background: #fff;
}
#lawyer-merits .sec_merit_detail .dl_block.after dd figure {
  width: 50px;
}
@media (min-width: 701px) {
  #lawyer-merits .sec_merit_detail .dl_block.after dd figure {
    width: 144px;
  }
}
#lawyer-merits .sec_merit_detail .dl_block.after dd .txt_area {
  width: calc(100% - 50px);
}
@media (min-width: 1441px) {
  #lawyer-merits .sec_merit_detail .dl_block.after dd .txt_area {
    width: calc(100% - 144px - 24px);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .dl_block.after dd .txt_area {
    width: 100%;
  }
}
#lawyer-merits .sec_merit_detail .merit_arrow {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-width: 140px;
  width: 10%;
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .merit_arrow {
    flex-direction: row-reverse;
    width: 100%;
  }
}
#lawyer-merits .sec_merit_detail .merit_arrow figure {
  width: 130px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .sec_merit_detail .merit_arrow figure {
    width: 80px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .sec_merit_detail .merit_arrow figure {
    transform: rotate(90deg);
    width: 61px;
  }
}
#lawyer-merits .sec_merit_detail .merit_arrow p {
  font-size: clamp(16px, 1.6vw, 20px);
}
#lawyer-merits .star_icon {
  display: inline-block;
  font-size: clamp(22px, 2.5vw, 32px);
}
@media (max-width: 700px) {
  #lawyer-merits .star_icon {
    padding: 40px 0 0;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .star_icon::before {
    inset: 0 0 auto 0;
  }
}
#lawyer-merits .example_wrap dl {
  display: flex;
  gap: 50px;
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dl {
    flex-direction: column;
    gap: 30px;
  }
}
#lawyer-merits .example_wrap dl + dl {
  margin-top: 20px;
}
#lawyer-merits .example_wrap dt {
  width: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: bold;
  position: relative;
  padding: 40px 0;
  background: #3957a6;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .example_wrap dt {
    width: 230px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dt {
    padding: 10px;
    width: 100%;
  }
}
#lawyer-merits .example_wrap dt::before {
  position: absolute;
  content: "";
  width: 40px;
  height: 80px;
  background: #3957a6;
}
@media (min-width: 701px) {
  #lawyer-merits .example_wrap dt::before {
    clip-path: polygon(40px 50%, 0% 0%, 0% 80px);
    right: -39px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dt::before {
    width: 40px;
    height: 15px;
    bottom: -14px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 15px, 0% 0%, 40px 0%);
  }
}
#lawyer-merits .example_wrap dd {
  width: calc(100% - 320px);
  display: flex;
  justify-content: center;
  gap: 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .example_wrap dd {
    width: calc(100% - 230px);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dd {
    width: 100%;
    flex-direction: column;
    margin-bottom: 0;
    gap: 60px;
  }
}
#lawyer-merits .example_wrap dd .price_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .example_wrap dd .price_box {
    flex-direction: column;
    justify-content: center;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dd .price_box {
    justify-content: center;
    gap: min(20px, 4vw);
    min-height: 70px;
    padding: 0;
  }
}
#lawyer-merits .example_wrap dd .price_box p {
  text-align: center;
}
#lawyer-merits .example_wrap dd .price_box p:first-of-type {
  font-size: clamp(16px, 1.6vw, 24px);
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dd .price_box p:first-of-type {
    font-size: min(20px, 4.5vw);
  }
}
#lawyer-merits .example_wrap dd .price_box p:last-of-type {
  font-size: clamp(20px, 2.2vw, 40px);
  letter-spacing: 0.05em;
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dd .price_box p:last-of-type {
    font-size: min(30px, 6.7vw);
  }
}
#lawyer-merits .example_wrap dd .price_box p:last-of-type.type_middle {
  font-size: clamp(18px, 2vw, 30px);
}
#lawyer-merits .example_wrap dd .price_box p span {
  font-size: 120%;
}
#lawyer-merits .example_wrap dd .price_box p strong {
  font-size: 140%;
  font-weight: bold;
}
#lawyer-merits .example_wrap dd .price_box p small {
  font-size: 80%;
}
#lawyer-merits .example_wrap dd .price_box p small.type_small {
  font-size: 70%;
}
#lawyer-merits .example_wrap dd .price_box p small span {
  font-size: 90%;
}
#lawyer-merits .example_wrap dd .before {
  background: #f1f5f9;
  position: relative;
}
@media (min-width: 701px) {
  #lawyer-merits .example_wrap dd .before {
    width: 40%;
  }
}
#lawyer-merits .example_wrap dd .before::before {
  position: absolute;
  content: "";
  background-color: #cbd5e1;
}
@media (min-width: 701px) {
  #lawyer-merits .example_wrap dd .before::before {
    right: -50px;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 80px;
    clip-path: polygon(40px 50%, 0% 0%, 0% 80px);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .example_wrap dd .before::before {
    width: 80px;
    height: 40px;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 40px, 0% 0%, 80px 0%);
  }
}
#lawyer-merits .example_wrap dd .after {
  border: 5px solid #cbd5e1;
  background: #f1f5f9;
}
@media (min-width: 701px) {
  #lawyer-merits .example_wrap dd .after {
    width: 50%;
    border-width: 10px;
  }
}
#lawyer-merits .card_link_block {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 2%;
}
#lawyer-merits .card_link_block:has(li:only-of-type) li {
  width: 100%;
}
#lawyer-merits .card_link_block:has(li:nth-of-type(n + 2)) li {
  width: 49%;
}
@media (max-width: 700px) {
  #lawyer-merits .card_link_block:has(li:nth-of-type(n + 2)) li {
    width: 100%;
  }
}
#lawyer-merits .card_link_block li a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  border: 1px solid #cbd5e1;
  padding: 20px 10px;
  background: #fff;
  position: relative;
  height: 100%;
}
@media (max-width: 700px) {
  #lawyer-merits .card_link_block li a {
    padding: 10px;
  }
}
#lawyer-merits .card_link_block li a::before {
  position: absolute;
  content: "";
  border-right: 1px solid #0f172a;
  border-bottom: 1px solid #0f172a;
  transform: rotate(-45deg);
  width: 25px;
  height: 25px;
  margin: auto;
  inset: 0 40px 0 auto;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .card_link_block li a::before {
    inset: 0 20px 0 auto;
  }
}
@media (max-width: 900px) {
  #lawyer-merits .card_link_block li a::before {
    width: 15px;
    height: 15px;
    inset: 0 15px 0 auto;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .card_link_block li a::before {
    width: 10px;
    height: 10px;
    inset: 0 10px 0 auto;
  }
}
#lawyer-merits .card_link_block li a:hover {
  background: #f1f5f9;
}
#lawyer-merits .card_link_block li figure {
  aspect-ratio: 3/2;
  max-width: 180px;
}
@media (max-width: 900px) {
  #lawyer-merits .card_link_block li figure {
    max-width: 120px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .card_link_block li figure {
    max-width: 90px;
  }
}
#lawyer-merits .card_link_block li figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#lawyer-merits .card_link_block li .txt_area {
  padding: 0 0 0 15px;
  width: calc(100% - 180px - 60px);
}
@media (max-width: 900px) {
  #lawyer-merits .card_link_block li .txt_area {
    width: calc(100% - 120px - 15px);
  }
}
@media (max-width: 700px) {
  #lawyer-merits .card_link_block li .txt_area {
    padding: 0 10px 0 15px;
    width: calc(100% - 90px - 15px);
  }
}
#lawyer-merits .card_link_block li .txt_area p {
  font-size: clamp(16px, 1.6vw, 18px);
}
#lawyer-merits .merit03_wrap {
  margin-bottom: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .merit03_wrap {
    margin-bottom: 60px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit03_wrap {
    margin-bottom: 40px;
  }
}
#lawyer-merits .merit03_wrap .merit03_inner {
  display: flex;
  align-items: flex-start;
  gap: 50px;
}
@media (max-width: 700px) {
  #lawyer-merits .merit03_wrap .merit03_inner {
    flex-direction: column;
    gap: 20px;
  }
}
#lawyer-merits .merit03_wrap .merit03_inner figure {
  aspect-ratio: 3/2;
}
@media (min-width: 701px) {
  #lawyer-merits .merit03_wrap .merit03_inner figure {
    width: 20%;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit03_wrap .merit03_inner figure {
    max-width: 58vw;
    margin: 0 auto;
  }
}
#lawyer-merits .merit03_wrap .merit03_inner figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (min-width: 701px) {
  #lawyer-merits .merit03_wrap .merit03_inner .txt_area {
    width: calc(80% - 50px);
  }
}
#lawyer-merits .merit03_wrap .merit03_inner .txt_area .border_ttl {
  margin-bottom: 20px;
}
#lawyer-merits .merit03_wrap .merit03_inner .txt_area p {
  font-size: clamp(16px, 1.6vw, 24px);
}
#lawyer-merits .merit03_wrap .merit03_inner .txt_area p + p {
  margin-top: 1.1em;
}
#lawyer-merits .merit03_wrap .merit03_inner + .merit03_inner {
  margin-top: 60px;
}
@media (max-width: 700px) {
  #lawyer-merits .merit03_wrap .merit03_inner + .merit03_inner {
    margin-top: 30px;
  }
}
@media (min-width: 701px) {
  #lawyer-merits .merit02 .txt_asterisk {
    text-align: right;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap {
    flex-direction: column-reverse;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
    display: none;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard:not(:first-of-type) {
    position: relative;
  }
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard:not(:first-of-type)::after {
    position: absolute;
    content: "";
    border-right: 4px solid #3957a6;
    border-bottom: 4px solid #3957a6;
    transform: rotate(45deg);
    width: 30px;
    height: 30px;
    margin: auto;
    inset: auto 0 -30px 0;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type01 dt, #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type03 dt {
    position: relative;
  }
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type01 dt::before, #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type03 dt::before {
    position: absolute;
    margin: auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    inset: 0 auto 0 10px;
    font-size: 20px;
    font-weight: 500;
    line-height: 40px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type03 dt::before {
    content: "高";
    background: #0f172a;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .dl_standard_wrap > .dl_standard.bg_type01 dt::before {
    content: "低";
    background: #3957a6;
  }
}
#lawyer-merits .merit02 .lost {
  max-width: 800px;
  margin: 0 auto;
}
#lawyer-merits .merit02 .lost dt {
  font-size: clamp(18px, 2vw, 24px);
  padding: 12px;
}
#lawyer-merits .merit02 .lost dd p {
  font-size: clamp(16px, 1.6vw, 24px);
}
@media (max-width: 700px) {
  #lawyer-merits .merit02 .catch.align_center {
    text-align: left !important;
  }
}
#lawyer-merits .merit03 .center {
  display: flex;
  justify-content: center;
  margin-bottom: 40px;
  margin-top: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #lawyer-merits .merit03 .center {
    margin-top: 60px;
  }
}
@media (max-width: 700px) {
  #lawyer-merits .merit03 .center {
    margin-top: 30px;
  }
}

#reason .reason_block {
  margin-bottom: 140px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #reason .reason_block {
    margin-bottom: 100px;
  }
}
@media (max-width: 700px) {
  #reason .reason_block {
    margin-bottom: 60px;
  }
}
#reason .reason_block.sec_features {
  padding: 0;
}
@media (min-width: 701px) {
  #reason .reason_block .catch {
    text-align: center;
  }
}
#reason .reason_block .features_wrap {
  margin-top: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #reason .reason_block .features_wrap {
    margin-top: 70px;
  }
}
@media (max-width: 700px) {
  #reason .reason_block .features_wrap {
    margin-top: 40px;
  }
}
@media (max-width: 900px) {
  #reason .reason_block .features_wrap .features_block {
    flex-direction: column;
  }
}
@media (max-width: 900px) {
  #reason .reason_block .features_wrap .features_block.re {
    flex-direction: column;
  }
}
@media (max-width: 900px) {
  #reason .reason_block .features_wrap .features_block .sp_area {
    order: 0;
    padding: 0 20px;
  }
}
#reason .reason_block .features_wrap .features_block .sp_area .txt_blue {
  font-size: min(6vw, 32px);
}
#reason .reason_block .features_wrap .features_block .sp_area .txt_blue .en {
  font-size: 200%;
  font-family: "Roboto", sans-serif;
  font-style: italic;
}
#reason .reason_block .features_wrap .features_block .sp_area .block_ttl {
  font-size: clamp(18px, 1.8vw, 32px);
  font-weight: bold;
}
#reason .reason_block .features_wrap .features_block .txt_blue {
  font-size: clamp(18px, 2vw, 24px);
  font-weight: bold;
}
#reason .reason_block .features_wrap .features_block .txt_blue .en {
  color: #3957a6;
}
#reason .reason_block .features_wrap .features_block + .features_block {
  margin-top: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #reason .reason_block .features_wrap .features_block + .features_block {
    margin-top: 50px;
  }
}
@media (max-width: 700px) {
  #reason .reason_block .features_wrap .features_block + .features_block {
    margin-top: 0;
  }
}
@media (max-width: 900px) {
  #reason .reason_block .features_wrap .features_block figure {
    order: 1;
    margin-top: 15px;
    margin-bottom: 15px;
  }
}
@media (max-width: 900px) {
  #reason .reason_block .features_wrap .features_block .txt_area {
    order: 2;
  }
}
#reason .reason_block .features_wrap .features_block .txt_area .block_ttl {
  margin-top: 20px;
}
#reason .reason_block .features_wrap .features_block .txt_area p:not(.block_ttl) {
  font-size: clamp(16px, 1.6vw, 18px);
}
#reason .reason_block .features_wrap .features_block .txt_area p.note {
  font-size: clamp(12px, 1.6vw, 14px);
  margin-top: 20px;
}
#reason .reason_block .features_wrap .features_block .txt_area p.note + p.note {
  margin-top: 5px;
}

#traffic-accident .sec_traffic-accident {
  margin-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #traffic-accident .sec_traffic-accident {
    margin-bottom: 80px;
  }
}
@media (max-width: 700px) {
  #traffic-accident .sec_traffic-accident {
    margin-bottom: 50px;
  }
}
@media (max-width: 700px) {
  #traffic-accident .sec_traffic-accident .sec_inner {
    width: 100%;
  }
}
#traffic-accident .inner_block {
  padding: 60px min(100px, 6vw) 50px;
}
@media (max-width: 700px) {
  #traffic-accident .inner_block {
    padding: 30px 4vw 20px;
  }
}
#traffic-accident .inner_block + .inner_block {
  margin-top: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #traffic-accident .inner_block + .inner_block {
    margin-top: 90px;
  }
}
@media (max-width: 700px) {
  #traffic-accident .inner_block + .inner_block {
    margin-top: 60px;
  }
}
#traffic-accident .inner_block:not(:last-of-type) {
  position: relative;
}
#traffic-accident .inner_block:not(:last-of-type)::after {
  position: absolute;
  content: "";
  width: 240px;
  height: 60px;
  background-color: #cbd5e1;
  clip-path: polygon(50% 60px, 0% 0%, 240px 0%);
  margin: auto;
  inset: auto 0 -90px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #traffic-accident .inner_block:not(:last-of-type)::after {
    width: 180px;
    height: 45px;
    clip-path: polygon(50% 45px, 0% 0%, 180px 0%);
    inset: auto 0 -70px 0;
  }
}
@media (max-width: 700px) {
  #traffic-accident .inner_block:not(:last-of-type)::after {
    width: 120px;
    height: 30px;
    inset: auto 0 -45px 0;
    clip-path: polygon(50% 30px, 0% 0%, 120px 0%);
  }
}
#traffic-accident .inner_block .hukidashi_ttl {
  margin-bottom: 40px;
}
@media (max-width: 700px) {
  #traffic-accident .inner_block .hukidashi_ttl {
    margin-bottom: 20px;
  }
}
#traffic-accident .inner_block .hukidashi_ttl span {
  font-size: clamp(46px, 6vw, 80px);
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0;
  padding: 0 65px;
  line-height: 1.1;
}
#traffic-accident .inner_block .catch {
  text-align: center;
  font-weight: 500;
  font-size: clamp(16px, 1.8vw, 24px);
}
@media (max-width: 900px) {
  #traffic-accident .inner_block .catch {
    text-align: left;
  }
}
#traffic-accident .inner_block .bg_white {
  margin-top: 40px;
  padding: 50px min(100px, 6vw);
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 700px) {
  #traffic-accident .inner_block .bg_white {
    margin-top: 20px;
    padding: 20px min(20px, 4vw);
  }
}
#traffic-accident .inner_block .bg_white > .txt_blue {
  font-size: clamp(16px, 2vw, 22px);
  margin-bottom: 20px;
  font-weight: 500;
  width: 100%;
}
#traffic-accident .inner_block .dot_list li {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 500;
}
#traffic-accident .inner_block .dot_list li::before {
  inset: 0.6em auto auto 0;
}
#traffic-accident .inner_block .dot_list li + li {
  margin-top: 15px;
}
@media (min-width: 901px) {
  #traffic-accident .inner_block .number_ttl_wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
@media (min-width: 901px) {
  #traffic-accident .inner_block .number_ttl_wrap > div {
    display: grid;
  }
}
#traffic-accident .inner_block .number_ttl_wrap .number_ttl {
  font-size: clamp(20px, 2vw, 30px);
}
@media (min-width: 901px) {
  #traffic-accident .inner_block .number_ttl_wrap .number_ttl {
    display: inline-block;
    vertical-align: baseline;
  }
}
#traffic-accident .inner_block .number_ttl_wrap .number_ttl span {
  font-size: clamp(20px, 2vw, 30px);
}
@media (min-width: 901px) {
  #traffic-accident .inner_block .number_ttl_wrap .number_ttl span {
    display: inline-block;
    vertical-align: baseline;
    margin-right: 12px;
  }
}
#traffic-accident .inner_block p.align_right {
  margin: 20px 0 0 auto;
}
#traffic-accident .inner_block .center_ttl {
  margin-bottom: 20px;
}
@media (max-width: 700px) {
  #traffic-accident .inner_block .grade_btn_middle > div:not(.bg) {
    width: auto;
  }
}

#faq .sec_faq_intro {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq_intro {
    padding-bottom: 90px;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq_intro {
    padding-bottom: 60px;
  }
}
@media (min-width: 701px) {
  #faq .sec_faq_intro .catch {
    text-align: center;
  }
}
#faq .sec_faq_intro .anchor_list {
  margin-top: 60px;
}
@media (max-width: 700px) {
  #faq .sec_faq_intro .anchor_list {
    margin-top: 30px;
  }
}
#faq .sec_faq {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq {
    padding: 50px 0;
  }
}
#faq .sec_faq:not(.bg_light_gray) .details_block {
  background: #f1f5f9;
}
#faq .sec_faq .details_block {
  background: #fff;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  cursor: pointer;
}
#faq .sec_faq .details_block + .details_block {
  margin-top: 30px;
}
#faq .sec_faq .details_block[open] .summary_block::after {
  transform: rotate(0deg);
}
#faq .sec_faq .summary_block {
  font-weight: bold;
  font-size: clamp(18px, 2vw, 24px);
  list-style: none;
  padding: 30px 70px 30px 40px;
  position: relative;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .summary_block {
    padding: 20px 50px 20px 20px;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq .summary_block {
    padding: 15px 30px 15px 20px;
  }
}
#faq .sec_faq .summary_block::-webkit-details-marker {
  display: none !important;
}
#faq .sec_faq .summary_block::before, #faq .sec_faq .summary_block::after {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 30px;
  height: 2px;
  margin: auto;
  inset: 0 min(40px, 2vw) 0 auto;
  transition: 0.3s ease-in-out;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .summary_block::before, #faq .sec_faq .summary_block::after {
    width: 25px;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq .summary_block::before, #faq .sec_faq .summary_block::after {
    width: 20px;
  }
}
#faq .sec_faq .summary_block::after {
  transform: rotate(90deg);
}
#faq .sec_faq .summary_block .summary_ttl {
  position: relative;
  padding-left: 42px;
  display: block;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .summary_block .summary_ttl {
    padding-left: 32px;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq .summary_block .summary_ttl {
    padding-left: 27px;
  }
}
#faq .sec_faq .summary_block .summary_ttl::before {
  position: absolute;
  content: "Q.";
  font-family: "Roboto", sans-serif;
  color: #3957a6;
  font-weight: 600;
  font-size: clamp(24px, 2.4vw, 40px);
  letter-spacing: 0;
  margin: auto;
  inset: -0.3em auto auto 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .summary_block .summary_ttl::before {
    inset: -0.1em auto auto 0;
  }
}
#faq .sec_faq .details_inner {
  position: relative;
  padding: 0 40px 40px;
  margin-left: 40px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .details_inner {
    margin-left: 20px;
    padding: 0 20px 20px 30px;
  }
}
@media (max-width: 700px) {
  #faq .sec_faq .details_inner {
    margin-left: 20px;
    padding: 0 10px 20px 30px;
  }
}
#faq .sec_faq .details_inner::before {
  position: absolute;
  content: "A.";
  font-family: "Roboto", sans-serif;
  color: #f97316;
  font-weight: 600;
  font-size: clamp(24px, 2.4vw, 40px);
  letter-spacing: 0;
  margin: auto;
  inset: -0.3em auto auto 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #faq .sec_faq .details_inner::before {
    inset: -0.1em auto auto 0;
  }
}
#faq .sec_faq .details_inner p {
  font-size: clamp(16px, 1.8vw, 24px);
}

#consolation-money h3.center_ttl.type_middle {
  font-size: clamp(22px, 2.8vw, 40px);
}
#consolation-money .dl_block_wrap {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin: 60px 0 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .dl_block_wrap {
    margin: 40px 0 80px;
    gap: 20px;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_block_wrap {
    margin: 20px 0 50px;
    flex-direction: column;
    gap: 10px;
  }
}
#consolation-money .dl_block {
  flex: 1 0 48%;
}
#consolation-money .dl_block dt {
  font-size: clamp(20px, 2vw, 28px);
  padding: 20px;
}
@media (max-width: 700px) {
  #consolation-money .dl_block dt {
    padding: 10px;
  }
}
#consolation-money .dl_block dd {
  height: calc(100% - 80px);
  display: flex;
  align-items: center;
  gap: 24px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .dl_block dd {
    gap: 0;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_block dd {
    height: auto;
  }
}
#consolation-money .dl_block dd .dot_list li {
  font-size: clamp(16px, 1.6vw, 22px);
}
#consolation-money .dl_block dd p {
  font-size: clamp(16px, 1.6vw, 22px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .dl_base dd {
    padding: 20px 0;
  }
}
#consolation-money .dl_base .bg_light_gray .dot_list li {
  font-size: clamp(16px, 1.6vw, 22px);
}
#consolation-money .dl_base .bg_light_gray .dot_list li + li {
  margin-top: 0.5em;
}
#consolation-money .dl_base .bg_light_gray p {
  font-size: clamp(16px, 1.6vw, 22px);
}
#consolation-money .dl_base .bg_light_gray p.note {
  font-size: clamp(12px, 1.6vw, 14px);
}
#consolation-money .dl_standard_wrap {
  margin-top: 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .dl_standard_wrap {
    margin-top: 40px;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap {
    margin-top: 20px;
    flex-direction: column-reverse;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
    display: none;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap > .dl_standard:not(:first-of-type) {
    position: relative;
  }
  #consolation-money .dl_standard_wrap > .dl_standard:not(:first-of-type)::after {
    position: absolute;
    content: "";
    border-right: 4px solid #3957a6;
    border-bottom: 4px solid #3957a6;
    transform: rotate(45deg);
    width: 30px;
    height: 30px;
    margin: auto;
    inset: auto 0 -30px 0;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap > .dl_standard.bg_type01 dt, #consolation-money .dl_standard_wrap > .dl_standard.bg_type03 dt {
    position: relative;
  }
  #consolation-money .dl_standard_wrap > .dl_standard.bg_type01 dt::before, #consolation-money .dl_standard_wrap > .dl_standard.bg_type03 dt::before {
    position: absolute;
    margin: auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    inset: 0 auto 0 10px;
    font-size: 20px;
    font-weight: 500;
    line-height: 40px;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap > .dl_standard.bg_type03 dt::before {
    content: "高";
    background: #0f172a;
  }
}
@media (max-width: 700px) {
  #consolation-money .dl_standard_wrap > .dl_standard.bg_type01 dt::before {
    content: "低";
    background: #3957a6;
  }
}
#consolation-money .sec_money {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_money {
    padding-bottom: 80px;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_money {
    padding-bottom: 50px;
  }
}
#consolation-money .sec_money .catch.txt01 {
  margin-bottom: 1em;
}
@media (min-width: 701px) {
  #consolation-money .sec_money .catch.txt01 {
    text-align: center;
  }
}
@media (min-width: 701px) {
  #consolation-money .sec_money .catch.txt02 {
    text-align: center;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_money .catch_mini {
    font-size: 16px;
  }
}
#consolation-money .sec_money .dl_base > .dl_midashi {
  font-size: clamp(22px, 2.8vw, 40px);
}
#consolation-money .sec_amount {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_amount {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_amount {
    padding: 50px 0;
  }
}
#consolation-money .sec_amount .amount_box {
  padding: 80px min(100px, 5vw);
  border-radius: 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_amount .amount_box {
    padding: 50px min(60px, 5vw);
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box {
    padding: 20px min(20px, 4vw);
    border-radius: 10px;
  }
}
#consolation-money .sec_amount .amount_box + .amount_box {
  margin-top: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_amount .amount_box + .amount_box {
    margin-top: 60px;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box + .amount_box {
    margin-top: 20px;
  }
}
#consolation-money .sec_amount .amount_box .bg_light_gray {
  padding: 50px;
  margin-bottom: 50px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .bg_light_gray {
    margin-bottom: 30px;
    padding: 20px min(20px, 4vw);
  }
}
#consolation-money .sec_amount .amount_box .bg_light_gray .amount_conts_top {
  border-bottom: 1px solid #cbd5e1;
  padding: 0 40px 30px;
  margin-bottom: 30px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .bg_light_gray .amount_conts_top {
    padding: 0 0 20px;
    margin-bottom: 20px;
  }
}
#consolation-money .sec_amount .amount_box .center_ttl small {
  font-size: 80%;
}
#consolation-money .sec_amount .amount_box .list_number {
  width: 100%;
  margin-left: 1em;
}
#consolation-money .sec_amount .amount_box .list_number li {
  font-size: clamp(16px, 2vw, 24px);
}
#consolation-money .sec_amount .amount_box .list_number li + li {
  margin-top: 1em;
}
#consolation-money .sec_amount .amount_box .txt_example {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  font-size: clamp(18px, 2vw, 28px);
  font-weight: bold;
}
#consolation-money .sec_amount .amount_box .txt_example span {
  display: inline-block;
  background: #3957a6;
  color: #fff;
  min-width: 40px;
  line-height: 40px;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  font-size: clamp(16px, 2vw, 20px);
  text-align: center;
}
#consolation-money .sec_amount .amount_box .border_box {
  border: 10px solid #cbd5e1;
  padding: 50px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .border_box {
    padding: 20px min(20px, 4vw);
    border-width: 5px;
  }
}
#consolation-money .sec_amount .amount_box .table_top_txt1 {
  text-align: center;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .table_top_txt1 {
    text-align: left;
  }
}
#consolation-money .sec_amount .amount_box .js-scroll + .js-scroll {
  margin-top: 60px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .js-scroll + .js-scroll {
    margin-top: 30px;
  }
}
#consolation-money .sec_amount .amount_box .caption {
  text-align: center;
  font-size: clamp(18px, 2vw, 28px);
  font-weight: 400;
}
#consolation-money .sec_amount .amount_box .caption span {
  display: block;
  font-size: clamp(14px, 1.5vw, 20px);
  margin-top: 10px;
}
#consolation-money .sec_amount .amount_box .base_table + .base_table {
  margin-top: 60px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .base_table + .base_table {
    margin-top: 30px;
  }
}
#consolation-money .sec_amount .amount_box .base_table caption {
  text-align: center;
  font-size: clamp(18px, 2vw, 28px);
  font-weight: 400;
}
#consolation-money .sec_amount .amount_box .base_table caption span {
  display: block;
  font-size: clamp(14px, 1.5vw, 20px);
  margin-top: 10px;
}
#consolation-money .sec_amount .amount_box .base_table thead th {
  padding: 13px;
  border-color: #cbd5e1;
}
#consolation-money .sec_amount .amount_box .base_table thead th.none {
  background: #fff;
  border: 1px solid #cbd5e1;
}
#consolation-money .sec_amount .amount_box .base_table tbody th {
  padding: 13px;
  border-right: 1px solid #cbd5e1;
  font-weight: 400;
  background: #f1f5f9;
}
#consolation-money .sec_amount .amount_box .base_table tbody th:first-of-type {
  font-weight: bold;
}
#consolation-money .sec_amount .amount_box .base_table tbody td {
  padding: 13px;
  border-color: #cbd5e1;
  text-align: center;
  background: #fff;
}
#consolation-money .sec_amount .amount_box .base_table tbody td:first-of-type {
  font-weight: bold;
}
@media (max-width: 1440px) {
  #consolation-money .sec_amount .amount_box .base_table thead tr th:first-child,
  #consolation-money .sec_amount .amount_box .base_table tbody tr th:first-child,
  #consolation-money .sec_amount .amount_box .base_table tbody tr td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
  }
}
#consolation-money .sec_amount .amount_box .ex_price {
  max-width: 1120px;
  width: 100%;
  margin: 25px auto 60px;
  display: flex;
  align-items: center;
  gap: 40px;
  justify-content: space-between;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .ex_price {
    flex-direction: column;
    gap: 20px;
    margin: 25px auto 30px;
  }
}
#consolation-money .sec_amount .amount_box .ex_price dt {
  background: #3957a6;
  width: 35%;
  display: block;
  text-align: center;
  color: #fff;
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: bold;
  position: relative;
  padding: 30px 0;
  max-height: 120px;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .ex_price dt {
    padding: 10px;
    width: 100%;
  }
}
#consolation-money .sec_amount .amount_box .ex_price dt::before {
  position: absolute;
  content: "";
  width: 40px;
  height: 80px;
  background: #3957a6;
}
@media (min-width: 701px) {
  #consolation-money .sec_amount .amount_box .ex_price dt::before {
    clip-path: polygon(40px 50%, 0% 0%, 0% 80px);
    right: -39px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .ex_price dt::before {
    width: 40px;
    height: 15px;
    bottom: -14px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 15px, 0% 0%, 40px 0%);
  }
}
#consolation-money .sec_amount .amount_box .ex_price dd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
@media (min-width: 701px) {
  #consolation-money .sec_amount .amount_box .ex_price dd {
    width: 60%;
  }
}
#consolation-money .sec_amount .amount_box .ex_price dd > p {
  font-size: clamp(24px, 3.4vw, 40px);
  font-weight: bold;
  text-align: center;
  width: 40%;
}
#consolation-money .sec_amount .amount_box .ex_price dd .border_box {
  border: 5px solid #cbd5e1;
  text-align: center;
  font-size: clamp(20px, 2.4vw, 40px);
  padding: 18px;
  font-weight: bold;
  width: 60%;
}
@media (max-width: 700px) {
  #consolation-money .sec_amount .amount_box .ex_price dd .border_box {
    padding: 15px;
  }
}
#consolation-money .sec_amount .amount_box .ex_price dd .border_box small {
  display: block;
  font-size: clamp(14px, 1.5vw, 20px);
}
#consolation-money .sec_amount .amount_box .ex_price dd .border_box span strong {
  font-size: clamp(22px, 2.6vw, 48px);
}
#consolation-money .sec_goal {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_goal {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_goal {
    padding: 50px 0;
  }
}
#consolation-money .sec_goal .dl_block_wrap {
  margin-bottom: 60px;
}
#consolation-money .sec_goal .bg_light_gray:has(.base_table) {
  padding: 80px min(100px, 5vw);
  margin-bottom: 50px;
  border-radius: 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_goal .bg_light_gray:has(.base_table) {
    padding: 50px min(60px, 5vw);
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_goal .bg_light_gray:has(.base_table) {
    margin-bottom: 30px;
    padding: 20px min(20px, 4vw);
  }
}
#consolation-money .sec_goal .base_table th,
#consolation-money .sec_goal .base_table td {
  padding: 13px min(40px, 2vw);
}
@media (max-width: 700px) {
  #consolation-money .sec_goal .base_table th,
  #consolation-money .sec_goal .base_table td {
    padding: 10px;
  }
}
#consolation-money .sec_goal .base_table th.right,
#consolation-money .sec_goal .base_table td.right {
  text-align: right;
  padding: 13px min(140px, 10vw);
  white-space: nowrap;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_goal .base_table th.right,
  #consolation-money .sec_goal .base_table td.right {
    padding: 13px min(70px, 4vw);
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_goal .base_table th.right,
  #consolation-money .sec_goal .base_table td.right {
    padding: 10px;
    white-space: inherit;
  }
}
#consolation-money .sec_goal .border_box {
  border: 10px solid #cbd5e1;
  background: #fff;
  padding: 50px;
}
@media (max-width: 700px) {
  #consolation-money .sec_goal .border_box {
    padding: 20px min(20px, 4vw);
    border-width: 5px;
  }
}
#consolation-money .sec_features {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_features {
    padding-bottom: 80px;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_features {
    padding-bottom: 50px;
  }
}
#consolation-money .sec_features .features_wrap .txt_area {
  /* @include mq(sp) {
      margin: 20px 0 0;
  } */
}
#consolation-money .sec_features .features_wrap .txt_area .inner p + p {
  margin-top: 1em;
}
#consolation-money .sec_features .features_wrap + .center_ttl {
  margin-top: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #consolation-money .sec_features .features_wrap + .center_ttl {
    margin-top: 60px;
  }
}
@media (max-width: 700px) {
  #consolation-money .sec_features .features_wrap + .center_ttl {
    margin-top: 30px;
  }
}

#fee mark {
  background: linear-gradient(transparent 70%, #ffd52b 30%);
}
#fee .sec_fee_free .hukidashi_ttl {
  gap: 0;
}
#fee .sec_fee_free .hukidashi_ttl > span {
  margin-bottom: 50px;
}
@media (max-width: 700px) {
  #fee .sec_fee_free .hukidashi_ttl > span {
    margin-bottom: 20px;
  }
}
#fee .sec_fee_free .hukidashi_ttl mark em {
  font-size: 150%;
  line-height: 1;
}
#fee .sec_fee_free .dl_block_wrap {
  max-width: 1480px;
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin: 60px auto 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_free .dl_block_wrap {
    margin: 40px auto 80px;
    gap: 20px;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_free .dl_block_wrap {
    margin: 20px auto 50px;
    flex-direction: column;
    gap: 10px;
  }
}
#fee .sec_fee_free .dl_block {
  flex: 1 0 48%;
}
#fee .sec_fee_free .dl_block .dl_midashi {
  font-size: clamp(20px, 2vw, 28px);
  padding: 20px;
}
@media (max-width: 700px) {
  #fee .sec_fee_free .dl_block .dl_midashi {
    padding: 10px;
  }
}
#fee .sec_fee_free .dl_block .bg_light_gray {
  height: calc(100% - 80px);
  display: flex;
  align-items: center;
  gap: 24px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_free .dl_block .bg_light_gray {
    gap: 0;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_free .dl_block .bg_light_gray {
    height: auto;
  }
}
#fee .sec_fee_free .dl_block .bg_light_gray .inner {
  width: 100%;
  /* padding: 30px; */
}
#fee .sec_fee_free .dl_block .bg_light_gray .dot_list li {
  font-size: clamp(16px, 1.6vw, 22px);
}
#fee .sec_fee_free .dl_block .bg_light_gray p:not(.catch) {
  font-size: clamp(16px, 1.6vw, 22px);
}
#fee .sec_fee_free .dl_block .bg_light_gray p.arrow {
  position: relative;
  padding-bottom: 60px;
}
#fee .sec_fee_free .dl_block .bg_light_gray p.arrow::after {
  position: absolute;
  width: 120px;
  height: 40px;
  background-color: #cbd5e1;
  clip-path: polygon(50% 40px, 0% 0%, 120px 0%);
  content: "";
  margin: auto;
  inset: auto 0 0 0;
}
#fee .sec_fee_free .dl_block .bg_light_gray p.txt_blue {
  font-size: clamp(22px, 3vw, 32px);
}
#fee .sec_fee_free .dl_block .bg_light_gray p.txt_blue strong {
  font-size: 160%;
}
#fee .sec_fee_free .dl_block .bg_light_gray p.txt_asterisk {
  font-size: 100%;
  text-align: center;
}
@media (max-width: 700px) {
  #fee .sec_fee_free .dl_block .bg_light_gray p.txt_asterisk {
    text-align: left;
  }
}
#fee .sec_fee_free .free_list {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 30px;
}
#fee .sec_fee_free .free_list li {
  width: 48%;
  background: #fff;
  border-radius: 80px;
  font-weight: bold;
  text-align: center;
  color: #3957a6;
  font-size: clamp(16px, 1.6vw, 22px);
}
#fee .sec_fee_free .free_list li span {
  font-size: 180%;
}
#fee .sec_fee_free .and {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 10px 0;
}
#fee .sec_fee_free .and span {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #cbd5e1;
  width: 40px;
  text-align: center;
  height: 40px;
  min-width: 40px;
  border-radius: 50%;
  font-size: clamp(18px, 2.6vw, 30px);
  font-weight: 400;
  font-family: "Roboto", sans-serif;
}
@media (max-width: 700px) {
  #fee .sec_fee_free .and span {
    width: 30px;
    height: 30px;
    min-width: 30px;
  }
}
#fee .sec_fee_type {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_type {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_type {
    padding: 50px 0;
  }
}
#fee .sec_fee_type .type_block + .type_block {
  margin-top: 50px;
}
#fee .sec_fee_type .type_block .catch mark {
  font-size: 125%;
}
#fee .sec_fee_type .type_block .type_head {
  background: #3957a6;
  color: #fff;
  border-radius: 10px 10px 0 0;
  padding: 30px 15px;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_head {
    padding: 15px 10px 20px;
  }
}
#fee .sec_fee_type .type_block .type_head h3 {
  font-size: clamp(24px, 3vw, 40px);
  font-weight: bold;
  text-align: center;
}
#fee .sec_fee_type .type_block .type_head p {
  text-align: center;
  font-size: clamp(16px, 1.6vw, 20px);
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_head p {
    text-align: left;
    margin-top: 5px;
  }
}
#fee .sec_fee_type .type_block .type_head p span {
  font-weight: bold;
  text-decoration: underline 2px #ffd52b;
  text-underline-offset: 6px;
}
#fee .sec_fee_type .type_block .type_body {
  background: #fff;
  border-radius: 0 0 10px 10px;
  padding: 30px min(100px, 8vw);
  text-align: center;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body {
    padding: 20px min(20px, 4vw);
  }
}
#fee .sec_fee_type .type_block .type_body .answer {
  font-weight: bold;
  font-size: clamp(20px, 2.1vw, 30px);
  margin-bottom: 30px;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body .answer {
    margin-bottom: 20px;
  }
}
#fee .sec_fee_type .type_block .type_body .answer span {
  background: #f1f5f9;
  border-radius: 80px;
  padding: 7px 50px;
  color: #3957a6;
  display: inline-block;
  margin-left: 15px;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body .answer span {
    margin: 15px 0 0;
    padding: 5px 20px;
  }
}
#fee .sec_fee_type .type_block .type_body .answer span small {
  font-size: 60%;
  letter-spacing: 0.1em;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body .answer span small {
    font-size: 75%;
  }
}
#fee .sec_fee_type .type_block .type_body .answer span strong {
  font-size: 160%;
  font-weight: bold;
}
#fee .sec_fee_type .type_block .type_body .txt_asterisk {
  font-size: clamp(16px, 1.6vw, 20px);
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body .txt_asterisk {
    text-align: left;
  }
}
#fee .sec_fee_type .type_block .type_body .fee_point {
  margin-top: 50px;
  padding: 30px 20px 20px;
}
@media (max-width: 700px) {
  #fee .sec_fee_type .type_block .type_body .fee_point {
    margin-top: 30px;
    padding: 20px 10px 10px;
  }
}
#fee .sec_fee_detail {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_detail {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_detail {
    padding: 50px 0;
  }
}
#fee .sec_fee_detail.bg_light_gray .detail_block {
  background: #fff;
}
#fee .sec_fee_detail.bg_light_gray .detail_block .detail dd {
  background: #f1f5f9;
}
#fee .sec_fee_detail.bg_light_gray .detail_block {
  /*  .base_table {
      tbody td {
          background: #fff;
      }
  } */
}
#fee .sec_fee_detail .square_ttl {
  font-weight: bold;
  font-size: clamp(20px, 2.2vw, 28px);
  padding-left: 1.3em;
}
#fee .sec_fee_detail .center_cont {
  display: flex;
  justify-content: center;
  margin-bottom: 60px;
}
#fee .sec_fee_detail .center_cont .asterisk_list li {
  font-size: clamp(14px, 1.6vw, 18px);
}
#fee .sec_fee_detail .detail_block_wrap + .detail_block_wrap {
  margin-top: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_detail .detail_block_wrap + .detail_block_wrap {
    margin-top: 40px;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block_wrap + .detail_block_wrap {
    margin-top: 20px;
  }
}
#fee .sec_fee_detail .detail_block {
  background: #f1f5f9;
  padding: 40px;
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block {
    padding: 20px min(20px, 4vw);
  }
}
#fee .sec_fee_detail .detail_block + .asterisk_list {
  margin: 20px 0 0 20px;
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block + .asterisk_list {
    margin: 20px 0 0;
  }
}
#fee .sec_fee_detail .detail_block .detail {
  display: flex;
}
#fee .sec_fee_detail .detail_block .detail + .detail {
  margin-top: 20px;
}
#fee .sec_fee_detail .detail_block .detail.navy dt {
  background: #0f172a;
}
#fee .sec_fee_detail .detail_block .detail.navy dt::before {
  background: #0f172a;
}
#fee .sec_fee_detail .detail_block .detail dt {
  width: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: bold;
  position: relative;
  padding: 40px 0;
  background: #3957a6;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_detail .detail_block .detail dt {
    width: 230px;
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block .detail dt {
    padding: 10px;
    width: 40%;
  }
}
#fee .sec_fee_detail .detail_block .detail dt::before {
  position: absolute;
  content: "";
  width: 40px;
  height: 80px;
  background: #3957a6;
}
@media (min-width: 701px) {
  #fee .sec_fee_detail .detail_block .detail dt::before {
    clip-path: polygon(40px 50%, 0% 0%, 0% 80px);
    right: -39px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block .detail dt::before {
    width: 15px;
    height: 30px;
    right: -14px;
    clip-path: polygon(15px 50%, 0% 0%, 0% 30px);
  }
}
#fee .sec_fee_detail .detail_block .detail dd {
  width: calc(100% - 320px);
  display: flex;
  justify-content: center;
  gap: 60px;
  background: #fff;
  display: flex;
  align-items: center;
  text-align: left;
  justify-content: flex-start;
  padding: 20px 20px 20px 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #fee .sec_fee_detail .detail_block .detail dd {
    width: calc(100% - 230px);
  }
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block .detail dd {
    width: 100%;
    flex-direction: column;
    margin-bottom: 0;
    gap: 60px;
    padding: 10px 10px 10px 20px;
  }
}
#fee .sec_fee_detail .detail_block .detail dd p {
  font-size: clamp(22px, 3.4vw, 48px);
  color: #3957a6;
  font-weight: bold;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  letter-spacing: 0.05em;
  line-height: 1.2;
}
#fee .sec_fee_detail .detail_block .detail dd p span {
  font-size: clamp(16px, 2vw, 32px);
}
#fee .sec_fee_detail .detail_block .detail dd p small {
  font-size: clamp(14px, 1.4vw, 24px);
}
#fee .sec_fee_detail .detail_block .base_table {
  max-width: 879px;
  margin: 20px auto 0;
  border: 1px solid #cbd5e1;
}
#fee .sec_fee_detail .detail_block .base_table tbody th {
  background: #4d68af;
  text-align: left;
  color: #fff;
  width: 60%;
  padding: 10px 15px;
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block .base_table tbody th {
    padding: 5px 10px;
  }
}
#fee .sec_fee_detail .detail_block .base_table tbody td {
  width: 40%;
  text-align: center;
  padding: 10px 15px;
  font-size: clamp(16px, 1.6vw, 20px);
  background: #fff;
  vertical-align: middle;
}
@media (max-width: 700px) {
  #fee .sec_fee_detail .detail_block .base_table tbody td {
    padding: 5px 10px;
  }
}
#fee .sec_fee_detail .detail_block .base_table.gray tbody th {
  background: #3f4555;
}
#fee .sec_fee_detail.detail02 .detail_block .detail.navy dd {
  background: #cbd5e1;
}
#fee .sec_fee_detail.detail02 .detail_block .detail.navy dd p span {
  color: #0f172a;
}

#voice .voice_block {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #voice .voice_block {
    padding-bottom: 60px;
  }
}
@media (max-width: 700px) {
  #voice .voice_block {
    padding-bottom: 40px;
  }
}
#voice .guest_comment {
  display: flex;
  justify-content: space-between;
  margin: 40px 0 80px;
}
@media (max-width: 700px) {
  #voice .guest_comment {
    margin: 20px 0 40px;
  }
}
#voice .guest_comment li {
  width: 31%;
  background: #f1f5f9;
  position: relative;
  text-align: center;
  border-radius: 20px;
  padding: 20px 10px;
  color: #3957a6;
  font-weight: bold;
  font-size: clamp(18px, 2vw, 24px);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 700px) {
  #voice .guest_comment li {
    padding: 10px 7px;
  }
}
#voice .guest_comment li::after {
  position: absolute;
  content: "";
  background: url(../img/voice/comment_arrow.svg) no-repeat top center/contain;
  width: 25px;
  height: 30px;
  margin: auto;
  inset: auto 0 -24px 0;
}
#voice .guest_comment li.icon2::after {
  transform: rotateY(180deg);
}
@media (min-width: 701px) {
  #voice .txt_asterisk {
    text-align: center;
  }
}
@media (max-width: 700px) {
  #voice .txt_asterisk {
    font-size: 14px;
  }
}

#staff .breadcrumb {
  margin-bottom: 0;
}
#staff .sec_staff {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #staff .sec_staff {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #staff .sec_staff {
    padding: 50px 0;
  }
}
#staff .sec_staff.bg_light_gray .staff_element {
  margin-top: 0;
}
#staff .sec_staff.bg_light_gray .message {
  background: #fff;
}
#staff .sec_staff .staff_element {
  display: flex;
  align-items: center;
  gap: 80px;
  margin: 80px auto 100px;
  max-width: 1200px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #staff .sec_staff .staff_element {
    gap: 40px;
  }
}
@media (max-width: 700px) {
  #staff .sec_staff .staff_element {
    flex-direction: column;
    gap: 30px;
    margin: 30px auto 60px;
  }
}
@media (max-width: 700px) {
  #staff .sec_staff .staff_element figure {
    max-width: 200px;
    margin: 0 auto;
  }
}
#staff .sec_staff .staff_element .staff_info {
  width: calc(100% - 400px - 80px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  #staff .sec_staff .staff_element .staff_info {
    width: calc(100% - 400px - 40px);
  }
}
@media (max-width: 700px) {
  #staff .sec_staff .staff_element .staff_info {
    width: 100%;
  }
}
#staff .sec_staff .staff_element .staff_info .name {
  font-size: clamp(26px, 3.8vw, 50px);
}
#staff .sec_staff .staff_element .staff_info p {
  font-size: clamp(16px, 1.8vw, 20px);
}
#staff .sec_staff .tablelike {
  max-width: 1200px;
  margin: 0 auto;
  font-size: clamp(16px, 1.8vw, 20px);
}
#staff .sec_staff .message {
  background: #f1f5f9;
  border-radius: 20px;
  padding: 60px 0;
  margin-top: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #staff .sec_staff .message {
    margin-top: 60px;
    padding: 40px 0;
  }
}
@media (max-width: 700px) {
  #staff .sec_staff .message {
    margin-top: 30px;
    border-radius: 0;
    padding: 30px 0;
  }
}
#staff .sec_staff .message .message_inner {
  max-width: 1400px;
  margin: 0 auto;
  width: 80%;
}
#staff .sec_staff .message .border_ttl {
  font-size: clamp(20px, 2vw, 32px);
}
#staff .sec_staff .message p {
  font-size: clamp(16px, 1.8vw, 20px);
}
#staff .sec_staff .message p + p {
  margin-top: 1em;
}

#office .sec_office {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_office {
    padding-bottom: 60px;
  }
}
@media (max-width: 700px) {
  #office .sec_office {
    padding-bottom: 40px;
  }
}
#office .sec_office .catch {
  margin: 70px auto 50px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_office .catch {
    margin: 45px auto 30px;
  }
}
@media (max-width: 700px) {
  #office .sec_office .catch {
    margin: 30px auto 20px;
  }
}
#office .sec_office .anchor_btn {
  display: block;
  border: 1px solid #cbd5e1;
  max-width: 500px;
  width: 100%;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 22px);
  padding: 15px 10px;
  position: relative;
  font-weight: 600;
  margin: 0 auto;
}
#office .sec_office .anchor_btn:hover {
  background: #f1f5f9;
}
#office .sec_office .anchor_btn::after {
  position: absolute;
  content: "";
  border-right: 1.5px solid #0f172a;
  border-bottom: 1.5px solid #0f172a;
  transform: rotate(45deg);
  width: 12px;
  height: 12px;
  inset: 0 30px 0 auto;
  margin: auto;
}
#office .sec_philosophy {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_philosophy {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #office .sec_philosophy {
    padding: 50px 0;
  }
}
#office .sec_philosophy .philosophy_block {
  padding: 80px min(80px, 10vw);
  border-radius: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0 40px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_philosophy .philosophy_block {
    padding: 40px;
  }
}
@media (max-width: 700px) {
  #office .sec_philosophy .philosophy_block {
    padding: 20px min(20px, 4vw);
    gap: 0;
  }
}
#office .sec_philosophy .philosophy_block .border_ttl {
  width: 100%;
  font-size: clamp(20px, 2vw, 32px);
}
#office .sec_philosophy .philosophy_block figure {
  width: calc(50% - 20px);
}
@media (max-width: 700px) {
  #office .sec_philosophy .philosophy_block figure {
    width: 100%;
    margin-bottom: 20px;
  }
}
#office .sec_philosophy .philosophy_block .txt_area {
  width: calc(50% - 20px);
}
@media (max-width: 700px) {
  #office .sec_philosophy .philosophy_block .txt_area {
    width: 100%;
  }
}
#office .sec_philosophy .philosophy_block .txt_area p {
  font-size: clamp(16px, 1.8vw, 20px);
}
#office .sec_philosophy .philosophy_block .txt_area p + p {
  margin-top: 1em;
}
#office .sec_philosophy .philosophy_block + .philosophy_block {
  margin-top: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_philosophy .philosophy_block + .philosophy_block {
    margin-top: 50px;
  }
}
@media (max-width: 700px) {
  #office .sec_philosophy .philosophy_block + .philosophy_block {
    margin-top: 30px;
  }
}
#office .sec_promise {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_promise {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #office .sec_promise {
    padding: 50px 0;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .features_block {
    flex-direction: column;
  }
}
#office .sec_promise .features_block .en {
  color: #cbd5e1;
  font-weight: 500;
  font-size: clamp(40px, 5.2vw, 80px);
  font-style: italic;
  line-height: 1.1;
}
@media (max-width: 700px) {
  #office .sec_promise .features_block.re {
    flex-direction: column;
  }
}
#office .sec_promise .features_block + .features_block {
  margin-top: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_promise .features_block + .features_block {
    margin-top: 50px;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .features_block + .features_block {
    margin-top: 30px;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .features_block .sp_area {
    order: 0;
    padding: 0 20px;
  }
}
#office .sec_promise .features_block .sp_area .txt_blue {
  font-size: min(6vw, 32px);
}
#office .sec_promise .features_block .sp_area .txt_blue .en {
  font-size: 200%;
  font-family: "Roboto", sans-serif;
  font-style: italic;
}
#office .sec_promise .features_block .sp_area .block_ttl {
  font-size: clamp(18px, 1.8vw, 32px);
  font-weight: bold;
}
@media (max-width: 700px) {
  #office .sec_promise .features_block figure {
    order: 1;
    margin-top: 15px;
    margin-bottom: 15px;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .features_block .txt_area {
    order: 2;
    margin-bottom: 0;
  }
}
#office .sec_promise .features_block .txt_area p + p {
  margin-top: 1em;
}
#office .sec_promise .office_bn a {
  width: 100%;
  max-width: 800px;
  margin: 120px auto 0;
  display: flex;
  background: url(../img/office/introduction_bg@2x.webp) no-repeat center/cover;
  border: 5px solid #cbd5e1;
  padding: 10px 40px 0;
  position: relative;
}
@media (max-width: 700px) {
  #office .sec_promise .office_bn a {
    flex-direction: column;
    padding: 20px 0 0;
    background: url(../img/office/introduction_bg_sp@2x.webp) no-repeat center/cover;
    margin: 60px auto 0;
  }
}
@media (min-width: 701px) {
  #office .sec_promise .office_bn a::before {
    position: absolute;
    content: "";
    border-right: 1.5px solid #0f172a;
    border-bottom: 1.5px solid #0f172a;
    transform: rotate(-45deg);
    width: 18px;
    height: 18px;
    inset: 0 30px 0 auto;
    margin: auto;
  }
}
#office .sec_promise .office_bn a:hover {
  opacity: 0.8;
}
#office .sec_promise .office_bn a figure {
  text-align: center;
}
@media (min-width: 701px) {
  #office .sec_promise .office_bn a figure {
    width: 30%;
  }
}
#office .sec_promise .office_bn a .txt_area {
  display: flex;
  flex-direction: column;
}
@media (min-width: 701px) {
  #office .sec_promise .office_bn a .txt_area {
    width: 70%;
    padding: 40px 0 10px 10px;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .office_bn a .txt_area {
    background: #cbd5e1;
    padding: 15px 0 5px;
    align-items: center;
    gap: 5px;
  }
}
#office .sec_promise .office_bn a .txt_area .txt {
  font-size: clamp(18px, 2vw, 22px);
}
#office .sec_promise .office_bn a .txt_area .txt_blue {
  font-size: clamp(24px, 2.6vw, 32px);
  font-weight: bold;
}
#office .sec_promise .office_bn a .txt_area .name {
  font-size: clamp(16px, 1.8vw, 20px);
  margin-top: auto;
}
#office .sec_promise .office_bn a .txt_area .txt_link {
  margin: 0 10px 0 auto;
}
#office .sec_promise .bn {
  margin: 120px auto 0;
  text-align: center;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_promise .bn {
    margin-top: 80px;
  }
}
@media (max-width: 700px) {
  #office .sec_promise .bn {
    margin-top: 40px;
  }
}
#office .sec_access {
  padding: 120px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_access {
    padding: 80px 0;
  }
}
@media (max-width: 700px) {
  #office .sec_access {
    padding: 50px 0;
  }
}
#office .sec_access .access_detail {
  padding: 80px min(80px, 10vw);
  border-radius: 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #office .sec_access .access_detail {
    padding: 40px;
  }
}
@media (max-width: 700px) {
  #office .sec_access .access_detail {
    padding: 30px min(20px, 4vw);
  }
}
#office .sec_access .tablelike dt {
  font-weight: bold;
  font-size: clamp(16px, 1.8vw, 20px);
  padding: 13px 15px;
  width: 184px;
}
@media (max-width: 700px) {
  #office .sec_access .tablelike dt {
    padding: 13px 0;
    width: 100%;
  }
}
#office .sec_access .tablelike dd {
  font-size: clamp(16px, 1.8vw, 20px);
  padding: 13px 15px;
  width: calc(100% - 184px);
}
@media (max-width: 700px) {
  #office .sec_access .tablelike dd {
    padding: 0 0 13px 0;
    width: 100%;
  }
}
@media (max-width: 700px) {
  #office .sec_access .tablelike dd a {
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}
@media (min-width: 701px) {
  #office .sec_access .tablelike dd a[href^="tel:"] {
    color: #0f172a;
    text-decoration: none;
  }
}
#office .sec_access .iframe_block {
  margin-top: 30px;
}
#office .sec_access .map_info {
  display: flex;
  align-items: center;
  gap: 30px;
  margin-top: 30px;
}
@media (max-width: 700px) {
  #office .sec_access .map_info {
    gap: 15px;
  }
}
@media (max-width: 700px) {
  #office .sec_access .map_info figure {
    width: 40%;
  }
}

#contact .sec_contact {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .sec_contact {
    padding-bottom: 60px;
  }
}
@media (max-width: 700px) {
  #contact .sec_contact {
    padding-bottom: 40px;
  }
}
#contact .sec_contact .sec_inner {
  max-width: 1300px;
}
#contact .sec_contact .contact_intro {
  text-align: center;
  margin-bottom: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .sec_contact .contact_intro {
    margin-bottom: 50px;
  }
}
@media (max-width: 700px) {
  #contact .sec_contact .contact_intro {
    margin-bottom: 30px;
  }
}
#contact .sec_contact .contact_intro span {
  background: #3957a6;
  padding: 15px 40px;
  font-size: clamp(20px, 2vw, 32px);
}
#contact .sec_contact .contact_intro p {
  font-size: clamp(20px, 2.4vw, 40px);
  margin-top: 40px;
}
#contact .sec_contact .center_cont {
  display: flex;
  justify-content: center;
  margin-bottom: 60px;
}
#contact .sec_contact .center_cont .asterisk_list li {
  font-size: clamp(14px, 1.6vw, 18px);
}
#contact .sec_contact .dl_block_wrap {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin: 60px 0 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .sec_contact .dl_block_wrap {
    margin: 40px 0 80px;
    gap: 20px;
  }
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block_wrap {
    margin: 20px 0 50px;
    flex-direction: column;
    gap: 10px;
  }
}
#contact .sec_contact .dl_block {
  flex: 1 0 48%;
}
#contact .sec_contact .dl_block.bg_line .dl_midashi {
  background: #4cc764;
}
#contact .sec_contact .dl_block .dl_midashi {
  font-size: clamp(26px, 3vw, 36px);
  padding: 10px;
}
#contact .sec_contact .dl_block .bg_white {
  height: calc(100% - 80px);
  gap: 24px;
  background: #fff;
  border-top: none;
  align-items: center;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .sec_contact .dl_block .bg_white {
    gap: 0;
  }
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white {
    height: auto;
  }
}
#contact .sec_contact .dl_block .bg_white .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#contact .sec_contact .dl_block .bg_white .tel {
  font-family: "Roboto", sans-serif;
  font-size: clamp(30px, 4vw, 64px);
  position: relative;
  padding-left: 92px;
  font-weight: bold;
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white .tel {
    padding-left: 50px;
  }
}
#contact .sec_contact .dl_block .bg_white .tel::before {
  position: absolute;
  content: "";
  background: url("../img/icon/icon_phone.svg") no-repeat center center/contain;
  width: 72px;
  height: 72px;
  inset: 0 auto 0 0;
  margin: auto;
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white .tel::before {
    width: 35px;
    height: 35px;
  }
}
#contact .sec_contact .dl_block .bg_white span {
  font-size: clamp(16px, 2vw, 24px);
}
#contact .sec_contact .dl_block .bg_white .line_link_btn {
  display: block;
  border-radius: 40px;
  border: 1px solid #cbd5e1;
  background: #fff;
  box-shadow: 3px 3px 7px 0 rgba(0, 0, 0, 0.15);
  width: 80%;
  max-width: 480px;
  line-height: 80px;
  text-align: center;
  font-size: clamp(20px, 2vw, 32px);
  font-weight: bold;
  position: relative;
  margin-bottom: 15px;
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white .line_link_btn {
    line-height: 60px;
  }
}
#contact .sec_contact .dl_block .bg_white .line_link_btn::before, #contact .sec_contact .dl_block .bg_white .line_link_btn::after {
  position: absolute;
  content: "";
  margin: auto;
}
#contact .sec_contact .dl_block .bg_white .line_link_btn::before {
  background: url("../img/icon/icon_line.svg") no-repeat center center/contain;
  width: 64px;
  height: 64px;
  inset: 8px auto 8px 8px;
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white .line_link_btn::before {
    width: 45px;
    height: 45px;
  }
}
#contact .sec_contact .dl_block .bg_white .line_link_btn::after {
  border-right: 1.5px solid #4cc764;
  border-bottom: 1.5px solid #4cc764;
  transform: rotate(-45deg);
  width: 26px;
  height: 26px;
  inset: 0 40px 0 auto;
}
@media (max-width: 700px) {
  #contact .sec_contact .dl_block .bg_white .line_link_btn::after {
    width: 15px;
    height: 15px;
    inset: 0 20px 0 auto;
  }
}
#contact .sec_contact .dl_block .bg_white .line_link_btn:hover {
  opacity: 0.8;
}
#contact .sec_contact .dl_block .bg_white .txt {
  font-size: clamp(18px, 2vw, 24px);
}
#contact .sec_contact .contact_txt {
  text-align: center;
}
#contact .contactform {
  max-width: 1200px;
  margin: 80px auto 0;
}
#contact .contactform .tablelike > div::after {
  width: 260px;
}
@media (max-width: 700px) {
  #contact .contactform .tablelike > div::after {
    width: 130px;
  }
}
#contact .contactform .tablelike > div:first-of-type::before {
  width: 260px;
}
@media (max-width: 700px) {
  #contact .contactform .tablelike > div:first-of-type::before {
    width: 130px;
  }
}
#contact .contactform .tablelike dt {
  font-weight: bold;
  display: flex;
  justify-content: space-between;
  width: 260px;
  padding: 35px 0;
  font-size: clamp(16px, 1.8vw, 20px);
}
@media (max-width: 700px) {
  #contact .contactform .tablelike dt {
    width: 100%;
    padding: 15px 0;
  }
}
#contact .contactform .tablelike dt.must {
  position: relative;
}
#contact .contactform .tablelike dt.must::after {
  position: absolute;
  content: "必須";
  background: #3957a6;
  width: 80px;
  line-height: 40px;
  color: #fff;
  font-size: clamp(16px, 1.8vw, 20px);
  text-align: center;
  margin: auto;
  inset: 30px 0 auto auto;
}
@media (max-width: 700px) {
  #contact .contactform .tablelike dt.must::after {
    width: 60px;
    line-height: 30px;
    inset: 13px 0 auto auto;
  }
}
#contact .contactform .tablelike dd {
  width: calc(100% - 260px);
  padding: 17px 20px;
}
@media (max-width: 700px) {
  #contact .contactform .tablelike dd {
    width: 100%;
    padding: 0 0 15px;
  }
}
#contact .contactform .tablelike dd .explanation {
  font-size: clamp(16px, 1.8vw, 20px);
  margin-bottom: 20px;
}
#contact .contactform .input_block + .input_block {
  margin-top: 20px;
}
#contact .contactform .input_block .in_box {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (max-width: 700px) {
  #contact .contactform .input_block .in_box {
    gap: 10px;
  }
}
#contact .contactform .input_block .in_box .title-contactform7 {
  font-size: clamp(16px, 1.8vw, 20px);
  width: 120px;
  min-width: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .contactform .input_block .in_box .title-contactform7 {
    width: 100px;
    min-width: 100px;
  }
}
@media (max-width: 700px) {
  #contact .contactform .input_block .in_box .title-contactform7 {
    width: 70px;
    min-width: 70px;
  }
}
#contact .contactform .input_block .in_box:not(.zip-group) input {
  width: 100%;
}
#contact .contactform .input_block .in_box .zip_txt {
  font-size: clamp(14px, 1.6vw, 18px);
}
#contact .contactform .input_block:has(input[type=radio]) {
  padding: 20px 0;
}
@media (max-width: 700px) {
  #contact .contactform .input_block:has(input[type=radio]) {
    padding: 0;
  }
}
#contact .contactform .input_block:has(input[type=radio]) .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 50px;
}
@media (max-width: 700px) {
  #contact .contactform .input_block:has(input[type=radio]) .wpcf7-radio {
    flex-direction: column;
    gap: 10px;
  }
}
#contact .contactform input[type=tel],
#contact .contactform input[type=text],
#contact .contactform input[type=email],
#contact .contactform select,
#contact .contactform textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 18px;
  box-sizing: border-box;
  background-color: #f1f5f9;
  border: 1px solid #cbd5e1;
  font-size: clamp(16px, 1.8vw, 20px);
  border-radius: 5px;
  width: 100%;
  font-family: "Noto Sans JP", sans-serif;
}
@media (max-width: 700px) {
  #contact .contactform input[type=tel],
  #contact .contactform input[type=text],
  #contact .contactform input[type=email],
  #contact .contactform select,
  #contact .contactform textarea {
    padding: 10px;
  }
}
#contact .contactform input[type=tel]::placeholder,
#contact .contactform input[type=text]::placeholder,
#contact .contactform input[type=email]::placeholder,
#contact .contactform select::placeholder,
#contact .contactform textarea::placeholder {
  color: rgba(58, 58, 58, 0.5);
}
#contact .contactform input[type=tel].p-postal-code,
#contact .contactform input[type=text].p-postal-code,
#contact .contactform input[type=email].p-postal-code,
#contact .contactform select.p-postal-code,
#contact .contactform textarea.p-postal-code {
  max-width: 240px;
}
#contact .contactform .mwform-radio-field-text {
  display: inline-block;
  vertical-align: top;
}
#contact .contactform .wpcf7-list-item-label {
  font-size: clamp(16px, 1.8vw, 20px);
  vertical-align: middle;
  cursor: pointer;
}
#contact .contactform .wpcf7-list-item {
  margin: 0;
  display: block;
  cursor: pointer;
}
#contact .contactform input[type=radio] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  border: none;
  font-family: "Noto Sans JP", sans-serif;
  height: 32px;
  width: 44px;
  cursor: pointer;
}
#contact .contactform input[type=radio]::before, #contact .contactform input[type=radio]::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
}
#contact .contactform input[type=radio]::before {
  background-color: #f1f5f9;
  border: 1px solid #cbd5e1;
  width: 32px;
  height: 32px;
  margin: auto;
  border-radius: 50%;
}
#contact .contactform input[type=radio]::after {
  width: 16px;
  height: 16px;
  opacity: 0;
  margin: auto;
  border-radius: 50%;
  box-sizing: border-box;
  background: #3957a6;
}
#contact .contactform input[type=radio]:checked::after {
  opacity: 1;
}
#contact .contactform input[type=checkbox] {
  padding-left: 30px;
  position: relative;
  border: none;
  font-family: "Noto Sans JP", sans-serif;
  margin: 0;
}
#contact .contactform input[type=checkbox]::after, #contact .contactform input[type=checkbox]::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  cursor: pointer;
}
#contact .contactform input[type=checkbox]::before {
  background-color: #fff;
  border: 1px solid #aaa;
  width: 24px;
  height: 24px;
  margin: auto;
  border-radius: 5px;
}
#contact .contactform input[type=checkbox]::after {
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  opacity: 0;
  height: 8px;
  width: 15px;
  transform: rotate(-45deg);
  margin: auto;
}
#contact .contactform input[type=checkbox]:checked:before {
  background-color: #3957a6;
}
#contact .contactform input[type=checkbox]:checked:after {
  opacity: 1;
}
#contact .contactform textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 18px;
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background-color: #f1f5f9;
  border: 1px solid #cbd5e1;
  font-size: clamp(16px, 1.8vw, 20px);
  font-family: "Noto Sans JP", sans-serif;
  border-radius: 10px;
}
#contact .contactform textarea::placeholder {
  color: rgba(58, 58, 58, 0.5);
  font-size: 16px;
}
#contact .contactform .btn_area {
  display: flex;
  justify-content: center;
  gap: 30px;
}
#contact .contactform .btn_area input[type=submit] {
  display: block;
  background: #3957a6;
  color: #fff;
  text-align: center;
  line-height: 90px;
  font-size: clamp(18px, 2vw, 24px);
  font-weight: bold;
  width: 500px;
  transition: 0.3s ease-in-out;
  border-radius: 50px;
  cursor: pointer;
}
@media (min-width: 701px) and (max-width: 1440px) {
  #contact .contactform .btn_area input[type=submit] {
    line-height: 80px;
  }
}
@media (max-width: 700px) {
  #contact .contactform .btn_area input[type=submit] {
    margin: 0 auto;
    width: 280px;
    line-height: 70px;
  }
}
#contact .contactform .btn_area input[type=submit]:hover {
  background: #0f172a;
}
#contact .contactform .wpcf7-spinner {
  display: none;
}
#contact .contactform .p-country-name {
  display: none;
}
#contact .contactform .cbx-container {
  text-align: center;
  margin: 60px auto;
}
#contact .contactform .cbx-container p {
  margin-bottom: 30px;
}
@media (max-width: 700px) {
  #contact .contactform .cbx-container p {
    margin-bottom: 15px;
  }
}
#contact .sec_contact_thanks .thanks_message {
  padding: 50px 0 100px;
  text-align: center;
}
#contact .sec_contact_thanks .thanks_message .common_btn {
  margin-top: 80px;
}
@media (max-width: 700px) {
  #contact .sec_contact_thanks .thanks_message .common_btn {
    margin-top: 40px;
  }
}
#contact footer {
  padding-bottom: 0;
}
#contact .pageTop {
  bottom: 90px;
}
#contact .grecaptcha-badge {
  z-index: 99 !important;
}
#contact .grecaptcha-badge {
  visibility: visible;
}

@media (min-width: 701px) {
  .sp {
    display: none;
  }
}

@media (min-width: 1441px) {
  .sptab {
    display: none;
  }
}

@media (min-width: 901px) {
  .sp_nav {
    display: none;
  }
}

@media (max-width: 900px) {
  .nav_pc {
    display: none;
  }
}

@media (max-width: 700px) {
  .tabpc {
    display: none;
  }
}

@media (max-width: 1440px) {
  .pc {
    display: none;
  }
}

/***********************
　　　レイアウト
*************************/
.grecaptcha-badge {
  visibility: hidden;
}

main {
  display: block;
  width: 100%;
  position: relative;
  z-index: 1;
}

.sec_inner {
  width: 96%;
  margin: 0 auto;
  max-width: 1600px;
}
@media (max-width: 700px) {
  .sec_inner {
    width: 94%;
  }
}
.sec_inner.tight {
  max-width: 1500px;
}
.sec_inner.tight2 {
  max-width: 1200px;
}

.bg_white {
  background: #fff !important;
}

.bg_light_gray {
  background: #f1f5f9 !important;
}

.bg_accent {
  background: #ffd52b;
}

.iframe_block {
  aspect-ratio: 16/9;
}
.iframe_block iframe {
  width: 100%;
  height: 100%;
}

.grid_column2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 40px;
  width: 100%;
}
@media (max-width: 1440px) {
  .grid_column2 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 20px;
  }
}

/***********************
　　　スクロール
*************************/
.js-scroll {
  overflow-y: hidden !important;
}
.js-scroll > * {
  min-width: 1000px;
}
.js-scroll.scroll-hint.is-right-scrollable {
  background: none;
}
@media (max-width: 1440px) {
  .js-scroll .scroll-hint-icon {
    left: 15% !important;
  }
}

.scroll_design {
  scrollbar-color: #414042 #f1f2f2;
  scrollbar-width: thin;
}
.scroll_design::-webkit-scrollbar {
  /* スクロールバー全体の幅 */
  width: 6px;
}
.scroll_design::-webkit-scrollbar-track {
  /* スクロールバーの背景 (トラック) */
  background-color: #f1f2f2;
  border-radius: 5px;
}
.scroll_design::-webkit-scrollbar-thumb {
  /* スクロールバーのつまみ (thumb) */
  border-radius: 5px;
  background-color: #414042;
}

/***********************
  　　　テキスト
*************************/
.vertical {
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}

.txt_white {
  color: #fff;
}

.txt_red {
  color: #e42815;
}

.txt_blue {
  color: #3957a6;
}

.txt_orange {
  color: #f97316;
}

.txt_yellow {
  color: #ffd52b;
}

.txt_black {
  color: #0f172a;
}

.txt_bold {
  font-weight: bold;
}

.txt_semi_bold {
  font-weight: 600;
}

.txt_medium {
  font-weight: 500;
}

.txt_normal {
  font-weight: 400;
}

.catch {
  font-size: clamp(18px, 2vw, 24px);
}

.note {
  font-size: clamp(12px, 1.6vw, 14px);
}

.en {
  font-family: "Roboto", sans-serif;
}

.txt_area p a {
  color: #3957a6;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.txt_area p a:hover {
  text-decoration: none;
}

.block {
  display: block;
}

.shadow {
  filter: drop-shadow(0px 2px 10px rgba(0, 0, 0, 0.1));
}

.align_left {
  text-align: left !important;
}

.align_center {
  text-align: center !important;
}

.align_right {
  text-align: right !important;
}

@media (max-width: 700px) {
  .align_left_sp {
    text-align: left !important;
  }
}

.txt_indent {
  text-indent: -1em;
  padding-left: 1em;
}

.txt_line_height2 {
  line-height: 2;
}

.txt_asterisk {
  position: relative;
  text-indent: -1em;
  padding-left: 1em;
}
.txt_asterisk::before {
  content: "※";
}

/***********************
　　　タイトル
*************************/
.hukidashi_ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 50px;
  font-size: clamp(24px, 3.6vw, 48px);
  font-weight: bold;
  letter-spacing: 0.05em;
  margin-bottom: 75px;
  text-align: center;
  text-wrap: balance;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .hukidashi_ttl {
    margin-bottom: 45px;
  }
}
@media (max-width: 700px) {
  .hukidashi_ttl {
    margin-bottom: 30px;
    gap: 30px;
  }
}
.hukidashi_ttl span {
  text-align: center;
  font-size: clamp(20px, 2.2vw, 40px);
  letter-spacing: 0.1em;
  position: relative;
  font-weight: 400;
}
.hukidashi_ttl span::after {
  position: absolute;
  content: "";
  background: url("../img/common/hukidashi_line.svg") no-repeat top center/cover;
  width: 100%;
  height: 27px;
  inset: auto 0 -40px;
}
@media (max-width: 700px) {
  .hukidashi_ttl span::after {
    background: url("../img/common/hukidashi_line_sp.svg") no-repeat top center/cover;
    height: 12px;
    inset: auto 0 -18px;
  }
}

/***********************
　　　リンク
*************************/
.common_btn {
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: 600;
  background: #3957a6;
  display: block;
  max-width: 640px;
  width: 100%;
  padding: 27px 47px 27px 27px;
  position: relative;
  text-align: center;
  border-radius: 50px;
  color: #fff;
}
@media (max-width: 700px) {
  .common_btn {
    margin: 0 auto;
    padding: 17px 37px 17px 17px;
  }
}
@media (max-width: 374px) {
  .common_btn {
    padding: 17px;
  }
}
.common_btn:hover {
  background: #0f172a;
}
.common_btn::before {
  position: absolute;
  content: "";
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transform: rotate(-45deg);
  width: 16px;
  height: 16px;
  margin: auto;
  inset: 0 40px 0 auto;
}
@media (max-width: 700px) {
  .common_btn::before {
    inset: 0 20px 0 auto;
  }
}
@media (max-width: 374px) {
  .common_btn::before {
    inset: 0 10px 0 auto;
  }
}
.common_btn.center {
  margin: 0 auto;
}
.common_btn.mini {
  max-width: 360px;
  padding: 15px 35px 15px 12px;
  font-size: clamp(16px, 1.7vw, 20px);
}
.common_btn.white {
  background: #fff;
  color: #3957a6;
}
.common_btn.white::before {
  border-color: #3957a6;
}
.common_btn.white:hover {
  background: #f1f5f9;
}
.common_btn.orange {
  background: #f97316;
}
.common_btn.orange:hover {
  background: #d75800;
}
.common_btn.square {
  border-radius: 0;
  padding: 23.5px 47px 23.5px 27px;
  font-size: clamp(16px, 1.6vw, 22px);
}
.common_btn.blank::before {
  transform: inherit;
  border: none;
  width: 32px;
  height: 32px;
  background: url("../img/icon/icon_blank.svg") no-repeat center center/contain;
}
@media (max-width: 700px) {
  .common_btn.blank::before {
    width: 20px;
    height: 20px;
  }
}

.txt_link span {
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: 0.3s;
  position: relative;
  padding-right: 15px;
}
.txt_link span:hover {
  text-decoration: none;
  color: #3957a6;
}
.txt_link span::before {
  position: absolute;
  content: "";
  border-right: 1.5px solid #0f172a;
  border-bottom: 1.5px solid #0f172a;
  transform: rotate(-45deg);
  width: 10px;
  height: 10px;
  inset: 0 0 0 auto;
  margin: auto;
}

.underline_link {
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: 0.3s;
}
.underline_link:hover {
  text-decoration: none;
  color: #3957a6;
}

@media (min-width: 701px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

/***********************
　　　リスト
*************************/
ul.disc_list li {
  list-style-type: disc;
  margin-left: 1.5em;
}
ul.dot_list li {
  position: relative;
  list-style-type: none;
  padding-left: 1em;
}
ul.dot_list li::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 0.45em;
  height: 0.45em;
  border-radius: 50%;
  inset: 0.5em auto auto 0;
  margin: auto;
}
ul.asterisk_list {
  margin-top: 10px;
}
ul.asterisk_list li {
  position: relative;
  list-style-type: none;
  padding-left: 1em;
  font-size: 90%;
}
ul.asterisk_list li::before {
  position: absolute;
  content: "※";
  font-weight: bold;
  color: #3957a6;
  inset: 0 auto auto 0;
  margin: auto;
}

ol.list_number {
  margin-left: 1rem;
}
ol.list_number li {
  list-style-type: decimal;
}
ol.list_alphabet {
  margin-left: 1rem;
}
ol.list_alphabet li {
  list-style-type: lower-latin;
}
ol.list_romaji {
  margin-left: 1rem;
}
ol.list_romaji li {
  list-style-type: upper-roman;
}
ol.number {
  counter-reset: circle-counter;
}
ol.number li {
  position: relative;
  list-style-type: none;
  padding-left: 2em;
  counter-increment: circle-counter;
  line-height: 1.8;
}
ol.number li::before {
  position: absolute;
  content: "(" counter(circle-counter) ")";
  /*  font-weight: 600;
  color: #fff;
  padding: 0 0.2em;
  background: $main_color;
  border-radius: 4px;
  margin-right: 0.5em;
  width: 1.7em;
  display: inline-block; */
  margin: auto;
  inset: 0 auto auto 0;
  text-align: center;
  /*  height: 1.7em; */
}

.anchor_list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .anchor_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1441px) {
  .anchor_list {
    grid-template-columns: repeat(4, 1fr);
  }
}
.anchor_list li a {
  display: block;
  font-size: clamp(16px, 1.6vw, 22px);
  border: 1px solid #cbd5e1;
  padding: 15px 10px;
  position: relative;
  text-align: center;
  font-weight: 600;
}
.anchor_list li a:hover {
  background: #f1f5f9;
}
.anchor_list li a::after {
  position: absolute;
  content: "";
  border-right: 1.5px solid #0f172a;
  border-bottom: 1.5px solid #0f172a;
  transform: rotate(45deg);
  width: 12px;
  height: 12px;
  inset: 0 30px 0 auto;
  margin: auto;
}

/***********************
　　　アニメーション
*************************/
.animate {
  opacity: 0;
}
.animate.is-active {
  animation: slideIn 0.8s 0.2s forwards;
}

/***********************
　　　タブ切り替え
*************************/
.tab-contents .tab-contents-item {
  display: none;
}
.tab-contents .tab-contents-item.active {
  display: block;
}

.pageTop {
  width: 60px;
  height: 60px;
  position: fixed;
  z-index: 7;
  bottom: 10px;
  right: 10px;
  transition: 0.5s ease-in-out;
}
@media (max-width: 700px) {
  .pageTop {
    width: 40px;
    height: 40px;
    bottom: 60px;
  }
}
.pageTop a {
  position: relative;
  display: block;
  background: #fff;
  border: 1px solid #3957a6;
  width: 60px;
  height: 60px;
  position: relative;
}
@media (max-width: 700px) {
  .pageTop a {
    width: 40px;
    height: 40px;
  }
}
.pageTop a::before {
  position: absolute;
  content: "";
  border-right: 1px solid #3957a6;
  border-bottom: 1px solid #3957a6;
  transform: rotate(-135deg);
  inset: 14% 0 0 0;
  margin: auto;
  width: 18px;
  height: 18px;
}
@media (max-width: 700px) {
  .pageTop a::before {
    width: 10px;
    height: 10px;
  }
}
.pageTop a:hover {
  background: #3957a6;
}
.pageTop a:hover::before {
  filter: brightness(0) invert(1);
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
@keyframes zoomOut {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes shorter {
  from {
    width: 330px;
  }
  to {
    width: 20px;
  }
}
@keyframes fuwafuwa {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, 30px);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes expand {
  from {
    width: 0;
  }
  to {
    width: 330px;
  }
}
@keyframes bgUpAnime {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes bgDownAnime {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(100%);
  }
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeUpAnime_mv {
  from {
    transform: translateY(100px);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes fadeDownAnime {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes img_shine {
  0% {
    filter: blur(10px) brightness(1.05);
  }
  60% {
    filter: blur(0) brightness(1.25);
  }
  100% {
    filter: blur(0) brightness(1);
  }
}
@keyframes loop_text {
  0% {
    transform: translateX(0) translate3d(0, 0, 0);
  }
  100% {
    transform: translateX(-100%) translate3d(0, 50%, 0);
  }
}
@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes slideIn {
  0% {
    opacity: 0;
    transform: translateY(-10px);
    -webkit-clip-path: inset(0 0 100% 0);
    clip-path: inset(0 0 100% 0);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    webkit-clip-path: inset(0);
    clip-path: inset(0);
  }
}
@keyframes slideInUp {
  0% {
    opacity: 0;
    transform: translateY(10px);
    -webkit-clip-path: inset(100% 0 0 0);
    clip-path: inset(100% 0 0 0);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    webkit-clip-path: inset(0);
    clip-path: inset(0);
  }
}
@keyframes slideOut {
  0% {
    opacity: 1;
    transform: translateY(0);
    webkit-clip-path: inset(0);
    clip-path: inset(0);
  }
  100% {
    opacity: 0;
    transform: translateY(10px);
    -webkit-clip-path: inset(0 0 100% 0);
    clip-path: inset(0 0 100% 0);
  }
}
@keyframes hamburger_line1 {
  0% {
    transform: translateY(20px) rotate(45deg);
  }
  50% {
    transform: translateY(20px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
@keyframes hamburger_line2 {
  0% {
    transform: translateY(-20px) rotate(-45deg);
  }
  50% {
    transform: translateY(-20px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
@keyframes fadeBlack {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes txtanimation {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.base_table {
  width: 100%;
  border-left: 1px solid #cbd5e1;
  border-right: 1px solid #cbd5e1;
  /*   border-collapse: separate;
  border-spacing: 2px; */
}
.base_table caption {
  font-size: clamp(16px, 1.7rem, 20px);
  font-weight: 600;
  margin-bottom: 10px;
  text-align: left;
}
.base_table caption span {
  font-size: 70%;
}
.base_table thead th {
  background: #3957a6;
  color: #fff;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 20px);
  font-weight: bold;
  padding: 20px;
  border-right: 1px solid #fff;
}
.base_table tbody tr th {
  background: #f1f5f9;
  border-bottom: 1px solid #cbd5e1;
  border-right: 1px solid #cbd5e1;
  text-align: center;
  vertical-align: middle;
  font-size: clamp(16px, 1.6vw, 20px);
  font-weight: bold;
}
.base_table tbody tr td {
  border-right: 1px solid #cbd5e1;
  border-bottom: 1px solid #cbd5e1;
  padding: 10px;
  font-size: clamp(16px, 1.6vw, 18px);
  padding: min(2vw, 40px);
}
.base_table a {
  text-decoration: underline;
  text-underline-offset: 4px;
  color: #3957a6;
}
.base_table a:hover {
  text-decoration: none;
}
.base_table.even_color tr:nth-child(2n+1) td {
  background: #f1f5f9;
}
.base_table.even_color tr:nth-child(2n) td {
  background: #fff;
}
.base_table.ftd_border tr:first-of-type td {
  border-top: 1px solid #cbd5e1;
}
@media (max-width: 700px) {
  .base_table.sp_block tr:first-of-type td {
    border-top: none;
  }
}
@media (max-width: 700px) {
  .base_table.sp_block th,
  .base_table.sp_block td {
    width: 100%;
    display: block;
    padding: 15px;
    border-right: none;
  }
}
@media (max-width: 700px) {
  .base_table.sp_block td {
    border-top: none;
  }
}

.breadcrumb {
  position: relative;
  z-index: 1;
  margin-bottom: 140px;
  margin-top: -40px;
}
@media (max-width: 1440px) {
  .breadcrumb {
    margin-bottom: 50px;
    margin-top: 0;
  }
}
.breadcrumb .bread_list {
  /*  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start; */
  margin: 20px auto 30px;
  gap: 10px 0;
}
@media (max-width: 700px) {
  .breadcrumb .bread_list {
    margin: 10px auto 20px;
  }
}
.breadcrumb .bread_list li {
  display: inline;
  font-size: clamp(14px, 1.4vw, 16px);
  letter-spacing: 0.05em;
  color: rgba(15, 23, 42, 0.5);
}
.breadcrumb .bread_list li:first-of-type a {
  white-space: nowrap;
}
.breadcrumb .bread_list li:not(:last-child) {
  padding-right: 21px;
  position: relative;
}
.breadcrumb .bread_list li:not(:last-child)::after {
  content: "";
  position: absolute;
  border-right: 1px solid #a4b0b9;
  border-bottom: 1px solid #a4b0b9;
  transform: rotate(-45deg);
  width: 0.5em;
  height: 0.5em;
  margin: auto;
  inset: 0 10px 0 auto;
}
.breadcrumb .bread_list li a {
  color: #0f172a;
  transition: 0.3s;
}
.breadcrumb .bread_list li a:hover {
  text-decoration: underline;
  text-underline-offset: 5px;
}
.breadcrumb .bread_list li a.single_cat:not(:last-of-type) {
  position: relative;
  padding-right: 8px;
  margin-right: 8px;
}
.breadcrumb .bread_list li a.single_cat:not(:last-of-type)::before {
  position: absolute;
  content: "";
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  background: rgba(15, 23, 42, 0.5);
  width: 1px;
  height: 10px;
}

.middle main .middleFV {
  position: relative;
  height: 360px;
  overflow: hidden;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .middleFV {
    height: 260px;
  }
}
@media (max-width: 700px) {
  .middle main .middleFV {
    height: 160px;
  }
}
.middle main .middleFV::before {
  position: absolute;
  content: "";
  width: 380px;
  height: 360px;
  background: url(../img/common/section_deco.svg) no-repeat center center/contain;
  right: -40px;
  top: 0;
}
@media (max-width: 700px) {
  .middle main .middleFV::before {
    width: 40vw;
    height: 38vw;
    right: 0;
  }
}
.middle main .middleFV::after {
  position: absolute;
  content: "";
  background: #f1f5f9;
  width: 100%;
  height: 320px;
  top: 0;
  left: 0;
  z-index: -1;
}
.middle main .middleFV .sec_inner {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 100%;
  margin-top: -20px;
}
@media (max-width: 1440px) {
  .middle main .middleFV .sec_inner {
    margin-top: 0;
  }
}
.middle main .middleFV .main_ttl {
  font-size: clamp(26px, 4vw, 56px);
  line-height: 1.2;
  margin-bottom: 0;
  letter-spacing: 0.05em;
  font-weight: bold;
  position: relative;
  z-index: 1;
}
.middle main .middleFV.newsFV {
  height: 100%;
  min-height: 360px;
  display: flex;
  align-items: center;
  padding: 30px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .middleFV.newsFV {
    min-height: 260px;
  }
}
@media (max-width: 700px) {
  .middle main .middleFV.newsFV {
    min-height: 160px;
    padding: 15px 0;
  }
}
.middle main .middleFV.newsFV::after {
  height: 100%;
}
.middle main .middleFV.newsFV + .breadcrumb {
  margin-top: 0;
}
.middle main .middleFV.newsFV .sec_inner {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
.middle main .middleFV.newsFV .sec_inner .main_ttl {
  text-align: left;
  font-size: clamp(26px, 4vw, 42px);
}
.middle main .middleFV.newsFV .sec_inner time {
  font-size: clamp(16px, 1.6vw, 18px);
}
.middle main .middleFV.infoFV {
  height: 100%;
  min-height: 360px;
  display: flex;
  align-items: center;
  padding: 30px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .middleFV.infoFV {
    min-height: 260px;
  }
}
@media (max-width: 700px) {
  .middle main .middleFV.infoFV {
    min-height: 160px;
    padding: 15px 0;
  }
}
.middle main .middleFV.infoFV::after {
  height: 100%;
}
.middle main .middleFV.infoFV + .breadcrumb {
  margin-top: 0;
}
.middle main .middleFV.infoFV .sec_inner .main_ttl {
  font-size: clamp(26px, 4vw, 42px);
}
.middle main .middleFV.blogFV {
  height: 100%;
  min-height: 360px;
  display: flex;
  align-items: center;
  padding: 30px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .middleFV.blogFV {
    min-height: 260px;
  }
}
@media (max-width: 700px) {
  .middle main .middleFV.blogFV {
    min-height: 160px;
  }
}
.middle main .middleFV.blogFV::after {
  height: 100%;
}
.middle main .middleFV.blogFV + .breadcrumb {
  margin-top: 0;
}
.middle main .middleFV.blogFV .sec_inner {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 10px;
}
.middle main .middleFV.blogFV .sec_inner .main_ttl {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  font-size: clamp(26px, 4vw, 42px);
}
@media (max-width: 700px) {
  .middle main .middleFV.blogFV .sec_inner .main_ttl {
    gap: 5px;
  }
}
.middle main .middleFV.blogFV .sec_inner .main_ttl span {
  background: #3957a6;
  padding: 0 12px;
  display: block;
  color: #fff;
  font-size: 42%;
}
@media (max-width: 700px) {
  .middle main .middleFV.blogFV .sec_inner .main_ttl span {
    padding: 0 6px;
    font-size: 75%;
  }
}
.middle main .middleFV.blogFV .sec_inner .fv_inner {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .middle main .middleFV.blogFV .sec_inner .fv_inner {
    gap: 5px;
  }
}
.middle main .middleFV.blogFV .sec_inner .fv_inner a {
  background: #cbd5e1;
  font-size: 16px;
  display: block;
  padding: 2px 15px;
}
@media (max-width: 700px) {
  .middle main .middleFV.blogFV .sec_inner .fv_inner a {
    padding: 0 8px;
    font-size: 14px;
  }
}
.middle main .middleFV.blogFV .sec_inner .fv_inner a:hover {
  color: #3957a6;
}
.middle main .middleFV.blogFV .sec_inner dl {
  display: flex;
  font-size: 16px;
}
.middle main .middleFV.blogFV .sec_inner dl dt:not(:first-of-type) {
  margin-left: 20px;
}
.middle main .middle_ttl {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 4px solid #cbd5e1;
  position: relative;
}
.middle main .middle_ttl::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 120px;
  height: 4px;
  margin: auto;
  bottom: -4px;
  left: 0;
}
.middle main .square_ttl {
  font-size: clamp(18px, 2vw, 24px);
  position: relative;
  padding-left: 2em;
  margin-bottom: 20px;
}
.middle main .square_ttl::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 1em;
  height: 1em;
  margin: auto;
  inset: 0.3em auto auto 0;
}
.middle main .center_ttl {
  text-align: center;
  font-weight: bold;
  font-size: clamp(24px, 3.8vw, 48px);
  letter-spacing: 0.05em;
  margin-bottom: 50px;
}
@media (max-width: 700px) {
  .middle main .center_ttl {
    margin-bottom: 30px;
  }
}
.middle main .center_ttl.type_middle {
  font-size: clamp(20px, 2.8vw, 40px);
}
.middle main .center_ttl.type_small {
  font-size: clamp(18px, 2vw, 30px);
}
.middle main .triangle_ttl {
  text-align: center;
  font-weight: bold;
  font-size: clamp(22px, 2.4vw, 48px);
  position: relative;
  padding-bottom: 100px;
  margin-bottom: 15px;
  z-index: 1;
  letter-spacing: 0.05em;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .triangle_ttl {
    padding-bottom: 80px;
  }
}
@media (max-width: 700px) {
  .middle main .triangle_ttl {
    padding-bottom: 70px;
  }
}
.middle main .triangle_ttl::before {
  content: "";
  position: absolute;
  width: 100%;
  max-width: 1200px;
  height: 100px;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  background: url("../img/top/polygon.png") no-repeat center center/contain;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .triangle_ttl::before {
    width: 50%;
    height: 50%;
  }
}
.middle main .number_ttl {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: bold;
  font-size: clamp(22px, 2.6vw, 32px);
}
.middle main .number_ttl span {
  background: #3957a6;
  width: 1.56em;
  height: 1.56em;
  color: #fff;
  border-radius: 50%;
  font-family: "Roboto", sans-serif;
  font-style: italic;
  font-weight: 500;
  min-width: 1.56em;
  font-size: clamp(20px, 2vw, 32px);
  text-align: center;
}
.middle main .border_ttl {
  text-align: center;
  font-size: clamp(20px, 2vw, 28px);
  padding-bottom: 10px;
  border-bottom: 2px solid #cbd5e1;
  margin-bottom: 40px;
  font-weight: bold;
}
@media (max-width: 700px) {
  .middle main .border_ttl {
    margin-bottom: 20px;
  }
}
.middle main .border_ttl.left {
  text-align: left;
}
.middle main .grade_btn_middle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(60px, 4vw);
  background: linear-gradient(180deg, #f97316 25.96%, #d32c00 100%);
  text-align: center;
  color: #fff;
  padding: 16px min(40px, 2vw);
  transition: 0.3s ease-in-out;
  position: relative;
  margin: 0 auto;
  max-width: 800px;
  width: 100%;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .middle main .grade_btn_middle {
    max-width: 600px;
  }
}
@media (max-width: 900px) {
  .middle main .grade_btn_middle {
    max-width: 500px;
  }
}
@media (max-width: 700px) {
  .middle main .grade_btn_middle {
    flex-wrap: wrap;
    gap: 15px 8px;
    padding: 15px 10px;
  }
}
.middle main .grade_btn_middle figure {
  width: 80px;
  height: 80px;
}
@media (max-width: 700px) {
  .middle main .grade_btn_middle figure {
    width: 40px;
    height: 40px;
  }
}
.middle main .grade_btn_middle > div {
  width: calc(100% - 50px);
}
@media (min-width: 701px) {
  .middle main .grade_btn_middle > div {
    width: calc(100% - 100px);
  }
}
.middle main .grade_btn_middle .bg {
  background: #fff;
  border-radius: 50px;
  padding: 0 15px;
}
.middle main .grade_btn_middle .bg.sp {
  width: 100%;
  margin: 0 5%;
}
.middle main .grade_btn_middle .bg p {
  text-align: center;
  font-weight: bold;
  font-size: clamp(16px, 2.2vw, 24px);
  margin-bottom: 5px;
  color: #0f172a;
}
.middle main .grade_btn_middle .bg p span {
  font-size: 120%;
  color: #4cc764;
}
@media (max-width: 700px) {
  .middle main .grade_btn_middle .bg p span {
    font-size: 16px;
  }
}
.middle main .grade_btn_middle .comment p {
  font-size: clamp(16px, 1.8vw, 30px);
  font-weight: bold;
}
@media (max-width: 700px) {
  .middle main .grade_btn_middle .comment p {
    font-size: min(16px, 4vw);
  }
}
.middle main .grade_btn_middle .comment span {
  display: block;
  font-weight: 400;
  font-size: clamp(12px, 1.6vw, 20px);
}
.middle main .grade_btn_middle:hover {
  opacity: 0.8;
}
.middle main .star_icon {
  padding-left: 53px;
  position: relative;
  font-size: clamp(20px, 2.2vw, 32px);
  display: inline;
  font-weight: bold;
}
.middle main .star_icon::before {
  position: absolute;
  content: "";
  background: url("../img/legal-advice/icon_star.svg") no-repeat center center/contain;
  width: 40px;
  height: 40px;
  margin: auto;
  inset: 0 auto 0 0;
}

.wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin: 30px auto 50px;
  width: 100%;
  gap: 12px;
}
@media (min-width: 1441px) {
  .wp-pagenavi {
    margin: 60px auto 120px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .wp-pagenavi {
    margin: 40px auto 80px;
  }
}
.wp-pagenavi .pages {
  display: none;
}
.wp-pagenavi > * {
  width: 28px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  text-align: center;
  box-sizing: border-box;
  border: 1px solid #3957a6 !important;
  background: #3957a6;
  color: #fff;
  font-size: clamp(16px, 1.6vw, 20px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  letter-spacing: 0;
  padding: 0 !important;
}
@media (max-width: 700px) {
  .wp-pagenavi > * {
    width: 30px;
    height: 30px;
  }
}
.wp-pagenavi > *.current {
  padding: 0;
  color: #0f172a;
  background: #cbd5e1;
  font-weight: 400 !important;
  border-color: #cbd5e1 !important;
}
.wp-pagenavi > *:hover {
  opacity: 0.7;
}
.wp-pagenavi > *.extend {
  background: none;
  border: none !important;
  color: #0f172a;
}
.wp-pagenavi > *.previouspostslink {
  position: relative;
  color: #0f172a;
  background: transparent;
  border: none !important;
  padding-left: 0.7em !important;
  width: 110px;
  font-weight: 400;
  text-decoration: underline;
  text-underline-offset: 5px;
  line-height: 32px;
}
.wp-pagenavi > *.previouspostslink::after {
  position: absolute;
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(-135deg);
  margin: auto;
  z-index: 1;
  inset: 5px auto 0 0;
}
@media (max-width: 700px) {
  .wp-pagenavi > *.previouspostslink::after {
    width: 0.5em;
    height: 0.5em;
  }
}
.wp-pagenavi > *.previouspostslink:hover {
  opacity: 0.7;
  text-decoration: none;
}
.wp-pagenavi > *.nextpostslink {
  position: relative;
  color: #0f172a;
  background: transparent;
  border: none !important;
  padding-right: 0.7em !important;
  width: 110px;
  font-weight: 400;
  text-decoration: underline;
  text-underline-offset: 5px;
  line-height: 32px;
}
.wp-pagenavi > *.nextpostslink::after {
  position: absolute;
  content: "";
  width: 0.6em;
  height: 0.6em;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg);
  margin: auto;
  z-index: 1;
  inset: 5px 0 0 auto;
}
@media (max-width: 700px) {
  .wp-pagenavi > *.nextpostslink::after {
    width: 0.5em;
    height: 0.5em;
  }
}
.wp-pagenavi > *.nextpostslink:hover {
  opacity: 0.7;
  text-decoration: none;
}

.single_pagenav {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin-top: 86px;
  align-items: center;
}
@media (max-width: 700px) {
  .single_pagenav {
    margin-top: 50px;
  }
}
.single_pagenav .all {
  width: 80%;
  max-width: 440px;
  margin: 0 auto;
}
.single_pagenav .tip a {
  display: block;
  position: relative;
}
.single_pagenav .tip a::before {
  content: "";
  position: absolute;
  background: url("../img/icon/arrow.svg") no-repeat center center/contain;
  width: 12px;
  height: 10px;
  margin: auto;
  z-index: 1;
  transition: 0.3s ease-in-out;
}
@media (max-width: 700px) {
  .single_pagenav .tip a::before {
    width: 7px;
    height: 6px;
  }
}
.single_pagenav .tip a::after {
  content: "";
  position: absolute;
  background: #fff;
  border-radius: 50%;
  width: 56px;
  height: 40px;
  margin: auto;
}
@media (max-width: 700px) {
  .single_pagenav .tip a::after {
    width: 32px;
    height: 23px;
  }
}
.single_pagenav .tip.prev a {
  padding-left: 68px;
}
@media (max-width: 700px) {
  .single_pagenav .tip.prev a {
    padding-left: 40px;
  }
}
.single_pagenav .tip.prev a::before {
  inset: 0 auto 0 21px;
  transform: rotate(180deg);
}
@media (max-width: 700px) {
  .single_pagenav .tip.prev a::before {
    inset: 0 auto 0 13px;
  }
}
.single_pagenav .tip.prev a::after {
  inset: 0 auto 0 0;
}
.single_pagenav .tip.prev a:hover::before {
  transform: translateX(-3px) rotate(180deg);
}
.single_pagenav .tip.next a {
  padding-right: 68px;
}
@media (max-width: 700px) {
  .single_pagenav .tip.next a {
    padding-right: 40px;
  }
}
.single_pagenav .tip.next a::before {
  inset: 0 21px 0 auto;
}
@media (max-width: 700px) {
  .single_pagenav .tip.next a::before {
    inset: 0 13px 0 auto;
  }
}
.single_pagenav .tip.next a::after {
  inset: 0 0 0 auto;
}
.single_pagenav .tip.next a:hover::before {
  transform: translateX(3px);
}

dl.tablelike > div {
  display: flex;
  position: relative;
  border-bottom: 1px solid #cbd5e1;
}
dl.tablelike > div::after {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 170px;
  height: 1px;
  margin: auto;
  bottom: -1px;
  left: 0;
}
@media (max-width: 700px) {
  dl.tablelike > div::after {
    width: 140px;
  }
}
dl.tablelike > div:first-of-type {
  border-top: 1px solid #cbd5e1;
}
dl.tablelike > div:first-of-type::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 170px;
  height: 1px;
  margin: auto;
  top: -1px;
  left: 0;
}
@media (max-width: 700px) {
  dl.tablelike > div:first-of-type::before {
    width: 140px;
  }
}
dl.tablelike > div dt {
  padding: 13px 0;
  white-space: nowrap;
  width: 20%;
}
@media (max-width: 700px) {
  dl.tablelike > div dt {
    padding: 10px 0;
  }
}
dl.tablelike > div dd {
  padding: 13px min(80px, 4vw);
  width: 80%;
}
@media (max-width: 700px) {
  dl.tablelike > div dd {
    padding: 0 0 10px;
  }
}
@media (max-width: 700px) {
  dl.tablelike.sp_block > div {
    flex-direction: column;
  }
}
@media (max-width: 700px) {
  dl.tablelike.sp_block > div dt {
    width: 100%;
  }
}
@media (max-width: 700px) {
  dl.tablelike.sp_block > div dd {
    width: 100%;
  }
}

* {
  font-family: "Noto Sans JP", sans-serif;
}

.original_block {
  margin: 30px 0;
}
.original_block .js-scroll {
  margin: 30px 0;
}
.original_block .js-scroll > table {
  margin: 0;
}
@media (max-width: 700px) {
  .original_block .js-scroll > table {
    min-width: 1000px !important;
  }
}

/* .custom-post-paragraph {
  font-weight: 500;
} */
.original_h2_text_block {
  margin: 50px 0 30px;
}
@media (max-width: 700px) {
  .original_h2_text_block {
    margin: 30px 0 20px;
  }
}
.original_h2_text_block h2 {
  font-weight: bold;
  font-size: clamp(20px, 2vw, 40px);
  position: relative;
  line-height: 1.5;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 4px solid #cbd5e1;
  position: relative;
  margin-top: 60px;
}
.original_h2_text_block h2::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 120px;
  height: 4px;
  margin: auto;
  bottom: -4px;
  left: 0;
}

.original_h3_text_block {
  margin: 50px 0 30px;
}
@media (max-width: 700px) {
  .original_h3_text_block {
    margin: 30px 0 20px;
  }
}
.original_h3_text_block h3 {
  font-size: clamp(20px, 2vw, 32px);
  position: relative;
  padding-left: 1em;
  margin-bottom: 20px;
  font-weight: 700;
}
.original_h3_text_block h3::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 0.6em;
  height: 0.6em;
  margin: auto;
  inset: 0 auto 0 0;
}

.original_h4_text_block {
  margin: 50px 0 30px;
}
@media (max-width: 700px) {
  .original_h4_text_block {
    margin: 30px 0 20px;
  }
}
.original_h4_text_block h4 {
  font-size: clamp(18px, 2vw, 28px);
  font-weight: bold;
  position: relative;
  padding-bottom: 0.6em;
  border-bottom: 1px solid #cbd5e1;
}

.original_h5_text_block {
  margin: 40px 0 30px;
}
@media (max-width: 700px) {
  .original_h5_text_block {
    margin: 20px 0;
  }
}
.original_h5_text_block h5 {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: bold;
  margin-bottom: 30px;
}

.original_ul_block {
  margin: 30px 0;
}
@media (max-width: 700px) {
  .original_ul_block {
    margin: 20px 0;
  }
}
.original_ul_block ul li {
  line-height: 1.8;
  display: flex;
  align-items: flex-start;
}
@media (min-width: 701px) {
  .original_ul_block ul li {
    font-size: 16px;
    font-weight: 500;
  }
}
.original_ul_block ul li .mark {
  display: block;
  width: 8px;
  height: 8px;
  background: #3957a6;
  border-radius: 50%;
  margin: 10px 10px 0;
}
@media (max-width: 700px) {
  .original_ul_block ul li .mark {
    width: 6px;
    height: 6px;
  }
}
.original_ul_block ul li p {
  font-size: clamp(16px, 1.6vw, 18px);
  margin: 0;
  display: block;
  font-weight: 500;
  width: calc(100% - 20px);
  /*  vertical-align: middle; */
}

.original_ol_block {
  margin: 30px 0;
}
@media (max-width: 700px) {
  .original_ol_block {
    margin: 20px 0;
  }
}
.original_ol_block ol {
  padding-left: 0.6em;
}
.original_ol_block ol li {
  line-height: 1.8;
  display: flex;
  font-size: 16px;
  font-weight: 500;
}
.original_ol_block ol li .num {
  display: block;
  width: 1.2em;
}
.original_ol_block ol li p {
  font-size: clamp(16px, 1.6vw, 18px);
  margin: 0;
  font-weight: 500;
  width: calc(100% - 1.2em);
}

.original_img_block {
  background: #fff;
  width: 100%;
  padding: 30px 0;
}
.original_img_block img {
  display: block;
  margin: 0 auto;
}

.original_link_block {
  margin: 30px 0;
}
@media (max-width: 700px) {
  .original_link_block {
    margin: 20px 0;
  }
}
.original_link_block p {
  display: flex;
  align-items: center;
  font-size: clamp(16px, 1.6vw, 18px);
}
.original_link_block a {
  position: relative;
  padding-right: 1em;
  display: inline-block;
  text-decoration: none !important;
}
.original_link_block a::before, .original_link_block a::after {
  content: "";
  position: absolute;
  margin: auto;
  transition: all 0.3s ease-in-out;
}
.original_link_block a::after {
  border-right: 1px solid #0f172a;
  border-bottom: 1px solid #0f172a;
  transform: rotate(-45deg);
  width: 0.6em;
  height: 0.6em;
  inset: 0 0 0 auto;
  z-index: 1;
}
.original_link_block a span {
  position: relative;
  line-height: 2.4;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.original_link_block a:hover span {
  text-decoration: none;
}

.original_button_link_block {
  margin: 60px 0;
}
@media (max-width: 700px) {
  .original_button_link_block {
    margin: 30px 0;
  }
}
.original_button_link_block a {
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: 600;
  background: #3957a6;
  display: block;
  max-width: 640px;
  width: 100%;
  padding: 27px 47px 27px 27px;
  position: relative;
  text-align: center;
  border-radius: 50px;
  color: #fff;
  margin: 0 auto;
}
.original_button_link_block a::before {
  position: absolute;
  content: "";
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transform: rotate(-45deg);
  width: 16px;
  height: 16px;
  margin: auto;
  inset: 0 40px 0 auto;
}
.original_button_link_block a:hover {
  background: #0f172a;
}

.original_button_link_small_block {
  margin: 60px 0;
}
@media (max-width: 700px) {
  .original_button_link_small_block {
    margin: 30px 0;
  }
}
.original_button_link_small_block a {
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 600;
  background: #3957a6;
  display: block;
  max-width: 320px;
  width: 100%;
  padding: 17px 37px 17px 17px;
  position: relative;
  text-align: center;
  border-radius: 50px;
  color: #fff;
  margin: 0 auto;
}
.original_button_link_small_block a::before {
  position: absolute;
  content: "";
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transform: rotate(-45deg);
  width: 16px;
  height: 16px;
  margin: auto;
  inset: 0 40px 0 auto;
}
.original_button_link_small_block a:hover {
  background: #0f172a;
}

.original_comment_block {
  padding: 35px 90px 40px;
  background: #f6f8fb;
}
@media (max-width: 700px) {
  .original_comment_block {
    padding: 15px;
  }
}
.original_comment_block .comment_block {
  padding: 0 80px;
  position: relative;
}
@media (max-width: 700px) {
  .original_comment_block .comment_block {
    padding: 0 40px;
  }
}
.original_comment_block .comment_block::before, .original_comment_block .comment_block::after {
  position: absolute;
  content: "";
  width: 41px;
  height: 36px;
  background: url("../../blocks/assets/img/comment.png") no-repeat center/contain;
}
@media (max-width: 700px) {
  .original_comment_block .comment_block::before, .original_comment_block .comment_block::after {
    width: 20px;
    height: 18px;
  }
}
.original_comment_block .comment_block::before {
  top: 0;
  left: 0;
}
.original_comment_block .comment_block::after {
  bottom: 0;
  right: 0;
  transform: rotate(180deg);
}
.original_comment_block .quote-text {
  font-size: clamp(16px, 1.6vw, 18px);
}
.original_comment_block .source-text {
  font-size: clamp(14px, 1.2vw, 16px);
  text-align: right;
}

/* 
.original_before_after_block {
  display: flex;
  gap: 40px;
  @include mq(sp) {
    flex-direction: column;
    gap: 20px;
  }
  img {
    margin-top: 30px;
    aspect-ratio: 688 / 458;
    object-fit: cover;
    @include mq(sp) {
      margin-top: 10px;
    }
  }
  .text {
    margin-top: 20px;
    font-weight: 500;
  }
  .before_box {
    width: 50%;
    padding: 30px;
    background: #efefef;
    @include mq(sp) {
      width: 100%;
      padding: 20px;
    }
    .before {
      text-align: center;
      font-size: 30px;
      font-weight: 700;
      line-height: 140%;
      @include mq(sp) {
        font-size: 24px;
      }
    }
  }
  .after_box {
    width: 50%;
    padding: 30px;
    background: #f6f8fb;
    @include mq(sp) {
      width: 100%;
      padding: 20px;
    }
    .after {
      text-align: center;
      font-size: 30px;
      font-weight: 700;
      line-height: 140%;
      color: #004488;
      @include mq(sp) {
        font-size: 24px;
      }
    }
  }
} */
/* 
.original_check_list_block {
  margin: 30px 0 0;
  &.pattern_01 {
    ul {
      border: 2px solid #244c9c;
    }
  }
  &.pattern_02 {
    ul {
      border: 2px solid #48a3c4;
      li {
        .check_mark {
          background: url('../../blocks/assets/img/blue_check_mark.png') no-repeat center / cover;
        }
      }
    }
  }
  &.pattern_03 {
    ul {
      border: 2px solid #ff4e0d;
    }
  }
  ul {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 40px;
    @include mq(sp) {
      padding: 20px;
    }
    li {
      display: flex;
      align-items: center;
      gap: 10px;
      width: 100%;
      position: relative;
      .check_mark {
        flex-shrink: 0;
        display: inline-block;
        width: 40px;
        height: 40px;
        background: url('../../blocks/assets/img/orange_check_mark.png') no-repeat center / cover;
        @include mq(tab) {
          width: 35px;
          height: 35px;
        }
        @include mq(sp) {
          width: 30px;
          height: 30px;
        }
      }
      p {
        width: 100%;
        color: #000;
        font-size: 24px;
        font-weight: 700;
        @include mq(tab) {
          font-size: 18px;
        }
        @include mq(sp) {
          font-size: 14px;
        }
      }
    }
  }
} */
/* 
.original_task_block {
  display: flex;
  align-items: center;
  gap: 2vw;
  @include mq(sp) {
    flex-direction: column;
  }
  img {
    width: calc(50% - 2vw);
    aspect-ratio: 536 / 370;
    object-fit: contain;
    @include mq(sp) {
      width: 100%;
    }
  }
  .text_container {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 50%;
    @include mq(sp) {
      width: 100%;
    }
    .text_box {
      padding: 30px;
      @include mq(sp) {
        padding: 20px;
      }
      .title {
        display: inline-block;
        width: 120px;
        margin-bottom: 10px;
        font-weight: 500;
        border-radius: 30px;
        text-align: center;
      }
      p {
        font-weight: 500;
      }
    }
    .purpose {
      background: #f6f8fb;
      span {
        border: 1px solid #004488;
        background: #fff;
        color: #004488;
      }
    }
    .discovery {
      background: #f6f8fb;
      span {
        background: #48a3c4;
        color: #fff;
      }
    }
    .result {
      background: #fff2ee;
      span {
        background: #ff4e0d;
        color: #fff;
      }
    }
  }
} */
/* 
.original_flow_block {
  display: flex;
  flex-wrap: wrap;
  gap: 54px;
  @include mq(sp) {
    justify-content: center;
  }
  .flow_box {
    position: relative;
    width: calc((100% - 54px * 4) / 5);
    border: 1px solid #244c9c;
    padding: 10px 10px 15px;
    @include mq(tab) {
      width: calc((100% - 54px) / 2);
      &:nth-of-type(2) {
        .flow_arrow {
          top: unset;
          right: unset;
          bottom: -47px;
          left: -47px;
          transform: rotate(135deg);
        }
      }
    }
    @include mq(sp) {
      width: 100%;
      max-width: 450px;
    }
    img {
      width: 100%;
      aspect-ratio: 228 / 177;
      object-fit: cover;
    }
    p {
      margin-top: 10px;
      padding: 0 10px;
      font-weight: 500;
    }
    .flow_arrow {
      position: absolute;
      top: 50%;
      right: -47px;
      transform: translateY(-50%);
      display: block;
      width: 40px;
      height: 40px;
      background: url('../../blocks/assets/img/blue_arrow.png') no-repeat center / cover;
      @include mq(sp) {
        top: unset;
        right: unset;
        left: 50%;
        bottom: -47px;
        transform: translateX(-50%) rotate(90deg);
      }
    }
  }
} */
/* .original_qanda_block {
  .qanda_box {
    margin-bottom: 30px;
    h3 {
      margin-bottom: 15px;
      padding: 7px 20px;
      background: #f6f8fb;
      font-size: 20px;
      font-weight: 700;
      color: #000;
      .q_mark {
        font-family: 'Roboto', sans-serif;
        color: #004488;
        font-size: 22px;
        font-weight: 500;
      }
    }
    p {
      font-weight: 500;
    }
  }
} */
/* 
.original_contents_block {
  .contents_box {
    display: flex;
    align-items: center;
    gap: 40px;
    padding: 50px 0;

    @include mq(sp) {
      flex-direction: column;
      gap: 20px;
    }

    &:nth-of-type(even) {
      @include mq(sp) {
        img {
          order: 1;
        }
        p {
          order: 2;
        }
      }
    }
    img {
      width: 50%;
      aspect-ratio: 748/500;
      object-fit: contain;
      background: #fff;
      @include mq(sp) {
        width: auto;
      }
    }
    p {
      width: 50%;
      font-weight: 500;
      @include mq(sp) {
        width: 100%;
      }
    }
  }
}

.original_contents_block_02 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  margin: 30px 0;
  @include mq(tab) {
    gap: 20px;
  }
  @include mq(sp) {
    gap: 10px;
    margin: 20px 0;
  }
  .contents {
    width: calc((100% - 40px) / 2);
    @include mq(tab) {
      width: calc((100% - 20px) / 2);
    }
    @include mq(sp) {
      width: 100%;
    }
    h3 {
      color: #000;
      text-align: center;
      font-size: 20px;
      font-weight: 700;
    }
    p {
      margin: 12px 0 20px;
      text-align: center;
      font-weight: 500;
    }
    img {
      width: 100%;
      aspect-ratio: 1/1;
      object-fit: contain;
      background: #fff;
    }
  }
} */
.original_contents_block_03 .contents_box {
  display: flex;
  align-items: center;
  gap: 60px;
  flex-direction: row-reverse;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .original_contents_block_03 .contents_box {
    gap: 30px;
  }
}
@media (max-width: 700px) {
  .original_contents_block_03 .contents_box {
    flex-direction: column;
    gap: 20px;
  }
}
@media (max-width: 700px) {
  .original_contents_block_03 .contents_box:nth-of-type(even) img {
    order: 1;
  }
  .original_contents_block_03 .contents_box:nth-of-type(even) p {
    order: 2;
  }
}
.original_contents_block_03 .contents_box img {
  width: 50%;
  object-fit: contain;
  background: #fff;
}
@media (max-width: 700px) {
  .original_contents_block_03 .contents_box img {
    width: auto;
  }
}
.original_contents_block_03 .contents_box div {
  width: 50%;
}
@media (max-width: 700px) {
  .original_contents_block_03 .contents_box div {
    width: 100%;
  }
}
.original_contents_block_03 .contents_box div h2 {
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
  color: #3957a6;
  line-height: 1.5;
  border: none;
  margin: 0 0 30px;
  padding: 0;
}
.original_contents_block_03 .contents_box div h2::before {
  display: none;
}
.original_contents_block_03 .contents_box div p {
  margin: 30px 0;
}
.original_contents_block_03 .contents_box div ul {
  margin: 30px 0;
}

.original_img_container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 2%;
}
.original_img_container:has(.img_box:only-of-type) .img_box {
  width: 100%;
}
.original_img_container:has(.img_box:nth-of-type(2)) .img_box {
  width: 49%;
}
@media (max-width: 900px) {
  .original_img_container:has(.img_box:nth-of-type(2)) .img_box {
    width: 100%;
  }
}
.original_img_container {
  /*   &:has(.img_box:nth-of-type(3)) {
    .img_box {
      width: 32%;
      @include mq(sp) {
        width: 100%;
      }
    }
  } */
}
.original_img_container .img_box {
  position: relative;
}
.original_img_container .img_box::before {
  position: absolute;
  content: "";
  border-right: 1px solid #0f172a;
  border-bottom: 1px solid #0f172a;
  transform: rotate(-45deg);
  width: 25px;
  height: 25px;
  margin: auto;
  inset: 0 40px 0 auto;
}
@media (max-width: 700px) {
  .original_img_container .img_box::before {
    width: 10px;
    height: 10px;
    inset: 0 10px 0 auto;
  }
}
.original_img_container .img_box:has(a) a {
  display: flex;
  justify-content: flex-start;
  border: 1px solid #cbd5e1;
  padding: 20px 10px;
  background: #fff;
}
@media (max-width: 700px) {
  .original_img_container .img_box:has(a) a {
    padding: 10px;
  }
}
.original_img_container .img_box:has(a) a:hover {
  background: #f1f5f9;
}
.original_img_container .img_box:not(:has(a)) > div {
  display: flex;
  justify-content: flex-start;
  border: 1px solid #cbd5e1;
  padding: 20px 10px;
}
@media (max-width: 700px) {
  .original_img_container .img_box:not(:has(a)) > div {
    padding: 10px;
  }
}
.original_img_container .img_box img {
  width: 100%;
  height: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  max-width: 180px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .original_img_container .img_box img {
    max-width: 120px;
  }
}
@media (max-width: 700px) {
  .original_img_container .img_box img {
    max-width: 90px;
  }
}
.original_img_container .img_box p {
  font-size: clamp(16px, 1.6vw, 18px);
  padding: 0 90px 0 15px;
  margin: 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .original_img_container .img_box p {
    padding: 0 50px 0 15px;
  }
}
@media (max-width: 700px) {
  .original_img_container .img_box p {
    padding: 0 10px 0 15px;
  }
}

.original_img_container_02 {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 2%;
}
.original_img_container_02:has(.img_box:only-of-type) .img_box {
  width: 100%;
}
.original_img_container_02:has(.img_box:nth-of-type(2)) .img_box {
  width: 49%;
}
@media (max-width: 700px) {
  .original_img_container_02:has(.img_box:nth-of-type(2)) .img_box {
    width: 100%;
  }
}
.original_img_container_02:has(.img_box:nth-of-type(3)) .img_box {
  width: 32%;
}
@media (max-width: 700px) {
  .original_img_container_02:has(.img_box:nth-of-type(3)) .img_box {
    width: 100%;
  }
}
.original_img_container_02 .img_box h3 {
  margin-bottom: 15px;
  color: #000;
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
}
.original_img_container_02 .img_box img {
  width: 100%;
  object-fit: contain;
}
.original_img_container_02 .img_box p {
  margin-top: 15px;
  font-weight: 500;
}

.original_table_01 {
  width: 100%;
  border-collapse: collapse;
}
.original_table_01 th {
  text-align: left;
  border-top: 1px solid #cad4dd;
  border-bottom: 1px solid #cad4dd;
  padding: 10px;
  background-color: #33475b;
  width: 31.25%;
  font-weight: 700;
  color: #fff;
}
@media (max-width: 700px) {
  .original_table_01 th {
    padding: 5px;
    font-size: 14px;
  }
}
.original_table_01 td {
  border-top: 1px solid #cad4dd;
  border-bottom: 1px solid #cad4dd;
  padding: 10px;
  font-weight: 500;
}
@media (max-width: 700px) {
  .original_table_01 td {
    padding: 5px;
    font-size: 14px;
  }
}

.original_table_02_wrapper {
  display: flex;
  gap: 5px;
}
@media (max-width: 700px) {
  .original_table_02_wrapper {
    flex-direction: column;
    gap: 20px;
  }
}
.original_table_02_wrapper .table_left,
.original_table_02_wrapper .table_right {
  width: 50%;
}
@media (max-width: 700px) {
  .original_table_02_wrapper .table_left,
  .original_table_02_wrapper .table_right {
    width: 100%;
  }
}
.original_table_02_wrapper .table_left .original_table_02,
.original_table_02_wrapper .table_right .original_table_02 {
  width: 100%;
  border-collapse: collapse;
}
.original_table_02_wrapper .table_left .original_table_02 th,
.original_table_02_wrapper .table_right .original_table_02 th {
  text-align: left;
  border-top: 1px solid #cad4dd;
  border-bottom: 1px solid #cad4dd;
  padding: 10px;
  background-color: #33475b;
  width: 38.3%;
  font-weight: 700;
  color: #fff;
}
@media (max-width: 700px) {
  .original_table_02_wrapper .table_left .original_table_02 th,
  .original_table_02_wrapper .table_right .original_table_02 th {
    width: 31.25%;
    padding: 5px;
    font-size: 14px;
  }
}
.original_table_02_wrapper .table_left .original_table_02 td,
.original_table_02_wrapper .table_right .original_table_02 td {
  border-top: 1px solid #cad4dd;
  border-bottom: 1px solid #cad4dd;
  padding: 10px;
  font-weight: 500;
}
@media (max-width: 700px) {
  .original_table_02_wrapper .table_left .original_table_02 td,
  .original_table_02_wrapper .table_right .original_table_02 td {
    padding: 5px;
    font-size: 14px;
  }
}

.original_table_03 {
  width: 100%;
  border-collapse: collapse;
}
.original_table_03 thead th {
  background-color: #33475b;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  padding: 15px;
  text-align: center;
  border-bottom: 1px solid #cad4dd;
}
.original_table_03 thead th:not(:last-child) {
  border-right: 1px solid #cad4dd;
}
.original_table_03 tbody th {
  background-color: #33475b;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  padding: 15px;
  text-align: center;
  border-bottom: 1px solid #cad4dd;
}
.original_table_03 tbody th:not(:last-child) {
  border-right: 1px solid #cad4dd;
}
.original_table_03 tbody td {
  background: #fff;
  font-size: 16px;
  padding: 15px;
  text-align: center;
  border-bottom: 1px solid #cad4dd;
}
.original_table_03 tbody td:not(:last-child) {
  border-right: 1px solid #cad4dd;
}
.original_table_03 tbody tr:nth-child(even) td {
  background-color: #f6f8fb;
}
.original_table_03 tbody td {
  vertical-align: middle;
}

.original_numberList_block ol {
  padding: 0;
  counter-reset: number-counter;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 700px) {
  .original_numberList_block ol {
    grid-template-columns: repeat(1, 1fr);
  }
}
.original_numberList_block ol li {
  position: relative;
  padding-left: 35px;
  text-indent: inherit;
  counter-increment: number-counter;
  display: flex;
  align-items: center;
}
.original_numberList_block ol li::before {
  content: counter(number-counter);
  position: absolute;
  margin: auto;
  inset: 0 auto 0 0;
  background: #004488;
  color: #fff;
  width: 28px;
  height: 28px;
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: 700;
  font-size: 18px;
  font-family: "Roboto", sans-serif;
}
@media (max-width: 700px) {
  .original_numberList_block ol li::before {
    width: 24px;
    height: 24px;
    font-size: 16px;
  }
}
.original_numberList_block ol li p {
  font-size: 16px;
  font-weight: bold;
}

.original_special_table {
  width: 100%;
  border-collapse: collapse;
}
.original_special_table th,
.original_special_table td {
  border: 1px solid #cad4dd;
  padding: 10px;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 500;
}
@media (max-width: 700px) {
  .original_special_table th,
  .original_special_table td {
    padding: 5px;
  }
}
.original_special_table thead th {
  background-color: #cbd5e1;
  color: #fff;
  font-weight: 600;
  vertical-align: middle;
}
.original_special_table thead th.bg-transparent {
  border: none;
}
.original_special_table tbody tr:nth-child(even) {
  background-color: #f6f8fb;
}
.original_special_table tbody td {
  vertical-align: middle;
}

.original_table_calendar {
  width: 100%;
  border-collapse: collapse;
}
.original_table_calendar thead th {
  background-color: #cbd5e1;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  padding: 15px;
  text-align: center;
  border-bottom: 1px solid #cad4dd;
}
.original_table_calendar thead th:not(:last-child) {
  border-right: 1px solid #cad4dd;
}
.original_table_calendar tbody td {
  background: #fff;
  font-size: 16px;
  padding: 15px 0;
  text-align: center;
  border-bottom: 1px solid #cad4dd;
}
.original_table_calendar tbody td:not(:last-child) {
  border-right: 1px solid #cad4dd;
}
.original_table_calendar tbody td.holiday {
  background: #3957a6;
  color: #fff;
}
.original_table_calendar tbody td.saturday {
  background: #3957a6;
  color: #fff;
}

.original_outline_block {
  background: #f1f5f9;
  padding: 40px;
}
@media (max-width: 700px) {
  .original_outline_block {
    padding: 20px;
  }
}
.original_outline_block .outline_title {
  font-size: clamp(20px, 2vw, 24px);
  font-weight: bold;
  border-bottom: 2px solid #3957a6;
  padding-bottom: 15px;
  margin: 0 0 15px;
}
.original_outline_block .outline_list .outline_item .outline_main {
  font-size: clamp(18px, 1.8vw, 20px);
  font-weight: bold;
  display: block;
  margin-bottom: 8px;
}
.original_outline_block .outline_list .outline_item .outline_main:hover {
  color: #3957a6;
}
.original_outline_block .outline_list .outline_item .outline_sub_list {
  list-style: none;
  padding-left: 20px;
  margin-top: 8px;
}
@media (max-width: 700px) {
  .original_outline_block .outline_list .outline_item .outline_sub_list {
    padding-left: 15px;
  }
}
.original_outline_block .outline_list .outline_item .outline_sub_list .outline_sub_item {
  margin-bottom: 5px;
  position: relative;
  padding-left: 15px;
}
.original_outline_block .outline_list .outline_item .outline_sub_list .outline_sub_item::before {
  content: "・";
  position: absolute;
  left: 0;
  color: #0f172a;
}
.original_outline_block .outline_list .outline_item .outline_sub_list .outline_sub_item a {
  font-size: 16px;
  font-weight: 400;
}
.original_outline_block .outline_list .outline_item .outline_sub_list .outline_sub_item a:hover {
  color: #3957a6;
}
.original_outline_block .outline_list .outline_item + .outline_item {
  margin-top: 10px;
}

.blocks_inner {
  margin-bottom: 120px;
  margin-top: 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .blocks_inner {
    margin-bottom: 80px;
    margin-top: 40px;
  }
}
@media (max-width: 700px) {
  .blocks_inner {
    margin-bottom: 40px;
    margin-top: 30px;
  }
}
.blocks_inner p {
  margin: 1em 0;
  font-size: clamp(16px, 1.6vw, 18px);
}
.blocks_inner p a {
  color: #3957a6;
  text-decoration: underline;
  text-underline-offset: 5px;
}
.blocks_inner p a:hover {
  text-decoration: none;
}
.blocks_inner > h2 {
  font-weight: bold;
  font-size: clamp(22px, 3vw, 40px);
  position: relative;
  line-height: 1.5;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 4px solid #cbd5e1;
  margin-top: 60px;
}
@media (max-width: 700px) {
  .blocks_inner > h2 {
    margin-top: 30px;
  }
}
.blocks_inner > h2::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 120px;
  height: 4px;
  margin: auto;
  bottom: -4px;
  left: 0;
  z-index: 1;
}
.blocks_inner > h2 strong {
  font-weight: 700;
}
.blocks_inner > h3 {
  font-size: clamp(20px, 2.4vw, 32px);
  position: relative;
  padding-left: 1.4em;
  margin-bottom: 20px;
  font-weight: 700;
}
.blocks_inner > h3::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 1em;
  height: 1em;
  margin: auto;
  inset: 0.3em auto auto 0;
}
.blocks_inner > h3 strong {
  font-weight: 700;
}
.blocks_inner > h4 {
  font-size: clamp(18px, 2vw, 28px);
  font-weight: bold;
  position: relative;
  padding-bottom: 0.6em;
  border-bottom: 1px solid #cbd5e1;
  margin-bottom: 20px;
}
.blocks_inner > h4 strong {
  font-weight: 700;
}
.blocks_inner > h5 {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: bold;
  margin-bottom: 30px;
}
.blocks_inner h1.wp-block-heading,
.blocks_inner h2.wp-block-heading {
  font-weight: bold;
  font-size: clamp(22px, 3vw, 40px);
  position: relative;
  line-height: 1.5;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 4px solid #cbd5e1;
  position: relative;
  margin-top: 60px;
}
@media (max-width: 700px) {
  .blocks_inner h1.wp-block-heading,
  .blocks_inner h2.wp-block-heading {
    margin-top: 30px;
  }
}
.blocks_inner h1.wp-block-heading strong,
.blocks_inner h2.wp-block-heading strong {
  font-weight: 700;
}
.blocks_inner h1.wp-block-heading::before,
.blocks_inner h2.wp-block-heading::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 120px;
  height: 4px;
  margin: auto;
  bottom: -4px;
  left: 0;
}
.blocks_inner h3.wp-block-heading {
  font-size: clamp(20px, 2.4vw, 32px);
  position: relative;
  padding-left: 1.4em;
  margin-bottom: 20px;
  font-weight: 700;
}
.blocks_inner h3.wp-block-heading strong {
  font-weight: 700;
}
.blocks_inner h3.wp-block-heading::before {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 1em;
  height: 1em;
  margin: auto;
  inset: 0.3em auto auto 0;
}
.blocks_inner h4.wp-block-heading {
  font-size: clamp(18px, 2vw, 28px);
  font-weight: bold;
  position: relative;
  padding-bottom: 0.6em;
  border-bottom: 1px solid #cbd5e1;
  margin-bottom: 20px;
}
.blocks_inner h4.wp-block-heading strong {
  font-weight: 700;
}
.blocks_inner h5.wp-block-heading,
.blocks_inner h6.wp-block-heading {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: bold;
  margin-bottom: 30px;
}
.blocks_inner h5.wp-block-heading strong,
.blocks_inner h6.wp-block-heading strong {
  font-weight: 700;
}
.blocks_inner * + h1.wp-block-heading, .blocks_inner * + h2.wp-block-heading, .blocks_inner * + h3.wp-block-heading {
  margin-top: 80px;
}
@media (max-width: 700px) {
  .blocks_inner * + h1.wp-block-heading, .blocks_inner * + h2.wp-block-heading, .blocks_inner * + h3.wp-block-heading {
    margin-top: 40px;
  }
}
.blocks_inner * + h4.wp-block-heading, .blocks_inner * + h5.wp-block-heading, .blocks_inner * + h6.wp-block-heading {
  margin-top: 40px;
}
@media (max-width: 700px) {
  .blocks_inner * + h4.wp-block-heading, .blocks_inner * + h5.wp-block-heading, .blocks_inner * + h6.wp-block-heading {
    margin-top: 20px;
  }
}
.blocks_inner ul.wp-block-list {
  padding-left: 1.5rem;
  margin-bottom: 30px;
}
.blocks_inner ul.wp-block-list li {
  list-style: disc;
}
.blocks_inner ol.wp-block-list {
  padding-left: 1.5rem;
  margin-bottom: 30px;
}
.blocks_inner ol.wp-block-list li {
  list-style: decimal;
}
.blocks_inner .wp-block-table .has-fixed-layout {
  max-width: 100%;
  border-top: 1px dotted #e5e5e5;
  border-spacing: 1px;
  border-collapse: inherit;
  margin: 10px -1px 24px 0;
  text-align: left;
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 85.7%;
  font-size: 18px;
  line-height: 141.7%;
}
.blocks_inner .wp-block-table .has-fixed-layout thead th {
  font-weight: bold;
  padding: 9px 24px;
  background: #3957a6;
  color: #fff;
  white-space: nowrap;
}
.blocks_inner .wp-block-table .has-fixed-layout tbody td {
  border: 1px solid #e5e5e5;
  padding: 10px 10px;
  vertical-align: top;
  font-weight: 500;
}
.blocks_inner .wp-block-table .has-fixed-layout tbody td strong {
  font-weight: bold;
}
.blocks_inner .wp-block-list {
  margin-left: 1em;
}
.blocks_inner .wp-block-list li {
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 500;
}
.blocks_inner .wp-block-list li::marker {
  color: #3957a6;
}
.blocks_inner .simpletoc-title {
  font-size: clamp(20px, 2vw, 24px);
  font-weight: bold;
  border-bottom: 2px solid #3957a6;
  padding-bottom: 15px;
  margin: 0;
  background: #f1f5f9;
  padding: 30px;
}
.blocks_inner .simpletoc-list {
  background: #f1f5f9;
  padding: 30px;
}
.blocks_inner .simpletoc-list li {
  font-size: clamp(18px, 1.8vw, 20px);
  display: block;
  margin-bottom: 8px;
  font-weight: bold;
}
.blocks_inner .simpletoc-list li a:hover {
  color: #3957a6;
}
.blocks_inner .simpletoc-list li > ul {
  margin: 1em 0 0 2em;
}
.blocks_inner .simpletoc-list li > ul li {
  padding-left: 1em;
  position: relative;
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: 400;
}
.blocks_inner .simpletoc-list li > ul li::before {
  content: "";
  position: absolute;
  margin: auto;
  width: 10px;
  height: 10px;
  background: #3957a6;
  inset: 10px auto auto 0;
}
.blocks_inner .wp-block-embed .wp-embedded-content {
  width: 700px;
  margin: 0 auto;
  display: block;
}
@media (max-width: 700px) {
  .blocks_inner .wp-block-embed .wp-embedded-content {
    width: 100%;
  }
}
.blocks_inner .wp-block-embed + .wp-block-embed {
  margin-top: 30px;
}

.accordion_ttl {
  cursor: pointer;
  position: relative;
}
.accordion_ttl::before, .accordion_ttl::after {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 18px;
  height: 2px;
  margin: auto;
  inset: 0 20px 0 auto;
  transition: transform 0.3s ease;
}
.accordion_ttl::after {
  transform: rotate(90deg);
}
.accordion_ttl.on::after {
  transform: rotate(0deg);
}

.common_contact {
  background: #0f172a;
  padding: 110px 0 100px;
  position: relative;
}
@media (max-width: 700px) {
  .common_contact {
    padding: 50px 0;
  }
}
.common_contact::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  width: 49%;
  height: 100%;
  background: url("../img/common/bg_contactus@2x.webp") no-repeat center center/cover;
}
@media (max-width: 700px) {
  .common_contact::before {
    width: 100%;
  }
}
.common_contact::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: rgba(15, 23, 42, 0.6);
}
.common_contact .sec_inner {
  position: relative;
  z-index: 2;
}
.common_contact .common_contact_catch {
  color: #fff;
  font-size: clamp(24px, 2.4vw, 30px);
  font-weight: 600;
  margin-bottom: 30px;
}
@media (max-width: 700px) {
  .common_contact .common_contact_catch {
    text-align: center;
  }
}
.common_contact .common_contact_catch strong {
  display: block;
  font-size: clamp(34px, 4vw, 48px);
  font-weight: 600;
}
.common_contact .common_contact_catch strong span {
  font-size: 116%;
}
.common_contact .tel_area {
  margin-bottom: 40px;
}
@media (max-width: 700px) {
  .common_contact .tel_area {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
.common_contact .tel_area .txt_area {
  padding-left: 40px;
}
@media (min-width: 701px) {
  .common_contact .tel_area .txt_area {
    padding-left: 80px;
    display: flex;
    align-items: center;
    gap: 29px;
  }
}
.common_contact .tel_area .txt_area .txt {
  font-size: clamp(16px, 2vw, 20px);
  color: #fff;
}
.common_contact .tel_area .tel_number {
  position: relative;
  padding-left: 80px;
  color: #fff;
  font-size: clamp(34px, 4vw, 80px);
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 1;
}
@media (max-width: 700px) {
  .common_contact .tel_area .tel_number {
    padding-left: 40px;
    font-size: min(40px, 12vw);
  }
}
.common_contact .tel_area .tel_number::before {
  content: "";
  position: absolute;
  margin: auto;
  inset: 0 auto 0 0;
  width: 64px;
  height: 64px;
  background: url("../img/icon/icon_phone.svg") no-repeat center center/contain;
  filter: brightness(0) invert(1);
}
@media (max-width: 700px) {
  .common_contact .tel_area .tel_number::before {
    width: 32px;
    height: 32px;
  }
}
.common_contact .btn_area {
  display: flex;
  gap: 30px;
}
@media (max-width: 700px) {
  .common_contact .btn_area {
    flex-direction: column;
    gap: 15px;
  }
}
.common_contact .btn_area .border_btn {
  border-radius: 200px;
  border: 2px solid #fff;
  color: #fff;
  font-weight: 700;
  font-size: clamp(16px, 1.8vw, 24px);
  position: relative;
  text-align: center;
  padding: 0 0 0 100px;
  width: 480px;
  line-height: 113px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_contact .btn_area .border_btn {
    line-height: 93px;
    padding: 0 0 0 50px;
  }
}
@media (max-width: 700px) {
  .common_contact .btn_area .border_btn {
    width: 100%;
    padding: 0 0 0 30px;
    line-height: 70px;
  }
}
.common_contact .btn_area .border_btn::before {
  content: "";
  position: absolute;
  margin: auto;
  inset: 0 auto 0 20px;
  width: 80px;
  height: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_contact .btn_area .border_btn::before {
    width: 60px;
    height: 60px;
  }
}
@media (max-width: 700px) {
  .common_contact .btn_area .border_btn::before {
    width: 50px;
    height: 50px;
    inset: 0 auto 0 10px;
  }
}
.common_contact .btn_area .border_btn.line {
  background: #4cc764;
  letter-spacing: -0.01em;
}
.common_contact .btn_area .border_btn.line::before {
  background: url("../img/icon/icon_line.svg") no-repeat center center/contain;
}
.common_contact .btn_area .border_btn.line:hover {
  filter: brightness(1.07);
}
.common_contact .btn_area .border_btn.mail {
  background: #f97316;
}
.common_contact .btn_area .border_btn.mail::before {
  background: url("../img/icon/icon_mail.svg") no-repeat center center/contain;
}
.common_contact .btn_area .border_btn.mail:hover {
  background: #d75800;
}
.common_contact .btn_area .border_btn strong {
  font-size: 133%;
}

.info_item {
  background: #fff;
  border-radius: 20px;
  border: 10px solid #cbd5e1;
  height: 100%;
  transition: 0.5s ease-in-out;
  padding-bottom: 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item {
    border-width: 8px;
  }
}
@media (max-width: 700px) {
  .info_item {
    border-width: 6px;
  }
}
.info_item a:not(.txt_link):not(.cat_link):not(.connection_link) {
  display: block;
  width: 100%;
  padding: 10px 30px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item a:not(.txt_link):not(.cat_link):not(.connection_link) {
    padding: 10px 20px 0;
  }
}
@media (max-width: 700px) {
  .info_item a:not(.txt_link):not(.cat_link):not(.connection_link) {
    padding: 10px 4vw 0;
  }
}
.info_item a:not(.txt_link):not(.cat_link):not(.connection_link):hover {
  color: #3957a6;
}
.info_item a:not(.txt_link):not(.cat_link):not(.connection_link):hover .detail {
  background: #cbd5e1;
}
.info_item a:not(.txt_link):not(.cat_link):not(.connection_link):hover .detail .info_detail02 span {
  background: #ccc;
}
.info_item a.txt_link {
  margin-top: 10px;
  display: block;
  text-align: right;
  padding: 0 30px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item a.txt_link {
    padding: 0 20px;
  }
}
@media (max-width: 700px) {
  .info_item a.txt_link {
    padding: 0 4vw;
  }
}
.info_item a.cat_link:hover {
  color: #3957a6;
}
.info_item figure {
  width: 120px;
  height: 120px;
  margin: 0 auto 30px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item figure {
    width: 80px;
    height: 80px;
    margin: 0 auto 20px;
  }
}
@media (max-width: 700px) {
  .info_item figure {
    width: 60px;
    height: 60px;
    margin: 0 auto 10px;
  }
}
.info_item figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.info_item time {
  font-size: clamp(14px, 1.6vw, 18px);
  margin-bottom: 10px;
  display: block;
}
.info_item .ttl {
  font-weight: 600;
  font-size: clamp(20px, 2vw, 24px);
}
.info_item .detail {
  background: #f1f5f9;
  padding: 30px 20px 20px;
  position: relative;
  margin: 60px 0 15px;
  transition: 0.3s ease-in-out;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item .detail {
    padding: 30px 15px 20px;
    margin: 30px 0 15px;
  }
}
@media (max-width: 700px) {
  .info_item .detail {
    margin: 30px 0 5px;
    padding: 20px 4vw;
  }
}
.info_item .detail::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 40px;
  margin: auto;
  inset: -20px 0 auto 0;
  background: #0f172a;
}
.info_item .detail dl {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  align-items: baseline;
}
@media (max-width: 1440px) {
  .info_item .detail dl {
    gap: 8px;
  }
}
.info_item .detail dl dt {
  background: #0f172a;
  color: #fff;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 20px);
  width: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item .detail dl dt {
    width: 66px;
  }
}
@media (max-width: 700px) {
  .info_item .detail dl dt {
    width: 60px;
  }
}
.info_item .detail dl dd {
  font-size: clamp(16px, 1.8vw, 20px);
  color: #3957a6;
  width: calc(100% - 95px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item .detail dl dd {
    width: calc(100% - 74px);
  }
}
@media (max-width: 700px) {
  .info_item .detail dl dd {
    width: calc(100% - 68px);
    line-height: 24px;
  }
}
.info_item .detail dl .info_detail02 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  margin-top: 3px;
  font-size: clamp(16px, 1.6vw, 18px);
}
.info_item .detail dl .info_detail02 span {
  color: #3957a6;
  background: #d9d9d9;
  padding: 5px 10px;
  line-height: 1;
  color: #0f172a;
  transition: 0.3s ease-in-out;
}
.info_item .tag {
  display: flex;
  flex-wrap: wrap;
  gap: 0 10px;
  padding: 0 30px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .info_item .tag {
    padding: 0 20px;
  }
}
@media (max-width: 700px) {
  .info_item .tag {
    padding: 0 4vw;
  }
}

.blog_item {
  box-shadow: 3px 3px 5px 0 rgba(15, 23, 42, 0.1);
  background: #fff;
  border: 1px solid #cbd5e1;
}
.blog_item:has(.blog_item_link:hover) {
  background: rgba(241, 245, 249, 0.3);
}
.blog_item:not(:has(.tag > a)) .blog_item_link {
  height: 100%;
}
.blog_item a.blog_item_link {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  padding: 20px;
  width: 100%;
}
.blog_item a.blog_item_link:hover {
  color: #3957a6;
}
.blog_item a.new {
  position: relative;
}
.blog_item a.new::before {
  content: "NEW";
  position: absolute;
  top: 2px;
  left: 2px;
  background: #0f172a;
  color: #fff;
  font-size: clamp(14px, 1.2vw, 18px);
  padding: 0;
  text-align: center;
  width: 80px;
  line-height: 30px;
}
@media (max-width: 700px) {
  .blog_item a.new::before {
    width: 60px;
    line-height: 20px;
    top: -4px;
    left: -4px;
  }
}
.blog_item figure {
  aspect-ratio: 3/2;
  width: 40%;
}
.blog_item figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.blog_item .txt_area {
  width: 57%;
}
.blog_item .news_date {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
@media (max-width: 700px) {
  .blog_item .news_date {
    gap: 7px;
  }
}
.blog_item .news_date time {
  font-size: clamp(14px, 1.6vw, 16px);
  margin-right: 12px;
}
@media (max-width: 700px) {
  .blog_item .news_date time {
    margin-right: 8px;
  }
}
.blog_item .news_date span {
  font-size: clamp(14px, 1.6vw, 16px);
  background: #cbd5e1;
  padding: 2px 15px;
}
@media (max-width: 700px) {
  .blog_item .news_date span {
    padding: 2px 8px;
  }
}
.blog_item .ttl {
  text-decoration: underline;
  font-size: clamp(16px, 1.6vw, 24px);
  text-underline-offset: 3px;
  font-weight: 600;
}
.blog_item .tag {
  width: 100%;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 0 20px 20px;
}
@media (max-width: 700px) {
  .blog_item .tag {
    gap: 7px;
  }
}
.blog_item .tag a {
  font-size: clamp(14px, 1.6vw, 16px);
  background: #cbd5e1;
  padding: 0 6px;
}
.blog_item .tag a:hover {
  color: #3957a6;
  background: #f1f5f9;
}

.line_mail_btns {
  margin: 12px 0 0;
  display: flex;
  justify-content: space-between;
}
.line_mail_btns > * {
  width: 49%;
}
.line_mail_btns a {
  display: block;
  line-height: 32px;
  border-radius: 200px;
  text-align: center;
  font-weight: bold;
  font-size: 15px;
  position: relative;
  border: 1px solid #fff;
}
.line_mail_btns a::before {
  position: absolute;
  content: "";
  width: 24px;
  height: 24px;
  margin: auto;
  inset: 0 auto 0 4px;
}
.line_mail_btns a.line {
  background: #4cc764;
  color: #fff;
}
.line_mail_btns a.line::before {
  background: url("../img/icon/icon_line.svg") no-repeat center center/contain;
}
.line_mail_btns a.line:hover {
  filter: brightness(1.07);
}
.line_mail_btns a.mail {
  background: #fff;
  color: #f97316;
}
.line_mail_btns a.mail::before {
  background: url("../img/icon/icon_mail_orange.svg") no-repeat center center/contain;
}

.aside_info {
  width: 22%;
  max-width: 360px;
  border-radius: 10px;
  background: #f1f5f9;
  padding: 0;
  margin-bottom: 30px;
}
@media (max-width: 900px) {
  .aside_info {
    width: 100%;
    max-width: inherit;
    margin-bottom: 0;
    border-radius: 10px;
  }
}
@media (max-width: 900px) {
  .aside_info .aside_inner {
    display: none;
  }
}
.aside_info .info_side_ttl {
  border-radius: 10px 10px 0 0;
  background: #3957a6;
  color: #fff;
  padding: 16px 0 16px 38px;
  font-weight: bold;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .aside_info .info_side_ttl {
    padding: 16px 0;
    text-align: center;
  }
}
@media (max-width: 900px) {
  .aside_info .info_side_ttl {
    text-align: center;
    padding: 15px 0;
    border-radius: 10px;
    position: relative;
  }
  .aside_info .info_side_ttl::before, .aside_info .info_side_ttl::after {
    position: absolute;
    content: "";
    background: #fff;
    width: 20px;
    height: 2px;
    margin: auto;
    inset: 0 20px 0 auto;
    transition: 0.3s all;
  }
  .aside_info .info_side_ttl::after {
    transform: rotate(90deg);
  }
}
@media (max-width: 900px) {
  .aside_info .info_side_ttl.open {
    border-radius: 10px 10px 0 0;
  }
  .aside_info .info_side_ttl.open::after {
    transform: rotate(0deg);
  }
}
.aside_info .info_cat {
  padding: 0 20px;
}
@media (max-width: 900px) {
  .aside_info .info_cat {
    padding: 0 15px;
  }
}
.aside_info .info_cat:has(.info_child) {
  padding-bottom: 24px;
}
@media (max-width: 900px) {
  .aside_info .info_cat:has(.info_child) {
    padding-bottom: 0;
  }
}
.aside_info .info_cat:not(:last-child) {
  position: relative;
}
.aside_info .info_cat:not(:last-child)::before {
  position: absolute;
  content: "";
  background: #cbd5e1;
  width: 90%;
  height: 1px;
  bottom: 0;
  left: 5%;
}
.aside_info .info_cat .info_parent {
  display: block;
  font-weight: bold;
  letter-spacing: 0.1em;
  padding: 10px;
  font-size: clamp(16px, 1.6vw, 20px);
}
@media (max-width: 900px) {
  .aside_info .info_cat .info_parent {
    position: relative;
  }
  .aside_info .info_cat .info_parent::before {
    position: absolute;
    content: "";
    border-right: 1.5px solid #0f172a;
    border-bottom: 1.5px solid #0f172a;
    transform: rotate(45deg);
    width: 12px;
    height: 12px;
    margin: auto;
    inset: 0 10px 0 auto;
    transition: 0.3s all;
  }
}
.aside_info .info_cat .info_parent.on {
  color: #3957a6;
}
@media (max-width: 900px) {
  .aside_info .info_cat .info_parent.on::before {
    transform: rotate(-135deg);
    inset: 5px 10px 0 auto;
  }
}
.aside_info .info_cat .info_child {
  background: #fff;
  padding: 0 20px;
}
@media (max-width: 900px) {
  .aside_info .info_cat .info_child {
    display: none;
  }
}
.aside_info .info_cat .info_child .info_child_item:not(:last-child) {
  border-bottom: 1px solid #cbd5e1;
}
.aside_info .info_cat .info_child .info_child_item a {
  display: block;
  padding: 10px 0;
  letter-spacing: 0.1em;
}
.aside_info .info_cat .info_child .info_child_item a:hover {
  color: #3957a6;
}
.aside_info .align_right {
  display: block;
  margin: 15px 20px 15px auto;
}

.archive_block {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media (max-width: 900px) {
  .archive_block {
    flex-direction: column-reverse;
    gap: 30px;
    margin-bottom: 30px;
  }
}
.archive_block .archive_article {
  width: 76%;
}
@media (max-width: 900px) {
  .archive_block .archive_article {
    width: 100%;
  }
}
.archive_block .archive_article .archive_inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .archive_block .archive_article .archive_inner {
    gap: 20px;
  }
}
@media (max-width: 700px) {
  .archive_block .archive_article .archive_inner {
    grid-template-columns: 1fr;
  }
}

.deco {
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.deco::after {
  content: "";
  position: absolute;
  top: 0;
  width: 677px;
  height: 640px;
  background: url("../img/common/section_deco.svg") no-repeat center center/contain;
  z-index: -1;
  pointer-events: none;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .deco::after {
    width: 400px;
    height: 380px;
  }
}
@media (max-width: 700px) {
  .deco::after {
    width: 60vw;
    height: 56vw;
  }
}
.deco.deco_left::after {
  left: -80px;
}
@media (max-width: 700px) {
  .deco.deco_left::after {
    left: -2vw;
  }
}
.deco.deco_right::after {
  right: -80px;
}
@media (max-width: 700px) {
  .deco.deco_right::after {
    right: -2vw;
  }
}
.deco .sec_inner {
  position: relative;
  z-index: 1;
}

.common_consultation {
  border-radius: 10px;
  max-width: 1200px;
  margin: 0 auto;
  box-shadow: 3px 3px 7px 0 rgba(0, 0, 0, 0.15);
}
.common_consultation .common_consultation_head {
  border-radius: 10px 10px 0 0;
  background: #3957a6;
  padding: 15px 20px;
}
@media (min-width: 701px) {
  .common_consultation .common_consultation_head {
    display: flex;
    align-items: center;
    gap: 70px;
    padding: 20px 60px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_consultation .common_consultation_head {
    padding: 15px 30px;
    gap: 20px;
  }
}
.common_consultation .common_consultation_head .free {
  background: #ffd52b;
  padding: 0 38px;
  text-align: center;
  border-radius: 50px;
  font-size: clamp(16px, 2vw, 26px);
  font-weight: bold;
  line-height: 60px;
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_head .free {
    line-height: 28px;
    padding: 0;
  }
}
.common_consultation .common_consultation_head .head_ttl {
  font-size: clamp(18px, 2.4vw, 32px);
  font-weight: bold;
  text-align: center;
  color: #fff;
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_head .head_ttl {
    margin-top: 15px;
    font-size: min(28px, 5vw);
  }
}
.common_consultation .common_consultation_body {
  background: #fff;
  border-radius: 0 0 10px 10px;
  padding: 15px;
  box-shadow: 3px 3px 7px 0 rgba(0, 0, 0, 0.15);
}
@media (min-width: 701px) {
  .common_consultation .common_consultation_body {
    display: flex;
    gap: 0 15px;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 35px min(70px, 3.6vw) 55px;
    align-items: center;
  }
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body {
    gap: 0;
  }
}
.common_consultation .common_consultation_body .center {
  text-align: center;
  margin-bottom: 30px;
  font-size: clamp(18px, 2vw, 26px);
  width: 100%;
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .center {
    margin-bottom: 20px;
  }
}
.common_consultation .common_consultation_body .center mark {
  background: linear-gradient(transparent 70%, rgba(255, 213, 43, 0.5) 30%);
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .info {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_consultation .common_consultation_body .info {
    width: 45%;
  }
}
@media (min-width: 1441px) {
  .common_consultation .common_consultation_body .info {
    width: 40%;
  }
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .info .info_in {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
.common_consultation .common_consultation_body .info .line {
  position: relative;
  padding-left: 56px;
  font-weight: bold;
  font-size: clamp(16px, 1.9vw, 22px);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
}
@media (min-width: 901px) and (max-width: 1440px) {
  .common_consultation .common_consultation_body .info .line {
    padding-left: 56px;
    margin-bottom: 10px;
  }
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body .info .line {
    padding-left: 44px;
    margin-bottom: 10px;
  }
}
.common_consultation .common_consultation_body .info .line::before {
  content: "";
  position: absolute;
  background: url("../img/icon/icon_line.svg") no-repeat center center/contain;
  width: 50px;
  height: 50px;
  inset: 0 auto 0 0;
  margin: auto;
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body .info .line::before {
    width: 34px;
    height: 34px;
    inset: 0 auto 0 0;
  }
}
.common_consultation .common_consultation_body .info .line span {
  color: #4cc764;
  font-size: clamp(18px, 2.4vw, 32px);
}
.common_consultation .common_consultation_body .info .tel {
  position: relative;
  padding-left: 56px;
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body .info .tel {
    padding-left: 44px;
    margin-bottom: 10px;
  }
}
.common_consultation .common_consultation_body .info .tel::before {
  content: "";
  position: absolute;
  background: url("../img/icon/icon_phone.svg") no-repeat center center/contain;
  width: 50px;
  height: 50px;
  inset: auto auto 0 0;
  margin: auto;
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body .info .tel::before {
    width: 30px;
    height: 30px;
    inset: auto auto 4px 0;
  }
}
.common_consultation .common_consultation_body .info .tel span {
  display: block;
  font-size: clamp(14px, 1.4vw, 18px);
}
.common_consultation .common_consultation_body .info .tel a {
  font-family: "Roboto", sans-serif;
  font-weight: bold;
  font-size: clamp(20px, 3vw, 50px);
  line-height: 1;
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .info .tel a {
    font-size: min(40px, 12vw);
  }
}
.common_consultation .common_consultation_body .grade_btn {
  display: block;
  background: linear-gradient(180deg, #f97316 25.96%, #d32c00 100%);
  text-align: center;
  color: #fff;
  padding: 16px 0;
  transition: 0.3s ease-in-out;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_consultation .common_consultation_body .grade_btn {
    width: calc(55% - 15px);
  }
}
@media (min-width: 1441px) {
  .common_consultation .common_consultation_body .grade_btn {
    width: calc(60% - 15px);
    padding: 40px 0;
  }
}
@media (max-width: 900px) {
  .common_consultation .common_consultation_body .grade_btn {
    width: 55%;
  }
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .grade_btn {
    width: 100%;
  }
}
.common_consultation .common_consultation_body .grade_btn .icon {
  position: relative;
  display: inline-block;
}
.common_consultation .common_consultation_body .grade_btn .icon::before {
  content: "";
  position: absolute;
  background: url("../img/icon/icon_mail.svg") no-repeat center center/contain;
  width: 80px;
  height: 80px;
  inset: 0 auto 0 5px;
  margin: auto;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_consultation .common_consultation_body .grade_btn .icon::before {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .grade_btn .icon::before {
    width: 60px;
    height: 60px;
  }
}
.common_consultation .common_consultation_body .grade_btn p {
  padding-left: 90px;
  font-size: clamp(16px, 2vw, 24px);
  font-weight: bold;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .common_consultation .common_consultation_body .grade_btn p {
    padding-left: 70px;
  }
}
@media (max-width: 700px) {
  .common_consultation .common_consultation_body .grade_btn p {
    padding-left: 80px;
  }
}
.common_consultation .common_consultation_body .grade_btn span {
  display: block;
  font-weight: 400;
  font-size: clamp(16px, 1.6vw, 20px);
}
.common_consultation .common_consultation_body .grade_btn:hover {
  opacity: 0.8;
}

.sec_recommend {
  padding: 110px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_recommend {
    padding: 60px 0;
  }
}
@media (max-width: 700px) {
  .sec_recommend {
    padding: 40px 0;
  }
}
.sec_recommend .blog_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_recommend .blog_list {
    gap: 20px;
  }
}
@media (max-width: 700px) {
  .sec_recommend .blog_list {
    grid-template-columns: 1fr;
  }
}

.sec_search {
  padding: 110px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_search {
    padding: 60px 0;
  }
}
@media (max-width: 700px) {
  .sec_search {
    padding: 40px 0;
  }
}
.sec_search .search_head {
  background: #3957a6;
  color: #fff;
  font-size: clamp(20px, 3vw, 32px);
  text-align: center;
  font-weight: bold;
  padding: 15px;
  border-radius: 10px 10px 0 0;
  letter-spacing: 0.1em;
  font-weight: bold;
}
@media (max-width: 700px) {
  .sec_search .search_head {
    padding: 8px;
  }
}
.sec_search .search_body {
  background: #f1f5f9;
  border-radius: 0 0 10px 10px;
  padding: 40px 70px 60px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_search .search_body {
    padding: 30px;
  }
}
@media (max-width: 700px) {
  .sec_search .search_body {
    padding: 20px min(20px, 4vw) 40px;
  }
}
.sec_search .search_body .search_block > div + div {
  margin-top: 40px;
}
@media (max-width: 700px) {
  .sec_search .search_body .search_block > div + div {
    margin-top: 20px;
  }
}
.sec_search .search_body .search_block dt {
  font-size: clamp(16px, 2vw, 24px);
  font-weight: bold;
  letter-spacing: 0.1em;
}
.sec_search .search_body .search_block dd {
  padding: 15px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.sec_search .search_body .search_block dd .checkbox-item > input {
  display: none;
}
.sec_search .search_body .search_block dd .checkbox-item.is-checked span {
  background: #cbd5e1;
  border-color: #cbd5e1;
}
.sec_search .search_body .search_block dd span {
  background: #fff;
  border-radius: 5px;
  padding: 12px 20px;
  cursor: pointer;
  display: inline-block;
  transition: all 0.3s ease;
  border: 1px solid #cbd5e1;
  font-size: clamp(16px, 1.6vw, 18px);
  letter-spacing: 0.1em;
}
@media (max-width: 700px) {
  .sec_search .search_body .search_block dd span {
    padding: 5px 10px;
  }
}
.sec_search .search_body .search_block dd span.active {
  background: #000;
  color: #fff;
}
.sec_search .search_body .search_block dd span:hover {
  opacity: 0.7;
}
.sec_search .search_body .common_btn {
  cursor: pointer;
}

.sec_connection {
  padding: 110px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_connection {
    padding: 60px 0;
  }
}
@media (max-width: 700px) {
  .sec_connection {
    padding: 40px 0;
  }
}
.sec_connection .connection_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_connection .connection_list {
    gap: 25px;
  }
}
@media (max-width: 700px) {
  .sec_connection .connection_list {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.sec_connection .info_item {
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0;
  height: 100%;
  width: 100%;
  padding: 0;
  position: relative;
}
@media (max-width: 900px) {
  .sec_connection .info_item {
    padding: 15px;
    gap: 10px;
    flex-direction: column;
  }
}
.sec_connection .info_item::before {
  position: absolute;
  content: "";
  border-right: 1.5px solid #0f172a;
  border-bottom: 1.5px solid #0f172a;
  transform: rotate(-45deg);
  width: 26px;
  height: 26px;
  margin: auto;
  inset: 0 20px 0 auto;
  pointer-events: none;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_connection .info_item::before {
    inset: 0 10px 0 auto;
  }
}
@media (max-width: 900px) {
  .sec_connection .info_item::before {
    display: none;
  }
}
.sec_connection .info_item .common_thumb {
  min-width: 120px;
  margin: 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_connection .info_item .common_thumb {
    min-width: 80px;
  }
}
@media (max-width: 900px) {
  .sec_connection .info_item .common_thumb {
    min-width: 60px;
  }
}
.sec_connection .info_item .ttl {
  font-size: clamp(16px, 1.8vw, 20px);
}
.sec_connection .info_item .tag {
  justify-content: flex-end;
  margin: 0 20px 10px auto;
}
@media (max-width: 900px) {
  .sec_connection .info_item .tag {
    margin: 10px 0 0 auto;
    padding: 0;
  }
}
.sec_connection .connection_link {
  padding: 20px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_connection .connection_link {
    padding: 10px;
  }
}
@media (max-width: 900px) {
  .sec_connection .connection_link {
    padding: 0;
  }
}
.sec_connection .connection_link:hover {
  color: #3957a6;
}
.sec_connection .connection_item > .connection_link {
  display: block;
  padding-right: 40px;
}
@media (max-width: 900px) {
  .sec_connection .connection_item > .connection_link {
    padding: 0;
  }
}
.sec_connection .info_item .connection_link:has(.common_thumb):hover ~ .connection_item .ttl {
  color: #3957a6;
}

.sec_voice {
  padding: 105px 0 120px;
  position: relative;
  background: #cbd5e1;
}
.sec_voice::before, .sec_voice::after {
  content: "";
  position: absolute;
  width: 18%;
  height: 100%;
  max-width: 320px;
  max-height: 480px;
  z-index: 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_voice::before, .sec_voice::after {
    width: 200px;
    height: 300px;
  }
}
@media (max-width: 700px) {
  .sec_voice::before, .sec_voice::after {
    width: 30vw;
    height: 40vw;
  }
}
.sec_voice::before {
  background: url("../img/top/voice_smartphone@2x.webp") no-repeat center center/contain;
  top: -80px;
  right: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_voice::before {
    left: inherit;
    right: 0;
  }
}
@media (max-width: 700px) {
  .sec_voice::before {
    right: 10px;
    top: -40px;
  }
}
.sec_voice::after {
  background: url("../img/top/voice_notepc@2x.webp") no-repeat center center/contain;
  bottom: -90px;
  left: 0;
}
@media (max-width: 700px) {
  .sec_voice::after {
    bottom: -60px;
    background-position: left center;
  }
}
.sec_voice .ti-widget.ti-goog .ti-review-content {
  font-size: 12px !important;
}
.sec_voice .sec_inner {
  position: relative;
  z-index: 1;
}
.sec_voice .voice_ttl {
  text-align: center;
  margin-bottom: 10px;
}
.sec_voice .voice_ttl .ja {
  display: block;
  font-size: clamp(16px, 1.6vw, 24px);
  letter-spacing: 0.2em;
}
.sec_voice .voice_ttl .en {
  font-style: italic;
  letter-spacing: 0.05em;
  font-size: clamp(60px, 9.6vw, 120px);
  display: block;
}
.sec_voice .comment {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 55px;
  flex-wrap: wrap;
}
@media (max-width: 700px) {
  .sec_voice .comment {
    margin-bottom: 30px;
  }
}
.sec_voice .comment li {
  background: #fff;
  padding: 7px 20px;
  font-size: clamp(16px, 1.6vw, 24px);
  flex: 0 0 auto;
}
@media (max-width: 700px) {
  .sec_voice .comment li {
    padding: 5px 13px;
  }
}
.sec_voice .txt_center {
  text-align: center;
  margin-bottom: 50px;
  font-size: clamp(16px, 1.8vw, 20px);
}
@media (max-width: 700px) {
  .sec_voice .txt_center {
    margin-bottom: 30px;
  }
}
.sec_voice .common_btn {
  margin-top: 80px;
}
@media (max-width: 700px) {
  .sec_voice .common_btn {
    margin-top: 40px;
  }
}

.sec_intro {
  padding-bottom: 100px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_intro {
    padding-bottom: 80px;
  }
}
@media (max-width: 700px) {
  .sec_intro {
    padding-bottom: 60px;
  }
}
.sec_intro .trouble_detail {
  border-radius: 20px 20px 0 0;
  padding: 100px 50px 50px;
  margin-top: -50px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_intro .trouble_detail {
    padding: 80px 30px 30px;
  }
}
@media (max-width: 700px) {
  .sec_intro .trouble_detail {
    padding: 50px 4vw 20px;
  }
}
.sec_intro .trouble_detail ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px 30px;
}
@media (max-width: 700px) {
  .sec_intro .trouble_detail ul {
    gap: 40px 4%;
  }
}
.sec_intro .trouble_detail ul li {
  position: relative;
  background: #fff;
  padding: 60px 30px 30px;
  border-radius: 20px;
  max-width: 480px;
  width: 31%;
  text-align: center;
  font-size: clamp(16px, 2vw, 22px);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_intro .trouble_detail ul li {
    width: 46%;
    padding: 40px 15px 20px;
  }
}
@media (max-width: 700px) {
  .sec_intro .trouble_detail ul li {
    width: 100%;
    padding: 30px 2vw 20px;
    border-radius: 10px;
  }
}
@media (min-width: 1441px) {
  .sec_intro .trouble_detail ul li:nth-of-type(1) {
    margin-left: 5%;
  }
}
@media (min-width: 1441px) {
  .sec_intro .trouble_detail ul li:nth-of-type(2) {
    margin-right: 5%;
  }
}
.sec_intro .trouble_detail figure {
  width: 80px;
  height: 80px;
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_intro .trouble_detail figure {
    width: 60px;
    height: 60px;
    top: -30px;
  }
}
@media (max-width: 700px) {
  .sec_intro .trouble_detail figure {
    width: 40px;
    height: 40px;
    top: -20px;
  }
}
.sec_intro .trouble_detail_ttl {
  background: #3957a6;
  padding: 40px 0;
  border-radius: 0 0 20px 20px;
}
@media (max-width: 1440px) {
  .sec_intro .trouble_detail_ttl {
    padding: 30px 10px;
  }
}
.sec_intro .trouble_detail_ttl h3 {
  font-size: clamp(16px, 2.2vw, 32px);
  letter-spacing: 0.05em;
}
.sec_intro .trouble_detail_ttl > p {
  font-size: clamp(16px, 2.2vw, 32px);
  letter-spacing: 0.05em;
}
.sec_intro .trouble_detail_ttl .ttl_head {
  font-size: clamp(16px, 2.2vw, 32px);
  letter-spacing: 0.05em;
}

.sec_merit {
  padding: 85px 0 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_merit {
    padding: 65px 0 80px;
  }
}
@media (max-width: 700px) {
  .sec_merit {
    padding: 50px 0;
  }
}
.sec_merit ul {
  display: flex;
  gap: min(49px, 2.2vw);
  margin-bottom: 60px;
}
@media (max-width: 700px) {
  .sec_merit ul {
    gap: 5px;
    margin-bottom: 30px;
    flex-direction: column;
  }
}
.sec_merit ul li {
  background: #fff;
  padding: 5px 10px;
}
@media (min-width: 1441px) {
  .sec_merit ul li {
    flex: auto;
    padding: 5px 25px 30px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_merit ul li {
    flex: auto;
    padding: 5px 10px 30px;
  }
}
@media (max-width: 700px) {
  .sec_merit ul li {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 20px;
  }
}
.sec_merit ul li .number {
  display: block;
  font-style: italic;
  font-weight: 600;
  color: #cbd5e1;
  font-size: clamp(26px, 3vw, 40px);
  margin-bottom: 18px;
  text-align: right;
  letter-spacing: 0.1em;
  line-height: 1.1;
}
@media (max-width: 700px) {
  .sec_merit ul li .number {
    font-size: min(16px, 4vw);
    margin-bottom: 4px;
    text-align: center;
  }
}
.sec_merit ul li .number strong {
  font-size: clamp(46px, 6vw, 80px);
  font-weight: 500;
  letter-spacing: 0;
  font-family: "Roboto", sans-serif;
}
@media (max-width: 700px) {
  .sec_merit ul li .number strong {
    font-size: min(24px, 6vw);
  }
}
.sec_merit ul li p {
  text-align: center;
  font-size: clamp(16px, 1.8vw, 32px);
  font-weight: 400;
}
@media (max-width: 700px) {
  .sec_merit ul li p {
    text-align: left;
  }
}
.sec_merit .common_btn {
  margin-bottom: 100px;
}
@media (max-width: 700px) {
  .sec_merit .common_btn {
    margin-bottom: 50px;
  }
}

.sec_features {
  padding: 120px 0 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_features {
    padding: 80px 0 0;
  }
}
@media (max-width: 700px) {
  .sec_features {
    padding: 50px 0 0;
  }
}
.sec_features .features_wrap {
  max-width: 1920px;
  margin: 0 auto;
}
.sec_features .features_wrap .features_block {
  display: flex;
}
@media (max-width: 900px) {
  .sec_features .features_wrap .features_block {
    flex-wrap: wrap;
    flex-direction: column-reverse;
    gap: 15px;
  }
}
.sec_features .features_wrap .features_block.re {
  flex-direction: row-reverse;
}
@media (max-width: 900px) {
  .sec_features .features_wrap .features_block.re {
    flex-direction: column-reverse;
    gap: 15px;
  }
}
.sec_features .features_wrap .features_block.re .txt_area .inner {
  padding: 0 min(80px, 5vw) 0 min(60px, 4vw);
}
@media (min-width: 901px) {
  .sec_features .features_wrap .features_block.re .txt_area .inner {
    padding: 0 30px;
  }
}
@media (max-width: 900px) {
  .sec_features .features_wrap .features_block.re .txt_area .inner {
    padding: 0 20px;
    width: auto;
    margin: 0 auto;
  }
}
@media (max-width: 900px) {
  .sec_features .features_wrap .features_block.re figure {
    margin: 0 20px 0 0;
  }
}
.sec_features .features_wrap figure {
  aspect-ratio: 26/13;
  width: 100%;
}
@media (min-width: 901px) {
  .sec_features .features_wrap figure {
    flex: 1 0 60%;
  }
}
@media (max-width: 900px) {
  .sec_features .features_wrap figure {
    margin: 0 0 0 20px;
    width: calc(100% - 20px);
  }
}
.sec_features .features_wrap figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sec_features .features_wrap .txt_area {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 900px) {
  .sec_features .features_wrap .txt_area {
    margin-bottom: 40px;
  }
}
@media (min-width: 901px) {
  .sec_features .features_wrap .txt_area {
    flex: 1 0 40%;
  }
}
.sec_features .features_wrap .txt_area .inner {
  padding: 0 min(60px, 4vw) 0 min(80px, 5vw);
}
@media (min-width: 901px) {
  .sec_features .features_wrap .txt_area .inner {
    padding: 0 30px;
  }
}
@media (max-width: 900px) {
  .sec_features .features_wrap .txt_area .inner {
    padding: 0 20px;
    width: auto;
    margin: 0 auto;
  }
}
.sec_features .features_wrap .txt_area .en {
  color: #cbd5e1;
  font-weight: 500;
  font-size: clamp(40px, 5.2vw, 80px);
  font-style: italic;
  line-height: 1.1;
}
.sec_features .features_wrap .txt_area .block_ttl {
  font-size: clamp(18px, 1.8vw, 32px);
  font-weight: bold;
  margin-bottom: 20px;
}
@media (max-width: 900px) {
  .sec_features .features_wrap .txt_area .block_ttl {
    margin-bottom: 10px;
  }
}
@media (max-width: 900px) {
  .sec_features .features_wrap .txt_area .block_ttl.tabpc {
    display: none;
  }
}
.sec_features .features_wrap .txt_area p {
  font-size: clamp(16px, 1.6vw, 18px);
}

.sec_choosing {
  padding: 114px 0 160px;
}
@media (max-width: 700px) {
  .sec_choosing {
    padding: 50px 0 80px;
  }
}
.sec_choosing .hukidashi_ttl {
  margin-bottom: 40px;
}
.sec_choosing .choosing_cards {
  display: flex;
  flex-wrap: wrap;
  gap: min(2vw, 40px);
  justify-content: center;
  margin-bottom: 60px;
}
@media (max-width: 700px) {
  .sec_choosing .choosing_cards {
    margin: 0 auto 30px;
    gap: 10px;
  }
}
.sec_choosing .choosing_cards .card {
  flex: 0 0 calc(25% - 40px);
  background: #fff;
  border: 1px solid #cbd5e1;
}
@media (max-width: 900px) {
  .sec_choosing .choosing_cards .card {
    flex: 0 0 calc(50% - 10px);
  }
}
.sec_choosing .choosing_cards figure {
  aspect-ratio: 3/2;
}
.sec_choosing .choosing_cards figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sec_choosing .choosing_cards h3,
.sec_choosing .choosing_cards .choosing_ttl {
  font-size: clamp(18px, 1.8vw, 28px);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  margin: 10px 0;
  padding: 0 20px;
}
@media (max-width: 700px) {
  .sec_choosing .choosing_cards h3,
  .sec_choosing .choosing_cards .choosing_ttl {
    justify-content: center;
    padding: 0 0;
  }
}
@media (max-width: 374px) {
  .sec_choosing .choosing_cards h3,
  .sec_choosing .choosing_cards .choosing_ttl {
    font-size: min(18px, 4.6vw);
  }
}
.sec_choosing .choosing_cards h3 .en,
.sec_choosing .choosing_cards .choosing_ttl .en {
  font-size: clamp(24px, 3vw, 40px);
  line-height: 1.2;
}
.sec_choosing .choosing_cards p {
  padding: 0 20px 20px;
}
@media (max-width: 700px) {
  .sec_choosing .choosing_cards p {
    padding: 0 10px 10px;
  }
}
.sec_choosing .choosing_cards p.txt {
  font-size: clamp(16px, 1.8vw, 18px);
}
.sec_choosing .choosing_cards p.note {
  padding-top: 0;
}

.sec_preparation {
  padding: 105px 0 120px;
}
@media (max-width: 700px) {
  .sec_preparation {
    padding: 60px 0;
  }
}
.sec_preparation .preparation_ttl {
  margin-bottom: 30px;
}
.sec_preparation .preparation_ttl span {
  font-size: clamp(20px, 2vw, 32px);
  padding: 15px 60px;
}
@media (max-width: 700px) {
  .sec_preparation .preparation_ttl span {
    padding: 8px 50px;
  }
}
.sec_preparation .preparation_subttl {
  font-size: clamp(20px, 2vw, 32px);
  margin-bottom: 10px;
}
.sec_preparation .preparation_comment {
  font-size: clamp(16px, 1.6vw, 24px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_preparation .preparation_comment {
    width: 80%;
    margin: 0 auto;
  }
}
.sec_preparation .smooth_block {
  width: 90%;
  max-width: 880px;
  margin: 80px auto 40px;
}
@media (max-width: 700px) {
  .sec_preparation .smooth_block {
    margin: 30px auto 20px;
    width: 100%;
  }
}
.sec_preparation .smooth_block .smooth_head {
  background: #3957a6;
  color: #fff;
  text-align: center;
  position: relative;
  margin-bottom: 50px;
  font-size: clamp(16px, 2vw, 32px);
  padding: 20px;
}
@media (max-width: 700px) {
  .sec_preparation .smooth_block .smooth_head {
    padding: 5px 0;
  }
}
.sec_preparation .smooth_block .smooth_head::before {
  position: absolute;
  content: "";
  width: 60px;
  height: 30px;
  background-color: #3957a6;
  clip-path: polygon(50% 30px, 0% 0%, 60px 0%);
  bottom: -29px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 700px) {
  .sec_preparation .smooth_block .smooth_head::before {
    width: 40px;
    height: 20px;
    clip-path: polygon(50% 20px, 0% 0%, 40px 0%);
    bottom: -19px;
  }
}
.sec_preparation .smooth_block .smooth_body {
  padding: 30px 50px;
}
@media (max-width: 700px) {
  .sec_preparation .smooth_block .smooth_body {
    padding: 20px 4vw;
  }
}
.sec_preparation .smooth_block .smooth_body .dot_list li {
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: 500;
}
.sec_preparation .smooth_block .smooth_body .dot_list li + li {
  margin-top: 0.5em;
}

.sec_info {
  padding: 114px 0;
}
@media (max-width: 700px) {
  .sec_info {
    padding: 50px 0;
  }
}
.sec_info .catch {
  margin-bottom: 100px;
}
@media (max-width: 700px) {
  .sec_info .catch {
    margin-bottom: 50px;
  }
}
.sec_info .example02 {
  margin-top: 120px;
}
@media (max-width: 700px) {
  .sec_info .example02 {
    margin-top: 60px;
  }
}
.sec_info .example02 .example_jiko h3::after {
  background: url("../img/jiko_common/icon_accident_person.svg") no-repeat center center/contain;
}
.sec_info .example_jiko {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 60px;
  position: relative;
}
@media (max-width: 700px) {
  .sec_info .example_jiko {
    padding-top: 10px;
    margin-bottom: 20px;
  }
}
.sec_info .example_jiko::after {
  position: absolute;
  content: "";
  background: #3957a6;
  width: 100%;
  height: 2px;
  left: 0;
  top: 40px;
  z-index: -1;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .example_jiko::after {
    top: 30px;
  }
}
@media (max-width: 700px) {
  .sec_info .example_jiko::after {
    top: 20px;
    height: 1px;
  }
}
.sec_info .example_jiko span {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  font-size: clamp(16px, 2vw, 32px);
  background: #3957a6;
  color: #ffd52b;
  text-align: center;
  padding: 0 35px;
  border: 1px solid #cbd5e1;
  line-height: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .example_jiko span {
    line-height: 60px;
  }
}
@media (max-width: 700px) {
  .sec_info .example_jiko span {
    line-height: 36px;
    padding: 0 22px;
    white-space: nowrap;
  }
}
.sec_info .example_jiko h3,
.sec_info .example_jiko h4 {
  text-align: center;
  font-size: clamp(22px, 3.2vw, 40px);
  margin: 120px 0 0;
  padding-top: 150px;
  position: relative;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .example_jiko h3,
  .sec_info .example_jiko h4 {
    padding-top: 120px;
    margin: 90px 0 0;
  }
}
@media (max-width: 700px) {
  .sec_info .example_jiko h3,
  .sec_info .example_jiko h4 {
    padding-top: 70px;
    margin: 40px 0 0;
  }
}
.sec_info .example_jiko h3::after,
.sec_info .example_jiko h4::after {
  position: absolute;
  content: "";
  background: url("../img/jiko_common/icon_accident.svg") no-repeat center center/contain;
  width: 120px;
  height: 120px;
  margin: auto;
  inset: 0 0 auto 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .example_jiko h3::after,
  .sec_info .example_jiko h4::after {
    width: 90px;
    height: 90px;
  }
}
@media (max-width: 700px) {
  .sec_info .example_jiko h3::after,
  .sec_info .example_jiko h4::after {
    width: 60px;
    height: 60px;
  }
}
.sec_info .price {
  margin-bottom: 60px;
  display: flex;
  justify-content: center;
  gap: 100px;
}
@media (max-width: 700px) {
  .sec_info .price {
    flex-direction: column;
    margin-bottom: 40px;
    gap: 60px;
  }
}
.sec_info .price .price_box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}
@media (max-width: 700px) {
  .sec_info .price .price_box {
    flex-direction: column;
  }
}
.sec_info .price .price_box p {
  text-align: center;
}
.sec_info .price .price_box p:first-of-type {
  font-size: clamp(16px, 1.6vw, 24px);
}
.sec_info .price .price_box p:last-of-type {
  font-size: clamp(20px, 2.2vw, 40px);
  letter-spacing: 0.05em;
}
.sec_info .price .price_box p:last-of-type.type_middle {
  font-size: clamp(18px, 2vw, 30px);
}
.sec_info .price .price_box p span {
  font-size: 150%;
}
.sec_info .price .price_box p strong {
  font-size: 140%;
  font-weight: bold;
}
.sec_info .price .price_box p small {
  font-size: 80%;
}
.sec_info .price .price_box p small.type_small {
  font-size: 70%;
}
.sec_info .price .price_box p small span {
  font-size: 90%;
}
.sec_info .price .before {
  background: #f1f5f9;
  position: relative;
}
@media (min-width: 701px) {
  .sec_info .price .before {
    width: 40%;
  }
}
.sec_info .price .before::before {
  position: absolute;
  content: "";
  background-color: #cbd5e1;
}
@media (min-width: 701px) {
  .sec_info .price .before::before {
    right: -80px;
    top: 50%;
    transform: translateY(-50%);
    width: 60px;
    height: 120px;
    clip-path: polygon(60px 50%, 0% 0%, 0% 120px);
  }
}
@media (max-width: 700px) {
  .sec_info .price .before::before {
    width: 80px;
    height: 40px;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 40px, 0% 0%, 80px 0%);
  }
}
.sec_info .price .after {
  border: 5px solid #cbd5e1;
  background: #fff;
}
@media (min-width: 701px) {
  .sec_info .price .after {
    width: 50%;
    border-width: 10px;
  }
}
.sec_info .situation {
  padding: 40px;
  margin-bottom: 60px;
}
@media (max-width: 700px) {
  .sec_info .situation {
    padding: 20px;
    margin-bottom: 30px;
  }
}
.sec_info .situation dl {
  display: flex;
  align-items: center;
  gap: 80px;
}
@media (max-width: 700px) {
  .sec_info .situation dl {
    flex-direction: column;
    gap: 20px;
  }
}
.sec_info .situation dl dt {
  width: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: bold;
  position: relative;
  padding: 40px 0;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .situation dl dt {
    width: 230px;
  }
}
@media (max-width: 700px) {
  .sec_info .situation dl dt {
    padding: 10px;
    width: 100%;
  }
}
.sec_info .situation dl dt::before {
  position: absolute;
  content: "";
  width: 40px;
  height: 80px;
}
@media (min-width: 701px) {
  .sec_info .situation dl dt::before {
    clip-path: polygon(40px 50%, 0% 0%, 0% 80px);
    right: -39px;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media (max-width: 700px) {
  .sec_info .situation dl dt::before {
    width: 40px;
    height: 15px;
    bottom: -14px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 15px, 0% 0%, 40px 0%);
  }
}
.sec_info .situation dl + dl {
  margin-top: 20px;
}
.sec_info .situation dl.type_blue dt {
  background: #3957a6;
}
.sec_info .situation dl.type_blue dt::before {
  background-color: #3957a6;
}
.sec_info .situation dl.type_black dt {
  background: #0f172a;
}
.sec_info .situation dl.type_black dt::before {
  background-color: #0f172a;
}
.sec_info .situation dl dd {
  font-size: clamp(16px, 1.8vw, 20px);
}
@media (min-width: 1441px) {
  .sec_info .situation dl dd {
    width: calc(100% - 400px);
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .situation dl dd {
    width: calc(100% - 260px);
  }
}
.sec_info .point {
  position: relative;
  padding: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .point {
    padding: 40px 30px;
  }
}
@media (max-width: 700px) {
  .sec_info .point {
    padding: 30px 4vw;
  }
}
.sec_info .point::before {
  position: absolute;
  content: "";
  background: url("../img/top/smile_man@2x.webp") no-repeat top center/contain;
  width: 15%;
  height: 100%;
  max-width: 184px;
  max-height: 250px;
  top: -30px;
  right: 80px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .point::before {
    right: 40px;
    max-width: 120px;
    max-height: 160px;
    top: -40px;
  }
}
@media (max-width: 700px) {
  .sec_info .point::before {
    max-width: 70px;
    max-height: 80px;
    right: 10px;
    width: 20%;
  }
}
@media (max-width: 374px) {
  .sec_info .point::before {
    top: -40px;
  }
}
.sec_info .point .center_ttl.type_middle {
  font-size: clamp(18px, 2.4vw, 32px);
}
.sec_info .point .center_ttl span {
  font-size: 120%;
}
@media (max-width: 700px) {
  .sec_info .point .center_ttl span {
    display: block;
  }
}
.sec_info .point .point_detail dl + dl {
  margin-top: 60px;
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl + dl {
    margin-top: 30px;
  }
}
.sec_info .point .point_detail dl dt {
  position: relative;
  margin-bottom: 10px;
}
@media (min-width: 701px) {
  .sec_info .point .point_detail dl dt {
    display: flex;
    align-items: center;
    gap: 20px;
  }
}
.sec_info .point .point_detail dl dt .en {
  color: #cbd5e1;
  font-weight: 500;
  font-size: clamp(40px, 7.2vw, 80px);
  font-style: italic;
  width: 80px;
  min-width: 80px;
  white-space: nowrap;
  line-height: 1.1;
}
.sec_info .point .point_detail dl dt .txt_area > p {
  font-size: clamp(18px, 1.8vw, 22px);
  margin-bottom: 5px;
}
@media (min-width: 701px) {
  .sec_info .point .point_detail dl dt .txt_area > p {
    letter-spacing: 0.05em;
  }
}
.sec_info .point .point_detail dl dt .txt_area > p span {
  font-size: 83%;
}
@media (min-width: 701px) {
  .sec_info .point .point_detail dl dd {
    margin-left: 100px;
  }
}
.sec_info .point .point_detail dl h5 {
  font-size: clamp(18px, 1.8vw, 22px);
  margin-bottom: 5px;
}
@media (min-width: 701px) {
  .sec_info .point .point_detail dl h5 {
    letter-spacing: 0.05em;
  }
}
.sec_info .point .point_detail dl h5 span {
  font-size: 83%;
}
.sec_info .point .point_detail dl p {
  font-size: clamp(16px, 1.6vw, 18px);
}
.sec_info .point .point_detail dl .point_result {
  background: #fff;
  padding: 20px 30px;
  text-align: center;
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl .point_result {
    padding: 20px 4vw;
  }
}
.sec_info .point .point_detail dl .point_result p:first-of-type {
  position: relative;
  margin-bottom: 60px;
}
.sec_info .point .point_detail dl .point_result p:first-of-type::before {
  position: absolute;
  content: "";
  width: 100px;
  height: 45px;
  background-color: #cbd5e1;
  clip-path: polygon(50% 45px, 0% 0%, 100px 0%);
  left: 50%;
  transform: translateX(-50%);
  bottom: -50px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_info .point .point_detail dl .point_result p:first-of-type::before {
    width: 80px;
    height: 40px;
    clip-path: polygon(50% 40px, 0% 0%, 80px 0%);
  }
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl .point_result p:first-of-type::before {
    width: 80px;
    height: 40px;
    clip-path: polygon(50% 40px, 0% 0%, 80px 0%);
  }
}
.sec_info .point .point_detail dl .point_result p:first-of-type small {
  font-size: 90%;
}
.sec_info .point .point_detail dl .point_result p.result_txt {
  font-size: clamp(18px, 1.8vw, 24px);
  margin-bottom: 5px;
}
@media (min-width: 701px) {
  .sec_info .point .point_detail dl .point_result p.result_txt {
    letter-spacing: 0.05em;
  }
}
.sec_info .point .point_detail dl .point_result p.result_txt span {
  font-size: 83%;
}
.sec_info .point .point_detail dl .box {
  background: #fff;
  padding: 30px;
  margin-top: 20px;
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl .box {
    padding: 20px 10px;
  }
}
.sec_info .point .point_detail dl .box .star_icon {
  padding-left: 53px;
  position: relative;
  display: inline-block;
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl .box .star_icon::before {
    inset: 0 auto auto 0;
  }
}
.sec_info .point .point_detail dl .box .star_icon + .star_icon {
  margin-top: 30px;
}
@media (max-width: 700px) {
  .sec_info .point .point_detail dl .box .star_icon + .star_icon {
    margin-top: 15px;
  }
}

.dl_base dt {
  color: #fff;
  text-align: center;
  border-radius: 10px 10px 0 0;
  padding: 15px;
}
.dl_base dd {
  background: #f1f5f9;
  padding: 30px 20px;
  border-radius: 0 0 10px 10px;
  border: 2px solid #cbd5e1;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .dl_base dd {
    padding: 25px 5px;
  }
}
@media (max-width: 700px) {
  .dl_base dd {
    padding: 20px 10px;
  }
}
.dl_base.bg_type01 dt {
  background: #0f172a;
}
.dl_base.bg_type02 dt {
  background: #8195b0;
}
.dl_base.bg_type02 dd {
  background: #fff;
}
.dl_base.bg_type03 dt {
  background: #3957a6;
}
.dl_base > .dl_midashi {
  color: #fff;
  text-align: center;
  border-radius: 10px 10px 0 0;
  padding: 15px;
  background: #3957a6;
  font-size: clamp(20px, 2vw, 28px);
}
.dl_base > .bg_light_gray,
.dl_base > .bg_white {
  background: #f1f5f9;
  height: 80%;
  padding: 20px;
  border-radius: 0 0 10px 10px;
  border: 2px solid #cbd5e1;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .dl_base > .bg_light_gray,
  .dl_base > .bg_white {
    padding: 25px 10px;
  }
}
@media (max-width: 700px) {
  .dl_base > .bg_light_gray,
  .dl_base > .bg_white {
    padding: 20px 10px;
  }
}

.dl_standard_wrap {
  display: flex;
  width: 100%;
  justify-content: space-between;
  margin-bottom: 100px;
}
@media (max-width: 700px) {
  .dl_standard_wrap {
    margin-bottom: 50px;
    flex-direction: column;
    gap: 50px;
  }
}
.dl_standard_wrap > .dl_standard {
  width: 30%;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .dl_standard_wrap > .dl_standard {
    width: 31%;
  }
}
@media (max-width: 700px) {
  .dl_standard_wrap > .dl_standard {
    width: 100%;
  }
}
.dl_standard_wrap > .dl_standard:not(:last-of-type) {
  position: relative;
}
.dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
  position: absolute;
  content: "";
  border-right: 4px solid #3957a6;
  border-bottom: 4px solid #3957a6;
  width: 30px;
  height: 30px;
  margin: auto;
  inset: 0 auto 0 calc(100% + 25px);
  transform: rotate(135deg);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
    width: 25px;
    height: 25px;
    border-width: 3px;
    inset: 0 auto 0 calc(100% + 12px);
  }
}
@media (max-width: 900px) {
  .dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
    width: 20px;
    height: 20px;
    inset: 0 auto 0 calc(100% + 10px);
  }
}
@media (max-width: 700px) {
  .dl_standard_wrap > .dl_standard:not(:last-of-type)::before {
    inset: auto 0 -50px 0;
    transform: rotate(-135deg);
  }
}
.dl_standard_wrap > .dl_standard dt {
  font-size: clamp(18px, 2vw, 24px);
  padding: 12px;
}
.dl_standard_wrap > .dl_standard dd p {
  font-size: clamp(16px, 1.6vw, 24px);
}

.sec_results_slider {
  padding: 140px 0 130px;
}
@media (max-width: 700px) {
  .sec_results_slider {
    padding: 50px 0 80px;
  }
}
@media (max-width: 1440px) {
  .sec_results_slider .sec_inner {
    width: 90%;
  }
}
.sec_results_slider .hukidashi_ttl {
  margin-bottom: 55px;
}
@media (max-width: 700px) {
  .sec_results_slider .hukidashi_ttl {
    margin-bottom: 30px;
  }
}
.sec_results_slider .swiper-slide {
  height: auto;
  display: flex;
}
.sec_results_slider .swiper-slide a {
  width: 100%;
}
.sec_results_slider a.swiper-slide,
.sec_results_slider .info_item {
  display: block;
  width: 100%;
  height: 100%;
}
.sec_results_slider .results_item {
  background: #fff;
  border-radius: 20px;
  border: 10px solid #cbd5e1;
  padding: 40px 30px 20px;
  height: 100%;
  transition: 0.5s ease-in-out;
}
@media (max-width: 700px) {
  .sec_results_slider .results_item {
    padding: 30px 4vw 20px;
  }
}
.sec_results_slider .results_item:hover {
  background: #f1f5f9;
}
.sec_results_slider .results_item figure {
  width: 120px;
  height: 120px;
  margin: 0 auto 30px;
}
@media (max-width: 700px) {
  .sec_results_slider .results_item figure {
    width: 80px;
    height: 80px;
  }
}
.sec_results_slider .results_item time {
  font-size: clamp(14px, 1.6vw, 18px);
  margin-bottom: 10px;
  display: block;
}
.sec_results_slider .results_item .ttl h3 {
  font-weight: 600;
  font-size: clamp(20px, 2vw, 24px);
}
.sec_results_slider .results_item .detail {
  background: #f1f5f9;
  padding: 30px 20px 20px;
  position: relative;
  margin: 60px 0 15px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .results_item .detail {
    padding: 30px 15px 20px;
  }
}
@media (max-width: 700px) {
  .sec_results_slider .results_item .detail {
    margin: 30px 0 5px;
    padding: 20px 4vw;
  }
}
.sec_results_slider .results_item .detail::before {
  position: absolute;
  content: "";
  width: 1px;
  height: 40px;
  margin: auto;
  inset: -20px 0 auto 0;
  background: #0f172a;
}
.sec_results_slider .results_item .detail dl {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  align-items: baseline;
}
@media (max-width: 1440px) {
  .sec_results_slider .results_item .detail dl {
    gap: 8px;
  }
}
.sec_results_slider .results_item .detail dl dt {
  background: #0f172a;
  color: #fff;
  text-align: center;
  font-size: clamp(16px, 1.6vw, 20px);
  width: 80px;
  line-height: 36px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .results_item .detail dl dt {
    width: 66px;
    line-height: 26px;
  }
}
@media (max-width: 700px) {
  .sec_results_slider .results_item .detail dl dt {
    width: 60px;
    line-height: 24px;
  }
}
.sec_results_slider .results_item .detail dl dd {
  line-height: 36px;
  font-size: clamp(16px, 1.6vw, 20px);
  color: #3957a6;
  width: calc(100% - 95px);
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .results_item .detail dl dd {
    width: calc(100% - 74px);
  }
}
@media (max-width: 700px) {
  .sec_results_slider .results_item .detail dl dd {
    width: calc(100% - 68px);
    line-height: 24px;
  }
}
.sec_results_slider .results_item .tag {
  display: flex;
  flex-wrap: wrap;
  gap: 0 10px;
}
.sec_results_slider .sw_btn {
  background: #3957a6;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  top: 52%;
  transition: 0.3s ease-in-out;
}
@media (min-width: 1400px) and (max-width: 1745px) {
  .sec_results_slider .sw_btn {
    width: 60px;
    height: 60px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .sw_btn {
    width: 60px;
    height: 60px;
  }
}
@media (max-width: 700px) {
  .sec_results_slider .sw_btn {
    width: 40px;
    height: 40px;
  }
}
.sec_results_slider .sw_btn:hover {
  background: #0f172a;
}
.sec_results_slider .sw_btn::after {
  color: #fff;
  font-size: 30px;
}
@media (max-width: 700px) {
  .sec_results_slider .sw_btn::after {
    font-size: 16px;
  }
}
.sec_results_slider .sw_btn.prev {
  left: -59px;
}
@media (min-width: 1400px) and (max-width: 1745px) {
  .sec_results_slider .sw_btn.prev {
    left: -30px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .sw_btn.prev {
    left: -30px;
  }
}
@media (max-width: 700px) {
  .sec_results_slider .sw_btn.prev {
    left: -4vw;
  }
}
.sec_results_slider .sw_btn.next {
  right: -59px;
}
@media (min-width: 1400px) and (max-width: 1745px) {
  .sec_results_slider .sw_btn.next {
    right: -30px;
  }
}
@media (min-width: 701px) and (max-width: 1440px) {
  .sec_results_slider .sw_btn.next {
    right: -30px;
  }
}
@media (max-width: 700px) {
  .sec_results_slider .sw_btn.next {
    right: -4vw;
  }
}
.sec_results_slider .common_btn {
  margin-top: 60px;
}
@media (max-width: 700px) {
  .sec_results_slider .common_btn {
    margin-top: 25px;
  }
}

.singlePage .post_common {
  padding-bottom: 120px;
}
@media (min-width: 701px) and (max-width: 1440px) {
  .singlePage .post_common {
    padding-bottom: 60px;
  }
}
@media (max-width: 700px) {
  .singlePage .post_common {
    padding-bottom: 40px;
  }
}
.singlePage .sns_block {
  max-width: 900px;
  margin: 0 auto 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f1f5f9;
  gap: 60px;
  padding: 40px;
}
@media (max-width: 700px) {
  .singlePage .sns_block {
    margin-bottom: 50px;
    flex-direction: column;
    gap: 20px;
    padding: 20px 0;
  }
}
.singlePage .sns_block p {
  font-size: clamp(16px, 1.6vw, 18px);
  font-weight: bold;
}
.singlePage .sns_block ul {
  display: flex;
  justify-content: center;
  gap: 16px;
}
.singlePage .sns_block ul img {
  width: 40px;
  height: 40px;
}
.singlePage .author_block {
  border: 1px solid #cbd5e1;
  padding: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto 50px;
  max-width: 700px;
}
@media (max-width: 700px) {
  .singlePage .author_block {
    flex-direction: column;
  }
}
.singlePage .author_block figure {
  width: 150px;
}
@media (min-width: 701px) {
  .singlePage .author_block .author_info {
    width: calc(100% - 170px);
  }
}
.singlePage .author_block .author_info .author_name {
  font-weight: bold;
  margin-bottom: 15px;
  color: #3957a6;
}

/*# sourceMappingURL=style.css.map */
