@charset "UTF-8";
/*! sanitize.css v7.0.3 | CC0 License | github.com/csstools/sanitize.css */
/* Document
 * ========================================================================== */
/**
 * 1. Remove repeating backgrounds in all browsers (opinionated).
 * 2. Add border box sizing in all browsers (opinionated).
 */
*,
:before,
:after {
  background-repeat: no-repeat;
  /* 1 */
  box-sizing: border-box;
  /* 2 */
}

/**
  * 1. Add text decoration inheritance in all browsers (opinionated).
  * 2. Add vertical alignment inheritance in all browsers (opinionated).
  */
:before,
:after {
  text-decoration: inherit;
  /* 1 */
  vertical-align: inherit;
  /* 2 */
}

/**
  * 1. Use the default cursor in all browsers (opinionated).
  * 2. Use the default user interface font in all browsers (opinionated).
  * 3. Correct the line height in all browsers.
  * 4. Use a 4-space tab width in all browsers (opinionated).
  * 5. Prevent adjustments of font size after orientation changes in
  *    IE on Windows Phone and in iOS.
  * 6. Breaks words to prevent overflow in all browsers (opinionated).
  */
html {
  cursor: default;
  /* 1 */
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Oxygen, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  /* 2 */
  line-height: 1.15;
  /* 3 */
  -moz-tab-size: 4;
  /* 4 */
  tab-size: 4;
  /* 4 */
  -ms-text-size-adjust: 100%;
  /* 5 */
  -webkit-text-size-adjust: 100%;
  /* 5 */
  word-break: break-word;
  /* 6 */
}

/* Sections
  * ========================================================================== */
/**
  * Remove the margin in all browsers (opinionated).
  */
body {
  margin: 0;
}

/**
  * Correct the font size and margin on `h1` elements within `section` and
  * `article` contexts in Chrome, Firefox, and Safari.
  */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
  * ========================================================================== */
/**
  * 1. Add the correct sizing in Firefox.
  * 2. Show the overflow in Edge and IE.
  */
hr {
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
  * Add the correct display in IE.
  */
main {
  display: block;
}

/**
  * Remove the list style on navigation lists in all browsers (opinionated).
  */
nav ol,
nav ul {
  list-style: none;
}

/**
  * 1. Use the default monospace user interface font
  *    in all browsers (opinionated).
  * 2. Correct the odd `em` font sizing in all browsers.
  */
pre {
  font-family: Menlo, Consolas, Roboto Mono, Ubuntu Monospace, Oxygen Mono, Liberation Mono, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
  * ========================================================================== */
/**
  * Remove the gray background on active links in IE 10.
  */
a {
  background-color: transparent;
}

/**
  * Add the correct text decoration in Edge, IE, Opera, and Safari.
  */
abbr[title] {
  text-decoration: underline;
  text-decoration: underline dotted;
}

/**
  * Add the correct font weight in Chrome, Edge, and Safari.
  */
b,
strong {
  font-weight: bolder;
}

/**
  * 1. Use the default monospace user interface font
  *    in all browsers (opinionated).
  * 2. Correct the odd `em` font sizing in all browsers.
  */
code,
kbd,
samp {
  font-family: Menlo, Consolas, Roboto Mono, Ubuntu Monospace, Oxygen Mono, Liberation Mono, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
  * Add the correct font size in all browsers.
  */
small {
  font-size: 80%;
}

/*
  * Remove the text shadow on text selections in Firefox 61- (opinionated).
  * 1. Restore the coloring undone by defining the text shadow
  *    in all browsers (opinionated).
  */

::selection {
  background-color: #b3d4fc;
  /* 1 */
  color: #000;
  /* 1 */
  text-shadow: none;
}

/* Embedded content
  * ========================================================================== */
/*
  * Change the alignment on media elements in all browers (opinionated).
  */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

/**
  * Add the correct display in IE 9-.
  */
audio,
video {
  display: inline-block;
}

/**
  * Add the correct display in iOS 4-7.
  */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
  * Remove the border on images inside links in IE 10-.
  */
img {
  border-style: none;
}

/**
  * Change the fill color to match the text color in all browsers (opinionated).
  */
svg {
  fill: currentColor;
}

/**
  * Hide the overflow in IE.
  */
svg:not(:root) {
  overflow: hidden;
}

/* Tabular data
  * ========================================================================== */
/**
  * Collapse border spacing in all browsers (opinionated).
  */
table {
  border-collapse: collapse;
}

/* Forms
  * ========================================================================== */
/**
  * Inherit styling in all browsers (opinionated).
  */
button,
input,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

/**
  * Remove the margin in Safari.
  */
button,
input,
select {
  margin: 0;
}

/**
  * 1. Show the overflow in IE.
  * 2. Remove the inheritance of text transform in Edge, Firefox, and IE.
  */
button {
  overflow: visible;
  /* 1 */
  text-transform: none;
  /* 2 */
}

/**
  * Correct the inability to style clickable types in iOS and Safari.
  */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
  * Correct the padding in Firefox.
  */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
  * Show the overflow in Edge and IE.
  */
input {
  overflow: visible;
}

/**
  * 1. Correct the text wrapping in Edge and IE.
  * 2. Correct the color inheritance from `fieldset` elements in IE.
  */
legend {
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  white-space: normal;
  /* 1 */
}

/**
  * 1. Add the correct display in Edge and IE.
  * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
  */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
  * Remove the inheritance of text transform in Firefox.
  */
select {
  text-transform: none;
}

/**
  * 1. Remove the margin in Firefox and Safari.
  * 2. Remove the default vertical scrollbar in IE.
  * 3. Change the resize direction on textareas in all browsers (opinionated).
  */
textarea {
  margin: 0;
  /* 1 */
  overflow: auto;
  /* 2 */
  resize: vertical;
  /* 3 */
}

/**
  * Remove the padding in IE 10-.
  */
[type="checkbox"],
[type="radio"] {
  padding: 0;
}

/**
  * 1. Correct the odd appearance in Chrome and Safari.
  * 2. Correct the outline style in Safari.
  */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
  * Correct the cursor style of increment and decrement buttons in Safari.
  */
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/**
  * Correct the text style of placeholders in Chrome, Edge, and Safari.
  */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=54)";
}

/**
  * Remove the inner padding in Chrome and Safari on macOS.
  */
::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
  * 1. Correct the inability to style clickable types in iOS and Safari.
  * 2. Change font properties to `inherit` in Safari.
  */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/**
  * Remove the inner border and padding of focus outlines in Firefox.
  */
::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
  * Restore the focus outline styles unset by the previous rule in Firefox.
  */
:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/* Interactive
  * ========================================================================== */
/*
  * Add the correct display in Edge and IE.
  */
details {
  display: block;
}

/*
  * Add the correct styles in Edge, IE, and Safari.
  */
dialog {
  background-color: white;
  border: solid;
  color: black;
  display: block;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content;
}

dialog:not([open]) {
  display: none;
}

/*
  * Add the correct display in all browsers.
  */
summary {
  display: list-item;
}

/* Scripting
  * ========================================================================== */
/**
  * Add the correct display in IE 9-.
  */
canvas {
  display: inline-block;
}

/**
  * Add the correct display in IE.
  */
template {
  display: none;
}

/* User interaction
  * ========================================================================== */
/*
  * 1. Remove the tapping delay on clickable elements
       in all browsers (opinionated).
  * 2. Remove the tapping delay in IE 10.
  */
a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation;
  /* 1 */
  touch-action: manipulation;
  /* 2 */
}

