@charset "UTF-8";

/* ====================================================== *
    Common Style
 * ====================================================== */

html {
  /* 基準フォントサイズを 10px に調整 */
  font-size: 62.5%;
  nowhitespace: afterproperty;
  overflow: hidden;
  overflow-y: scroll;
}

body {
  background-color: #FFF;
  color: #333;
  font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 13px;
  font-size: 1.3rem;
  letter-spacing: 0;
  line-height: 1.75;
  text-align: center;
}

/* ------------------------------------------------------ */

input[type="checkbox"],
input[type="radio"] {
  vertical-align: -0.2em
}

/* ------------------------------------------------------ */

img {
  vertical-align: top;
}

/* ------------------------------------------------------ */

/* clearfix */

.clear {
  zoom: 1
}

.clear:after {
  clear: both;
  content: "";
  display: block;
}

/* ------------------------------------------------------ */

/* anchor */

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

a:visited {
  color: #71399C;
  text-decoration: none;
}

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

/* ------------------------------------------------------ */

/* general class */

.message-box {
  background: #FFF3EF;
  border: 2px solid #E79181;
  color: #8D3C27;
  padding: 10px;
  text-align: center;
}

.require {
  color: #EC6D56;
  font-weight: bold;
  margin: 0 5px 0 5px;
}

.more-link {
  overflow: hidden;
  margin: 0.5em 0 0;
}

.more-link a {
  float: right;
  padding: 3px 12px;
  background-color: #ECECEC;
  display: block;
  border-radius: 5px;
}

.modest-link a {
  color: #727171;
  text-decoration: none;
}

.modest-link a:hover {
  text-decoration: underline
}

/* ------------------------------------------------------ */

.sns-counter {
  float: right;
  padding: 0;
  margin: 30px 0 0 0;
}

.sns-counter .btn.twitter {
  width: 110px
}

.sns-counter .btn {
  float: left
}

#site-sns-counter {
  bottom: 10px;
  position: absolute;
  right: -10px;
}

/* ------------------------------------------------------ */

.bt-wrap {
  background-position: center center;
  background-repeat: no-repeat;
  overflow: hidden;
}

.bt {
  background-position: center center;
  background-repeat: no-repeat;
  display: block;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}

.bt:hover {
  background-image: none !important
}

/* ------------------------------------------------------ */

.back-to-nav {
  clear: both;
  text-align: right;
  overflow: hidden;
}

.back-to-nav .link {
  display: block;
  padding: 10px 2px;
  float: right;
}

.back-to-nav .link .arrow {
  margin-right: 5px;
}

/* ------------------------------------------------------ */

.page_top {
  clear: both;
  text-align: center;
  margin: 0;
  position: fixed;
  bottom: 0;
  width: 687px;
  display: none;
}

.page_top .link {
  color: #000;
  /* border-bottom: solid 1px #000; */
  padding: 10px 10px 10px 25px;
  position: relative;
  background-color: #C9CACA;
  border-radius: 5px 5px 0 0;
  display: block;
  height: 20px;
  width: 125px;
  margin: 0 auto;
  opacity: 0.5;
}

.page_top .link:hover {
  text-decoration: none;
}

.page_top .link .arrow {
  display: inline-block;
  font-size: 16px;
  font-size: 1.6rem;
  position: absolute;
  top: 7px;
  left: 8px;
}

/* ------------------------------------------------------ */

.flexible_list {
  padding: 0;
  list-style: none;
  overflow: hidden;
}

.flexible_list .item {
  float: left;
}

/* ------------------------------------------------------ */
/* Form */

form .error {
  margin: 0 0 20px 0;
  background-color: #FFF;
  background-color: #FFF2F4;
  padding: 3px 7px;
}

form .ex {
    display: block;
    margin: 5px 0 5px 0;
    font-size: 12px;
    font-size: 1.2rem;
}

form .note {
    margin: 5px 0;
}

form .attention {
  color: #EC6D56;
}

form .checkbox .error {
  text-indent: 5px;
}

/* ------------------------------------------------------ */
/* Sider */

.slider {
  position: relative;
  margin-bottom: 20px;
}

.slider .sls-view {
  position: relative;
  overflow: hidden;
}

