@charset "UTF-8";
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background: transparent;
  text-decoration: underline;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -.5em;
}

sub {
  bottom: -.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
  vertical-align: bottom;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Remove margin
 */
figure {
  margin: 0;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/* Blockquote
   ========================================================================== */
blockquote {
  margin: 0;
}

*, *:before, *:after {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  width: 100%;
  overflow-x: hidden;
}

html, h1, h2, h3, h4, h5, h6, ul, ol, li, dl, dd {
  margin: 0;
  padding: 0;
}

body {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0;
  padding: 0;
  background: #fff;
  color: #000;
  word-wrap: break-word;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.7857142857;
  overflow-x: hidden;
  position: relative;
  width: 100%;
  overflow-x: hidden;
}
body.is-open {
  overflow: hidden;
}

ul {
  list-style-type: none;
}

a {
  text-decoration: none;
  color: #fff;
}

p, ul, ol, dl {
  margin: 0 0 10px;
  padding: 0;
}

ul > :last-child, ol > :last-child, dl > :last-child {
  margin-bottom: 0;
}

em {
  font-weight: bold;
  font-style: normal;
}

dt {
  margin-bottom: 8px;
}

i {
  font-style: normal;
}

/* ----------------------------------------------------------------
    Header
----------------------------------------------------------------- */
#header {
  background: #bf0014;
  width: 100%;
  min-height: 58px;
  padding: 15px 8px 6px;
  box-shadow: 0 8px 16px rgba(12, 4, 8, 0.35);
}

.header-body:before, .header-body:after {
  content: "";
  display: table;
}
.header-body:after {
  clear: both;
}

.header-logo {
  float: left;
}
.header-logo img {
  display: block;
}

.header-btn {
  font-size: 12px;
  font-size: 1.2rem;
  float: right;
  position: relative;
  right: -5px;
  width: 50px;
  margin: 0;
  line-height: 1;
  text-align: center;
}
.header-btn img {
  display: block;
  margin: 0 auto 5px;
}
.header-btn a {
  display: block;
  color: #000;
  font-weight: bold;
  text-decoration: none;
}

.heade-menu {
  font-size: 16px;
  font-size: 1.6rem;
  margin: 16px 0 0;
}
.heade-menu:before, .heade-menu:after {
  content: "";
  display: table;
}
.heade-menu:after {
  clear: both;
}
.heade-menu li {
  float: left;
  margin-left: 1.3157894737%;
  width: 49.3421052632%;
  font-weight: bold;
  text-align: center;
}
.heade-menu li:first-child {
  margin-left: 0;
}
.heade-menu a {
  display: block;
  width: 100%;
  padding: 13px 15px 13px 0px;
  background-color: #2c2c2c;
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.01) 0%, rgba(108, 108, 108, 0.01) 100%);
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.01) 0%, rgba(108, 108, 108, 0.01) 100%);
  box-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  text-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  position: relative;
}
.heade-menu a:after {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.heade-menu img {
  position: relative;
  top: -.4em;
  margin-right: 8px;
}

/* ----------------------------------------------------------------
    Global Navigation
----------------------------------------------------------------- */
nav {
  position: relative;
  overflow: hidden;
}

.nav-overlay {
  display: none;
  background: #000;
  opacity: 0;
}
.is-open .nav-overlay {
  position: fixed;
  z-index: 50;
  z-index: 150;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: block;
}

#global-nav {
  width: 100%;
  height: 100%;
  display: none;
}
#global-nav:before, #global-nav:after {
  content: "";
  display: table;
}
#global-nav:after {
  clear: both;
}
.is-open #global-nav {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 200;
  display: block;
  overflow: hidden;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.global-nav-contents {
  width: 280px;
  padding-bottom: 15px;
  background: #0c0c0c;
  float: right;
  position: relative;
  display: none;
}
.is-open .global-nav-contents {
  display: block;
}

.global-nav-btn {
  display: none;
}
.is-open .global-nav-btn {
  font-size: 10px;
  font-size: 1rem;
  line-height: 1.1;
  display: block;
  position: fixed;
  top: 0;
  left: 2px;
  z-index: 500;
  text-align: center;
  font-weight: bold;
}
.is-open .global-nav-btn a {
  display: inline-block;
}
.is-open .global-nav-btn a:before {
  font-size: 40px;
  font-size: 4rem;
  content: "×";
  color: #bf0014;
  display: block;
}

.global-nav-menu {
  font-size: 16px;
  font-size: 1.6rem;
  margin-bottom: 0;
  padding: 10px 10px 0;
  text-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
}
.global-nav-menu li {
  margin-bottom: 10px;
  font-weight: bold;
}
.global-nav-menu a {
  display: block;
  position: relative;
  padding: 13px 20px 13px 10px;
  background-color: #2c2c2c;
  border: 1px solid #383838;
  box-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
}
.global-nav-menu a:after {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.global-nav-menu img {
  position: relative;
  top: -.4em;
  margin-right: 8px;
}

.global-nav-menu-02 {
  margin-bottom: 14px;
}
.global-nav-menu-02 > li {
  font-weight: bold;
  border-bottom: 1px solid #383838;
}
.global-nav-menu-02 > li:first-child {
  border-top: 1px solid #383838;
}
.global-nav-menu-02 > li.shibuya,
.global-nav-menu-02 > li.roppongi {
  border-bottom: none;
}
.global-nav-menu-02 > li > a {
  display: block;
  position: relative;
  padding: 18px 20px 14px 17px;
}
.global-nav-menu-02 > li.shibuya > a,
.global-nav-menu-02 > li.fukuoka > a {
  padding: 18px 20px 14px 30px;
}
.global-nav-menu-02 > li.roppongi > a {
  padding: 0 20px 0 30px;
}
.global-nav-menu-02 a:after {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.global-nav-menu-02 > li.shibuya > a:before,
.global-nav-menu-02 > li.fukuoka > a:before {
  content: "";
  display: block;
  position: absolute;
  top: 38%;
  left: 18px;
  margin-top: -1px;
  width: 3px;
  height: 20px;
  background: #bf0014;
}
.global-nav-menu-02 > li.roppongi > a:before {
  content: "";
  display: block;
  position: absolute;
  top: 20%;
  left: 18px;
  margin-top: -1px;
  width: 3px;
  height: 20px;
  background: #bf0014;
}
.global-nav-menu-02 img {
  position: relative;
  top: -.4em;
  margin-right: 8px;
}

.global-nav-menu-sub {
  margin-bottom: 0;
  border-top: 1px solid #383838;
}
.global-nav-menu-sub > li > a {
  display: block;
  position: relative;
  font-size: 12px;
  line-height: 1;
}
.global-nav-menu-sub > li:first-child > a {
  padding: 18px 20px 7px 38px;
}
.global-nav-menu-sub > li:last-child > a {
  padding: 8px 20px 14px 38px;
}
.global-nav-menu-sub > li:first-child > a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 22px;
  margin-top: -1px;
  width: 3px;
  height: 12px;
  background: #bf0014;
}
.global-nav-menu-sub > li:last-child > a:before {
  content: "";
  display: block;
  position: absolute;
  top: 30%;
  left: 22px;
  margin-top: -1px;
  width: 3px;
  height: 12px;
  background: #bf0014;
}

.global-nav-menu-03 {
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 0;
  letter-spacing: -.35em;
  text-align: center;
}
.global-nav-menu-03 li {
  display: inline-block;
  letter-spacing: 0;
  padding: 0 10px;
  border-right: 1px solid #fff;
  line-height: 1.2;
}
.global-nav-menu-03 li:first-child {
  padding-left: 0;
}
.global-nav-menu-03 li:last-child {
  padding-right: 0;
  border: none;
}

/* ----------------------------------------------------------------
    breadcrumb
----------------------------------------------------------------- */
#breadcrumb {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 10px;
  color: #fff;
}
#breadcrumb ul {
  margin-bottom: 0;
}
#breadcrumb ul:before, #breadcrumb ul:after {
  content: "";
  display: table;
}
#breadcrumb ul:after {
  clear: both;
}
#breadcrumb li {
  float: left;
}
#breadcrumb li:before {
  content: ">";
  display: inline-block;
  padding: 0 10px;
}
#breadcrumb li:first-child:before {
  display: none;
}
#breadcrumb a {
  text-decoration: underline;
}