/**
  * Add the correct display in IE 10-.
  */
[hidden] {
  display: none;
}

/* Accessibility
  * ========================================================================== */
/**
  * Change the cursor on busy elements in all browsers (opinionated).
  */
[aria-busy="true"] {
  cursor: progress;
}

/*
  * Change the cursor on control elements in all browsers (opinionated).
  */
[aria-controls] {
  cursor: pointer;
}

/*
  * Change the cursor on disabled, not-editable, or otherwise
  * inoperable elements in all browsers (opinionated).
  */
[aria-disabled],
[disabled] {
  cursor: not-allowed;
}

/*
  * Change the display on visually hidden accessible elements
  * in all browsers (opinionated).
  */
[aria-hidden="false"][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  display: inherit;
  position: absolute;
}

h1, h2, h3, h4, h5, p, ul, li, ol, dl, dd, dt {
  font-size: 100%;
  font-weight: normal;
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

html {
  min-height: 100%;
  position: relative;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "Hiragino Kaku Gothic ProN","メイリオ","游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  line-height: 1.7;
  color: #000;
  -webkit-tap-highlight-color: transparent;
}

img[src$=".svg"] {
  width: 100%;
}

img {
  max-width: 100%;
}

a {
  text-decoration: none;
  color: inherit;
}

body.-in_modal, html.-in_modal {
  overflow: hidden;
  width: 100%;
  height: 100%;
}

/**
 * Lightcase - jQuery Plugin
 * The smart and flexible Lightbox Plugin.
 *
 * @author		Cornel Boppart <cornel@bopp-art.com>
 * @copyright	Author
 *
 * @version		2.5.0 (11/03/2018)
 */
/**
 * Lightcase settings
 *
 * Note: Override default settings for your project without touching this source code by simply
 * defining those variables within a SASS map called '$lightcase-custom'.
 *
 * // Example usage
 * $lightcase-custom: (
 *   'breakpoint': 768px
 * );
 */
@font-face {
  font-family: 'lightcase';
  src: url("../fonts/lightcase.eot?55356177");
  src: url("../fonts/lightcase.eot?55356177#iefix") format("embedded-opentype"), url("../fonts/lightcase.woff?55356177") format("woff"), url("../fonts/lightcase.ttf?55356177") format("truetype"), url("../fonts/lightcase.svg?55356177#lightcase") format("svg");
  font-weight: normal;
  font-style: normal;
}

/* line 12, ../scss/components/fonts/_font-lightcase.scss */
[class*='lightcase-icon-']:before {
  font-family: 'lightcase', sans-serif;
  font-style: normal;
  font-weight: normal;
  speak: none;
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  text-align: center;
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}

/* Codes */
/* line 35, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-play:before {
  content: '\e800';
}

/* line 36, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-pause:before {
  content: '\e801';
}

/* line 37, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-close:before {
  content: '';
  width: 32px;
  height: 32px;
  background: url(/assets/img/common/ico/ico_close.svg);
  background-size: 100%;
}

@media (min-width: 768px) {
  .lightcase-icon-close:before {
    width: 64px;
    height: 64px;
  }
}

/* line 38, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-prev:before {
  content: '\e803';
}

/* line 39, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-next:before {
  content: '\e804';
}

/* line 40, ../scss/components/fonts/_font-lightcase.scss */
.lightcase-icon-spin:before {
  content: '\e805';
}

/**
 * Mixin providing icon defaults to be used on top of font-lightcase.
 *
 * Example usage:
 * @include icon(#e9e9e9)
 */
/**
 * Mixin providing icon defaults including a hover status to be used
 * on top of font-lightcase.
 *
 * Example usage:
 * @include icon-hover(#e9e9e9, #fff)
 */
/**
 * Provides natural content overflow behavior and scrolling support
 * even so for touch devices.
 *
 * Example usage:
 * @include overflow()
 */
/**
 * Neutralizes/resets dimensions including width, height, position as well as margins,
 * paddings and styles. Used to enforce a neutral and unstyled look and behavoir!
 *
 * Example usage:
 * @include clear(true)
 *
 * @param boolean $important
 */
@-webkit-keyframes lightcase-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}

