@charset "UTF-8";
/*! normalize.css v3.0.1 | MIT License | git.io/normalize */
html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

a {
  background: transparent;
}

a:active,
a:hover {
  outline: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b,
strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 40px;
}

hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 2;
  color: #333333;
  background-color: #fff;
}

input,
button,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

a {
  color: #428bca;
  text-decoration: none;
}

a:hover, a:focus {
  color: #2a6496;
  text-decoration: underline;
}

a:focus {
  outline: thin dotted;
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}

figure {
  margin: 0;
}

img {
  vertical-align: middle;
}

.img-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

.img-rounded {
  border-radius: 6px;
}

.img-thumbnail {
  padding: 4px;
  line-height: 2;
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 4px;
  -webkit-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  display: inline-block;
  max-width: 100%;
  height: auto;
}

.img-circle {
  border-radius: 50%;
}

hr {
  margin-top: 28px;
  margin-bottom: 28px;
  border: 0;
  border-top: 1px solid #eeeeee;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.sr-only-focusable:active, .sr-only-focusable:focus {
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  clip: auto;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: inherit;
  font-weight: 500;
  line-height: 1.1;
  color: inherit;
}

h1 small,
h1 .small, h2 small,
h2 .small, h3 small,
h3 .small, h4 small,
h4 .small, h5 small,
h5 .small, h6 small,
h6 .small,
.h1 small,
.h1 .small, .h2 small,
.h2 .small, .h3 small,
.h3 .small, .h4 small,
.h4 .small, .h5 small,
.h5 .small, .h6 small,
.h6 .small {
  font-weight: normal;
  line-height: 1;
  color: #999999;
}

h1, .h1,
h2, .h2,
h3, .h3 {
  margin-top: 28px;
  margin-bottom: 14px;
}

h1 small,
h1 .small, .h1 small,
.h1 .small,
h2 small,
h2 .small, .h2 small,
.h2 .small,
h3 small,
h3 .small, .h3 small,
.h3 .small {
  font-size: 65%;
}

h4, .h4,
h5, .h5,
h6, .h6 {
  margin-top: 14px;
  margin-bottom: 14px;
}

h4 small,
h4 .small, .h4 small,
.h4 .small,
h5 small,
h5 .small, .h5 small,
.h5 .small,
h6 small,
h6 .small, .h6 small,
.h6 .small {
  font-size: 75%;
}

h1, .h1 {
  font-size: 30px;
}

h2, .h2 {
  font-size: 21px;
}

h3, .h3 {
  font-size: 21px;
}

h4, .h4 {
  font-size: 18px;
}

h5, .h5 {
  font-size: 18px;
}

h6, .h6 {
  font-size: 14px;
}

p {
  margin: 0 0 14px;
}

.lead {
  margin-bottom: 28px;
  font-size: 16px;
  font-weight: 200;
  line-height: 1.4;
}

@media (min-width: 540px) {
  .lead {
    font-size: 21px;
  }
}
small,
.small {
  font-size: 85%;
}

cite {
  font-style: normal;
}

