@charset "UTF-8";
/* Device Width */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
/* font setting */
* {
  box-sizing: border-box; }

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

body {
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75;
  color: #3D3D3D;
  background: #E8D7C4; }
  @media only, screen and (max-width: 736px) {
    body {
      font-size: 14px; } }
  body .bg {
    display: none; }
  body.open .bg {
    display: block;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0.6;
    position: fixed;
    z-index: 2; }

.pc-inline {
  display: inline; }
  @media only, screen and (max-width: 736px) {
    .pc-inline {
      display: none; } }

.sp-inline {
  display: none; }
  @media only, screen and (max-width: 736px) {
    .sp-inline {
      display: inline; } }

.pc-block {
  display: block; }
  @media only, screen and (max-width: 736px) {
    .pc-block {
      display: none; } }

.sp-block {
  display: none; }
  @media only, screen and (max-width: 736px) {
    .sp-block {
      display: block; } }

.flex-box {
  display: flex; }

img {
  width: 100%;
  height: auto; }

header {
  display: block;
  width: 250px;
  height: 100vh;
  padding: 20px 20px 0 0;
  position: sticky;
  top: 0;
  overflow-y: auto; }
  @media screen and (max-width: 1080px) {
    header {
      display: none; } }
  header .logo-box {
    margin: 0 0 40px;
    gap: 10px; }
    header .logo-box a {
      display: block;
      width: 80px;
      margin-left: auto; }
      header .logo-box a img {
        vertical-align: bottom; }
  header .header-content {
    width: 220px;
    margin: 0 auto; }
    header .header-content .header-ttl {
      margin-bottom: 15px;
      text-align: center; }
      header .header-content .header-ttl img {
        display: block;
        width: 36px;
        margin: 0 auto 15px; }
      header .header-content .header-ttl span {
        display: inline-block;
        font-size: 20px;
        font-weight: 600;
        line-height: 1.5; }
    header .header-content ul li {
      margin: 0 0 10px;
      padding: 0 0 10px;
      list-style: none;
      border-bottom: solid 1px #3d3d3d; }
      header .header-content ul li a {
        display: block;
        text-decoration: none;
        color: #8C6236;
        transition: color 0.3s; }
        header .header-content ul li a:hover {
          color: #3d3d3d; }
      header .header-content ul li > ul li {
        margin-bottom: 0;
        padding: 0;
        border-bottom: none; }
        header .header-content ul li > ul li a {
          font-size: 14px; }
      header .header-content ul li:last-of-type {
        padding: 0;
        border-bottom: none; }
  header .pagetop {
    display: block;
    width: 78px;
    margin: 30px auto 10px;
    cursor: pointer; }

.thanks-event {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  justify-content: space-between;
  width: 1280px;
  margin: 0 auto;
  /* main */ }
  @media screen and (max-width: 1080px) {
    .thanks-event {
      width: 100%; } }
  .thanks-event main {
    width: 940px;
    margin: 20px 20px 30px;
    padding: 20px 0 0;
    background: #fff;
    border-radius: 20px;
    box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.1); }
    @media screen and (max-width: 1080px) {
      .thanks-event main {
        width: calc(100% - 40px);
        max-width: 940px;
        margin: 70px auto 20px; } }
    @media only, screen and (max-width: 736px) {
      .thanks-event main {
        border-radius: 12px; } }
    @media screen and (max-width: 320px) {
      .thanks-event main {
        padding: 10px 0 0; } }
    .thanks-event main .kv {
      margin: 0 auto 60px;
      padding: 0 20px; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .kv {
          margin: 0 auto 30px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .kv {
          padding: 0 10px; } }
      .thanks-event main .kv img {
        vertical-align: bottom;
        border-radius: 20px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .kv img {
            border-radius: 12px; } }
    .thanks-event main .read {
      text-align: center; }
      .thanks-event main .read p {
        margin-bottom: 1em; }
        @media screen and (max-width: 320px) {
          .thanks-event main .read p {
            width: calc(100% -  20px);
            margin: 0 auto 1em; } }
        .thanks-event main .read p:nth-of-type(3) {
          margin-bottom: 3em; }
          @media screen and (max-width: 320px) {
            .thanks-event main .read p:nth-of-type(3) {
              amrgin: 0 auto 3em; } }
        .thanks-event main .read p:last-of-type {
          margin-bottom: 70px; }
          @media screen and (max-width: 320px) {
            .thanks-event main .read p:last-of-type {
              margin: 0 auto 30px; } }
    .thanks-event main h1 {
      margin: 0 0 20px;
      font-size: 24px;
      font-weight: 600;
      line-height: 1.35;
      text-align: center; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main h1 {
          font-size: 22px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main h1 {
          font-size: 18px; } }
      .thanks-event main h1 img {
        display: block;
        width: 240px;
        margin: 0 auto 20px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main h1 img {
            width: 140px;
            margin: 0 auto 15px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main h1 img {
            width: 120px; } }
    .thanks-event main .event-date {
      width: 318px;
      margin: 0 auto 30px;
      padding: 15px 0 10px;
      font-size: 26px;
      line-height: 1.5;
      text-align: center;
      border-top: solid 1px #3D3D3D;
      border-bottom: solid 1px #3D3D3D; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .event-date {
          width: calc(100% - 40px);
          max-width: 318px;
          margin: 0 auto 20px;
          padding: 5px 0 3px;
          font-size: 20px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .event-date {
          width: calc(100% - 20px);
          font-size: 18px; } }
      .thanks-event main .event-date span {
        display: block;
        font-size: 20px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .event-date span {
            font-size: 16px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .event-date span {
            font-size: 14px; } }
    .thanks-event main .attention {
      width: 640px;
      margin: 0 auto 60px;
      padding: 20px;
      font-weight: 600;
      color: #fff;
      background: #EE5852;
      border-radius: 6px; }
      @media screen and (max-width: 1080px) {
        .thanks-event main .attention {
          width: calc(100% - 40px); } }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .attention {
          padding: 10px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .attention {
          width: calc(100% - 20px); } }
      .thanks-event main .attention.read-attention {
        width: 500px;
        margin: 0 auto 60px; }
        @media screen and (max-width: 1080px) {
          .thanks-event main .attention.read-attention {
            width: calc(100% - 40px);
            max-width: 318px;
            margin: 0 auto 30px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .attention.read-attention {
            width: calc(100% - 20px); } }
        .thanks-event main .attention.read-attention .txt-indent {
          display: block;
          margin: 0 auto 0 1em;
          text-indent: -1em; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .attention.read-attention .txt-indent {
              width: fit-content;
              margin: 0 auto; } }
          @media screen and (max-width: 320px) {
            .thanks-event main .attention.read-attention .txt-indent {
              font-size: 12px; } }
    .thanks-event main .event-place {
      margin: 0 0 20px;
      text-align: center; }
      @media screen and (max-width: 320px) {
        .thanks-event main .event-place {
          margin: 0 0 5px; } }
      .thanks-event main .event-place p {
        display: inline-block;
        padding: 0 28px;
        font-size: 26px;
        line-height: 1.35;
        position: relative; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .event-place p {
            padding: 0 26px;
            font-size: 20px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .event-place p {
            font-size: 18px; } }
        .thanks-event main .event-place p:before {
          content: "";
          display: block;
          width: 18px;
          height: 26px;
          background: url(../thanks-event/img/icn_place.png) left top/100% auto no-repeat;
          position: absolute;
          top: 7px;
          left: 0; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .event-place p:before {
              width: 16px;
              height: 24px;
              top: 4px; } }
        .thanks-event main .event-place p span {
          display: block;
          font-size: 12px; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .event-place p span {
              font-size: 10px; } }
          @media screen and (max-width: 320px) {
            .thanks-event main .event-place p span {
              font-size: 9px; } }
      .thanks-event main .event-place address {
        margin: 0 0 20px;
        font-style: normal; }
      .thanks-event main .event-place iframe {
        width: calc(100% - 40px);
        height: 42.65625vw;
        border: none;
        border-radius: 20px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .event-place iframe {
            height: 67.7083333333vw;
            border-radius: 12px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .event-place iframe {
            width: calc(100% - 20px); } }
    .thanks-event main .btn-ticket {
      width: 100%;
      padding: 15px;
      border-radius: 0 0 20px 20px;
      backdrop-filter: blur(5px);
      position: sticky;
      bottom: -80px;
      opacity: 0;
      z-index: 1;
      transition: opacity 0.5s; }
      .thanks-event main .btn-ticket:before {
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        background: #fff;
        border-radius: 0 0 20px 20px;
        opacity: 0.7;
        position: absolute;
        left: 0;
        bottom: 0;
        z-index: 0; }
      .thanks-event main .btn-ticket a {
        display: block;
        width: 220px;
        margin: 0 auto;
        padding: 11px 0;
        font-weight: 700;
        text-align: center;
        color: #fff;
        text-decoration: none;
        background: #EE5852;
        border-radius: 6px;
        position: relative;
        z-index: 2; }
        .thanks-event main .btn-ticket a span {
          padding: 0 20px;
          position: relative; }
          .thanks-event main .btn-ticket a span:after {
            content: "";
            display: block;
            width: 7px;
            height: 7px;
            margin: auto;
            border-top: solid 1px #fff;
            border-right: solid 1px #fff;
            transform: rotate(45deg);
            transform-origin: center;
            position: absolute;
            top: 0;
            bottom: 0;
            right: 0;
            transition: right 0.3s; }
        .thanks-event main .btn-ticket a:hover span:after {
          right: -5px; }
      .thanks-event main .btn-ticket.open {
        bottom: 0;
        opacity: 1; }
    .thanks-event main .ttl-event {
      width: 640px;
      margin: 0 auto 30px;
      padding: 20px 0 0;
      font-size: 28px;
      font-weight: 600;
      line-height: 1.75;
      color: #8C6236;
      text-align: center;
      position: relative; }
      @media screen and (max-width: 1080px) {
        .thanks-event main .ttl-event {
          width: calc(100% - 40px);
          max-width: 640px;
          margin: 0 auto 20px; } }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .ttl-event {
          padding: 15px 0 0;
          font-size: 18px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .ttl-event {
          width: calc(100% - 20px);
          font-size: 16px; } }
      .thanks-event main .ttl-event:before, .thanks-event main .ttl-event:after {
        content: "";
        display: block;
        width: 100%;
        background: #8C6236;
        position: absolute; }
      .thanks-event main .ttl-event:before {
        height: 3px;
        top: 0; }
      .thanks-event main .ttl-event:after {
        height: 1px;
        top: 7px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .ttl-event:after {
            top: 5px; } }
      .thanks-event main .ttl-event span {
        display: block;
        font-size: 16px;
        position: relative; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .ttl-event span {
            font-size: 12px; } }
        .thanks-event main .ttl-event span > span {
          display: inline-block;
          padding: 0 20px;
          background: #fff; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .ttl-event span > span {
              padding: 0 10px; } }
          .thanks-event main .ttl-event span > span:before {
            content: none; }
        .thanks-event main .ttl-event span:before {
          content: "";
          display: block;
          width: 100%;
          height: 1px;
          margin: auto;
          background: #8C6236;
          position: absolute;
          top: 0;
          bottom: 0; }
    .thanks-event main .ttl-headline {
      width: fit-content;
      margin: 0 auto 10px;
      padding: 0 110px 40px;
      position: relative; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .ttl-headline {
          width: 100%;
          padding: 0 20px 30px; } }
      .thanks-event main .ttl-headline:after {
        content: "";
        display: block;
        width: 1px;
        height: 30px;
        margin: auto;
        background: #3d3d3d;
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .ttl-headline:after {
            height: 20px; } }
      .thanks-event main .ttl-headline h3 {
        font-size: 24px;
        font-weight: 400;
        text-align: center; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .ttl-headline h3 {
            font-size: 18px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .ttl-headline h3 {
            font-size: 16px; } }
        .thanks-event main .ttl-headline h3 span {
          display: inline-block;
          margin: 0 0 5px;
          padding: 3px 20px;
          font-size: 16px;
          font-weight: 400;
          color: #fff;
          background: #BE8F61; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .ttl-headline h3 span {
              padding: 3px 10px;
              font-size: 12px; } }
          @media screen and (max-width: 320px) {
            .thanks-event main .ttl-headline h3 span {
              font-size: 10px; } }
      .thanks-event main .ttl-headline .icn-limit {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 90px;
        height: 90px;
        margin: auto;
        font-size: 16px;
        font-weight: 500;
        line-height: 1.5;
        color: #fff;
        text-align: center;
        background: #3d3d3d;
        border-radius: 100%;
        position: absolute;
        right: 0;
        top: 0;
        bottom: 0; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .ttl-headline .icn-limit {
            width: 60px;
            height: 60px;
            font-size: 12px;
            right: 30px;
            top: -55px;
            bottom: inherit; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .ttl-headline .icn-limit {
            right: 15px;
            top: -50px; } }
    .thanks-event main .time-schedule {
      margin: 0 0 50px;
      padding: 70px 0 40px;
      background: #F1E6DA; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .time-schedule {
          margin: 0 0 30px;
          padding: 40px 0 20px; } }
      .thanks-event main .time-schedule .schedule-att {
        margin: 0 auto 20px;
        text-align: center; }
        .thanks-event main .time-schedule .schedule-att img {
          display: block;
          width: 112px;
          margin: 0 auto; }
          @media screen and (max-width: 320px) {
            .thanks-event main .time-schedule .schedule-att img {
              width: 92px; } }
      .thanks-event main .time-schedule--box {
        max-width: 900px;
        margin: 0 auto;
        padding: 20px 0 20px 20px;
        background: #fff;
        border-radius: 20px; }
        @media screen and (max-width: 1080px) {
          .thanks-event main .time-schedule--box {
            width: calc(100% - 40px);
            max-width: inherit; } }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .time-schedule--box {
            border-radius: 12px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .time-schedule--box {
            padding: 10px 0 10px 10px; } }
        .thanks-event main .time-schedule--box .time-schedule-inner {
          margin: 0 20px 0 0; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .time-schedule--box .time-schedule-inner {
              margin: 0; } }
          .thanks-event main .time-schedule--box .time-schedule-inner img {
            width: 1120px;
            border-radius: 20px; }
            @media only, screen and (max-width: 736px) {
              .thanks-event main .time-schedule--box .time-schedule-inner img {
                margin: 0 20px 0 0;
                border-radius: 12px; } }
            @media screen and (max-width: 320px) {
              .thanks-event main .time-schedule--box .time-schedule-inner img {
                margin: 0 10px 0 0; } }
          .thanks-event main .time-schedule--box .time-schedule-inner .simplebar-track {
            bottom: -10px; }
          .thanks-event main .time-schedule--box .time-schedule-inner .simplebar-scrollbar::before {
            opacity: 0.8;
            background: #666; }
      .thanks-event main .time-schedule .ttl-event span > span {
        background: #F1E6DA; }
    .thanks-event main .content-box p {
      max-width: 640px;
      margin: 0 auto 40px;
      line-height: 2;
      text-align: justify;
      letter-spacing: 0.05em; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .content-box p {
          width: calc(100% - 40px);
          max-width: inherit;
          margin: 0 auto 20px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .content-box p {
          width: calc(100% - 20px);
          margin: 0 auto 20px; } }
      .thanks-event main .content-box p.txt-time {
        margin: 0 auto 20px;
        text-align: center; }
      .thanks-event main .content-box p b {
        font-weight: 700;
        color: #F81916; }
      .thanks-event main .content-box p.sub-ttl {
        display: block;
        width: fit-content;
        max-width: 11em;
        margin: 0 auto 20px;
        padding: 3px 20px;
        font-size: 16px;
        font-weight: 400;
        color: #fff;
        background: #BE8F61; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .content-box p.sub-ttl {
            padding: 3px 10px;
            font-size: 12px; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .content-box p.sub-ttl {
            font-size: 10px; } }
      .thanks-event main .content-box p.mb100 {
        margin: 0 auto 100px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .content-box p.mb100 {
            margin: 0 auto 60px; } }
    .thanks-event main .content-box a {
      color: #8C6236;
      transition: color 0.3s; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .content-box a {
          text-decoration: underline; } }
      .thanks-event main .content-box a:hover {
        color: #3D3D3D;
        text-decoration: none; }
    .thanks-event main .content-box .att {
      max-width: 640px;
      margin: 0 auto 60px;
      padding: 20px;
      color: #fff;
      line-height: 1.75;
      background: #EE5852;
      border-radius: 6px; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .content-box .att {
          width: calc(100% - 40px);
          max-width: inherit;
          margin: 0 auto 40px;
          padding: 10px 20px;
          font-size: 13px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .content-box .att {
          width: calc(100% - 20px);
          padding: 10px; } }
      .thanks-event main .content-box .att li {
        list-style: none;
        margin-left: 1em;
        text-indent: -1em; }
    .thanks-event main .content-box figure {
      max-width: 900px;
      margin: 0 auto 40px; }
      @media screen and (max-width: 1080px) {
        .thanks-event main .content-box figure {
          width: calc(100% - 40px);
          max-width: inherit; } }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .content-box figure {
          width: calc(100% - 40px);
          margin: 0 auto 20px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .content-box figure {
          width: calc(100% - 20px); } }
      .thanks-event main .content-box figure img {
        vertical-align: bottom;
        border-radius: 20px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .content-box figure img {
            border-radius: 12px; } }
      .thanks-event main .content-box figure.img-talk {
        max-width: 640px;
        margin: 0 auto 20px; }
        @media screen and (max-width: 720px) {
          .thanks-event main .content-box figure.img-talk {
            width: calc(100% - 40px);
            max-width: inherit; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .content-box figure.img-talk {
            width: calc(100% - 20px); } }
    .thanks-event main .content-box .ticket-info {
      max-width: 640px;
      margin: 0 auto 100px;
      padding: 20px 50px;
      color: #fff;
      background: #EE5852;
      border-radius: 6px; }
      @media screen and (max-width: 720px) {
        .thanks-event main .content-box .ticket-info {
          width: calc(100% - 40px);
          max-width: inherit; } }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .content-box .ticket-info {
          margin: 0 auto 60px;
          padding: 10px 20px; } }
      @media screen and (max-width: 320px) {
        .thanks-event main .content-box .ticket-info {
          width: calc(100% - 20px);
          padding: 10px; } }
      .thanks-event main .content-box .ticket-info h3 {
        margin: 0 0 15px;
        font-size: 24px;
        font-weight: 500;
        text-align: center; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .content-box .ticket-info h3 {
            margin: 0 0 10px;
            font-size: 15px;
            line-height: 1.35; } }
        @media screen and (max-width: 320px) {
          .thanks-event main .content-box .ticket-info h3 {
            font-size: 14px; } }
        .thanks-event main .content-box .ticket-info h3 span {
          font-size: 18px; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .content-box .ticket-info h3 span {
              font-size: 12px; } }
      .thanks-event main .content-box .ticket-info ul {
        padding-top: 15px;
        border-top: solid 1px #fff; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .content-box .ticket-info ul {
            padding: 10px 0 0; } }
        .thanks-event main .content-box .ticket-info ul li {
          margin-left: 1em;
          font-size: 14px;
          text-indent: -1em;
          list-style: none; }
          @media only, screen and (max-width: 736px) {
            .thanks-event main .content-box .ticket-info ul li {
              font-size: 13px; } }
        .thanks-event main .content-box .ticket-info ul.border-none {
          padding: 0;
          border-top: none; }
    .thanks-event main .content-box .btn-faq {
      display: block;
      width: 220px;
      margin: 0 auto 30px;
      padding: 8px 0;
      font-size: 14px;
      text-align: center;
      text-decoration: none;
      border: solid 1px #000;
      cursor: pointer;
      background: #fff;
      border-radius: 6px;
      transition: background 0.3s, color 0.3s; }
      @media screen and (max-width: 720px) {
        .thanks-event main .content-box .btn-faq {
          margin: 0 auto 10px; } }
      .thanks-event main .content-box .btn-faq:hover {
        color: #fff;
        background: #000; }
    .thanks-event main .img-short {
      margin: 0 auto;
      gap: 20px; }
      @media only, screen and (max-width: 736px) {
        .thanks-event main .img-short {
          display: block;
          max-width: inherit;
          width: calc(100% - 40px); } }
      .thanks-event main .img-short figure {
        width: 460px; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .img-short figure {
            width: 100%; } }
        .thanks-event main .img-short figure img {
          border-radius: 20px; }
        .thanks-event main .img-short figure figcaption {
          padding: 10px 0;
          font-size: 14px;
          font-weight: 400;
          color: #777;
          text-align: center; }
      .thanks-event main .img-short p {
        flex: 1; }
        @media only, screen and (max-width: 736px) {
          .thanks-event main .img-short p {
            max-width: inherit;
            width: 100%; } }
      .thanks-event main .img-short.reverse {
        flex-direction: row-reverse; }

footer {
  padding: 12px 0 10px;
  background: #000; }
  @media screen and (max-width: 600px) {
    footer {
      padding: 15px 0; } }
  footer .footer-box {
    justify-content: space-between;
    align-items: center;
    max-width: 1240px;
    margin: 0 auto; }
    @media screen and (max-width: 1080px) {
      footer .footer-box {
        max-width: inherit;
        padding: 0 20px; } }
    @media screen and (max-width: 600px) {
      footer .footer-box {
        display: block; } }
    footer .footer-box p {
      margin: 0;
      font-family: "Noto Sans JP", sans-serif;
      font-size: 11px;
      font-weight: 400;
      color: #fff;
      text-align: right; }
      @media screen and (max-width: 600px) {
        footer .footer-box p {
          text-align: center; } }
      footer .footer-box p.footer-logo {
        display: block;
        width: 68px; }
        @media screen and (max-width: 600px) {
          footer .footer-box p.footer-logo {
            margin: 0 auto 10px; } }
    footer .footer-box ul.flex-box {
      margin: 0;
      padding: 0 0 0 40px;
      justify-content: center;
      list-style: none; }
      @media screen and (max-width: 600px) {
        footer .footer-box ul.flex-box {
          margin: 0 auto 10px;
          padding: 0; } }
      footer .footer-box ul.flex-box li {
        margin: 0 8px; }
        footer .footer-box ul.flex-box li:nth-of-type(2) {
          margin: 0 20px 0 8px; }
        footer .footer-box ul.flex-box li:nth-of-type(3) {
          margin: 0 8px 0 20px;
          position: relative; }
          footer .footer-box ul.flex-box li:nth-of-type(3):before {
            content: "";
            display: inline-block;
            width: 1px;
            height: 20px;
            margin: auto;
            background: #333;
            position: absolute;
            left: -20px;
            top: 0;
            bottom: 0; }
        footer .footer-box ul.flex-box li a {
          display: block;
          width: 26px;
          height: 26px;
          background: #fff;
          border-radius: 100%;
          transition: background 0.3s; }
          footer .footer-box ul.flex-box li a:hover {
            background: #B48C0F; }

.faq-box {
  max-width: 900px;
  height: calc(100vh - 60px);
  margin: 0 auto;
  background: #fff;
  border: solid 16px #F1E9E2;
  position: fixed;
  z-index: -2;
  top: 50vh;
  left: 3.125vw;
  right: inherit;
  opacity: 0;
  transition: top 0.3s, opacity 0.3s; }
  @media screen and (min-width: 1281px) {
    .faq-box {
      left: 0;
      right: 300px; } }
  @media screen and (max-width: 1080px) {
    .faq-box {
      width: 90%;
      max-width: inherit; } }
  @media screen and (max-width: 600px) {
    .faq-box {
      width: calc(100% - 30px);
      border: solid 12px #F1E9E2; } }
  .faq-box .faq-box-content {
    width: 100%;
    height: 100%;
    padding: 44px 60px 60px;
    overflow-y: scroll; }
    @media screen and (max-width: 600px) {
      .faq-box .faq-box-content {
        padding: 24px 20px 20px; } }
  .faq-box .close {
    width: 40px;
    height: 40px;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 20px;
    line-height: 30px;
    font-weight: 700;
    text-align: center;
    color: #fff;
    background: #000;
    border: solid 4px #fff;
    border-radius: 100%;
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
    position: absolute;
    right: -35px;
    top: -35px;
    z-index: -1;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.1s; }
    @media screen and (max-width: 600px) {
      .faq-box .close {
        right: -25px; } }
  .faq-box h2 {
    margin: 0 0 40px;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.35;
    text-align: center;
    color: #8C6236; }
    @media only, screen and (max-width: 736px) {
      .faq-box h2 {
        margin: 0 0 20px;
        font-size: 20px; } }
  .faq-box dl dt {
    margin: 0 0 10px;
    padding: 0 0 10px;
    font-size: 18px;
    font-weight: 600;
    color: #8C6236;
    border-bottom: solid 1px #3D3D3D; }
    @media screen and (max-width: 600px) {
      .faq-box dl dt {
        font-size: 16px; } }
  .faq-box dl dd {
    margin: 0 0 60px;
    font-size: 16px;
    line-height: 1.75;
    text-align: justify; }
    @media screen and (max-width: 600px) {
      .faq-box dl dd {
        margin: 0 0 30px;
        font-size: 14px; } }
    .faq-box dl dd:last-of-type {
      margin: 0; }
    .faq-box dl dd p {
      margin: 0;
      line-heeight: 1.5; }
    .faq-box dl dd ul {
      margin: 0 0 1em;
      padding: 0;
      list-style: none; }
      .faq-box dl dd ul li {
        margin: 0 0 0 1em;
        padding: 0;
        text-indent: -1em; }
        .faq-box dl dd ul li:before {
          content: "・";
          display: inline; }

body.open .faq-box {
  top: 60px;
  opacity: 1;
  z-index: 3; }
  @media screen and (max-width: 1080px) {
    body.open .faq-box {
      top: 53px; } }
  body.open .faq-box .close {
    opacity: 1;
    z-index: 4; }

.sp-content {
  display: none; }
  @media screen and (max-width: 1080px) {
    .sp-content {
      display: block;
      width: 100%;
      height: 54px;
      padding: 12px 20px 0;
      background: #fff;
      box-shadow: 0 5px 5px 0px rgba(0, 0, 0, 0.1);
      position: fixed;
      top: 0;
      z-index: 1; } }
  .sp-content .sp-logo {
    display: inline-block;
    width: 60px;
    margin: 0 20px 0 0; }
  .sp-content .drawer {
    display: inline-block;
    width: 50px;
    height: 50px;
    background: #fff;
    cursor: pointer;
    padding: 0;
    -webkit-tap-highlight-color: transparent;
    position: fixed;
    top: 0;
    right: 20px; }
    .sp-content .drawer div span {
      position: absolute;
      height: 2px;
      width: 24px;
      margin: auto;
      background: #3D3D3D;
      left: 0;
      right: 0;
      -webkit-transition: 0.35s ease-in-out;
      transition: 0.35s ease-in-out; }
      .sp-content .drawer div span:nth-child(1) {
        top: 22px; }
      .sp-content .drawer div span:nth-child(2) {
        top: 26px; }
      .sp-content .drawer div span:nth-child(3) {
        top: 30px; }

.spNav {
  display: block;
  width: 18%;
  min-width: 180px;
  margin: auto;
  padding: 18px 20px 0 20px;
  transition: opacity 0.5s, right 0.35s ease-in-out;
  background-color: #E8D7C4;
  box-sizing: border-box;
  opacity: 0;
  position: fixed;
  top: 54px;
  bottom: 0;
  overflow-y: scroll;
  right: -100vw;
  left: inherit;
  z-index: 8; }
  .spNav ul {
    margin: 0 auto 30px; }
    .spNav ul li {
      margin: 0 0 10px;
      padding: 0 0 10px;
      list-style: none;
      border-bottom: solid 1px #3d3d3d; }
      .spNav ul li a {
        display: block;
        font-size: 14px;
        text-decoration: none;
        color: #8C6236;
        transition: color 0.3s; }
        .spNav ul li a:hover {
          color: #3d3d3d; }
      .spNav ul li > ul li {
        margin-bottom: 0;
        padding: 0;
        border-bottom: none; }
        .spNav ul li > ul li a {
          font-size: 12px; }
      .spNav ul li:last-of-type {
        padding: 0;
        border-bottom: none; }
  .spNav .pagetop {
    width: 78px;
    margin: 0 auto; }

.navOpen .sp-content .drawer {
  background: transparent; }
  .navOpen .sp-content .drawer span {
    background: #000; }
    .navOpen .sp-content .drawer span:nth-child(1) {
      top: 26px;
      -webkit-transform: rotate(-135deg);
      transform: rotate(-135deg); }
    .navOpen .sp-content .drawer span:nth-child(2) {
      width: 0;
      left: 50%; }
    .navOpen .sp-content .drawer span:nth-child(3) {
      top: 26px;
      -webkit-transform: rotate(135deg);
      transform: rotate(135deg); }
.navOpen .sp-content .spNav {
  opacity: 1;
  right: 0;
  z-index: 8;
  transition: opacity 0.5s, right 0.35s ease-in-out; }

.btn-ticket2 {
  width: 100%;
  padding: 15px; }
  .btn-ticket2 a {
    display: block;
    width: 220px;
    margin: 0 auto 20px;
    padding: 11px 0;
    font-weight: 700;
    text-align: center;
    color: #fff;
    text-decoration: none;
    background: #EE5852;
    border-radius: 6px; }
    @media only, screen and (max-width: 736px) {
      .btn-ticket2 a {
        margin: 0 auto; } }
    .btn-ticket2 a span {
      padding: 0 20px;
      position: relative; }
      .btn-ticket2 a span:after {
        content: "";
        display: block;
        width: 7px;
        height: 7px;
        margin: auto;
        border-top: solid 1px #fff;
        border-right: solid 1px #fff;
        transform: rotate(45deg);
        transform-origin: center;
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        transition: right 0.3s; }
    .btn-ticket2 a:hover span:after {
      right: -5px; }

.txt-attention {
  width: 500px;
  margin: 0 auto 60px;
  font-weight: 600;
  color: #EE5852; }
  @media screen and (max-width: 1080px) {
    .txt-attention {
      width: calc(100% - 40px);
      max-width: 318px;
      margin: 0 auto 30px; } }
  @media screen and (max-width: 320px) {
    .txt-attention {
      width: calc(100% - 20px);
      font-size: 12px; } }
  .txt-attention .txt-indent {
    display: block;
    margin: 0 auto 0 1em;
    text-indent: -1em; }
    @media only, screen and (max-width: 736px) {
      .txt-attention .txt-indent {
        width: fit-content;
        margin: 0 auto; } }