@keyframes lightcase-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}

/* line 1, ../scss/components/modules/_case.scss */
#lightcase-case {
  display: none;
  position: fixed;
  z-index: 2002;
  top: 50%;
  left: 50%;
  font-family: arial, sans-serif;
  font-size: 13px;
  line-height: 1.5;
  text-align: left;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

@media screen and (max-width: 640px) {
  /* line 16, ../scss/components/modules/_case.scss */
  html[data-lc-type=inline] #lightcase-case, html[data-lc-type=ajax] #lightcase-case {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    margin: 0 !important;
    padding: 55px 0 70px 0;
    width: 100% !important;
    height: 100% !important;
    overflow: auto !important;
  }
}

@media screen and (min-width: 641px) {
  /* line 4, ../scss/components/modules/_content.scss */
  html:not([data-lc-type=error]) #lightcase-content {
    position: relative;
    z-index: 1;
    text-shadow: none;
    background-color: #fff;
    -o-box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
    -webkit-backface-visibility: hidden;
  }
}

@media screen and (min-width: 641px) {
  /* line 23, ../scss/components/modules/_content.scss */
  html[data-lc-type=image] #lightcase-content, html[data-lc-type=video] #lightcase-content {
    background-color: #333;
  }
}

/* line 31, ../scss/components/modules/_content.scss */
html[data-lc-type=inline] #lightcase-content, html[data-lc-type=ajax] #lightcase-content, html[data-lc-type=error] #lightcase-content {
  -o-box-shadow: none;
  box-shadow: none;
}

@media screen and (max-width: 640px) {
  /* line 31, ../scss/components/modules/_content.scss */
  html[data-lc-type=inline] #lightcase-content, html[data-lc-type=ajax] #lightcase-content, html[data-lc-type=error] #lightcase-content {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
  }
}

/* line 43, ../scss/components/modules/_content.scss */
html[data-lc-type=inline] #lightcase-content .lightcase-contentInner, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner {
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 640px) {
  /* line 43, ../scss/components/modules/_content.scss */
  html[data-lc-type=inline] #lightcase-content .lightcase-contentInner, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner {
    padding: 15px;
  }
  /* line 52, ../scss/components/modules/_content.scss */
  html[data-lc-type=inline] #lightcase-content .lightcase-contentInner, html[data-lc-type=inline] #lightcase-content .lightcase-contentInner > *, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner > *, html[data-lc-type=error] #lightcase-content .lightcase-contentInner, html[data-lc-type=error] #lightcase-content .lightcase-contentInner > * {
    width: 100% !important;
    max-width: none !important;
  }
  /* line 59, ../scss/components/modules/_content.scss */
  html[data-lc-type=inline] #lightcase-content .lightcase-contentInner > *:not(iframe), html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner > *:not(iframe), html[data-lc-type=error] #lightcase-content .lightcase-contentInner > *:not(iframe) {
    height: auto !important;
    max-height: none !important;
  }
}