mark,
.mark {
  background-color: #fcf8e3;
  padding: .2em;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.text-center {
  text-align: center;
}

.text-justify {
  text-align: justify;
}

.text-muted {
  color: #999999;
}

.text-primary {
  color: #428bca;
}

a.text-primary:hover {
  color: #3071a9;
}

.text-success {
  color: #3c763d;
}

a.text-success:hover {
  color: #2b542c;
}

.text-info {
  color: #31708f;
}

a.text-info:hover {
  color: #245269;
}

.text-warning {
  color: #8a6d3b;
}

a.text-warning:hover {
  color: #66512c;
}

.text-danger {
  color: #a94442;
}

a.text-danger:hover {
  color: #843534;
}

.bg-primary {
  color: #fff;
}

.bg-primary {
  background-color: #428bca;
}

a.bg-primary:hover {
  background-color: #3071a9;
}

.bg-success {
  background-color: #dff0d8;
}

a.bg-success:hover {
  background-color: #c1e2b3;
}

.bg-info {
  background-color: #d9edf7;
}

a.bg-info:hover {
  background-color: #afd9ee;
}

.bg-warning {
  background-color: #fcf8e3;
}

a.bg-warning:hover {
  background-color: #f7ecb5;
}

.bg-danger {
  background-color: #f2dede;
}

a.bg-danger:hover {
  background-color: #e4b9b9;
}

.page-header {
  padding-bottom: 13px;
  margin: 56px 0 28px;
  border-bottom: 1px solid #eeeeee;
}

ul,
ol {
  margin-top: 0;
  margin-bottom: 14px;
}

ul ul,
ul ol,
ol ul,
ol ol {
  margin-bottom: 0;
}

.list-unstyled, .list-inline {
  padding-left: 0;
  list-style: none;
}

.list-inline {
  margin-left: -5px;
}

.list-inline > li {
  display: inline-block;
  padding-left: 5px;
  padding-right: 5px;
}

dl {
  margin-top: 0;
  margin-bottom: 28px;
}

dt,
dd {
  line-height: 2;
}

dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

.dl-horizontal dd:before, .dl-horizontal dd:after {
  content: " ";
  display: table;
}

.dl-horizontal dd:after {
  clear: both;
}

@media (min-width: 540px) {
  .dl-horizontal dt {
    float: left;
    width: 160px;
    clear: left;
    text-align: right;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .dl-horizontal dd {
    margin-left: 180px;
  }
}
abbr[title],
abbr[data-original-title] {
  cursor: help;
  border-bottom: 1px dotted #999999;
}

.initialism {
  font-size: 90%;
  text-transform: uppercase;
}

blockquote {
  padding: 14px 28px;
  margin: 0 0 28px;
  font-size: 17.5px;
  border-left: 5px solid #eeeeee;
}

blockquote p:last-child,
blockquote ul:last-child,
blockquote ol:last-child {
  margin-bottom: 0;
}

blockquote footer,
blockquote small,
blockquote .small {
  display: block;
  font-size: 80%;
  line-height: 2;
  color: #999999;
}

blockquote footer:before,
blockquote small:before,
blockquote .small:before {
  content: '\2014 \00A0';
}

.blockquote-reverse,
blockquote.pull-right {
  padding-right: 15px;
  padding-left: 0;
  border-right: 5px solid #eeeeee;
  border-left: 0;
  text-align: right;
}

.blockquote-reverse footer:before,
.blockquote-reverse small:before,
.blockquote-reverse .small:before,
blockquote.pull-right footer:before,
blockquote.pull-right small:before,
blockquote.pull-right .small:before {
  content: '';
}

.blockquote-reverse footer:after,
.blockquote-reverse small:after,
.blockquote-reverse .small:after,
blockquote.pull-right footer:after,
blockquote.pull-right small:after,
blockquote.pull-right .small:after {
  content: '\00A0 \2014';
}

blockquote:before,
blockquote:after {
  content: "";
}

address {
  margin-bottom: 28px;
  font-style: normal;
  line-height: 2;
}

.clearfix:before, .row:before, .block-link:before, .block-link-item a:before, .l-global-area:before, .l-global-navi:before, .l-footer-sitemap > ul:before, .l-footer ul.l-utility-navi:before, .l-footer .l-site-data:before, .footer-switcharea ul:before, .l-property-area:before, .l-breadcrumbs-wrap:before, .l-breadcrumbs-wrap .l-breadcrumbs-nav:before, .l-contents:before, .l-contents .l-main:before, .l-contents .l-side:before, .frame-line .line-navi-item a:before, .ban-area:before, .theme-smp .cta-navi:before, ul.text-link-ul-v:before, .asterisk-list:before, .asterisk-s-list:before, .attention-list:before, .text-icon-1em:before, .text-icon-2em:before, .text-icon-3em:before, .text-icon-4em:before, .text-icon-5em:before, .text-icon-6em:before, .text-icon-7em:before, .text-icon-8em:before, .text-icon-9em:before, .text-icon-10em:before, .text-icon-11em:before, .text-icon-12em:before, .clearfix:after, .row:after, .block-link:after, .block-link-item a:after, .l-global-area:after, .l-global-navi:after, .l-footer-sitemap > ul:after, .l-footer ul.l-utility-navi:after, .l-footer .l-site-data:after, .footer-switcharea ul:after, .l-property-area:after, .l-breadcrumbs-wrap:after, .l-breadcrumbs-wrap .l-breadcrumbs-nav:after, .l-contents:after, .l-contents .l-main:after, .l-contents .l-side:after, .frame-line .line-navi-item a:after, .ban-area:after, .theme-smp .cta-navi:after, ul.text-link-ul-v:after, .asterisk-list:after, .asterisk-s-list:after, .attention-list:after, .text-icon-1em:after, .text-icon-2em:after, .text-icon-3em:after, .text-icon-4em:after, .text-icon-5em:after, .text-icon-6em:after, .text-icon-7em:after, .text-icon-8em:after, .text-icon-9em:after, .text-icon-10em:after, .text-icon-11em:after, .text-icon-12em:after {
  content: " ";
  display: table;
}

.clearfix:after, .row:after, .block-link:after, .block-link-item a:after, .l-global-area:after, .l-global-navi:after, .l-footer-sitemap > ul:after, .l-footer ul.l-utility-navi:after, .l-footer .l-site-data:after, .footer-switcharea ul:after, .l-property-area:after, .l-breadcrumbs-wrap:after, .l-breadcrumbs-wrap .l-breadcrumbs-nav:after, .l-contents:after, .l-contents .l-main:after, .l-contents .l-side:after, .frame-line .line-navi-item a:after, .ban-area:after, .theme-smp .cta-navi:after, ul.text-link-ul-v:after, .asterisk-list:after, .asterisk-s-list:after, .attention-list:after, .text-icon-1em:after, .text-icon-2em:after, .text-icon-3em:after, .text-icon-4em:after, .text-icon-5em:after, .text-icon-6em:after, .text-icon-7em:after, .text-icon-8em:after, .text-icon-9em:after, .text-icon-10em:after, .text-icon-11em:after, .text-icon-12em:after {
  clear: both;
}

.center-block {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.pull-right {
  float: right !important;
}

.pull-left {
  float: left !important;
}

.hide {
  display: none !important;
}

.show {
  display: block !important;
}

.invisible {
  visibility: hidden;
}

.text-hide {
  font: 0/0 a;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  border: 0;
}

.hidden {
  display: none !important;
  visibility: hidden !important;
}

.affix {
  position: fixed;
}

@-ms-viewport {
  width: device-width;
}
.visible-xs, .visible-sm, .visible-md, .visible-lg {
  display: none !important;
}

.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
  display: none !important;
}

@media (max-width: 539px) {
  .visible-xs {
    display: block !important;
  }

  table.visible-xs {
    display: table;
  }

  tr.visible-xs {
    display: table-row !important;
  }

  th.visible-xs,
  td.visible-xs {
    display: table-cell !important;
  }
}
@media (max-width: 539px) {
  .visible-xs-block {
    display: block !important;
  }
}
@media (max-width: 539px) {
  .visible-xs-inline {
    display: inline !important;
  }
}
@media (max-width: 539px) {
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 540px) and (max-width: 739px) {
  .visible-sm {
    display: block !important;
  }

  table.visible-sm {
    display: table;
  }

  tr.visible-sm {
    display: table-row !important;
  }

  th.visible-sm,
  td.visible-sm {
    display: table-cell !important;
  }
}
@media (min-width: 540px) and (max-width: 739px) {
  .visible-sm-block {
    display: block !important;
  }
}
@media (min-width: 540px) and (max-width: 739px) {
  .visible-sm-inline {
    display: inline !important;
  }
}
@media (min-width: 540px) and (max-width: 739px) {
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 740px) and (max-width: 999px) {
  .visible-md {
    display: block !important;
  }

  table.visible-md {
    display: table;
  }

  tr.visible-md {
    display: table-row !important;
  }

  th.visible-md,
  td.visible-md {
    display: table-cell !important;
  }
}
@media (min-width: 740px) and (max-width: 999px) {
  .visible-md-block {
    display: block !important;
  }
}
@media (min-width: 740px) and (max-width: 999px) {
  .visible-md-inline {
    display: inline !important;
  }
}
@media (min-width: 740px) and (max-width: 999px) {
  .visible-md-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1000px) {
  .visible-lg {
    display: block !important;
  }

  table.visible-lg {
    display: table;
  }

  tr.visible-lg {
    display: table-row !important;
  }

  th.visible-lg,
  td.visible-lg {
    display: table-cell !important;
  }
}
@media (min-width: 1000px) {
  .visible-lg-block {
    display: block !important;
  }
}
@media (min-width: 1000px) {
  .visible-lg-inline {
    display: inline !important;
  }
}
@media (min-width: 1000px) {
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}
@media (max-width: 539px) {
  .hidden-xs {
    display: none !important;
  }
}
@media (min-width: 540px) and (max-width: 739px) {
  .hidden-sm {
    display: none !important;
  }
}
@media (min-width: 740px) and (max-width: 999px) {
  .hidden-md {
    display: none !important;
  }
}
@media (min-width: 1000px) {
  .hidden-lg {
    display: none !important;
  }
}
.visible-print {
  display: none !important;
}

@media print {
  .visible-print {
    display: block !important;
  }

  table.visible-print {
    display: table;
  }

  tr.visible-print {
    display: table-row !important;
  }

  th.visible-print,
  td.visible-print {
    display: table-cell !important;
  }
}
.visible-print-block {
  display: none !important;
}

@media print {
  .visible-print-block {
    display: block !important;
  }
}
.visible-print-inline {
  display: none !important;
}

@media print {
  .visible-print-inline {
    display: inline !important;
  }
}
.visible-print-inline-block {
  display: none !important;
}

@media print {
  .visible-print-inline-block {
    display: inline-block !important;
  }
}
@media print {
  .hidden-print {
    display: none !important;
  }
}
.icon-answer:before {
  content: url(../images/layout/icon_answer.png);
}

.icon-arrow-bottom:before {
  content: url(../images/layout/icon_arrow_bottom_r.png);
}

.icon-arrow-left:before {
  content: url(../images/layout/icon_arrow_left_r.png);
}

.icon-arrow-right:before {
  content: url(../images/layout/icon_arrow_right_r.png);
}

.icon-arrow-top:before {
  content: url(../images/layout/icon_arrow_top_r.png);
}

.icon-download:before {
  content: url(../images/layout/icon_download.png);
}

.icon-openwindow:before {
  content: url(../images/layout/icon_owr.png);
}

.icon-question:before {
  content: url(../images/layout/icon_question.png);
}

.icon-question-small:before {
  content: url(../images/layout/icon_question_small.png);
}

.icon-rss:before {
  content: url(../images/layout/icon_rss.png);
}

.icon-print:before {
  content: url(../images/layout/icon_print.png);
}

.text-link:before, .theme-smp .l-footer ul.l-utility-navi li:before, .l-local-navi li a:before, .frame-line .line-navi-item .line-navi-text:before, .stock-quotation .chart-link a:before, h2.title-link:before, ul.text-link-ul li:before, ul.text-link-ul-v li:before, .flat-btn:before, .more-btn:before, .block-link-item a:before, .frame-line .line-navi-item a[target="_blank"] .line-navi-text:after {
  display: inline;
}

/*base*/
/*color*/
/*link_color*/
/*font-size*/
/*line-height*/
/*box-shadow*/
/*border-radius*/
/*link-color*/
.row, .block-link {
  margin-left: -10px;
  margin-right: -10px;
}

a {
  color: #224488;
}

a:hover, a:active, a:focus {
  color: #4170cf;
}

.flat-btn, .more-btn, .block-link-item a, .l-global-navi li a,
.l-global-navi li a:hover,
.l-global-navi li a:active,
.l-global-navi li a:visited, .l-footer-sitemap a,
.l-footer-sitemap a:hover,
.l-footer-sitemap a:active,
.l-footer-sitemap a:visited {
  text-decoration: none;
}

.flat-btn:hover, .more-btn:hover, .block-link-item a:hover, .l-global-navi li a:hover, .l-footer-sitemap a:hover {
  text-decoration: none;
}

.l-global-area, .l-global-navi, .l-footer-sitemap > ul, .l-footer ul.l-utility-navi, .l-footer .l-site-data, .l-branding-head, .l-property-area {
  width: 990px;
  margin: 0 auto;
}

.theme-smp .l-global-area, .theme-smp .l-global-navi, .theme-smp .l-footer-sitemap > ul, .theme-smp .l-footer ul.l-utility-navi, .l-footer .theme-smp ul.l-utility-navi, .theme-smp .l-footer .l-site-data, .l-footer .theme-smp .l-site-data, .theme-smp .l-branding-head, .theme-smp .l-property-area {
  width: 100%;
  min-width: 320px;
}

.theme-popup .l-global-area, .theme-popup .l-global-navi, .theme-popup .l-footer-sitemap > ul, .theme-popup .l-footer ul.l-utility-navi, .l-footer .theme-popup ul.l-utility-navi, .theme-popup .l-footer .l-site-data, .l-footer .theme-popup .l-site-data, .theme-popup .l-branding-head, .theme-popup .l-property-area {
  width: 736px;
}

.l-pagetop p, .l-breadcrumbs-wrap {
  width: 990px;
  margin: 0 auto;
}

/*arrow link*/
.text-link, .theme-smp .l-footer ul.l-utility-navi li, .l-local-navi li a, .frame-line .line-navi-item .line-navi-text, .stock-quotation .chart-link a, h2.title-link, ul.text-link-ul li, ul.text-link-ul-v li {
  list-style: none;
}

.text-link:before, .theme-smp .l-footer ul.l-utility-navi li:before, .l-local-navi li a:before, .frame-line .line-navi-item .line-navi-text:before, .stock-quotation .chart-link a:before, h2.title-link:before, ul.text-link-ul li:before, ul.text-link-ul-v li:before {
  position: relative;
  display: inline-block;
  content: url(../images/layout/icon_arrow_right_r.png);
  font-size: 16px;
  color: #cc0022;
  margin-left: -3px;
  text-decoration: none !important;
}

.text-link:before {
  /*ie8fix*/
  font-family: 'sompoicon';
  line-height: 1;
}

.clearfix, .row, .block-link, .block-link-item a, .l-global-area, .l-global-navi, .l-footer-sitemap > ul, .l-footer ul.l-utility-navi, .l-footer .l-site-data, .footer-switcharea ul, .l-property-area, .l-breadcrumbs-wrap, .l-breadcrumbs-wrap .l-breadcrumbs-nav, .l-contents, .l-contents .l-main, .l-contents .l-side, .frame-line .line-navi-item a, .ban-area, .theme-smp .cta-navi, ul.text-link-ul-v, .asterisk-list, .asterisk-s-list, .attention-list, .text-icon-1em, .text-icon-2em, .text-icon-3em, .text-icon-4em, .text-icon-5em, .text-icon-6em, .text-icon-7em, .text-icon-8em, .text-icon-9em, .text-icon-10em, .text-icon-11em, .text-icon-12em {
  *zoom: 1;
}

.clearfix:after, .row:after, .block-link:after, .block-link-item a:after, .l-global-area:after, .l-global-navi:after, .l-footer-sitemap > ul:after, .l-footer ul.l-utility-navi:after, .l-footer .l-site-data:after, .footer-switcharea ul:after, .l-property-area:after, .l-breadcrumbs-wrap:after, .l-breadcrumbs-wrap .l-breadcrumbs-nav:after, .l-contents:after, .l-contents .l-main:after, .l-contents .l-side:after, .frame-line .line-navi-item a:after, .ban-area:after, .theme-smp .cta-navi:after, ul.text-link-ul-v:after, .asterisk-list:after, .asterisk-s-list:after, .attention-list:after, .text-icon-1em:after, .text-icon-2em:after, .text-icon-3em:after, .text-icon-4em:after, .text-icon-5em:after, .text-icon-6em:after, .text-icon-7em:after, .text-icon-8em:after, .text-icon-9em:after, .text-icon-10em:after, .text-icon-11em:after, .text-icon-12em:after {
  content: "\0020";
  display: block;
  height: 0;
  clear: both;
  overflow: hidden;
  visibility: hidden;
}

/*hover effect*/
/*animation*/
/*button*/
.flat-btn {
  display: block;
  background: #eeeeee;
  position: relative;
  border-right: 2px solid #d6d6d6;
  border-bottom: 2px solid #d6d6d6;
  padding: 15px 15px 15px 30px;
  line-height: 1.2em;
  font-weight: bold;
  color: #333;
  font-size: 15px;
}

.flat-btn:before {
  position: absolute;
  display: block;
  width: 1em;
  height: 1em;
  text-align: center;
  content: url(../images/layout/icon_arrow_right_r.png);
  font-size: 15px;
  left: 8px;
  top: 50%;
  margin-top: -8px;
  color: #cc0022;
  line-height: 1.2em;
}

.fxb-block-channel .flat-btn:before {
  top: 16px;
  margin-top: 0;
}

.flat-btn:hover, .flat-btn:active, .flat-btn:focus {
  background: #d6d6d6;
  color: #333;
  border-color-right: #c1c1c1;
  border-color-bottom: #c1c1c1;
}

.flat-btn:visited {
  color: #333;
}

.flat-btn.float-right {
  margin: 0 0 0 10px;
}

.flat-btn.float-left {
  margin: 0 10px 0 0;
}

.btn-inline {
  display: inline-block;
  padding: 8px 8px 8px 25px;
  font-size: 14px;
  font-weight: normal;
  border-right-width: 1px;
  border-bottom-width: 1px;
}

.btn-small {
  padding: 8px 8px 8px 25px;
  font-size: 12px;
  font-weight: normal;
  border-right-width: 1px;
  border-bottom-width: 1px;
}

.btn-dark {
  background: #666;
  border-right: 2px solid #525252;
  border-bottom: 2px solid #525252;
  color: #fff;
}

.btn-dark:before {
  content: url(../images/layout/icon_arrow_right_c.png);
}

.btn-dark:hover, .btn-dark:active, .btn-dark:visited, .btn-dark:focus {
  background: #5c5c5c;
  text-decoration: none;
  color: #fff;
  border-color-right: #4a4a4a;
  border-color-bottom: #4a4a4a;
}

.btn-anchor:before {
  content: url(../images/layout/icon_arrow_bottom_r.png);
}

.btn-anchor.btn-dark:before {
  content: url(../images/layout/icon_arrow_bottom_c.png);
}

.btn-fit {
  width: 100%;
}

.btn-msize {
  width: 50%;
}

.btn-lsize {
  width: 100%;
}

.btn-rss {
  background: #fe9900;
  border-right: 1px solid #e58900;
  width: 33px;
  height: 33px;
  padding: 0;
}

.btn-rss:hover {
  background: #cb7a00;
}

.btn-rss:before {
  content: url(../images/layout/icon_rss.png);
  left: 6px;
  top: 14px;
}

.btn-rss span {
  display: block;
  overflow: hidden;
  text-indent: -999px;
}

.more-btn {
  color: #9f9f9f;
  position: absolute;
  width: 5em;
  right: 0;
  top: 15px;
  font-size: 11px;
  font-weight: normal;
}

.more-btn:before {
  content: "\e607";
  font-size: 10px;
  padding: 0 5px;
  /*ie8fix*/
  font-family: 'sompoicon';
  line-height: 1;
}

.more-btn:hover {
  color: #e0667a;
}

.block-link {
  margin-top: 30px;
  margin-bottom: 30px;
}

.block-link-item a {
  position: relative;
  margin: -10px;
  padding: 10px;
  display: block;
  color: #333;
}

.block-link-item a:hover {
  color: #333;
  background: #f7d9de;
}

.block-link-item a:before {
  position: absolute;
  display: block;
  width: 1em;
  height: 1em;
  text-align: center;
  content: "\e607";
  font-size: 10px;
  right: 10px;
  bottom: 10px;
  color: #cc0022;
  /*ie8fix*/
  font-family: 'sompoicon';
  line-height: 1;
}

.block-link-item a .image-wrap img {
  width: 100%;
}

.frame-red-bold, .frame-red, .frame-glay-bold, .frame-glay, .frame-titlebox .frame-titlebox-contents {
  padding: 10px 0;
  margin-bottom: 20px;
}

.frame-red-bold *:last-child, .frame-red *:last-child, .frame-glay-bold *:last-child, .frame-glay *:last-child, .frame-titlebox .frame-titlebox-contents *:last-child {
  margin-bottom: 0;
}

.frame-red-bold {
  border: 2px solid #cc0022;
}

.frame-red {
  border: 1px solid #cc0022;
}

.frame-glay-bold {
  border: 2px solid #777;
}

.frame-glay {
  border: 1px solid #777;
}

.frame-titlebox .frame-titlebox-title {
  background: #e6e6e6;
  padding: 10px;
  margin: 0;
}

.frame-titlebox .frame-titlebox-title .btn-inline {
  padding: 6px 8px 6px 25px;
  margin: -2px;
}

.frame-titlebox .frame-titlebox-contents {
  border: 2px solid #e6e6e6;
  border-top: 0px;
  margin-bottom: 30px;
}

.theme-smp .frame-titlebox .frame-titlebox-contents {
  margin-bottom: 35px;
}

/*font-size*/
.text-size-10 {
  font-size: 10px !important;
}

.text-size-11 {
  font-size: 11px !important;
}

.text-size-12 {
  font-size: 12px !important;
}

.text-size-13 {
  font-size: 13px !important;
}

.text-size-14 {
  font-size: 14px !important;
}

.text-size-15 {
  font-size: 15px !important;
}

.text-size-16 {
  font-size: 16px !important;
}

.text-size-17 {
  font-size: 17px !important;
}

.text-size-18 {
  font-size: 18px !important;
}

.text-size-19 {
  font-size: 19px !important;
}

.text-size-20 {
  font-size: 20px !important;
}

.text-size-21 {
  font-size: 21px !important;
}

.text-size-22 {
  font-size: 22px !important;
}

.text-size-23 {
  font-size: 23px !important;
}

/*margin*/
.margin-all0 {
  margin: 0px !important;
}

.margin-allm0 {
  margin: -0px !important;
}

.margin-top0 {
  margin-top: 0px !important;
}

.margin-topm0 {
  margin-top: -0px !important;
}

.margin-bottom0 {
  margin-bottom: 0px !important;
}

.margin-bottomm0 {
  margin-bottom: -0px !important;
}

.margin-right0 {
  margin-right: 0px !important;
}

.margin-rightm0 {
  margin-right: -0px !important;
}

.margin-left0 {
  margin-left: 0px !important;
}

.margin-leftm0 {
  margin-left: -0px !important;
}

.margin-all10 {
  margin: 10px !important;
}

.margin-allm10 {
  margin: -10px !important;
}

.margin-top10 {
  margin-top: 10px !important;
}

.margin-topm10 {
  margin-top: -10px !important;
}

.margin-bottom10 {
  margin-bottom: 10px !important;
}

.margin-bottomm10 {
  margin-bottom: -10px !important;
}

.margin-right10 {
  margin-right: 10px !important;
}

.margin-rightm10 {
  margin-right: -10px !important;
}

.margin-left10 {
  margin-left: 10px !important;
}

.margin-leftm10 {
  margin-left: -10px !important;
}

.margin-all20 {
  margin: 20px !important;
}

.margin-allm20 {
  margin: -20px !important;
}

.margin-top20 {
  margin-top: 20px !important;
}

.margin-topm20 {
  margin-top: -20px !important;
}

.margin-bottom20 {
  margin-bottom: 20px !important;
}

.margin-bottomm20 {
  margin-bottom: -20px !important;
}

.margin-right20 {
  margin-right: 20px !important;
}

.margin-rightm20 {
  margin-right: -20px !important;
}

.margin-left20 {
  margin-left: 20px !important;
}

.margin-leftm20 {
  margin-left: -20px !important;
}

.margin-all30 {
  margin: 30px !important;
}

.margin-allm30 {
  margin: -30px !important;
}

.margin-top30 {
  margin-top: 30px !important;
}

.margin-topm30 {
  margin-top: -30px !important;
}

.margin-bottom30 {
  margin-bottom: 30px !important;
}

.margin-bottomm30 {
  margin-bottom: -30px !important;
}

.margin-right30 {
  margin-right: 30px !important;
}

.margin-rightm30 {
  margin-right: -30px !important;
}

.margin-left30 {
  margin-left: 30px !important;
}

.margin-leftm30 {
  margin-left: -30px !important;
}

.margin-all40 {
  margin: 40px !important;
}

.margin-allm40 {
  margin: -40px !important;
}

.margin-top40 {
  margin-top: 40px !important;
}

.margin-topm40 {
  margin-top: -40px !important;
}

.margin-bottom40 {
  margin-bottom: 40px !important;
}

.margin-bottomm40 {
  margin-bottom: -40px !important;
}

.margin-right40 {
  margin-right: 40px !important;
}

.margin-rightm40 {
  margin-right: -40px !important;
}

.margin-left40 {
  margin-left: 40px !important;
}

.margin-leftm40 {
  margin-left: -40px !important;
}

.margin-all50 {
  margin: 50px !important;
}

.margin-allm50 {
  margin: -50px !important;
}

.margin-top50 {
  margin-top: 50px !important;
}

.margin-topm50 {
  margin-top: -50px !important;
}

.margin-bottom50 {
  margin-bottom: 50px !important;
}

.margin-bottomm50 {
  margin-bottom: -50px !important;
}

.margin-right50 {
  margin-right: 50px !important;
}

.margin-rightm50 {
  margin-right: -50px !important;
}

.margin-left50 {
  margin-left: 50px !important;
}

.margin-leftm50 {
  margin-left: -50px !important;
}

.margin-all5 {
  margin: 5px !important;
}

.margin-allm5 {
  margin: -5px !important;
}

.margin-top5 {
  margin-top: 5px !important;
}

.margin-topm5 {
  margin-top: -5px !important;
}

.margin-bottom5 {
  margin-bottom: 5px !important;
}

.margin-bottomm5 {
  margin-bottom: -5px !important;
}

.margin-right5 {
  margin-right: 5px !important;
}

.margin-rightm5 {
  margin-right: -5px !important;
}

.margin-left5 {
  margin-left: 5px !important;
}

.margin-leftm5 {
  margin-left: -5px !important;
}

.margin-all15 {
  margin: 15px !important;
}

.margin-allm15 {
  margin: -15px !important;
}

.margin-top15 {
  margin-top: 15px !important;
}

.margin-topm15 {
  margin-top: -15px !important;
}

.margin-bottom15 {
  margin-bottom: 15px !important;
}

.margin-bottomm15 {
  margin-bottom: -15px !important;
}

.margin-right15 {
  margin-right: 15px !important;
}

.margin-rightm15 {
  margin-right: -15px !important;
}

.margin-left15 {
  margin-left: 15px !important;
}

.margin-leftm15 {
  margin-left: -15px !important;
}

.margin-all25 {
  margin: 25px !important;
}

.margin-allm25 {
  margin: -25px !important;
}

.margin-top25 {
  margin-top: 25px !important;
}

.margin-topm25 {
  margin-top: -25px !important;
}

.margin-bottom25 {
  margin-bottom: 25px !important;
}

.margin-bottomm25 {
  margin-bottom: -25px !important;
}

.margin-right25 {
  margin-right: 25px !important;
}

.margin-rightm25 {
  margin-right: -25px !important;
}

.margin-left25 {
  margin-left: 25px !important;
}

.margin-leftm25 {
  margin-left: -25px !important;
}

.margin-all35 {
  margin: 35px !important;
}

.margin-allm35 {
  margin: -35px !important;
}

.margin-top35 {
  margin-top: 35px !important;
}

.margin-topm35 {
  margin-top: -35px !important;
}

.margin-bottom35 {
  margin-bottom: 35px !important;
}

.margin-bottomm35 {
  margin-bottom: -35px !important;
}

.margin-right35 {
  margin-right: 35px !important;
}

.margin-rightm35 {
  margin-right: -35px !important;
}

.margin-left35 {
  margin-left: 35px !important;
}

.margin-leftm35 {
  margin-left: -35px !important;
}

.margin-all45 {
  margin: 45px !important;
}

.margin-allm45 {
  margin: -45px !important;
}

.margin-top45 {
  margin-top: 45px !important;
}

.margin-topm45 {
  margin-top: -45px !important;
}

.margin-bottom45 {
  margin-bottom: 45px !important;
}

.margin-bottomm45 {
  margin-bottom: -45px !important;
}

.margin-right45 {
  margin-right: 45px !important;
}

.margin-rightm45 {
  margin-right: -45px !important;
}

.margin-left45 {
  margin-left: 45px !important;
}

.margin-leftm45 {
  margin-left: -45px !important;
}

.margin-all55 {
  margin: 55px !important;
}

.margin-allm55 {
  margin: -55px !important;
}

.margin-top55 {
  margin-top: 55px !important;
}

.margin-topm55 {
  margin-top: -55px !important;
}

.margin-bottom55 {
  margin-bottom: 55px !important;
}

.margin-bottomm55 {
  margin-bottom: -55px !important;
}

.margin-right55 {
  margin-right: 55px !important;
}

.margin-rightm55 {
  margin-right: -55px !important;
}

.margin-left55 {
  margin-left: 55px !important;
}

.margin-leftm55 {
  margin-left: -55px !important;
}

.margin-bottom35 {
  margin-bottom: 35px !important;
}

.padding-all0 {
  padding: 0px !important;
}

.padding-top0 {
  padding-top: 0px !important;
}

.padding-bottom0 {
  padding-bottom: 0px !important;
}

.padding-right0 {
  padding-right: 0px !important;
}

.padding-left0 {
  padding-left: 0px !important;
}

.padding-all10 {
  padding: 10px !important;
}

.padding-top10 {
  padding-top: 10px !important;
}

.padding-bottom10 {
  padding-bottom: 10px !important;
}

.padding-right10 {
  padding-right: 10px !important;
}

.padding-left10 {
  padding-left: 10px !important;
}

.padding-all20 {
  padding: 20px !important;
}

.padding-top20 {
  padding-top: 20px !important;
}

.padding-bottom20 {
  padding-bottom: 20px !important;
}

.padding-right20 {
  padding-right: 20px !important;
}

.padding-left20 {
  padding-left: 20px !important;
}

.padding-all30 {
  padding: 30px !important;
}

.padding-top30 {
  padding-top: 30px !important;
}

.padding-bottom30 {
  padding-bottom: 30px !important;
}

.padding-right30 {
  padding-right: 30px !important;
}

.padding-left30 {
  padding-left: 30px !important;
}

.padding-all40 {
  padding: 40px !important;
}

.padding-top40 {
  padding-top: 40px !important;
}

.padding-bottom40 {
  padding-bottom: 40px !important;
}

.padding-right40 {
  padding-right: 40px !important;
}

.padding-left40 {
  padding-left: 40px !important;
}

.padding-all50 {
  padding: 50px !important;
}

.padding-top50 {
  padding-top: 50px !important;
}

.padding-bottom50 {
  padding-bottom: 50px !important;
}

.padding-right50 {
  padding-right: 50px !important;
}

.padding-left50 {
  padding-left: 50px !important;
}

.padding-all5 {
  padding: 5px !important;
}

.padding-top5 {
  padding-top: 5px !important;
}

.padding-bottom5 {
  padding-bottom: 5px !important;
}

.padding-right5 {
  padding-right: 5px !important;
}

.padding-left5 {
  padding-left: 5px !important;
}

.padding-all15 {
  padding: 15px !important;
}

.padding-top15 {
  padding-top: 15px !important;
}

.padding-bottom15 {
  padding-bottom: 15px !important;
}

.padding-right15 {
  padding-right: 15px !important;
}

.padding-left15 {
  padding-left: 15px !important;
}

.padding-all25 {
  padding: 25px !important;
}

.padding-top25 {
  padding-top: 25px !important;
}

.padding-bottom25 {
  padding-bottom: 25px !important;
}

.padding-right25 {
  padding-right: 25px !important;
}

.padding-left25 {
  padding-left: 25px !important;
}

.padding-all35 {
  padding: 35px !important;
}

.padding-top35 {
  padding-top: 35px !important;
}

.padding-bottom35 {
  padding-bottom: 35px !important;
}

.padding-right35 {
  padding-right: 35px !important;
}

.padding-left35 {
  padding-left: 35px !important;
}

.padding-all45 {
  padding: 45px !important;
}

.padding-top45 {
  padding-top: 45px !important;
}

.padding-bottom45 {
  padding-bottom: 45px !important;
}

.padding-right45 {
  padding-right: 45px !important;
}

.padding-left45 {
  padding-left: 45px !important;
}

.padding-all55 {
  padding: 55px !important;
}

.padding-top55 {
  padding-top: 55px !important;
}

.padding-bottom55 {
  padding-bottom: 55px !important;
}

.padding-right55 {
  padding-right: 55px !important;
}

.padding-left55 {
  padding-left: 55px !important;
}

/*accordion*/
.ac-section {
  border-top: 1px solid #e5e5e5;
}

.ac-section h2 {
  margin: 20px auto;
  padding: 0 0 0 70px;
}

.ac-btn {
  margin: 0 auto;
  width: 100%;
  max-width: 1200px;
  background-size: 30px 30px;
  border-bottom: 0px;
  font-size: 1.8em;
}

.ac-btn:before {
  display: none;
}

.active .ac-btn {
  background-size: 30px 30px;
}

.ac-area {
  display: none;
  margin: 0 auto 50px;
  width: 100%;
  max-width: 1200px;
  padding: 0 5%;
}

.active .ac-area {
  display: block;
}

/*link*/
a {
  color: #6666AA;
  text-decoration: none;
}

a:visited {
  color: #6666AA;
}

a:hover {
  color: #444488;
  text-decoration: underline;
}

a:active {
  color: #444488;
}

body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Arial, sans-serif;
  color: #222;
  -webkit-text-size-adjust: 100%;
  vertical-align: bottom;
  zoom: 1;
}

body.theme-en {
  font-family: "Helvetica Neue", "Helvetica", Arial, sans-serif !important;
}

.fontS {
  font-size: 12px;
}

.fontM {
  font-size: 14px;
}

.fontL {
  font-size: 16px;
}

html {
  overflow-y: scroll;
  word-wrap: break-word;
}

img {
  max-width: 100%;
}

.theme-smp img {
  max-width: 100%;
}

.theme-smp .l-main img {
  height: auto !important;
}

.blockSkip {
  position: relative;
  top: -48px;
  display: block;
  text-align: center;
  background-color: #fbf1f2;
  padding: 8px;
  margin-bottom: -48px;
  width: 100%;
  height: 48px;
}

.blockSkip:focus {
  top: 0;
  margin-bottom: 0;
}

.blockSkip::before {
  content: '';
  width: 15px;
  height: 15px;
  margin-right: 8px;
  display: inline-block;
  background: url(../images/layout/icon_arrow_bottom_r.png) center no-repeat;
}

@media (max-width: 600px) {
  .blockSkip {
    display: none;
  }
}
/*header*/
.l-header {
  position: relative;
  background: #ffffff;
}

.theme-smp .l-header {
  width: auto;
  min-width: 320px;
  height: 65px;
  margin: 0;
  position: relative;
  z-index: 10;
  /* background: url(../images/layout/header_arc_bg_center_m.png) no-repeat bottom left; */
  background-size: 1000px 8px;
}

.theme-smp .l-header:before {
  background-color: #cc0022;
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
}

/* @media (min-width: 960px) and (max-width: 2400px) {
  .theme-smp .l-header:before {
    width: 30%;
  }
}
@media (min-width: 2401px) and (max-width: 4000px) {
  .theme-smp .l-header:before {
    width: 40%;
  }
} */
.theme-smp .l-header:after {
  /* background: url(../images/layout/header_arc_bg_right_m.png) repeat-x bottom center; */
  background-size: 1px 8px;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
}

/* @media (min-width: 1001px) and (max-width: 1500px) {
  .theme-smp .l-header:after {
    width: 40%;
  }
}
@media (min-width: 1501px) and (max-width: 2000px) {
  .theme-smp .l-header:after {
    width: 60%;
  }
}
@media (min-width: 600px) {
  .theme-smp .l-header {
    height: 70px;
  }
}
@media (min-width: 600px) {
  .l-header #headerwrapper {
    height: 70px;
  }
} */
.panelBK {
  position: fixed;
  z-index: 9;
  height: 100%;
  width: 100%;
  background: #000;
  opacity: 0.2;
  filter: alpha(opacity=20);
  -moz-opacity: 0.20;
  display: none;
  top: 0;
}

/*global-navi*/
.l-global-area-warp {
  height: 82px;
  position: relative;
}

.l-global-area-warp:before {
  background-color: #cc0022;
  content: "";
  display: block;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
}

.l-global-area-warp:after {
  /* background: url(../images/layout/header_arc_bg_right.png) repeat-x center bottom; */
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
}

@media (min-width: 960px) and (max-width: 2000px) {
  .l-global-area-warp:after {
    width: 32%;
  }
}
@media (min-width: 2001px) and (max-width: 3500px) {
  .l-global-area-warp:after {
    width: 38%;
  }
}
@media (min-width: 3501px) and (max-width: 4000px) {
  .l-global-area-warp:after {
    width: 40%;
  }
}
.theme-popup .l-global-area-warp {
  height: 82px;
}

.theme-popup .l-global-area-warp:after {
  /* background: url(../images/layout/header_arc_bg_right_736.png) repeat-x center bottom; */
}

@media (min-width: 736px) and (max-width: 930px) {
  .theme-popup .l-global-area-warp:after {
    width: 10%;
  }
}
@media (min-width: 931px) and (max-width: 1240px) {
  .theme-popup .l-global-area-warp:after {
    width: 20%;
  }
}
@media (min-width: 1241px) and (max-width: 1500px) {
  .theme-popup .l-global-area-warp:after {
    width: 26%;
  }
}
/* .theme-popup.theme-990w .l-global-area-warp:after {
  background: url(../images/layout/header_arc_bg_right.png) repeat-x center bottom;
} */
/* .l-global-area {
  margin: 0 auto;
  position: relative;
  height: 82px;
  background: url(../images/layout/header_arc_bg_center.png) no-repeat center bottom;
  z-index: 2;
  background-size: 990px 16px;
} */
.theme-smp .l-global-area {
  background: #fff;
}

/* .theme-popup .l-global-area {
  height: 58px;
  background: url(../images/layout/header_arc_bg_center_736.png) repeat-x center bottom;
  background-size: 736px 16px;
} */
.logo-area {
  margin: 0;
  width: 170px;
  position: absolute;
  left: 20px;
  top: 50%;
  height: 38px;
  transform: translateY(-50%);
}

.theme-smp .logo-area {
  /* position: relative;
  top: 7px;
  left: 10px;
  width: 185px;
  z-index: 21; */
  margin: 0 auto;
  position: relative;
  height: 65px;
  z-index: 21;
  left: 0;
  transform: none;
}

.theme-smp .logo-area .l-logo a img:first-child {
  display: block;
  width: 113px;
  height: 26px;
  position: relative;
  top: 2px;
}

.theme-smp .logo-area .l-logo a img:last-child {
  display: block;
  width: 180px;
  height: 28px;
  position: relative;
  right: 0;
  bottom: 1px;
}

/* .theme-smp .logo-area .l-logo a img:last-child {
  display: block;
  width: 180px;
  height: 28px;
  position: relative;
  right: -5px;
  bottom: 1px;
} */
/* .theme-en .logo-area {
  margin: 0;
  width: 275px;
  position: absolute;
  left: 20px;
  top: 14px;
  height: 48px;
} */
/* @media (min-width: 600px) {
  .theme-smp .logo-area {
    top: 10px;
    width: 260px;
  }
} */
/* .theme-en .logo-area {
  top: 7px;
} */
/* .theme-en.theme-popup .logo-area {
  top: 7px;
  width: 197px;
} */
.theme-popup .logo-area {
  margin: 0;
  width: 170px;
  position: absolute;
  left: 20px;
  /* top: 50%; */
  transform: translateY(-50%);
  /* top: calc(50% + 5px); */
}

.logo-area h1 {
  margin: 0;
}

p.btn-pc {
  border: none;
  width: 52px;
  height: 46px;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  position: absolute;
  right: 52px;
  top: 0;
  text-indent: -9999px;
  background: url(../images/layout/mobile_btn_pc.png) no-repeat center center;
  background-size: 52px 46px;
  margin: 0;
}

@media (min-width: 600px) {
  p.btn-pc {
    width: 70px;
    height: 62px;
    right: 70px;
    background-size: 70px 62px;
  }
}
.theme-en p.btn-pc {
  background: url(../images/layout/mobile_btn_pc_en.png) no-repeat center center;
  background-size: 52px 46px;
}

@media (min-width: 600px) {
  .theme-en p.btn-pc {
    background-size: 70px 62px;
  }
}
p.btn-pc a {
  display: block;
  width: 52px;
  height: 46px;
}

@media (min-width: 600px) {
  p.btn-pc a {
    width: 70px;
    height: 62px;
  }
}
.dl-trigger {
  border: none;
  width: 52px;
  height: 46px;
  background: url(../images/layout/mobile_btn_menu.png) no-repeat 0px 0px;
  background-size: 52px 46px;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  position: absolute;
  right: 0;
  top: 10px;
  margin: 0;
}

@media (min-width: 600px) {
  .theme-pc .dl-trigger {
    /* width: 70px; */
    height: 62px;
    /* background-size: 70px 62px; */
  }
}
.theme-en .dl-trigger {
  background: url(../images/layout/mobile_btn_menu_en.png) no-repeat 0px 0px;
  background-size: 52px 46px;
}

@media (min-width: 600px) {
  .theme-pc.theme-en .dl-trigger {
    background-size: 70px 62px;
  }
}
.dl-trigger.close {
  background: url(../images/layout/mobile_btn_close.png) no-repeat 0px 0px;
  background-size: 52px 46px;
}

@media (min-width: 600px) {
  .theme-pc.dl-trigger.close {
    background-size: 70px 62px;
  }
}
.theme-en .dl-trigger.close {
  background: url(../images/layout/mobile_btn_close_en.png) no-repeat 0px 0px;
  background-size: 52px 46px;
}

@media (min-width: 600px) {
  .theme-pc.theme-en .dl-trigger.close {
    background-size: 70px 62px;
  }
}
.dl-trigger a {
  display: block;
  width: 52px;
  height: 46px;
}

@media (min-width: 600px) {
  .theme-pc .dl-trigger a {
    width: 70px;
    height: 62px;
  }
}
p.btn_close {
  border: none;
  width: 52px;
  height: 46px;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  position: absolute;
  right: 0;
  top: 0;
}

p.btn_close img {
  width: 52px;
  height: 46px;
}

.theme-smp .dl-menuwrapper div.dl-menu {
  margin: 5px 5px 10px;
  position: absolute;
  background: #fff;
  width: 97%;
  display: none;
  z-index: 10;
  border-radius: 3px;
  -webkit-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
  -ms-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
}

.theme-smp .dl-menuwrapper div.dl-menu:after {
  content: ' ';
  height: 0;
  position: absolute;
  width: 0;
  border: 10px solid transparent;
  border-bottom-color: #fff;
  bottom: 100%;
  right: 8px;
}

.theme-smp .dl-menuwrapper div.dl-menu a:hover {
  text-decoration: none;
  color: #333;
}

.l-global-navi {
  position: relative;
  margin: 0 auto;
  padding: 0;
}

.theme-smp .l-global-navi {
  width: 100%;
  min-width: 300px;
  border-radius: 3px 3px 0 0;
}

.l-global-navi li {
  float: left;
  width: 165px;
  position: relative;
  list-style: none;
  text-align: center;
}

.theme-smp .l-global-navi li {
  margin: 0;
}

.l-global-navi li a,
.l-global-navi li a:hover,
.l-global-navi li a:active,
.l-global-navi li a:visited {
  display: block;
  padding: 0;
}

.theme-smp .l-global-navi li a, .theme-smp
.l-global-navi li a:hover, .theme-smp
.l-global-navi li a:active, .theme-smp
.l-global-navi li a:visited {
  padding: 12px 12px 12px 43px;
  color: #333;
}

.l-global-navi li:first-child {
  width: 165px;
  margin-left: 0px;
}

.l-global-navi li:last-child {
  width: 165px;
  margin-right: 0px;
}

.l-global-navi li:hover {
  z-index: 2;
  background: #ededed;
}

.l-global-navi li.is-active {
  z-index: 3;
  background: #5f5f5f;
}

.theme-smp .l-global-navi li {
  float: none;
  width: 100%;
  position: relative;
  border-bottom: 1px solid #ccc;
  font-size: 115%;
  line-height: 22px;
  font-weight: bold;
  background-color: #fff;
  text-align: left;
}

.theme-smp .l-global-navi li:before {
  position: absolute;
  content: url(../images/layout/icon_arrow_right_r.png);
  left: 15px;
  top: 13px;
}

.theme-smp .l-global-navi li:first-child {
  border-radius: 3px 3px 0 0;
}

.theme-smp .l-global-navi li.n_leisure {
  background-color: #fbdee0;
}

.l-extra-navi {
  position: absolute;
  right: 257px;
  top: 16px;
  margin: 0;
}

.theme-smp .l-extra-navi {
  position: relative;
  top: 0;
  border-radius: 0 0 3px 3px;
  margin: 0;
  right: 0;
}

.l-extra-navi li {
  float: left;
  position: relative;
  list-style: none;
  padding: 0;
  margin: 0;
}

.l-extra-navi li::before {
  content: '';
  display: block;
  height: 1em;
  border-left: 1px solid #cdcdcd;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

.l-extra-navi li:last-child::after {
  content: '';
  display: block;
  height: 1em;
  border-left: 1px solid #cdcdcd;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}

.l-extra-navi li a {
  display: block;
  color: #666666;
  padding: 0 12px;
  font-size: 100%;
}
@media (max-width: 600px) {
  .l-extra-navi li a {
    padding: 0;
  }
}
.thema-pc .l-extra-navi li a {
  padding: 0 12px;
}

.l-extra-navi li img {
  display: block;
}

.theme-smp .l-extra-navi li {
  float: none;
  width: 100%;
  height: auto;
  border-bottom: 1px solid #ccc;
  padding: 8px 43px;
  font-weight: bold;
}

.theme-smp .l-extra-navi li:before {
  position: absolute;
  content: url(../images/layout/icon_arrow_right_r.png);
  left: 15px;
  top: -4px;
  border-left: none;
}

.theme-smp .l-extra-navi li a {
  font-size: 100%;
  padding: 0;
  color: #333;
  padding: 0;
}

.theme-smp .l-extra-navi li.last {
  border-radius: 0 0 3px 3px;
  border-bottom: 0px;
}

.theme-smp .l-extra-navi:last-child li:last-child {
  border-radius: 0 0 3px 3px;
  border-bottom: 0px;
}

.theme-smp .l-extra-navi li:last-child::after {
  border-left: none;
}

.l-search-area {
  position: absolute;
  top: 41px;
  right: 257px;
}

.theme-en .l-search-area {
  /* width: 257px; */
  right: 21px;
}

.theme-smp .l-search-area {
  position: relative;
  width: 100%;
  right: 0;
  top: 0;
  border-bottom: 1px solid #ccc;
  padding: 10px;
}

.l-search-area .search-box {
  width: 191px;
  height: 22px;
  float: left;
  color: #444;
  border: 1px solid #d9d9d9;
  padding: 0 2px;
  line-height: 1em;
  margin-right: 5px;
  margin-top: 1px;
  font-size: 100%;
}

.theme-smp .l-search-area .search-box {
  width: 73%;
  height: 32px;
  border-radius: 3px;
}

.l-search-area .search-but {
  height: 22px;
  line-height: 24px;
  border: none;
  background: #e6e6e6;
  color: #333;
  font-size: 100%;
  vertical-align: top;
  margin-top: 1px;
  padding: 0 10px;
}

.l-search-area .search-but:hover {
  background: #666666;
  color: #fff;
}

.theme-smp .l-search-area .search-but {
  width: 25%;
  height: 32px;
  color: #fff;
  font-weight: bold;
  border-radius: 3px;
  background: #626161;
  background: -webkit-linear-gradient(top, #626161, #484747);
  background: linear-gradient(to bottom, #626161, #484747);
  border: 1px solid #717171;
  padding: 0;
}

.l-search-area legend {
  display: none;
}

.l-font-size {
  position: absolute;
  width: 133px;
  right: 21px;
  top: 35px;
}

.theme-en .l-font-size {
  width: 126px;
}

.l-font-size img {
  vertical-align: top;
}

.l-font-size p {
  font-size: 12px;
  color: #999;
  width: 58px;
  height: 12px;
  padding: 3px 0;
  float: left;
  margin: 2px 0;
}

.theme-en .l-font-size p {
  width: 51px;
  height: 9px;
  padding: 5px 0;
}

.l-font-size ul {
  float: left;
  margin: 0;
  padding: 0;
}

.l-font-size li {
  margin: 0;
  margin-left: 5px;
  list-style: none;
  float: left;
  width: 20px;
  height: 22px;
  display: block;
  background: none no-repeat 0 0 transparent;
  cursor: pointer;
}

.l-font-size li.active {
  background-repeat: no-repeat;
  background-position: left top;
}

.l-font-size li.active img {
  visibility: hidden;
}

.l-font-size #fontS {
  background-image: url(../images/layout/fontsize_s_on.png);
}

.theme-en .l-font-size #fontS {
  background-image: url(../images/layout/fontsize_s_en_on.png);
}

.l-font-size #fontM {
  background-image: url(../images/layout/fontsize_m_on.png);
}

.theme-en .l-font-size #fontM {
  background-image: url(../images/layout/fontsize_m_en_on.png);
}

.l-font-size #fontL {
  background-image: url(../images/layout/fontsize_l_on.png);
}