.slider .sls-container {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

.slider .sls-container .sls-content {
  display: block;
  position: relative;
  float: left;
}

.slider .sls-pagination {
  position: absolute;
  bottom: -9px;
  right: 0px;
}

.slider .sls-pagination a {
  float: left;
  width: 100px;
  height: 7px;
  overflow: hidden;
  margin: 0 0 0 0;
  border: none;
  /*box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2) inset;*/
  background: #E6E6E6;
  text-indent: -9999px;
  vertical-align: middle;
}

.slider .sls-pagination a:hover {
  background: #DEDEDE;
}

.slider .sls-pagination a.current {
  /*box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5) inset;*/
  background: #E60012;
}

/* ------------------------------------------------------ */
/* Contact Form 7 */

/*
span.wpcf7-list-item {
  margin: 0;
}

span.wpcf7-not-valid-tip {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 100;
  width: 280px;
  padding: 2px 5px;
  color: #8D3C27;
  font-size: 11px;
  background: #FFF3EF;
  border: 2px solid #E79181;
}

div.wpcf7-validation-errors {
  color: #665618;
  border: 2px solid #F3DA1F;
  background-color: #FFFFE7;
}

div.wpcf7-mail-sent-ok {
  border: 2px solid #62A346;
  background-color: #F7FFF4;
  color: #227422;
}
*/

/*--------------------------------------------------------*/

/* Page navigation */

.pagenavi_wrapper {
  display: table;
  margin: 0 auto;
  padding: 10px 0;
  width: 100%;
  border-top: 1px solid #000;
}

.pagenavi_wrapper .inner_wrap {
  text-align: center;
  display: table-cell;
}

.wp-pagenavi {
  padding: 10px 0;
  display: inline-block;
}

.wp-pagenavi a ,
.wp-pagenavi span {
  border: 1px solid #E5B4B8;
  color: #231815;
  display:block;
  float:left;
  font-weight: bold;
  margin: 0 2px;
  padding:1px 7px;
  text-decoration: none;
}

.wp-pagenavi .pages {
  background-color:transparent;
  border:none;
  color:#555;
  font-weight:normal;
}

.wp-pagenavi a:hover ,
.wp-pagenavi span.current:hover {
  /*border: 1px solid #231815;*/
  color: #000;
  background-color: #FDD8D8;
}

.wp-pagenavi span.current {
  background-color: #E22828;
  border-color: #E60012;
  color: #FFF;
  font-weight: bold;
}

/* ------------------------------------------------------ */

.prev-next-nav {
  clear: both;
  overflow: hidden;
  padding: 10px 10px 0;
  margin: 0 40px 0;
}

.prev-next-nav .prev {
  float: left;
}

.prev-next-nav .next {
  float: right;
}

/* ------------------------------------------------------ */

.debug {
  background-color: #FFF;
  text-align: left;
}

/* ====================================================== *
    widget
 * ====================================================== */

.wid {
  margin: 20px 0;
  overflow: hidden;
}

.wid .wid_title {
  background-color: #000;
  color: #FFF;
  font-size: 13px;
  font-size: 1.3rem;
  padding: 2px 10px;
}

/* ------------------------------------------------------ */

.wid_2col_banner ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wid_2col_banner li {
  margin: 0 8px 10px 0;
  padding: 0;
  float: left;
  display: block;
}

.wid_2col_banner li:nth-child(2n) {
  margin: 0 0 10px 0;
}

.wid_2col_banner li a {
  display: block;
}

/* ------------------------------------------------------ */

.wid_2col_catalog {
    width: 687px;
}

.wid_2col_catalog .item {
    width: 333px;
    margin: 0 21px 10px 0;
    padding: 0;
    float: left;
    display: block;
}

.wid_2col_catalog .item:nth-child(2n) {
    margin: 0 0 10px 0;
}

/* ------------------------------------------------------ */

.wid_new_arrival_list {
  border-bottom: solid 1px #000;
}

.wid_new_arrival_list dl {
  padding-left:20px;
  margin: 10px 0 5px;
}

.wid_new_arrival_list dt {
  float:left;
  width: 110px;
}

.wid_new_arrival_list dd {
  margin: 0 0 7px 125px;
}

.wid_new_arrival_list .more-link {
  margin: 0 0 10px 0;
}

/* ------------------------------------------------------ */

.wid_osaka_now_pickup {
  border-bottom: solid 1px #000;
  padding: 0 0 10px 0;
}

/* ------------------------------------------------------ */

.wid_links .giin_links {
  width: 716px;
  margin-bottom: 30px;
}

.wid_links .giin_links .item {
  margin: 0 29px 10px 0;
}

.wid_links .other_links {
  width: 694px;
  margin-bottom: 20px;
}

.wid_links .other_links .item {
  margin: 0 8px 10px 0;
}

/* ------------------------------------------------------ */

.wid_text_link_list ul {
  margin: 0;
  padding: 0;
}

.wid_text_link_list ul li {
  background: url(../img/common/yajirusi.gif) 0px 3px no-repeat;
  margin: 0 0 15px 0;
  padding-left: 20px;
}

/* ------------------------------------------------------ */

.wid_archive_menu {
  margin: 0 0 30px 0;
}

.wid_archive_menu .menu {
  list-style: none;
  margin: 0;
  padding: 15px 0 0 5px;
}

.wid_archive_menu .category_menu,
.wid_archive_menu .monthly_menu {
  margin: 0 0 30px 0;
}

.wid_archive_menu .menu ul {
  padding: 3px 0 0 0;
  list-style: none;
}

.wid_archive_menu .menu li {
  background: url(../img/common/yajirusi_02.gif) 0px 5px no-repeat;
  margin: 0 0 10px 0;
  padding: 0 0 0 14px;
}

.wid_archive_menu .menu ul li {
  padding-bottom: 0;
  margin-bottom: 2px;

}

.wid_archive_menu .title {
  border-bottom: solid 2px #000;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.wid_archive_menu select {
  margin: 10px 0;
  width: 250px;
}

/* ------------------------------------------------------ */

/* wid-banner */

.wid_banner_link {
  margin: 30px 0;
}

.wid_banner_link .list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wid_banner_link .item {
  margin-bottom: 20px;
}

.wid_banner_link .item:last-child {
  margin-bottom: 0;
}

.wid_banner_link .item .link {
  white-space: nowrap;
  overflow: hidden;
  text-indent: 100%;
  display: block;
  background-repeat: no-repeat;
  background-position: 0 0;
  width: 250px;
  height: 41px;
}

.wid_banner_link .item.facebook .link {
  background-image: url(../img/common/bn_jcp-osaka_facebook.png);
  height: 66px;
}

.wid_banner_link .item.mail_magazine .link {
  background-image: url(../img/common/bn_jcp-osaka_mail-magazine.png);
}

/* ------------------------------------------------------ */

.wid_pickup_movie {
  border-bottom: 1px solid #CCC;
  padding-bottom: 15px;
}

.wid_pickup_movie .title .link {
  background: url(../img/common/side_wid-title_link-marker.png) 220px 7px no-repeat #E60012;
  color: #FFF;
  display: block;
  font-size: 18px;
  font-weight: bold;
  padding: 2px 15px 0;
  margin-bottom: 15px;
}

.wid_pickup_movie .title .link:hover {
  background-color: #EE3946;
  text-decoration: none;
}

.wid_pickup_movie .list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wid_pickup_movie .list .item {
  margin: 0 0 20px 0;
}

.wid_pickup_movie .list .item:last-child {
  margin: 0;
}

/* ------------------------------------------------------ */

.wid_akahata_today {
  border: 2px solid #3d62ac;
  width: 246px;
}

.wid_akahata_today .wid_title {
  padding: 0;
  margin: 0;
}

.wid_akahata_today .wid_title .link {
  display: block;
  background: url(../img/common/wid_akahata-today_title.png) center 40% no-repeat #3d62ac;
  white-space: nowrap;
  text-indent: 100%;
  overflow: hidden;
  padding: 10px 0;
  margin: 0;
  width: 246px;
}

.wid_akahata_today .service_link {
  text-align: right;
  padding: 5px 10px;
}

.wid_akahata_today .service_link .link {
  color: #CCC;
  font-size: 11px;
  font-size: 1.1rem;
}

.wid_akahata_today .wid_footer {
  background-color: #3D62AC;
  text-align: center;
  padding: 3px 10px 2px;
}

.wid_akahata_today .wid_footer .link {
  color: #FFF;
}

/* ------------------------------------------------------ */

.wid-in-page-jump-nav {
    margin: 0;
  padding: 10px;
  border: 1px solid #ccc;
}

.wid-in-page-jump-nav .list {
    margin: 0;
  padding: 0 0 0 10px;
    overflow: hidden;
}

.wid-in-page-jump-nav .list:nth-of-type(1) {
  padding: 0;
}

.wid-in-page-jump-nav .list > .item {
    margin: 0 15px 0 0;
    display: inline-block;
}

.wid-in-page-jump-nav .list > .item:before {
    content: "・";
}

.wid-in-page-jump-nav .list > .item > .link {
    /*text-decoration: none;*/
}

.wid-in-page-jump-nav .label {
  margin: 5px 0 3px;
  font-weight: bold;
}

/* ------------------------------------------------------ */
.wid_twitter {
  height: 607px;
}

.wid_twitter .twitter-timeline {
  width: 250px !important;
}

/* ------------------------------------------------------ */
/* Candidates List */

/* common */

.entry-body table.wid_candidates_ilst .career span ,
.wid_candidates_person_list .item .career {
  display: block;
  float: left;
  font-size: 16px;
  background-color: #CCC;
  padding: 5px 5px 4px 5px;
  line-height: 1.0;
  border-radius: 3px;
  margin: 0 0 0 12px;
}

.entry-body table.wid_candidates_ilst .career span.new ,
.wid_candidates_person_list .item .career.new {
  background-color: #FADAE0;
  color: #CE2E2E;
}

.entry-body table.wid_candidates_ilst .career span.incumbent ,
.wid_candidates_person_list .item .career.incumbent {
  background-color: #DAE8FA;
  color: #186FCE;
}

.entry-body table.wid_candidates_ilst .career span.one-time ,
.wid_candidates_person_list .item .career.one-time {
  background-color: #EBFADA;
  color: #679E15;
}

.entry-body table.wid_candidates_ilst {
  border: none;
  font-size: 15px;
  font-size: 1.5rem;
  width: 100%;
}

.entry-body table.wid_candidates_ilst caption {
  text-align: left;
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 10px 0;
}

.entry-body table.wid_candidates_ilst tr {
  border-bottom: 1px solid #CCC;
}

/*
.entry-body table.wid_candidates_ilst tr:last-child {
  border-bottom: none;
}
*/

.entry-body table.wid_candidates_ilst td,
.entry-body table.wid_candidates_ilst th {
  border: none;
  padding: 20px 10px 3px 10px;
}

.entry-body table.wid_candidates_ilst tr:first-child td,
.entry-body table.wid_candidates_ilst tr:first-child th {
  padding-top: 0;
}

.entry-body table.wid_candidates_ilst .area {
  width: 40%;
}

.entry-body table.wid_candidates_ilst .name {
  width: 40%;
}

.entry-body table.wid_candidates_ilst .career {
  width: auto;
  text-align: center;
  padding-bottom: 8px;
}

/* ------------------------------------------------------ */

.wid_candidates_person_list {
  width: 687px;
}

.wid_candidates_person_list .item {
  margin: 0 21px 10px 0;
  float: left;
  display: block;
  border-bottom: 1px solid #ccc;
  width: 295px;/*333px*/
  padding: 10px 18px 10px;
}

.wid_candidates_person_list .item:nth-child(2n) {
  margin: 0 0 10px 0;
}

.wid_candidates_person_list .item .name {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  margin: 0;
  padding: 1px 0 0 0;
  float: left;
}

/* ====================================================== *
    Entry
 * ====================================================== */

.entry-header {
  overflow: hidden;
  margin: 10px 0;
}

.entry-header .date {
  float: left;
  margin: 2px 10px 0 0;
}

.entry-header .terms {
  float: left;
  list-style: none;
  padding: 0;
  margin: 0;
}

.entry-header .terms .term {
  float: left;
  margin: 0 10px 0 0;
}

.entry-header .terms .term .link {
  color: #E60012;
  display: block;
  padding: 2px 10px 2px;
  font-size: 12px;
  font-size: 1.2rem;
  border: 1px solid #E60012;
  border-radius: 6px;
}

.entry-header .terms .term .link:hover {
  text-decoration: none;
  background-color: #FAE7E7;
}

.entry-header .main_term {
  clear: both;
  float: left;
  width: 64px;
  margin: 11px 10px 0 0;
}

.entry-header .main_term .link {
  color: #E60012;
  border: 2px solid #E60012;
  border-radius: 5px;
  padding: 2px;
  width: 56px;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  height: 56px;
}

.entry-header .main_term .link:hover {
  text-decoration: none;
  background-color: #FAE7E7;
}

.entry-header .title {
  float: left;
  width: 610px;
  margin: 8px 0 0 0;
  padding: 0;
  line-height: 1.35;
}

.entry-header .title a {
  color: #000;
  font-size: 26px;
  font-size: 2.6rem;
}

.entry-header .title .post-type {
  margin: 8px 0 0 0;
  /*text-indent: -10px;*/
}

.entry-header .title .post-type ,
.entry-header .title .post-type .link {
  color: #000;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: normal;
}

/* ------------------------------------------------------ */

.entry-wrapper {
  margin: 20px 0 50px;
  overflow: hidden;
}

.entry-wrapper.movie {
  border-top: 1px solid #333;
}

.entry-wrapper.movie:nth-of-type(1) {
  border-top: none;
}

.entry-wrapper.normal {
  position: relative;
}

/* ------------------------------------------------------ */

.entry-body {
  overflow: hidden;
  margin: -15px 0 0;
}

.entry-body .thumb {
  float: left;
  margin: 17px 20px 15px 0;
}

.entry-body .thumb img {
  width: 250px;
}

.entry-body .thumb .thumb_img {
  width: 200px;
  display: none;
}

.entry-body .excerpt {
  overflow: hidden;
}

.entry-body .movie {
  margin: 20px 0;
}

.thumb .icon_load {
  width: 200px;
  min-height: 150px;
  background: url(../img/common/icon_load.gif) no-repeat center center;
}

.entry-body h1 {
  clear: both;
  font-size: 20px;
  font-size: 2.0rem;
  line-height: 1.5;
  background: #F2F2F2;
  border-bottom: #9E9E9E 1px dotted;
  padding: 10px 15px;
  margin: 30px 0 20px 0;
  font-weight: bold;
}

.entry-body h1.page-title {
  clear: both;
  background-color: #E60012;
  color: #FFF;
  padding: 0 10px;
  font-size: 2em;
  border: none;
  line-height: 1.75;
}

.entry-body h2 {
  clear: both;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.5;
  border-bottom: 7px solid #F2F2F2;
  margin: 30px 0 20px 0;
  padding: 5px;
  background: none;
}

.entry-body h3 {
  clear: both;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
  border-left: 10px solid #333;
  padding: 0 0 0 11px;
  margin: 30px 0 20px 0;
}

.entry-body h4 {
  clear: both;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
  margin: 30px 0 20px 0;
}

.entry-body h5 {
  clear: both;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 30px 0 20px 0;
}

.entry-body h6 {
  clear: both;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.5;
  margin: 30px 0 20px 0;
}

/* ------------------------------------------------------ */

.entry-body p {
  clear: both;
}

.wp-caption + p {
  clear: none;
}

.entry-body em {
  color: #DF2020;
  font-weight: bold;
}

.entry-body ins {
  border-bottom: none;
  text-decoration: underline;
  color: #333;;
}

.entry-body del {
  color: #333;
  text-decoration: line-through;
}

.entry-body small {
  font-size: 11px;
  font-size: 1.1rem;
}

.entry-body dt {
  font-weight: bold;
  margin-left: 20px;
}

.entry-body dd {
  display: list-item;
  list-style-type: square;
  list-style-position: outside;
}

.entry-body blockquote {
  padding: 6px 15px;
  margin-left: 0;
  margin-right: 0;
  background-color: #EAF3F3;
}

/* ------------------------------------------------------ */

.entry-body hr {
  border: 0;
  border-bottom: 1px dotted #CCC;
  margin: 2em 0;
}

.entry-body .alignleft {
  text-align: left;
}

.entry-body .aligncenter {
  text-align: center;
}

.entry-body .alignright {
  text-align: right;
}

.entry-body div.alignleft ,
.entry-body img.alignleft {
  display: block;
  float: left;
  margin: 0 13px 10px 0;
}

.entry-body img.aligncenter {
  display: block;
  margin: 0 auto;
  padding-bottom: 0.5em;
}

.entry-body div.alignright ,
.entry-body img.alignright {
  display: block;
  float: right;
  margin: 0 0 10px 13px;
}

.entry-body .wp-caption {
  border: none;
  text-align: center;
  background: none;
  padding: 7px 3px;
  margin: 13px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
}

.entry-body .wp-caption img {
  margin: 0;
}

.entry-body .wp-caption-text {
  text-align: left;
  padding: 5px 5px 0;
}

.entry-body .wp-caption.alignleft {
  float: left;
  margin-left: 0;
  margin-right: 25px;
}

.entry-body .wp-caption.aligncenter {
  margin-right: auto;
  margin-left: auto;
}

.entry-body .wp-caption.alignright {
  float: right;
  margin-left: 25px;
  margin-right: 0;
}

.entry-body .extract-first-image {
  overflow: hidden;
  margin-bottom: 10px;
}

.entry-body .extract-first-image img {
  float: none;
  clear: both;
  margin: 0;
}

/*--------------------------------------------------------*/
/* Table formats */

/* Default */
.entry-body table {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
  margin: 2em 0;
  font-size: 12px;
  font-size: 1.2rem;
}

.entry-body table th,
.entry-body table td {
  border-right: 1px solid #CCCCCC;
  border-bottom: 1px solid #CCCCCC;
  padding: 5px 10px;
}

.entry-body table th {
  font-weight: bold;
  white-space: nowrap;
  background-color: #F3F3F3;
}

.entry-body table caption {
  font-weight: bold;
  margin-top: 5px;
}

/* ------------------------------------------------------ */
/* Style clear */

.entry-body table.none,
.entry-body table.none td,
.entry-body table.none th {
  border: none;
  background: none;
}

.entry-body table.none td,
.entry-body table.none th {
  padding: 0;
  margin: 0;
}

/* ------------------------------------------------------ */

.entry-body table.hori-line {
  border: none;
}

.entry-body table.hori-line td,
.entry-body table.hori-line th {
  border: none;
}

.entry-body table.hori-line tr {
  border-bottom: 1px solid #CCC;
}

.entry-body table.hori-line tr:last-child {
  border-bottom: none;
}

/* ------------------------------------------------------ */

.entry-body dl.table-format {
  margin: 2em 0;
  padding: 0;
  list-style: none;
  overflow: hidden;
}

.entry-body dl.table-format dt {
  clear: left;
  float: left;
  width: 10em;
  list-style: none;
  margin: 0 0 15px 10px;
}

.entry-body dl.table-format dd {
  list-style: none;
  float: left;
  margin: 0 0 15px 1.5em;
}



/* ====================================================== *
    header
 * ====================================================== */

#header a {
  text-decoration: none;
}

