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

body {
  padding: 0;
  font-size: 18px;
  font-family: "Noto Sans JP", "Noto Sans Japanese";
  color: #333333;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 3.7vw;
  }
}

h2 {
  font-size: min(3vw, 44px);
  margin-bottom: min(4.2vw, 60px);
  font-weight: 700;
  line-height: 1.2em;
}
h2 span {
  font-weight: 700;
}
h2 span.ttl_small {
  font-size: clamp(14px, 1.3vw, 20px);
  line-height: 0.1em;
}

h3 {
  font-size: min(2.2vw, 32px);
  font-weight: 700;
}

p {
  font-size: clamp(12px, 1.25vw, 18px);
  font-weight: 400;
}

li {
  list-style: none;
}

a {
  color: #333333;
  text-decoration: none;
}

.fgreen {
  color: #21A77E;
}

.forange {
  color: #FC7700;
}

.ac_green {
  background-color: #21A77E;
}

.bg_y {
  background-color: #FFFAE4;
}

small {
  font-size: 14px;
}

img {
  width: 100%;
}

section .in {
  max-width: 1128px;
  width: 90%;
  margin: 0 auto;
}

.fukidashi {
  position: relative;
  display: inline-block;
  margin: min(4.9vw, 70px) 0;
  padding: min(0.7vw, 10px) 0 min(2vw, 30px);
  text-align: center;
  width: min(58.89vw, 848px);
  background: #fff;
  border-radius: 80px;
}
.fukidashi:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -12px;
  border: 12px solid transparent;
  border-top: 18px solid #fff;
  z-index: 2;
}
.fukidashi.border {
  border: solid 4px #FCCF00;
}
.fukidashi.border:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -18px;
  border: 18px solid transparent;
  border-top: 26px solid #FCCF00;
  z-index: 1;
}

.sankaku {
  position: relative;
}
.sankaku::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: min(4.4vw, 64px);
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  background-color: #FFFAE4;
}

.list_block {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(2.78vw, 40px);
}
.list_block figure {
  width: 100%;
}
.list_block figure img {
  width: 100%;
}

.btn {
  width: min(29vw, 420px);
  height: min(6.3vw, 90px);
  border-radius: 50px;
  padding: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: min(2.2vw, 32px);
  font-weight: 700;
}
.btn::before {
  content: "";
  display: block;
  width: min(2.8vw, 40px);
  height: min(2vw, 30px);
  background: url(../images/icon_mail.png) no-repeat center;
  background-size: contain;
  margin: 2px 1.4vw 0 0;
}

