@charset "UTF-8";
@media all and (min-width: 760px), print {
}
@media all and (min-width: 980px) and (max-width: 1365px) {
}
@media all and (min-width: 760px) and (max-width: 979px) {
}
@media all and (max-width: 759px) {
}

/* ==========================================================================
  FONT FACE ncommon_shared.css
========================================================================== */
@font-face {
  font-weight: normal;
  font-family: 'ncommonJp';
  src: url('/common/font/NotoSansJP-Regular.woff2') format('woff2'), url('/common/font/NotoSansJP-Regular.woff') format('woff');
}
@font-face {
  font-weight: bold;
  font-family: 'ncommonJp';
  src: url('/common/font/NotoSansJP-Bold.woff2') format('woff2'), url('/common/font/NotoSansJP-Bold.woff') format('woff');
}
@font-face {
  font-weight: normal;
  font-family: 'YakuHanJPs';
  font-style: normal;
  src: url('/common/font/YakuHanJPs-Regular.woff2') format('woff2'), url('/common/font/YakuHanJPs-Regular.woff') format('woff');
}
@font-face {
  font-weight: bold;
  font-family: 'YakuHanJPs';
  font-style: normal;
  src: url('/common/font/YakuHanJPs-Bold.woff2') format('woff2'), url('/common/font/YakuHanJPs-Bold.woff') format('woff');
}
/* ==========================================================================
  ELEMENT RESET
========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
  font-family: sans-serif;
}
body {
  font-size: 1em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1em;
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
}
ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 0;
}
dd {
  margin-left: 0;
}
ol,
ul {
  margin: 0;
  padding-left: 0;
  list-style: none;
}
a {
  color: inherit;
  text-decoration: none;
}
a {
  outline: 0;
}
a:focus,
button:focus {
  outline: 0;
}
em {
  font-style: normal;
}
figure {
  margin: 0;
}
table {
  border-collapse: collapse;
}
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
}
button:focus {
  outline: none;
}
input,
button,
select,
textarea {
  line-height: inherit;
}
textarea {
  resize: vertical;
}
fieldset {
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}
legend {
  display: block;
  width: 100%;
  margin-bottom: 0;
  padding: 0;
  line-height: inherit;
}
hr {
  margin: 0;
}
img {
  max-width: 100%;
}
a {
  display: block;
}
/* ==========================================================================
  MEDIA QUERIES
========================================================================== */
/*
@media all and (min-width: 760px),print {
}
@media all and (min-width: 980px),print {
}
@media all and (min-width: 760px) and (max-width: 979px) {
}
@media all and (max-width: 759px) {
}
*/
/* ==========================================================================
  UTILL
========================================================================== */
/* 画像置換 */
.u-ir {
  display: block;
  overflow: hidden;
  font: 0/0 a;
  white-space: nowrap;
  text-indent: 100%;
}

/* PC、タブレットで画像置換 */
@media all and (min-width: 760px), print {
  .u-ir--tab-pc {
    display: block;
    overflow: hidden;
    font: 0/0 a;
    white-space: nowrap;
    text-indent: 100%;
  }
}
/* --------------------------------------------------------------------------
  非表示
-------------------------------------------------------------------------- */
/* PCで非表示 */
@media all and (min-width: 980px), print {
  .u-hide-pc {
    display: none;
  }
}
/* PC、タブレットで非表示 */
@media all and (min-width: 760px), print {
  .u-hide-tab-pc {
    display: none;
  }
}
/* タブレットのみ非表示 */
@media all and (min-width: 760px) and (max-width: 979px) {
  .u-hide-tab {
    display: none;
  }
}
/* SPで非表示 */
@media all and (max-width: 759px) {
  .u-hide-sp {
    display: none;
  }
}
/* SPの小さい画面サイズのみ表示 */
@media all and (min-width: 374px) {
  .u-hide-sp-wide {
    display: none;
  }
}

/* --------------------------------------------------------------------------
  jsからMedia Queries取得用 要<div class="mq"></div>
-------------------------------------------------------------------------- */
/* PC用 */
#mq {
  display: none;
  font-family: 'pc';
}
/* TAB用 */
@media all and (min-width: 760px) and (max-width: 979px) {
  #mq {
    font-family: 'tab';
  }
}
/* SP用 */
@media all and (max-width: 759px) {
  #mq {
    font-family: 'sp';
  }
}

/* --------------------------------------------------------------------------
  行揃え
-------------------------------------------------------------------------- */
.u-center {
  text-align: center;
}
/* TAB,PCのみテキストセンター */
@media all and (min-width: 760px), print {
  .u-center-tab-pc {
    text-align: center;
  }
}
/* SPのみテキストセンター */
@media all and (max-width: 759px) {
  .u-center-sp {
    text-align: center;
  }
}
.u-justify {
  text-align: justify;
  text-justify: inter-ideograph;
}

/* --------------------------------------------------------------------------
  マージン
-------------------------------------------------------------------------- */
.u-mt-05 {
  margin-top: 0.5em;
}
.u-mt-10 {
  margin-top: 1em;
}
.u-mb-05 {
  margin-bottom: 0.5em;
}
.u-mb-10 {
  margin-bottom: 1em;
}
/* ==========================================================================
  TYPO
========================================================================== */
.content-container,
.content-container button,
.content-container input {
  font-family: YakuHanJPs, Roboto, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', ncommonJp, sans-serif;
}
.u-font-sys {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Segoe UI', Arial, sans-serif;
}
.u-font-en {
  font-family: Roboto, sans-serif;
}
body {
  color: #000;
}

