/* ======================================================================
 reset
====================================================================== */
/*
  Josh's Custom CSS Reset
  https://www.joshwcomeau.com/css/custom-css-reset/
*/
*, *::before, *::after {
  box-sizing: border-box;
}
* {
  margin: 0;
}
html {
  overflow-y: scroll;
}
/* html, body {
  height: 100%;
} */
body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}
input, button, textarea, select {
  font: inherit;
}
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}
ul {
  list-style: none;
  padding-left: 0;
}



/* ======================================================================
 base
====================================================================== */
:root {
  --color-main: #ff5d5f;
  --color-text: #000;
  --font-base: "Noto Sans JP", 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic',Avenir, "Helvetica Neue", Helvetica, Arial, Verdana, Roboto, sans-serif;
  --font-awesome: "Font Awesome 7 Free";
  --base-width: 1240px;
}

html {
  font-size: 62.5%;
}

body {
  font-family: var(--font-base);
  font-weight: 400;
  color: var(--color-text);
  line-height: 1.6;
  word-wrap : break-word;
	word-break: break-all;
  min-width: var(--base-width);
	overflow: hidden;
  @media (width <= 768px) {
    min-width: inherit;
  }
}

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

strong {
	font-weight: bold;
}

a {
  transition: opacity .2s;
	&:link {
		color: var(--color-text);
		text-decoration: none;
		cursor: pointer;
	}
	&:visited {
		color: var(--color-text);
		text-decoration: none;
	}
	&:hover {
		color: var(--color-text);
		text-decoration: none;
    /* opacity: .8; */
    @media (width >= 769px) {
      opacity: .8;
    }
	}
	&:active {
		color: var(--color-text);
		text-decoration: none;
	}
}

/* モバイル時 電話番号カラー */
a[href^="tel"]{
  color: var(--color-text);
}

:focus-ring {
  outline: none;
}

.pink {
  color: var(--color-main);
}