.ttl {
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 768px) {
  h2 {
    font-size: 7.7vw;
    margin-bottom: min(4.2vw, 60px);
    line-height: 1.2em;
  }
  h2 span.ttl_small {
    font-size: 4.4vw;
  }
  h3 {
    font-size: 6.15vw;
  }
  p {
    font-size: 4vw;
  }
  section .in {
    width: unset;
    padding: 0 3.8vw;
  }
  .sankaku::after {
    height: 11vw;
  }
  .fukidashi {
    margin: 15.4vw 0;
    padding: 4vw 0 7.6vw;
    width: 100%;
    border-radius: 23vw;
  }
  .fukidashi:before {
    margin-left: -3vw;
    border: 3vw solid transparent;
    border-top: 4.6vw solid #fff;
  }
  .fukidashi.border {
    border: solid 1vw #FCCF00;
  }
  .fukidashi.border:after {
    margin-left: -4.6vw;
    border: 4.6vw solid transparent;
    border-top: 6.4vw solid #FCCF00;
  }
  .ttl {
    padding: 0 1vw;
  }
}
header .logo {
  width: min(16.67vw, 240px);
  height: min(5.6vw, 80px);
  display: flex;
  align-items: center;
  position: absolute;
  top: 0;
  left: min(2.3vw, 34px);
  z-index: 110;
}
header .logo img {
  width: 100%;
}
header .in {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 min(2.3vw, 34px);
  width: 100%;
  height: min(5.6vw, 80px);
  background-color: #fff;
  z-index: 100;
  position: fixed;
  top: 0;
  left: 0;
}
header .in nav {
  font-size: clamp(12px, 0.9vw, 14px);
  height: min(4.2vw, 60px);
  margin: min(0.7vw, 10px) 0 min(0.7vw, 10px) auto;
  text-align: right;
  display: flex;
  align-items: center;
  position: fixed;
  top: 0;
  right: min(2.3vw, 34px);
  z-index: 100;
}
header .in nav a {
  padding: 0 min(1vw, 15px);
  font-weight: 700;
  letter-spacing: normal;
  display: block;
}
header .in nav a div {
  font-weight: 700;
  color: #fff;
}
header .in nav .btn {
  width: clamp(120px, 11.1vw, 160px);
  height: min(4.2vw, 60px);
  border-radius: 40px;
  padding: 0;
  font-size: clamp(12px, 0.9vw, 14px);
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: min(2vw, 30px);
}
header .in nav .btn::before {
  content: "";
  display: block;
  width: clamp(13px, 1.4vw, 20px);
  height: clamp(13px, 1.1vw, 16px);
  background: url(../images/icon_mail.png) no-repeat center;
  background-size: contain;
  margin: 2px 0.4vw 0 0;
}
header .kv {
  background: url(../images/bg_kv.png) no-repeat center;
  background-size: cover;
  padding: min(4.2vw, 60px) 0 min(1.8vw, 26px);
  margin: min(5.6vw, 80px) auto 0;
  z-index: 0;
}
header .kv .in {
  width: 61.5vw;
  max-width: 887px;
  height: unset;
  background-color: unset;
  margin: 0 auto;
  display: block;
  position: relative;
  padding: 0;
}
header .kv .in::before {
  content: "";
  display: block;
  width: min(19vw, 278px);
  height: min(18.6vw, 280px);
  background: url(../images/cta_illust.png) no-repeat center;
  background-size: contain;
  position: absolute;
  top: min(9.5vw, 138px);
  left: max(-15vw, -217px);
}
header .kv .in::after {
  content: "";
  display: block;
  width: min(16vw, 233px);
  height: min(15vw, 215px);
  background: url(../images/kv_illust_right.png) no-repeat center;
  background-size: contain;
  position: absolute;
  top: min(13.75vw, 198px);
  right: max(-15vw, -218px);
}
header .kv .in .marutto {
  width: min(46vw, 666px);
  padding: min(1.4vw, 20px) min(10vw, 145px) min(1.4vw, 20px) min(2.5vw, 34px);
  background-color: #fff;
  border-radius: 38px;
  margin: 0 auto min(2.4vw, 34px);
  position: relative;
}
header .kv .in .marutto .marutto_pc {
  width: min(11.5vw, 164px);
  height: min(10vw, 149px);
  position: absolute;
  top: max(-0.5vw, -8px);
  right: max(-2.8vw, -40px);
}
header .kv .in h1 {
  font-size: min(5.5vw, 79px);
  font-weight: 900;
  text-align: center;
  line-height: 1.1em;
  margin-bottom: min(2.9vw, 42px);
}
header .kv .in h1 span {
  font-weight: 900;
}
header .kv .in h1 span.ttl_small {
  font-size: min(4vw, 59px);
  font-weight: 700;
}
header .kv .in .list_block {
  gap: min(1.25vw, 18px);
}
header .kv .in .list_block figure {
  width: clamp(90px, 10vw, 146px);
}
header .kv small {
  font-size: clamp(11px, 1vw, 15px);
  font-weight: 700;
  text-shadow: 2px 2px 0 #e5f6f2, -2px 2px 0 #e5f6f2, -2px -2px 0 #e5f6f2, 2px -2px 0 #e5f6f2;
  margin-top: min(0.9vw, 14px);
  margin-left: min(2vw, 30px);
}
@media screen and (max-width: 768px) {
  header .logo {
    width: 51vw;
    height: 18vw;
    top: 0;
    left: 5vw;
    z-index: 0;
  }
  header .in {
    padding: 5.3vw 5vw;
    height: unset;
    background-color: unset;
  }
  header .in figure {
    width: 12.8vw;
    cursor: pointer;
  }
  header .kv {
    margin-top: 18vw;
    padding: 14vw 0 3.3vw;
    background: url(../images/bg_kv_sp.png) no-repeat center;
    background-size: cover;
  }
  header .kv .in {
    width: 95%;
    margin-bottom: 35.9vw;
  }
  header .kv .in::before {
    width: 38vw;
    height: 37vw;
    top: unset;
    bottom: -34.5vw;
    left: 8.2vw;
  }
  header .kv .in::after {
    width: 33.6vw;
    height: 30.7vw;
    top: unset;
    bottom: -34.5vw;
    right: 6.2vw;
  }
  header .kv .in .marutto {
    width: 72%;
    border-radius: 78px;
    padding: 3.8vw 20vw 3.8vw 6.4vw;
  }
  header .kv .in .marutto .marutto_pc {
    width: 25vw;
    height: 22.6vw;
    top: -6.2vw;
    right: 0;
  }
  header .kv .in h1 {
    font-size: 9.7vw;
    margin-bottom: 7.6vw;
  }
  header .kv .in h1 span.ttl_small {
    font-size: 7.3vw;
  }
  header .kv .in .list_block {
    padding: 0 10%;
  }
  header .kv .in .list_block figure {
    width: 30vw;
  }
  header .kv small {
    font-size: 3.3vw;
  }
}