#header .upper_block {
  background-color: #E60012;
  color: #FFF;
  overflow: hidden;
  min-width: 1020px;
}

#header .upper_block .inner_wrap {
  padding: 0 30px;
  margin: 0 auto;
  width: 960px;
}

#header .site_name {
  font-size: 14px;
  font-size: 1.4rem;
  float: left
}

#header .site_name a {
  background: url(../img/common/logo.png) left 50% no-repeat;
  color: #FFF;
  display: block;
  padding: 9px 0 9px 80px;
}

#header .utility {
  position: relative;
}

#header .utility .contact {
  position: absolute;
  top: 17px;
  right: 230px;
  white-space: nowrap;
}

#header .utility .contact a {
  background: url(../img/common/icon_mail.gif) left 50% no-repeat;
  color: #FFF;
  display: block;
  padding: 3px 7px 3px 30px;
}

#header .utility .search {
  position: absolute;
  top: 14px;
  right: 0px;
}

#header .utility .search .keyword {
  background-color: #E60012;
  border: 4px solid #FFF;
  color: #FFF;
  height: 24px;
  padding-left: 7px;
  width: 200px;
}

#header .utility .search .submit {
  background: url(../img/common/icon_search.gif) 50% 50% no-repeat;
  border: none;
  height: 26px;
  overflow: hidden;
  position: absolute;
  right: 4px;
  text-indent: 30px;
  top: 4px;
  white-space: nowrap;
  width: 30px;
}

