
@charset "UTF-8";
:root {
  --font-size: 16px;
}
*,
*:before,
*:after {
  box-sizing: border-box;
}
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure {
  margin: 0;
}
ul,
ol {
  list-style: none;
  padding: 0;
}
img,
picture {
  max-width: 100%;
  display: block;
}
a {
  text-decoration: none;
  color: inherit;
}
button {
  padding: 0;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: none;
}
@media (hover: hover) {
  button {
    cursor: pointer;
  }
}
dialog {
  padding: 0;
  border: none;
  color: inherit;
  max-width: none;
  max-height: none;
}
dialog * {
  outline: none;
}
.l-page_wrapper {
  margin-left: 50px;
}
@media (max-width: 750.999px) {
  .l-page_wrapper {
    margin-left: 40px;
  }
}
.l-content {
  max-width: 1270px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  box-sizing: content-box;
}
@media (max-width: 750.999px) {
  .l-content {
    padding-left: 18px;
    padding-right: 18px;
  }
}
.l-content_inner {
  max-width: 1180px;
}
.footer {
  position: relative;
  color: #fff;
  text-align: center;
  padding-top: 40px;
}
@media (max-width: 750.999px) {
  .footer {
    padding-bottom: 60px;
  }
}
@media (min-width: 751px) {
  .footer {
    max-width: 390px;
    margin: 0 auto;
  }
}
.footer_share-ttl {
  width: 45%;
  margin: 0 auto;
}
.footer_share ul {
  width: 65.5%;
  margin: 20px auto 50px;
  display: flex;
  justify-content: space-between;
}
.footer_share li {
  width: 16%;
}
.footer_share li a,
.footer_share li button,
.footer_share li img {
  width: 100%;
}
.footer_head {
  display: block;
  font-size: 20px;
  font-weight: 700;
}
.footer_tell {
  display: block;
  font-size: 48px;
  font-weight: 700;
  line-height: 1;
}
.footer_time {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: left;
  display: inline-block;
}
.footer_note {
  margin-top: 18px;
  font-size: 20px;
  font-weight: 700;
}
.footer_copy {
  display: block;
  margin: 40px 27px 0;
  padding: 20px 0 40px;
  border-top: solid 1px #fff;
  font-size: 10px;
  line-height: 1;
}
.footer.is-no-padding {
  padding-top: 0;
  padding-bottom: 0;
}
@media (min-width: 751px) {
  .c-cookie.is-show + .footer {
    padding-bottom: 80px;
  }
}
.c-bg-white {
  background-image: url(https://tb-2026otosidama.jp/cp001/images/bg_white.webp);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  position: relative;
}
.c-bg-white:before,
.c-bg-white:after {
  content: " ";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  pointer-events: none;
  border-style: solid;
}
.c-bg-white:before {
  border-width: 4px;
  border-color: #fff;
  width: calc(100% - 7px);
  height: calc(100% - 7px);
}
.c-bg-white:after {
  border-width: 2px;
  border-color: #000;
  width: calc(100% - 12px);
  height: calc(100% - 12px);
}
@media (max-width: 750.999px) {
  .c-bg-white {
    padding: 8px;
  }
}
@media (min-width: 751px) {
  .c-bg-white {
    padding: 16px;
  }
}
.c-bg-white--pale {
  background-image: linear-gradient(#0000000d, #00000026),
    url(https://tb-2026otosidama.jp/cp001/images/bg_white.webp);
}
.c-btn {
  display: block;
  width: 75vw;
  margin: 20px auto 0;
  max-width: 390px;
}
.c-btn + .c-btn {
  margin-top: 12px;
}
@media (min-width: 751px) {
  .c-btn {
    max-width: 280px;
  }
}
.c-btn-pulse {
  position: relative;
}
.c-btn-pulse img {
  position: relative;
  z-index: 1;
}
.c-btn-pulse:before {
  content: " ";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 0;
  border-radius: 50%;
  animation-name: pulse;
  animation-duration: 1.2s;
  animation-timing-function: ease-out;
  animation-iteration-count: infinite;
}
.c-btn.c-btn-pulse:before {
  border-radius: 50px;
  animation-name: pulse-rectangle;
}
.c-spbg {
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  top: 0;
  left: 0;
}
@media (max-width: 750.999px) {
  .c-spbg:after {
    content: " ";
    display: block;
    position: sticky;
    top: -100px;
    margin-bottom: -100px;
    z-index: -1;
    width: 100%;
    height: calc(100vh + 150px);
    background-image: url(https://tb-2026otosidama.jp/cp001/images/bg.webp);
    background-position: center;
    background-size: 100% 100%;
  }
}
.c-pcbg {
  display: none;
  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/pc_bg_left.webp),
    url(https://tb-2026otosidama.jp/cp001/images/pc_bg_right.webp), url(https://tb-2026otosidama.jp/cp001/images/pc_bg.webp);
  background-repeat: no-repeat;
  background-position: left top 20px, right top, center;
  background-size: 108px auto, 290px auto, cover;
}
.c-pcbg--form:before,
.c-pcbg--form:after {
  content: " ";
  display: block;
  position: absolute;
  pointer-events: none;
  background-size: 100% auto;
  background-repeat: no-repeat;
}
.c-pcbg--form:before {
  top: 45%;
  right: calc(50% + 195px);
  width: 343px;
  height: 343px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/pc_form_bg_left.webp);
}
.c-pcbg--form:after {
  bottom: 0;
  left: calc(50% + 195px);
  width: 246px;
  height: 246px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/pc_form_bg_right.webp);
  background-position: left bottom;
}
@media (min-width: 751px) {
  .c-pcbg {
    display: block;
  }
  .c-pcbg_image-wrapper {
    position: absolute;
    top: 0;
    right: max(max(50% + 220px, 67%));
    display: grid;
    gap: 15px;
    grid-template-columns: auto;
    grid-template-rows: auto auto;
    align-content: center;
    justify-content: center;
    height: 100%;
  }
  .c-pcbg_image01,
  .c-pcbg_image02 {
    margin: 0 auto;
  }
  .c-pcbg_image01 {
    width: min(495px, 30vw);
  }
  .c-pcbg_image02 {
    width: min(480px, 27vw);
  }
  .c-pcbg_image03 {
    position: absolute;
    top: 52%;
    left: max(max(50% + 220px, 68%));
    width: min(470px, 30vw);
  }
}
.c-lp {
  position: relative;
}
@media (min-width: 751px) {
  .c-lp {
    max-width: 390px;
    min-height: 100svh;
    margin: 0 auto;
  }
  .c-lp:after {
    content: " ";
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: calc(50% - 195px);
    mix-blend-mode: multiply;
    box-shadow: 0 0 100px #af8c71;
    pointer-events: none;
  }
  .c-lp--top:before {
    content: " ";
    display: block;
    position: absolute;
    left: -59px;
    width: 137%;
    height: 100%;
    background-image: url(https://tb-2026otosidama.jp/cp001/images/hero_bg_3.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% auto;
  }
}
.c-site-head {
  padding: 20px 27px;
}
@media (min-width: 751px) {
  .c-show-sp {
    display: none !important;
  }
}
@media (max-width: 750.999px) {
  .c-show-pc {
    display: none !important;
  }
}
.c-fc_red {
  color: red;
}
.c-modal {
  z-index: 1000;
  opacity: 0;
  transition: scale 0.35s cubic-bezier(0.21, 0.72, 0.74, 1),
    opacity 0.3s cubic-bezier(0.21, 0.72, 0.74, 1);
}
.c-modal[open] {
  opacity: 0;
  scale: 0.98;
}
.c-modal::backdrop {
  opacity: 0;
  transition: opacity 0.3s cubic-bezier(0.21, 0.72, 0.74, 1);
}
.c-modal.is-visible {
  opacity: 1;
  scale: 1;
}
.c-modal.is-visible::backdrop {
  opacity: 1;
}
.c-modal.is-closing {
  opacity: 0;
  scale: 0.97;
}
.c-modal.is-closing::backdrop {
  opacity: 0;
}
@media (max-width: 750.999px) {
  .c-modal {
    min-height: 100dvh;
    max-height: 100dvh;
  }
}
.c-modal_backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}
@media (max-width: 750.999px) {
  .c-modal_backdrop {
    display: none;
  }
}
.c-modal_close--icon {
  position: absolute;
  top: 20px;
  right: 20px;
}
.c-modal_close--icon img {
  pointer-events: none;
}
.c-modal_close {
  position: relative;
  display: block;
  margin: 20px auto 0;
  width: 128px;
  padding: 10px;
}
.c-modal_close * {
  pointer-events: none;
}
@media (min-width: 751px) {
  .c-modal_inner {
    max-width: 980px;
  }
}
.c-modal--terms {
  background-color: transparent;
}
@media (min-width: 751px) {
  .c-modal--terms {
    overflow: visible;
    max-width: 980px;
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (max-width: 750.999px) {
  .c-modal--terms .c-modal_close--icon {
    top: 10px;
    right: 10px;
  }
}
@media (min-width: 751px) {
  .c-modal--terms .c-modal_close--icon {
    top: -10px;
    right: 25px;
    translate: 0 -100%;
  }
}
.c-modal--terms .c-modal_close {
  margin-top: 30px;
}
.c-modal--terms .c-modal_main {
  overflow: hidden;
  background-color: #fff;
}
@media (min-width: 751px) {
  .c-modal--terms .c-modal_main {
    border-radius: 10px;
  }
}
.c-modal--terms .c-modal_inner {
  padding: 40px 30px;
  overflow: auto;
}
@media (min-width: 751px) {
  .c-modal--terms .c-modal_inner {
    max-height: 100%;
    max-height: 90vh;
  }
}
.c-modal--terms h2 {
  text-align: center;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: solid 1px #000;
}
.c-modal--terms h3 {
  font-size: 16px;
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  text-decoration: underline;
}
.c-modal--terms dl {
  margin: 0;
}
@media (min-width: 751px) {
  .c-modal--terms dl {
    display: grid;
    grid-template-columns: auto 1fr;
  }
}
@media (max-width: 750.999px) {
  .c-modal--terms dl dt {
    margin-top: 0.6em;
  }
}
@media (max-width: 750.999px) {
  .c-modal--terms dl dd {
    margin-left: 0;
  }
}
@media (min-width: 751px) {
  .c-modal--terms dl dd {
    margin-left: 2em;
  }
}
.c-modal--terms p,
.c-modal--terms ul,
.c-modal--terms dl {
  font-weight: 400;
  line-height: 1.6;
}
.c-modal--terms p,
.c-modal--terms dl {
  margin-top: 0.8em;
}
.c-modal--terms li {
  margin-left: 1em;
  text-indent: -1em;
  margin-top: 0.3em;
}
.c-modal--terms a {
  text-decoration: underline;
  word-break: break-all;
}
.c-modal--article {
  width: 100vw;
  background-color: transparent;
}
@media (min-width: 751px) {
  .c-modal--article {
    max-height: 100vh;
  }
}
.c-modal--article .c-modal_inner {
  position: relative;
  padding: 25px;
}
@media (min-width: 751px) {
  .c-modal--article .c-modal_inner {
    margin: 0 auto;
  }
}
.c-modal--article.c-modal_head,
.c-modal--article .c-btn {
  position: relative;
}
.c-modal[open]::backdrop {
  background: #0009;
}
.c-article_head-sub {
  position: relative;
  width: 50%;
  max-width: 390px;
  margin: 0 auto;
}
.c-article_head-main {
  position: relative;
  display: grid;
  grid-template-columns: auto auto;
  justify-content: space-between;
  align-items: center;
  margin-top: 25px;
  padding: 16px;
  min-height: 56px;
  background-color: #fff;
}
.c-article_head-main:before,
.c-article_head-main:after {
  content: " ";
  display: block;
  position: absolute;
}
.c-article_head-main:before {
  top: -48px;
  left: -20px;
  width: 118px;
  height: 118px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/article_decor.webp);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100% auto;
  z-index: -1;
}
.c-article_head-main:after {
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  top: 2px;
  left: 2px;
  border: solid 2px #868686;
  pointer-events: none;
}
.c-article_head-date {
  display: block;
  width: auto;
  height: 20px;
}
.c-article_head-media {
  display: grid;
  grid-template-columns: 16px auto;
  align-items: center;
  gap: 5px;
}
.c-article_head-media-img {
  display: block;
  width: auto;
  height: 26px;
}
.c-article_title {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: solid 1px #000;
}
@media (max-width: 750.999px) {
  .c-article_title {
    font-size: 18px;
  }
}
@media (min-width: 751px) {
  .c-article_title {
    font-size: 24px;
  }
}
.c-article_inner {
  margin: 20px 0 35px;
}
@media (max-width: 750.999px) {
  .c-article_inner {
    padding: 30px 24px;
  }
}
@media (min-width: 751px) {
  .c-article_inner {
    padding: 36px;
  }
}
.c-article_inner p {
  line-height: 1.8;
}
@media (max-width: 750.999px) {
  .c-article_inner p {
    font-size: 13px;
  }
}
@media (min-width: 751px) {
  .c-article_inner p {
    font-size: 16px;
  }
}
.c-article_inner p + p {
  margin-top: 1em;
}
.c-form_wrapper {
  padding: 40px 0 80px;
  font-weight: 400;
}
.c-form_main {
  margin-top: 30px;
  padding: 0 27px;
}
.c-form_inner {
  margin-bottom: 40px;
  padding: 35px 25px;
  background-color: #fff;
}
.c-form_inner p {
  padding-bottom: 20px;
  margin-bottom: 30px;
  text-align: center;
  font-size: 14px;
  border-bottom: solid 1px #000;
}
.c-form_inner p img {
  display: inline-block;
  vertical-align: middle;
}
.c-form_inputs label {
  display: block;
}
.c-form_inputs input {
  width: 100%;
  padding: 5px 10px;
  border: 1px solid #dddddd;
  border-radius: 6px;
  line-height: 1.8;
  font-size: 12px;
}
.c-form_inputs input::placeholder {
  font-size: 12px;
}
.c-form_inputs--confirm input {
  background-color: transparent;
  border: none;
}
.c-form_inputs--confirm input:focus-visible {
  outline: none;
}
.c-form_group {
  margin-top: 20px;
  font-size: 12px;
}
.c-form_group-title {
  display: block;
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 8px;
  padding-top: 10px;
  line-height: 1;
}
.c-form_group-title--required:after {
  content: "必須";
  font-size: 10px;
  color: #6c8;
  vertical-align: middle;
  padding-left: 0.4em;
}
.c-form_group-title:first-child {
  padding-top: 0;
}
.c-form_group-note {
  display: block;
  margin-top: 10px;
  font-size: 10px;
  line-height: 1.5;
}
.c-form_group-link {
  margin-top: 10px;
}
.c-form_group-link a {
  display: inline-block;
  padding-left: 1.4em;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/form_icon_info.svg);
  background-repeat: no-repeat;
  background-position: left center;
  font-size: 12px;
}
.c-form_group + .c-form_group {
  margin-top: 30px;
  padding-top: 30px;
  border-top: solid 1px #b3b3b3;
}
.c-form_inner .c-form_group-lead {
  text-align: left;
  padding-bottom: 0;
  margin-bottom: 10px;
  border: none;
}
.c-form_group-error {
  margin-top: 0.3em;
  font-size: 10px;
  color: red;
  display: none;
  font-weight: 700;
}
.c-form_group-error.is-show {
  display: block;
}
.c-form_note {
  background: #fff;
  margin-top: 10px;
  padding: 14px;
  border: 1px solid #f00;
}
.c-form_note-head {
  color: red;
  font-size: 16px;
  font-weight: 700;
}
.c-form_note-head span {
  display: block;
  font-size: 12px;
}
.c-form_note ul {
  margin-top: 15px;
  font-size: 12px;
}
.c-form_note ul li {
  margin-left: 1em;
  text-indent: -1em;
  font-size: 10px;
}
.c-form_note ul li + li {
  margin-top: 5px;
}
.c-form_links {
  font-size: 12px;
}
.c-form_links .c-form_link-item > * {
  font-family: inherit;
  padding-left: 1em;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/form_icon_arrow.svg);
  background-repeat: no-repeat;
  background-position: left center;
  color: inherit;
}
.c-form_link-item + .c-form_link-item {
  margin-top: 0.5em;
}
.c-form_radio {
  margin-top: 10px;
}
.c-form_radio input {
  width: auto;
  margin: 0 0.3em 0 0;
  vertical-align: middle;
  cursor: pointer;
}
.c-form_radio label {
  display: inline-block;
  line-height: 1;
  cursor: pointer;
  vertical-align: middle;
}
.c-form_radio input + label {
  padding-top: 0;
}
.c-form_radio + .c-form_radio {
  margin-top: 7px;
}
.c-form_consent {
  width: auto;
  text-align: center;
}
.c-form_consent input {
  display: inline-block;
  width: auto;
  cursor: pointer;
}
.c-form_consent input + label {
  padding-top: 0;
  display: inline-block;
  font-size: 16px;
  cursor: pointer;
}
.c-form_button {
  width: 75vw;
  margin: 40px auto 0;
  display: block;
  pointer-events: none;
  max-width: 390px;
}
@media (min-width: 751px) {
  .c-form_button {
    max-width: 280px;
  }
}
.c-form_button .-active {
  display: none;
}
.c-form_button .-disabled {
  display: block;
}
.c-form_button--confirm {
  pointer-events: auto;
}
.c-form_button--confirm .-active {
  display: block;
}
.c-form_button--confirm .-disabled {
  display: none;
}
.c-form_back-button {
  display: block;
  width: 50vw;
  margin: 15px auto 0;
  max-width: 260px;
}
@media (min-width: 751px) {
  .c-form_back-button {
    max-width: 187px;
  }
}
.c-form_back-button--top {
  width: 75vw;
}
@media (max-width: 750.999px) {
  .c-form_back-button--top {
    max-width: 390px;
  }
}
@media (min-width: 751px) {
  .c-form_back-button--top {
    max-width: 280px;
  }
}
.c-form_kuji {
  position: relative;
}
.c-form_kuji img {
  width: 100%;
}
.c-form_kuji-button {
  position: absolute;
  display: block;
  left: 50%;
  bottom: 5px;
  translate: -50% 0;
  width: 65%;
}
.c-form_main:has(#consent:checked) .c-form_button {
  pointer-events: auto;
}
.c-form_main:has(#consent:checked) .c-form_button .-active {
  display: block;
}
.c-form_main:has(#consent:checked) .c-form_button .-disabled {
  display: none;
}
.c-cookie {
  position: fixed;
  bottom: 0;
  z-index: 110;
  display: none;
  width: 100%;
}
@media (min-width: 751px) {
  .c-cookie {
    width: 100%;
    left: 0;
  }
}
.c-cookie.is-show {
  display: block;
}
.c-cookie_inner {
  display: grid;
  align-items: center;
  gap: 15px;
  background-color: #000000b3;
}
@media (max-width: 750.999px) {
  .c-cookie_inner {
    padding: 10px 20px;
    grid-template-columns: auto min(150px, 30%);
  }
}
@media (min-width: 751px) {
  .c-cookie_inner {
    padding: 18px 20px;
    grid-template-columns: auto 126px;
    justify-content: center;
  }
}
.c-cookie p {
  color: #fff;
  line-height: 1.6;
}
@media (max-width: 750.999px) {
  .c-cookie p {
    font-size: 11px;
  }
}
@media (max-width: 750.999px) {
  .u-show-lg {
    display: none;
  }
}
@media (min-width: 751px) {
  .u-show-sm {
    display: none;
  }
}
.u-pointer-none {
  pointer-events: none;
}
.u-mt_08 {
  margin-top: 0.8em !important;
}
.u-d_b {
  display: block;
}
.u-ta_r {
  text-align: right;
}
.p-hero {
  position: relative;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/hero_bg_1.webp);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
  aspect-ratio: 780/1320;
  overflow: hidden;
}
.p-hero_title {
  padding-top: 1.5%;
  width: 99.5%;
}
.p-hero_image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-hero_image:before {
  content: " ";
  display: block;
  position: absolute;
  height: 100%;
  background-position: center top;
  background-size: 100% auto;
  background-repeat: no-repeat;
}
.p-hero_image:before {
  width: 100%;
  top: 37.5%;
  left: 0;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/hero_bg_2.webp);
  z-index: 2;
  pointer-events: none;
}
.p-hero_image-1,
.p-hero_image-2,
.p-hero_image-3 {
  position: absolute;
  display: block;
}
.p-hero_image-1 {
  top: 34.8%;
  left: 10%;
  width: 45.2%;
  z-index: 1;
}
.p-hero_image-2 {
  top: 46.5%;
  right: 10.2%;
  width: 43.7333333333%;
  z-index: 1;
}
.p-hero_image-3 {
  top: 62.5%;
  left: 10%;
  width: 44.1333333333%;
  z-index: 3;
}
.p-hero_btn {
  width: 27.6%;
  position: absolute;
  display: block;
  right: 8%;
  bottom: 9%;
  z-index: 10;
}
.p-hero_logo {
  position: absolute;
  top: 37.4%;
  left: 3%;
  width: 11%;
  z-index: 3;
}
.p-hero_logo img {
  width: 100%;
}
body {
  font-family: 游ゴシック, YuGothic, Yu Gothic, 游ゴシック体, Helvetica Neue,
    Arial, Hiragino Kaku Gothic ProN, Hiragino Sans, Meiryo, sans-serif;
  font-size: 100%;
  font-weight: 300;
  line-height: 1.5;
  color: #000;
}
body.is-modal-open,
body.is-menu-open {
  position: fixed;
  width: 100%;
  overflow: hidden;
}
body.is-menu-open .p-menu_button .-default {
  display: none;
}
body.is-menu-open .p-menu_button .-active {
  display: block;
}
body.is-menu-open .p-menu_wrapper {
  pointer-events: auto;
}
body.is-menu-open .p-menu_inner {
  translate: 0% 0;
}
.p-menu_button {
  position: fixed;
  top: -10px;
  z-index: 1001;
  padding: 15px;
}
@media (max-width: 750.999px) {
  .p-menu_button {
    right: -10px;
  }
}
@media (min-width: 751px) {
  .p-menu_button {
    right: calc(50% - 205px);
  }
}
.p-menu_button .-default {
  display: block;
}
.p-menu_button .-active {
  display: none;
  width: 25px;
}
.p-menu_title {
  width: 96%;
  margin: 0 auto;
  padding-top: 2%;
}
.p-menu_wrapper {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  overflow: hidden;
  width: 100%;
  pointer-events: none;
}
@media (min-width: 751px) {
  .p-menu_wrapper {
    left: 50%;
    max-width: 390px;
    translate: -50% 0;
  }
}
.p-menu_inner {
  width: 100%;
  min-height: 100dvh;
  background: linear-gradient(360deg, #ff0f1a, #ffc09e);
  translate: 102% 0;
}
.is-loaded .p-menu_inner {
  transition: translate 0.3s ease;
}
.p-menu_inner:before,
.p-menu_inner:after {
  content: " ";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  pointer-events: none;
  border-style: solid;
  z-index: -1;
}
.p-menu_inner:before {
  border-width: 4px;
  border-color: #e6b800;
  width: calc(100% - 7px);
  height: calc(100% - 7px);
}
.p-menu_inner:after {
  border-width: 3px;
  border-color: #fff;
  width: calc(100% - 14px);
  height: calc(100% - 14px);
}
.p-menu_list {
  width: 48%;
  max-width: 330px;
  margin: min(40px, 10%) auto 0;
  height: min(332px, 50dvh);
  display: grid;
  gap: 42px;
}
@media (max-width: 375.999px) {
  .p-menu_list {
    margin: min(10%, 2vh) auto 0;
    gap: min(42px, 3.5vh);
  }
}
.p-menu_list img {
  width: 100%;
}
main {
  position: relative;
}
main [id] {
  scroll-margin-top: 30px;
}
.nav {
  position: fixed;
  z-index: 100;
  width: 100%;
}
@media (max-width: 750.999px) {
  .nav {
    display: flex;
    bottom: 0;
    max-width: 100%;
    opacity: 0;
    translate: 0 105%;
    transition: translate 0.4s ease;
  }
  .nav.is-show {
    translate: 0 0%;
  }
}
@media (min-width: 751px) {
  .nav {
    opacity: 1 !important;
    width: 380px;
    top: 48%;
    left: max(50% + 250px, 70%);
    translate: 0 -100%;
  }
}
.nav_btn {
  display: block;
}
@media (max-width: 750.999px) {
  .nav_btn:nth-child(1) {
    order: 3;
  }
  .nav_btn:nth-child(2) {
    order: 2;
  }
  .nav_btn:nth-child(3) {
    order: 1;
  }
  .nav_btn img {
    width: 100%;
  }
}
@media (min-width: 751px) {
  .nav_btn {
    margin-top: 20px;
  }
}
.p-content01 {
  margin-top: 20px;
}
.p-content02 {
  margin-top: 10px;
}
@media (max-width: 750.999px) {
  .p-content02 {
    padding: 0 7.2vw;
  }
}
@media (min-width: 751px) {
  .p-content02 {
    padding: 0 27px;
  }
}
.p-content02_01,
.p-content02_02 {
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
@media (max-width: 750.999px) {
  .p-content02_01,
  .p-content02_02 {
    padding: 6.4vw 5.3333333333vw;
  }
}
@media (min-width: 751px) {
  .p-content02_01,
  .p-content02_02 {
    padding: 24px 20px;
  }
}
.p-content02_01 {
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content02_bg_1.webp);
}
.p-content02_01 p {
  width: 61%;
}
.p-content02_02 {
  margin-top: 20px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content02_bg_2.webp);
}
.p-content02_02 p {
  width: 68%;
}
.p-content02 p {
  margin: 20px auto;
}
.p-content03 {
  margin-top: 40px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content03_bg_1.webp);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: 0 23%;
}
.p-content03_status {
  width: 72%;
  margin: 0 auto;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content03_bg_2.webp);
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
@media (max-width: 750.999px) {
  .p-content03_status {
    padding: 8vw 0;
  }
}
@media (min-width: 751px) {
  .p-content03_status {
    padding: 30px 0;
  }
}
.p-content03_table {
  width: 85.5%;
  margin: 0 auto;
  position: relative;
  display: grid;
  justify-content: space-between;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px 8px;
}
.p-content03_table:after {
  content: " ";
  display: block;
  position: absolute;
  right: -29%;
  bottom: -12.5%;
  width: 150px;
  height: 100px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content03_bg_3.webp);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: right bottom;
  pointer-events: none;
}
.p-content03_table-cell {
  position: relative;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1/1;
}
.p-content03_table-cell img {
  display: block;
  height: 32%;
  pointer-events: none;
}
.p-content03_table-cell.is-active:before {
  position: absolute;
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content03_stamp.webp);
  background-repeat: no-repeat;
  background-size: 80% auto;
  background-position: center;
}
.p-content04 {
  margin-top: 55px;
}
.p-content04 h2 {
  width: 77%;
  margin: 0 auto 15px;
}
@media (max-width: 750.999px) {
  .p-content04 h2 {
    padding: 0 7.2vw;
  }
}
@media (min-width: 751px) {
  .p-content04 h2 {
    padding: 0 27px;
  }
}
.p-content04 h2 img {
  width: 100%;
}
@media (max-width: 750.999px) {
  .p-content04 h3 {
    padding: 0 7.2vw;
  }
}
@media (min-width: 751px) {
  .p-content04 h3 {
    padding: 0 27px;
  }
}
.p-content04 h3 img {
  width: 100%;
}
.p-content04_article-list {
  padding-top: 25px;
  background-image: url(https://tb-2026otosidama.jp/cp001/images/content04_bg.webp);
  background-repeat: no-repeat;
  background-size: auto 93%;
  background-position: left 2% bottom 35%;
}
@media (max-width: 750.999px) {
  .p-content04_article-list {
    padding-right: 7.2vw;
  }
}
@media (min-width: 751px) {
  .p-content04_article-list {
    padding-right: 27px;
  }
}
.p-content04_article-inner {
  padding-left: 38%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(6, auto);
  gap: 14px;
  align-items: end;
}
.p-content04_article-link {
  width: 100%;
  display: block;
  pointer-events: none;
  position: relative;
}
.p-content04_article-img.-active {
  display: none;
}
.p-content04_article-img.-disabled {
  display: block;
}
.p-content04_article-img--balloon {
  position: absolute;
  top: 0;
  left: 50%;
  width: 80%;
  translate: -50% -25%;
}
.p-content04_article-item:nth-child(1) {
  grid-row: 1;
  grid-column: 1;
}
.p-content04_article-item:nth-child(2) {
  grid-row: 2;
  grid-column: 1;
}
.p-content04_article-item:nth-child(3) {
  grid-row: 3;
  grid-column: 1;
}
.p-content04_article-item:nth-child(4) {
  grid-row: 4;
  grid-column: 1;
}
.p-content04_article-item:nth-child(5) {
  grid-row: 5;
  grid-column: 1;
}
.p-content04_article-item:nth-child(6) {
  grid-row: 6;
  grid-column: 1;
}
.p-content04_article-item:nth-child(7) {
  grid-row: 1;
  grid-column: 2;
}
.p-content04_article-item:nth-child(8) {
  grid-row: 2;
  grid-column: 2;
}
.p-content04_article-item:nth-child(9) {
  grid-row: 3;
  grid-column: 2;
}
.p-content04_article-item:nth-child(10) {
  grid-row: 4;
  grid-column: 2;
}
.p-content04_article-item:nth-child(11) {
  grid-row: 5;
  grid-column: 2;
}
.p-content04_article-item:nth-child(12) {
  grid-row: 6;
  grid-column: 2;
}
.p-content04_article-item.is-active .p-content04_article-link {
  pointer-events: auto;
  cursor: pointer;
}
.p-content04_article-item.is-active .p-content04_article-img.-active {
  display: block;
}
.p-content04_article-item.is-active .p-content04_article-img.-disabled {
  display: none;
}
.p-content05 {
  margin-top: 35px;
}
@media (max-width: 750.999px) {
  .p-content05 {
    padding: 0 7.2vw;
  }
}
@media (min-width: 751px) {
  .p-content05 {
    padding: 0 27px;
  }
}
.p-content05_btn {
  display: block;
  margin-top: 10px;
  margin-left: auto;
  margin-right: auto;
}
.p-content05_btn:nth-of-type(1) {
  margin-top: 55px;
}
@media (max-width: 750.999px) {
  .p-content05_btn {
    max-width: 420px;
  }
}
.p-error {
  display: flex;
  flex-direction: column;
}
@media (max-width: 750.999px) {
  .p-error {
    overflow: hidden;
    min-height: 100dvh;
  }
}
.p-error .c-form_wrapper {
  padding-bottom: 0;
}
.p-error .c-form_main {
  margin-top: 0;
}
.p-error .c-form_inner h1 img {
  width: 100%;
}
.p-error .c-form_inner p {
  margin: 25px 0 0;
  padding: 80px 0;
  border-bottom: none;
  border-top: solid 1px #000;
  font-size: 16px;
  letter-spacing: -0.02em;
}
.p-error .footer {
  margin-top: auto;
  padding-top: 0;
  padding-bottom: 0;
  width: 100%;
}
.p-error .footer_copy {
  margin-top: 20px;
  margin-bottom: 0;
}
.p-hero_image:before,
.p-hero_image-1,
.p-hero_image-2,
.p-hero_image-3,
.p-hero_title,
.p-hero_logo,
.p-hero_btn {
  opacity: 0;
}
body.is-loaded .p-hero_image:before,
body.is-loaded .p-hero_image-1,
body.is-loaded .p-hero_image-2,
body.is-loaded .p-hero_image-3 {
  animation: bounceIn 0.6s cubic-bezier(0.22, 1.61, 0.36, 1) both;
}
body.is-loaded .p-hero_image-1 {
  animation-delay: 0.2s;
}
body.is-loaded .p-hero_image-2 {
  animation-delay: 0.5s;
}
body.is-loaded .p-hero_image-3 {
  animation-delay: 0.8s;
}
body.is-loaded .p-hero_image:before {
  animation-delay: 1.1s;
  transition-duration: 0.3s;
}
body.is-loaded .p-hero_title,
body.is-loaded .p-hero_logo,
body.is-loaded .p-hero_btn {
  animation: fadeIn 0.8s ease-out both;
  animation-delay: 1.8s;
}
@keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.2) translateY(20px);
  }
  20% {
    opacity: 1;
    transform: scale(1.06) translateY(0);
  }
  30% {
    opacity: 1;
    transform: scale(0.92);
  }
  50% {
    opacity: 1;
    transform: scale(1.03) translateY(0);
  }
  70% {
    opacity: 1;
    transform: scale(0.96);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes pulse {
  0% {
    scale: 0.95;
    opacity: 1;
  }
  90% {
    opacity: 0.1;
  }
  to {
    scale: 1.4;
    opacity: 0;
  }
}
@keyframes pulse-rectangle {
  0% {
    scale: 0.95;
    opacity: 1;
  }
  90% {
    opacity: 0.1;
  }
  to {
    scale: 1.18 1.5;
    opacity: 0;
  }
}
