html {
  font-size: min(0.834vw, 10px);
}
@media (max-width: 768px) {
  html {
    font-size: min(1.334vw, 10px);
  }
}

body {
  display: grid;
  grid-template-rows: 1fr auto;
  min-height: 100dvh;
}

body, h1, h2, h3, h4, p, figure, ul, ol, dl, dt, dd {
  margin: 0;
  padding: 0;
}

ul, ol, li {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
}

input, button {
  font: inherit;
  transition: 0.2s linear;
}
input:focus, button:focus {
  transition: none;
}

img {
  max-width: 100%;
  max-height: 100%;
  vertical-align: bottom;
}

svg {
  max-width: 100%;
  max-height: 100%;
}

*, *::before, *::after {
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .pc-only {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .sp-only {
    display: none !important;
  }
}

.js-animation.fadeIn {
  opacity: 0;
  transition: opacity 0.4s linear;
}
.js-animation.fadeIn.is-animated {
  opacity: 1;
}
.js-animation.slideUpIn {
  opacity: 0;
  translate: 0 30px;
  transition: opacity 0.4s linear, translate 0.4s ease-out;
}
.js-animation.slideUpIn.is-animated {
  opacity: 1;
  translate: 0 0;
}

.globalFooter {
  position: relative;
  margin: 0 auto;
}
@media (min-width: 769px) {
  .globalFooter {
    max-width: 1200px;
  }
}

.wrapper {
  position: relative;
  width: 100%;
  letter-spacing: 0.06em;
  font-feature-settings: "palt";
  color: #662b1f;
}
.wrapper * {
  font-family: "Noto Sans JP", sans-serif;
}
.wrapper::before, .wrapper::after {
  content: "";
  position: fixed;
  width: 100%;
  height: 100%;
  inset: 0;
  pointer-events: none;
}
.wrapper::before {
  background: linear-gradient(to bottom, #f9f0b4, #f4db61);
}
.wrapper::after {
  background-image: linear-gradient(90deg, #fff7bb, #fff7bb 4rem, transparent 4rem, transparent 8rem);
  background-position: center top;
  background-repeat: repeat;
  background-size: 8rem auto;
}

.main_outer {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  background: linear-gradient(to bottom, #f9f0b4, #f4db61);
  width: 100%;
  min-height: 100%;
  margin: 0 auto;
  contain: paint;
  z-index: 2;
}
@media (min-width: 769px) {
  .main_outer {
    max-width: 1200px;
    padding: 15.3rem 0 19.1rem;
  }
}
@media (max-width: 768px) {
  .main_outer {
    padding: 18.9rem 0 17.5rem;
  }
}
.main_outer::before, .main_outer::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  left: 0;
  right: 0;
  pointer-events: none;
}
.main_outer::before {
  background-position: center top;
  top: 0;
}
@media (min-width: 769px) {
  .main_outer::before {
    background-image: url(../img/present/bg1_pc.png);
    height: 16.3rem;
  }
}
@media (max-width: 768px) {
  .main_outer::before {
    background-image: url(../img/present/bg1_sp.png);
    height: 16.7rem;
  }
}
.main_outer::after {
  background-position: center bottom;
  bottom: 0;
}
@media (min-width: 769px) {
  .main_outer::after {
    background-image: url(../img/present/bg2_pc.png);
    height: 16.3rem;
  }
}
@media (max-width: 768px) {
  .main_outer::after {
    background-image: url(../img/present/bg2_sp.png);
    height: 13.8rem;
  }
}
.main_title {
  position: relative;
}
@media (min-width: 769px) {
  .main_title {
    width: 26.2rem;
  }
}
@media (max-width: 768px) {
  .main_title {
    width: 38.7rem;
  }
}
@media (min-width: 769px) {
  .main_title + .main_box {
    margin-top: 2rem;
  }
}
@media (max-width: 768px) {
  .main_title + .main_box {
    margin-top: 2.8rem;
  }
}
.main_kome {
  position: relative;
  font-weight: 700;
}
@media (min-width: 769px) {
  .main_kome {
    padding-top: 1rem;
  }
}
@media (max-width: 768px) {
  .main_kome {
    padding-top: 3rem;
    line-height: 1.5;
    font-size: 2.4rem;
  }
  .main_kome > li {
    font: inherit;
  }
  .main_kome > li:first-of-type {
    margin-top: -0.25em;
  }
  .main_kome > li:last-of-type {
    margin-bottom: -0.25em;
  }
}
.main_kome > li {
  padding-left: 1em;
  text-indent: -1em;
}
@media (min-width: 769px) {
  .main_kome + .main_box {
    margin-top: 2rem;
  }
}
@media (max-width: 768px) {
  .main_kome + .main_box {
    margin-top: 4rem;
  }
}
.main_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  background: #fff;
}
@media (min-width: 769px) {
  .main_box {
    border-radius: 1rem;
    width: 80rem;
    min-height: 34.7rem;
    padding: 4rem;
  }
}
@media (max-width: 768px) {
  .main_box {
    border-radius: 2rem;
    width: 65rem;
    min-height: 48.6rem;
    padding: 6rem 0;
  }
}
.main_lead {
  font-weight: 700;
  text-align: center;
}
@media (min-width: 769px) {
  .main_lead {
    line-height: 1.773;
    font-size: 2.2rem;
  }
  .main_lead > p {
    font: inherit;
  }
  .main_lead > p:first-of-type {
    margin-top: -0.386em;
  }
  .main_lead > p:last-of-type {
    margin-bottom: -0.386em;
  }
}
@media (max-width: 768px) {
  .main_lead {
    line-height: 1.688;
    font-size: 3.2rem;
  }
  .main_lead > p {
    font: inherit;
  }
  .main_lead > p:first-of-type {
    margin-top: -0.343em;
  }
  .main_lead > p:last-of-type {
    margin-bottom: -0.343em;
  }
}
.main_list {
  font-weight: 700;
}
@media (min-width: 769px) {
  .main_list {
    width: 100%;
    line-height: 1.438;
    font-size: 1.6rem;
  }
  .main_list > li {
    font: inherit;
  }
  .main_list > li:first-of-type {
    margin-top: -0.218em;
  }
  .main_list > li:last-of-type {
    margin-bottom: -0.218em;
  }
}
@media (max-width: 768px) {
  .main_list {
    line-height: 1.6;
    font-size: 3rem;
  }
  .main_list > li {
    font: inherit;
  }
  .main_list > li:first-of-type {
    margin-top: -0.3em;
  }
  .main_list > li:last-of-type {
    margin-bottom: -0.3em;
  }
}
@media (min-width: 769px) {
  .main_list small {
    font-size: inherit;
  }
}
@media (max-width: 768px) {
  .main_list small {
    font-size: 0.867em;
  }
}