/* --------------------------------------------------------------------------
  見出し
-------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
  本文
-------------------------------------------------------------------------- */
/* l */
@media all and (min-width: 760px), print {
  .c-txt-l {
    font-size: 1.8rem;
    line-height: 1.666666667;
  }
}
@media all and (max-width: 759px) {
  .c-txt-l {
    font-size: 1.5rem;
    line-height: 1.666666667;
  }
}
/* m */
@media all and (min-width: 760px), print {
  .c-txt-m,
  .c-list-m {
    font-size: 1.6rem;
    line-height: 1.75;
  }
}
@media all and (max-width: 759px) {
  .c-txt-m,
  .c-list-m {
    font-size: 1.4rem;
    line-height: 1.75;
  }
}
/* s */
@media all and (min-width: 760px), print {
  .c-txt-s,
  .c-list-s {
    font-size: 1.4rem;
    line-height: 1.75;
  }
}
@media all and (max-width: 759px) {
  .c-txt-s,
  .c-list-s {
    font-size: 1.2rem;
    line-height: 1.5;
  }
}
/* xs */
@media all and (min-width: 760px), print {
  .c-txt-xs,
  .c-list-xs {
    font-size: 1.1rem;
    line-height: 1.5;
  }
}
@media all and (max-width: 759px) {
  .c-txt-xs,
  .c-list-xs {
    font-size: 1rem;
    line-height: 1.5;
  }
}
/* --------------------------------------------------------------------------
  注釈
-------------------------------------------------------------------------- */
/* m */
@media all and (min-width: 760px), print {
  .c-note-m {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
@media all and (max-width: 759px) {
  .c-note-m {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
/* s */
@media all and (min-width: 760px), print {
  .c-note-s {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
@media all and (max-width: 759px) {
  .c-note-s {
    font-size: 1.2rem;
    line-height: 1.5;
  }
}
/* xs */
@media all and (min-width: 760px), print {
  .c-note-xs {
    font-size: 1.1rem;
    line-height: 1.5;
  }
}
@media all and (max-width: 759px) {
  .c-note-xs {
    font-size: 1rem;
    line-height: 1.5;
  }
}

/* --------------------------------------------------------------------------
  リスト
-------------------------------------------------------------------------- */
.c-list-m,
.c-list-s,
.c-list-xs {
}
.c-list-m li + li,
.c-list-s li + li,
.c-list-xs li + li {
}
li .c-list-m,
li .c-list-s,
li .c-list-xs {
  margin-top: 0.5em;
}
ol.c-list-m,
ol.c-list-s,
ol.c-list-xs {
  padding-left: 2em;
  list-style-type: decimal;
}

ul.c-list-m li,
ul.c-list-s li,
ul.c-list-xs li {
  position: relative;
  padding-left: 1.25em;
}
ul.c-list-m li::before,
ul.c-list-s li::before,
ul.c-list-xs li::before {
  position: absolute;
  left: 0;
  display: block;
  background: #8c8c8c;
  border-radius: 999px;
  content: '';
}
ul.c-list-m li::before,
ul.c-list-s li::before {
  width: 0.75em;
  height: 0.75em;
}
ul.c-list-xs li::before {
  width: 0.7em;
  height: 0.7em;
}
ul.c-list-m li::before,
ul.c-list-s li::before {
  top: calc((1.5em / 2) - 0.225em);
}
ul.c-list-xs li::before {
  top: calc((1.5em / 2) - 0.4em);
}

ul.c-list--num li::before {
  display: none;
}
ul.c-list--num li {
  padding-left: 2.5em;
}
.c-list__ico-num {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
}
ul.c-list--dot li::before {
  top: 0;
  width: auto;
  height: auto;
  background-color: transparent;
  content: '・';
}
@media all and (min-width: 760px), print {
  ul.c-list-s li::before {
    width: 10px;
    height: 10px;
  }
  ul.c-list--dot li::before {
    top: 0;
    width: auto;
    height: auto;
    background-color: transparent;
    content: '・';
  }
}
/* --------------------------------------------------------------------------
  注釈
-------------------------------------------------------------------------- */
.c-note-m,
.c-note-s,
.c-note-xs {
  position: relative;
  padding-left: 1.25em;
  color: #8c8c8c;
}

.c-note-m::before,
.c-note-s::before,
.c-note-xs::before {
  position: absolute;
  top: 0;
  left: 0;
  content: '※';
}
.c-note-m.c-note--num::before,
.c-note-s.c-note--num::before,
.c-note-xs.c-note--num::before {
  display: none;
}
.c-note--num .c-note-ico {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 2.25em;
}
.c-note-m.c-note--num,
.c-note-s.c-note--num,
.c-note-xs.c-note--num {
  padding-left: 2.25em;
}
/* --------------------------------------------------------------------------
  文中テキストリンク
-------------------------------------------------------------------------- */
.c-txt-l a,
.c-txt-m a,
.c-txt-s a,
.c-txt-xs a,
.c-list-m a,
.c-list-s a,
.c-list-xs a,
.c-note-m a,
.c-note-s a,
.c-note-xs a {
  color: inherit;
  text-decoration: underline;
}
.no-touchevents .c-txt-l a,
.no-touchevents .c-txt-m a,
.no-touchevents .c-txt-s a,
.no-touchevents .c-txt-xs a,
.no-touchevents .c-list-m a,
.no-touchevents .c-list-s a,
.no-touchevents .c-list-xs a,
.no-touchevents .c-note-m a,
.no-touchevents .c-note-s a,
.no-touchevents .c-note-xs a {
  transition: color 0.15s ease-out;
}
.no-touchevents .c-txt-l a:hover,
.no-touchevents .c-txt-m a:hover,
.no-touchevents .c-txt-s a:hover,
.no-touchevents .c-txt-xs a:hover,
.no-touchevents .c-list-m a:hover,
.no-touchevents .c-list-s a:hover,
.no-touchevents .c-list-xs a:hover,
.no-touchevents .c-note-m a:hover,
.no-touchevents .c-note-s a:hover,
.no-touchevents .c-note-xs a:hover {
  color: #4285f4;
  text-decoration: none;
}
/* --------------------------------------------------------------------------
  テキスト 装飾
-------------------------------------------------------------------------- */
/* 強い強調 */
strong,
.u-strong {
  color: #e60012;
  font-weight: bold;
}
/* 強調 */
em,
.u-em {
  color: #d8231e;
}

.u-bold {
  font-weight: bold;
}
.u-red {
  color: #e60012;
}
/* --------------------------------------------------------------------------
  上付き、下付き
-------------------------------------------------------------------------- */
.c-txt-l sub,
.c-txt-l sup {
  font-size: 54%;
}
.c-txt-l sup {
  top: -0.64em;
}
.c-txt-l sub {
  bottom: -0.1em;
}
@media all and (min-width: 760px), print {
  .c-txt-m sub,
  .c-txt-m sup {
    font-size: 54%;
  }
  .c-txt-m sup {
    top: -0.5em;
  }
  .c-txt-m sub {
    bottom: -0.1em;
  }
  .c-txt-s sub,
  .c-txt-s sup {
    font-size: 54%;
  }
  .c-txt-s sup {
    top: -0.4em;
  }
  .c-txt-s sub {
    bottom: -0.05em;
  }
  .c-txt-xs sub,
  .c-txt-xs sup {
    display: inline-block;
    font-size: 10px;
    transform: scale(0.8);
  }
  .c-txt-xs sup {
    top: -0.2em;
    transform-origin: 0 0;
  }
  .c-txt-xs sub {
    bottom: -0.1em;
    transform-origin: 0 100%;
  }
}
@media all and (max-width: 759px) {
  .c-txt-m sub,
  .c-txt-m sup {
    font-size: 54%;
  }
  .c-txt-m sup {
    top: -0.7em;
  }
  .c-txt-m sub {
    bottom: -0.1em;
  }
  .c-txt-s sub,
  .c-txt-s sup {
    font-size: 60%;
  }
  .c-txt-s sup {
    top: -0.6em;
  }
  .c-txt-s sub {
    bottom: -0.1em;
  }
  .c-txt-xs sub,
  .c-txt-xs sup {
    font-size: 60%;
  }
  .c-txt-xs sup {
    top: -0.6em;
  }
  .c-txt-xs sub {
    bottom: -0.05em;
  }
}
@media all and (min-width: 760px), print {
  .c-table-txt {
    display: table;
  }
  .c-table-txt__row {
    display: table-row;
  }
  .c-table-txt__h {
    display: table-cell;
    font-weight: bold;
  }
  .c-table-txt__d {
    display: table-cell;
    padding: 0 0 0 5px;
  }
  .c-table-txt__row + .c-table-txt__row .c-table-txt__h,
  .c-table-txt__row + .c-table-txt__row .c-table-txt__d {
    padding-top: 0.25em;
  }
}
@media all and (max-width: 759px) {
  .c-table-txt {
  }
  .c-table-txt__row {
    display: block;
  }
  .c-table-txt__h {
    display: block;
    font-weight: bold;
  }
  .c-table-txt__d {
    display: block;
  }
  .c-table-txt__row + .c-table-txt__row {
    margin-top: 0.5em;
  }
}



@media all and (min-width: 760px), print {
  .c-txt-link {
    font-weight: bold;
  }
  .c-txt-link--em {
    color: #e60012 !important;
    font-weight: bold;
  }

  .c-txt-link__ico {
    display: inline-block;
    width: 13px;
    height: 13px;
    margin-right: 5px;
    vertical-align: baseline;
    background-image: url(../img/common/ico_arrow_block.svg);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-txt-link__ico--gray {
    background-image: url(../img/common/ico_arrow_block_gray.svg);
  }
  .c-txt-link__ico--dark-gray {
    background-image: url(../img/common/ico_arrow_block_dark-gray.svg);
  }
  .c-txt-link__txt {
    display: inline-block;
    font-size: 14px;
    text-decoration: underline;
    vertical-align: baseline;
  }
  .no-touchevents .c-txt-link {
    transition: color 0.15s ease-out;
  }
  .no-touchevents .c-txt-link:hover {
    color: #e60012;
    text-decoration: none;
  }
  .no-touchevents .c-txt-link:hover .c-txt-link__txt {
    text-decoration: none;
  }
}
@media all and (max-width: 759px) {
  .c-txt-link--em {
    color: #e60012 !important;
    font-weight: bold;
  }

  .c-txt-link__ico {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-right: 5px;
    vertical-align: baseline;
    background-image: url(../img/common/ico_arrow_block.svg);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-txt-link__ico--gray {
    background-image: url(../img/common/ico_arrow_block_gray.svg);
  }
  .c-txt-link__ico--dark-gray {
    background-image: url(../img/common/ico_arrow_block_dark-gray.svg);
  }
  .c-txt-link__txt {
    display: inline-block;
    font-size: inherit;
    text-decoration: underline;
    vertical-align: baseline;
  }

  .c-txt-link--fl {
    position: relative;
    display: inline-block;
    padding-left: 15px;
  }
  .c-txt-link--fl .c-txt-link__ico {
    position: absolute;
    top: 0.2em;
    left: 0;
  }
}

/* ==========================================================================
  gnav
========================================================================== */
.c-grid,
.c-grid--2-3-4,
.c-grid--1-1-3,
.c-grid--2-2-4,
.c-grid-m--2-3-4,
.c-grid--1-2,
.c-grid--2-3,
.c-grid--2-4,
.c-grid--1-3,
.c-grid--4,
.c-grid--3,
.c-grid--2,
.c-grid--1 {
  display: flex;
  flex-wrap: wrap;
}
.c-grid__col {
  flex-grow: 0;
  flex-shrink: 1;
}
@media all and (min-width: 980px), print {
  .c-grid--1-1-3 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid--2-3-4 .c-grid__col,
  .c-grid--2-2-4 .c-grid__col,
  .c-grid-m--2-3-4 .c-grid__col {
    width: calc(100% / 4);
  }
  .c-grid-m--2-3-4 .c-grid__col {
    width: calc((100% - 32px * 3) / 4);
  }
  .c-grid-m--2-3-4 .c-grid__col:not(:nth-child(4n)) {
    margin-right: 32px;
  }
  .c-grid-m--2-3-4 .c-grid__col:nth-child(n + 5) {
    margin-top: 32px;
  }
}
@media all and (min-width: 760px) and (max-width: 979px) {
  .c-grid--1-1-3 .c-grid__col {
    width: 100%;
  }
  .c-grid--2-3-4 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid-m--2-3-4 .c-grid__col {
    width: calc((100% - 32px * 2) / 3);
  }
  .c-grid-m--2-3-4 .c-grid__col:not(:nth-child(3n)) {
    margin-right: 32px;
  }
  .c-grid-m--2-3-4 .c-grid__col:nth-child(n + 4) {
    margin-top: 32px;
  }
  .c-grid--2-2-4 .c-grid__col {
    width: calc(100% / 2);
  }
}
@media all and (max-width: 759px) {
  .c-grid--1-1-3 .c-grid__col {
    width: 100%;
  }
  .c-grid--2-3-4 .c-grid__col,
  .c-grid--2-2-4 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid-m--2-3-4 .c-grid__col {
    width: calc((100% - 14px) / 2);
  }
  .c-grid-m--2-3-4 .c-grid__col:not(:nth-child(2n)) {
    margin-right: 14px;
  }
  .c-grid-m--2-3-4 .c-grid__col:nth-child(n + 3) {
    margin-top: 28px;
  }
}

@media all and (min-width: 760px), print {
  .c-grid--1-2 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid--2-3 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid--2-4 .c-grid__col {
    width: calc(100% / 4);
  }
  .c-grid--1-3 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid--4 .c-grid__col {
    width: calc(100% / 4);
  }
  .c-grid--3 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid--2 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid--1 .c-grid__col {
    width: 100%;
  }
}
@media all and (max-width: 759px) {
  .c-grid--1-2 .c-grid__col {
    width: 100%;
  }
  .c-grid--2-3 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid--2-4 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid--1-3 .c-grid__col {
    width: 100%;
  }
  .c-grid--4 .c-grid__col {
    width: calc(100% / 4);
  }
  .c-grid--3 .c-grid__col {
    width: calc(100% / 3);
  }
  .c-grid--2 .c-grid__col {
    width: calc(100% / 2);
  }
  .c-grid--1 .c-grid__col {
    width: 100%;
  }
}
/* --------------------------------------------------------------------------
  SECTION
-------------------------------------------------------------------------- */
.c-section__body--gray {
  background-color: #f8f8f8;
}
.c-section__body--yellow {
  background-color: #ffd302;
}
@media all and (min-width: 760px), print {
  .c-section {
  }
  .c-section__inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 20px;
  }
  .c-section__body {
  }

  .c-section-narrow {
  }
  .c-section-narrow__inner {
    max-width: 980px;
    margin: 0 auto;
    padding: 0 10px;
  }
  .c-section-narrow__body {
  }
}
@media all and (min-width: 760px) and (max-width: 979px) {
}
@media all and (max-width: 759px) {
  .c-section {
  }
  .c-section__inner {
    padding: 0 6px;
  }
  .c-section__body {
  }
  .c-section-narrow {
  }
  .c-section-narrow__inner {
    padding: 0 11px;
  }
  .c-section-narrow__body {
  }
}

/* --------------------------------------------------------------------------
  PAGE HEADER
-------------------------------------------------------------------------- */
.page-header__day img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media all and (min-width: 760px), print {
  .page-header {
    padding: 20px 0;
  }
  .page-header__body {
    display: flex;
    align-items: center;
  }
  .page-header__ico {
    display: flex;
  }
  .page-header__day {
    width: 80px;
  }
  .page-header__day + .page-header__day {
    margin-left: 3px;
  }
  .page-header__title {
    margin-left: 28px;
    font-size: 28px;
    line-height: 1.428571429;
  }
  .page-header__title span {
    display: block;
    font-size: 20px;
  }
  /* .page-header__title {
    margin-left: 14px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .page-header__title::before {
    display: block;
    content: '';
  }
  .page-header__title--haikalive {
    width: 390px;
    background-image: url(../img/event/haikalive/page_title_pc.svg);
  }
  .page-header__title--haikalive::before {
    padding-top: calc((60.02 / 390.37) * 100%);
  } */
}
@media all and (min-width: 760px) and (max-width: 979px) {
  .page-header__title {
    font-size: 24px;
  }
  .page-header__title span {
    font-size: 16px;
  }
}
@media all and (max-width: 759px) {
  .page-header {
    padding: 6px 0;
  }
  .page-header__body {
    display: flex;
    align-items: center;
  }
  .page-header__ico {
    display: flex;
  }
  .page-header__day {
    width: 40px;
  }
  .page-header__day + .page-header__day {
    margin-left: 2px;
  }
  .page-header__title {
    margin-left: 7px;
    font-size: 14px;
    line-height: 1.428571429;
  }
  .page-header__title span {
    display: block;
    font-size: 11px;
  }

  /* .page-header__title {
    margin-left: 7px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .page-header__title::before {
    display: block;
    content: '';
  }
  .page-header__title--haikalive {
    width: calc((422 / 738) * 100%);
    background-image: url(../img/event/haikalive/page_title_pc.svg);
  }
  .page-header__title--haikalive::before {
    padding-top: calc((60.02 / 390.37) * 100%);
  } */
}
@media all and (max-width: 374px) {
  .page-header__title--yoiko br {
    display: none;
  }
}

/* ==========================================================================
  GLOBAL HEADER
========================================================================== */
.gheader img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media all and (min-width: 980px), print {
  .gheader {
  }
  .gheader__inner {
    position: relative;
  }
  .gheader__inner::before {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    height: 9px;
    background: #e60012;
    border-top: 2px solid #fafafa;
    content: '';
  }
  .gheader-body {
    position: relative;
    /* max-width: 1440px; */
    /* margin: 0 auto; */
  }
  .gheader-bar {
    height: 163px;
  }
  .gheader-bar__logo {
    position: absolute;
    top: 40px;
    left: 50px;
    width: 258px;
  }
  .gheader-bar__logo-btn {
    display: block;
  }
  .gheader-bar__title {
    position: absolute;
    top: 71px;
    left: 47px;
    width: 539px;
    height: 52px;
    background-repeat: no-repeat;
    background-position: 0 center;
    background-size: contain;
  }

  .gheader-bar__title--faq {
    position: absolute;
    top: 71px;
    left: 47px;
    width: 434px;
  }

  .gheader-bar__title--event {
    background-image: url(../img/event/local_header_pc.svg);
  }
  .gheader-bar__title--event::before {
    display: block;
    padding-top: calc((52 / 434) * 100%);
    content: '';
  }
  .gheader-bar__title--tournament {
    background-image: url(../img/tournament/local_header_pc.svg);
  }
  .gheader-bar__title--tournament::before {
    display: block;
    padding-top: calc((52 / 539) * 100%);
    content: '';
  }
  .gheader-bar__btn {
    display: none;
  }
  .gheader-drawer {
    position: absolute;
    top: 0;
    right: 0;
  }
  .gheader-drawer__bg {
    display: none;
  }
  .gheader-main {
  }
  .gheader-main__body {
  }
  .gheader-nav {
  }
  .gheader-nav__body {
    display: flex;
  }
  .gheader-nav__item {
    width: 158px;
    height: 163px;
    padding-left: 2px;
    background: #fafafa;
  }
  .gheader-nav__btn {
    display: block;
    height: 163px;
  }
  .gheader-nav__btn::after {
    display: block;
    height: 7px;
    margin-top: 2px;
    background: #e60012;
    content: '';
  }
  .gheader-nav__btn-body {
    height: 154px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .gheader-nav__item:nth-child(2n + 1) .gheader-nav__btn-body {
    background-color: #fafafa;
  }
  .gheader-nav__item:nth-child(2n) .gheader-nav__btn-body {
    background-color: #ececec;
  }
  .gheader-nav__item.gheader-nav__item--haikalive .gheader-nav__btn-body {
    background-color: #000;
    background-image: url(../img/common/gnav_haikalive.jpg);
  }
  .gheader-nav__item.gheader-nav__item--yoiko .gheader-nav__btn-body {
    background-color: #ffce00;
    background-image: url(../img/common/gnav_yoiko.png);
  }
  .gheader-nav__item.gheader-nav__item--smb-japan .gheader-nav__btn-body {
    background-color: #000;
    background-image: url(../img/common/gnav_smb-japan.png);
  }
  .gheader-nav__item.gheader-nav__item--smb-world .gheader-nav__btn-body {
    background-color: #f7f3f9;
    background-image: url(../img/common/gnav_smb-world.jpg);
  }
  .gheader-nav__item.gheader-nav__item--jr-zenkoku .gheader-nav__btn-body {
    background-color: #000;
    background-image: url(../img/common/gnav_jr-zenkoku.jpg);
  }

  .gheader-nav__item.gheader-nav__item--jr-kyoto .gheader-nav__btn-body {
    background-color: #000;
    background-image: url(../img/common/gnav_jr-kyoto.jpg);
  }
  .gheader-nav__item.gheader-nav__item--saikyo .gheader-nav__btn-body {
    background-color: #fff;
    background-image: url(../img/common/gnav_saikyo.png);
  }
  .gheader-nav__item.gheader-nav__item--asobu .gheader-nav__btn-body {
    background-color: #ffce00;
    background-image: url(../img/common/gnav_asobu.png);
  }
  .gheader-nav__item.gheader-nav__item--splatoon .gheader-nav__btn-body {
    background-color: #140aff;
    background-image: url(../img/common/gnav_splatoon.png);
  }

  .gheader-nav__item--haikalive .gheader-nav__btn::after {
  }
  .gheader-close {
    display: none;
  }
}
@media all and (min-width: 980px) and (max-width: 1365px) {
  .gheader__inner::before {
    height: 9px;
  }
  .gheader-bar {
    height: calc((106px + 2px) + 7px);
  }
  .gheader-bar__logo {
    top: 20px;
    left: 30px;
    width: 206px;
  }
  .gheader-bar__title {
    top: 51px;
    left: 23px;
    width: 431.2px; /* 0.8 */
    height: 41.6px;
  }
  .gheader-bar__title--faq {
    position: absolute;
    top: 51px;
    left: 30px;
    width: 360px;
  }
  .gheader-nav__item {
    width: calc(107px + 2px);
    height: calc((106px + 2px) + 7px);
  }
  .gheader-nav__btn {
    height: calc((106px + 2px) + 7px);
  }
  .gheader-nav__btn::after {
    height: 7px;
  }
  .gheader-nav__btn-body {
    height: 106px;
  }
}

@media all and (max-width: 979px) {
  html.is-drawer-opened {
    overflow: hidden;
  }
  .gheader {
  }
  .gheader__inner {
  }
  .gheader-body {
  }
  .gheader-bar {
    position: absolute;
    top: 60px;
    right: 0;
    left: 0;
    z-index: 11;
    background: #fff;
  }
  .gheader-bar__logo {
    padding-top: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid #d6d6d6;
  }
  .gheader-bar__logo-btn {
    display: block;
    width: 256px;
    margin: 0 auto;
  }
  .gheader-bar__body {
    position: relative;
    z-index: 10;
    height: 89px;
    border-bottom: 5px solid #e60012;
  }
  .gheader-bar__title {
    position: absolute;
    top: 50%;
    left: 10px;
    width: calc((435.69 / 750) * 100%);
    height: 40px;
    background-repeat: no-repeat;
    background-position: 0 50%;
    background-size: contain;
    transform: translateY(-50%);
  }
  .gheader-bar__title--faq {
    position: absolute;
    top: 50%;
    left: 10px;
    width: calc((337.69 / 750) * 100%);
    transform: translateY(-50%);
  }
  .gheader-bar__title--event {
    background-image: url(../img/event/local_header_sp.svg);
  }
  .gheader-bar__title--event::before {
    display: block;
    padding-top: calc((79.23 / 435.69) * 100%);
    content: '';
  }
  .gheader-bar__title--tournament {
    background-image: url(../img/tournament/local_header_sp.svg);
  }
  .gheader-bar__title--tournament::before {
    display: block;
    padding-top: calc((79.23 / 435.69) * 100%);
    content: '';
  }
  .gheader-bar__btn {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
  }
  .gheader-hamburger {
  }
  .gheader-hamburger__body {
    display: flex;
  }
  .gheader-hamburger__ico {
    position: relative;
    width: 10px;
    height: 10px;
    margin-left: 5px;
  }
  .gheader-hamburger__ico i {
    position: absolute;
    left: 0;
    display: block;
    width: 10px;
    height: 1px;
    background: #3c3c3c;
  }
  .gheader-hamburger__ico i:nth-child(1) {
    top: 2px;
  }
  .gheader-hamburger__ico i:nth-child(2),
  .gheader-hamburger__ico i:nth-child(3) {
    top: 5px;
    transition: 0.2s;
  }
  .gheader-hamburger__ico i:nth-child(4) {
    top: 8px;
  }

  .is-drawer-active .gheader-hamburger__ico i:nth-child(1) {
    opacity: 0;
  }
  .is-drawer-active .gheader-hamburger__ico i:nth-child(2) {
    transform: rotate(-45deg);
  }
  .is-drawer-active .gheader-hamburger__ico i:nth-child(3) {
    transform: rotate(45deg);
  }
  .is-drawer-active .gheader-hamburger__ico i:nth-child(4) {
    opacity: 0;
  }
  .gheader-hamburger__label {
    font-weight: bold;
    font-size: 10px;
    transform-origin: 100% 50%;
  }
  .gheader-drawer {
    position: absolute;
    top: 60px;
    right: 0;
    left: 0;
    height: 100%;
    visibility: hidden;
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-duration: 1s;
    transition-property: visibility;
  }
  .gheader-drawer.is-drawer-active {
    visibility: visible;
  }
  .gheader-drawer__bg {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    opacity: 0;
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-duration: 1s;
    transition-property: opacity;
  }
  .gheader-drawer__bg.is-drawer-active {
    z-index: 0;
    opacity: 9;
  }
  .gheader-main {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    height: 100%;
    overflow: auto;
    transform: translate3d(0, -100%, 0);
    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    transition-duration: 1s;
    transition-property: transform;
    -webkit-overflow-scrolling: touch;
  }
  .is-drawer-active .gheader-main {
    transform: translate3d(0, 0, 0);
  }
  .gheader-main__body {
    padding-top: 128px;
    padding-bottom: 72px;
    background: #fff;
  }
  .gheader-nav {
    padding: 16px;
  }
  .gheader-nav__body {
    display: flex;
    flex-wrap: wrap;
  }
  .gheader-nav__item {
    flex-grow: 0;
    flex-shrink: 1;
    width: calc((100% - 16px) / 2);
    margin-top: 16px;
    margin-right: 16px;
  }
  .gheader-nav__item:nth-child(2n + 1) {
    background-color: #fafafa;
  }
  .gheader-nav__item:nth-child(2n) {
    margin-right: 0;
    background-color: #ececec;
  }
  .gheader-nav__item:nth-child(-n + 2) {
    margin-top: 0;
  }
  .gheader-nav__btn {
    display: block;
    padding-top: 100%;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .gheader-nav__item--haikalive .gheader-nav__btn {
    background-color: #000;
    background-image: url(../img/common/gnav_haikalive.jpg);
  }
  .gheader-nav__item--yoiko .gheader-nav__btn {
    background-color: #ffce00;
    background-image: url(../img/common/gnav_yoiko.png);
  }

  .gheader-nav__item--smb-japan .gheader-nav__btn {
    background-color: #000;
    background-image: url(../img/common/gnav_smb-japan.png);
  }
  .gheader-nav__item--smb-world .gheader-nav__btn {
    background-color: #f7f3f9;
    background-image: url(../img/common/gnav_smb-world.jpg);
  }
  .gheader-nav__item--jr-zenkoku .gheader-nav__btn {
    background-color: #000;
    background-image: url(../img/common/gnav_jr-zenkoku.jpg);
  }

  .gheader-nav__item--jr-kyoto .gheader-nav__btn {
    background-color: #000;
    background-image: url(../img/common/gnav_jr-kyoto.jpg);
  }
  .gheader-nav__item--saikyo .gheader-nav__btn {
    background-color: #fff;
    background-image: url(../img/common/gnav_saikyo.png);
  }
  .gheader-nav__item--asobu .gheader-nav__btn {
    background-color: #ffce00;
    background-image: url(../img/common/gnav_asobu.png);
  }
  .gheader-nav__item--splatoon .gheader-nav__btn {
    background-color: #140aff;
    background-image: url(../img/common/gnav_splatoon.png);
  }

  .gheader-close {
    padding: 0 16px;
  }
  .gheader-close__btn {
    display: block;
    padding: 10px 0;
    background: #e8e8e8;
  }
  .gheader-close__btn span {
    display: block;
    width: calc((90 / 686) * 100%);
    margin: 0 auto;
  }
}

@media all and (min-width: 641px) and (max-width: 979px) {
  .gheader-bar {
    top: 40px;
  }
  .gheader-drawer {
    top: 40px;
  }
}

/* ==========================================================================
  FOOTER
========================================================================== */
@media all and (min-width: 1080px), print {
  .page-footer {
    position: relative;
    padding-top: 14px;
    background-color: #FFF;
    border-top: 1px solid #d6d6d6;
  }
  .page-footer-inner {
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 0 10px 16px;;
  }
  .page-footer-right {
    display: flex;
    justify-content: flex-end;
  }
  .page-footer-right__list {
    display: flex;
  }
  .page-footer-right__sns-btn {
    position: relative;
    top: -4px;
  }
  .page-footer-right__sns-btn + .page-footer-right__sns-btn {
    margin-left: 6px;
  }
  .page-footer-left__body {
    display: flex;
    justify-content: flex-end;
  }
  .page-footer-nav {
    display: flex;
    margin-right: 30px;
  }
  .page-footer-nav__item a:hover {
    color: #e60012;
  }
  .page-footer-nav__item + .page-footer-nav__item {
    margin-left: 34px;
  }
  .page-footer-nav__item span {
    display: inline-block;
    font-weight: bold;
    font-size: 11px;
    line-height: 1;
    margin-left: 8px;
  }
  .page-footer__back2top {
    margin-right: 25px;
  }
  .page-footer__copyright {
    width: 100%;
    color: #fff;
    background: #e60012;
    font-weight: bold;
    font-size: 10px;
    line-height: 1;
    width: 100%;
    padding: 15px 0 16px;
    text-align: center;

  }
}
@media all and (min-width: 1080px) and (max-width: 1240px) {
  .page-footer-nav {
    display: flex;
    margin-right: 15px;
  }
  .page-footer-nav__item {
  }
  .page-footer-nav__item + .page-footer-nav__item {
    margin-left: 17px;
  }
  .page-footer__back2top {
    margin-right: 17.5px;
  }
}
@media all and (max-width: 1079px) {
  .page-footer {
    position: relative;
    background-color: #FFF;
    border-top: 1px solid #d6d6d6;
  }
  .page-footer-inner {
    padding: 16px 15px;
    position: relative;
  }
  .page-footer-right__list {
    display: flex;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -ms-flex-pack: justify;
    justify-content: flex-end;
    margin-top: 10px;
  }
  .page-footer-right__sns-btn + .page-footer-right__sns-btn {
    margin-right: 6px;
  }
  .page-footer-left__body {
    display: flex;
    justify-content: space-between;
  }
  .page-footer-nav__item {
  }
  .page-footer-nav__item + .page-footer-nav__item {
    margin-top: 10px;
  }
  .page-footer-nav__item span {
    display: inline-block;
    font-weight: bold;
    font-size: 11px;
    line-height: 1;
    margin-left: 8px;
  }
  .page-footer__back2top {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .page-footer__back2top .c-inline-icon--red {
    text-align: center;
  }
  .page-footer__back2top .c-inline-icon--red:before {
    display: block;
    width: 14px;
    height: 14px;
    margin: 0 auto;
  }
  .page-footer__back2top .c-inline-icon--red span {
    margin: 5px 0 0;
  }
  .page-footer__copyright {
    width: 100%;
    color: #fff;
    background: #e60012;
    font-weight: bold;
    font-size: 10px;
    line-height: 1;
    width: 100%;
    padding: 15px 0 16px;
    text-align: center;

  }
}
/* ==========================================================================
  MODAL
========================================================================== */
.modal {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -10;
  visibility: hidden;
  transition-duration: 0.2s;
  transition-property: visibility;
}
.modal-bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: url(../img/common/c-bg.png) 0 0 ;
  opacity: 0;
  transition-timing-function: ease-out;
  transition-duration: 0.2s;
  transition-property: opacity;
}
.modal-main {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: auto;
  transform: translate3d(0, 1.5%, 0);
  transition-timing-function: ease-out;
  transition-duration: 0.2s;
  transition-property: transform;
  -webkit-overflow-scrolling: touch;
}
.modal-content {
  opacity: 0;
  transition-timing-function: ease-out;
  transition-duration: 0.2s;
  transition-property: opacity;
}
/* open */
.is-modal-opened .modal {
  z-index: 10999;
  visibility: visible;
}
.modal.is-opened .modal-bg {
  opacity: 1;
}
.modal.is-opened .modal-main {
  transform: translate3d(0, 0, 0);
}
.modal.is-opened .modal-content {
  opacity: 1;
}
html {
  overflow-y: scroll;
}
html.is-modal-opened {
  overflow: hidden;
}
html.is-modal-opened .modal-main {
  /* overflow-y: scroll; */
}
/* clese */

@media all and (min-width: 768px) {
  .modal-main-bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
  }
  .modal-content {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin: 0 auto;
    padding: 0 0;
  }
  .modal-close {
    width: 80px;
    position: fixed;
    right: 10px;
    top: 10px;
  }
  .modal-close a {
    display: block;
    width: 80px;
    height: 80px;
    text-align: center;
    background: #e60012;
    position: relative;
  }
  .modal-close a span{
    position: absolute;
    display: block;
    width: 60px;
    height: 60px;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
    transform: rotate(45deg);
  }
  .modal-close a span::before{
    content: "";
    width: 100%;
    height: 2px;
    background: #FFF;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
  .modal-close a span::after{
    content: "";
    width: 2px;
    height: 100%;
    background: #FFF;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
  .no-touchevents .modal-close a:hover {
    opacity: 0.8;
  }
}
@media all and (max-width: 759px) {
  .modal-content {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 94%;
    margin: 0 auto;
    padding: 0 0 0 0;
  }

  .modal-close {
    display: block;
    padding: 10px 0;
    background: #e60012;
    position: relative;
    text-align: center;
    margin-top: 40px;
    margin-bottom: 40px;
    width: 70%;
    margin-left: auto;
    margin-right: auto;
  }
  .modal-close a::after {
    content: "とじる";
    display: inline-block;
    vertical-align: middle;
    color: #FFF;
    font-weight: bold;
    font-size: 13px;
    margin-left: 10px;
  }
  .modal-close span {
    width: 14px;
    height: 14px;
    transform: rotate(45deg);
    display: inline-block;
    vertical-align: middle;
  }
  .modal-close a span::before{
    content: "";
    width: 100%;
    height: 2px;
    background: #FFF;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
  .modal-close a span::after{
    content: "";
    width: 2px;
    height: 100%;
    background: #FFF;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
  }
}
@media all and (max-width: 374px) {
}

/* ==========================================================================
  Layout
========================================================================== */
body::before{
  content: "";
  display: block;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background-image: url(../img/common/c-bg.png);
  background-position: left center;
  background-repeat: repeat;
  z-index: -1;
}
.content-container {
}
.content-container.no-back-ground-image {
  background-image: none;
  background-color: #FFF;
}
.navi-container-navi dd a {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  font-size: 0;
}
.navi-container-navi dd.is-current a {
  pointer-events:none;
}
.navi-container-navi dd a.is-active img,
.navi-container-navi dd.is-current a img {
  opacity: 0;
}
@media all and (min-width: 980px), print {
  .content-container {
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  /* side navi */
  .navi-container {
    width: 249px;
    position: absolute;
    top: 0;
    bottom: 0;
  }
  .is-page-navi-fixed .navi-container {
    position: fixed;
  }
  .navi-container-inner {
    position: relative;
    height: 100%;
    border-right: 1px solid #dedede;
    background-color: #fbfbfb;

  }
  .navi-container-inner h1{
    position: absolute;
    left: 0;
    top: 40px;
  }
  .is-page-navi-fixed .navi-container-inner h1{
    top: 0;
  }
  .navi-container-navi {
    position: fixed;
    left: 0;
    bottom: 0;
  }
  .navi-container-navi dt {
    font-size: 12px;
    padding: 0 20px;
  }
  .navi-container-navi dd  a img {
    width: 248px;
  }
  .navi-container-navi dd:nth-child(2) a {
    background-image: url(../img/common/navi01-hover.svg);
  }
  .navi-container-navi dd:nth-child(3) a {
    background-image: url(../img/common/navi02-hover.svg);
  }
  .navi-container-navi dd:nth-child(4) a {
    background-image: url(../img/common/navi03-hover.svg);
  }
  .navi-container-navi dd:nth-child(5) a {
    background-image: url(../img/common/navi04-hover.svg);
  }
  .navi-container-navi dd:nth-child(6) a {
    background-image: url(../img/common/navi05-hover.svg);
  }
  .navi-container-navi dd.is-current:nth-child(2) a {
    background-image: url(../img/common/navi01-on.svg);
  }
  .navi-container-navi dd.is-current:nth-child(3) a {
    background-image: url(../img/common/navi02-on.svg);
  }
  .navi-container-navi dd.is-current:nth-child(4) a {
    background-image: url(../img/common/navi03-on.svg);
  }
  .navi-container-navi dd.is-current:nth-child(5) a {
    background-image: url(../img/common/navi04-on.svg);
  }
    .navi-container-navi dd.is-current:nth-child(6) a {
    background-image: url(../img/common/navi05-on.svg);
  }
  .navi-container-navi a {
    display: inline-block;
    position: relative
  }
  .navi-container-navi a::after {
    content: '';
    position: absolute;
    display: block;
    padding-top: calc(45 / 248 * 100%);
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
  }
  /* main contents */
  .main-container {
    width: 100%;
    padding: 0 0 0 249px;
  }
  .main-inner {
    padding: 0 10px;
  }
  .main-section {
    padding: 0 30px;
  }
  .main-section--wide {
    padding: 0;
  }
}
@media all and (min-width: 760px) and (max-width: 979px) {
}
@media all and (max-width: 979px) {
  .content-container {
    overflow: hidden;
  }
  /* side navi */
  .navi-container-inner {
    position: relative;
    height: 100%;
    background-color: #fbfbfb;
    background-image: url(../img/common/c-bg.png);
    background-position: left top;
    background-repeat: repeat;
  }
  .navi-container-inner h1 {
    width: calc(397 / 750 * 100%);
    margin: 0 auto;
    padding-top: calc(17 / 750 * 100%);
  }
  .navi-container-inner h1 .u-hide-sp{
    display: none;
  }
  .navi-container-inner h1 img {
    width: 100%;
  }
  .main-section {
    padding: 0 15px;
  }
  .main-section--wide {
    padding: 0;
  }
  .navi-wrap {
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    background-color: #f2f2f2;
  }
  .navi-container-navi {
    font-size: 0;
    display: flex;
    margin: 0 auto;
    padding: 0 calc(21/1071*100%);
    box-sizing: content-box;
    width: 142.8vw;
  }
  .navi-container-navi .u-hide-sp{
    display: none;
  }
  .navi-container-navi .u-hide-tab-pc{
    display: block;
  }
  .navi-container-navi dt{
    display: none;
  }
  .navi-container-navi dd {
    display: inline-block;
  }
  .navi-container-navi dd:nth-child(2) {
    width: calc(175/1071*100%);
    background-image: url(../img/common/navi01-sp-on.svg);
  }
  .navi-container-navi dd:nth-child(3) {
    width: calc(237/1071*100%);
    background-image: url(../img/common/navi02-sp-on.svg);

  }
  .navi-container-navi dd:nth-child(4) {
    width: calc(231/1071*100%);
    background-image: url(../img/common/navi03-sp-on.svg);

  }
  .navi-container-navi dd:nth-child(5) {
    width: calc(254/1071*100%);
    background-image: url(../img/common/navi04-sp-on.svg);

  }
  .navi-container-navi dd:nth-child(6) {
    width: calc(132/1071*100%);
    background-image: url(../img/common/navi05-sp-on.svg);
  }
  .navi-container-navi dd {
    background-position: center top;
    background-repeat: no-repeat;
    background-size: contain;
    font-size: 0;
    flex-grow: 1;
  }
  .navi-container-navi dd.is-active a {
    pointer-events:none;
  }
  .navi-container-navi dd.is-active img {
    opacity: 0;
  }
  @media all and (max-width: 749px) {
    .navi-container-navi dd a:hover img {
      opacity: 1;
    }
  }
}
/* ==========================================================================
  menu
========================================================================== */
@media all and (max-width: 2006px) {
  .page-menu {
    background-color: #e60012;
    height: 58px;
    width: 64px;
    padding: 5px;
    box-sizing: border-box;
    text-align: center;
    display: none;
    border: 2px solid #FFF;
    position: fixed;
    right: 0;
    bottom: 0;
    right: 15px;
    bottom: 15px;
    z-index: 20;
  }
  .page-menu.is-active {
    z-index: 10200;
  }
  .menu-trigger,
  .menu-trigger span {
    display: inline-block;
    transition: all .4s;
    box-sizing: border-box;
  }
  .menu-trigger {
    position: relative;
    width: 25px;
    height: 25px;
  }
  .menu-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #fff;
    border-radius: 4px;
  }
  .menu-trigger span:nth-of-type(1) {
    top: 0;
  }
  .menu-trigger span:nth-of-type(2) {
    top: 10px;
  }
  .menu-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  .menu-trigger::after {
    position: absolute;
    left: 0;
    bottom: -20px;
    content: '';
    display: block;
    background-image: url(../img/common/menu-white.svg);
    background-size: cover;
    background-repeat: no-repeat;
    width: 100%;
    color: #fff;
    width: 48px;
    height: 11px;
    text-decoration: none;
    text-align: center;
    white-space: nowrap;
    transition: all .4s;
    transform: translateX(-25%);
  }
  .is-active .menu-trigger::after {
    display: block;
    background-image: url(../img/common/close-white.svg);
    background-size: cover;
    background-repeat: no-repeat;
    width: 52px;
    height: 11px;
    bottom: -20px;
  }
  .is-active .menu-trigger span:nth-of-type(1) {
    -webkit-transform: translateY(11px) rotate(-45deg);
    transform: translateY(11px) rotate(-45deg);
  }
  .is-active .menu-trigger span:nth-of-type(2) {
    opacity: 0;
  }
  .is-active .menu-trigger span:nth-of-type(3) {
    -webkit-transform: translateY(-10px) rotate(45deg);
    transform: translateY(-10px) rotate(45deg);
  }
}
/* ==========================================================================
  local header(switch logo)
========================================================================== */
.local-header-logo {
  position: absolute;
  top: 0;
  right: 0;
  width: 64px;
  height: 65px;
}
.local-header {
  position: relative;
  z-index: 100;
  width: 100%
}
@media all and (max-width: 759px) {
  .local-header-logo {
    width: 40px;
    height: 40px;
    top: 5px;
    right: 5px;
  }
}
/* ==========================================================================
  txt
========================================================================== */
  .c-note-right::after {
    content: "*";
    display: inline-block;
    color: #e60012;
    font-size: 10px;
    vertical-align: top;
  }
  .c-note-left::before {
    content: "*";
    display: inline-block;
    color: #e60012;
    font-size: 10px;
    vertical-align: top;
  }
/* ==========================================================================
  button
========================================================================== */
  .c-btn-wrap {
    display:-ms-flexbox;
    display:flex;
    -ms-flex-pack: center;
    justify-content: center;
  }
  .c-btn {
    position: relative;
    overflow: hidden;
  }
  .c-btn:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    top: 0;
    transform: translateX(-100%);
    background-color: #FFF;
    opacity: 0.3;
    transition: all 0.65s cubic-bezier(0.19, 1, 0.22, 1);
  }
  .c-btn:hover:after {
    transform: translateY(0);
  }
  .c-btn > span:first-child {
    display:-ms-flexbox;
    display:flex;
    -ms-flex-align: center;
    align-items: center;
    justify-content: center;
    -ms-flex-pack: center;
  }
  .c-btn--color-red {
    background-color: #e60012;
    color: white;
    font-weight: bold;
  }
  .c-btn--color-white {
    background-color: white;
    color:#e60012;
    font-weight: bold;
  }
  .c-btn--color-black {
    background-color: #000000;
    color: white;
    font-weight: bold;
  }
  .c-btn--color-glay {
    background-color: #8c8c8c;
    color: white;
    font-weight: bold;
  }
  .c-btn--icon-arrow-white::before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-arrow-white.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    position: absolute;
  }
  .c-btn--icon-circle-white span:first-child:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-white.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-btn--icon-black-glay span:first-child:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-glay.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-btn--icon-circle-black span:first-child:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-black.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-btn--icon-circle-red span:first-child:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-red.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-btn--icon-cart > span:first-child:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-cart.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
  }
  .c-inline-icon--red:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-red.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    height: 10px;
    width: 10px;
  }
  .c-inline-icon--white:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-white.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    height: 10px;
    width: 10px;
  }
  .c-inline-icon--movie:before {
    display: inline-block;
    content: '';
    background-image: url(../img/common/icon-movie.svg);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    height: 10px;
    width: 10px;
  }

  .c-btn--cart{
    padding: 15px 0 16px;
    position: relative;
    text-align: left;
  }
  .c-btn__label{
    font-size: 14px;
    display: inline-block;
    line-height: 1;
    margin-left: 32px;
  }
  .c-btn__label-sub{
    font-size: 11px;
    display: inline-block;
    line-height: 15px;
  }
  .c-btn__ico--cart{
    width: 30px;
    height: 30px;
    position: absolute;
    left: 8px;
    top: 50%;
    margin-top: -15px;
  }
  .c-btn__ico--cart img{
    width: 16px;
    height: 16px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  @media all and (min-width: 980px) and (max-width: 1440px) {
    .c-btn__label{
      font-size: 13px;
    }
    .c-btn__label-sub{
      font-size: 11px;
    }
  }

  .c-icon-rotate90:before {
    transform: rotate(-90deg);
  }
  .c-icon-rotate180:before {
    transform: rotate(-180deg);
  }
  a.c-text-link {
    display: inline-block;
    text-decoration: underline;
    font-weight: bold;
  }
  a.c-text-link:hover {
    text-decoration: none;
    color: #e60012;
  }
  @media all and (min-width: 760px), print {
  .c-btn {
    font-size: 18px;
    display:-ms-inline-flexbox;
    display:inline-flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .c-btn--color-red {
    background-color: #e60012;
    color: white;
    font-weight: bold;
  }
  .c-btn--icon-arrow-white {
    padding: 10px 25px 11px 36px;
  }
  .c-btn--icon-arrow-white::before {
    width: 7.2px;
    height: 11.3px;
    top: 50%;
    left: 15px;
    transform: translate(0,-50%);
  }
  .c-btn--icon-circle-white,
  .c-btn--icon-circle-red,
  .c-btn--icon-circle-black {
    padding: 15px 58px 16px;
  }
  .c-btn--icon-circle-white span::before,
  .c-btn--icon-circle-red span::before,
  .c-btn--icon-circle-black span::before {
    width: 15px;
    height: 15px;
    margin-right: 10px;
  }
  .c-btn--icon-cart span::before {
    width: 23px;
    height: 23px;
    margin-right: 10px;
    margin-right: 10px;
    position: relative;
  }
}
@media all and (max-width: 759px) {
  .c-btn {
    font-size: 18px;
    display:-ms-inline-flexbox;
    display:inline-flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .c-btn--color-red {
    background-color: #e60012;
    color: white;
    font-weight: bold;
    font-size: 14px;
  }
  .c-btn--icon-arrow-white {
    padding: 10px 25px 11px 36px;
  }
  .c-btn--icon-arrow-white::before {
    width: 7.2px;
    height: 11.3px;
    top: 50%;
    left: 15px;
    transform: translate(0,-50%);
  }
   .c-btn--icon-circle-white {
    padding: 15px 32px 16px;
  }
  .c-btn--icon-circle-black {
    padding: 15px 58px 16px;
  }
  .c-btn--icon-circle-white span::before,
  .c-btn--icon-circle-red span::before,
  .c-btn--icon-circle-black span::before {
    width: 15px;
    height: 15px;
    margin-right: 10px;
  }
  .c-btn--icon-cart span::before {
    width: 23px;
    height: 23px;
    margin-right: 10px;
    margin-right: 10px;
    position: relative;
  }
}
/* --------------------------------------------------------------------------
  PAGE HEADER
-------------------------------------------------------------------------- */
@media all and (min-width: 760px), print {
  .main-header  h2 img {
    width: 100%;
  }
}
@media all and (min-width: 980px) and (max-width: 1365px) {
}
@media all and (min-width: 760px) and (max-width: 979px) {
}
@media all and (max-width: 759px) {
}
