@charset "UTF-8";
/*
Site Name: SJ（レスポンシブ）
Version: 2023.06.14
*/
/*! ==================================================

  このCSSファイルはSassから生成されていますので
  編集しないようご注意ください。

================================================== */
html {
  overflow-y: scroll;
}

body {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  background: transparent;
  border: 0;
  font-size: 100%;
  list-style: none;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
  word-wrap: break-word;
}

sub,
sup {
  border: 0;
  margin: 0;
  outline: 0;
  padding: 0;
  _position: relative;
}

sup {
  _bottom: 0.2em;
  _vertical-align: baseline;
}

sub {
  _vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
  content: none;
}

a {
  background: transparent;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

ins {
  background-color: #ff9;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  border: 0;
  border-top: 1px solid #ccc;
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Arial", sans-serif;
  vertical-align: middle;
}

header,
section,
footer {
  margin: 0 !important;
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: top;
}

/*
======================================================
  base
--------------------------------------------------- */
.ma0 {
  margin: 0 !important;
}

.ma05 {
  margin: 5px !important;
}

.ma10 {
  margin: 10px !important;
}

.ma20 {
  margin: 20px !important;
}

.ma30 {
  margin: 30px !important;
}

.ma40 {
  margin: 40px !important;
}

.ma50 {
  margin: 50px !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mr05 {
  margin-right: 5px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.ml0 {
  margin-left: 0 !important;
}

.ml05 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

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

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

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

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

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

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

.mt50 {
  margin-top: 50px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

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

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

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

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

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

.mb50 {
  margin-bottom: 50px !important;
}

.mb1 {
  margin-bottom: 18px !important;
}

.mb2 {
  margin-bottom: 28px !important;
}

.mb3 {
  margin-bottom: 38px !important;
}

.mb4 {
  margin-bottom: 48px !important;
}

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

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

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

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

.pa0 {
  padding: 0 !important;
}

.pa10 {
  padding: 10px !important;
}

.pa20 {
  padding: 20px !important;
}

.pa30 {
  padding: 30px !important;
}

.pa40 {
  padding: 40px !important;
}

.pa50 {
  padding: 50px !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pl0 {
  padding-left: 0 !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

/* fontsize */
.fontL {
  font-size: 100% !important;
}

.fontM {
  font-size: 87.5% !important;
}

.fontS {
  font-size: 75% !important;
}

/* linkicon */
.linkiconG,
#sideArea .contactbox .link,
.main .contactbox .link {
  background: url(../SJ/common/images/icon_arrow_g.gif) no-repeat 0 4px;
  padding: 0 0 0 12px;
}

/* link */
a {
  color: #66a;
  text-decoration: none;
}

a:visited {
  color: #9b9dff;
}

a:hover {
  color: #448;
  text-decoration: underline;
}

a:active {
  color: #448;
}

/* contentswrapper */
@media screen and (min-width: 1024px) {
  #contentswrapper {
    background: #fff;
    margin: 0 auto;
    position: relative;
    width: 990px;
    z-index: 0;
  }
  #contentswrapper::after {
    clear: both;
    content: "";
    display: table;
  }
}
@media screen and (max-width: 1023px) {
  #contentswrapper {
    margin: 0 auto;
    min-width: 320px;
    overflow: hidden;
    width: 100%;
  }
}

@media screen and (min-width: 1024px) {
  #mainArea {
    float: left;
    margin: 18px 0 21px 21px;
    position: relative;
    width: 696px;
  }
  #mainArea::after {
    clear: both;
    content: "";
    display: table;
  }
}
@media screen and (max-width: 1023px) {
  #mainArea {
    float: none;
    margin: 20px auto;
    width: 94%;
  }
}

@media screen and (min-width: 1024px) {
  #sideArea {
    float: right;
    margin: 18px 21px 21px 0;
    position: relative;
    width: 222px;
  }
  #sideArea::after {
    clear: both;
    content: "";
    display: table;
  }
}
@media screen and (max-width: 1023px) {
  #sideArea {
    float: none;
    margin: 20px auto;
    width: 94%;
  }
}
@media screen and (max-width: 767px) {
  #sideArea {
    width: 100%;
  }
}

/*
======================================================
  body
--------------------------------------------------- */
html {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "メイリオ", "Meiryo", "Arial", sans-serif;
  font-size: 62.5%;
  height: 100%;
  -webkit-overflow-scrolling: touch;
  overflow-y: scroll;
}

body {
  background: #fff;
  height: 100%;
  position: relative;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
          text-size-adjust: none;
  zoom: 1;
}

body {
  color: #333;
  font-size: 1.6rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-weight: 400;
  line-height: 1;
  -webkit-overflow-scrolling: touch;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
          text-size-adjust: none;
  width: 100%;
  word-wrap: break-word;
}

#wrapper {
  font-size: 87.5%;
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 768px) {
  #wrapper {
    *padding-left: 1px;
  }
}
@media screen and (max-width: 767px) {
  #wrapper {
    background: none;
    background-color: #fff;
  }
}
#wrapper::after {
  clear: both;
  content: "";
  display: table;
}

@media screen and (min-width: 768px) {
  html[xmlns*=""]:root #wrapper {
    padding-left: 1px;
  }
}
/*
======================================================
  header
--------------------------------------------------- */
.header {
  position: relative;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .header#header-pc {
    display: block;
  }
}
@media screen and (max-width: 1023px) {
  .header#header-pc {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .header {
    background-size: 1px 16px;
    height: 82px;
    margin: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 1023px) {
  .header {
    background: url(../SJ/common/images/mobile/header_arc_bg_center_m.png) no-repeat bottom left;
    background-size: 1000px 8px;
    height: 70px;
    margin: 0;
    z-index: 10;
  }
}
@media screen and (max-width: 767px) {
  .header {
    height: 54px;
    min-width: 320px;
  }
}
.header::before {
  background-color: #c02;
  bottom: 0;
  content: "";
  display: block;
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: 1;
}
.header::after {
  background: url(../SJ/common/images/header_arc_bg_right.png) repeat-x center bottom;
  bottom: 0;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 1;
}
@media screen and (min-width: 960px) and (max-width: 2400px) {
  .header::after {
    width: 33%;
  }
}
@media (min-width: 2401px) and (max-width: 4000px) {
  .header::after {
    width: 40%;
  }
}
@media screen and (max-width: 1023px) {
  .header::after {
    background: url(../SJ/common/images/mobile/header_arc_bg_right_m.png) repeat-x bottom center;
    background-size: 1px 8px;
  }
}
@media screen and (min-width: 1024px) {
  .header#header-mobile {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  .header#header-mobile {
    display: block;
  }
}