.worries {
  background: url(../images/bg_worries.png) no-repeat center center;
  background-size: cover;
}
.worries .in {
  width: min(58.89vw, 848px);
}
.worries .in .box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: min(4.9vw, 70px);
}
.worries .in .box figure {
  width: min(21.5vw, 310px);
}
.worries .in .box ul {
  width: min(23vw, 330px);
  background-color: #fff;
  padding: min(2vw, 30px) min(2.4vw, 35px);
  font-size: clamp(12px, 1.2vw, 18px);
}
.worries .in .box ul li {
  position: relative;
  padding-left: min(2.4vw, 34px);
  line-height: 1.4em;
}
.worries .in .box ul li:before {
  content: "";
  display: block;
  width: clamp(14px, 1.5vw, 22px);
  height: clamp(14px, 1.5vw, 22px);
  background: url(../images/icon_worries.png) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 0;
  left: 0;
}
.worries .in .box ul li:not(:last-child) {
  margin-bottom: 20px;
}
.worries .in .box ul li:not(:last-child)::after {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  background: url(../images/line.png) no-repeat center;
  background-size: cover;
  position: absolute;
  bottom: -10px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .worries .in {
    width: unset;
    padding: 0 5vw;
  }
  .worries .in .box {
    flex-direction: column-reverse;
    padding-bottom: 15.4vw;
    gap: 7.6vw;
  }
  .worries .in .box figure {
    width: 79%;
  }
  .worries .in .box ul {
    width: 70vw;
    padding: 7.7vw 8.9vw;
    font-size: 4.6vw;
  }
  .worries .in .box ul li {
    padding-left: 8.2vw;
  }
  .worries .in .box ul li:before {
    width: 5.6vw;
    height: 5.6vw;
    position: absolute;
    top: 0;
    left: 0;
  }
}

