/**
 * uaplus.css version 0.0.1
 */
*, *::after, *::before {
  box-sizing: border-box;
}

:focus-visible {
  outline-offset: 3px;
}

:where(html) {
  -webkit-text-size-adjust: none;
  -moz-text-size-adjust: none;
       text-size-adjust: none;
}

:where(html) {
  line-height: 1.5;
}

:where(html) {
  scrollbar-gutter: stable;
}

:where(h1) {
  font-size: 2em;
  margin-block: 0.67em;
}

:where(abbr[title]) {
  cursor: help;
  text-decoration-line: underline;
  text-decoration-style: dotted;
}

@media (forced-colors: active) {
  mark {
    color: HighlightText;
    background-color: Highlight;
  }
}
:where(del, ins, s)::before, :where(del, ins, s)::after {
  -webkit-clip-path: inset(100%);
          clip-path: inset(100%);
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  width: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  content: "test";
}

:where(s)::before {
  content: "stricken text start ";
}

:where(s)::after {
  content: " stricken text end";
}

:where(del)::before {
  content: "deletion start ";
}

:where(del)::after {
  content: " deletion end";
}

:where(ins)::before {
  content: "insertion start ";
}

:where(ins)::after {
  content: " insertion end";
}

:where(audio, iframe, img, svg, video) {
  max-block-size: 100%;
  max-inline-size: 100%;
}

:where(fieldset) {
  min-inline-size: 0;
}

:where(label):has(+ :where(textarea, input, select)) {
  display: block;
}

:where(textarea:not([rows])) {
  min-block-size: 6em;
}

:where(button, input, select, textarea) {
  font-family: inherit;
  font-size: inherit;
}

:where([type=search]) {
  -webkit-appearance: textfield;
}

@supports (-webkit-touch-callout: none) {
  :where([type=search]) {
    border: 1px solid -apple-system-secondary-label;
    background-color: canvas;
  }
}
:where([type=tel], [type=url], [type=email], [type=number]):not(:-moz-placeholder-shown) {
  direction: ltr;
}
:where([type=tel], [type=url], [type=email], [type=number]):not(:placeholder-shown) {
  direction: ltr;
}

:where(table) {
  border-collapse: collapse;
  border: 1px solid;
}

:where(th, td) {
  border: 1px solid;
  padding: 0.25em 0.5em;
}

:where(dialog)::backdrop {
  background: oklch(0% 0 0/0.3);
}

:where(dialog), :where(dialog)::backdrop {
  opacity: 0;
  transition: opacity 300ms ease-out, display 300ms allow-discrete, overlay 300ms allow-discrete;
}

:where(dialog[open]), :where(dialog[open])::backdrop {
  opacity: 1;
}

@starting-style {
  :where(dialog[open]), :where(dialog[open])::backdrop {
    opacity: 0;
  }
}
[hidden]:not([hidden=until-found]) {
  display: none !important;
}

body {
  margin: 0;
  background-image: url("../img/main-bg.png");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
}

section {
  text-align: center;
  padding-left: 15px;
  padding-right: 15px;
}

ul, ol {
  padding-left: 0;
}

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

header h1 {
  margin: 0;
}
header h1 img {
  width: 100%;
}

.about {
  padding: 80px 15px;
}
@media (max-width: 768px) {
  .about {
    padding: 40px 15px;
  }
}
.about h2 {
  font-size: 36px;
  font-weight: 600;
  margin-bottom: 50px;
  color: #fff;
  text-shadow: 2px 2px 10px deepskyblue, -2px 2px 10px deepskyblue, 2px -2px 10px deepskyblue, -2px -2px 10px deepskyblue;
}
@media (max-width: 768px) {
  .about h2 {
    font-size: 24px;
    margin-bottom: 30px;
  }
}
.about p {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 50px;
}
@media (max-width: 768px) {
  .about p {
    font-size: 18px;
    margin-bottom: 30px;
  }
}
.about img {
  max-width: 700px;
}