.theme-en .l-font-size #fontL {
  background-image: url(../images/layout/fontsize_l_en_on.png);
}

.theme-smp .dl-menuwrapper {
  width: 100%;
  min-width: 320px;
  position: absolute;
  top: 0;
  right: 0;
  padding-top: 65px;
  z-index: 20;
}

/* @media (min-width: 600px) {
  .theme-smp .dl-menuwrapper {
    padding-top: 70px;
  }
} */
.theme-smp .dl-menuwrapper hr {
  background: #cc0022;
  border: 0;
  height: 2px;
  margin: 0;
}

.theme-smp .dl-menuwrapper ul {
  background: #fff;
  padding: 0;
  list-style: none;
  position: relative;
}

.theme-smp .dl-menuwrapper li {
  position: relative;
}

.theme-smp .dl-menuwrapper li a {
  display: block;
  position: relative;
  outline: none;
}

.l-global-area {
  margin: 0 auto;
  position: relative;
  height: 82px;
  z-index: 2;
  background-size: 990px 16px;
  font-size: 12px;
  display: flex;
  justify-content: end;
  align-items: center;
}

.group-logo {
  position: relative;
  top: 3px;
  right: 9px;
  width: 226px;
  height: 36px;
}

.theme-popup .group-logo {
  position: relative;
  right: 96px;
}