.tegaru {
  padding: min(4.7vw, 68px) 0 min(3.4vw, 50px);
  text-align: center;
  margin-bottom: min(4.4vw, 64px);
}
.tegaru h3 span {
  font-weight: 700;
}
.tegaru h3 span.hanamaru {
  position: relative;
}
.tegaru h3 span.hanamaru::before {
  content: "";
  display: block;
  width: min(3.5vw, 51px);
  height: min(2.6vw, 42px);
  background: url(../images/icon_hanamaru.png) no-repeat center;
  background-size: contain;
  position: absolute;
  top: 0;
  left: max(-3.6vw, -55px);
}
@media screen and (max-width: 768px) {
  .tegaru {
    padding-top: 24vw;
    padding-bottom: 7.6vw;
    margin-bottom: 11.3vw;
  }
  .tegaru h3 span.hanamaru::before {
    width: 12.8vw;
    height: 10.7vw;
    position: absolute;
    top: -12.8vw;
    left: 39%;
  }
}

.service.sankaku::after {
  background-color: #fff;
}
.service .in .txt {
  width: min(58.89vw, 848px);
  margin: 0 auto;
}
.service .in .txt .fukidashi {
  background-color: #E2F5F1;
}
.service .in .txt .fukidashi::before {
  border-top: 18px solid #E2F5F1;
}
.service .in .txt p {
  padding: 0 min(8vw, 137px);
  margin-bottom: min(3.6vw, 52px);
}
.service .in .possible {
  margin-top: min(4.9vw, 70px);
  text-align: center;
}
.service .in .possible h3 {
  width: min(44vw, 640px);
  margin: 0 auto min(3.5vw, 50px);
  background-color: #FCCF00;
  padding: min(0.7vw, 10px) min(2.8vw, 40px) min(0.7vw, 10px) min(6.9vw, 100px);
  border-radius: 50px;
  position: relative;
}
.service .in .possible h3::before {
  content: "";
  display: block;
  width: min(3.5vw, 51px);
  height: min(2.6vw, 42px);
  background: url(../images/icon_hanamaru_w.png) no-repeat center;
  background-size: contain;
  position: absolute;
  top: 20%;
  left: min(2.8vw, 40px);
}
.service .in .possible .list_block .box {
  width: min(10vw, 150px);
}
.service .in .possible .list_block .box p {
  margin-top: min(1.4vw, 20px);
  font-weight: 700;
  font-size: clamp(12px, 1.4vw, 20px);
  margin-bottom: min(5.6vw, 80px);
}
@media screen and (max-width: 768px) {
  .service .in {
    padding-bottom: 7.6vw;
  }
  .service .in .txt {
    padding: 0 1vw;
    width: unset;
  }
  .service .in .txt .fukidashi::before {
    border-top: 4.6vw solid #E2F5F1;
  }
  .service .in .txt p {
    padding: 0 5.1vw;
    margin-bottom: 10vw;
  }
  .service .in .possible h3 {
    margin: 12.8vw 0 12.3vw;
    padding: 5.9vw 0;
    width: 100%;
    border-radius: 23vw;
    background: url(../images/icon_hanamaru_w_50.png) no-repeat center center, #FCCF00;
    background-size: 21vw;
  }
  .service .in .possible h3::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -3vw;
    border: 3vw solid transparent;
    border-top: 4.6vw solid #FCCF00;
    z-index: 2;
  }
  .service .in .possible h3::before {
    display: none;
  }
  .service .in .possible .list_block {
    gap: 9vw;
  }
  .service .in .possible .list_block .box {
    width: 33.3%;
  }
  .service .in .possible .list_block .box p {
    font-size: 4.6vw;
  }
}