/* ----------------------------------------------------------------
    Contents
----------------------------------------------------------------- */
#contents {
  width: 100%;
  padding: 8px 8px 40px;
  background-color: #363636;
}

.primary {
  margin-bottom: 10px;
  background: #000;
  color: #fff;
}

.primary-02 {
  margin-bottom: 6px;
}

.primary > :last-child > :last-child, .primary-02 > :last-child > :last-child {
  margin-bottom: 0;
}
.primary > :last-child > :last-child > :last-child, .primary-02 > :last-child > :last-child > :last-child {
  margin-bottom: 0;
}

.primary-contents {
  padding: 0 1px 10px;
  margin-top: 20px;
}
.primary-contents02 {
  padding: 18px 16px 18px;
}
.primary-contents a {
	text-decoration: underline;
}
.primary-contents .premium_shop_link1_sp a{
	text-decoration: none;
}

.primary-contents .premium_shop_link2_sp a{
	text-decoration: none;
}


.primary-contents.theme {
  background: #fff;
  color: #2f1d00;
  padding: 18px 16px 18px;
}

.primary-contents.theme a {
  color: #0070bf;
}

.primary-contents.theme .btn {
  color: #fff;
}

.primary-contents.theme  > :first-child {
  margin-top: 0;
}

.primary-contents.ver2 {
  border-bottom: 1px solid #363636;
}

.primary-contents-inner {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px dotted #363636;
}

.primary-contents-inner > section:last-child > :last-child {
  margin-bottom: 0;
}

.primary-contents-inner  > :last-child {
  margin-bottom: 0;
}

.primary-contents-02 {
  padding: 15px 16px;
  background: #fff;
}

.primary-contents-03 {
  padding: 15px 16px;
  background: #565656;
}

.primary-contents-04 {
  margin-bottom: 6px;
  padding: 15px 16px;
  background: #bf0014;
  color: #fff;
}
.primary-contents-04 p {
  margin-bottom: 0;
}

.primary-contents > :last-child, .primary-contents-02 > :last-child, .primary-contents-03 > :last-child, .primary-contents-04 > :last-child {
  margin-bottom: 0;
}
.primary-contents > :last-child > :last-child, .primary-contents-02 > :last-child > :last-child, .primary-contents-03 > :last-child > :last-child, .primary-contents-04 > :last-child > :last-child {
  margin-bottom: 0;
}
.primary-contents > :last-child > :last-child > :last-child, .primary-contents-02 > :last-child > :last-child > :last-child, .primary-contents-03 > :last-child > :last-child > :last-child, .primary-contents-04 > :last-child > :last-child > :last-child {
  margin-bottom: 0;
}

.primary-block {
  margin-top: 20px;
  padding: 15px;
  background: #282828;
}

.primary-block >:last-child {
  margin-bottom: 0;
}

.primary-block img {
  max-width: 100%;
  width: auto;
}

.primary-block.ver2 {
  border-bottom: 1px solid #000;
}

/* ----------------------------------------------------------------
    footer
----------------------------------------------------------------- */
#footer {
  padding: 30px 8px 15px;
  width: 100%;
  background: #363636;
  color: #fff;
  box-shadow: inset 0 4px 12px rgba(12, 4, 8, 0.5);
}

.foooter-pagetop {
  margin-bottom: 15px;
  text-align: center;
}

.foooter-btn {
  margin: 0 8px 20px;
  text-align: center;
}
.foooter-btn a {
  display: block;
  padding: 6px;
  border: 1px solid #9b9b9b;
}
.foooter-btn img {
  position: relative;
  top: -.4em;
  margin-right: 8px;
}

.footer-nav-menu {
  margin-bottom: 8px;
  letter-spacing: -.35em;
  text-align: center;
}
.footer-nav-menu li {
  display: inline-block;
  letter-spacing: 0;
  padding: 0 10px;
  border-right: 1px solid #fff;
  line-height: 1.2;
}
.footer-nav-menu li:first-child {
  padding-left: 0;
}
.footer-nav-menu li:last-child {
  padding-right: 0;
  border: none;
}
.footer-nav-menu img {
  position: relative;
  top: -.1em;
  padding-right: 8px;
  box-sizing: content-box;
}

.footer-copyright {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  text-align: center;
}

/* ----------------------------------------------------------------
    SNSarea
----------------------------------------------------------------- */
.snsarea {
  padding: 20px 0 12px 0;
  background-color: #363636;
}
.snsarea ul {
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  padding: 0 0 0 15px;
}
.snsarea ul li {
  float: left;
  width: 125px;
}
.snsarea ul li:last-child {
  margin: 0 0 0 20px;
}
.snsarea ul li img {
  width: 100%;
}

/* ----------------------------------------------------------------
    SNSareafko
----------------------------------------------------------------- */
.snsareafko {
  padding: 8px 0 8px 0;
  border-top: 0px solid #5a5a5a;
  background-color: #363636;
}
.snsareafko ul {
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  padding: 0 0 0 20px;
}
.snsareafko ul li {
  float: left;
  width: 125px;
}
.snsareafko ul li:last-child {
  margin: 0 0 0 20px;
}
.snsareafko ul li img {
  width: 100%;
}

/* ----------------------------------------------------------------
    SYSarea
-----------------------------------------------------------------
.sysarea {
  padding: 40px 0 32px 0;
  border-top: 1px solid #000000;
  background-color: #000000;
}
.sysarea ul {
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  padding: 0 0 0 20px;
}
.sysarea ul li {
  float: left;
  width: 130px;
}
.sysarea ul li:last-child {
  margin: 0 0 0 20px;
}
.sysarea ul li img {
  width: 100%;
}
 */

/* ----------------------------------------------------------------
    SYSarea02
-----------------------------------------------------------------
.sysarea02 {
}
.sysarea02 ul {
  width: 100%;
  margin: 0 auto;
}
.sysarea02 ul li {
  float: left;
  width: 49%;
}
.sysarea02 ul li:last-child {
  margin: 0 0 0 2%;
}
.sysarea02 ul li img {
  width: 100%;
}

#link .top-list-bnr {
  padding: 20px 36px 16px;
}
#link .sysarea02 {
  margin-top: 14px;
}
 */

/* ----------------------------------------------------------------
    Link
----------------------------------------------------------------- */
#link {
  width: 100%;
  padding: 6px 8px 30px;
  background-color: #363636;
}

.hdg-l1 {
  font-size: 25px;
  font-size: 2.5rem;
  line-height: 1.4;
  padding: 30px 14px;
}

.hdg-l1-text {
  font-size: 12px;
  font-size: 1.2rem;
  display: block;
  color: #bf0014;
}

.hdg-l1-02 {
  font-size: 20px;
  font-size: 2rem;
  margin-bottom: 10px;
  padding: 22px 12px;
  color: #fff;
  background: #000;
  border-left: 4px solid #bf0014;
}

.hdg-l1-03 {
  font-size: 26px;
  font-size: 2.6rem;
  line-height: 1.4;
  margin-bottom: 20px;
  padding: 30px 16px;
  border-bottom: 1px solid #363636;
}

.hdg-l1-text-02 {
  font-size: 12px;
  font-size: 1.2rem;
  display: block;
  color: #999;
}

.hdg-l2 {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.4;
  margin: 20px 0;
  padding: 16px 13px;
  border-left: 3px solid #bf0014;
  border-bottom: 1px solid #363636;
}

.hdg-l2.hdg-l2-link {
  padding: 0;
}
.hdg-l2.hdg-l2-link a {
  position: relative;
  display: block;
  padding: 16px 35px 16px 13px;
}
.hdg-l2.hdg-l2-link a:before, .hdg-l2.hdg-l2-link a:after {
  content: "";
  display: table;
}
.hdg-l2.hdg-l2-link a:after {
  clear: both;
}
.hdg-l2.hdg-l2-link a:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.hdg-l2.hdg-l2-link .hdg-l2-blcok {
  float: left;
}
.hdg-l2.hdg-l2-link .hdg-l2-blcok-02 {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  float: right;
  margin-top: 12px;
}
.hdg-l2.hdg-l2-link.theme a:before {
  background: url(../images/icon-arrow-06.png) no-repeat;
  background-size: 8px 14px;
}
.hdg-l2.theme {
  margin-top: 10px;
  border-left-color: #e2b517;
  background: #fff;
  color: #2f1d00;
}
.hdg-l2.theme a {
  color: #2f1d00;
}