.theme-en .group-logo {
  position: relative;
  top: 3px;
  right: 15px;
}

.theme-en .group-logo {
  position: relative;
  top: 3px;
  right: 15px;
  width: 185px;
}

.theme-en .group-logo a {
  display: block;
}

.theme-en .l-global-area .l-extra-navi {
  right: 226px;
}

.theme-en .l-global-area .l-search-area {
  right: 226px;
}

.l-popup-close {
  position: absolute;
  right: 10px;
  top: calc(50% - 6px);
  margin: 0;
  cursor: pointer;
  line-height: 0;
  border: none;
  background: none;
}

.theme-smp .l-popup-close {
  border: none;
  width: 52px;
  height: 46px;
  overflow: hidden;
  outline: none;
  position: absolute;
  right: 0;
  top: 10px;
  text-indent: -9999px;
  background: url(../images/layout/mobile_btn_close.png) no-repeat center center;
  background-size: 52px auto;
  margin: 0;
}

/* @media (min-width: 600px) {
  .theme-smp .l-popup-close {
    width: 70px;
    height: 62px;
    background-size: 70px auto;
  }
} */
/* .theme-en.theme-smp .l-popup-close {
  background: url(../images/layout/mobile_btn_close_en.png) no-repeat center center;
  background-size: 52px auto;
} */
/* @media (min-width: 600px) {
  .theme-en.theme-smp .l-popup-close {
    width: 70px;
    height: 62px;
    background-size: 70px auto;
  }
} */
/*footer*/
.l-footer-sitemap {
  width: 100%;
  position: relative;
  padding: 15px 0;
}

.l-footer-sitemap:before {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 3px;
  background: #cc0022;
  top: 0;
  left: 0;
}

.l-footer-sitemap:after {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 5px;
  top: 3px;
  left: 0;
  background: url(../images/layout/shadow.png) repeat 0px 0px;
}

.l-footer-sitemap a,
.l-footer-sitemap a:hover,
.l-footer-sitemap a:active,
.l-footer-sitemap a:visited {
  color: #666666;
}

.l-footer-sitemap > ul {
  margin: 0 auto;
}

.l-footer-sitemap > ul > li {
  float: left;
  list-style: none;
  width: 16.66667%;
  padding: 10px;
  font-size: 86%;
}

.l-footer-sitemap > ul > li:first-child {
  width: 100%;
  float: none;
}

.l-footer-sitemap > ul > li > a {
  font-weight: bold;
  padding-top: 20px;
  display: block;
}

.l-footer-sitemap > ul > li > a:first-child {
  padding-top: 0;
}

.l-footer-sitemap > ul > li > ul {
  padding: 0;
  margin: 0;
}

.l-footer-sitemap > ul > li > ul > li {
  list-style: none;
  margin: 6px 0;
  line-height: 1.4em;
}

.l-footer {
  width: 100%;
  height: 69px;
  position: relative;
  border-top: 1px solid #999;
}

.theme-smp .l-footer {
  border-top: 1px solid #ccc;
}

.theme-popup .l-footer {
  border-top: 0;
}

.l-footer ul.l-utility-navi {
  margin: 0 auto;
  padding: 10px 20px;
}

.theme-smp .l-footer ul.l-utility-navi {
  width: 100%;
  padding: 0;
}

.l-footer ul.l-utility-navi li {
  position: relative;
  float: left;
  list-style: none;
  line-height: 12px;
  margin: 0;
  padding: 0;
  height: 12px;
}

