@charset "UTF-8";

/*-------------------------
  reset
-------------------------*/
body {
  font-family: "Yu Gothic", "YuGothic", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Arial, sans-serif;
}
*,
:after,
:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
blockquote,
body,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
p {
  margin: 0;
}
ol,
ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
ol[role="list"],
ul[role="list"] {
  list-style: none;
}
html {
  scroll-behavior: auto;
  scroll-behavior: smooth;
  overflow-x: hidden;
}
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
}
a {
  outline: none;
  text-decoration: none;
}
a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}
img,
picture {
  width: 100%;
  height: auto;
  display: block;
}
button,
input,
select,
textarea {
  font: inherit;
}
summary::-webkit-details-marker {
  display: none;
}
/*-------------------------
  settings
-------------------------*/
:root {
  --main-color: #e6f5f5;
  --txt-color: #584d39;
  --bg-color: #a5977e;
  --bg2-color: #f5f5f5;
  --accent-color: #46a3bb;
  --border-color: #d0c9bd;
}

/*-------------------------
  common
-------------------------*/
.sp-only {
  display: block !important;
}
@media screen and (min-width: 768px) {
  .sp-only {
    display: none !important;
  }
}
.pc-only {
  display: none !important;
}
@media screen and (min-width: 768px) {
  .pc-only {
    display: block !important;
  }
}
/* head
-------------------------*/
.c-head {
  font-family: "Shippori Mincho B1";
  font-weight: 700;
  font-size: calc(22 / 375 * 100vw);
  letter-spacing: 0.06em;
  line-height: 1.8;
  text-align: center;
  color: var(--txt-color);
}
@media screen and (min-width: 768px) {
  .c-head {
    font-size: min(calc(36 / 1366 * 100vw), 36px);
    line-height: 1.4;
  }
}
.c-head--w {
  color: #fff;
}
.c-head--line {
  color: #fff;
  max-width: max-content;
  margin: auto;
  border-bottom: solid 2px #fff;
}
/* c-head2 */
.c-head2 {
  margin-bottom: calc(16 / 375 * 100vw);
  font-family: "Shippori Mincho B1";
  font-weight: 600;
  font-size: calc(18 / 375 * 100vw);
  line-height: 1.8;
  letter-spacing: -0.02em;
  text-align: center;
  color: var(--txt-color);
}
.c-head2--middle {
  font-size: calc(16 / 375 * 100vw);
}
.c-head2--small {
  font-size: calc(15 / 375 * 100vw);
  line-height: 1.4;
}
.c-head2--triangle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(4 / 375 * 100vw);
  font-size: calc(15 / 375 * 100vw);
}
.c-head2--triangle:after {
  content: "";
  width: calc(10 / 375 * 100vw);
  height: calc(7 / 375 * 100vw);
  background-color: var(--bg-color);
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
@media screen and (min-width: 768px) {
  .c-head2 {
    margin-bottom: min(calc(30 / 1366 * 100vw), 30px);
    font-size: min(calc(30 / 1366 * 100vw), 30px);
    line-height: 1.4;
  }
  .c-head2--middle {
    font-size: min(calc(24 / 1366 * 100vw), 24px);
  }
  .c-head2--small {
    font-size: min(calc(20 / 1366 * 100vw), 20px);
  }
  .c-head2--triangle {
    gap: min(calc(8 / 1366 * 100vw), 8px);
    font-size: min(calc(20 / 1366 * 100vw), 20px);
  }
  .c-head2--triangle:after {
    width: min(calc(13 / 1366 * 100vw), 13px);
    height: min(calc(8 / 1366 * 100vw), 8px);
  }
}
.c-head2--w {
  color: #fff;
}
.c-head3 {
  font-family: "Shippori Mincho B1";
  font-weight: 600;
  font-size: calc(16 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .c-head3 {
    font-size: min(calc(22 / 1366 * 100vw), 22px);
  }
}
.c-head4 {
  padding: 8px;
  font-family: "Shippori Mincho B1";
  font-weight: 500;
  font-size: calc(16 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
  background-color: var(--accent-color);
}
.c-head5 {
  padding: 4px;
  font-family: "Crimson Text";
  font-weight: normal;
  font-size: calc(24 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
  background-color: var(--bg-color);
}
@media screen and (min-width: 768px) {
  .c-head5 {
    padding: min(calc(12 / 1366 * 100vw), 12px);
    font-size: min(calc(30 / 1366 * 100vw), 30px);
  }
}
.c-head6 {
  padding: 2px;
  font-family: "Shippori Mincho B1";
  font-weight: 500;
  font-size: calc(16 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
  background-color: var(--accent-color);
}
.c-head6--small {
  font-size: calc(14 / 375 * 100vw);
  letter-spacing: -0.04em;
}
@media screen and (min-width: 768px) {
  .c-head6 {
    padding: min(calc(8 / 1366 * 100vw), 8px);
    font-size: min(calc(24 / 1366 * 100vw), 24px);
  }
}
.c-balloon-head {
  font-family: "Shippori Mincho B1";
  line-height: 1.6;
  text-align: center;
  letter-spacing: 0.06em;
}
.c-balloon-head p {
  position: relative;
  padding: 2vw 0;
  font-weight: bold;
  font-size: calc(14 / 375 * 100vw);
  color: #fff;
  background-color: var(--bg-color);
}
.c-balloon-head h2 {
  padding-top: calc(12 / 375 * 100vw);
  font-size: calc(22 / 375 * 100vw);
  text-align: center;
  color: var(--txt-color);
}
.c-balloon-head p::after {
  position: absolute;
  content: "";
  inset: 0;
  bottom: calc(-11 / 375 * 100vw);
  margin: auto auto 0;
  background-color: var(--bg-color);
  width: calc(22 / 375 * 100vw);
  height: calc(12 / 375 * 100vw);
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
@media screen and (min-width: 768px) {
  .c-balloon-head p {
    max-width: max-content;
    margin: auto;
    padding: min(calc(8 / 1366 * 100vw), 8px) min(calc(60 / 1366 * 100vw), 60px);
    font-size: min(calc(26 / 1366 * 100vw), 26px);
  }
  .c-balloon-head h2 {
    padding-top: min(calc(16 / 1366 * 100vw), 16px);
    font-size: min(calc(36 / 1366 * 100vw), 36px);
  }
  .c-balloon-head p::after {
    bottom: -13px;
    width: 28px;
    height: 14px;
  }
}
.c-border-head {
  margin: 9vw auto 4vw;
  font-family: "Shippori Mincho B1";
  font-weight: 600;
  font-size: calc(18 / 375 * 100vw);
  letter-spacing: 0.06em;
  line-height: 2;
  text-align: center;
  color: var(--txt-color);
  border-top: solid 1px var(--accent-color);
  border-bottom: solid 1px var(--accent-color);
}
@media screen and (min-width: 768px) {
  .c-border-head {
    margin: 26px auto 34px;
    padding: min(calc(4 / 1366 * 100vw), 4px);
    font-size: min(calc(24 / 1366 * 100vw), 24px);
  }
}
.c-underline-head {
  max-width: max-content;
  margin: auto;

  font-weight: 500;
  font-size: calc(18 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  border-bottom: solid 2px #fff;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .c-underline-head {
    font-size: 26px;
  }
}
.c-center-head {
  position: relative;
  margin: 0 auto 2vw;
  font-weight: bold;
  font-size: calc(18 / 375 * 100vw);
  letter-spacing: 0.06em;
  text-align: center;
  color: var(--txt-color);
}
.c-center-head:before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background-color: var(--txt-color);
}
.c-center-head span {
  position: relative;
  padding: 0 8px;
  background-color: #fff;
}
.c-center-head--en {
  font-family: "Crimson Text";
  font-weight: normal;
  font-size: calc(25 / 375 * 100vw);
  color: var(--accent-color);
}
.c-center-head--en:before {
  background-color: var(--accent-color);
}
@media screen and (min-width: 768px) {
  .c-center-head {
    margin-bottom: 16px;
  }
  .c-center-head {
    font-size: 26px;
  }
  .c-center-head--en {
    font-size: 32px;
  }
}
/* text
-------------------------*/
.c-txt {
  font-weight: 500;
  font-size: calc(16 / 375 * 100vw);
  letter-spacing: 0.04em;
  line-height: 2;
  color: var(--txt-color);
}
.c-txt--w {
  color: #fff;
}
.c-txt--c {
  text-align: center;
}
.c-txt--small {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.8;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 768px) {
  .c-txt {
    font-size: min(calc(18 / 1366 * 100vw), 18px);
  }
  .c-txt--small {
    font-size: min(calc(16 / 1366 * 100vw), 16px);
  }
}
/* button
-------------------------*/
.c-button {
  width: 130%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Shippori Mincho B1";
  font-size: calc(16 / 375 * 100vw);
  font-weight: 600;
  letter-spacing: 0.06em;
  border-radius: 100vmax;
  color: #fff;
  background-color: var(--accent-color);
  cursor: pointer;
  transition: opacity 0.2s ease-in;
  text-align: center;
  padding: .6vw;
  white-space: nowrap;
}

.c-button:after {
  content: "";
  width: calc(7 / 375 * 100vw);
  height: calc(10 / 375 * 100vw);
  margin-left: calc(8 / 375 * 100vw);
  background-color: currentColor;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
}
@media (any-hover: hover) {
  .c-button:hover {
    opacity: 0.7;
  }
}
@media screen and (min-width: 768px) {
  .c-button {
    font-size: min(calc(20 / 1366 * 100vw), 20px);
  }
  .c-button:after {
    width: min(calc(12 / 1366 * 100vw), 12px);
    height: min(calc(18 / 1366 * 100vw), 18px);
    margin-left: min(calc(16 / 1366 * 100vw), 16px);
  }
}
/* check-box
-------------------------*/
.check-box {
  border: solid 1px var(--txt-color);
  padding: calc(18 / 375 * 100vw) calc(14 / 375 * 100vw);
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .check-box {
    padding: min(calc(26 / 1366 * 100vw), 26px) min(calc(22 / 1366 * 100vw), 22px);
  }
}
/* triangle
-------------------------*/
.triangle {
  display: block;
  position: relative;
}
.triangle::after {
  position: absolute;
  display: block;
  content: "";
  inset: 0;
  margin: 7.8vw auto;
  background-color: var(--bg-color);
  width: calc(62 / 375 * 100vw);
  height: calc(16 / 375 * 100vw);
}
.triangle--upside-down::after {
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.triangle p {
  margin: 1vw auto 8vw;
}
@media screen and (min-width: 768px) {
  .triangle::after {
    margin: min(calc(40 / 1366 * 100vw), 40px) auto;
    width: min(calc(170 / 1366 * 100vw), 170px);
    height: min(calc(44 / 1366 * 100vw), 44px);
  }
  .triangle p {
    margin: 24px auto 70px;
    text-align: center;
  }
}
/* list-item
-------------------------*/
.list-item {
  font-weight: 700;
  font-size: calc(16 / 375 * 100vw);
  line-height: 130%;
  color: var(--txt-color);
}
.list-item--check {
  padding-left: calc(24 / 375 * 100vw);
  background: url("../img/c-check.png") left center / calc(16 / 375 * 100vw) calc(16 / 375 * 100vw) no-repeat;
}
@media screen and (min-width: 768px) {
  .list-item {
    font-size: min(calc(18 / 1366 * 100vw), 18px);
  }
  .list-item span {
    padding-left: min(calc(30 / 1366 * 100vw), 30px);
  }
  .list-item--check {
    padding-left: min(calc(30 / 1366 * 100vw), 30px);
    background-size: min(calc(20 / 1366 * 100vw), 20px);
  }
}
/* c-img
-------------------------*/
.c-img,
.c-img-small,
.c-img-middle {
  max-width: 100%;
  margin: auto;
}
@media screen and (min-width: 768px) {
  .c-img {
    max-width: min(calc(700 / 1366 * 100vw), 700px);
  }
  .c-img-small {
    max-width: min(calc(490 / 1366 * 100vw), 490px);
  }
  .c-img-middle {
    max-width: min(calc(540 / 1366 * 100vw), 540px);
  }
}
/* c-box, grid, etc
-------------------------*/
.c-box {
  padding: 6px;
  background-color: #fff;
}
.c-grid {
  display: grid;
  gap: 6px;
}
.c-grid--2 {
  grid-template-columns: repeat(2, 1fr);
}
.c-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}
.c-grid--5 {
  grid-template-columns: repeat(5, 1fr);
}
.c-col__item {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 4px;
  font-family: "Shippori Mincho B1";
  font-weight: 500;
  font-size: calc(10 / 375 * 100vw);
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-align: center;
  color: var(--txt-color);
  background-color: var(--bg2-color);
}
.c-col__item .head {
  width: 38vw;
  margin-bottom: 8px;
  display: inline-block;
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.6;
  border-top: 1px solid var(--txt-color);
  border-bottom: 1px solid var(--txt-color);
}
.c-col__item .border {
  margin-bottom: 8px;
  border-bottom: 1px solid var(--txt-color);
}
.c-col__item .bg {
  padding: 0 4px;
  margin-right: 8px;
  color: #fff;
  background-color: var(--bg-color);
}
.c-col__item .num {
  font-size: calc(23 / 375 * 100vw);
  vertical-align: sub;
}
.c-col__item .note {
  font-size: calc(10 / 375 * 100vw);
	display: block;
}
@media screen and (min-width: 768px) {
  .c-col__item {
    padding: min(calc(30 / 1366 * 100vw), 30px) 0;
    font-size: min(calc(22 / 1366 * 100vw), 22px);
  }
  .c-col__item .head {
    width: min(calc(420 / 1366 * 100vw), 420px);
    font-size: min(calc(22 / 1366 * 100vw), 22px);
    line-height: 2;
  }
  .c-col__item .num {
    font-size: min(calc(44 / 1366 * 100vw), 44px);
  }
  .c-col__item .small {
    font-size: min(calc(20 / 1366 * 100vw), 20px);
  }
  .c-col__item .note {
    font-size: min(calc(13 / 1366 * 100vw), 13px);
  }	
}
/*-------------------------
  helper css
-------------------------*/
.mt-1 {
  margin-top: calc(10 / 375 * 100vw);
}
.mt-2 {
  margin-top: calc(20 / 375 * 100vw);
}
.mt-3 {
  margin-top: calc(30 / 375 * 100vw);
}
.mt-4 {
  margin-top: calc(40 / 375 * 100vw);
}
.mt-5 {
  margin-top: calc(50 / 375 * 100vw);
}
.mt-6 {
  margin-top: calc(60 / 375 * 100vw);
}
.mb-1 {
  margin-bottom: calc(10 / 375 * 100vw);
}
.mb-2 {
  margin-bottom: calc(20 / 375 * 100vw);
}
.mb-3 {
  margin-bottom: calc(30 / 375 * 100vw);
}
.mb-4 {
  margin-bottom: calc(40 / 375 * 100vw);
}
.mb-5 {
  margin-bottom: calc(50 / 375 * 100vw);
}
.mb-6 {
  margin-bottom: calc(60 / 375 * 100vw);
}
@media screen and (min-width: 768px) {
  .mt-1 {
    margin-top: min(calc(10 / 1336 * 100vw), 10px);
  }
  .mt-2 {
    margin-top: min(calc(20 / 1336 * 100vw), 20px);
  }
  .mt-3 {
    margin-top: min(calc(30 / 1336 * 100vw), 30px);
  }
  .mt-4 {
    margin-top: min(calc(40 / 1336 * 100vw), 40px);
  }
  .mt-5 {
    margin-top: min(calc(50 / 1336 * 100vw), 50px);
  }
  .mt-6 {
    margin-top: min(calc(60 / 1336 * 100vw), 60px);
  }
  .mb-1 {
    margin-bottom: min(calc(10 / 1336 * 100vw), 10px);
  }
  .mb-2 {
    margin-bottom: min(calc(20 / 1336 * 100vw), 20px);
  }
  .mb-3 {
    margin-bottom: min(calc(30 / 1336 * 100vw), 30px);
  }
  .mb-4 {
    margin-bottom: min(calc(40 / 1336 * 100vw), 40px);
  }
  .mb-5 {
    margin-bottom: min(calc(50 / 1336 * 100vw), 50px);
  }
  .mb-6 {
    margin-bottom: min(calc(60 / 1336 * 100vw), 60px);
  }
}