@media screen and (max-width: 640px) {
  /* line 70, ../scss/components/modules/_content.scss */
  html.lightcase-isMobileDevice[data-lc-type=iframe] #lightcase-content .lightcase-contentInner iframe {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
}

@media screen and (max-width: 640px) and (min-width: 641px) {
  /* line 74, ../scss/components/modules/_content.scss */
  html[data-lc-type=image] #lightcase-content .lightcase-contentInner, html[data-lc-type=video] #lightcase-content .lightcase-contentInner {
    line-height: 0.75;
  }
}

/* line 82, ../scss/components/modules/_content.scss */
html[data-lc-type=image] #lightcase-content .lightcase-contentInner {
  position: relative;
  overflow: hidden !important;
}

@media screen and (max-width: 640px) {
  /* line 91, ../scss/components/modules/_content.scss */
  html[data-lc-type=inline] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap, html[data-lc-type=ajax] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap, html[data-lc-type=error] #lightcase-content .lightcase-contentInner .lightcase-inlineWrap {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
  }
}

@media screen and (min-width: 641px) {
  /* line 100, ../scss/components/modules/_content.scss */
  html:not([data-lc-type=error]) #lightcase-content .lightcase-contentInner .lightcase-inlineWrap {
    padding: 30px;
    overflow: auto;
    -o-box-sizing: border-box;
    box-sizing: border-box;
  }
}

@media screen and (max-width: 640px) {
  /* line 117, ../scss/components/modules/_content.scss */
  #lightcase-content h1, #lightcase-content h2, #lightcase-content h3, #lightcase-content h4, #lightcase-content h5, #lightcase-content h6, #lightcase-content p {
    color: #aaa;
  }
}

@media screen and (min-width: 641px) {
  /* line 117, ../scss/components/modules/_content.scss */
  #lightcase-content h1, #lightcase-content h2, #lightcase-content h3, #lightcase-content h4, #lightcase-content h5, #lightcase-content h6, #lightcase-content p {
    color: #333;
  }
}

/* line 3, ../scss/components/modules/_error.scss */
#lightcase-case p.lightcase-error {
  margin: 0;
  font-size: 17px;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #aaa;
}

@media screen and (max-width: 640px) {
  /* line 3, ../scss/components/modules/_error.scss */
  #lightcase-case p.lightcase-error {
    padding: 30px 0;
  }
}

@media screen and (min-width: 641px) {
  /* line 3, ../scss/components/modules/_error.scss */
  #lightcase-case p.lightcase-error {
    padding: 0;
  }
}

/* line 4, ../scss/components/modules/_global.scss */
.lightcase-open body {
  overflow: hidden;
}

/* line 8, ../scss/components/modules/_global.scss */
.lightcase-isMobileDevice .lightcase-open body {
  max-width: 100%;
  max-height: 100%;
}

/* line 1, ../scss/components/modules/_info.scss */
#lightcase-info {
  position: absolute;
  padding-top: 15px;
}

/* line 9, ../scss/components/modules/_info.scss */
#lightcase-info #lightcase-title,
#lightcase-info #lightcase-caption {
  margin: 0;
  padding: 0;
  line-height: 1.5;
  font-weight: normal;
  text-overflow: ellipsis;
}

/* line 19, ../scss/components/modules/_info.scss */
#lightcase-info #lightcase-title {
  font-size: 17px;
  color: #aaa;
}

@media screen and (max-width: 640px) {
  /* line 19, ../scss/components/modules/_info.scss */
  #lightcase-info #lightcase-title {
    position: fixed;
    top: 10px;
    left: 0;
    max-width: 87.5%;
    padding: 5px 15px;
    background: #333;
  }
}

/* line 33, ../scss/components/modules/_info.scss */
#lightcase-info #lightcase-caption {
  clear: both;
  font-size: 13px;
  color: #aaa;
}

/* line 39, ../scss/components/modules/_info.scss */
#lightcase-info #lightcase-sequenceInfo {
  font-size: 11px;
  color: #aaa;
}

@media screen and (max-width: 640px) {
  /* line 45, ../scss/components/modules/_info.scss */
  .lightcase-fullScreenMode #lightcase-info {
    padding-left: 15px;
    padding-right: 15px;
  }
  /* line 51, ../scss/components/modules/_info.scss */
  html:not([data-lc-type=image]):not([data-lc-type=video]):not([data-lc-type=flash]):not([data-lc-type=error]) #lightcase-info {
    position: static;
  }
}

/* line 1, ../scss/components/modules/_loading.scss */
#lightcase-loading {
  position: fixed;
  z-index: 9999;
  width: 1.123em;
  height: auto;
  font-size: 38px;
  line-height: 1;
  text-align: center;
  text-shadow: none;
  position: fixed;
  z-index: 2001;
  top: 50%;
  left: 50%;
  margin-top: -0.5em;
  margin-left: -0.5em;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  font-size: 32px;
  text-shadow: 0 0 15px #fff;
  -moz-transform-origin: 50% 53%;
  -webkit-animation: lightcase-spin 0.5s infinite linear;
  animation: lightcase-spin 0.5s infinite linear;
}