.cta {
  padding: min(8.6vw, 124px) 0 min(4.2vw, 60px);
  background: url(../images/bg_dot.jpeg) no-repeat center;
  background-size: cover;
}
.cta .in {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(3.5vw, 50px);
}
.cta .in figure {
  width: min(17.4vw, 250px);
}
.cta .in .box p {
  font-size: clamp(16px, 1.7vw, 24px);
  font-weight: 700;
  text-align: center;
}
.cta .in .box a {
  margin: min(2vw, 30px) auto 0;
  position: relative;
  top: 0;
  box-shadow: 0 6px #186F55;
  transition: 0.2s ease-in-out;
}
.cta .in .box a:hover {
  top: 6px;
  box-shadow: 0 0px #186F55;
}
@media screen and (max-width: 768px) {
  .cta {
    padding: 11.3vw 0 15.4vw;
    background: url(../images/bg_dot.jpeg) no-repeat center;
    background-size: 300%;
  }
  .cta .in {
    display: block;
  }
  .cta .in figure {
    width: 48.7vw;
    margin: 15.9vw auto 7.6vw;
  }
  .cta .in .box p {
    font-size: 4.6vw;
    margin-bottom: 7.6vw;
  }
  .cta .in .box a.btn {
    width: 82vw;
    height: 16.4vw;
    font-size: 5.6vw;
    margin-left: 3.6vw;
    border-radius: 12.8vw;
  }
  .cta .in .box a.btn::before {
    width: 8.2vw;
    height: 6.1vw;
  }
}

.point {
  background-color: #FFFAE4;
  padding-bottom: min(5.6vw, 80px);
}
.point .fukidashi .ttl_small {
  color: #333333;
}
.point .list_box {
  width: min(23.6vw, 340px);
  border-radius: 20px;
  overflow: hidden;
  background-color: #fff;
}
.point .list_box figure {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FCCF00;
  padding: min(2.8vw, 40px) 0 min(2vw, 30px);
}
.point .list_box figure img {
  width: 44%;
}
.point .list_box:last-child img {
  width: 82%;
}
.point .list_box h3 {
  font-size: clamp(14px, 1.7vw, 24px);
  text-align: center;
  padding-top: min(2vw, 30px);
}
.point .list_box p {
  padding: min(2vw, 30px) min(2.2vw, 32px) min(2.9vw, 42px);
}
@media screen and (max-width: 768px) {
  .point {
    padding-bottom: 15.4vw;
  }
  .point .list_block {
    gap: 10vw;
  }
  .point .list_block .list_box {
    width: 77vw;
  }
  .point .list_block .list_box figure {
    padding: 5vw 0;
  }
  .point .list_block .list_box h3 {
    font-size: 5vw;
    padding-top: 7.6vw;
  }
  .point .list_block .list_box p {
    padding: 5vw 6.4vw 10vw;
  }
}