.headerwrapper {
  position: relative;
}
@media screen and (min-width: 1024px) {
  .headerwrapper {
    background: url(../SJ/common/images/header_arc_bg_center.png) no-repeat center bottom;
    background-size: 960px 16px;
    height: 82px;
    margin: 0 auto;
    padding: 0;
    width: 990px;
    z-index: 2;
  }
}
@media screen and (max-width: 1023px) {
  .headerwrapper {
    height: 70px;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .headerwrapper {
    height: 54px;
  }
}

.logo {
  left: 21px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 187px;
}
@media screen and (max-width: 1023px) {
  .logo {
    left: 5px;
    z-index: 99999;
  }
  .logo img {
    height: 35px;
    width: auto;
  }
}

#logo-pc,
#logo-mobile {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

@media screen and (min-width: 1024px) {
  #logo-pc {
    left: 21px;
    width: 187px;
  }
}

@media screen and (max-width: 1023px) {
  #logo-mobile {
    left: 5px;
    z-index: 99999;
  }
  #logo-mobile img {
    height: 45px;
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  #logo-mobile img {
    height: 35px;
  }
}

#group_logo-pc {
  position: absolute;
  right: 19px;
}
@media screen and (min-width: 1024px) {
  #group_logo-pc {
    top: 16px;
    width: 200px;
  }
}
@media screen and (max-width: 1023px) {
  #group_logo-pc {
    display: none;
  }
}

/*
======================================================
  pc-nav
--------------------------------------------------- */
#headernavi {
  position: absolute;
  right: 232px;
  top: 10px;
}
#headernavi li {
  float: left;
}
#headernavi li a {
  display: block;
  height: 14px;
}

#search_form {
  position: absolute;
  right: 375px;
  top: 35px;
  width: 257px;
}
#search_form .searchBox {
  border: 1px solid #dadada;
  color: #444;
  float: left;
  font-size: 93%;
  height: 15px;
  margin-right: 5px;
  margin-top: 1px;
  padding: 2px;
  width: 191px;
}
#search_form legend {
  display: none;
}

.main #search_form_inner .searchBox,
.basic-element #search_form_inner .searchBox {
  background: #fcfcfc;
  border: 1px solid #d9d9d9;
  color: #444;
  float: left;
  font-size: 93%;
  height: 15px;
  _margin-right: 2px;
  margin-top: 1px;
  *padding: 4px 2px 0;
  width: 65%;
}

.font_size {
  position: absolute;
  right: 232px;
  top: 35px;
  _width: 140px;
}
.font_size p {
  color: #999;
  float: left;
  font-size: 12px;
  padding: 5px 0;
  width: 58px;
}
.font_size ul {
  float: left;
}
.font_size ul li {
  background: none no-repeat 0 0 transparent;
  cursor: pointer;
  display: block;
  float: left;
  height: 22px;
  margin-left: 5px;
  width: 20px;
}
.font_size ul li.active {
  background-position: left top;
  background-repeat: no-repeat;
}
.font_size ul li.active img {
  visibility: hidden;
}
.font_size #fontS {
  background-image: url(../SJ/common/images/fontsize_s_on.gif);
}
.font_size #fontM {
  background-image: url(../SJ/common/images/fontsize_m_on.gif);
}
.font_size #fontL {
  background-image: url(../SJ/common/images/fontsize_l_on.gif);
}

/* globalnavi_megamenu */
@media screen and (max-width: 1023px) {
  .globalnaviWrapper {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .globalnaviWrapper {
    position: relative;
    z-index: 9999;
  }
}
.globalnaviWrapper #globalnavi .itemBtn {
  cursor: pointer;
}
.globalnaviWrapper #globalnavi .itemContent {
  display: none;
  left: 0;
  position: absolute;
  width: 100%;
}
.globalnaviWrapper.is-fixed {
  background-color: #fff;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.2);
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
}

.globalnaviWrapper #globalnavi {
  height: 46px;
  margin: 0 auto;
  position: relative;
  width: 990px;
}
.globalnaviWrapper #globalnavi .globalnaviItem {
  background: no-repeat 0 0 transparent;
  float: left;
  height: 46px;
  width: 165px;
}
.globalnaviWrapper #globalnavi .globalnaviItem .itemBtn {
  background: no-repeat 0 0 transparent;
  display: block;
  height: 46px;
  width: 165px;
}
.globalnaviWrapper #globalnavi .globalnaviItem .itemBtn:hover, .globalnaviWrapper #globalnavi .globalnaviItem .itemBtn:active, .globalnaviWrapper #globalnavi .globalnaviItem .itemBtn.ac {
  background-position: left top;
  background-repeat: no-repeat;
}
.globalnaviWrapper #globalnavi .globalnaviItem .itemBtn:hover img, .globalnaviWrapper #globalnavi .globalnaviItem .itemBtn:active img, .globalnaviWrapper #globalnavi .globalnaviItem .itemBtn.ac img {
  visibility: hidden;
}
.globalnaviWrapper #globalnavi #covenanter {
  background-image: url(../SJ/common/images/sjnk_gnav_covenanter_on.gif);
}
.globalnaviWrapper #globalnavi #covenanter .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_covenanter_on.gif);
}
.globalnaviWrapper #globalnavi #covenanter .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_covenanter_on.gif);
}
.globalnaviWrapper #globalnavi #covenanter .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_covenanter_ac.gif);
}
.globalnaviWrapper #globalnavi #individual {
  background-image: url(../SJ/common/images/sjnk_gnav_individual_on.gif);
}
.globalnaviWrapper #globalnavi #individual .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_individual_on.gif);
}
.globalnaviWrapper #globalnavi #individual .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_individual_on.gif);
}
.globalnaviWrapper #globalnavi #individual .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_individual_ac.gif);
}
.globalnaviWrapper #globalnavi #corporate {
  background-image: url(../SJ/common/images/sjnk_gnav_corporate_on.gif);
}
.globalnaviWrapper #globalnavi #corporate .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_corporate_on.gif);
}
.globalnaviWrapper #globalnavi #corporate .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_corporate_on.gif);
}
.globalnaviWrapper #globalnavi #corporate .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_corporate_ac.gif);
}
.globalnaviWrapper #globalnavi #about {
  background-image: url(../SJ/common/images/sjnk_gnav_about_on.gif);
}
.globalnaviWrapper #globalnavi #about .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_about_on.gif);
}
.globalnaviWrapper #globalnavi #about .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_about_on.gif);
}
.globalnaviWrapper #globalnavi #about .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_about_ac.gif);
}
.globalnaviWrapper #globalnavi #csr {
  background-image: url(../SJ/common/images/sjnk_gnav_csr_on.gif);
}
.globalnaviWrapper #globalnavi #csr .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_csr_on.gif);
}
.globalnaviWrapper #globalnavi #csr .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_csr_on.gif);
}
.globalnaviWrapper #globalnavi #csr .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_csr_ac.gif);
}
.globalnaviWrapper #globalnavi #contact {
  background-image: url(../SJ/common/images/sjnk_gnav_contact_on.gif);
}
.globalnaviWrapper #globalnavi #contact .itemBtn {
  background-image: url(../SJ/common/images/sjnk_gnav_contact_on.gif);
}
.globalnaviWrapper #globalnavi #contact .itemBtn:hover {
  background-image: url(../SJ/common/images/sjnk_gnav_contact_on.gif);
}
.globalnaviWrapper #globalnavi #contact .itemBtn.ac {
  background-image: url(../SJ/common/images/sjnk_gnav_contact_ac.gif);
}