.point h2 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.point h2 img {
  max-width: 700px;
}
@media (max-width: 768px) {
  .point h2 {
    font-size: 24px;
  }
}
.point ul {
  padding: 0;
  max-width: 800px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  margin: 0 auto 20px;
  list-style: none;
}
.point ul li {
  width: 100%;
  position: relative;
  padding: 15px;
  background-image: url("../img/point-frame-x.svg"), url("../img/point-frame-x.svg");
  background-repeat: repeat-x;
  background-position: left top, left bottom;
  background-size: auto 15px, auto 15px;
}
.point ul li h3 {
  font-size: 36px;
  font-weight: 500;
  margin-bottom: 20px;
}
@media (max-width: 768px) {
  .point ul li h3 {
    font-size: 24px;
    margin-bottom: 10px;
  }
}
.point ul li h4 {
  height: 60px;
  margin-top: 20px;
  margin-bottom: 0;
  background-image: url("../img/ribbon.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  font-size: 30px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  color: white;
}
@media (max-width: 768px) {
  .point ul li h4 {
    margin-top: 10px;
    font-size: 15px;
    height: 30px;
  }
}
.point ul li h5 {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: -10px;
  margin-bottom: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 26px;
}
@media (max-width: 768px) {
  .point ul li h5 {
    font-size: 14px;
  }
}
.point ul li h5 img {
  max-width: 320px;
}
@media (max-width: 768px) {
  .point ul li h5 img {
    max-width: 160px;
  }
}
.point ul li P {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
}
@media (max-width: 768px) {
  .point ul li P {
    font-size: 14px;
  }
}
.point ul li P strong {
  font-weight: 700;
  font-size: 30px;
  text-shadow: 3px 3px #99FFFF;
}
@media (max-width: 768px) {
  .point ul li P strong {
    font-size: 20px;
  }
}
.point ul li P b {
  font-weight: 700;
  font-size: 24px;
  text-shadow: 3px 3px #99FFFF;
}
@media (max-width: 768px) {
  .point ul li P b {
    font-size: 16px;
  }
}
.point ul li:before, .point ul li:after {
  content: "";
  display: block;
  position: absolute;
  top: 15px;
  width: 15px;
  height: calc(100% - 30px);
  background-image: url("../img/point-frame-y.svg");
  background-repeat: repeat-y;
}
.point ul li:before {
  left: -1px;
}
.point ul li:after {
  right: -1px;
}
.point ul li > div {
  border: 5px solid #dfbe70;
  margin: 5px;
  position: relative;
}
.point ul li > div:before, .point ul li > div:after {
  position: absolute;
  content: "";
  display: block;
  width: 75px;
  height: 75px;
  top: 25px;
  background-image: url("../img/point-frame-inner.svg");
}
@media (max-width: 768px) {
  .point ul li > div:before, .point ul li > div:after {
    top: 15px;
  }
}
.point ul li > div:before {
  left: 25px;
}
@media (max-width: 768px) {
  .point ul li > div:before {
    left: 15px;
  }
}
.point ul li > div:after {
  right: 25px;
  transform: rotate(90deg);
}
@media (max-width: 768px) {
  .point ul li > div:after {
    right: 15px;
  }
}
.point ul li > div > div {
  border: 1.5px solid #dfbe70;
  margin: 5px;
  padding: 25px;
}
@media (max-width: 768px) {
  .point ul li > div > div {
    padding: 15px;
  }
}
.point ul li > div > div:before, .point ul li > div > div:after {
  position: absolute;
  content: "";
  display: block;
  width: 75px;
  height: 75px;
  bottom: 25px;
  background-image: url("../img/point-frame-inner.svg");
}
@media (max-width: 768px) {
  .point ul li > div > div:before, .point ul li > div > div:after {
    bottom: 15px;
  }
}
.point ul li > div > div:before {
  left: 25px;
  transform: rotate(270deg);
}
@media (max-width: 768px) {
  .point ul li > div > div:before {
    left: 15px;
  }
}
.point ul li > div > div:after {
  right: 25px;
  transform: rotate(180deg);
}
@media (max-width: 768px) {
  .point ul li > div > div:after {
    right: 15px;
  }
}
.point img {
  display: block;
  margin: 0 auto;
}

.creator {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 50px;
}
@media (max-width: 768px) {
  .creator {
    margin-top: 30px;
  }
}
.creator h2 {
  font-weight: 600;
  font-size: 36px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.creator h2 img {
  max-width: 700px;
}
@media (max-width: 768px) {
  .creator h2 {
    font-size: 24px;
  }
}
.creator h3 {
  font-size: 24px;
}
@media (max-width: 768px) {
  .creator h3 {
    font-size: 18px;
  }
}
.creator dl {
  font-size: 24px;
  text-align: left;
  font-weight: 600;
}
.creator dl dd {
  margin-left: 0;
  margin-bottom: 30px;
}
@media (max-width: 768px) {
  .creator dl {
    font-size: 16px;
  }
}

.flow {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.flow h2 {
  font-weight: 600;
  font-size: 36px;
  min-width: 700px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.flow h2 img {
  max-width: 700px;
}
@media (max-width: 768px) {
  .flow h2 {
    min-width: auto;
    font-size: 24px;
  }
}
.flow ul {
  text-align: left;
  font-size: 24px;
  font-weight: 600;
}
@media (max-width: 768px) {
  .flow ul {
    font-size: 16px;
    padding-left: 1em;
  }
}
.flow ol {
  list-style: none;
  text-align: left;
  font-size: 24px;
  font-weight: 600;
}
@media (max-width: 768px) {
  .flow ol {
    font-size: 16px;
  }
}
.flow h3 {
  font-size: 36px;
}
@media (max-width: 768px) {
  .flow h3 {
    font-size: 24px;
  }
}

.faq {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.faq h2 {
  font-weight: 600;
  font-size: 22px;
}
@media (max-width: 768px) {
  .faq h2 {
    font-size: 18px;
  }
}
.faq dl {
  font-size: 20px;
  text-align: left;
  font-weight: 600;
}
@media (max-width: 768px) {
  .faq dl {
    font-size: 16px;
  }
}
.faq dl dt {
  display: flex;
}
.faq dl dt:before {
  content: "Q.";
  margin-right: 5px;
}
.faq dl dd {
  display: flex;
  margin-left: 0;
  margin-bottom: 15px;
}
.faq dl dd:before {
  content: "A.";
  margin-right: 5px;
}

footer {
  position: relative;
}
footer img:first-child {
  width: 100%;
}
footer img:nth-child(2) {
  max-width: 400px;
  position: absolute;
  bottom: 70px;
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 768px) {
  footer img:nth-child(2) {
    bottom: auto;
    top: 30px;
  }
}
footer address {
  position: absolute;
  bottom: 0;
  width: 100%;
}
footer address ul {
  display: flex;
  justify-content: center;
  list-style: none;
  font-style: normal;
  gap: 20px;
  font-size: 20px;
  font-weight: 600;
}
@media (max-width: 768px) {
  footer address ul {
    flex-direction: column;
    font-size: 13px;
    gap: 0;
    align-items: center;
  }
}
footer address ul li {
  background-color: rgba(255, 255, 255, 0.7);
  padding-left: 0.5em;
  padding-right: 0.5em;
}

.entry-form {
  padding-top: 60px;
  padding-bottom: 60px;
  text-align: left;
}
.entry-form-inner {
  max-width: 900px;
  margin: 0 auto;
}
.entry-form h2 {
  text-align: center;
}
.entry-form-box {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 50px;
  font-size: 1.2em;
  font-weight: bold;
}
@media (max-width: 550px) {
  .entry-form-box {
    padding: 0px;
  }
}
.entry-form-box label {
  margin-top: 30px;
  display: flex;
  margin-bottom: 5px;
  align-items: center;
}
.entry-form-box input[type=text], .entry-form-box input[type=email], .entry-form-box input[type=url], .entry-form-box select {
  width: 100%;
  padding: 15px;
}
.entry-form-box textarea {
  width: 100%;
}
.entry-form-box input[type=checkbox] {
  margin-right: 10px;
}
.entry-form-box input[type=file] {
  max-width: 100%;
}
.entry-form-badge {
  font-size: 0.8em;
  background-color: white;
  display: inline-block;
  color: #0D051C;
  line-height: 1;
  padding: 5px;
  margin-left: 10px;
  border-radius: 4px;
}
.entry-form-button {
  display: inline-block;
  background-color: white;
  padding: 20px 40px;
  color: #222;
  text-decoration: none;
}
.entry-form-button-area {
  text-align: center;
  margin-top: 40px;
  margin-bottom: 40px;
}
.entry-form-button:last-child {
  margin-left: 10px;
}
.entry-form-policy {
  font-size: 0.6em;
  line-height: 1.4;
  text-align: left;
}

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}/*# sourceMappingURL=style.css.map */