.example {
  padding-bottom: min(5.6vw, 80px);
}
.example.sankaku::after {
  background-color: #fff;
}
.example .in .fukidashi {
  background-color: #FFFAE4;
  padding: min(2vw, 30px) 0;
}
.example .in .fukidashi::before {
  border-top: 18px solid #FFFAE4;
}
.example .in .wrap .example_block {
  border-radius: 20px;
  background-color: #F3F3F3;
  position: relative;
  padding: min(6.25vw, 90px) min(8.3%, 94px) min(4.2vw, 60px);
}
.example .in .wrap .example_block:not(:first-of-type) {
  margin-top: min(6.2vw, 90px);
}
.example .in .wrap .example_block:first-of-type {
  margin-top: min(2.8vw, 40px);
}
.example .in .wrap .example_block figure {
  width: min(7vw, 100px);
  position: absolute;
  top: max(-3.6vw, -50px);
  left: 45.6%;
}
.example .in .wrap .example_block h3 span {
  color: #000;
  font-size: min(1.7vw, 24px);
}
.example .in .wrap .example_block .txt_block {
  display: flex;
  justify-content: space-between;
}
.example .in .wrap .example_block dl {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.8vw, 12px);
  width: 38%;
  min-width: 256px;
  padding: min(1.4vw, 20px) min(2vw, 30px);
  background-color: #fff;
  font-size: clamp(11px, 1.1vw, 16px);
  line-height: 2.2em;
}
.example .in .wrap .example_block dt {
  width: 30%;
  text-align: center;
  background-color: #333;
  border-radius: 70px;
  color: #fff;
}
.example .in .wrap .example_block dd {
  width: 64%;
}
.example .in .wrap .example_block .list_block {
  flex-wrap: nowrap;
  justify-content: space-between;
}
.example .in .wrap .example_block .list_block .list_box {
  width: 24%;
  padding: min(4.2vw, 60px) min(2vw, 30px) min(2vw, 30px);
  background-color: #fff;
  border-radius: 20px;
  position: relative;
  margin-top: min(7vw, 100px);
  border: solid 4px #777777;
}
.example .in .wrap .example_block .list_block .list_box h4 {
  font-size: clamp(12px, 1.4vw, 20px);
  font-weight: 700;
  width: min(5.6vw, 80px);
  line-height: min(5.6vw, 80px);
  text-align: center;
  border-radius: 50%;
  background-color: #777777;
  margin: 0 auto;
  color: #fff;
  position: absolute;
  top: -3vw;
  left: 37%;
}
.example .in .wrap .example_block .list_block .list_box p::before {
  content: "";
  display: block;
  width: min(3.9vw, 56px);
  height: min(3.9vw, 56px);
  background: url(../images/icon_teian.png) no-repeat center;
  background-size: contain;
  margin: 0 auto min(1.4vw, 20px);
}
.example .in .wrap .example_block .list_block .list_box ul::before {
  content: "";
  display: block;
  width: min(3.5vw, 50px);
  height: min(3.5vw, 50px);
  background: url(../images/icon_worries.png) no-repeat center;
  background-size: contain;
  margin: 0 auto min(1.4vw, 20px);
}
.example .in .wrap .example_block .list_block .list_box ul li {
  position: relative;
  padding-left: 0.6em;
  font-size: clamp(12px, 1.25vw, 18px);
}
.example .in .wrap .example_block .list_block .list_box ul li:before {
  border-radius: 50%;
  width: min(2.8vw, 4px);
  height: min(2.8vw, 4px);
  display: block;
  position: absolute;
  left: 0;
  top: 0.6em;
  content: "";
  background: #777777;
}
.example .in .wrap .example_block .list_block .list_box ul li .forange {
  font-weight: 700;
}
.example .in .wrap .example_block .list_block .list_box:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: max(-2.6vw, -33px);
  width: min(1.1vw, 16px);
  height: min(1.4vw, 20px);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background-color: #777777;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(2) {
  border: solid 4px #FCCF00;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(2)::after {
  background-color: #FCCF00;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(2) h4 {
  background-color: #FCCF00;
  color: #333333;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(2) ul::before {
  width: min(3.9vw, 56px);
  height: min(3.9vw, 56px);
  background: url(../images/icon_teian.png) no-repeat center;
  background-size: contain;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(2) ul li:before {
  background: #FCCF00;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(3) {
  border: solid 4px #FC7700;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(3) h4 {
  background-color: #FC7700;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(3) ul::before {
  width: min(4.2vw, 60px);
  height: min(3.5vw, 50px);
  background: url(../images/icon_hanamaru.png) no-repeat center;
  background-size: contain;
}
.example .in .wrap .example_block .list_block .list_box:nth-of-type(3) ul li:before {
  background: #FC7700;
}
@media screen and (max-width: 768px) {
  .example {
    padding-bottom: 15.4vw;
  }
  .example .in .fukidashi {
    padding: 7.6vw 0;
  }
  .example .in .fukidashi::before {
    margin-left: -3vw;
    border: 3vw solid transparent;
    border-top: 4.6vw solid #FFFAE4;
  }
  .example .in .wrap .example_block {
    padding: 20vw 5vw 10vw;
  }
  .example .in .wrap .example_block:not(:first-of-type) {
    margin-top: 23vw;
  }
  .example .in .wrap .example_block:first-of-type {
    margin-top: 12.8vw;
  }
  .example .in .wrap .example_block figure {
    width: 25.6vw;
    top: -12.8vw;
    left: 33.3vw;
  }
  .example .in .wrap .example_block .txt_block {
    display: block;
    margin-bottom: 18vw;
  }
  .example .in .wrap .example_block .txt_block h3 {
    margin-bottom: 7.6vw;
  }
  .example .in .wrap .example_block .txt_block h3 span {
    font-size: 5vw;
  }
  .example .in .wrap .example_block .txt_block dl {
    width: 92%;
    margin: 0 auto;
    min-width: unset;
    padding: 3.6vw 3vw;
    font-size: 3.6vw;
    gap: 2.6vw;
  }
  .example .in .wrap .example_block .txt_block dl dt {
    width: 29%;
    border-radius: 18vw;
  }
  .example .in .wrap .example_block .txt_block dl dd {
    width: 67%;
  }
  .example .in .wrap .example_block .list_block {
    display: block;
  }
  .example .in .wrap .example_block .list_block .list_box {
    width: 59%;
    margin: 0 auto;
    padding: 12.8vw 7.6vw 7.6vw;
    border: solid 1vw #777777;
  }
  .example .in .wrap .example_block .list_block .list_box p::before {
    width: 14.3vw;
    height: 14.3vw;
  }
  .example .in .wrap .example_block .list_block .list_box:nth-of-type(2) {
    border: solid 1vw #FCCF00;
  }
  .example .in .wrap .example_block .list_block .list_box:nth-of-type(2) ul::before {
    width: 14.3vw;
    height: 14.3vw;
  }
  .example .in .wrap .example_block .list_block .list_box:nth-of-type(3) {
    border: solid 1vw #FC7700;
  }
  .example .in .wrap .example_block .list_block .list_box:nth-of-type(3) ul::before {
    width: 15.4vw;
    height: 12.8vw;
  }
  .example .in .wrap .example_block .list_block .list_box:not(:last-of-type) {
    margin-bottom: 19vw;
  }
  .example .in .wrap .example_block .list_block .list_box:not(:last-child)::after {
    width: 5vw;
    height: 4.1vw;
    clip-path: polygon(0 0, 100% 0%, 50% 100%);
    top: unset;
    bottom: -8.7vw;
    right: 44%;
  }
  .example .in .wrap .example_block .list_block .list_box h4 {
    font-size: 4.6vw;
    width: 18vw;
    line-height: 18vw;
    top: -9vw;
  }
  .example .in .wrap .example_block .list_block .list_box ul::before {
    width: 12.8vw;
    height: 12.8vw;
  }
  .example .in .wrap .example_block .list_block .list_box ul li {
    font-size: 4vw;
  }
  .example .in .wrap .example_block .list_block .list_box ul li::before {
    width: 1vw;
    height: 1vw;
  }
  .example .in .wrap .example_block .list_block .list_box p {
    font-size: 4vw;
  }
}