/* color */
.megamenu {
  box-shadow: 0 10px 7px rgba(0, 0, 0, 0.15);
  float: none;
  height: auto;
  width: 100%;
}

.megamenu .megamenuHeader {
  align-items: center;
  background-color: #c02;
  display: flex;
  justify-content: space-between;
  padding: 20px;
}

.megamenu .megamenuHeader .heading a {
  color: #fff;
  font-size: 150%;
  font-weight: bold;
  height: auto;
  width: auto;
}

.megamenu .megamenuHeader .heading a::after {
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  content: "";
  display: inline-block;
  height: 13px;
  margin-left: 10px;
  transform: rotate(45deg);
  width: 13px;
}

.megamenu .megamenuHeader .close button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: transparent;
  border: none;
  color: #fff;
  cursor: pointer;
  font-size: 115%;
  font-weight: bold;
  outline: none;
  padding: 0;
  padding-right: 40px;
  position: relative;
}

.megamenu .megamenuHeader .close button::before,
.megamenu .megamenuHeader .close button::after {
  background-color: #fff;
  content: "";
  display: block;
  height: 2px;
  position: absolute;
  right: 0;
  top: calc(50% - 1px);
  width: 30px;
}

.megamenu .megamenuHeader .close button::before {
  transform: rotate(45deg);
}

.megamenu .megamenuHeader .close button::after {
  transform: rotate(-45deg);
}

.megamenu .megamenuBody {
  background-color: #f0f0f0;
  padding: 30px 30px 10px;
}