.hdg-l2 + .link-menu li:first-child {
  border-top: none;
}

.hdg-l2-text {
  font-size: 12px;
  font-size: 1.2rem;
  display: block;
  color: #bf0014;
  text-align: left;
}

.hdg-l2.theme .hdg-l2-text {
  color: #e2b517;
}

.hdg-l2-link {
	display: block;
	text-align: right;
}
.hdg-l2-link-s {
	display: block;
	font-size: 12px;
	font-size: 1.2rem;
	text-align: right;
}

.hdg-l2-02 {
  font-size: 1.8rem;
  line-height: 1.4;
  margin-bottom: 18px;
}

.nav-pagetop + .primary .hdg-l2 {
  margin-top: 0;
}
.nav-pagetop + .primary .hdg-l2 a {
  color: #ffffff;
  padding: 2px 0 0 12px;
}

.hdg-l3 {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 20px 0;
  line-height: 1.4;
}

section + section .hdg-l3 {
  margin-top: 42px;
}

.hdg-l3-02 {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 15px 0;
  padding: 10px;
  background: #282828;
  line-height: 1.4;
}

.hdg-l3-02.theme {
  background: #ffcd1f;
  text-align: center;
}

.hdg-l3-03 {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 25px 0 13px;
  line-height: 1.4;
}

.hdg-l3-03 .hdg-l3-color {
  color: #bf0014;
}

.hdg-l3-04 {
  font-size: 1.6rem;
  margin: 0 0 13px;
  line-height: 1.4;
}

.hdg-l3-05 {
  font-size: 18px;
  margin: 25px 0 13px;
  line-height: 1.4;
}

.hdg-l4 {
  margin: 42px 0 20px;
}

.hdg-l3 + section .hdg-l4 {
  margin-top: 20px;
}

/* ----------------------------------------------------------------
    Paragraph
----------------------------------------------------------------- */
em {
  font-style: normal;
  font-weight: bold;
}

strong {
  font-weight: bold;
}

b {
  font-weight: bold;
}

.color {
  color: #d0121b;
}

.color-02 {
  color: #2469be;
}

.color-03 {
  color: #fff;
}

.underline {
	text-decoration: underline;
}

/* ----------------------------------------------------------------
    List
----------------------------------------------------------------- */
.list {
  margin: 0 0 20px;
}
.list > li {
  margin: 0 0 8px;
}
.list :last-child {
  margin-bottom: 0;
}

.list > li {
  position: relative;
  padding-left: 10px;
}
.list > li:before {
  content: "";
  display: block;
  width: 3px;
  height: 3px;
  background: #bf0014;
  position: absolute;
  left: 0;
  top: .8em;
}
.list_white > li:before {
  content: "";
  display: block;
  width: 3px;
  height: 3px;
  background: #ffffff;
  position: absolute;
  left: 0;
  top: .8em;
}

.list-flow-form {
  margin-bottom: 10px;
  color: #fff;
}
.list-flow-form:before, .list-flow-form:after {
  content: "";
  display: table;
}
.list-flow-form:after {
  clear: both;
}
.list-flow-form li {
  font-size: 16px;
  font-size: 1.6rem;
  width: 33.3333333224%;
  height: 50px;
  padding: 11px 0 8px;
  float: left;
  background: #000;
  text-align: center;
  position: relative;
}
.list-flow-form li span {
  padding-left: 10px;
}
.list-flow-form li:before {
  content: "";
  background: url(../images/bg-flow-02.png) no-repeat;
  width: 16px;
  height: 50px;
  background-size: 16px 50px;
  position: absolute;
  top: 0;
  left: 0;
}
.list-flow-form li:first-child {
  width: 30.7017532895%;
  padding-left: 0;
}
.list-flow-form li:first-child:before {
  display: none;
}
.list-flow-form li:first-child.is-current + li:before {
  background: url(../images/bg-flow.png) no-repeat;
  background-size: 16px 50px;
}
.list-flow-form li.is-current {
  background: #bf0014;
}
.list-flow-form li.is-current:before {
  background: url(../images/bg-flow-02.png) no-repeat;
  background-size: 16px 50px;
}
.list-flow-form li.is-current + li:last-child:before {
  background: url(../images/bg-flow.png) no-repeat;
  background-size: 16px 50px;
}
.list-flow-form li:last-child {
  width: 35.9649122697%;
}
.list-flow-form li:last-child:before {
  background: url(../images/bg-flow-02.png) no-repeat;
  background-size: 16px 50px;
}

.list-concept {
  width: 100%;
  display: table;
  margin-bottom: 0;
  border-top: 1px solid #000;
}
.list-concept li {
  width: 31.5789473684%;
  padding: 15px 7px 65px;
  background: #282828;
  display: table-cell;
  vertical-align: top;
  border-left: 1px solid #000;
  position: relative;
}
.list-concept li:first-child {
  border: none;
}
.list-concept .title {
  font-size: 11px;
  font-size: 1.1rem;
  font-weight: bold;
  display: block;
  margin-bottom: 14px;
}
.list-concept .text {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  margin-bottom: 10px;
}
.list-concept .btn {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.3;
  padding: 10px 8px 10px 0;
}
.list-concept .btn:before {
  right: 6px;
}
.list-concept .list-btn {
  position: absolute;
  bottom: 10px;
  left: 0;
  width: 100%;
  padding: 0 9px;
}

.list-num li {
  position: relative;
  padding-left: 23px;
}

.list-num img {
  position: absolute;
  left: 0;
  top: .2em;
  display: block;
  width: 16px;
  height: 16px;
}

.list-notes > li {
  position: relative;
  margin-bottom: 5px;
  padding: 0 0 0 1.5em;
  font-size: 1rem;
  list-style-type: none;
}

.list-notes>li .mark {
    position: absolute;
    left: 0;
}

.list-notes.num li {
    padding: 0 0 0 2.2em;
}

.list-num-02 {
  list-style-position: inside;
}

.list-num-02 > li {
  text-indent: -1em;
  padding-left: 1em;
}

.list-num-02 .list-num-inner {
  list-style: none;
  margin-top: 15px;
}

.list-num-02 > li,
.list-num-02 .list-num-inner > li {
  margin-bottom: 15px;
}

.list-num-02 > li:last-child,
.list-num-02 .list-num-inner > li:last-child {
  margin-bottom: 0;
}

.list-num-02 .list-num-inner > li {
  position: relative;
  padding-left: 20px;
}

.list-num-02 .list-num-inner > li span {
  position: absolute;
  left: 0;
}

/* ----------------------------------------------------------------
    Link
----------------------------------------------------------------- */
.link {
  color: #0070bf;
  position: relative;
  padding-left: 10px;
  display: inline-block;
}
.link:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: .35em;
  left: 0;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.link-inline {
  position: inline;
  color: #0070bf;
  position: relative;
  padding-left: 10px;
}
.link-inline:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.link .link-img,
.link-inline .link-img {
  position: relative;
  top: -.4em;
}

.link-underline {
  text-decoration: underline;
}

.link-menu {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
}
.link-menu > li {
  border-top: 1px solid #363636;
}

.link-menu > li.border_bottom_line {
  border-bottom: 2px solid #656565;
}

.link-menu > li.border_bottom_line2 {
  border-bottom: 2px solid #656565;
}

.link-menu > li.border_head_line {
  border-top: 2px solid #656565;
}

.link-menu > li > a {
  position: relative;
  display: block;
  padding: 14px 30px 14px 16px;
  background: #000;
}
.link-menu > li > a:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.link-menu.theme > li > a {
  background: #fff;
  color: #2f1d00;
}
.link-menu.theme > li > a:before {
  background: url(../images/icon-arrow-06.png) no-repeat;
  background-size: 8px 14px;
}
.link-menu.theme-anchor a:before {
  background: url(../images/icon-arrow-02.png) no-repeat;
  width: 13px;
  height: 8px;
  margin-top: -4px;
  background-size: 13px 8px;
}
.link-menu .link-menu-theme a {
  padding: 14px 30px 14px 42px;
}
.link-menu .link-menu-theme-02 a {
  padding: 25px 30px 25px 16px;
}
.link-menu.link-menu-theme > li {
  font-weight: bold;
}
.link-menu.link-menu-theme > li .link-menu-third, .link-menu.link-menu-theme > li .link-menu-fourth {
  font-weight: normal;
}