#header .gnav {
  display: block;
  margin: 10px auto;
  padding: 0 20px;
  overflow: hidden;
  width: 980px;
}

#header .gnav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#header .gnav li {
  float: left;
  margin: 0 1px 0 0;
  text-align: center;
  text-decoration: none;
}

#header .gnav li:last-child {
  margin-right: 0;
}

#header .gnav li a {
  background-color: #C9CACA;
  color: #333;
  display: block;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 11px 0px 9px;
  width: 195px;
}

#header .gnav li a:hover {
  background-color: #FDD8D8;
}

/* ====================================================== *
    Content
 * ====================================================== */

#contents {
  clear: both;
  margin: 0 auto;
  padding: 0 20px;
  min-height: 100%;
  width: 980px;
}

#cont_main {
  display: table;
  width: 980px;
  padding: 2px 0 0;
  text-align: left;
}

#cont_header {
  margin: 0 0 20px 0;
}

#cont_article {
  display: table-cell;
  vertical-align: top;
  width: 686px;
  padding-right: 20px;
  padding-bottom: 40px;
}

#cont_article > .inner_wrap > *:first-child {
  margin-top: 0;
}

#cont_article > .inner_wrap > .title {
  background-color: #E60012;
  color: #FFF;
  padding: 0 10px;
}