/* line 20, ../scss/components/mixins/_presets.scss */
#lightcase-loading, #lightcase-loading:focus {
  text-decoration: none;
  color: #fff;
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: color, opacity, ease-in-out 0.25s;
  transition: color, opacity, ease-in-out 0.25s;
}

/* line 32, ../scss/components/mixins/_presets.scss */
#lightcase-loading > span {
  display: inline-block;
  text-indent: -9999px;
}

/* line 2, ../scss/components/modules/_navigation.scss */
a[class*='lightcase-icon-'] {
  position: fixed;
  z-index: 9999;
  width: 1.123em;
  height: auto;
  font-size: 38px;
  line-height: 1;
  text-align: center;
  text-shadow: none;
  outline: none;
  cursor: pointer;
}

/* line 20, ../scss/components/mixins/_presets.scss */
a[class*='lightcase-icon-'], a[class*='lightcase-icon-']:focus {
  text-decoration: none;
  color: rgba(255, 255, 255, 0.6);
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: color, opacity, ease-in-out 0.25s;
  transition: color, opacity, ease-in-out 0.25s;
}

/* line 32, ../scss/components/mixins/_presets.scss */
a[class*='lightcase-icon-'] > span {
  display: inline-block;
  text-indent: -9999px;
}

/* line 49, ../scss/components/mixins/_presets.scss */
a[class*='lightcase-icon-']:hover {
  color: white;
  text-shadow: 0 0 15px white;
}

/* line 10, ../scss/components/modules/_navigation.scss */
.lightcase-isMobileDevice a[class*='lightcase-icon-']:hover {
  color: #aaa;
  text-shadow: none;
}

/* line 17, ../scss/components/modules/_navigation.scss */
a[class*='lightcase-icon-'].lightcase-icon-close {
  position: fixed;
  top: 15px;
  right: 15px;
  bottom: auto;
  margin: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  outline: none;
  width: 32px;
  height: 32px;
}

@media (min-width: 768px) {
  a[class*='lightcase-icon-'].lightcase-icon-close {
    width: 64px;
    height: 64px;
  }
}

/* line 28, ../scss/components/modules/_navigation.scss */
a[class*='lightcase-icon-'].lightcase-icon-prev {
  left: 15px;
}

/* line 33, ../scss/components/modules/_navigation.scss */
a[class*='lightcase-icon-'].lightcase-icon-next {
  right: 15px;
}

/* line 38, ../scss/components/modules/_navigation.scss */
a[class*='lightcase-icon-'].lightcase-icon-pause, a[class*='lightcase-icon-'].lightcase-icon-play {
  left: 50%;
  margin-left: -0.5em;
}

@media screen and (min-width: 641px) {
  /* line 38, ../scss/components/modules/_navigation.scss */
  a[class*='lightcase-icon-'].lightcase-icon-pause, a[class*='lightcase-icon-'].lightcase-icon-play {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  }
}

@media screen and (max-width: 640px) {
  /* line 2, ../scss/components/modules/_navigation.scss */
  a[class*='lightcase-icon-'] {
    bottom: 15px;
    font-size: 24px;
  }
}

@media screen and (min-width: 641px) {
  /* line 2, ../scss/components/modules/_navigation.scss */
  a[class*='lightcase-icon-'] {
    bottom: 50%;
    margin-bottom: -0.5em;
  }
  /* line 57, ../scss/components/modules/_navigation.scss */
  a[class*='lightcase-icon-']:hover, #lightcase-case:hover ~ a[class*='lightcase-icon-'] {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
}

/* line 1, ../scss/components/modules/_overlay.scss */
#lightcase-overlay {
  display: none;
  width: 100%;
  min-height: 100%;
  position: fixed;
  z-index: 2000;
  top: -9999px;
  bottom: -9999px;
  left: 0;
  background: #fff;
}

@media screen and (max-width: 640px) {
  /* line 1, ../scss/components/modules/_overlay.scss */
  #lightcase-overlay {
    opacity: 1 !important;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
}

body {
  background: url(../img/common/bg/bg.png);
  background-size: 100% auto;
}

@media (min-width: 768px) {
  body {
    background-size: auto;
    height: 100%;
  }
}

@media (min-width: 768px) {
  .l-bg__wrap {
    position: relative;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
  }
  .l-bg__wrap:before {
    background: url(../img/common/bg/bg_left.png) left top repeat-y;
    content: "";
    display: block;
    height: calc(100% - 1020px);
    width: 500px;
    pointer-events: none;
    z-index: 1;
    position: absolute;
    top: 1020px;
    left: 0;
  }
  .l-bg__wrap:after {
    background: url(../img/common/bg/bg_right.png) right top repeat-y;
    content: "";
    display: block;
    height: calc(100% - 1020px);
    width: 500px;
    pointer-events: none;
    z-index: 1;
    position: absolute;
    top: 1020px;
    right: 0;
  }
}