.link-menu-text {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  color: #bf0014;
}

.link-menu.theme .link-menu-text {
  color: #e2b517;
}

.link-menu-date {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  color: #999;
}

.link-menu-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  margin-top: -8px;
}

.link-menu-icon-02 {
  position: relative;
  top: -.28em;
  margin-right: 7px;
}

.link-menu-sub {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 0;
}
.link-menu-sub > li {
  border-top: 1px solid #363636;
}
.link-menu-sub > li > a {
  position: relative;
  display: block;
  padding: 14px 30px 14px 16px;
  background: #282828;
}
.link-menu-sub > li > a:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}

.link-menu-sub-02 {
  margin-bottom: 0;
}
.link-menu-sub-02 > li {
  border-top: 1px solid #383838;
}
.link-menu-sub-02 > li > a {
  display: block;
  position: relative;
  padding: 18px 25px 14px 38px;
}
.link-menu-sub-02 > li > a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 22px;
  margin-top: 1px;
  width: 6px;
  height: 2px;
  background: #fff;
}
.link-menu-sub-02 > li > a:after {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}

.link-menu-third, .link-menu-fourth {
  margin-bottom: 0;
}
.link-menu-third > li, .link-menu-fourth > li {
  border-top: 1px solid #383838;
}
.link-menu-third > li > a, .link-menu-fourth > li > a {
  display: block;
  position: relative;
  padding: 18px 20px 14px 35px;
  background: #282828;
}
.link-menu-third > li > a:after, .link-menu-fourth > li > a:after {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}

.link-menu-fourth > li > a {
  padding: 18px 20px 14px 58px;
}

.link-menu-02 {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.5;
  background: #000;
}
.link-menu-02 li {
  border-top: 1px solid #363636;
}
.link-menu-02 li:first-child {
  border: none;
}
.link-menu-02 .link-menu-contents {
  display: table;
  width: 100%;
}
.link-menu-02 .link-menu-img {
  display: table-cell;
  vertical-align: middle;
}
.link-menu-02 .link-menu-col {
  display: table-cell;
  padding-left: 18px;
  width: 100%;
  vertical-align: middle;
  font-weight: bold;
}
.link-menu-02 .link-menu-text {
  font-weight: normal;
}
.link-menu-02 a {
  position: relative;
  display: block;
  padding-right: 20px;
}
.link-menu-02 a:before, .link-menu-02 a:after {
  content: "";
  display: table;
}
.link-menu-02 a:after {
  clear: both;
}
.link-menu-02 a:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}

.link-menu-02 a.ver2:before {
  background: url(../images/icon-window-02.png) no-repeat;
  top: 50%;
  right: 10px;
  margin-top: -8px;
  width: 15px;
  height: 13px;
  background-size: 15px 13px;
}

.primary + .link-menu-02 {
  margin-top: 40px;
}

.link-menu-02 ul {
  padding: 20px 20px 10px 20px;
}
.link-menu-02 ul li:first-child {
  border: 1px solid #363636;
}
.link-menu-02 ul li {
  border: 1px solid #363636;
  border-width: 0 1px 1px 1px;
}
.link-menu-02 ul li a {
  display: block;
  padding: 16px 20px;
  font-size: 80%;
  font-weight: bold;
}
.link-menu-02 ul li a img {
  position: relative;
  top: -0.3em;
  margin-right: 8px;
}

.link-contents {
  position: relative;
  border: 1px solid #363636;
}
.link-contents:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.link-contents a {
  display: block;
  padding: 16px 20px;
  text-decoration: none;
  font-weight: bold;
}

/* ----------------------------------------------------------------
   Table
----------------------------------------------------------------- */
.table-form {
  width: 100%;
  margin-bottom: 6px;
}
.table-form th {
  font-size: 16px;
  font-size: 1.6rem;
  padding: 12px 16px;
  background: #e9e9e9;
  text-align: left;
  display: block;
  color: #000;
}
.table-form td {
  padding: 14px 16px;
  display: block;
  background: #fff;
  border-bottom: 1px solid #363636;
  color: #000;
}
.table-form p {
  margin-bottom: 10px;
  color: #000;
}
.table-form .form-label {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  top: -2px;
  margin: 0 0 0 7px;
}
.table-form.table-form-theme tr:first-child th {
  border-top: 1px solid #363636;
}
.table-form a {
  color: #000;
}

.table th {
  padding: 20px 10px 0 0;
  font-weight: normal;
  min-width: 75px;
  vertical-align: top;
  text-align: left;
}
.table td {
  padding: 20px 0 0 0;
}
.table tr:first-child th, .table tr:first-child td {
  padding-top: 0;
}

.table-02 {
  width: 100%;
  margin-bottom: 20px;
}

.table-02 th.head {
  width: 100%;
  background: #404040;
  text-align: center;
  border-top-width: 2px;
  font-weight: bold;
}

.table-02 th {
  background: #141414;
  width: 50%;
  text-align: left;
  font-weight: normal;
}

.table-02 td {
  width: 50%;
  text-align: right;
}

.table-02 th ,
.table-02 td {
  padding: 13px;
  border: 1px solid #282828;
}

.table-02.ver2 th {
  width: 15%;
  text-align: center;
  vertical-align: top;
}

.table-02.ver2 td {
  width: 85%;
  text-align: left;
  vertical-align: top;
}

.table-nomarl {
  width: 100%;
}

.table-nomarl th {
  text-align: left;
  font-weight: normal;
  vertical-align: top;
}

.table-nomarl td {
  text-align: left;
  font-weight: normal;
  vertical-align: top;
}

/* ----------------------------------------------------------------
    Media
----------------------------------------------------------------- */
.media {
  margin: 0 0 20px;
  text-align: center;
}
.media img {
  width: 100%;
}

.media-caption {
  font-size: 13px;
  font-size: 1.3rem;
  margin-top: 5px;
  display: block;
  text-align: left;
}

.media-element {
  margin: 0 0 20px;
}
.media-element > .media-item {
  margin-bottom: 10px;
  text-align: center;
}
.media-element > .media-col > :last-child {
  margin-bottom: 0;
}
.media-element > .media-col > section:last-child > :last-child {
  margin-bottom: 0;
}

.media-element:before, .media-element:after, .media-element-02:before, .media-element-02:after {
  content: "";
  display: table;
}
.media-element:after, .media-element-02:after {
  clear: both;
}

.media-element[data-media-layout*=" parallel"] > .media-col, .media-element[data-media-layout^=parallel] > .media-col {
  overflow: hidden;
}
.media-element[data-media-layout*=" parallel"] > .media-item, .media-element[data-media-layout^=parallel] > .media-item {
  margin-bottom: 0;
}

.media-element[data-media-layout*=" right"] > .media-item, .media-element[data-media-layout^=right] > .media-item {
  float: right;
  margin-left: 10px;
}

.media-element[data-media-layout*=" left"] .media-item, .media-element[data-media-layout^=left] .media-item {
  float: left;
  margin-right: 10px;
}

.media-element-02 {
  display: table;
  width: 100%;
  border-bottom: 1px solid #282828;
  padding-bottom: 12px;
  margin-bottom: 10px;
}
.media-element-02.ver2 {
  border: none;
  padding-bottom: 0;
  margin-bottom: 20px;
}
.media-element-02 > .media-col {
  display: table-cell;
  width: 80px;
  padding: 10px;
  vertical-align: middle;
  font-weight: bold;
  text-align: center;
  line-height: 1.4;
  background: #282828;
}
.media-element-02.theme > .media-col {
  background: #e9e9e9;
}
.media-element-02 > .media-col > :last-child {
  margin-bottom: 0;
}
.media-element-02 > .media-item {
  display: table-cell;
  padding-left: 12px;
  vertical-align: middle;
}
.media-element-02 > .media-item > :last-child {
  margin-bottom: 0;
}

.media-wrap {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px dotted #2d1c00;
}

.media-wrap > :last-child {
  margin-bottom: 0;
}

.mt-image-center {
  max-width: 100%;
  height: auto;
}