#cont_article > .inner_wrap > .sub-title {
  border-bottom: 5px solid #E60012;
}

#cont_article .wid {
  width: 686px;
}

#cont_article .wid_2col_banner .flexible_list {
  width: 694px;
}

/* ====================================================== */

#cont_sidebar {
  border-left: 4px solid #333;
  display: table-cell;
  padding: 0 0 0 18px;
  vertical-align: top;
  width: 250px;
}

#cont_sidebar > *:first-child {
  margin-top: 0;
}

/* ====================================================== *
    footer
 * ====================================================== */

#footer {
  background-color: #E60012;
  clear: both;
  color: #FFF;
  padding: 15px 0 17px;
  min-width: 1020px;
}

#footer .inner_wrap {
  margin: 0 auto;
  width: 980px;
}

#footer address {
  margin: 0 0 3px 0;
}

#footer address ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#footer address ul li {
  display: inline-block;
  margin: 0;
  padding: 0 5px;
}

#footer address .name {
  font-weight: bold;
}

#footer address .email {
  background: url(../img/common/icon_mail_small.png) 0 6px no-repeat;
  padding: 0 0 0 20px;
  margin-left: 7px;
}

#footer .copyright {
  clear: both;
  font-size: 12px;
  font-size: 1.2rem;
}