.megamenu .megamenuBody .megamenu-row {
  display: flex;
  margin-left: -15px;
  margin-right: -15px;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-1,
.megamenu .megamenuBody .megamenu-row .megamenu-col-2,
.megamenu .megamenuBody .megamenu-row .megamenu-col-3,
.megamenu .megamenuBody .megamenu-row .megamenu-col-4,
.megamenu .megamenuBody .megamenu-row .megamenu-col-5,
.megamenu .megamenuBody .megamenu-row .megamenu-col-6,
.megamenu .megamenuBody .megamenu-row .megamenu-col-7,
.megamenu .megamenuBody .megamenu-row .megamenu-col-8,
.megamenu .megamenuBody .megamenu-row .megamenu-col-9,
.megamenu .megamenuBody .megamenu-row .megamenu-col-10,
.megamenu .megamenuBody .megamenu-row .megamenu-col-11,
.megamenu .megamenuBody .megamenu-row .megamenu-col-12,
.megamenu .megamenuBody .megamenu-row .megamenu-col,
.megamenu .megamenuBody .megamenu-row .megamenu-col-auto {
  box-sizing: border-box;
  min-height: 1px;
  padding-left: 15px;
  padding-right: 15px;
  position: relative;
  width: 100%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-1 {
  width: 8.33333%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-2 {
  width: 16.66667%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-3 {
  width: 25%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-4 {
  width: 33.33333%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-5 {
  width: 41.66667%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-6 {
  width: 50%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-7 {
  width: 58.33333%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-8 {
  width: 66.66667%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-9 {
  width: 75%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-10 {
  width: 83.33333%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-11 {
  width: 91.66667%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-12 {
  width: 100%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col {
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
}

.megamenu .megamenuBody .megamenu-row .megamenu-col-auto {
  flex: 0 0 auto;
  max-width: none;
  width: auto;
}

.megamenu .megamenuBody .image img {
  max-width: 100%;
  width: auto;
}

.megamenu .megamenuBody .verticalLinkBox.bdTopRed {
  border-top: 3px solid #c02;
}

.megamenu .megamenuBody .mypageGuidance {
  background-color: #fff;
  border-bottom: 1px solid #c02;
  border-left: 1px solid #c02;
  border-right: 1px solid #c02;
  border-top: 3px solid #c02;
  box-sizing: border-box;
  height: calc(100% - 20px);
  padding: 20px;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody {
  display: flex;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidanceMypage {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidanceMypage .guidanceGroup .link {
  display: block;
  text-align: center;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidanceMypage .guidanceGroup .link .mypageLogo {
  display: inline-block;
  margin-bottom: 10px;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidanceMypage .guidanceGroup .link .mypageLogo img {
  width: 160px;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin {
  display: flex;
  flex: 2;
  flex-wrap: wrap;
  justify-content: center;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .guidanceGroup {
  width: calc(50% - 7px);
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .guidanceGroup + .guidanceGroup {
  margin-left: 14px;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .textBtlinkUI {
  width: 100%;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .textBtlinkUI a {
  box-sizing: border-box;
  padding: 15px 2% 14px;
  width: 100%;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .textBtlinkRUI {
  width: 100%;
}

.megamenu .megamenuBody .mypageGuidance .guidanceBody .guidancelogin .textBtlinkRUI a {
  box-sizing: border-box;
  padding: 15px 2% 14px;
  width: 100%;
}

.megamenu .megamenuBody .btnWrap {
  margin: auto;
  width: calc(33.3333333333% - 30px);
}

.megamenu .megamenuBody p {
  line-height: 1.6em;
  margin: 0 0 20px;
}

.megamenu .megamenuBody .altextC {
  text-align: center;
}

.megamenu .megamenuBody .sttextR {
  color: #c02 !important;
}

.megamenu .megamenuBody .sttextG {
  font-weight: bold;
}

.megamenu .megamenuBody .textS {
  font-size: 86%;
}

.megamenu .megamenuBody .textL {
  font-size: 115%;
}

.megamenu .megamenuBody .textLL {
  font-size: 129%;
}

.megamenu .megamenuBody .arrowlistR li {
  background: url(../SJ/common/images/icon_arrow_r.gif) no-repeat 2px 4px;
  background-position: 2px 4px;
  color: #333;
  font-size: 100%;
  line-height: 136%;
  list-style: none;
  margin: 0 0 6px;
  padding: 0 0 0 12px;
  zoom: 1;
}

.megamenu .megamenuBody .arrowlistR li:last-child {
  margin-bottom: 0;
}

.megamenu .megamenuBody .arrowlistR li ul {
  margin-bottom: 0;
}

.megamenu .megamenuBody .arrowlinkR {
  background: url(../SJ/common/images/icon_bt_arrow_r.gif) no-repeat left center;
  padding: 0 0 0 20px;
}

.megamenu .megamenuBody .btnTypeRedRound.arrowBottom a {
  background-image: url(../SJ/common/images/icon_uarrow_w.gif);
}

.megamenu .megamenuBody .btnTypeRedRound a {
  background-color: #c02;
  background-image: url(../SJ/common/images/icon_arrow_w.gif);
  background-position: 15px center;
  background-repeat: no-repeat;
  border-radius: 35px;
  box-sizing: border-box;
  color: #fff;
  display: inline-block;
  font-size: 115%;
  font-weight: bold;
  margin: 0 auto;
  padding: 10px 35px;
}

.megamenu .megamenuBody .btnTypeRedRound a .btnInner {
  display: table;
  min-height: 50px;
  width: 100%;
}

.megamenu .megamenuBody .btnTypeRedRound a .btnInner .btText {
  display: table-cell;
  vertical-align: middle;
}

.megamenu .megamenuBody .btnTypeRedRound a .btnInner .btText .btTitle {
  line-height: 1.5;
}

.megamenu .megamenuBody .btnTypeRedRound a:hover {
  background-color: #9d001a;
  text-decoration: none;
}

.megamenu .megamenuBody .btnTypeRedRound a.w1 {
  width: 30%;
}

.megamenu .megamenuBody .btnTypeRedRound a.w2 {
  width: 50%;
}

.megamenu .megamenuBody .btnTypeRedRound a.w3 {
  width: 75%;
}

.megamenu .megamenuBody .btnTypeRedRound a.w4 {
  width: 100%;
}

.megamenu .megamenuBody .btnTypeRedRound.btnAlignHeight {
  height: calc(100% - 20px);
}

.megamenu .megamenuBody .btnTypeRedRound.btnAlignHeight a {
  height: 100%;
}

.megamenu .megamenuBody .btnTypeRedRound.btnAlignHeight a .btnInner {
  height: 100%;
}

.megamenu .megamenuBody .horizontalLinkBox,
.megamenu .megamenuBody .verticalLinkBox,
.megamenu .megamenuBody .verticalBox {
  background-color: #fff;
  box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
  display: flex;
  height: calc(100% - 20px);
  margin: 0 0 20px;
  position: relative;
  text-decoration: none;
  width: 100%;
}

.megamenu .megamenuBody .horizontalLinkBox span,
.megamenu .megamenuBody .verticalLinkBox span,
.megamenu .megamenuBody .verticalBox span {
  color: #333;
  display: block;
  line-height: 150%;
  margin-left: 0;
  margin-right: 0;
}

.megamenu .megamenuBody .horizontalLinkBox .sttextGn,
.megamenu .megamenuBody .verticalLinkBox .sttextGn,
.megamenu .megamenuBody .verticalBox .sttextGn {
  color: #00b900;
}

.megamenu .megamenuBody .horizontalLinkBox .inlineText,
.megamenu .megamenuBody .verticalLinkBox .inlineText,
.megamenu .megamenuBody .verticalBox .inlineText {
  display: inline;
}

.megamenu .megamenuBody .horizontalLinkBox .arrowlinkR,
.megamenu .megamenuBody .verticalLinkBox .arrowlinkR,
.megamenu .megamenuBody .verticalBox .arrowlinkR {
  margin-left: -8px;
  padding-left: 25px;
}

.megamenu .megamenuBody .horizontalLinkBox .tel,
.megamenu .megamenuBody .verticalLinkBox .tel,
.megamenu .megamenuBody .verticalBox .tel {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "メイリオ", "Meiryo", "Arial", sans-serif;
  font-size: 172%;
  font-weight: bold;
}

.megamenu .megamenuBody .horizontalLinkBox.pa10.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalLinkBox.pa10.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalBox.pa10.externalLinkIcon .icon {
  bottom: 3px;
  position: absolute;
  right: 0;
}

.megamenu .megamenuBody .horizontalLinkBox.pa20.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalLinkBox.pa20.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalBox.pa20.externalLinkIcon .icon {
  bottom: 7px;
  position: absolute;
  right: 3px;
}

.megamenu .megamenuBody .horizontalLinkBox.pa30.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalLinkBox.pa30.externalLinkIcon .icon,
.megamenu .megamenuBody .verticalBox.pa30.externalLinkIcon .icon {
  bottom: 8px;
  position: absolute;
  right: 8px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .subTitle,
.megamenu .megamenuBody .horizontalLinkBox .content .title,
.megamenu .megamenuBody .verticalLinkBox .content .subTitle,
.megamenu .megamenuBody .verticalLinkBox .content .title,
.megamenu .megamenuBody .verticalBox .content .subTitle,
.megamenu .megamenuBody .verticalBox .content .title {
  font-weight: bold;
  margin-bottom: 0;
}

.megamenu .megamenuBody .horizontalLinkBox .content .subTitle,
.megamenu .megamenuBody .verticalLinkBox .content .subTitle,
.megamenu .megamenuBody .verticalBox .content .subTitle {
  font-size: 19px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .title,
.megamenu .megamenuBody .verticalLinkBox .content .title,
.megamenu .megamenuBody .verticalBox .content .title {
  font-size: 27px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .outline,
.megamenu .megamenuBody .verticalLinkBox .content .outline,
.megamenu .megamenuBody .verticalBox .content .outline {
  color: #000;
  margin-top: 10px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .textTop,
.megamenu .megamenuBody .verticalLinkBox .content .textTop,
.megamenu .megamenuBody .verticalBox .content .textTop {
  min-height: 42px;
  width: 100%;
}

.megamenu .megamenuBody .horizontalLinkBox .content .textTop .arrowlinkR,
.megamenu .megamenuBody .verticalLinkBox .content .textTop .arrowlinkR,
.megamenu .megamenuBody .verticalBox .content .textTop .arrowlinkR {
  background: url(../SJ/common/images/icon_bt_arrow_r.gif) no-repeat left top -6px;
  display: inline;
  margin-left: -15px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .iconBottom,
.megamenu .megamenuBody .verticalLinkBox .content .iconBottom,
.megamenu .megamenuBody .verticalBox .content .iconBottom {
  height: 60px;
  margin: 0;
}

.megamenu .megamenuBody .horizontalLinkBox .content .iconBottom img,
.megamenu .megamenuBody .verticalLinkBox .content .iconBottom img,
.megamenu .megamenuBody .verticalBox .content .iconBottom img {
  height: inherit;
  width: auto;
}

.megamenu .megamenuBody .horizontalLinkBox .content.contentVerticalAlignMiddle,
.megamenu .megamenuBody .verticalLinkBox .content.contentVerticalAlignMiddle,
.megamenu .megamenuBody .verticalBox .content.contentVerticalAlignMiddle {
  vertical-align: middle;
}

.megamenu .megamenuBody .horizontalLinkBox .image {
  padding: 0 27px 0 0;
  vertical-align: middle;
}

.megamenu .megamenuBody .horizontalLinkBox .content {
  flex: 1;
}

.megamenu .megamenuBody .horizontalLinkBox .content.bdLeftGray {
  border-left: 1px solid #d9d9d9;
}

.megamenu .megamenuBody .horizontalLinkBox .content .subTitle {
  font-size: 19px;
}

.megamenu .megamenuBody .horizontalLinkBox .content .subTitle.arrowlinkR {
  background-position-y: -3px;
}

.megamenu .megamenuBody .horizontalLinkBox.bdTopRed {
  border-top: 3px solid #c02;
}

.megamenu .megamenuBody .verticalLinkBox {
  flex-direction: column;
}

.megamenu .megamenuBody .verticalLinkBox .image {
  margin: 0 0 24px;
}

.megamenu .megamenuBody .verticalLinkBox .horizontalInner {
  align-items: center;
  display: flex;
  justify-content: center;
}

.megamenu .megamenuBody .verticalLinkBox .horizontalInner .horizontalInnerImage {
  padding-right: 15px;
}

.megamenu .megamenuBody .verticalLinkBox .horizontalInner .horizontalInnerImage img {
  width: 45px;
}

.megamenu .megamenuBody .verticalLinkBox .content.contentVerticalAlignMiddle {
  height: 100%;
}

.megamenu .megamenuBody .verticalBox .content {
  flex: 1;
}

.megamenu .megamenuBody .textBtlinkUI {
  text-align: center;
}

.megamenu .megamenuBody .textBtlinkUI a {
  background: #666 url(../SJ/common/images/gy_btui_bg.gif) no-repeat left top;
  border-bottom: 2px solid #525252;
  border-right: 2px solid #525252;
  color: #fff;
  display: inline-block;
  line-height: 1;
  padding: 15px 2% 14px 28px;
}

.megamenu .megamenuBody .textBtlinkUI a:hover {
  background: #666 url(../SJ/common/images/gy_btui_bg_on.gif) no-repeat left top;
  border-bottom: 2px solid #3f3f3f;
  border-right: 2px solid #3f3f3f;
  text-decoration: none;
}

.megamenu .megamenuBody .textBtlinkRUI {
  text-align: center;
}

.megamenu .megamenuBody .textBtlinkRUI a {
  background: #c02 url(../SJ/common/images/gy_btrui_bg.gif) no-repeat left top;
  border-bottom: 2px solid #a3001b;
  border-right: 2px solid #a3001b;
  color: #fff;
  display: inline-block;
  line-height: 1;
  padding: 15px 2% 14px 28px;
}

.megamenu .megamenuBody .textBtlinkRUI a:hover {
  background: #9d001a url(../SJ/common/images/gy_btrui_bg_on.gif) no-repeat left top;
  border-bottom: 2px solid #7d0015;
  border-right: 2px solid #7d0015;
  text-decoration: none;
}

.megamenu .megamenuBody .textBtlinkRUI a.txtL {
  font-size: 18px;
}

.megamenu .megamenuBody .btnTypeWhite a {
  background-color: #fff;
  background-image: url(../SJ/common/images/icon_bt_arrow_g.gif);
  background-position: 5px center;
  background-repeat: no-repeat;
  border: 1px solid #d9d9d9;
  box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
  color: #333;
  display: inline-block;
  font-weight: bold;
  line-height: 136%;
  padding: 12px 35px 11px;
  position: relative;
  text-decoration: none;
}

.megamenu .megamenuBody .btnTypeWhite a.BtR {
  background-image: url(../SJ/common/images/icon_bt_arrow_r.gif);
}

.megamenu .megamenuBody .btnTypeWhite a.w1 {
  width: 30%;
}

.megamenu .megamenuBody .btnTypeWhite a.w2 {
  width: 50%;
}

.megamenu .megamenuBody .btnTypeWhite a.w3 {
  width: 75%;
}

.megamenu .megamenuBody .btnTypeWhite a.w4 {
  width: 100%;
}

.megamenu .megamenuBody .btnTypeWhite a .icon {
  margin: -6px 0 0;
  position: absolute;
  right: 11px;
  top: 50%;
}

.megamenu .megamenuBody .btnTypeWhite.altextC .btnInner {
  justify-content: center;
}

.megamenu .megamenuBody .btnTypeWhite .btnInner {
  align-items: center;
  display: flex;
  min-height: 45px;
  width: 100%;
}

.megamenu .megamenuBody .btnTypeWhite .btImage {
  padding-right: 15px;
  width: 45px;
}

.megamenu .megamenuBody .btnTypeWhite .btImage img {
  width: inherit;
}

.megamenu .megamenuBody .btnTypeWhite .btText > span {
  display: block;
}

.megamenu .megamenuBody .btnTypeWhite .btText .btTitle {
  font-size: 115%;
}

.megamenu .megamenuBody .btnTypeWhite .btText .btOutline {
  font-size: 86%;
  margin-top: 5px;
}

.megamenu .megamenuBody .btnTypeWhite .btText .btTel {
  color: #c02;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "メイリオ", "Meiryo", "Arial", sans-serif;
  font-size: 157%;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall a {
  padding: 12px 30px 12px 35px;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner {
  min-height: auto;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner > .btImage,
.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText {
  display: inline-block;
  vertical-align: middle;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText > span {
  display: inline-block;
  vertical-align: middle;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText .btTitle {
  font-size: 100%;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText .btTitle + .textS,
.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText .btTitle + .btTel {
  margin-left: 5px;
}

.megamenu .megamenuBody .btnTypeWhite.btnSmall .btnInner .btText .textS {
  font-weight: normal;
}

.megamenu .megamenuBody .btnTypeWhite.btnAlignHeight {
  height: calc(100% - 20px);
}

.megamenu .megamenuBody .btnTypeWhite.btnAlignHeight a {
  height: 100%;
}

.megamenu .megamenuBody .btnTypeWhite.btnAlignHeight a .btnInner {
  height: 100%;
}

/*
======================================================
  mobile-nav
--------------------------------------------------- */
p.dl-trigger {
  background: url(../SJ/common/images/mobile/mobile_btn_menu.png) no-repeat 0 0;
  background-size: 52px 46px;
  border: none;
  cursor: pointer;
  height: 46px;
  outline: none;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
  width: 52px;
}
@media screen and (min-width: 768px) {
  p.dl-trigger {
    background-size: 70px 62px;
    height: 62px;
    width: 70px;
  }
}
p.dl-trigger.close {
  background: url(../SJ/common/images/mobile/mobile_btn_close.png) no-repeat 0 0;
  background-size: 52px 46px;
}
@media screen and (min-width: 768px) {
  p.dl-trigger.close {
    background-size: 70px 62px;
  }
}
p.dl-trigger img {
  height: 30px;
  margin: 7px 10px;
  width: 26px;
}

.dl-menuwrapper {
  min-width: 320px;
  padding-top: 54px;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  z-index: 9999;
}
@media screen and (min-width: 768px) {
  .dl-menuwrapper {
    padding-top: 70px;
  }
}
.dl-menuwrapper hr {
  background: #c02;
  border: 0;
  height: 2px;
  margin: 0;
}

.dl-menuwrapper ul {
  background: #fff;
  list-style: none;
  padding: 0;
  position: relative;
}
.dl-menuwrapper ul li {
  position: relative;
}
.dl-menuwrapper ul li a {
  display: block;
  outline: none;
  position: relative;
  text-decoration: none;
}
.dl-menuwrapper div.dl-menu {
  background: #fff;
  border-radius: 3px;
  box-shadow: rgba(0, 0, 0, 0.4) 0 0 3px;
  display: none;
  margin: 5px 5px 10px;
  position: absolute;
  width: 97%;
  z-index: 10;
}
.dl-menuwrapper div.dl-menu::after {
  border: 10px solid transparent;
  border-bottom-color: #fff;
  bottom: 100%;
  content: " ";
  height: 0;
  position: absolute;
  right: 8px;
  width: 0;
}
.dl-menuwrapper div.dl-menu a:hover {
  color: #333;
  text-decoration: none;
}
.dl-menuwrapper div.dl-menu .text_btn_r {
  background: linear-gradient(to bottom, #cc0021, #ab001c);
  background-color: #cc0021;
  border-radius: 3px;
  margin: 8px;
}
.dl-menuwrapper div.dl-menu .text_btn_r a {
  background: url(../SJ/common/images/mobile/mobile_icon_arrow_w.png) no-repeat 15px 15px;
  background-size: 6px 12px;
  color: #fff;
  display: block;
  font-size: 115%;
  font-weight: bold;
  padding: 15px 15px 15px 37px;
}
.dl-menuwrapper div.dl-menu ul {
  border-top: 1px solid #ccc;
  margin: 0;
}
.dl-menuwrapper div.dl-menu ul.g_nav:first-child {
  border-top: 0;
}
.dl-menuwrapper div.dl-menu ul.g_nav li {
  background: linear-gradient(to bottom, #fefefe, #efefef);
  background-color: #fefefe;
  border-bottom: 1px solid #ccc;
  font-size: 115%;
  font-weight: bold;
}
.dl-menuwrapper div.dl-menu ul.g_nav li a {
  background: url(../SJ/common/images/mobile/mobile_arrow_r_r.png) no-repeat right center;
  background-size: 40px 40px;
  color: #333;
  padding: 15px 45px;
}
.dl-menuwrapper div.dl-menu ul.g_nav li a img {
  height: 40px;
  left: 3px;
  position: absolute;
  top: 3px;
  vertical-align: middle;
  width: 40px;
}
.dl-menuwrapper div.dl-menu ul.g_nav li.n_leisure {
  background: linear-gradient(to bottom, #fbdee0, #ffc5ca);
  background-color: #fbdee0;
}
.dl-menuwrapper div.dl-menu ul.g_nav:first-child {
  border-top: 0;
}
.dl-menuwrapper div.dl-menu ul.gs_nav {
  border-radius: 0 0 3px 3px;
}
.dl-menuwrapper div.dl-menu ul.gs_nav li {
  background: url(../SJ/common/images/mobile/mobile_icon_arrow_r.png) no-repeat 20px 12px;
  background-size: 6px 12px;
  border-bottom: 1px solid #ccc;
  font-weight: bold;
  padding: 12px 45px;
}
.dl-menuwrapper div.dl-menu ul.gs_nav li a {
  color: #333;
}
.dl-menuwrapper div.dl-menu ul.gs_nav li.last {
  border-bottom: 0;
  border-radius: 0 0 3px 3px;
}
.dl-menuwrapper .momenu {
  padding: 10px;
}
.dl-menuwrapper .momenu #g_search_form {
  margin: 0 auto;
  width: 100%;
}
.dl-menuwrapper .momenu #g_search_form::after {
  clear: both;
  content: "";
  display: table;
}
.dl-menuwrapper .momenu #g_search_form legend {
  display: none;
}
.dl-menuwrapper .momenu .searchBox {
  border: 1px solid #ccc;
  border-radius: 3px;
  box-sizing: content-box;
  height: 18px;
  padding: 7px;
  width: 65%;
}
@media (min-width: 480px) and (max-width: 696px) {
  .dl-menuwrapper .momenu .searchBox {
    width: 75%;
  }
}
@media screen and (min-width: 768px) {
  .dl-menuwrapper .momenu .searchBox {
    width: 83%;
  }
}
.dl-menuwrapper .momenu .search_but {
  height: 32px;
  width: 78px;
}

#i_search_autocomplete {
  z-index: 9999 !important;
}

.panelBK {
  background: #000;
  display: none;
  filter: alpha(opacity=20);
  height: 100%;
  -moz-opacity: 0.2;
  opacity: 0.2;
  position: fixed;
  width: 100%;
  z-index: 999;
}
@media screen and (min-width: 1024px) {
  .panelBK {
    display: none;
  }
}

/*
======================================================
  footer
--------------------------------------------------- */
@media screen and (min-width: 768px) {
  #footer {
    background: #fff;
    border-top: 1px solid #999;
    height: 69px;
    margin: 0 auto;
    position: relative;
    width: 100%;
  }
}
@media screen and (max-width: 1023px) {
  #footer {
    height: 36px;
  }
}
@media screen and (max-width: 767px) {
  #footer {
    height: 65px;
    min-width: 320px;
    width: 100%;
  }
}

#copy_area {
  background: #c02;
}
@media screen and (min-width: 768px) {
  #copy_area {
    height: 36px;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #copy_area {
    height: 65px;
    position: relative;
    top: 0;
    width: 100%;
    z-index: 1;
  }
}
@media screen and (min-width: 768px) {
  #copy_area #copy {
    margin: 0 auto;
    position: relative;
  }
}
@media screen and (min-width: 1024px) {
  #copy_area #copy {
    width: 990px;
  }
}
@media screen and (max-width: 1023px) {
  #copy_area #copy {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  #copy_area #copy #footerlogo {
    left: 21px;
    position: absolute;
    top: 12px;
  }
}
@media screen and (max-width: 767px) {
  #copy_area #copy #footerlogo {
    display: none;
  }
}
#copy_area #copy #copyright {
  font-size: 72%;
  position: absolute;
}
@media screen and (min-width: 768px) {
  #copy_area #copy #copyright {
    color: #fff;
    font-family: "Helvetica", "Arial";
    position: absolute;
    right: 21px;
    text-align: right;
    top: 12px;
  }
}
@media screen and (max-width: 767px) {
  #copy_area #copy #copyright {
    color: #d9d9d9;
    line-height: 130%;
    text-align: center;
    top: 12px;
    width: 100%;
  }
}

/* フッターメニュー（PC用）
========================================================= */
@media screen and (max-width: 1023px) {
  ul#footer__menu-pc {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  ul#footer__menu-pc {
    box-sizing: border-box;
    font-size: 12px;
    line-height: 100%;
    margin: 10px auto;
    padding: 0 21px;
    width: 990px;
  }
  ul#footer__menu-pc::after {
    clear: both;
    content: "";
    display: table;
  }
  ul#footer__menu-pc li {
    float: left;
  }
  ul#footer__menu-pc li a {
    background: no-repeat 0 0 transparent;
    display: block;
    height: 14px;
  }
  ul#footer__menu-pc li a:hover {
    background-position: left top;
    background-repeat: no-repeat;
  }
  ul#footer__menu-pc li a:hover img {
    _display: none;
    visibility: hidden;
  }
  ul#footer__menu-pc li#fn_sitepolicy a {
    width: 123px;
  }
  ul#footer__menu-pc li#fn_sitepolicy a:hover {
    background-image: url(../SJ/common/images/footernavi_about_on.gif);
  }
  ul#footer__menu-pc li#fn_sitepolicy a:active, ul#footer__menu-pc li#fn_sitepolicy a.ac {
    background-image: url(../SJ/common/images/footernavi_about_ac.gif);
  }
  ul#footer__menu-pc li#fn_private a {
    width: 125px;
  }
  ul#footer__menu-pc li#fn_private a:hover {
    background-image: url(../SJ/common/images/footernavi_private_on.gif);
  }
  ul#footer__menu-pc li#fn_private a:active, ul#footer__menu-pc li#fn_private a.ac {
    background-image: url(../SJ/common/images/footernavi_private_ac.gif);
  }
  ul#footer__menu-pc li#fn_solicitation a {
    width: 73px;
  }
  ul#footer__menu-pc li#fn_solicitation a:hover {
    background-image: url(../SJ/common/images/footernavi_solicitation_on.gif);
  }
  ul#footer__menu-pc li#fn_solicitation a:active, ul#footer__menu-pc li#fn_solicitation a.ac {
    background-image: url(../SJ/common/images/footernavi_solicitation_ac.gif);
  }
  ul#footer__menu-pc li#fn_guidance a {
    width: 125px;
  }
  ul#footer__menu-pc li#fn_guidance a:hover {
    background-image: url(../SJ/common/images/footernavi_guidance_on.gif);
  }
  ul#footer__menu-pc li#fn_guidance a:active, ul#footer__menu-pc li#fn_guidance a.ac {
    background-image: url(../SJ/common/images/footernavi_guidance_ac.gif);
  }
  ul#footer__menu-pc li#fn_sitemap a {
    width: 93px;
  }
  ul#footer__menu-pc li#fn_sitemap a:hover {
    background-image: url(../SJ/common/images/footernavi_sitemap_on.gif);
  }
  ul#footer__menu-pc li#fn_sitemap a:active, ul#footer__menu-pc li#fn_sitemap a.ac {
    background-image: url(../SJ/common/images/footernavi_sitemap_ac.gif);
  }
}

/* フッターメニュー（SP用）
========================================================= */
@media screen and (min-width: 1024px) {
  .footer_link_m {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  .footer_link_m {
    border-radius: 3px;
    margin: 0 auto 18px;
    width: 100%;
  }
  .footer_link_m ::after {
    clear: both;
    content: "";
    display: table;
  }
  .footer_link_m li {
    background: url(../SJ/common/images/mobile/mobile_icon_arrow_r.png) no-repeat 10px 8px;
    background-size: 6px 12px;
    float: left;
    width: 50%;
  }
  .footer_link_m li:nth-child(1) {
    border-radius: 3px 0 0;
  }
  .footer_link_m li:nth-child(1) a {
    border-right: 1px solid #ccc;
    border-top: 1px solid #ccc;
  }
  .footer_link_m li:nth-child(2) {
    border-radius: 0 3px 0 0;
    border-right: 0;
  }
  .footer_link_m li:nth-child(2) a {
    border-top: 1px solid #ccc;
  }
  .footer_link_m li:nth-child(3) {
    border-radius: 0 0 3px;
  }
  .footer_link_m li:nth-child(3) a {
    border-right: 1px solid #ccc;
  }
  .footer_link_m li:nth-child(4) {
    border-radius: 0 0 3px;
    border-right: 0;
  }
  .footer_link_m li a {
    border-bottom: 1px solid #ccc;
    color: #333;
    display: block;
    font-weight: normal;
    padding: 8px 4px 8px 25px;
  }
  .footer_link_m p {
    border-top: 1px solid #ccc;
    padding: 0;
    text-align: center;
  }
  .footer_link_m p .icon {
    margin-right: 10px;
    width: 14px;
  }
  .footer_link_m p a {
    color: #333;
    display: block;
    padding: 8px;
  }
}

@media screen and (min-width: 1024px) {
  #group_logo {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  #group_logo {
    margin: 20px auto;
    text-align: center;
  }
  #group_logo img {
    width: 320px;
  }
}

/*
======================================================
  common
--------------------------------------------------- */
.pc-br,
img.pc {
  display: none;
}
@media screen and (min-width: 1024px) {
  .pc-br,
  img.pc {
    display: block;
  }
}

.tab-br,
img.tab {
  display: none;
}
@media screen and (max-width: 1023px) {
  .tab-br,
  img.tab {
    display: block;
  }
}

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

.super-txt {
  font-size: 60%;
  position: relative;
  top: -0.1em;
  vertical-align: top;
}

.fadein {
  opacity: 0;
  transform: translateY(20px);
  transition: all 1s;
}

.section {
  margin: 0 auto;
  width: 948px;
}
@media screen and (max-width: 1023px) {
  .section {
    width: 90%;
  }
}

/*
======================================================
  floating
--------------------------------------------------- */
#pagetop {
  position: fixed;
}
@media screen and (min-width: 1024px) {
  #pagetop {
    bottom: 9px;
    left: calc(50% - 485px);
    text-align: right;
    width: 970px;
    z-index: 98;
  }
  #pagetop a {
    display: block;
    height: 31px;
    margin-left: auto;
    width: 97px;
  }
  #pagetop a:hover {
    cursor: pointer;
  }
  #footer.active #pagetop {
    bottom: 49px;
  }
}
@media screen and (max-width: 1023px) {
  #pagetop {
    bottom: 2px;
    right: 2px;
    z-index: 2;
  }
  #pagetop img {
    height: 44px;
    width: 44px;
  }
}
@media screen and (max-width: 1023px) and (min-width: 768px) {
  #pagetop img {
    height: 70px;
    width: 70px;
  }
}
@media screen and (max-width: 1023px) {
  #footer.active #pagetop {
    bottom: 56px;
  }
}