.l-footer__sharelist {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 1;
  padding-top: 27px;
}

@media (min-width: 768px) {
  .l-footer__sharelist {
    padding-top: 40px;
  }
}

.l-footer__sharelist__item {
  margin: 0 10px 0 0;
}

@media (min-width: 768px) {
  .l-footer__sharelist__item {
    margin: 0 16px 0 0;
  }
}

.l-footer__sharelist__item img {
  width: 26px;
  height: 25px;
}

@media (min-width: 768px) {
  .l-footer__sharelist__item img {
    width: 36px;
    height: 33px;
  }
}

.l-footer {
  position: relative;
  padding: 0 0 30px;
}

@media (min-width: 768px) {
  .l-footer {
    border-radius: none;
    padding: 0 0 40px;
  }
}

.l-footer__inner {
  padding: 58px 0 0;
  width: 225px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .l-footer__inner {
    width: 360px;
    padding: 108px 0 0;
  }
}

.l-footer__copyright {
  color: #efd275;
  margin-top: 12px;
  text-align: center;
  font-size: 10px;
  font-size: 0.625rem;
}

@media (min-width: 768px) {
  .l-footer__copyright {
    margin-top: 12px;
    position: relative;
  }
}

@media (min-width: 768px) {
  .l-gnav__sharelist {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    z-index: 1;
    position: absolute;
    top: 0;
    right: -162px;
    padding-top: 13px;
  }
  .l-gnav__sharelist__item {
    margin: 0 16px 0 0;
  }
  .l-gnav__sharelist__item img {
    width: 30px;
    height: 28px;
  }
}

.l-gnav {
  position: fixed;
  top: 0;
  left: auto;
  z-index: 3;
  width: 100%;
  height: 50px;
}

@media (min-width: 768px) {
  .l-gnav {
    max-width: 100%;
    width: 960px;
    height: 56px;
    left: 50%;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    box-shadow: 0px 0px 6px 3px rgba(0, 0, 0, 0.4);
  }
}

.l-gnav__menu {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  background: #e8360d;
}

.l-gnav__menu:after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 100%;
  height: 5px;
  background: rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
  .l-gnav__menu:after {
    height: 5px;
  }
}

.l-gnav__menu__item {
  cursor: pointer;
  background: #e8360d;
  width: 33.33333%;
  height: 50px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top center;
}

.l-gnav__menu__item.-about {
  background-image: url(../img/common/gnav/nav_about_wh_nrw.png);
}

.l-gnav__menu__item.-live {
  background-image: url(../img/common/gnav/nav_live_wh_nrw.png);
}

.l-gnav__menu__item.-goods {
  background-image: url(../img/common/gnav/nav_goods_wh_nrw.png);
}

@media (min-width: 768px) {
  .l-gnav__menu__item {
    height: 56px;
    background-size: 320px 56px;
  }
  .l-gnav__menu__item.-about {
    background-image: url(../img/common/gnav/nav_about_wh.png);
  }
  .l-gnav__menu__item.-live {
    background-image: url(../img/common/gnav/nav_live_wh.png);
  }
  .l-gnav__menu__item.-goods {
    background-image: url(../img/common/gnav/nav_goods_wh.png);
  }
}

.l-gnav__menu__item a {
  display: block;
  height: 100%;
}

.l-gnav__menu__item.-current {
  background-color: #dbb569;
}

.l-gnav__menu__item.-current.-about {
  background-image: url(../img/common/gnav/nav_about_bl_nrw.png);
}

.l-gnav__menu__item.-current.-live {
  background-image: url(../img/common/gnav/nav_live_bl_nrw.png);
}

.l-gnav__menu__item.-current.-goods {
  background-image: url(../img/common/gnav/nav_goods_bl_nrw.png);
}

@media (min-width: 768px) {
  .l-gnav__menu__item.-current {
    height: 56px;
    background-size: 320px 56px;
  }
  .l-gnav__menu__item.-current.-about {
    background-image: url(../img/common/gnav/nav_about_bl.png);
  }
  .l-gnav__menu__item.-current.-live {
    background-image: url(../img/common/gnav/nav_live_bl.png);
  }
  .l-gnav__menu__item.-current.-goods {
    background-image: url(../img/common/gnav/nav_goods_bl.png);
  }
}

.l-gnav__menu__item.-cs {
  position: relative;
  pointer-events: none;
}

.l-gnav__menu__item.-cs:before {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}

@-webkit-keyframes eto_loop {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -840px 0;
  }
}

@keyframes eto_loop {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -840px 0;
  }
}

@-webkit-keyframes bg_loop {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-transform: rotate(0deg) translate(-50%, -50%);
            transform: rotate(0deg) translate(-50%, -50%);
  }
  1% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    -webkit-transform: rotate(360deg) translate(-50%, -50%);
            transform: rotate(360deg) translate(-50%, -50%);
  }
}