.faq {
  padding-bottom: min(5.6vw, 80px);
  background-color: #FFFAE4;
}
.faq .in {
  margin: 0 auto;
}
.faq .in .fukidashi {
  padding: min(2vw, 30px) 0;
}
.faq .in .faq_box {
  width: 74%;
  max-width: 848px;
  margin: 0 auto;
}
.faq .in .faq_box:not(:last-child) {
  margin-bottom: min(2.8vw, 40px);
}
.faq .in .faq_box h4 {
  border: solid 4px #21A77E;
  border-radius: 20px 20px 0 0;
  background-color: #21A77E;
  font-size: clamp(12px, 1.25vw, 18px);
  color: #fff;
  height: min(6.6vw, 95px);
  padding-left: 11.5%;
  padding-right: 7.5%;
  display: flex;
  align-items: center;
}
.faq .in .faq_box h4::before {
  content: "Q";
  font-size: min(1.7vw, 24px);
  position: absolute;
  color: #21A77E;
  background-color: #fff;
  width: min(3.5vw, 50px);
  height: min(3.5vw, 50px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: max(-5%, -72px);
}
.faq .in .faq_box p {
  background-color: #fff;
  border-radius: 0 0 20px 20px;
  border: solid 4px #21A77E;
  padding: min(2vw, 30px);
  padding-left: 11.5%;
  padding-right: 7.5%;
}
.faq .in .faq_box p::before {
  content: "A";
  font-size: min(1.7vw, 24px);
  position: absolute;
  color: #fff;
  background-color: #21A77E;
  width: min(3.5vw, 50px);
  height: min(3.5vw, 50px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -0.9vw;
  margin-left: max(-5%, -72px);
}
@media screen and (max-width: 768px) {
  .faq {
    padding-bottom: 10vw;
  }
  .faq .in .ttl .fukidashi {
    padding: 7.6vw 0;
  }
  .faq .in .faq_box {
    width: 89%;
  }
  .faq .in .faq_box h4 {
    font-size: 4vw;
    height: unset;
    padding: 5vw 5vw 5vw 18vw;
    display: block;
  }
  .faq .in .faq_box h4::before {
    width: 9.2vw;
    height: 9.2vw;
    font-size: 4.6vw;
    margin-top: -1.2vw;
    margin-left: -12.8vw;
  }
  .faq .in .faq_box p {
    padding: 5vw 5vw 5vw 18vw;
    border: solid 1vw #21A77E;
  }
  .faq .in .faq_box p::before {
    width: 9.2vw;
    height: 9.2vw;
    font-size: 4.6vw;
    margin-top: -1.2vw;
    margin-left: -12.8vw;
  }
}

footer {
  background-color: #F0F0F0;
  padding: min(1.7vw, 25px) 0;
  text-align: center;
}
footer p {
  font-size: clamp(10px, 0.9vw, 13px);
}
@media screen and (max-width: 768px) {
  footer {
    padding: 6.6vw 0;
  }
  footer p {
    font-size: 3.3vw;
  }
}

.smp {
  display: none;
}

.pc {
  display: block;
}

@media screen and (max-width: 768px) {
  .smp {
    display: block;
  }
  .pc {
    display: none;
  }
  header nav.pc {
    display: none;
  }
}
/*スマホドロワーメニュー*/
header .hamburger {
  position: absolute;
  position: fixed;
  top: 2.6vw;
  right: 5vw;
  z-index: 100;
}

header .menu {
  transition: 0.4s ease-in-out;
}
header .menu.smp {
  display: block;
  width: 100%;
  height: 100%;
  z-index: 999999;
  background-color: #E2F5F1;
  position: absolute;
  position: fixed;
  top: 0;
  right: -100%;
  font-size: 4.6vw;
}
header .menu.smp .top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 5vw 0;
  margin-bottom: 20.5vw;
}
header .menu.smp .top .logo {
  width: 51vw;
  position: unset;
}
header .menu.smp .top .close {
  width: 12.8vw;
  height: auto;
  display: flex;
  align-items: center;
}
header .menu.smp ul li {
  text-align: center;
  margin-bottom: 10vw;
}
header .menu.smp ul li a {
  font-weight: 700;
  margin: 0 auto min(2.8vw, 40px);
}
header .menu.smp ul li a:last-of-type {
  width: 61.5vw;
  height: 15vw;
  font-size: 4.6vw;
}
header .menu.smp ul li a:last-of-type::before {
  width: 5.1vw;
  height: 3.8vw;
  margin: 0 2.6vw 0 0;
}

/*========= 最下部テキストリンク ===============*/
.textlink {
  text-decoration: underline;
  max-width: 90%;
  text-align: center;
  font-size: 3.4vw;
  display: block;
  margin: 40px auto 0;
}

@media (min-width: 1024px) {
  .textlink {
    max-width: inherit;
    font-size: 15px;
    margin: 20px auto 0;
  }
}/*# sourceMappingURL=style.css.map */