/* ----------------------------------------------------------------
   Button
----------------------------------------------------------------- */
.btn {
  font-size: 16px;
  font-size: 1.6rem;
  display: block;
  position: relative;
  padding: 15px 25px;
  background-color: #a8a8a8;
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.09) 0%, rgba(255, 255, 255, 0.09) 100%);
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.09) 0%, rgba(255, 255, 255, 0.09) 100%);
  box-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  text-shadow: 0 1px 2px rgba(6, 2, 4, 0.35);
  text-align: center;
  font-weight: bold;
  text-decoration: none;
}
.primary-contents .btn {
	text-decoration: none;
}
.btn.theme {
  background-color: #2f1d00;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.01) 0%, rgba(255, 255, 255, 0.01) 100%);
  box-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  text-decoration: none;
}

.btn:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.btn .btn-icon {
  position: relative;
  top: -.4em;
  margin-right: 8px;
}

.btn-back {
  font-size: 16px;
  font-size: 1.6rem;
  display: block;
  position: relative;
  padding: 15px 25px 15px 33px;
  background: #282828;
  width: 100%;
  color: #fff;
  border: none;
  text-decoration: none;
}
.btn-back:before {
  content: "";
  background: url(../images/icon-arrow-03.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  left: 16px;
  margin-top: -6px;
  width: 8px;
  height: 13px;
  background-size: 8px 13px;
}
.btn-back.btn-back-theme {
  padding: 11px 8px 11px 33px;
}

.btn-strong {
  font-size: 16px;
  font-size: 1.6rem;
  display: block;
  position: relative;
  width: 100%;
  padding: 15px 28px 15px 23px;
  background-color: #d0121b;
  border: none;
  color: #fff;
  font-weight: bold;
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.04) 0%, rgba(255, 255, 255, 0.04) 100%);
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.04) 0%, rgba(255, 255, 255, 0.04) 100%);
  box-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  text-shadow: 0 2px 4px rgba(12, 4, 8, 0.35);
  text-decoration: none;
}
.btn-strong:before {
  content: "";
  background: url(../images/icon-arrow-04.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  margin-top: -6px;
  width: 8px;
  height: 13px;
  background-size: 8px 13px;
}
.btn-strong.theme {
  font-size: 20px;
  font-size: 2rem;
  text-align: center;
  text-decoration: none;
}
.btn-strong.theme:before {
  background: url(../images/icon-arrow-05.png) no-repeat;
  right: 9px;
  margin-top: -8px;
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
}
.btn-strong .btn-icon-tel {
  position: relative;
  top: -.25em;
  margin-right: 8px;
}

.btn-mail {
  line-height: 1.4;
  text-decoration: none;
}
.btn-mail .btn-icon {
  top: -.3em;
}
.btn-mail .btn-mail-text {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  padding-left: 14px;
}

.btn-blank:before {
    background: url(../images/icon-window.png) no-repeat;
    right: 9px;
    margin-top: -8px;
    width: 16px;
    height: 16px;
    background-size: 16px 16px;
}

.btn-blank-02:before {
    background: url(../images/icon-window-02.png) no-repeat;
    right: 9px;
    margin-top: -8px;
    width: 16px;
    height: 16px;
    background-size: 16px 16px;
}

.btn-anchor:before {
    background: url(../images/icon-arrow-02.png) no-repeat;
    width: 13px;
    height: 8px;
    margin-top: -4px;
    background-size: 13px 8px;
}

.btn-list li {
  margin-bottom: 5px;
}

.btn-list li:last-child {
  margin-bottom: 0;
}

.btn-list li a {
  text-align: left;
}

/* ----------------------------------------------------------------
    Form
----------------------------------------------------------------- */
input[type=color],
input[type=date],
input[type=datetime-local],
input[type=datetime],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week],
select,
textarea {
  font-size: 16px;
  font-size: 1.6rem;
  padding: 8px;
  background: #fff;
  border: 1px solid #999;
  box-shadow: inset 0 2px 4px rgba(6, 2, 4, 0.15);
  border-radius: 4px;
}

input[type=checkbox] {
  margin-right: 10px;
}

.table-form .form_select {
  margin-bottom: 20px;
}
.table-form .form_select select {
  width: 80%;
}

.form-label {
  font-size: 16px;
  font-size: 1.6rem;
  display: inline-block;
  margin-right: 5px;
  padding: 0 5px;
  border-radius: 4px;
  color: #fff;
  text-align: center;
  background: #bf0014;
  font-weight: normal;
}

textarea {
  width: 100%;
}
.panel-03 textarea {
  overflow-x: visible;
  overflow-y: scroll;
}

.form-list {
  margin-bottom: 0;
}
.form-list li {
  display: inline-block;
  margin-left: 15px;
  color: #000;
}
.form-list li:first-child {
  margin-left: 0;
}

.form-box {
  padding: 20px 16px;
  background: #e9e9e9;
}

.form-notice {
  color: #666;
  line-height: 1.5;
}
.form-notice a {
  color: #666;
}

/* ----------------------------------------------------------------
    Nav
----------------------------------------------------------------- */
.nav-pagetop {
  margin: 10px 0;
  text-align: right;
}
.nav-pagetop a {
  position: relative;
}
.nav-pagetop a:before {
  content: "";
  background: url(../images/icon-pagetop.png) no-repeat;
  width: 21px;
  height: 21px;
  background-size: 21px 21px;
  position: absolute;
  top: -.2em;
  left: -28px;
}

.nav-paginate {
  text-align: center;
  letter-spacing: -.35em;
}
.nav-paginate li {
  display: inline-block;
  letter-spacing: 0;
}
.nav-paginate .paging, .nav-paginate .preview, .nav-paginate .next {
  letter-spacing: -.35em;
}
.nav-paginate .paging a, .nav-paginate .paging span, .nav-paginate .preview a, .nav-paginate .preview span, .nav-paginate .next a, .nav-paginate .next span {
  letter-spacing: 0;
  border-left: 1px solid #565656;
  background: #282828;
  width: 40px;
  padding: 8px 0 7px;
  display: inline-block;
  text-align: center;
  vertical-align: middle;
}
.nav-paginate .paging a.current_page, .nav-paginate .paging span.current_page, .nav-paginate .preview a.current_page, .nav-paginate .preview span.current_page, .nav-paginate .next a.current_page, .nav-paginate .next span.current_page {
  background: #bf0014;
  color: #fff;
}
.nav-paginate .paging span, .nav-paginate .preview span, .nav-paginate .next span {
  background: #3f3f3f;
}
.nav-paginate .preview {
  margin-right: 2.4671052632%;
}
.nav-paginate .preview a {
  border: none;
}
.nav-paginate .next {
  margin-left: 2.4671052632%;
}

.nav-paginate.ver2 > .current_page span {
  letter-spacing: 0;
  border-left: 1px solid #565656;
  background: #bf0014;
  width: 40px;
  padding: 8px 0 7px;
  display: inline-block;
  text-align: center;
  vertical-align: middle;
  color: #fff;
}

.nav-paginate.ver2 li a {
  letter-spacing: 0;
  border-left: 1px solid #565656;
  background: #3f3f3f;
  width: 40px;
  padding: 8px 0 7px;
  display: inline-block;
  text-align: center;
  vertical-align: middle;
  color: #fff;
}

.top-hdg {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 28px 0 10px 0;
  text-align: center;
  background: #363636;
  color: #fff;
}

.top-hdg-02 {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 -8px;
  padding: 0;
  text-align: center;
  background: #747474;
  color: #fff;
}

.top-menu {
  margin: 0 -8px;
}
.top-menu li {
  border-top: 1px solid #363636;
}
.top-menu li:first-child {
  border-top-color: #000;
}
.top-menu a {
  display: block;
  width: 100%;
  min-height: 119px;
  background-color: #000;
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 122px 119px;
  padding-top: 20px;
}
.top-menu .top-menu-item {
  background-image: url(../../images/index-menu.jpg);
}
.top-menu .top-menu-item-02 {
  background-image: url(../../images/index-menu-02.jpg);
}
.top-menu .top-menu-item-03 {
  background-image: url(../../images/index-menu-03.jpg);
}
.top-menu .top-menu-item-04 {
  background-image: url(../../images/index-menu-04.jpg);
  padding-top: 40px;
}
.top-menu .top-menu-item-05 {
  background-image: url(../../images/index-menu-01.jpg);
}
.top-menu .title {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.3;
  font-weight: bold;
  margin-bottom: 8px;
}
.top-menu .title-sub {
  font-size: 12px;
  font-size: 1.2rem;
  color: #d0121b;
  font-weight: normal;
  display: block;
}
.top-menu .text {
  color: #999;
  padding-right: 10px;
}
.top-menu .menu-wrap {
  display: table;
  width: 100%;
}
.top-menu .menu-contents {
  display: table-cell;
  width: 100%;
  line-height: 1.2;
  vertical-align: middle;
  padding-left: 100px;
}