@keyframes bg_loop {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-transform: rotate(0deg) translate(-50%, -50%);
            transform: rotate(0deg) translate(-50%, -50%);
  }
  1% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    -webkit-transform: rotate(360deg) translate(-50%, -50%);
            transform: rotate(360deg) translate(-50%, -50%);
  }
}

@-webkit-keyframes navFadeIn {
  from {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    visibility: hidden;
  }
  to {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    visibility: visible;
  }
}

@keyframes navFadeIn {
  from {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    visibility: hidden;
  }
  to {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    visibility: visible;
  }
}

@-webkit-keyframes pageIn {
  from {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-transform: translate(0, 20px);
            transform: translate(0, 20px);
  }
  to {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@keyframes pageIn {
  from {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-transform: translate(0, 20px);
            transform: translate(0, 20px);
  }
  to {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

.c-backbtn {
  font-size: 14px;
  font-size: 0.875rem;
  position: relative;
  display: block;
  text-align: center;
  color: #ccc;
  border: 2px solid #ddd;
  padding: 10px;
  width: 200px;
  line-height: 1;
  font-weight: bold;
  z-index: 0;
  margin: 24px auto 0;
}

@media (min-width: 768px) {
  .c-backbtn {
    font-size: 0.9375rem;
    width: 160px;
    margin: 32px auto 0;
  }
}

.c-backbtn:before {
  content: '＜';
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

.c-backbtn:after {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  content: '';
  width: 100%;
  height: 100%;
  -webkit-transform: scaleX(0);
      -ms-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  background: #ddd;
  z-index: -1;
}

.c-backbtn:hover {
  color: #fff;
}

.c-backbtn:hover:after {
  -webkit-transform: scaleX(1);
      -ms-transform: scaleX(1);
          transform: scaleX(1);
}

.c-bg_brown {
  background: url(../img/common/bg/bg_brown.png) center top;
  background-size: 100% auto;
  position: relative;
}

@media (min-width: 768px) {
  .c-bg_brown {
    background-size: auto;
    margin-top: -30px;
    margin-bottom: 250px;
  }
}

.c-bg_brown:before {
  display: block;
  content: "";
  background: url(../img/common/bg/bg_brown_top_nrw.png);
  background-size: 100%;
  height: 16.933vw;
  width: 100%;
  position: absolute;
  top: -16.933vw;
  left: 0;
  z-index: 1;
}

@media (min-width: 768px) {
  .c-bg_brown:before {
    background: url(../img/common/bg/bg_brown_top.png) center top;
    height: 210px;
    width: 100%;
    position: absolute;
    top: -210px;
    left: 0;
  }
}

@media (min-width: 768px) {
  .c-bg_brown:after {
    background: url(../img/common/bg/bg_brown_bottom.png) center bottom;
    display: block;
    content: "";
    height: 250px;
    width: 100%;
    position: absolute;
    left: 0;
    bottom: -250px;
  }
}

@media (min-width: 768px) {
  .c-wrapper {
    max-width: calc(1560px + 5vw);
    margin: 0 auto;
    padding: 0 2.5vw;
  }
}

.c-main {
  overflow: hidden;
  position: relative;
  padding-bottom: 26px;
}

@media (min-width: 768px) {
  .c-main {
    position: static;
    padding-bottom: 62px;
  }
}

.c-inner {
  margin: 0 auto;
  max-width: 540px;
  padding: 0 20px;
}

@media (min-width: 768px) {
  .c-inner {
    max-width: 880px;
    padding: 0 20px;
    position: relative;
    z-index: 2;
  }
}

.c-br_wide {
  display: none;
}

@media (min-width: 768px) {
  .c-br_wide {
    display: block;
  }
}

.c-br_nrw {
  display: block;
}

@media (min-width: 768px) {
  .c-br_nrw {
    display: none;
  }
}

.c-ev_none {
  pointer-events: none;
}

.c-external {
  position: relative;
}

.c-external:after {
  position: absolute;
  top: 0;
  right: 0;
  content: '';
  right: -14px;
  width: 11px;
  height: 9px;
  background: url(../img/common/ui/ico_external.svg) top center/contain no-repeat;
}

@media (min-width: 768px) {
  .c-hover_op {
    -webkit-transition: 0.3s ease opacity;
    transition: 0.3s ease opacity;
    cursor: pointer;
  }
  .c-hover_op:hover {
    opacity: 0.7;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
  }
}

.c-pagein {
  position: relative;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-animation: pageIn 0.6s 0.4s ease forwards;
          animation: pageIn 0.6s 0.4s ease forwards;
}

@media (min-width: 768px) {
  .c-ticket {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.c-ticket__item {
  background: #f7f3e9;
  border-radius: 5px;
  margin-top: 10px;
  padding: 15px;
}

@media (min-width: 768px) {
  .c-ticket__item {
    margin-top: 20px;
    padding: 25px;
    width: calc( 50% - 8px);
    font-size: 1.125rem;
  }
}

.c-ticket__ttl {
  color: #e8360d;
  font-weight: bold;
  font-size: 13px;
  font-size: 0.8125rem;
}

@media (min-width: 768px) {
  .c-ticket__ttl {
    font-size: 1.0625rem;
  }
}

.c-ticket__txt {
  border-bottom: 1px dotted #000000;
  padding-bottom: 4px;
}

@media (min-width: 768px) {
  .c-ticket__txt {
    border-bottom: 2px dotted #000000;
    padding-bottom: 8px;
    font-size: 1.0625rem;
  }
}

.c-ticket dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  padding: 5px 0;
}

@media (min-width: 768px) {
  .c-ticket dl {
    padding: 10px 0;
  }
}

.c-ticket dl dt {
  font-weight: bold;
  width: 60px;
  font-size: 12px;
  font-size: 0.75rem;
}

@media (min-width: 768px) {
  .c-ticket dl dt {
    width: 90px;
    font-size: 1rem;
  }
}

.c-ticket dl dd {
  font-weight: bold;
  width: calc(100% - 60px);
  font-size: 12px;
  font-size: 0.75rem;
}

@media (min-width: 768px) {
  .c-ticket dl dd {
    width: calc(100% - 90px);
    font-size: 1rem;
  }
}

.c-ticket__btn.-finished {
  opacity: 0.2;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)";
}

.c-ticket__btn span, .c-ticket__btn a {
  background: #e8360d;
  border-radius: 5px;
  color: #ffffff;
  display: block;
  text-align: center;
  padding: 10px;
  position: relative;
}

.c-ticket__btn a:after {
  position: absolute;
  top: 50%;
  right: 4px;
  content: '';
  background: url(../img/common/ui/ico_arw_wh_r.svg) top center/contain no-repeat;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 4px;
  height: 7px;
}

@media (min-width: 768px) {
  .c-ticket__btn a:after {
    right: 11px;
    width: 7px;
    height: 13px;
  }
}

.c-ttlbox {
  margin-bottom: 19px;
}

@media (min-width: 768px) {
  .c-ttlbox {
    margin-bottom: 42px;
  }
}

.c-ttl {
  height: 22px;
}

.c-ttl img {
  height: 100%;
}

@media (min-width: 768px) {
  .c-ttl {
    height: 37px;
  }
}

.c-subttl {
  height: 8px;
  margin-top: 8px;
}

@media (min-width: 768px) {
  .c-subttl {
    margin-top: 10px;
    height: 13px;
  }
}

.c-subttl img {
  height: 100%;
  vertical-align: top;
}

.c-offer {
  font-size: 10px;
  font-size: 0.625rem;
  line-height: 14px;
  margin-top: 4px;
}

@media (min-width: 768px) {
  .c-offer {
    font-size: 0.8125rem;
    line-height: 21px;
  }
}

.c-red {
  color: #e8360d;
}

.c-bold {
  font-weight: bold;
}

.c-unit {
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  font-weight: bold;
  padding: 12px 0;
}

@media (min-width: 768px) {
  .c-unit {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 20px 0;
  }
}

.c-unit.-bottom {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}

.c-unit.-black {
  border-top: 1px solid rgba(0, 0, 0, 0.2);
}

.c-unit.-black.-bottom {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.c-unit_head {
  background: #dbb569;
  border-radius: 40px;
  display: inline-block;
  padding: 0 10px;
  min-width: 60px;
  font-size: 11px;
  font-size: 0.6875rem;
  line-height: 18px;
  font-weight: bold;
  text-align: center;
}

@media (min-width: 768px) {
  .c-unit_head {
    width: 130px;
    height: 26px;
    font-size: 0.875rem;
    line-height: 26px;
  }
}

.c-unit_head.-black {
  background: #f7f3e9;
}

.c-unit_cont {
  color: #323232;
}

@media (min-width: 768px) {
  .c-unit_cont {
    width: calc(100% - 112px);
    padding-left: 18px;
  }
}

.c-unit_cont p {
  font-weight: bold;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 20px;
}

@media (min-width: 768px) {
  .c-unit_cont p {
    font-size: 0.9375rem;
    line-height: 26px;
  }
}

.c-unit_cont p.-large {
  font-size: 13px;
  font-size: 0.8125rem;
  line-height: 21px;
}

@media (min-width: 768px) {
  .c-unit_cont p.-large {
    margin-top: -6px;
    font-size: 1.25rem;
    line-height: 38px;
  }
}

.c-unit_cont .end {
  color: #e8360d;
}

.c-visible_nrw {
  visibility: visible;
}

@media (min-width: 768px) {
  .c-visible_nrw {
    visibility: hidden;
  }
}

.c-visible_wide {
  visibility: visible;
}

@media (max-width: 767px) {
  .c-visible_wide {
    visibility: hidden !important;
  }
}