/* input */
/* ( 1 ) radio / checkbox 以外リセット */
input[type='button'], input[type='submit'], input[type='text'], input[type='email'], input[type='tel'],  input[type='url'], input[type='password'], input[type='reset'], input[type='search'], textarea, select {
  display: block;
  margin: 0;
  padding: 0;
  outline: none;
  border: none;
  border-image: none;
  background: transparent;
  font-family: inherit; /* 子要素へ引き継ぎ */
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

textarea {
  resize: vertical;
}

input, textarea {
  &:placeholder-shown {
    color: var(--color-text);
  }
  &::placeholder {
    color: var(--color-text);
  }
  &:focus {
    &:placeholder-shown {
      color: var(--color-text);
    }
    &::placeholder {
      color: var(--color-text);
    }
  }
}


/* =================================
 l-content__size
================================= */
.l-content__size-pc-1 {
  width: var(--base-width);
  margin: 0 auto;
  padding-inline: 20px;
  @media (width <= 768px) {
    width: auto;
    padding-inline: calc(40/750*100vw);
  }
}


/* =================================
 l-header
================================= */
.l-header {
  position: relative;
  z-index: 998;
  &.active {
    .l-header__toggle {
      span {
        &:nth-of-type(1) {
          top: 39px;
          transform: rotate(45deg);
          @media (width <= 768px) {
            top: calc(46/750*100vw);
          }
        }
        &:nth-of-type(2) {
          top: 39px;
          transform: rotate(-45deg);
          @media (width <= 768px) {
            top: calc(46/750*100vw);
          }
        }
      }
    }
  }
}

.l-header__logo {
  margin: 40px 0 40px 40px;
  @media (width <= 768px) {
    margin: calc(42/750*100vw) 0 calc(42/750*100vw) calc(30/750*100vw);
    width: calc(147/750*100vw);
  }
  a {
    display: inline-block;
  }
}

.l-header__toggle {
  position: fixed;
  width: 80px;
  height: 80px;
  top: 30px;
  right: 30px;
  cursor: pointer;
  border-radius: 50%;
  background: var(--color-main);
  border: 2px solid #fff;
  @media (width <= 768px) {
    width: calc(100/750*100vw);
    height: calc(100/750*100vw);
    top: calc(30/750*100vw);
    right: calc(30/750*100vw);
  }
  span {
    width: 30px;
    height: 2px;
    border-radius: 1.5px;
    background: #fff;
    display: block;
    position: absolute;
    left: 23px;
    transition: transform 0.6s ease-in-out, top 0.5s ease;
    @media (width <= 768px) {
      width: calc(40/750*100vw);
      left: calc(26/750*100vw);
    }
    &:nth-of-type(1) {
      top: 34px;
      @media (width <= 768px) {
        top: calc(39/750*100vw);
      }
    }
    &:nth-of-type(2) {
      top: 44px;
      @media (width <= 768px) {
        top: calc(53/750*100vw);
      }
    }
  }
}


.l-menu {
  z-index: 997;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: rgb(255 255 255 /.95);
  width: 100%;
  height: 100vh;
  height: 100svh;
  display: none;
  overflow-y: auto;
}

.l-menu__nav {
  width: 500px;
  margin: 0 auto;
  padding-block: 208px;
  @media (width <= 768px) {
    width: auto;
    margin-inline: calc(40/750*100vw);
    padding-block: calc(305/750*100vw);
  }
  li {
    &:not(:last-of-type) {
      border-bottom: 1px solid var(--color-main);
    }
    a {
      display: flex;
      justify-content: center;
      padding-block: 29px 26px;
      @media (width <= 768px) {
        padding-block: calc(35/750*100vw);
        img {
          height: calc(50/750*100vw);
        }
      }
    }
  }
}


/* =================================
 l-footer
================================= */
.l-footer {
  background: var(--color-main);
  padding-block: 60px 58px;
  @media (width <= 768px) {
    padding-block: calc(80/750*100vw);
  }
}

.l-footer__note-box {
  background: #fff;
  width: 800px;
  height: 200px;
  margin-inline: auto;
  padding: 30px;
  margin-bottom: 60px;
  overflow-y: auto;
  @media (width <= 768px) {
    width: auto;
    height: calc(400/750*100vw);
    padding: calc(40/750*100vw) calc(30/750*100vw);
    margin-bottom: calc(80/750*100vw);
  }
}

.l-footer__note-ttl {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
  margin-bottom: 22px;
  @media (width <= 768px) {
    font-size: calc(28/750*100vw);
    margin-bottom: calc(30/750*100vw);
  }
}

.l-footer__note-item {
  font-size: 1.2rem;
  color: #555555;
  @media (width <= 768px) {
    font-size: calc(20/750*100vw);
  }
  & + & {
    margin-top: 20px;
  }
  dt {
    font-weight: 700;
  }
}

.l-footer__note-disc {
  list-style: disc;
  margin-left: 1.5em;
}

.l-footer__logo {
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
  @media (width <= 768px) {
    margin-bottom: calc(40/750*100vw);
    margin-inline: auto;
    width: calc(465/750*100vw);
  }
}

.l-footer__sns {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 30px;
  @media (width <= 768px) {
    gap: calc(40/750*100vw);
    margin-bottom: calc(50/750*100vw);
    li {
      width: calc(80/750*100vw);
    }
  }
}

.l-footer__copy {
  font-size: 1.2rem;
  text-align: center;
  @media (width <= 768px) {
    font-size: calc(20/750*100vw);
  }
}

.c-toTop {
  position: fixed;
  bottom: 30px;
  right: 30px;
  cursor: pointer;
  transition: opacity .2s;
  opacity: 0;
  pointer-events: none;
  @media (width <= 768px) {
    bottom: calc(30/750*100vw);
    right: calc(30/750*100vw);
    width: calc(80/750*100vw);
  }
  &.fade-in {
    opacity: 1;
    pointer-events: inherit;
  }
}

.c-btn__submit {
  display: flex;
  justify-content: center;
  button {
    border: none;
    background: transparent;
    cursor: pointer;
  }
}

.c-btn__back {
  margin-top: 30px;
  input {
    width: 450px;
    height: 60px;
    border-radius: 10px;
    background: var(--color-main);
    color: #fff;
    font-size: 3rem;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    @media (width <= 768px) {
      width: calc(570/750*100vw);
      height: calc(100/750*100vw);
      border-radius: calc(15/750*100vw);
      font-size: calc(44/750*100vw);
    }
  }
}



.p-index__mv {
  background: linear-gradient(to bottom, #fff 308px, var(--color-main) 308px);
  @media (width <= 768px) {
    background: linear-gradient(to bottom, #fff calc(1100/750*100vw), var(--color-main) calc(1100/750*100vw));
    background: #fff;
  }
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-index__ashirai-1,
.p-index__ashirai-2,
.p-index__ashirai-3,
.p-index__ashirai-4,
.p-index__ashirai-5,
.p-index__ashirai-6,
.p-index__ashirai-7,
.p-index__ashirai-8,
.p-index__ashirai-9,
.p-index__ashirai-10,
.p-index__ashirai-11,
.p-index__ashirai-12,
.p-index__ashiraisp-1,
.p-index__ashiraisp-2,
.p-index__ashiraisp-3,
.p-index__ashiraisp-4,
.p-index__ashiraisp-5,
.p-index__ashiraisp-6,
.p-index__ashiraisp-7,
.p-index__ashiraisp-8,
.p-index__ashiraisp-9,
.p-index__ashiraisp-10,
.p-index__ashiraisp-11,
.p-index__ashiraisp-12,
.p-index__ashiraisp-13 {
  position: absolute;
}

.p-index__ashirai-1 {
  top: 116px;
  left: -295px;
}

.p-index__ashirai-2 {
  top: 238px;
  right: 0;
  margin-right: -134px;
}

.p-index__ashirai-3 {
  top: 1012px;
  right: 0;
  margin-right: -30px;
}

.p-index__ashirai-4 {
  top: -35px;
  right: 367px;
}

.p-index__ashirai-5 {
  top: 299px;
  right: 0;
  margin-right: -237px;
}

.p-index__ashirai-6 {
  top: -30px;
  left: 45px;
}

.p-index__ashirai-7 {
  top: 1013px;
  left: -66px;
}

.p-index__ashirai-8 {
  top: -53px;
  right: 0;
  margin-right: -70px;
}

.p-index__ashirai-9 {
  top: 193px;
  left: -275px;
}

.p-index__ashirai-10 {
  top: 786px;
  left: -38px;
}

.p-index__ashirai-11 {
  top: 928px;
  right: 40px;
}

.p-index__ashirai-12 {
  top: 11px;
  right: 0;
  margin-right: -43px;
}

.p-index__ashiraisp-1 {
  top: calc(123/750*100vw);
  left: 0;
}

.p-index__ashiraisp-2 {
  top: calc(1288/750*100vw);
  right: 0;
  width: calc(241/750*100vw);
}

.p-index__ashiraisp-3 {
  top: calc(1932/750*100vw);
  left: 0;
  width: calc(60/750*100vw);
}

.p-index__ashiraisp-4 {
  top: calc(2340/750*100vw);
  right: calc(24/750*100vw);
  width: calc(78/750*100vw);
}

.p-index__ashiraisp-5 {
  top: calc(48/750*100vw);
  left: calc(12/750*100vw);
  width: calc(58/750*100vw);
}

.p-index__ashiraisp-6 {
  top: calc(337/750*100vw);
  right: calc(6/750*100vw);
  width: calc(110/750*100vw);
}

.p-index__ashiraisp-7 {
  top: calc(1525/750*100vw);
  left: 0;
  width: calc(79/750*100vw);
}

.p-index__ashiraisp-8 {
  top: calc(2137/750*100vw);
  right: calc(31/750*100vw);
  width: calc(58/750*100vw);
}

.p-index__ashiraisp-9 {
  top: calc(2231/750*100vw);
  right: 0;
  width: calc(70/750*100vw);
}

.p-index__ashiraisp-10 {
  bottom: calc(571/750*100vw);
  right: 0;
  width: calc(90/750*100vw);
}

.p-index__ashiraisp-11 {
  bottom: calc(43/750*100vw);
  left: 0;
  width: calc(81/750*100vw);
}

.p-index__ashiraisp-12 {
  top: calc(-29/750*100vw);
  right: calc(57/750*100vw);
  width: calc(58/750*100vw);
}

.p-index__ashiraisp-13 {
  top: calc(495/750*100vw);
  left: 0;
  width: calc(60/750*100vw);
}

.p-index__mv-inner {
  display: flex;
  @media (width <= 768px) {
    display: block;
  }
}

.p-index__mv-left {
  margin-left: 50px;
  @media (width <= 768px) {
    margin-left: 0;
  }
}

.p-index__mv-logo {
  margin-block: 50px 27px;
  position: relative;
  @media (width <= 768px) {
    margin-block: calc(42/750*100vw) calc(-103/750*100vw);
    margin-left: calc(-10/750*100vw);
    width: calc(162/750*100vw);
  }
}

.p-index__mv-box {
  @media (width <= 768px) {
    background: var(--color-main);
    margin-inline: calc(-40/750*100vw);
    padding-inline: calc(40/750*100vw);
    padding-block: calc(78/750*100vw) calc(80/750*100vw);
    position: relative;
  }
}

.p-index__mv-ttl-1 {
  margin-bottom: 86px;
  @media (width <= 768px) {
    margin-inline: calc(-33/750*100vw);
    margin-bottom: calc(5/750*100vw);
  }
}

.p-index__mv-ttl-2 {
  margin-bottom: 45px;
  @media (width <= 768px) {
    width: calc(479/750*100vw);
    margin-left: calc(38/750*100vw);
    margin-bottom: calc(59/750*100vw);
  }
}

.p-index__mv-txt {
  margin-bottom: 19px;
  @media (width <= 768px) {
    width: calc(520/750*100vw);
    margin-left: calc(38/750*100vw);
    margin-bottom: calc(44/750*100vw);
  }
}

.p-index__mv-img-1 {
  margin-inline: -173px -200px;
  @media (width <= 768px) {
    margin-inline: calc(20/750*100vw) calc(-40/750*100vw);
    margin-bottom: calc(-1216/750*100vw);
  }
}

.p-index__mv-img-2 {
  margin-left: 19px;
  @media (width <= 768px) {
    width: calc(570/750*100vw);
    margin-inline: auto;
  }
}


.p-index__search {
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-index__search-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 50px;
  margin-inline: 50px;
  @media (width <= 768px) {
    flex-direction: column;
    gap: calc(54/750*100vw);
    padding-block: calc(100/750*100vw) calc(145/750*100vw);
    margin-inline: auto;
  }
}

.p-index__search-map-wrap {
  position: relative;
}

.p-index__search-location {
  position: absolute;
  top: 199px;
  left: 110px;
  @media (width <= 768px) {
    width: calc(350/750*100vw);
    top: calc(69/750*100vw);
    left: calc(72/750*100vw);
  }
  a {
    &:hover {
      opacity: 1;
    }
  }
}


.p-index__cp {
  background: linear-gradient(to bottom, var(--color-main) 324px, #fff 324px);
  padding-bottom: 90px;
  @media (width <= 768px) {
    background: linear-gradient(to bottom, var(--color-main) calc(466/750*100vw), #fff calc(466/750*100vw));
    padding-bottom: calc(100/750*100vw);
  }
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-index__cp-ttl-wrap {
  position: relative;
  padding-block: 90px 80px;
  @media (width <= 768px) {
    padding-block: calc(126/750*100vw) calc(127/750*100vw);
  }
}

.p-index__cp-chara {
  position: absolute;
  top: 71px;
  right: 5px;
  @media (width <= 768px) {
    width: calc(225/750*100vw);
    top: calc(-133/750*100vw);
    right: 0;
    left: 0;
    margin-inline: auto;
  }
}

.p-index__cp-ttl {
  display: flex;
  justify-content: center;
  @media (width <= 768px) {
    position: relative;
  }
}

.p-index__cp-box1 {
  background: #fff;
  border: 4px solid #a467e3;
  padding: 32px 46px 46px;
  margin-bottom: 86px;
  position: relative;
  @media (width <= 768px) {
    padding: calc(46/750*100vw) calc(26/750*100vw) calc(36/750*100vw);
    margin-bottom: calc(130/750*100vw);
  }
}

.p-index__cp-box1-balloon,
.p-index__cp-box2-balloon {
  position: absolute;
  top: -62px;
  left: -32px;
  @media (width <= 768px) {
    width: calc(355/750*100vw);
    top: calc(-103/750*100vw);
    left: calc((-40/750*100vw) - 4px);
  }
}

.p-index__cp-box1-ttl {
  margin-bottom: 30px;
  @media (width <= 768px) {
    margin-bottom: calc(42/750*100vw);
  }
}

.p-index__cp-box1-period {
  margin-bottom: 30px;
  @media (width <= 768px) {
    margin-bottom: calc(16/750*100vw);
  }
}

.p-index__cp-box1-goods {
  position: absolute;
  bottom: 46px;
  right: 29px;
  z-index: 1;
  @media (width <= 768px) {
    position: static;
    margin-left: calc(98/750*100vw);
    width: calc(484/750*100vw);
  }
}

.p-index__cp-box1-inner {
  background: #a467e3;
  padding: 30px 0 30px 55px;
  display: flex;
  align-items: center;
  gap: 17px;
  position: relative;
  @media (width <= 768px) {
    padding: calc(80/750*100vw) calc(60/750*100vw);
    gap: calc(38/750*100vw);
    flex-direction: column;
  }
}

.p-index__cp-box1-item-img {
  display: flex;
  justify-content: center;
  margin-bottom: 18px;
  @media (width <= 768px) {
    margin-bottom: calc(25/750*100vw);
    margin-inline: auto;
    width: calc(390/750*100vw);
  }
}

.p-index__cp-box1-item-arrow {
  @media (width <= 768px) {
    margin-inline: auto;
    width: calc(25/750*100vw);
  }
}

.p-index__cp-box1-item-attend {
  position: absolute;
  right: 10px;
  bottom: 10px;
  @media (width <= 768px) {
    right: calc(15/750*100vw);
    bottom: calc(15/750*100vw);
    width: calc(197/750*100vw);
  }
}

.p-index__cp-box2 {
  background: #fff;
  border: 4px solid #ff5494;
  padding: 9px 46px 46px;
  position: relative;
  @media (width <= 768px) {
    padding: calc(40/750*100vw) calc(26/750*100vw) calc(36/750*100vw);
  }
}

.p-index__cp-box2-ttl {
  margin-bottom: 14px;
  @media (width <= 768px) {
    margin-bottom: calc(52/750*100vw);
  }
}

.p-index__cp-box2-period {
  margin-bottom: 30px;
  @media (width <= 768px) {
    margin-bottom: calc(48/750*100vw);
  }
}

.p-index__cp-box2-goods {
  position: absolute;
  top: 227px;
  right: 10px;
  z-index: 1;
  @media (width <= 768px) {
    position: static;
    margin-bottom: calc(36/750*100vw);
    margin-inline: auto;
    width: calc(563/750*100vw);
    display: none;
  }
}

.p-index__cp-box2-inner {
  background: #ff5494;
  padding: 30px 0 30px 29px;
  display: flex;
  align-items: center;
  gap: 13px;
  position: relative;
  @media (width <= 768px) {
    padding: calc(114/750*100vw) calc(60/750*100vw) calc(80/750*100vw);
    gap: calc(38/750*100vw);
    flex-direction: column;
  }
}

.p-index__cp-box2-img {
  @media (width <= 768px) {
    width: calc(519/750*100vw);
    margin-inline: auto;
    margin-bottom: calc(-56/750*100vw);
    position: relative;
    z-index: 1;
  }
}

.p-index__cp-box2-item-img {
  display: flex;
  justify-content: center;
  margin-bottom: 18px;
  @media (width <= 768px) {
    margin-bottom: calc(25/750*100vw);
    margin-inline: auto;
    width: calc(390/750*100vw);
  }
}

.p-index__cp-box2-item-arrow {
  @media (width <= 768px) {
    margin-inline: auto;
    width: calc(52/750*100vw);
  }
}

.p-index__cp-box2-item-btn {
  position: relative;
  z-index: 1;
  @media (width <= 768px) {
    &.large {
      margin-inline: calc(-30/750*100vw);
    }
  }
}


.p-index__movie {
  background: linear-gradient(to bottom, var(--color-main) 324px, #fff 324px);
  @media (width <= 768px) {
    background: linear-gradient(to bottom, var(--color-main) calc(426/750*100vw), #fff calc(426/750*100vw));
  }
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-index__movie-ttl-wrap {
  position: relative;
  padding-block: 90px;
  @media (width <= 768px) {
    padding-block: calc(100/750*100vw) calc(90/750*100vw);
  }
}

.p-index__movie-chara {
  position: absolute;
  top: -117px;
  left: 139px;
  @media (width <= 768px) {
    top: calc(-70/750*100vw);
    left: calc(50/750*100vw);
    width: calc(212/750*100vw);
  }
}

.p-index__movie-ttl {
  display: flex;
  justify-content: center;
  @media (width <= 768px) {
    margin-left: calc(292/750*100vw);
    width: calc(249/750*100vw);
  }
}

.p-index__movie-box {
  background: #fff;
  border: 1px solid var(--color-main);
  padding-block: 50px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 50px;
  position: relative;
  @media (width <= 768px) {
    padding: calc(80/750*100vw) calc(39/750*100vw);
    gap: calc(80/750*100vw);
  }
}

.p-index__manifest {
  padding-block: 90px;
  @media (width <= 768px) {
    padding-block: calc(78/750*100vw) calc(100/750*100vw);
  }
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-index__manifest-img {
  display: flex;
  justify-content: center;
}


.p-subcon__contents {
  margin-bottom: 90px;
  @media (width <= 768px) {
    margin-bottom: calc(100/750*100vw);
  }
}


.p-subcon__contents-meta {
  background: var(--color-main);
  padding-block: 60px;
  margin-bottom: 90px;
  @media (width <= 768px) {
    padding-block: calc(80/750*100vw);
    margin-bottom: calc(100/750*100vw);
    &.large {
      padding-bottom: calc(154/750*100vw);
      margin-bottom: calc(164/750*100vw);
    }
  }
  .l-content__size-pc-1 {
    position: relative;
  }
}

.p-subcon__contents-ashirai-1 {
  position: absolute;
  top: -100px;
  left: -80px;
  @media (width <= 768px) {
    width: calc(56/750*100vw);
    top: calc(190/750*100vw);
    left: 0;;
  }
}

.p-subcon__contents-ashirai-2 {
  position: absolute;
  top: -30px;
  right: 0;
  margin-right: -291px;
  @media (width <= 768px) {
    width: calc(73/750*100vw);
    top: calc(-21/750*100vw);
    right: 0;;
    margin-right: 0;
  }
}

.p-subcon__contents-ttl {
  display: flex;
  justify-content: center;
  @media (width <= 768px) {
    margin-inline: auto;
    img {
      height: calc(150/750*100vw);
    }
  }
}

.p-campaign__contents-ttl-1 {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
  @media (width <= 768px) {
    width: calc(560/750*100vw);
    margin-inline: auto;
    margin-bottom: calc(36/750*100vw);
  }
}

.p-campaign__contents-img-1 {
  position: absolute;
  bottom: -105px;
  right: 69px;
  @media (width <= 768px) {
    width: calc(237/750*100vw);
    bottom: calc(-272/750*100vw);
    margin-inline: auto;
    right: 0;
    left: 0;
  }
}

.p-campaign__contents-box {
  background: #fff;
  border: 1px solid var(--color-main);
  padding: 20px 60px 50px;
  margin-inline: auto;
  width: 840px;
  @media (width <= 768px) {
    padding: 0 calc(30/750*100vw) calc(62/750*100vw);
    width: auto;
  }
  &:has(.p-campaign__contents-txt) {
    padding-block: 90px;
    @media (width <= 768px) {
      padding-block: calc(80/750*100vw);
    }
  }
}

.p-campaign__contents-box-item {
  border-bottom: 1px solid var(--color-main);
  padding: 20px 20px 30px;
  @media (width <= 768px) {
    padding: calc(60/750*100vw) calc(18/750*100vw);
  }
  dt {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 20px;
    @media (width <= 768px) {
      font-size: calc(28/750*100vw);
      margin-bottom: calc(30/750*100vw);
    }
  }
  .require {
    font-size: 1.6rem;
    color: #fff;
    background: var(--color-main);
    padding: 0 8px 2px;
    margin-left: 12px;
    @media (width <= 768px) {
      font-size: calc(20/750*100vw);
      padding: 0 calc(10/750*100vw) calc(4/750*100vw);
      margin-left: calc(15/750*100vw);
    }
  }
  dd {
    input[type="text"],
    input[type="email"] {
      border-radius: 8px;
      border: 1px solid rgb(0 0 0 / .15);
      font-size: 1.7rem;
      padding: 10px;
      @media (width <= 768px) {
        font-size: 1.6rem;
        padding: calc(20/750*100vw);
      }
      &::placeholder {
        color: #bbbbbb;
      }
    }
    input[name="お名前"],
    input[name="メールアドレス"],
    input[name="市区町村"],
    input[name="番地 / 建物名 / 号室"],
    input[name="X ID"] {
      width: 500px;
      @media (width <= 768px) {
        width: 100%;
      }
    }
  }
}

.p-campaign__contents-box-item-ttl {
  font-size: 1.4rem;
  color: #666666;
  margin-block: 10px;
  @media (width <= 768px) {
    font-size: calc(24/750*100vw);
    margin-block: calc(30/750*100vw) calc(10/750*100vw);
  }
}

.p-campaign__contents-box-agree {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-block: 50px;
  font-size: 1.7rem;
  @media (width <= 768px) {
    display: block;
    margin-block: calc(60/750*100vw);
    font-size: calc(28/750*100vw);
    li + li {
      margin-top: calc(36/750*100vw);
    }
  }
  .checkbox {
    width: fit-content;
    display: grid;
    grid-template-columns: auto 1fr; /* auto はアイコン、1fr はラベル文字列を想定 */
    gap: 10px;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
    color: #404040;
    cursor: pointer;
    @media (width <= 768px) {
      width: auto;
      display: flex;
      justify-content: center;
      align-items: center;
      gap: calc(18/750*100vw);
      font-size: calc(28/750*100vw);
    }
  }
  .checkbox_icon {
    position: relative;
    width: 24px;
    height: 24px;
    appearance: none;
    background: #FFFFFF;
    border: solid 1px rgb(0 0 0 / .15);
    border-radius: 6px;
    box-shadow: 0 0 0 0 transparent;
    @media (width <= 768px) {
      width: calc(40/750*100vw);
      height: calc(40/750*100vw);
    }
    &::before {
      position: absolute;
      inset: 0;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 100%;
      height: 100%;
      opacity: 0;
      content: "\f00c";
      font-family: var(--font-awesome);
      font-weight: 900;
      color: #fff;
    }
    &:checked {
      background: var(--color-main);
    }
    &:checked::before {
      opacity: 1;
    }
  }
}

.p-campaign__contents-txt {
  margin-bottom: 60px;
  display: flex;
  justify-content: center;
  
  @media (width <= 768px) {
    margin-bottom: calc(80/750*100vw);
    margin-inline: auto;
    width: calc(314/750*100vw);
  }
}

.p-campaign__contents-txt-2 {
  @media (width <= 768px) {
    width: calc(431/750*100vw);
  }
}

.p-campaign__contents-txt-3 {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
  margin-bottom: 0;
  @media (width <= 768px) {
    font-size: calc(42/750*100vw);
    width: auto;
  }
}


.p-thanks__contents-box {
  background: #fff;
  border: 1px solid var(--color-main);
  width: 960px;
  margin-inline: auto;
  padding: 90px;
  @media (width <= 768px) {
    width: auto;
    padding: calc(80/750*100vw) calc(50/750*100vw);
  }
}

.p-thanks__contents-txt-1 {
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
  @media (width <= 768px) {
    width: calc(496/750*100vw);
    margin-inline: auto;
    margin-bottom: calc(44/750*100vw);
  }
}

.p-thanks__contents-txt-2-wrap {
  position: relative;
}

.p-thanks__contents-txt-2 {
  display: flex;
  justify-content: center;
  margin-block: 50px 30px;
  @media (width <= 768px) {
    width: calc(508/750*100vw);
    margin-inline: auto;
    margin-block: calc(30/750*100vw) calc(80/750*100vw);
  }
}

.p-thanks__contents-img-1 {
  position: absolute;
  top: -20px;
  left: 100px;
  @media (width <= 768px) {
    top: calc(-60/750*100vw);
    left: calc(-75/750*100vw);
    width: calc(100/750*100vw);
  }
}

.p-thanks__contents-btn {
  display: flex;
  justify-content: center;
  margin-bottom: 60px;
  @media (width <= 768px) {
    margin-block: calc(80/750*100vw);
  }
}

.p-thanks__contents-txt-3 {
  text-align: center;
  a {
    display: inline-block;
    padding: 0 10px 5px;
    border-bottom: 2px solid var(--color-main);
    @media (width <= 768px) {
      width: calc(142/750*100vw);
      padding: 0 calc(14/750*100vw) calc(8/750*100vw);
    }
  }
}

.p-confirm__box {
  margin-block: 100px 100px;
  font-size: 1.6rem;
  h4 {
    margin-bottom: 30px;
  }
}


.p-hall__contents-ttl-1 {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
  @media (width <= 768px) {
    width: calc(387/750*100vw);
    margin-inline: auto;
    margin-bottom: calc(40/750*100vw);
  }
}

.p-hall__contents-tab {
  display: flex;
  justify-content: center;
  gap: 15px;
  @media (width <= 768px) {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: calc(20/750*100vw);
  }
}

.p-hall__load-error {
  text-align: center;
  padding: 1.5em 1em;
  color: #c00;
  font-size: 1.4rem;
}

.p-hall__contents-tab-item {
  border-top: 1px solid var(--color-main);
  border-left: 1px solid var(--color-main);
  border-right: 1px solid var(--color-main);
  font-size: 2.2rem;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--color-main);
  /* cursor: pointer; */
  @media (width <= 768px) {
    width: calc(210/750*100vw);
    height: calc(80/750*100vw);
    border-bottom: 1px solid var(--color-main);
    font-size: calc(34/750*100vw);
  }
  a {
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--color-main);
    width: 100px;
    height: 50px;
  }
}

.p-hall__contents-tab-top {
  border-bottom: 1px solid var(--color-main);
  @media (width <= 768px) {
    border-bottom: none;
  }
}

.p-hall__contents-tab-outer {
  padding-top: 60px;
  @media (width <= 768px) {
    border-top: none;
    padding-top: calc(80/750*100vw);
  }
  &:has(#hokkaido),
  &:has(#location) {
    padding-top: 0;
  }
}

.p-hall__contents-tab-cont {
  width: 960px;
  margin-inline: auto;
  @media (width <= 768px) {
    width: auto;
  }
  & + & {
    margin-top: 50px;
    @media (width <= 768px) {
      margin-top: calc(60/750*100vw);
    }
  }
}

.p-hall__contents-ttl {
  background: var(--color-main);
  font-size: 3.2rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  margin-bottom: 50px;
  @media (width <= 768px) {
    font-size: calc(40/750*100vw);
    margin-bottom: calc(60/750*100vw);
  }
}

.p-hall__contents-item {
  border-bottom: 1px solid var(--color-main);
  margin-inline: 30px;
  @media (width <= 768px) {
    margin-inline: calc(30/750*100vw);
  }
  &:first-of-type {
    border-top: 1px solid var(--color-main);
  }
  a, &.noid {
    padding: 16px 10px;
    display: flex;
    gap: 15px;
    position: relative;
    @media (width <= 768px) {
      padding: calc(30/750*100vw) calc(10/750*100vw);
    }
  }
  a {
    &:after {
      position: absolute;
      top: calc(50% - 6px);
      right: 10px;
      content: "";
      width: 33px;
      height: 12px;
      background: url(../img/hall/arrow.png);
      @media (width <= 768px) {
        display: none;
      }
    }
  }
}

.p-hall__contents-item-img {
  width: 70px;
  @media (width <= 768px) {
    width: calc(100/750*100vw);
  }
  img {
    width: 100%;
    height: 70px;
    object-fit: cover;
    /* border: 1px solid var(--color-main); */
    @media (width <= 768px) {
      height: calc(100/750*100vw);
    }
  }
}

.p-hall__contents-no-result {
  font-size: 1.6rem;
  text-align: center;
  @media (width <= 768px) {
    font-size: calc(24/750*100vw);
  }
}

.p-hall__contents-item-info {
  flex: 1;
}

.p-hall__contents-item-shop {
  font-size: 2.6rem;
  font-weight: 700;
  color:  var(--color-main);
  /* background: var(--color-main);
  display: inline-block;
  padding: 0 11px;
  margin-bottom: 4px; */
  @media (width <= 768px) {
    font-size: calc(34/750*100vw);
    /* padding: calc(4/750*100vw) calc(10/750*100vw);
    margin-bottom: calc(10/750*100vw);
    display: block; */
  }
}

.p-hall__contents-item-address {
  font-size: 1.6rem;
  color: #555555;
  @media (width <= 768px) {
    font-size: calc(24/750*100vw);
  }
}

.p-download__contents-box {
  width: 960px;
  margin-inline: auto;
  border: 1px solid var(--color-main);
  padding: 70px 20px;
  @media (width <= 768px) {
    width: inherit;
  }
  &.coming {
    padding: 100px 20px;
  }
}

.p-download__contents-box-txt-1 {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--color-main);
  text-align: center;
}

.p-download__contents-box-txt-2 {
  font-size: 1.5rem;
  text-align: center;
  margin-bottom: 30px;
}

.p-download__contents-attend {
  margin-bottom: 70px;
  border: 1px solid #dcdcdc;
  padding: 24px 30px;
  margin-inline: auto;
  width: 740px;
  @media (width <= 768px) {
    width: inherit;
  }
}

.p-download__contents-attend-ttl {
  font-size: 1.5rem;
  font-weight: 400;
  text-align: center;
  margin-bottom: 30px;
}

.p-download__contents-attend-list {
  font-size: 1.5rem;
  li {
    list-style: disc;
    margin-left: 1.5em;
  }
  .pink {
    font-weight: 500;
  }
}

.p-download__contents-item {
  & + & {
    margin-top: 60px;
  }
  &:hover {
    .p-download__contents-item-txt {
      text-decoration: none;
    }
  }
}

.p-download__contents-item-img {
  display: flex;
  justify-content: center;
}

.p-download__contents-item-txt {
  color: #0096ff;
  font-weight: 700;
  font-size: 2.4rem;
  text-align: center;
  text-decoration: underline;
}

 /* spからコーディング : モバイルファースト */
/* @media (width >= 1025px) {
  .u-pc {
    display: block;
  }
  .u-sp {
    display: none;
  }
}
@media (width <= 1024px) {
  .u-pc {
    display: none;
  }
  .u-sp {
    display: block;
  }
} */

/* pcからコーディング */
@media (width >= 769px) {
  .u-pc {
    display: block;
  }
  .u-sp {
    display: none;
  }
}
@media (width <= 768px) {
  .u-pc {
    display: none;
  }
  .u-sp {
    display: block;
  }
}