.top-list-menu > li {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  border-top: 10px solid #363636;
}
.top-list-menu > li:first-child {
  border-width: 2px 0 0;
}
.top-list-menu > li .sub-text {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: normal;
  float: right;
}
.top-list-menu > li > a {
  position: relative;
  display: block;
  padding: 14px 30px 14px 16px;
  background: #000;
}
.top-list-menu > li > a:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}

.top-list-menu-sub {
  margin-bottom: 0;
}
.top-list-menu-sub > li {
  font-size: 14px;
  font-size: 1.4rem;
  border-top: 1px solid #363636;
  font-weight: normal;
  line-height: 1.5;
}
.top-list-menu-sub > li > .menu-link {
  position: relative;
  display: block;
  padding: 10px 30px 10px 16px;
  background: #282828;
}
.top-list-menu-sub > li > .menu-link:before {
  content: "";
  background: url(../images/icon-arrow.png) no-repeat;
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -7px;
  width: 8px;
  height: 14px;
  background-size: 8px 14px;
}
.top-list-menu-sub > li .menu-sub-date {
  font-size: 12px;
  font-size: 1.2rem;
  color: #999;
  display: block;
}
.top-list-menu-sub > li img {
  width: 100%;
}

.top-panel {
  margin-bottom: 15px;
  border-bottom: 1px solid #363636;
}

.top-box {
  padding: 8px;
  background: #e5e5e5;
  color: #000;
}

.top-btn-strong:before, .top-btn-strong:after {
  content: "";
  display: table;
}
.top-btn-strong:after {
  clear: both;
}
.top-btn-strong .btn-strong {
  font-size: 16px;
  font-size: 1.6rem;
  padding: 15px 22px 15px 0;
}
.top-btn-strong li {
  float: left;
  padding-left: 4px;
  width: 33.33333333%;
}
.top-btn-strong li:first-child {
  padding-left: 0;
}


.top-list-bnr {
  margin: 0 -8px;
  padding: 12px 16px 10px 16px;
  background: #5a5a5a;
}
.top-list-bnr li {
  margin-top: 2px;
}
.top-list-bnr li:first-child {
  margin-top: 0;
  margin-bottom: 4px;
}

.top-list-bnr li ul.column2 {
  overflow: hidden;
  margin: 0;
}
.top-list-bnr li ul.column2 li {
  display: inline-block;
  margin: 0;
}
.top-list-bnr li ul.column2 li.first {
  float: left;
  width: 60%;
}
.top-list-bnr li ul.column2 li.last {
  float: right;
  width: 38%;
  xmargin-left: 2%;
}
.top-list-bnr li a img {
  width: 100%;
}

/*
.top-list-bnr {
  margin: 0 -8px;
  padding: 20px 16px 16px 16px;
  background: #5a5a5a;
}
.top-list-bnr li {
  max-width: 288px;
  margin: 4px auto 0;
}
.top-list-bnr li:first-child {
  margin-top: 0;
}
.top-list-bnr li ul.column2 {
  display: flex;
  margin: 0;
}
.top-list-bnr li ul.column2 li {
  margin: 0;
}
.top-list-bnr li ul.column2 li.first {
  width: 60%;
}
.top-list-bnr li ul.column2 li.last {
  width: 38%;
  margin-left: 2%;
}
.top-list-bnr li a img {
  width: 100%;
}
*/
/* Slider */
.slider {
  box-shadow: 0 8px 16px rgba(12, 4, 8, 0.35);
}

.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir="rtl"] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.top-slider .slick-prev, .top-slider .slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  margin-top: -25px;
  padding: 0;
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent;
  width: 44px;
  height: 44px;
}
.top-slider .slick-prev {
  left: 5px;
}
.top-slider .slick-next {
  right: 5px;
}
.top-slider .slick-prev:before, .top-slider .slick-next:before {
  content: "";
  display: block;
  width: 15px;
  height: 27px;
  background-position: left top;
  background-size: 15px 27px;
  background-repeat: no-repeat;
  position: relative;
}
.top-slider .slick-prev:before {
  background-image: url("../../images/index-slider-arrow.png");
  right: -13px;
}
.top-slider .slick-next:before {
  background-image: url("../../images/index-slider-arrow-02.png");
  left: 15px;
}
.top-slider .slick-dots {
  position: absolute;
  bottom: 7px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.top-slider .slick-dots li {
  position: relative;
  display: inline-block;
  height: 10px;
  width: 10px;
  margin: 0 7px;
  padding: 0;
  cursor: pointer;
}
.top-slider .slick-dots li button {
  border: 0;
  display: block;
  height: 10px;
  width: 10px;
  border-radius: 5px;
  cursor: pointer;
  background: #fff;
  line-height: 0;
  font-size: 0;
  padding: 0;
}
.top-slider .slick-dots li:first-child {
  margin-left: 0;
}
.top-slider .slick-dots li:last-child {
  margin-right: 0;
}
.top-slider .slick-dots li.slick-active {
  width: 16px;
  height: 16px;
}
.top-slider .slick-dots li.slick-active button {
  height: 16px;
  width: 16px;
  border-radius: 8px;
  background: #bf0014;
}

.slick-slide {
  position: relative;
}
.slick-slide .slider-contents {
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  width: 100%;
  padding: 15px 15px 35px;
}
.slick-slide .slider-lead {
  font-size: 25px;
  font-size: 2.5rem;
  font-weight: bold;
  line-height: 1.1;
  margin-bottom: 6px;
}
.slick-slide .slider-lead-sub {
  font-size: 15px;
  font-size: 1.5rem;
  color: #bf0014;
}
.slick-slide .slider-text {
  margin-bottom: 0;
  line-height: 1.4;
}

.join_btn{
	width: 100%;
	height: auto;
}

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

.taphere_btn {
	position: absolute;
	width: 100px;
	height: auto;
	border: 1px solid #fff;
	border-radius: 10px;
	color: #fff;
	font-weight: 500;
	font-size: 2rem;
	text-align: center;
	padding: 20px;
	top:200px;
	left:30px;

}


/* FOOD SUPPORT
----------------------------------------------- */
.hdg-cafe-block {
  border-bottom: 1px solid #363636;
  padding: 20px;
  text-align: center;
  background: #fff;
}

.hdg-cafe-block p {
  margin-bottom: 0;
}

.hdg-cafe-block > :last-child {
  margin-bottom: 0;
}

.hdg-cafe {
  font-size: 2.6rem;
  line-height: 1.25;
  color: #2f1d00;
}

.hdg-logo-cafe {
  line-height: 0;
}

.hdg-cafe .hdg-cafe-text {
  display: block;
  padding-top: 5px;
  font-size: 1.3rem;
  line-height: 1.4;
  color: #e2b517;
}

.hdg-cafe-02 {
  font-size: 1.6rem;
  margin: 15px 0;
  padding: 5px 0;
  border-top: 2px dotted #565656;
  border-bottom: 2px dotted #565656;
  text-align: center;
}

/* schedule
----------------------------------------------- */
.table-schedule table {
  width: 100%;
  border: 1px solid #282828;
  border-left: none;
  border-bottom: none;
}

.table-schedule th,
.table-schedule td {
  padding: 7px 10px;
  border-left: 1px solid #282828;
  border-bottom: 1px solid #282828;
  text-align: center;
}

.table-schedule tr:first-child th {
  background: #404040;
}

.table-schedule tr th.Sun {
  background: #bf0014;
}

.table-schedule tr th.Sat {
  background: #2469be;
}

.table-schedule .check {
  background: #141414;
}

.table-schedule-02 {
  width: 100%;
  border: 1px solid #282828;
  border-left: none;
  border-bottom: none;
}

.table-schedule-02 td {
  padding: 7px 10px;
  border-left: 1px solid #282828;
  border-bottom: 1px solid #282828;
  text-align: center;
  width: 10%;
}

.table-schedule-02 td:last-child {
  width: 80%;
  text-align: left;
}

.table-schedule-02 td:first-child + td {
  background: #404040;
}

.table-schedule-02 tr td.sat {
  background: #2469be;
}

.table-schedule-02 tr td.sun {
  background: #bf0014;
}

.table-schedule-02 tr:nth-child(odd) {
  background: #141414;
}


/* box
----------------------------------------------- */
.box {
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.4;
  position: relative;
  margin-bottom: 30px;
  padding: 22px 12px;
  text-align: center;
  background: url("../images/bg.png");
}

.box > :last-child {
  margin-bottom: 0;
}

.box .notice {
  position: absolute;
  right: 10px;
  top: 10px;
  font-size: 1.2rem;
}

.box-color {
  color: #333;
}

.box-02 {
  margin-bottom: 30px;
  padding: 10px;
  background: #300005;
}

.box-02 .box {
  margin-bottom: 0;
}

.box-02.ver2 {
  position: relative;
  margin-bottom: 40px;
}

.box-02.ver2:after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  bottom: -35px;
  margin: 0 0 0 -30px;
  background-image: url("../images/bg-arw.png");
  background-position: left bottom;
  background-repeat: no-repeat;
  background-size: 69px 36px;
  width: 69px;
  height: 36px;
}