.l-footer ul.l-utility-navi li::before {
  content: '';
  display: block;
  height: 1em;
  border-left: 1px solid #cdcdcd;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

.l-footer ul.l-utility-navi li:last-child::after {
  content: '';
  display: block;
  height: 1em;
  border-left: 1px solid #cdcdcd;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
}

.l-footer ul.l-utility-navi li a {
  display: block;
  color: #666666;
  padding: 0 12px;
  font-size: 86%;
}

.theme-smp .l-footer ul.l-utility-navi li {
  position: relative;
  width: 100%;
  height: auto;
}

.theme-smp .l-footer ul.l-utility-navi li:before {
  position: absolute;
  left: 10px;
  top: 8px;
  content: url(../images/layout/icon_arrow_right_g.png);
  border: none;
  height: auto;
}

.theme-smp .l-footer ul.l-utility-navi li:last-child::after {
  display: none;
}

.theme-smp .l-footer ul.l-utility-navi li a {
  font-size: 100%;
}

.theme-smp .l-footer ul.l-utility-navi li a,
.theme-smp .l-footer ul.l-utility-navi li a:hover,
.theme-smp .l-footer ul.l-utility-navi li a:active,
.theme-smp .l-footer ul.l-utility-navi li a:visited {
  padding: 9px 4px 9px 25px;
  border-bottom: 1px solid #ccc;
  font-size: 100%;
  color: #333;
}

.theme-smp .l-footer .l-footer-popup-close {
  width: 156px;
  margin: 15px auto;
  cursor: pointer;
  text-indent: -9999px;
  overflow: hidden;
  background: url(../images/layout/mobile_footer_close.png) no-repeat center center;
  background-size: 156px 20px;
  border: none;
  display: block;
}

.l-footer .l-footer-popup-close .theme-smp, .theme-en .l-footer .l-footer-popup-close, .theme-multi.theme-en.theme-popup .l-footer .l-footer-popup-close {
  background: url(../images/layout/mobile_footer_close_en.png) no-repeat center center;
  background-size: 156px 20px;
}

.l-footer .l-footer-contents {
  background: #cc0022;
  width: 100%;
  height: 35px;
}

.theme-smp .l-footer .l-footer-contents {
  position: relative;
  width: 100%;
  height: auto;
  min-width: 320px;
}

.l-footer .l-site-data {
  margin: 0 auto;
  position: relative;
}

.theme-smp .l-footer .l-site-data {
  min-width: 320px;
}

.l-footer .l-footer-logo {
  position: absolute;
  margin: 0;
  line-height: 12px;
  top: 12px;
  left: 20px;
}

.l-footer .l-copy {
  position: absolute;
  top: 12px;
  right: 20px;
  color: #ffffff;
  font-size: 72%;
  line-height: 13px;
  text-align: right;
  padding: 0;
  margin: 0;
  font-family: 'Helvetica', 'Arial';
}

.theme-smp .l-footer .l-copy {
  position: relative;
  text-align: center;
  top: 0;
  right: 0;
  padding: 10px;
  line-height: 143%;
}

#footer-search-form {
  background: #f2f2f2;
  padding: 10px;
  border-bottom: 1px solid #cccccc;
}

#footer-search-form .footer-search-form-area {
  width: 100%;
  margin: 0 auto;
}

#footer-search-form .footer-search-form-area legend {
  display: none;
}

#footer-search-form .footer-search-form-area .search-box-f {
  width: 73%;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 7px;
  height: 34px;
}