#footer .copyright a {
  color: #FFFFFF;
}

#footer .sp_view_btn {
  text-align:center;
  font-size: 48px;
  background-color:#E60012;
  padding: 55px 3%;
}

#footer .sp_view_btn .sp_mode {
  border:solid 3px #fff;
  padding: 10px 30px;
  color: #fff;
  display: block;
  height: 120px;
  line-height: 120px;
}

#footer .sp_view_btn .sp_mode:hover {
  color: #A7010D;
  background-color: #FFF;
}

/* share btn */
.share-btn {
  padding: 10px 0;
  display: flex;
  justify-content: flex-end;
}

.share-btn__items {
  display: flex;
  justify-content: space-between;
  margin: 0;
}

.share-btn__item {
  list-style-type: none;
  position: relative;
  width: 100%;
  padding-right: 5px;
  padding-left: 5px;
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
}

.share-btn__item a {
  width: 45px;
  border-radius: 35px;
  display: block;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 2;
  padding: 4px 0;
  text-align: center;
}

.share-btn__item a:hover {
  text-decoration: none;
  opacity: 0.8;
}

.share-btn__item a.item--fb {
  border: solid 1px #43609c;
  background-color: #43609c;
  color: #fff;
}

.share-btn__item a.item--tw {
  border: solid 1px #55aded;
  background-color: #55aded;
  color: #fff;
}

.share-btn__item a.item--ln {
  border: solid 1px #00b833;
  background-color: #00b833;
  color: #fff;
  text-align: center;
}

.share-btn__item a.item--ln img {
  width: 30px;
  margin-top: 4px;
}

.share-btn__item a .fab {
  font-size: 2.2rem;
  position: relative;
  bottom: -2px;
}