.box-03 {
  padding: 10px;
  background: #ffe3e3;
}

/* privilege_ser
----------------------------------------------- */

.sort {
  display: table;
  width: 100%;
}

.sort .input-btn-warp {
  padding-left: 10px;
}

.sort #input_btn {
  display: table-cell;
  min-width: 92px;
  background-color: #c00014;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.04) 0%, rgba(255, 255, 255, 0.04) 100%);
  box-shadow: 0 1px 2px rgba(12, 4, 8, 0.35);
  border: none;
  font-size: 1.6rem;
  font-weight: bold;
  white-space: nowrap;
}

.sort #select_form {
  display: table-cell;
  width: calc(100% - 102px);
  color: #282828;
  font-size: 1.6rem;
  border-radius: 0;
}

.ser-list li {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #363636;
}

.ser-list a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.ser-list .logo {
  float: left;
}

.ser-list .text {
  overflow: hidden;
  padding: 15px 28px 15px 15px;
}

.ser-list .shop_name {
  font-weight: bold;
  margin-bottom: 0;
  position: relative;
}

.ser-list .shop_name:before {
    content: "";
    background: url(../images/icon-arrow.png) no-repeat;
    display: block;
    position: absolute;
    top: 50%;
    right: -19px;
    margin-top: -7px;
    width: 8px;
    height: 14px;
    background-size: 8px 14px;
}

.ser-list .detail {
  margin: 8px 0 0;
  padding-top: 8px;
  border-top: 1px dotted #565656;
}

.ser-list .detail em {
  color: #c00014;
}

/* Magnific Popup CSS */
.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #000;
  opacity: 0.6;
  filter: alpha(opacity=60); }

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden; }

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.mfp-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.mfp-align-top .mfp-container:before {
  display: none; }

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045; }

.mfp-inline-holder .mfp-content, .mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto; }

.mfp-ajax-cur {
  cursor: progress; }

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.mfp-auto-cursor .mfp-content {
  cursor: auto; }

.mfp-close, .mfp-arrow, .mfp-preloader, .mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

.mfp-loading.mfp-figure {
  display: none; }

.mfp-hide {
  display: none !important; }

.mfp-preloader {
  color: #cccccc;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044; }
  .mfp-preloader a {
    color: #cccccc; }
    .mfp-preloader a:hover {
      color: white; }

.mfp-s-ready .mfp-preloader {
  display: none; }

.mfp-s-error .mfp-content {
  display: none; }

.white-popup{
  background: none repeat scroll 0 0 #FFFFFF;
  margin: 20px auto;
  max-width: 600px;
  position: relative;
  width: auto;
  overflow: hidden;
}
.white-popup div.name{
  margin: 20px 15px;
}
.white-popup p.ttl{
  font-size: 1.6rem;
  font-weight: bold;
  padding: 7px;
  background-color: #333;
  border-left: 3px solid #bf0014;
  border-bottom: 1px solid #000;
  color: #fff;
}
.white-popup h1{
  font-size: 1.6rem;
  text-align: left;
}
.white-popup .pop_name{
  overflow: hidden;
  margin: 20px 15px;
}

.white-popup .pop_name .media-element-02 .media-col {
  width: 100%;
  background: none;
  text-align: left;
  padding: 0;
}

.white-popup .pop_name .media-element-02 {
  border-bottom: none;
}

.white-popup .pop_name .media-element-02 > .media-item {
  padding-left: 0;
}

.white-popup .pop_name p{
/*  width: 448px;
  font-size: 18px;
  float: right;
  margin-top: 10px;
  font-weight: bold;
  line-height: 1.4;*/
}
.white-popup .pop_name span{
  font-weight: normal;
  font-size: 14px;
}
.white-popup .pop_logo{
  border: 1px solid #ccc;
  float: left;
  margin-right: 15px;
}
.white-popup em{
  color: #ff0000;
  font-style: normal;
}
.white-popup .pop_data{
  margin: 0 15px;
/*  background: #dddddd;
  margin: 0 15px 55px;
  padding-top: 10px;*/
}
.white-popup .pop_data section {
  padding: 10px 0 10px 20px;
}
.white-popup .pop_data section p{
  display: table-cell;
  padding-right: 20px;
  min-width: 50px;
}
.white-popup .pop_data section p:first-child {
  font-weight: bold;
}
.white-popup .pop_data a{
/*  padding-left: 10px;
  background: url(../../fukuoka/images/pri_arrow.png) no-repeat left 4px;*/
  color: #0070bf;
}

.white-popup .pop_data .pop_def {
  margin: 20px 0;
}

.white-popup .pop_data .pop_def dt {
  display: table-cell;
  padding-right: 20px;
  min-width: 90px;
  font-weight: bold;
}

.white-popup .pop_data .pop_def dd {
  display: table-cell;
}

.white-popup .pop_data .pop_data_text {
    border-top: 2px dotted #565656;
    border-bottom: 2px dotted #565656;
    margin: 0 0 15px;
    padding: 10px 0;
}

.white-popup .pop_data .pop_data_text > :last-child {
  margin-bottom: 0;
}

.white-popup .pop_data .btn {
  display: inline-block;
  padding: 10px 25px;
  color: #fff;
  text-align: center;
}

.white-popup .pop_name .modal_box {
  border: 2px solid #C00014;
}

.white-popup .pop_name .modal_box_title {
  font-size: 1.6rem;
  padding: 5px 0;
  background: #C00014;
  color: #fff;
  text-align: center;
}

.white-popup .pop_name .modal_box_inner {
  padding: 8px;
  background: #feecee;
  font-weight: bold;
  font-size: 1.6rem;
}

.white-popup .pop_name .modal_box_inner >:last-child {
  margin-bottom: 0;
}

.white-popup .pop_data .pop_blank {
  position: relative;
  padding-left: 20px;
}

.white-popup .pop_data .pop_blank:before {
    content: "";
    background: url(../images/icon-window-03.png) no-repeat;
    display: inline-block;
    position: absolute;
    left: 0;
    top: .2em;
    margin-right: 3px;
    width: 15px;
    height: 13px;
    background-size: 15px 13px;
}

.white-popup .pop_data .btn:before {
  display: none;
}

button.mfp-close, button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  -webkit-box-shadow: none;
  box-shadow: none; }
button::-moz-focus-inner {
  padding: 0;
  border: 0; }

.mfp-close-btn-in .mfp-close {
  color: #333333; }

.mfp-image-holder .mfp-close, .mfp-iframe-holder .mfp-close {
  color: white;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%; }

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #cccccc;
  font-size: 12px;
  line-height: 18px; }

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
  .mfp-arrow:active {
    margin-top: -54px; }
  .mfp-arrow:hover, .mfp-arrow:focus {
    opacity: 1; }
  .mfp-arrow:before, .mfp-arrow:after, .mfp-arrow .mfp-b, .mfp-arrow .mfp-a {
    content: '';
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent; }
/*  .mfp-arrow:after, .mfp-arrow .mfp-a {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px; }
  .mfp-arrow:before, .mfp-arrow .mfp-b {
    border-top-width: 21px;
    border-bottom-width: 21px; }*/

.mfp-arrow-left {
  left: 0; }
  .mfp-arrow-left:after, .mfp-arrow-left .mfp-a {
    border-right: 17px solid white;
    margin-left: 31px; }
  .mfp-arrow-left:before, .mfp-arrow-left .mfp-b {
    margin-left: 25px;
    border-right: 27px solid #3f3f3f; }

/*.mfp-arrow-right {
  right: 0; }
  .mfp-arrow-right:after, .mfp-arrow-right .mfp-a {
    border-left: 17px solid white;
    margin-left: 39px; }
  .mfp-arrow-right:before, .mfp-arrow-right .mfp-b {
    border-left: 27px solid #3f3f3f; }*/

/*.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px; }
  .mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px; }
  .mfp-iframe-holder .mfp-close {
    top: -40px; }*/

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%; }
  .mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: black; }

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0px 0 40px;
  margin: 0 auto; }