#footer-search-form .footer-search-form-area .search-but {
  width: 25%;
  height: 32px;
  color: #fff;
  font-weight: bold;
  border-radius: 3px;
  background: #626161;
  background: -webkit-linear-gradient(top, #626161, #484747);
  background: linear-gradient(to bottom, #626161, #484747);
  border: 1px solid #717171;
  padding: 0;
}

.header-switcharea {
  background-color: #f2f2f2;
  background: #ffffff;
  background: -webkit-linear-gradient(top, #ffffff, #f1f1f3);
  background: linear-gradient(to bottom, #ffffff, #f1f1f3);
  border-bottom: 1px solid #ccc;
  padding: 0;
  text-align: center;
  vertical-align: middle;
  font-size: 300%;
  font-weight: bold;
}

.header-switcharea a {
  color: #333;
  display: block;
  text-decoration: none;
  padding: 35px 0 30px;
}

.header-switcharea img {
  width: 45px;
  height: 76px;
  vertical-align: middle;
  margin-right: 15px;
}

.footer-switcharea {
  background: #f2f2f2;
  padding: 40px 0 40px;
}

.footer-switcharea ul {
  width: 90%;
  border-radius: 3px;
  margin: 0 auto;
}

.footer-switcharea ul li {
  list-style: none;
  float: left;
  width: 49%;
  margin-left: -1px;
  border: 1px solid #ccc;
  text-align: center;
  font-size: 13px;
  line-height: 13px;
  font-weight: bold;
  vertical-align: middle;
  position: relative;
  height: 42px;
  background-color: #5e5e5e;
  background: #5e5e5e;
  background: -webkit-linear-gradient(top, #5e5e5e, #5e5e5e);
  background: linear-gradient(to bottom, #5e5e5e, #5e5e5e);
}

.footer-switcharea ul li.active {
  background-color: #fbfbfc;
  background: #fbfbfc;
  background: -webkit-linear-gradient(top, #fbfbfc, #f1f1f3);
  background: linear-gradient(to bottom, #fbfbfc, #f1f1f3);
}

.footer-switcharea ul li.active a {
  color: #333;
}

.footer-switcharea ul li img {
  height: 15px;
  position: absolute;
  left: 13px;
  top: 13px;
}

.footer-switcharea ul li:nth-child(1) {
  border-radius: 3px 0 0 3px;
}

.footer-switcharea ul li:nth-child(2) {
  border-radius: 0 3px 3px 0;
}

.footer-switcharea ul li a,
.footer-switcharea ul li span.a-active {
  display: block;
  padding: 13px 4px 0px 13px;
  height: 40px;
  color: #ffffff;
}

.footer-switcharea ul li a:hover,
.footer-switcharea ul li span.a-active:hover {
  text-decoration: none;
}

.footer-switcharea ul li a span,
.footer-switcharea ul li span.a_active span {
  display: block;
  font-size: 11px;
}

#btn-page-list {
  position: fixed;
  bottom: 2px;
  right: 50px;
  z-index: 2;
}

@media (min-width: 600px) {
  #btn-page-list {
    right: 74px;
  }
}
#btn-page-list p {
  margin: 0;
}

#btn-page-list a {
  display: block;
  width: 44px;
  height: 44px;
  overflow: hidden;
  text-indent: -9999px;
  background: url(../images/layout/mobile_pagelist.png) no-repeat left top;
  background-size: 44px 44px;
}

@media (min-width: 600px) {
  #btn-page-list a {
    width: 70px;
    height: 70px;
    background-size: 70px 70px;
  }
}
.l-pagetop {
  position: fixed;
  bottom: 50px;
  right: 10px;
  z-index: 2;
  width: 100%;
  display: none;
}

.theme-smp .l-pagetop {
  right: 2px;
  bottom: 46px;
}

@media (min-width: 600px) {
  .theme-smp .l-pagetop {
    bottom: 72px;
  }
}
.l-pagetop p {
  margin: 0 auto;
  position: relative;
  height: 0;
}

.theme-smp .l-pagetop p {
  margin: 0;
  width: 100%;
}

.theme-popup .l-pagetop p {
  width: 736px;
}

.l-pagetop a {
  width: 97px;
  height: 31px;
  right: 0;
  display: block;
  text-indent: -9999px;
  background: url(../images/layout/pagetop_off.png) no-repeat left top;
  overflow: hidden;
  position: absolute;
}

.l-pagetop a:hover {
  background: url(../images/layout/pagetop_on.png) no-repeat left top;
}

.theme-en .l-pagetop a {
  background: url(../images/layout/pagetop_en_off.png) no-repeat left top;
}

.theme-en .l-pagetop a:hover {
  background: url(../images/layout/pagetop_en_on.png) no-repeat left top;
}

.theme-smp .l-pagetop a, .theme-smp.theme-en .l-pagetop a {
  width: 44px;
  height: 44px;
  background: url(../images/layout/mobile_pagetop.png) no-repeat left top;
  background-size: 44px 44px;
}

@media (min-width: 600px) {
  .theme-smp .l-pagetop a, .theme-smp.theme-en .l-pagetop a {
    width: 70px;
    height: 70px;
    background-size: 70px 70px;
  }
}
.theme-smp .l-pagetop a:hover, .theme-smp.theme-en .l-pagetop a:hover {
  background: url(../images/layout/mobile_pagetop.png) no-repeat left top;
  width: 44px;
  height: 44px;
  background-size: 44px 44px;
}

@media (min-width: 600px) {
  .theme-smp .l-pagetop a:hover, .theme-smp.theme-en .l-pagetop a:hover {
    width: 70px;
    height: 70px;
    background-size: 70px 70px;
  }
}
.theme-smp.theme-en .logo-area {
  display: flex;
  align-items: center;
  width: 152px;
}

.theme-smp .logo-area .l-logo {
  height: 65px;
  display: flex;
  align-items: center;
  width: 180px;
  position: relative;
  right: 5px;
}

.theme-smp .logo-area .l-logo a {
  display: flex;
  flex-flow: column;
  align-items: center;
  height: 50px;
}

.l-girdText {
  clear: both;
  padding: 10px 21px;
  height: 12px;
  font-size: 86%;
  border-top: 1px solid #d9d9d9;
}

/*hero*/
.hero-slider {
  display: none;
}

.l-branding-head {
  margin: 0 auto;
}

.l-property-area {
  width: 100%;
  position: relative;
  background: #cc0022;
  z-index: 2;
}

.l-hero {
  overflow: hidden;
  padding-bottom: 30px;
  margin-bottom: 0;
}

.l-main .l-hero {
  margin-bottom: 10px;
}

.l-hero:after {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 5px;
  top: 0;
  left: 0;
  background: url(../images/layout/shadow.png) repeat 0px 0px;
}

.theme-smp .l-hero.slick-slider {
  background: #fff;
  margin-bottom: 0;
  padding-bottom: 46px;
}

.l-hero .slick-list {
  overflow: hidden;
  background: #f4f4f4;
}

.l-hero .slick-dots {
  bottom: -26px;
}

.theme-smp .l-hero .slick-dots {
  bottom: 10px;
  margin: 0;
}

.l-hero .slick-dots li {
  width: 10px;
  height: 10px;
}

.theme-smp .l-hero .slick-dots li {
  width: 20px;
  height: 20px;
}

.theme-smp .l-hero .slick-dots li button {
  height: 20px;
}

.l-hero .slick-dots li button:before {
  background: #e4e4e4;
  width: 10px;
  color: #e4e4e4;
  opacity: 1;
  font-size: 24px;
  content: "";
  height: 10px;
  border-radius: 5px;
}

.theme-smp .l-hero .slick-dots li button:before {
  font-size: 48px;
  width: 16px;
  height: 16px;
  border-radius: 8px;
}

.l-hero .slick-dots li.slick-active button:before {
  color: #646464;
  background: #646464;
}

.is-disaster {
  text-align: center;
}

.is-disaster .slick-list {
  background: #fff;
}

.is-disaster img {
  max-width: initial;
  width: auto;
  height: auto;
}

.theme-smp .is-disaster img {
  max-width: 100%;
  height: auto;
}

.theme-smp .is-disaster .hero-item {
  max-width: 100%;
  height: auto;
}

.is-disaster .hero-item img {
  margin: 0 auto;
  max-width: initial;
  width: auto !important;
}

.theme-smp .is-disaster .hero-item img {
  max-width: 100%;
  height: auto;
}

.hero-item {
  margin: 0 auto !important;
  display: none;
}

.hero-item.slick-slide {
  display: block;
}

.hero-item img {
  width: 100%;
}

#bodyfade {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  opacity: 1;
  z-index: 20;
  display: none\9;
}

.theme-smp .l-breadcrumbs-wrap {
  width: 100%;
  min-width: 320px;
}

.theme-popup .l-breadcrumbs-wrap {
  width: 736px;
}

.l-breadcrumbs-wrap .l-breadcrumbs-nav {
  margin: 0 21px 0;
  padding: 21px 0 0 0;
}

.theme-smp .l-breadcrumbs-wrap .l-breadcrumbs-nav {
  padding: 0;
  margin: 20px 10px;
}

.l-breadcrumbs-wrap .l-breadcrumbs-nav li {
  display: inline-block;
  list-style: none;
  float: left;
  font-size: 86%;
  line-height: 115%;
  margin: 1px 0 5px 5px;
}

.theme-smp .l-breadcrumbs-wrap .l-breadcrumbs-nav li {
  float: none;
}

.l-breadcrumbs-wrap .l-breadcrumbs-nav li a {
  background: url(../images/layout/topicpath_arrow.gif) no-repeat right center;
  padding: 0 20px 0 0;
}

.l-local-navi + .l-breadcrumbs-wrap {
  margin-top: -20px;
}

.l-contents {
  width: 990px;
  margin: 0 auto;
  z-index: 0;
  position: relative;
  background: #ffffff;
  font-size: 16px;
}

.theme-single .l-contents {
  width: 100%;
  min-width: 990px;
}

.theme-popup .l-contents {
  width: 736px;
}

.theme-popup.theme-smp .l-contents {
  width: 100%;
  min-width: 320px;
}

.theme-popup.theme-en .group-logo {
  position: relative;
  right: 109px;
}

.theme-smp .l-contents {
  width: 100%;
  min-width: 320px;
}

.l-contents .l-main {
  width: 696px;
  margin: 21px 0px 21px 21px;
  position: relative;
  float: left;
}

.theme-smp .l-contents .l-main {
  width: auto;
  overflow: hidden;
  min-width: 320px;
  margin: 0;
  float: none;
  padding: 20px 0;
}

.theme-single .l-contents .l-main {
  width: 948px;
  margin: 21px auto;
  float: none;
}

.theme-single.theme-smp .l-contents .l-main {
  width: auto;
  overflow: hidden;
  min-width: 320px;
  margin: 0;
  float: none;
  padding: 20px 0;
}

.l-contents .l-side {
  width: 222px;
  margin: 18px 21px 21px 0;
  float: right;
}

.theme-smp .l-contents .l-side {
  width: auto;
  min-width: 320px;
  margin: 0 auto;
  float: none;
}

.l-local-navi {
  margin: 0 0 20px;
}

.l-local-navi .local-navi-panel {
  position: relative;
}

.l-local-navi .local-navi-panel .local-navi-switch {
  height: 42px;
  display: block;
  background: #333 url(../images/layout/mobile_icon_m_plus.png) no-repeat right center;
  background-size: 34px 34px;
  padding: 8px 40px 8px 10px;
  color: #ffffff;
  font-size: 100%;
  font-weight: bold;
}

.l-local-navi .local-navi-panel .local-navi-switch .close {
  display: none;
}

.l-local-navi .local-navi-box {
  display: none;
}

.l-local-navi.is-hide .local-navi-panel .local-navi-switch {
  background: #333 url(../images/layout/mobile_icon_m_minus.png) no-repeat right center;
  background-size: 34px 34px;
}

.l-local-navi.is-hide .local-navi-panel .local-navi-switch .open {
  display: none;
}

.l-local-navi.is-hide .local-navi-panel .local-navi-switch .close {
  display: inline;
}

.l-local-navi.is-hide .local-navi-box {
  display: block;
}

.l-local-navi h3 {
  padding: 0;
  margin: 0;
  border-left: 0;
  border-radius: 3px 3px 0 0;
  overflow: hidden;
  font-size: 100%;
}

.theme-smp .l-local-navi h3 {
  padding: 0;
  border-radius: 0;
  margin: 0;
}

.theme-smp .l-local-navi h3 a {
  background: #7f7f7f;
  background: -webkit-linear-gradient(top, #7f7f7f, #424242);
  background: linear-gradient(to bottom, #7f7f7f, #424242);
  color: #ffffff !important;
  font-weight: bold;
  line-height: 136%;
  font-size: 107%;
  padding: 12px 40px 12px 10px;
  display: block;
}

.theme-smp .l-local-navi h3 a:hover {
  color: #ffffff;
  background: #4e4e4e;
  background: -webkit-linear-gradient(top, #4e4e4e, #383838);
  background: linear-gradient(to bottom, #4e4e4e, #383838);
}

.theme-smp .l-local-navi h3 a:active {
  color: #ffffff;
}

.l-local-navi h3 a {
  background: #7d7e7e;
  background: -webkit-linear-gradient(top, #7d7e7e, #454444);
  background: linear-gradient(to bottom, #7d7e7e, #454444);
  color: #ffffff !important;
  font-weight: bold;
  padding: 15px 10px;
  display: block;
}

.l-local-navi h3 a:hover {
  color: #ffffff;
  background: #7c7c7c;
  background: -webkit-linear-gradient(top, #7c7c7c, #343334);
  background: linear-gradient(to bottom, #7c7c7c, #343334);
}

.l-local-navi h3 a:active {
  color: #ffffff;
}

.l-local-navi a {
  color: #333;
}

.l-local-navi a:visited {
  color: #333;
}

.l-local-navi a:hover {
  text-decoration: none;
}

.l-local-navi ul {
  padding: 0;
  margin: 0;
  border-bottom: 0;
  overflow: hidden;
}

.theme-smp .l-local-navi ul {
  border-right: 0;
  border-left: 0;
}

.l-local-navi li {
  /*navi 1*/
  padding: 0;
  margin: 0;
  list-style: none;
}

.l-local-navi li a {
  font-size: 100%;
  line-height: 136%;
  font-weight: bold;
  position: relative;
  display: block;
  padding: 6px 6px 6px 25px;
  border-bottom: 1px solid #b3b3b3;
  border-left: 1px solid #ccc;
  border-right: 1px solid #ccc;
  border-top: 1px solid #fff;
  background: #e6e6e6;
}

.l-local-navi li a:hover {
  background: #b8b8b8;
  border-top: 1px solid #cccccc;
}

.l-local-navi li a:hover:before {
  content: url(../images/layout/icon_arrow_right_s_r.png);
}

.l-local-navi li a:before {
  position: absolute;
  left: 10px;
  top: 6px;
  content: url(../images/layout/icon_arrow_right_s_r.png);
}

.l-local-navi li a:hover, .l-local-navi li a:active, .l-local-navi li a:visited, .l-local-navi li a:focus {
  text-decoration: none;
}

.l-local-navi li.ac > a, .l-local-navi li.ac > a:hover {
  background: #696969;
  border: 1px solid #696969;
  color: #ffffff;
}

.l-local-navi li.ac > a:before, .l-local-navi li.ac > a:hover:before {
  content: url(../images/layout/icon_arrow_right_s_c.png);
}

.l-local-navi li.ac > a span, .l-local-navi li.ac > a:hover span {
  color: #ffffff;
}

.l-local-navi li.ac a, .l-local-navi li.ac a:visited {
  color: #ffffff;
}

.l-local-navi li.ac li a, .l-local-navi li.ac li a:visited {
  color: #333;
}

.l-local-navi li ul {
  z-index: 1;
  margin: 0;
  zoom: 1;
  border: none;
  position: relative;
}

.l-local-navi li ul:after {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 4px;
  top: 0;
  left: 0;
  background: url(../images/layout/shadow.png) repeat bottom left;
}

.l-local-navi li ul ul:after {
  display: none;
}

.l-local-navi li li, .l-local-navi li.ac li {
  /*navi 2*/
}

.l-local-navi li li a, .l-local-navi li.ac li a {
  background-color: #fff;
  background-image: none;
  font-size: 93%;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  -ms-box-shadow: none;
  box-shadow: none;
  padding: 6px 6px 6px 25px;
  border-bottom: 1px solid #b3b3b3;
}

.l-local-navi li li a:before, .l-local-navi li.ac li a:before {
  content: url(../images/layout/icon_arrow_right_s_g.png);
  left: 10px;
}

.l-local-navi li li a:hover, .l-local-navi li.ac li a:hover {
  color: #333;
  background-color: #b8b8b8;
  background-image: none;
}

.l-local-navi li li a:hover:before, .l-local-navi li.ac li a:hover:before {
  content: url(../images/layout/icon_arrow_right_s_g.png);
}

.l-local-navi li li a ul:after, .l-local-navi li.ac li a ul:after {
  display: none;
}

.l-local-navi li li li, .l-local-navi li li.ac li, .l-local-navi li.ac li li, .l-local-navi li.ac li.ac li {
  /*navi 3*/
}

.l-local-navi li li li a, .l-local-navi li li.ac li a, .l-local-navi li.ac li li a, .l-local-navi li.ac li.ac li a {
  background-color: #fff;
  padding: 6px 6px 6px 31px;
}

.l-local-navi li li li a:before, .l-local-navi li li.ac li a:before, .l-local-navi li.ac li li a:before, .l-local-navi li.ac li.ac li a:before {
  left: 16px;
}

.l-local-navi li li li a.ac a, .l-local-navi li li li a.ac a:hover, .l-local-navi li li.ac li a.ac a, .l-local-navi li li.ac li a.ac a:hover, .l-local-navi li.ac li li a.ac a, .l-local-navi li.ac li li a.ac a:hover, .l-local-navi li.ac li.ac li a.ac a, .l-local-navi li.ac li.ac li a.ac a:hover {
  background-position: 37px 10px;
  color: #ffffff;
}

.l-local-navi li li li li, .l-local-navi li li li.ac li, .l-local-navi li li.ac li li, .l-local-navi li li.ac li.ac li, .l-local-navi li.ac li li li, .l-local-navi li.ac li li.ac li, .l-local-navi li.ac li.ac li li, .l-local-navi li.ac li.ac li.ac li {
  /*navi 4*/
}

.l-local-navi li li li li a, .l-local-navi li li li.ac li a, .l-local-navi li li.ac li li a, .l-local-navi li li.ac li.ac li a, .l-local-navi li.ac li li li a, .l-local-navi li.ac li li.ac li a, .l-local-navi li.ac li.ac li li a, .l-local-navi li.ac li.ac li.ac li a {
  background-color: #fff;
  padding: 6px 6px 6px 37px;
}

.l-local-navi li li li li a:before, .l-local-navi li li li.ac li a:before, .l-local-navi li li.ac li li a:before, .l-local-navi li li.ac li.ac li a:before, .l-local-navi li.ac li li li a:before, .l-local-navi li.ac li li.ac li a:before, .l-local-navi li.ac li.ac li li a:before, .l-local-navi li.ac li.ac li.ac li a:before {
  left: 22px;
}

.theme-smp .l-local-navi a {
  color: #333;
  cursor: pointer;
}

.theme-smp .l-local-navi a:visited {
  color: #333;
}

.theme-smp .l-local-navi a:hover {
  text-decoration: none;
}

.theme-smp .l-local-navi .localNavPanel {
  position: relative;
}

.theme-smp .l-local-navi .localNavPanel .localNavSwitch {
  height: 14px;
  display: block;
  background: #333 url(../images/mobile_icon_m_plus.png) no-repeat right center;
  background-size: 34px 34px;
  padding: 14px 40px 14px 10px;
  color: #ffffff;
  font-size: 100%;
  font-weight: bold;
}

.theme-smp .l-local-navi .localNavPanel .localNavSwitch .close {
  display: none;
}

.theme-smp .l-local-navi.hide_l .localNavPanel .localNavSwitch {
  background: #333 url(../images/mobile_icon_m_minus.png) no-repeat right center;
  background-size: 34px 34px;
}

.theme-smp .l-local-navi.hide_l .localNavPanel .localNavSwitch .open {
  display: none;
}

.theme-smp .l-local-navi.hide_l .localNavPanel .localNavSwitch .close {
  display: inline;
}

.l-main-title {
  width: 990px;
  margin: 0 auto;
  padding: 0;
}

.theme-smp .l-main-title {
  width: 100%;
}

.theme-smp .l-main-title img {
  width: 100%;
}

.l-sns {
  background: #efefef;
  padding: 15px 15px 20px;
  text-align: center;
}

.l-sns ul {
  margin: 0;
  padding: 0;
  height: 86px;
}

.theme-smp .l-sns ul {
  height: 47px;
}

.l-sns li {
  display: inline-block;
  list-style: none;
  margin: 0;
  padding: 0 5px;
}

.l-sns li a {
  display: block;
  width: 84px;
  height: 86px;
  background-size: 84px 86px;
  overflow: hidden;
  text-indent: -9999px;
}

.theme-smp .l-sns li a {
  width: 64px;
  height: 47px;
}

.l-sns .sns-facebook a {
  background: url(../images/layout/sns_icon_facebook.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-facebook a {
  background: url(../images/layout/sns_icon_facebook_e.png) no-repeat center bottom;
}

.l-sns .sns-twitter a {
  background: url(../images/layout/sns_icon_twitter.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-twitter a {
  background: url(../images/layout/sns_icon_twitter_e.png) no-repeat center bottom;
}

.l-sns .sns-gplus a {
  background: url(../images/layout/sns_icon_gplus.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-gplus a {
  background: url(../images/layout/sns_icon_gplus_e.png) no-repeat center bottom;
}

.l-sns .sns-line a {
  background: url(../images/layout/sns_icon_line.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-line a {
  background: url(../images/layout/sns_icon_line_e.png) no-repeat center bottom;
}

.l-sns .sns-x a {
  background: url(../images/layout/sns_icon_x.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-x a {
  background: url(../images/layout/sns_icon_x_e.png) no-repeat center bottom;
}

.l-sns .sns-linkedin a {
  background: url(../images/layout/sns_icon_linkedin.png) no-repeat center bottom;
}

.theme-en .l-sns .sns-linkedin a {
  background: url(../images/layout/sns_icon_linkedin_e.png) no-repeat center bottom;
}

/*side*/
.l-side hr {
  border-top: 1px solid #aaaaaa;
  margin: 20px 0;
}

.theme-smp .l-side hr {
  margin: 20px 10px;
}

.frame-line {
  margin-bottom: 18px;
  border: 2px solid #d6d6d6;
  background: #fff;
}

.theme-smp .frame-line {
  margin: 0 10px 30px;
}

.frame-line h4 {
  padding: 10px 12px;
  margin: -2px;
  border-top: 3px solid #777777;
}

.frame-line .line-navi {
  margin: 0 10px;
}

.frame-line .line-navi.line-navi-pdf .line-navi-item a[target="_blank"] .line-navi-text:after {
  display: none;
}

.frame-line .line-navi.line-navi-pdf .line-navi-item .line-navi-text {
  padding-left: 75px;
}

.frame-line .line-navi.line-navi-pdf .line-navi-item .line-navi-text:before {
  position: absolute;
  left: 57px;
  content: url(../images/layout/icon_pdf.png);
  margin-top: -5px;
}

.frame-line .line-navi-item {
  border-top: 1px solid #ccc;
}

.frame-line .line-navi-item a {
  display: block;
  padding: 11px 0;
  font-size: 93%;
}

.frame-line .line-navi-item a[target="_blank"] .line-navi-text:after {
  display: inline-block;
  content: url(../images/layout/icon_owr.png);
  padding: 0 10px;
  font-size: 93%;
  color: #cc0022;
  text-decoration: none;
}

.frame-line .line-navi-item p {
  margin: 0;
  padding: 0;
  font-size: 93%;
  line-height: 1.4em;
}

.frame-line .line-navi-item .line-navi-image {
  float: left;
  display: inline-block;
  width: 50px;
}

.frame-line .line-navi-item .line-navi-text {
  position: relative;
  padding-left: 18px;
}

.frame-line .line-navi-item .line-navi-text:before {
  position: absolute;
  left: 0px;
  top: 50%;
  content: url(../images/layout/icon_arrow_right_g.png);
  margin-top: -8px;
}

.frame-line .line-navi-item .line-navi-image + .line-navi-text {
  padding-left: 75px;
}

.frame-line .line-navi-item .line-navi-image + .line-navi-text:before {
  position: absolute;
  left: 60px;
  top: 4px;
  content: url(../images/layout/icon_arrow_right_g.png);
  margin-top: 0;
}

.stock-quotation {
  margin-bottom: 18px;
}

.stock-quotation .chart-table {
  height: 100px;
}

.stock-quotation .chart-link {
  margin: -1px;
}

.stock-quotation .chart-link a {
  position: relative;
  display: block;
  margin: 0;
  padding: 10px 10px 10px 28px;
  background: #656565;
  color: #fff;
}

.stock-quotation .chart-link a:before {
  content: url(../images/layout/icon_arrow_right_c.png);
  position: absolute;
  left: 10px;
  top: 12px;
}

.stock-quotation .chart-link a:hover {
  text-decoration: none;
}

.access-rank .access-rank-list {
  padding: 0;
  margin: 0 10px;
}

.access-rank .access-rank-list li {
  list-style: none;
  position: relative;
  padding: 9px 0 9px 28px;
  border-top: 1px solid #cccccc;
  font-size: 93%;
}

.access-rank .access-rank-list li:before {
  position: absolute;
  display: block;
  left: 0;
  top: 10px;
  width: 17px;
  height: 17px;
  border-radius: 8px;
  background: #cc0022;
  color: #fff;
  line-height: 10px;
  font-size: 10px;
  text-align: center;
  padding: 3px;
  font-weight: bold;
}

.access-rank .access-rank-list li:first-child:before {
  content: '1';
}

.access-rank .access-rank-list li:first-child + *:before {
  content: '2';
}

.access-rank .access-rank-list li:first-child + * + *:before {
  content: '3';
}

.access-rank .access-rank-list li:first-child + * + * + *:before {
  content: '4';
}

.access-rank .access-rank-list li:first-child + * + * + * + *:before {
  content: '5';
}

.ban-area {
  margin-bottom: 18px;
}

.theme-smp .ban-area {
  margin: 0 5px 18px;
}

.ban-area .ban-item {
  margin-bottom: 6px;
}

.theme-smp .ban-area .ban-item {
  padding: 5px;
  margin: 0;
  width: 50%;
  float: left;
}

.theme-smp .ban-area .ban-item img {
  width: 100%;
}

.theme-smp .ban-area .ban-item.ban-l-smp {
  width: 100%;
}

.cta-navi {
  background: #eeeeee;
  padding: 0 0 10px;
  margin: 0 0 18px;
}

.theme-smp .cta-navi {
  width: 100%;
  padding: 5px;
}

.cta-navi a {
  display: block;
  background: #fff;
  padding: 10px 2px 10px 40px;
  color: #333;
  font-weight: bold;
  font-size: 14px;
}

.cta-navi a:hover {
  text-decoration: none;
  background-color: #c4c4c4;
}

.theme-smp .cta-navi a:hover {
  text-decoration: none;
  background-color: #c4c4c4;
}

.theme-smp .cta-navi a {
  height: 74px;
  display: block;
  background: #fff;
  padding: 10px;
  color: #333;
  font-weight: bold;
  border: 1px solid #ccc;
  text-align: center;
  font-size: 11px;
}

.theme-smp .cta-navi a:before {
  display: block;
  width: 100%;
  height: 35px;
  text-align: center;
  content: '';
}

.theme-en.theme-smp .cta-navi a {
  height: 80px;
  line-height: 1.2em;
}

.cta-navi li {
  padding: 10px 10px 0;
  list-style: none;
}

.theme-smp .cta-navi li {
  width: 50%;
  float: left;
  padding: 5px;
  list-style: none;
}

.cta-navi .cta-mail a {
  background: #fff url(../images/layout/icon_mail.png) no-repeat 10px 12px;
}

.theme-smp .cta-navi .cta-mail a {
  background: #fff;
}

.theme-smp .cta-navi .cta-mail a:before {
  background: #fff url(../images/layout/icon_mail_smp.png) no-repeat center top;
  background-size: 27px auto;
}

.cta-navi .cta-mail a:hover {
  background-color: #c4c4c4;
}

.theme-smp .cta-navi .cta-mail a:hover:before {
  background-color: #c4c4c4;
}

.cta-navi .cta-question a {
  background: #fff url(../images/layout/icon_help.png) no-repeat 10px 12px;
}

.theme-smp .cta-navi .cta-question a {
  background: #fff;
}

.theme-smp .cta-navi .cta-question a:before {
  background: #fff url(../images/layout/icon_help_smp.png) no-repeat center top;
  background-size: 27px auto;
}

.cta-navi .cta-question a:hover {
  background-color: #c4c4c4;
}

.theme-smp .cta-navi .cta-question a:hover:before {
  background-color: #c4c4c4;
}

.cta-navi .cta-contact a {
  background: #fff url(../images/layout/icon_contact.png) no-repeat 10px 12px;
}

.theme-smp .cta-navi .cta-contact a {
  background: #fff;
}

.theme-smp .cta-navi .cta-contact a:before {
  background: #fff url(../images/layout/icon_contact_smp.png) no-repeat center top;
  background-size: 27px auto;
}

.cta-navi .cta-contact a:hover {
  background-color: #c4c4c4;
}

.theme-smp .cta-navi .cta-contact a:hover:before {
  background-color: #c4c4c4;
}

.cta-navi .cta-irevent a {
  background: #fff url(../images/layout/icon_ir_event.png) no-repeat 10px 12px;
}

.theme-smp .cta-navi .cta-irevent a {
  background: #fff;
}

.theme-smp .cta-navi .cta-irevent a:before {
  background: #fff url(../images/layout/icon_ir_event_smp.png) no-repeat center top;
  background-size: 27px auto;
}

.cta-navi .cta-irevent a:hover {
  background-color: #c4c4c4;
}

.theme-smp .cta-navi .cta-irevent a:hover:before {
  background-color: #c4c4c4;
}

.theme-smp {
  -webkit-text-size-adjust: none;
  background: #ffffff;
}

.theme-smp #i_search_autocomplete {
  z-index: 20 !important;
}

.theme-smp #contentswrapper {
  width: 100%;
  min-width: 320px;
  margin: 0 auto;
}

.theme-smp .footer_close {
  width: 100%;
  text-align: center;
  margin: 0 auto 15px;
}

.theme-smp .footer_close img {
  width: 156px;
  height: 20px;
}

.theme-smp .f_s_zenrin ul li.active a {
  padding-top: 8px;
  height: 32px;
}

ul, ol ul {
  list-style-type: disc;
}

h2 {
  position: relative;
  font-size: 150%;
  font-weight: bold;
  line-height: 30px;
  border-top: 3px solid #cc0022;
  margin: 0;
  padding: 20px 10px 23px;
  color: #333;
}

.theme-smp h2 {
  font-size: 122%;
  padding: 12px 10px 23px;
}

h2.titleB {
  border-top: 3px solid #777;
}

h2.title-link {
  padding-left: 24px;
  position: relative;
}

h2.title-link:before {
  font-size: 115%;
  position: absolute;
  left: 10px;
  top: 20px;
}

.theme-smp h2.title-link:before {
  top: 12px;
}

h2.title-link a {
  color: #333;
}

h2.title-link a:hover {
  text-decoration: none;
}

h3 {
  font-size: 115%;
  font-weight: bold;
  line-height: 24px;
  color: #333;
  border-left: 4px solid #cc0022;
  margin: 0 10px 23px;
  padding: 8px 0 8px 15px;
}

.theme-smp h3 {
  font-size: 107%;
  margin: 0 5px 15px;
  padding: 0 0 0 5px;
}

h3.titleB {
  border-left: 4px solid #777;
}

.theme-smp h3.title-bg {
  background: #f6f6f6;
}

h4 {
  font-size: 115%;
  font-weight: bold;
  color: #333;
  line-height: 24px;
  margin: 0 10px 23px;
}

h5 {
  margin: 0 10px 23px;
  font-size: 115%;
  line-height: 24px;
  font-weight: bold;
  color: #333;
}

h6 {
  line-height: 1.4em;
  margin: 0 10px 23px;
  font-size: 100%;
  font-weight: bold;
  color: #333;
}

p {
  line-height: 1.6em;
  margin: 0 10px 23px;
  font-size: 100%;
}

blockquote {
  font-size: 100%;
}

ul {
  margin: 0 10px 23px;
  padding: 0 0 0 15px;
}

ul li {
  line-height: 1.6em;
}

ul.text-link-ul {
  padding: 0;
  margin: 0 10px 23px;
}

ul.text-link-ul li {
  position: relative;
  padding-left: 15px;
  margin: 0 0 10px;
}

ul.text-link-ul li:before {
  position: absolute;
  left: 0px;
  top: 0px;
}

ul.text-link-ul ul {
  margin: 20px 0;
  padding-left: 0;
}

ul.text-link-ul.list-gray li:before {
  content: url(../images/layout/icon_arrow_right_g.png);
}

ul.text-link-ul.anchor-list li:before {
  content: url(../images/layout/icon_arrow_bottom_r.png);
}

ul.text-link-ul-v {
  padding: 0;
}

ul.text-link-ul-v li {
  position: relative;
  float: left;
  width: 33.3333%;
  padding: 0 10px 10px 15px;
  margin-bottom: 15px;
}

ul.text-link-ul-v li:before {
  position: absolute;
  left: 0px;
  top: 0px;
}

ul.text-link-ul-v.list-gray li:before {
  color: #777;
}

ul.text-link-ul-v.anchor-list li:before {
  content: url(../images/layout/icon_arrow_bottom_r.png);
}

ol {
  padding: 0 0 0 15px;
  margin: 0 10px 23px;
}

ol li {
  line-height: 1.6em;
}

ol.style-decimal > li {
  list-style-type: decimal;
}

ol.style-lalfa > li {
  list-style-type: lower-alpha;
}

ol.style-lroman > li {
  list-style-type: lower-roman;
}

.asterisk-list {
  padding: 0;
  counter-reset: asterisk;
}

.asterisk-list li {
  padding-left: 30px;
  list-style: none;
  position: relative;
}

.asterisk-list li:before {
  position: absolute;
  left: 0;
  counter-increment: asterisk;
  content: "※" counter(asterisk);
}

ul.asterisk-list li {
  padding-left: 15px;
}

ul.asterisk-list li:before {
  content: "※";
}

.asterisk-s-list {
  padding: 0;
  counter-reset: asterisk;
}

.asterisk-s-list li {
  padding-left: 30px;
  list-style: none;
  position: relative;
}

.asterisk-s-list li:before {
  position: absolute;
  left: 0;
  counter-increment: asterisk;
  content: "*" counter(asterisk);
}

ul.asterisk-s-list li {
  padding-left: 15px;
}

ul.asterisk-s-list li:before {
  content: "*";
}

.attention-list {
  padding: 0;
  counter-reset: attention;
}

.attention-list li {
  padding-left: 30px;
  list-style: none;
  position: relative;
}

.attention-list li:before {
  position: absolute;
  left: 0;
  counter-increment: attention;
  content: "注" counter(attention) ")";
}

ul.attention-list li:before {
  content: "(注)";
}

.text-icon-1em, .text-icon-2em, .text-icon-3em, .text-icon-4em, .text-icon-5em, .text-icon-6em, .text-icon-7em, .text-icon-8em, .text-icon-9em, .text-icon-10em, .text-icon-11em, .text-icon-12em {
  position: relative;
}

.text-icon-1em span.text-icon, .text-icon-2em span.text-icon, .text-icon-3em span.text-icon, .text-icon-4em span.text-icon, .text-icon-5em span.text-icon, .text-icon-6em span.text-icon, .text-icon-7em span.text-icon, .text-icon-8em span.text-icon, .text-icon-9em span.text-icon, .text-icon-10em span.text-icon, .text-icon-11em span.text-icon, .text-icon-12em span.text-icon {
  position: absolute;
  display: block;
  left: 0;
}

div > span.text-icon {
  margin-left: 10px;
}

.text-icon-1em {
  padding-left: 1.5em;
}

.text-icon-1em span.text-icon {
  width: 1.5em;
}

.text-icon-2em {
  padding-left: 2.5em;
}

.text-icon-2em span.text-icon {
  width: 2.5em;
}

.text-icon-3em {
  padding-left: 3.5em;
}

.text-icon-3em span.text-icon {
  width: 3.5em;
}

.text-icon-4em {
  padding-left: 4.5em;
}

.text-icon-4em span.text-icon {
  width: 4.5em;
}

.text-icon-5em {
  padding-left: 5.5em;
}

.text-icon-5em span.text-icon {
  width: 5.5em;
}

.text-icon-6em {
  padding-left: 6.5em;
}

.text-icon-6em span.text-icon {
  width: 6.5em;
}

.text-icon-7em {
  padding-left: 7.5em;
}

.text-icon-7em span.text-icon {
  width: 7.5em;
}

.text-icon-8em {
  padding-left: 8.5em;
}

.text-icon-8em span.text-icon {
  width: 8.5em;
}

.text-icon-9em {
  padding-left: 9.5em;
}

.text-icon-9em span.text-icon {
  width: 9.5em;
}

.text-icon-10em {
  padding-left: 10.5em;
}

.text-icon-10em span.text-icon {
  width: 10.5em;
}

.text-icon-11em {
  padding-left: 11.5em;
}

.text-icon-11em span.text-icon {
  width: 11.5em;
}

.text-icon-12em {
  padding-left: 12.5em;
}

.text-icon-12em span.text-icon {
  width: 12.5em;
}

dl dt {
  font-size: 115%;
  color: #555;
}

dl dd {
  margin-bottom: 1em;
}

hr {
  border-top: 1px solid #e5e5e5;
  margin: 20px 0;
}

.blank {
  background: url("../images/layout/window-icon.png") no-repeat right center;
  padding-right: 15px;
  margin-right: 5px;
}

.lead-text {
  margin: 0 0 35px;
  font-weight: bold;
}

table {
  margin: 0 0 23px 0;
  width: 100%;
  background: #fff;
}

table caption {
  font-size: 100%;
  margin-bottom: 10px;
  font-weight: bold;
  text-align: left;
}

table td {
  border: 1px solid #ccc;
  padding: 8px;
  line-height: 172%;
  font-size: 100%;
  word-wrap: break-word;
  text-align: center;
}

table th {
  border: 1px solid #ccc;
  padding: 8px;
  font-size: 100%;
  line-height: 172%;
  background: #f5f5f5;
  word-wrap: break-word;
}

table ul {
  margin: 10px 0;
}

table li {
  font-size: 100%;
}

table p {
  font-size: 100%;
  margin: 0;
}

table.noline {
  background: none;
}

table.noline td {
  border: none;
}

table.noline th {
  border: none;
  background: none;
}

table.bline {
  background: none;
}

table.bline thead + tbody > tr:first-child {
  border-top: 1px solid #707070;
}

table.bline tbody > tr > th + td {
  border-left: 1px dotted #707070;
}

table.bline tr {
  border-bottom: 1px solid #e0e0e0;
}

table.bline thead tr {
  border-bottom: 0px;
}

table.bline tbody tr:nth-child(2n+1) {
  background: whitesmoke;
}

table.bline tbody > tr:first-child {
  border-top: 1px solid #e0e0e0;
}

table.bline td {
  border: none;
}

table.bline th {
  border: none;
  background: none;
  color: #333;
}

table .lg-bg {
  background: #aaa;
}

table .hd-bg {
  background: #777;
  color: #fff;
}

table .ac-bg {
  background: #f5ccd3;
}

.tablewrap {
  padding: 0 10px;
}

.theme-smp .tablewrap {
  overflow-y: hidden;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  position: relative;
}

.theme-smp .tablewrap.noscroll table {
  opacity: 0.4;
}

.theme-smp .tablewrap.scroll table {
  width: auto;
  min-width: 676px;
}

.theme-smp .tablewrap .icon-scroll {
  position: absolute;
  display: block;
  content: '';
  width: 100%;
  height: 56px;
  left: 0;
  top: 0;
  opacity: 0.8;
  background: url("../images/layout/icon_scrollarea.png") no-repeat center center;
  background-size: 56px 56px;
  z-index: 2;
}

.theme-smp .tablewrap table caption {
  background: #fff;
  margin-bottom: 0;
  padding-bottom: 10px;
}

.img-wrap {
  max-width: 100%;
  text-align: center;
  overflow: hidden;
}

.img-wrap .text-left {
  text-align: left;
}

.img-wrap .text-center {
  text-align: center;
}

.img-wrap .text-right {
  text-align: right;
}

.img-wrap img {
  max-width: 100%;
  height: auto;
}

.float-left {
  float: left;
  margin: 0 15px 15px 0;
}

.float-right {
  float: right;
  margin-left: 0 0 15px 15px;
}

.float-tag {
  float: right;
  display: inline-block;
  margin-left: 10px;
}

.float-tag.float-clear {
  clear: right;
}

input, textarea {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Arial, sans-serif;
}

sub, sup {
  font-size: 84%;
}

/*          レスポンシブ対応          */
.theme-multi .l-contents .l-main {
  width: 100%;
}

.theme-multi .l-header #headerwrapper {
  display: none;
}

.theme-multi .footer-switcharea {
  display: none;
}

.theme-multi .l-footer ul.l-utility-navi li {
  padding: 0;
  /* font-size: 90%; */
  /* border-right: 1px solid #999; */
}

/* .theme-multi .l-footer ul.l-utility-navi li:first-child {
  border-left: 1px solid #999;
} */
/* .theme-multi .l-footer ul.l-utility-navi li a {
  font-size: 100%;
  color: #999;
}
.theme-multi .l-footer ul.l-utility-navi li a:hover {
  color: #333;
} */
.theme-multi .l-footer .l-copy br {
  display: none;
}

/*popup 990w*/
.theme-multi.theme-popup.theme-990w .l-global-area {
  background-size: 990px 16px;
  margin: 0 auto;
  position: relative;
  /* background: url(../images/layout/header_arc_bg_center.png) no-repeat center bottom; */
  z-index: 2;
}

.theme-multi.theme-popup.theme-990w .l-global-area,
.theme-multi.theme-popup.theme-990w .l-contents,
.theme-multi.theme-popup.theme-990w .l-footer ul.l-utility-navi,
.theme-multi.theme-popup.theme-990w .l-footer .l-site-data {
  width: 990px;
}

#footer-search-form {
  display: none;
}

.theme-multi.theme-popup .l-footer-popup-close {
  display: none;
}

/* .theme-multi.theme-en.theme-popup .logo-area {
  top: 7px;
  width: 197px;
} */
/* .theme-multi.theme-popup .logo-area {
  top: 8px;
  width: 197px;
} */
@media (max-width: 600px) {
  /*popup 990w*/
  .theme-multi.theme-popup.theme-990w .l-global-area,
  .theme-multi.theme-popup.theme-990w .l-contents,
  .theme-multi.theme-popup.theme-990w .l-footer ul.l-utility-navi,
  .theme-multi.theme-popup.theme-990w .l-footer .l-site-data {
    width: 100%;
  }

  .theme-multi.theme-en.theme-popup .logo-area {
    width: 185px;
  }

  /* .theme-multi.theme-popup .logo-area {
    width: 185px;
    top: 7px;
  } */
  .theme-multi.theme-popup .l-footer-popup-close {
    display: block;
  }

  .theme-multi .l-contents,
  .theme-multi .l-contents .l-main {
    width: 100%;
    margin: 0;
  }

  .theme-multi .l-header > .l-global-navi {
    display: none;
  }

  .theme-multi .l-header .l-global-area-warp {
    display: none;
  }

  .theme-multi .l-header #headerwrapper {
    display: block;
  }

  .theme-multi .dl-menuwrapper div.dl-menu {
    margin: 5px 5px 10px;
    position: absolute;
    background: #fff;
    width: 97%;
    display: none;
    z-index: 10;
    border-radius: 3px;
    -webkit-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    -ms-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
  }

  .theme-multi .dl-menuwrapper div.dl-menu:after {
    content: ' ';
    height: 0;
    position: absolute;
    width: 0;
    border: 10px solid transparent;
    border-bottom-color: #fff;
    bottom: 100%;
    right: 8px;
  }

  .theme-multi .dl-menuwrapper div.dl-menu a:hover {
    text-decoration: none;
    color: #333;
  }

  .theme-multi .dl-menuwrapper div.dl-menu {
    margin: 5px 5px 10px;
    position: absolute;
    background: #fff;
    width: 97%;
    display: none;
    z-index: 10;
    border-radius: 3px;
    -webkit-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    -moz-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    -ms-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
    box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.4);
  }

  .theme-multi .dl-menuwrapper div.dl-menu:after {
    content: ' ';
    height: 0;
    position: absolute;
    width: 0;
    border: 10px solid transparent;
    border-bottom-color: #fff;
    bottom: 100%;
    right: 8px;
  }

  .theme-multi .dl-menuwrapper div.dl-menu a:hover {
    text-decoration: none;
    color: #333;
  }

  .theme-multi .l-global-navi {
    width: 100%;
    min-width: 300px;
    border-radius: 3px 3px 0 0;
  }

  .theme-multi .l-global-navi li {
    margin: 0;
  }

  .theme-multi .l-global-navi li a,
  .theme-multi .l-global-navi li a:hover,
  .theme-multi .l-global-navi li a:active,
  .theme-multi .l-global-navi li a:visited {
    padding: 12px 12px 12px 43px;
    color: #333;
  }

  .theme-multi .l-global-navi li {
    float: none;
    width: 100%;
    position: relative;
    border-bottom: 1px solid #ccc;
    font-size: 115%;
    line-height: 22px;
    font-weight: bold;
    background-color: #fff;
    text-align: left;
  }

  .theme-multi .l-global-navi li:before {
    position: absolute;
    content: url(../images/layout/icon_arrow_right_r.png);
    left: 15px;
    top: 13px;
  }

  .theme-multi .l-global-navi li:first-child {
    border-radius: 3px 3px 0 0;
  }

  .theme-multi .l-global-navi li.n_leisure {
    background-color: #fbdee0;
  }

  .theme-multi .l-extra-navi {
    position: relative;
    top: 0;
    border-radius: 0 0 3px 3px;
    margin: 0;
    right: 0;
  }

  .theme-multi .l-extra-navi li {
    float: none;
    width: 100%;
    height: auto;
    border-bottom: 1px solid #ccc;
    padding: 8px 43px;
    font-weight: bold;
  }

  .theme-multi .l-extra-navi li:last-child::after {
    border-left: none;
  }

  .theme-multi .l-extra-navi li:before {
    position: absolute;
    content: url(../images/layout/icon_arrow_right_r.png);
    left: 15px;
    top: -4px;
    border: none;
  }

  .theme-multi .l-extra-navi li a {
    font-size: 100%;
    color: #333;
  }

  .theme-multi .l-extra-navi li.last {
    border-radius: 0 0 3px 3px;
    border-bottom: 0px;
  }

  .theme-multi .l-extra-navi:last-child li:last-child {
    border-radius: 0 0 3px 3px;
    border-bottom: 0px;
  }

  .theme-multi .l-search-area {
    position: relative;
    width: 100%;
    right: 0;
    top: 0;
    border-bottom: 1px solid #ccc;
    padding: 10px;
  }

  .theme-multi .l-search-area .search-box {
    width: 73%;
    height: 32px;
    border-radius: 3px;
  }

  .theme-multi .l-search-area .search-but {
    width: 25%;
    height: 32px;
    color: #fff;
    font-weight: bold;
    border-radius: 3px;
    background: #626161;
    background: -webkit-linear-gradient(top, #626161, #484747);
    background: linear-gradient(to bottom, #626161, #484747);
    border: 1px solid #717171;
    padding: 0;
  }

  .theme-multi .dl-menuwrapper {
    width: 100%;
    min-width: 320px;
    position: absolute;
    top: 0;
    right: 0;
    padding-top: 54px;
    z-index: 20;
  }

  .theme-multi .dl-menuwrapper hr {
    background: #cc0022;
    border: 0;
    height: 2px;
    margin: 0;
  }

  .theme-multi .dl-menuwrapper ul {
    background: #fff;
    padding: 0;
    list-style: none;
    position: relative;
  }

  .theme-multi .dl-menuwrapper li {
    position: relative;
  }

  .theme-multi .dl-menuwrapper li a {
    display: block;
    position: relative;
    outline: none;
  }

  .theme-multi .l-popup-close {
    border: none;
    width: 52px;
    height: 46px;
    overflow: hidden;
    outline: none;
    position: absolute;
    right: 0;
    top: 10px;
    text-indent: -9999px;
    background: url(../images/layout/mobile_btn_close.png) no-repeat center center;
    background-size: 52px auto;
    margin: 0;
  }

  .theme-en.theme-multi .l-popup-close {
    background: url(../images/layout/mobile_btn_close_en.png) no-repeat center center;
    background-size: 52px auto;
  }

  .theme-multi img {
    max-width: 100%;
  }

  .theme-multi .l-main img {
    height: auto !important;
  }

  .theme-multi .l-header {
    width: auto;
    /* min-width: 320px;
    height: 54px; */
    margin: 0;
    position: relative;
    z-index: 10;
    /* background: url(../images/layout/header_arc_bg_center_m.png) no-repeat bottom left; */
    background-size: 1000px 8px;
  }

  .theme-multi .l-header:before {
    background-color: #cc0022;
    content: "";
    display: block;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
  }

  .theme-multi .l-header:after {
    /* background: url(../images/layout/header_arc_bg_right_m.png) repeat-x bottom center; */
    background-size: 1px 8px;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
  }

  .theme-multi .logo-area {
    /* top: 7px;
    left: 10px;
    width: 185px; */
    z-index: 21;
  }

  .theme-multi .footer-switcharea {
    display: block;
  }

  /*     footer     */
  #footer-search-form {
    display: block;
  }

  .theme-multi .l-footer {
    border-top: 1px solid #ccc;
  }

  .theme-multi .l-footer ul.l-utility-navi {
    width: 100%;
    padding: 0;
  }

  .theme-multi .l-footer ul.l-utility-navi li:last-child::after {
    border-left: none;
  }

  .theme-multi .l-footer ul.l-utility-navi li::before {
    border: none;
  }

  .theme-multi .l-footer ul.l-utility-navi li {
    position: relative;
    width: 100%;
    height: auto;
    border-right: none;
    border-left: none !important;
  }

  .theme-multi .l-footer ul.l-utility-navi li:before {
    position: absolute;
    left: 10px;
    content: url(../images/layout/icon_arrow_right_g.png);
  }

  .theme-pc.theme-multi .l-footer ul.l-utility-navi li:before {
    top: -4px;
  }

  .theme-multi .l-footer ul.l-utility-navi li a,
  .theme-multi .l-footer ul.l-utility-navi li a:hover,
  .theme-multi .l-footer ul.l-utility-navi li a:active,
  .theme-multi .l-footer ul.l-utility-navi li a:visited {
    /* display: block; */
    padding: 9px 4px 9px 25px;
    color: #333;
    font-size: 100%;
    border-bottom: 1px solid #ccc;
  }

  .theme-multi .l-footer .l-footer-popup-close {
    width: 156px;
    margin: 15px auto;
    cursor: pointer;
    text-indent: -9999px;
    overflow: hidden;
    background: url(../images/layout/mobile_footer_close.png) no-repeat center center;
    background-size: 156px 20px;
    border: none;
  }

  .theme-multi.theme-en .l-footer .l-footer-popup-close,
  .theme-multi.theme-en.theme-theme-popup .l-footer .l-footer-popup-close {
    width: 156px;
    margin: 15px auto;
    cursor: pointer;
    text-indent: -9999px;
    overflow: hidden;
    background: url(../images/layout/mobile_footer_close_en.png) no-repeat center center;
    background-size: 156px 20px;
    border: none;
  }

  .theme-multi .l-footer .l-footer-contents {
    position: relative;
    width: 100%;
    height: auto;
    min-width: 320px;
  }

  .theme-multi .l-footer .l-site-data {
    width: 100%;
    min-width: 320px;
  }

  .theme-multi .l-footer .l-copy {
    position: relative;
    text-align: center;
    top: 0;
    right: 0;
    padding: 10px;
    line-height: 143%;
  }

  .theme-multi .l-footer .l-copy br {
    display: block;
  }

  .theme-multi .l-footer .l-footer-logo {
    display: none;
  }
}
/*          グロナビ固定          */
.l-global-navi.is-fixed {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999;
  display: flex;
  justify-content: center;
  background-color: #fff;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
}

.dl-menu .l-global-navi.is-fixed {
  display: block;
  background: #fff;
  padding: 0;
  list-style: none;
  position: relative;
  width: 100%;
  min-width: 300px;
  border-radius: 3px 3px 0 0;
}

@media (max-width: 600px) {
  .theme-multi:not(.theme-pc) .l-header:before, .theme-popup:not(.theme-pc) .l-header:before {
    background-color: #c02;
    content: "";
    display: block;
    height: 1px;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    width: 100%;
  }

  .theme-multi:not(.theme-pc) .logo-area, .theme-popup:not(.theme-pc) .logo-area {
    margin: 0 auto;
    position: relative;
    height: 65px;
    z-index: 21;
    top: auto;
    left: auto;
    transform: none;
    width: 180px;
    left: 0;
  }

  .theme-multi:not(.theme-pc) .logo-area .l-logo, .theme-popup:not(.theme-pc) .logo-area .l-logo {
    height: 65px;
    display: flex;
    align-items: center;
    width: 180px;
  }

  .theme-multi:not(.theme-pc) .logo-area .l-logo a, .theme-popup:not(.theme-pc) .logo-area .l-logo a {
    display: flex;
    flex-flow: column;
    align-items: center;
    height: 50px;
  }

  .theme-multi:not(.theme-pc) .logo-area .l-logo a img:first-child, .theme-popup:not(.theme-pc) .logo-area .l-logo a img:first-child {
    display: block;
    width: 113px;
    height: 26px;
    position: relative;
    top: 2px;
  }

  .theme-multi:not(.theme-pc) .logo-area .l-logo a img:last-child, .theme-popup:not(.theme-pc) .logo-area .l-logo a img:last-child {
    display: block;
    width: 180px;
    height: 28px;
    position: relative;
    right: -5px;
    bottom: 1px;
  }

  .theme-multi:not(.theme-pc) .dl-menuwrapper, .theme-popup.theme-multi:not(.theme-pc) .dl-menuwrapper {
    padding-top: 65px;
  }

  .theme-multi.theme-en:not(.theme-pc) .logo-area .l-logo img:last-child, .theme-popup.theme-en:not(.theme-pc) .logo-area .l-logo img:last-child {
    display: block;
    width: 152px;
    height: 28px;
    right: -1px;
  }
}
@media (min-width: 600px) {
  .l-global-navi:not(.theme-smp .l-global-navi) {
    display: flex;
  }
}

.l-global-navi ul {
  margin: 0 auto;
  padding: 0;
  width: 990px;
  display: flex;
}
.l-global-navi ul li {
  width: 165px;
  position: relative;
}
.l-global-navi ul li.is-active {
  z-index: 3;
  font-weight: bold;
  position: relative;
  background-color: #fff;
}
.l-global-navi ul li.is-active::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 2px;
  border-bottom: 2px solid #cc0022;
  bottom: 0;
  left: 0;
}
.l-global-navi ul li + li a::before {
  border-left: 1px solid rgba(0, 0, 0, 0.2);
  content: '';
  display: block;
  height: 20px;
  left: 0;
  margin-top: -10px;
  position: absolute;
  top: 50%;
}
.l-global-navi ul li a,
.l-global-navi ul li a:hover,
.l-global-navi ul li a:active,
.l-global-navi ul li a:visited {
  align-items: center;
  color: #333;
  display: flex;
  flex-direction: column;
  font-size: 87.5%;
  height: 46px;
  justify-content: center;
  line-height: 113%;
  padding: 0 0.5rem;
  text-align: center;
}
.l-global-navi ul li a:hover,
.l-global-navi ul li a:hover:hover,
.l-global-navi ul li a:active:hover,
.l-global-navi ul li a:visited:hover {
  z-index: 2;
  font-weight: bold;
  background: #ededed;
}