/*
======================================================
  topicpath
--------------------------------------------------- */
@media screen and (max-width: 1023px) {
  #topicpath_area-pc {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  #topicpath_area-pc {
    *zoom: 1;
  }
  #topicpath_area-pc::after {
    clear: both;
    content: "";
    display: table;
  }
}

@media screen and (min-width: 1024px) {
  ol#topicpath-pc {
    margin: 0 auto;
    padding-top: 30px;
    width: 960px;
  }
  ol#topicpath-pc li {
    display: inline-block;
    float: left;
    font-size: 1.2rem;
    line-height: 136%;
    margin: 0 0 5px 5px;
    *zoom: 1;
  }
  ol#topicpath-pc li strong {
    font-weight: 700;
  }
  ol#topicpath-pc li a {
    background: url(../images/topicpath_arrow.gif) no-repeat right center;
    color: #66a;
    padding: 0 15px 0 0;
    text-decoration: none;
  }
  ol#topicpath-pc li a:visited {
    color: #66a;
  }
  ol#topicpath-pc li a:hover {
    color: #448;
  }
  ol#topicpath-pc li a:active {
    color: #448;
  }
}

@media screen and (min-width: 1024px) {
  #topicpath_area-mobile {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  #topicpath_area-mobile {
    margin-bottom: 18px;
    *zoom: 1;
  }
  #topicpath_area-mobile::after {
    clear: both;
    content: "";
    display: table;
  }
  #topicpath_area-mobile #topicpath-mobile {
    margin: 0 10px;
    padding-top: 10px;
  }
  #topicpath_area-mobile #topicpath-mobile li {
    display: inline-block;
    float: left;
    font-size: 86%;
    line-height: 115%;
    margin: 1px 0 5px 5px;
    *zoom: 1;
  }
  #topicpath_area-mobile #topicpath-mobile li a {
    background: url(../images/topicpath_arrow.gif) no-repeat right center;
    padding: 0 15px 0 0;
  }
}

.topicpath_area-wrap {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 1024px) {
  .topicpath_area-wrap {
    width: 990px;
  }
}

/* secondtop fix */
#mainArea #topicpath_area {
  margin-bottom: 5px;
}

#mainArea #topicpath_area #topicpath {
  margin: 0 0 0 5px;
  padding-top: 0;
}