/* The shadow behind the image */
.mfp-figure {
  line-height: 0; }
  .mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #444444; }
  .mfp-figure small {
    color: #bdbdbd;
    display: block;
    font-size: 12px;
    line-height: 14px; }
  .mfp-figure figure {
    margin: 0; }

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto; }

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #f3f3f3;
  word-wrap: break-word;
  padding-right: 36px; }

.mfp-image-holder .mfp-content {
  max-width: 100%; }

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer; }

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
       * Remove all paddings around the image on small screen
       */
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0; }
  .mfp-img-mobile img.mfp-img {
    padding: 0; }
  .mfp-img-mobile .mfp-figure {
    /* The shadow behind the image */ }
    .mfp-img-mobile .mfp-figure:after {
      top: 0;
      bottom: 0; }
    .mfp-img-mobile .mfp-figure small {
      display: inline;
      margin-left: 5px; }
  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }
    .mfp-img-mobile .mfp-bottom-bar:empty {
      padding: 0; }
  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px; }
/*  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0; } */
  }

@media all and (max-width: 900px) {
  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    transform-origin: 0; }
  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    transform-origin: 100%; }
  .mfp-container {
    padding-left: 6px;
    padding-right: 6px; } }

.mfp-ie7 .mfp-img {
  padding: 0; }
.mfp-ie7 .mfp-bottom-bar {
  width: 600px;
  left: 50%;
  margin-left: -300px;
  margin-top: 5px;
  padding-bottom: 5px; }
.mfp-ie7 .mfp-container {
  padding: 0; }
.mfp-ie7 .mfp-content {
  padding-top: 44px; }
.mfp-ie7 .mfp-close {
  top: 0;
  right: 0;
  padding-top: 0; }

.mfp-image-holder .mfp-close {
  font-size: 4rem;
  color: #bf0014;
  position: absolute;
  top: -21px;
}

.mfp-counter {
  display: none;
}

.mfp-arrow {
  width: 40px;
  height: 40px;
  opacity: 1;
  height: auto;
}

.mfp-arrow:before {
  margin-top: 0;
}

.mfp-arrow-right {
  right: 0px;
  left: auto;
  top: 43%;
}

.mfp-arrow-left {
  left: 0;
  top: 43%;
}

.mfp-arrow-right:before {
  width: 30px;
  height: 30px;
  background-image: url(../images/popup-next.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 30px 30px;
  margin-left: 0;
  border: none;
}

.mfp-arrow-left:before {
  width: 30px;
  height: 30px;
  background-image: url(../images/popup-prev.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 30px 30px;
  margin-left: 0;
  border: none;
}

.mfp-arrow-left {
  left: 15px;
}

.mfp-arrow-left:after {
  display: none;
}

.mfp-arrow-right:after {
  display: none;
}


/* ----------------------------------------------------------------
  Utils
----------------------------------------------------------------- */
/* Display Control
----------------------------------------------- */
.block {
  display: block !important;
}

.inline-block {
  display: inline-block !important;
}

.inline {
  display: inline !important;
}

.table-block {
  display: table !important;
}
.table-block img {
  max-width: none;
}

.table-cell {
  display: table-cell !important;
}

/* Flat Control
----------------------------------------------- */
.f-left {
  float: left;
}

.f-right {
  float: right;
}

.clearfix:before, .clearfix:after {
  content: "";
  display: table;
}
.clearfix:after {
  clear: both;
}

/* Align Control
----------------------------------------------- */
.left {
  text-align: left !important;
}

.center {
  margin-right: auto !important;
  margin-left: auto !important;
  text-align: center !important;
}

.right {
  text-align: right !important;
}

.top {
  vertical-align: top !important;
}

.middle {
  vertical-align: middle !important;
}

.bottom {
  vertical-align: bottom !important;
}

/* Width Control
----------------------------------------------- */
.w-5 {
  width: 5%;
}

.w-10 {
  width: 10%;
}

.w-15 {
  width: 15%;
}

.w-20 {
  width: 20%;
}

.w-25 {
  width: 25%;
}

.w-30 {
  width: 30%;
}

.w-35 {
  width: 35%;
}

.w-40 {
  width: 40%;
}

.w-45 {
  width: 45%;
}

.w-50 {
  width: 50%;
}

.w-55 {
  width: 55%;
}

.w-60 {
  width: 60%;
}

.w-65 {
  width: 65%;
}

.w-70 {
  width: 70%;
}

.w-75 {
  width: 75%;
}

.w-80 {
  width: 80%;
}

.w-85 {
  width: 85%;
}

.w-90 {
  width: 90%;
}

.w-95 {
  width: 95%;
}

.w-100 {
  width: 100%;
}

/* Margin and Padding Control
----------------------------------------------- */
.mb0 {
  margin-bottom: 0px !important;
}

.mt0 {
  margin-top: 0px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mt40 {
  margin-top: 40px !important;
}

/* Font Control
----------------------------------------------- */
.f10 {
  font-size: 10px;
  font-size: 1rem;
}

.f11 {
  font-size: 11px;
  font-size: 1.1rem;
}

.f12 {
  font-size: 12px;
  font-size: 1.2rem;
}

.f13 {
  font-size: 13px;
  font-size: 1.3rem;
}

.f14 {
  font-size: 14px;
  font-size: 1.4rem;
}

.f15 {
  font-size: 15px;
  font-size: 1.5rem;
}

.f16 {
  font-size: 16px;
  font-size: 1.6rem;
}

.f17 {
  font-size: 17px;
  font-size: 1.7rem;
}

.f18 {
  font-size: 18px;
  font-size: 1.8rem;
}

.f19 {
  font-size: 19px;
  font-size: 1.9rem;
}

.f20 {
  font-size: 20px;
  font-size: 2rem;
}

.f21 {
  font-size: 21px;
  font-size: 2.1rem;
}

.f22 {
  font-size: 22px;
  font-size: 2.2rem;
}

.f23 {
  font-size: 23px;
  font-size: 2.3rem;
}

.f24 {
  font-size: 24px;
  font-size: 2.4rem;
}

.f25 {
  font-size: 25px;
  font-size: 2.5rem;
}

.message_sign img{
	margin-bottom: 20px;
	width: 70%;
	height: auto;
	float: right;
	clear: both;
	}

.trackman {
	float: left;
	margin-right: 15px;
}

.form2 table tr td input.fd61{
  width: 40%;
}

.right_bottom_btn_back {
	text-align: right;
	margin: 60px 0 0 0;
}

.swiper-button-next, .swiper-button-prev {
    top: 30% !important;
    z-index: 10 !important;
    position: absolute !important;
}

.swiper-button-next:after, .swiper-button-prev:after {
    color: #000 !important;
    text-shadow: 0 0 0 #000;
    -webkit-transition: color 0.4s ease, background 0.4s ease, transform 0.4s ease, opacity 0.4s ease, border 0.4s ease, padding 0.4s ease, left 0.4s ease, box-shadow 0.4s ease;
    transition: color 0.4s ease, background 0.4s ease, transform 0.4s ease, opacity 0.4s ease, border 0.4s ease, padding 0.4s ease, left 0.4s ease, box-shadow 0.4s ease;
}



.movie_tit {
	text-decoration: none !important;
}

.swiper-slide22 a {
    text-decoration: none !important;
}

.swiper-slide a {
    text-decoration: none !important;
}

.swiper-slide22 {
    width: 180px!important;
}

.slide_right_arrow {
	float: right;
	margin-right: 10px;
}