@charset "UTF-8";
/*!
  Theme Name: ad
  Author: ad
  Author URI: http://shikiori.com/
  Description: ad
  Version: 1.0
  Date: 2017.01.10
  License: GNU General Public License v2 or later
  License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

html {
  font-size: 10px;
  -webkit-tap-highlight-color: transparent; }

body {
  font-size: 14px;
  color: #1F1F1F;
  font-family: "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 游ゴシック体, "Yu Gothic", YuGothic, メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: normal;
  height: 100%;
  margin: 0;
  padding: 0;
  line-height: 1.8;
  width: 100%; }
  @media screen and (min-width: 992px) {
    body {
      min-width: 1130px; } }

.oldie body {
  min-width: 1130px; }

p {
  margin-top: 0; }

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

.oldie img {
  width: auto; }

a {
  color: #D90000;
  text-decoration: underline;
  -webkit-transition: 0.15s;
  -moz-transition: 0.15s;
  -ms-transition: 0.15s;
  -o-transition: 0.15s;
  transition: 0.15s;
  -webkit-backface-visibility: hidden;
  /* 追加 */
  backface-visibility: hidden;
  /* 追加 */ }

a:hover {
  color: #D90000;
  text-decoration: none;
  opacity: 0.65;
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  -webkit-backface-visibility: hidden;
  /* 追加 */
  backface-visibility: hidden;
  /* 追加 */ }

a.rev {
  text-decoration: none; }

a.rev:hover {
  text-decoration: underline; }

address {
  font-style: normal; }

figure {
  margin: 0; }

dd {
  margin-left: 0; }

ol,
ul {
  padding-left: 1.5em; }

li {
  margin-bottom: .5em; }

section {
  margin-bottom: 60px; }

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

@media print {
  a[href]:after {
    display: none; }

  abbr[title]:after {
    display: none; } }
.btn {
  border: 1px transparent;
  cursor: pointer;
  outline: none;
  text-align: center;
  text-decoration: none;
  vertical-align: middle; }
  .btn:hover {
    text-decoration: none; }

.btn-link {
  line-height: 60px;
  width: 100%;
  max-width: 345px;
  -webkit-border-radius: 60px;
  border-radius: 60px;
  border: 2px solid #D90000; }

.list, .pagination {
  list-style: none;
  margin-top: 0;
  padding-left: 0; }

input[type=text],
input[type=email],
input[type=tel],
input[type=url],
input[type=password],
input[type=number],
select {
  font-size: 16px;
  font-size: 1.6rem;
  background: #FFF;
  border: 1px solid #ccc;
  height: 2em;
  line-height: 2;
  outline: none;
  padding: 0 .3em;
  width: 100%; }
  input[type=text]:focus,
  input[type=email]:focus,
  input[type=tel]:focus,
  input[type=url]:focus,
  input[type=password]:focus,
  input[type=number]:focus,
  select:focus {
    border-color: #000; }

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0; }

select {
  font-size: 13px;
  font-size: 1.3rem;
  height: 2.5em;
  padding: .5em;
  width: auto;
  min-width: 7em; }

textarea {
  font-size: 16px;
  font-size: 1.6rem;
  background: #FFF;
  border: 1px solid #ccc;
  padding: 0 .3em;
  outline: none;
  resize: vertical;
  width: 100%; }
  textarea:focus {
    border-color: #000; }

input[type=checkbox],
input[type=radio] {
  background: #FFF;
  cursor: pointer;
  margin-right: .5em; }

.table {
  border-collapse: collapse;
  border-spacing: 0;
  max-width: 100%;
  width: 100%; }

.table-responsive {
  min-height: .01%;
  overflow-x: auto; }

.table-basic, .article-format table, .article-format .table-basic {
  border: 1px solid #ccc; }

@media screen and (max-width: 767px) {
  .table > thead,
  .table > thead > tr,
  .table > thead > tr > th,
  .table > thead > tr > td,
  .table > tbody,
  .table > tbody > tr,
  .table > tbody > tr > th,
  .table > tbody > tr > td {
    width: auto; }

  .table-responsive {
    width: 100%;
    overflow-y: hidden;
    -ms-overflow-style: -ms-autohiding-scrollbar;
    border: 1px solid #ccc; }
    .table-responsive > .table {
      margin-top: 0;
      margin-bottom: 0;
      width: 1130px; }

  .table-sm-block {
    display: block; }
    .table-sm-block > thead,
    .table-sm-block > thead > tr,
    .table-sm-block > thead > tr > th,
    .table-sm-block > thead > tr > td,
    .table-sm-block > tbody,
    .table-sm-block > tbody > tr,
    .table-sm-block > tbody > tr > th,
    .table-sm-block > tbody > tr > td {
      display: block;
      width: 100%; } }
.panel {
  background-color: #fff;
  border: 1px solid transparent;
  border-radius: 4px;
  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
  margin-bottom: 20px; }

.panel-heading {
  padding: 10px 15px;
  border-bottom: 1px solid transparent;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px; }

.panel-body {
  padding: 15px; }

.pager {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  height: 35px;
  margin-bottom: 60px;
  max-width: 100%;
  padding: 30px 0;
  position: relative; }
  .pager a {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -moz-box-flex: 1;
    -moz-flex: 1;
    -ms-flex: 1;
    flex: 1;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block;
    position: relative;
    line-height: 1.42857143;
    text-decoration: none;
    color: #1f1f1f;
    margin: 5px;
    padding: 20px 10px; }

.pager .previous,
.pager .next,
.pager .back {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -moz-box-flex: 1;
  -moz-flex: 1;
  -ms-flex: 1;
  flex: 1; }
.pager .previous,
.pager .next {
  width: calc( 50% - 80px ); }
.pager .back {
  width: 10em; }
.pager .previous a {
  padding-left: 3em;}
  .pager .previous a:before {
    content: "";
    position: absolute;
    left: 2px;
    top: 31px;
	width: 20px;
	height: 1px;
	background: #1F1F1F;}
.pager .previous a:after {
    content: "";
    position: absolute;
    left: 2px;
    top: 28px;
	width: 7px;
	height: 1px;
	background: #1F1F1F;
	transform: rotate(-45deg);}
.pager .next a {
  padding-right: 3em; }
  .pager .next a:after {
    content: "";
    position: absolute;
    right: 2px;
    top: 31px;
	width: 20px;
	height: 1px;
	background: #1F1F1F;}
.pager .next a:before {
    content: "";
    position: absolute;
    right: 2px;
    top: 28px;
	width: 7px;
	height: 1px;
	background: #1F1F1F;
	transform: rotate(45deg);}
	.pager .back a {
  border: 1px solid #1F1F1F;  }

/*
 pagination

 */
.pagination {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  text-align: center; }
  .pagination > li {
    position: relative; }
  .pagination > span,
  .pagination > li > a {
    border-radius: 4px;
    border: 1px solid #ccc;
    color: #1F1F1F;
    margin: 3px;
    width: 2.4em;
    height: 2.4em;
    line-height: 2.4;
    display: block;
    text-decoration: none;
    padding: 0; }
  .pagination > span {
    border-color: #1F1F1F;
    cursor: default; }
  .pagination > li > a:active, .pagination > li > a:hover, .pagination > li > a:visited {
    border-color: #D90000;
    color: #D90000; }
  .pagination span.dot {
    border: none;
    width: 1em; }

/**
 * Grid System width Flex
 */
.flexbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;}

.flex-inline {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex; }

.flex-row {
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -ms-flex-direction: row;
  flex-direction: row; }

.flex-row-rev {
  -webkit-box-direction: reverse;
  -webkit-box-orient: horizontal;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse; }

.flex-col {
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -ms-flex-direction: col;
  flex-direction: col; }

.flex-col-rev {
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -ms-flex-direction: col-reverse;
  flex-direction: col-reverse; }

.flex-nowrap {
  -ms-flex-wrap: none;
  flex-wrap: nowrap; }

.flex-wrap {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }

.flex-wrap-reverse {
  -ms-flex-wrap: wrap-reverse;
  flex-wrap: wrap-reverse; }

.flex-justify-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }

.flex-justify-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; }

.flex-justify-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }

.flex-justify-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.flex-justify-around {
  -ms-flex-pack: distribute;
  justify-content: space-around; }

.flex-align-start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start; }

.flex-align-end {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end; }

.flex-align-center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }

.flex-align-baseline {
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline; }

.flex-align-stretch {
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch; }

.flex-content-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }

.flex-content-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; }

.flex-content-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }

.flex-content-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.flex-content-around {
  -ms-flex-pack: distribute;
  justify-content: space-around; }

.flex-content-around {
  -webkit-box-pack: stretch;
  -ms-flex-pack: stretch;
  justify-content: stretch; }


/*
 toggle button

*/
.toggle {
  display: none; }

@media screen and (max-width: 767px) {
  .toggle {
    cursor: pointer;
    display: inline-block;
    background: none;
    border: none;
    outline: none;
    position: absolute;
    padding: 13px;
    right: 10px;
    text-align: center;
    top: 5px;
    z-index: 3; }

  .toggle__bar {
    position: relative;
    margin-top: 8px;
    margin-bottom: 8px;
    margin-left: auto;
    margin-right: auto;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none; }
    .toggle__bar, .toggle__bar::before, .toggle__bar::after {
      display: block;
      width: 25px;
      height: 3px;
      background-color: #1F1F1F;
      outline: 1px solid transparent;
      -webkit-transition-property: background-color, -webkit-transform;
      -moz-transition-property: background-color, -moz-transform;
      -o-transition-property: background-color, -o-transform;
      transition-property: background-color, transform;
      -webkit-transition-duration: 0.3s;
      -moz-transition-duration: 0.3s;
      -o-transition-duration: 0.3s;
      transition-duration: 0.3s; }
    .toggle__bar::before, .toggle__bar::after {
      position: absolute;
      content: ""; }
    .toggle__bar::before {
      top: -8px; }
    .toggle__bar::after {
      top: 8px; }

  .toggle__title {
    font-size: 10px;
    font-size: 1rem;
    display: block;
    padding-top: 5px;
    width: 4em;
    white-space: nowrap; }

  .toggle__title:before {
    content: "メニュー"; } }
.toggle[aria-expanded="true"] .toggle__bar {
  background-color: transparent; }
.toggle[aria-expanded="true"] .toggle__bar::before {
  -webkit-transform: translateY(8px) rotate(45deg);
  -moz-transform: translateY(8px) rotate(45deg);
  -ms-transform: translateY(8px) rotate(45deg);
  -o-transform: translateY(8px) rotate(45deg);
  transform: translateY(8px) rotate(45deg); }
.toggle[aria-expanded="true"] .toggle__bar::after {
  -webkit-transform: translateY(-8px) rotate(-45deg);
  -moz-transform: translateY(-8px) rotate(-45deg);
  -ms-transform: translateY(-8px) rotate(-45deg);
  -o-transform: translateY(-8px) rotate(-45deg);
  transform: translateY(-8px) rotate(-45deg); }
.toggle[aria-expanded="true"] .toggle__title:before {
  content: "とじる"; }

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

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

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

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

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

.slick-prev {
  background: url(img/slide_prev.png) no-repeat center center;
  z-index: 100;
  top: 50%;
  left: 50%;
  margin-left: -31%;
  width: 70px;
  height: 75px; }

.slick-next {
  background: url(img/slide_next.png) no-repeat center center;
  z-index: 100;
  top: 50%;
  right: 50%;
  margin-right: -31%;
  width: 70px;
  height: 75px; }

.slick-arrow {
  margin-top: -35px;
  border: none;
  text-indent: -300px;
  overflow: hidden;
  position: absolute; }

.slick-dots {
  list-style: none;
  text-align: center;
  border: none;
  position: absolute;
  bottom: -10px;
  width: 100%;
  padding: 0; }

.slick-dots > li {
  display: inline-block;
  margin: 0 5px; }

.slick-dots > li > button {
  width: 60px;
  height: 3px;
  padding: 0;
  border: none;
  text-indent: -9999px;
  background: rgba(255, 255, 255, 0.5); }

.slick-dots > li.slick-active button {
  width: 60px;
  height: 3px;
  background: #ececfb; }

.m-0 {
  margin: 0; }

.mt-0 {
  margin-top: 0; }

.mb-0 {
  margin-bottom: 0px; }

.mb-10 {
  margin-bottom: 10px; }

.mb-20 {
  margin-bottom: 20px; }

.mb-30 {
  margin-bottom: 30px; }

.mb-40 {
  margin-bottom: 40px; }

.mb-50 {
  margin-bottom: 50px; }

.mb-60 {
  margin-bottom: 60px; }

.mb-70 {
  margin-bottom: 70px; }

.mb-80 {
  margin-bottom: 80px; }

.mb-90 {
  margin-bottom: 90px; }

.mb-100 {
  margin-bottom: 100px; }

.mb-110 {
  margin-bottom: 110px; }

.mb-120 {
  margin-bottom: 120px; }

.mb-130 {
  margin-bottom: 130px; }

.mb-140 {
  margin-bottom: 140px; }

.mb-150 {
  margin-bottom: 150px; }

.mb-160 {
  margin-bottom: 160px; }

.mb-170 {
  margin-bottom: 170px; }

.mb-180 {
  margin-bottom: 180px; }

.mb-190 {
  margin-bottom: 190px; }

.mb-200 {
  margin-bottom: 200px; }

.mt-0 {
  margin-top: 0px; }

.mt-10 {
  margin-top: 10px; }

.mt-20 {
  margin-top: 20px; }

.mt-30 {
  margin-top: 30px; }

.mt-40 {
  margin-top: 40px; }

.mt-50 {
  margin-top: 50px; }

.mt-60 {
  margin-top: 60px; }

.mt-70 {
  margin-top: 70px; }

.mt-80 {
  margin-top: 80px; }

.mt-90 {
  margin-top: 90px; }

.mt-100 {
  margin-top: 100px; }

.mt-110 {
  margin-top: 110px; }

.mt-120 {
  margin-top: 120px; }

.mt-130 {
  margin-top: 130px; }

.mt-140 {
  margin-top: 140px; }

.mt-150 {
  margin-top: 150px; }

.mt-160 {
  margin-top: 160px; }

.mt-170 {
  margin-top: 170px; }

.mt-180 {
  margin-top: 180px; }

.mt-190 {
  margin-top: 190px; }

.mt-200 {
  margin-top: 200px; }

.mb-1em {
  margin-bottom: 1em; }
.mb-2em {
  margin-bottom: 2em; }

.fl-l {
  float: left; }
.fl-r {
  float: right; }

.fl-box.fl-l {
  margin-right: 20px; }
.fl-box.fl-r {
  margin-left: 20px; }

@media screen and (min-width: 992px) {
  .fl-md-l {
    float: left; }
  .fl-md-r {
    float: right; }

  .fl-box.fl-md-l {
    margin-right: 20px; }
  .fl-box.fl-md-r {
    margin-left: 20px; } }
@media screen and (min-width: 768px) {
  .fl-sm-l {
    float: left; }
  .fl-sm-r {
    float: right; }

  .fl-box.fl-sm-l {
    margin-right: 20px; }
  .fl-box.fl-sm-r {
    margin-left: 20px; } }
/*
 status

 */
.overflow {
  overflow: hidden; }

.block {
  display: block; }

.inline {
  display: inline; }

.inlineblock {
  display: inline-block; }

.pc .opa:hover {
  opacity: .75; }

.txt-base {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  margin: 0 0 10px; }

.fz-s {
  font-size: 10px;
  font-size: 1rem; }
.fz-n {
  font-size: 14px;
  font-size: 1.4rem; }
.fz-ms {
  font-size: 16px;
  font-size: 1.6rem; }
.fz-m {
  font-size: 18px;
  font-size: 1.8rem; }
.fz-l {
  font-size: 20px;
  font-size: 2rem; }

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

.bold {
  font-weight: bold; }

.normal {
  font-weight: normal; }

.lighter {
  font-weight: lighter; }

.right {
  text-align: right; }

.center {
  text-align: center; }

.left {
  text-align: left; }

.vat {
  vertical-align: top; }

.vam {
  vertical-align: middle; }

.vab {
  vertical-align: bottom; }

.relative {
  position: relative; }

.color-brand {
  color: #D90000; }

.red {
  color: red; }

.blue {
  color: blue; }

.green {
  color: green; }

.bgc-brand {
  background-color: #D90000; }

.none {
  display: none; }

.none-before:before {
  display: none; }

.none-after:after {
  display: none; }

@media screen and (max-width: 991px) {
  .md-center {
    text-align: center; }
  .md-block {
    display: block; }
  .md-inline {
    display: inline; }
  .md-none {
    display: none; } }
@media screen and (max-width: 767px) {
  .sm-center {
    text-align: center; }
  .sm-block {
    display: block; }
  .sm-inline {
    display: inline; }
  .sm-none {
    display: none; } }
@media screen and (max-width: 480px) {
  .xs-center {
    text-align: center; }
  .xs-block {
    display: block; }
  .xs-inline {
    display: inline; }
  .xs-none {
    display: none; } }
.container {
  width: 100%;
  max-width: 1130px;
  margin: 0 auto;
  padding-right: 15px;
  padding-left: 15px; }

.header {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1160px;
  margin-right: auto;
  margin-left: auto;
  padding: 20px 15px; }
  .header .logo {
    margin: 0;
    font-size: 14px;
    font-size: 1.4rem; }

@media screen and (min-width: 768px) {
  .gnav {
    display: block;
    height: auto !important; } }
.gnav {
  z-index: 1; }

.header__nav__list {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  margin-left: -15px;
  margin-bottom: 0; }
  .header__nav__list li {
    padding-left: 15px;
    margin-bottom: 0; }
    .header__nav__list li a {
      display: block;
      font-weight: bold;
      text-decoration: none;
      border-bottom: 1px solid transparent;
      color: #1F1F1F; }
    .header__nav__list li a.current {
      border-bottom: 1px solid #36A0DA; }

.header__sns__list {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 0; }
  .header__sns__list li {
    margin-bottom: 0;
    padding-left: 10px; }
  .header__sns__list::before {
    content: "|";
    color: #AAA; }

@media screen and (max-width: 767px) {
  .gnav {
    position: absolute;
    top: 70px;
    right: 0;
    left: 0;
    width: 100%;
    background: rgba(255, 255, 255, 0.7); }

  .header__nav__list {
    display: block;
    margin-left: 0; }
    .header__nav__list li {
      padding-left: 0; }
      .header__nav__list li a {
        padding-top: 5px;
        padding-bottom: 5px;
        border-bottom: 1px solid #666;
        text-align: center; }

  .header__sns__list {
    margin-right: 60px; } }

.breadcrumbs ul,
.breadcrumbs ol {
  list-style: none;
  padding: 0; }
.breadcrumbs li {
  display: inline;
  margin: 0; }
.breadcrumbs li:before {
  content: ">";
  margin: 0 10px; }
.breadcrumbs li:first-child:before {
  display: none; }

.side-bar {
  right: 0;
  top: 160px;
  position: fixed;
  z-index: 10; }
  .side-bar > div {
    margin-bottom: 10px; }

.official__list {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 60%; }
  .official__list li {
    width: 48%;
    max-width: 273px;
    padding-right: 1px; }
    .official__list li a {
      display: block;
      text-decoration: none; }
      .official__list li a .ttl {
        color: #FFF;
        padding: 18px 0;
        text-align: center; }
      .official__list li a .ttl-facebook {
        background: #2F58A7; }
      .official__list li a .ttl-insta {
        background: #202E53; }
      .official__list li a .ttl-abema {
        background: #4CAC26; }



.footer {
  background: #151515;
  padding-top: 70px; }

.foot__inner {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  position: relative;  }

.foot__nav__list__wrap {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: distribute;
  -webkit-justify-content: space-around;
  -moz-justify-content: space-around;
  justify-content: space-around;
  width: 100%;
  margin-left: 50px;}

.foot__nav__list li.ttl {
  margin-bottom: 15px; }
  .foot__nav__list li.ttl a,
  .foot__nav__list li.ttl {
    font-weight: bold; }
.foot__nav__list li a,
.foot__nav__list li.ttl,
footer .sns_list li a {
  display: block;
  color: #FFF;
  text-decoration: none; }

footer .sns_list{
	position: absolute;
	left: 0;
	bottom: -50px;
	margin: 0;
	padding: 0;
}

footer .sns_list li{
	margin: 0 10px 0 0;
	list-style: none;
}

footer .sns_list li.qr a{
	padding: 1px 5px;
	border: 1px solid #FFF;
}

footer .sns_list li.line{
	margin-left: 25px;
	position: relative;
}

footer .sns_list li.line::before{
	position: absolute;
	content: "|";
	left: -20px;
	color: #DDD;
}

footer .sns_list li i{
	vertical-align: middle;
}

.foot__logo {
  -webkit-flex-shrink: 0;
  -moz-flex-shrink: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0; }

.foot__info__wrap {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border-top: 1px solid #414141;
  color: #FFF;
  padding: 10px 0;
  margin-top: 60px; }
  .foot__info__wrap * {
    margin-bottom: 0; }
  .foot__info__wrap .add {
    font-size: 10px;
    font-size: 1rem; }
  .foot__info__wrap .foot__contact {
    -js-display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex; }
    .foot__info__wrap .foot__contact li {
      margin-left: 10px; }
      .foot__info__wrap .foot__contact li a {
        text-decoration: none;
        color: #FFF; }
    .foot__info__wrap .foot__contact .mail::after {
      content: "|";
      margin-left: 10px; }

@media screen and (max-width: 767px) {
  .official__list {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%; }
    .official__list li {
      width: 50%;
      margin: 10px auto; }
      .official__list li a {
        display: block;
        text-decoration: none; }
        .official__list li a .ttl {
          margin-bottom: 0; }
        .official__list li a .img img {
          width: 100%; }
  .sns-box.flexbox{
    display: block;
  }
  .fb-box{
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
  }

  .footer {
    background: #151515;
    padding-top: 40px; }

  .foot__inner {
    display: block; }

  .foot__nav__list__wrap {
    display: none; }

  .foot__logo {
    text-align: center;
    margin-bottom: 20px; }

  .foot__info__wrap {
    display: block; } }
@media screen and (max-width: 480px) {
  .official__list {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .official__list li {
      width: 100%; }

  .foot__info__wrap {
    display: block; }
    .foot__info__wrap .foot__contact li {
      margin-left: 5px; }
    .foot__info__wrap .foot__contact .mail::after {
      content: "|";
      margin-left: 5px; } }
/* ------------------------------

  共通スタイル(タイトルなど)

------------------------------ */
.page__ttl__wrap {
  background: url(img/common/bg_page_ttl.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  padding: 90px 0 60px;
  margin: 0 0 100px; }
  .page__ttl__wrap h1 {
    text-align: center;
    font-weight: normal;
    color: #FFF; }
    .page__ttl__wrap h1 .ttl__en {
      font-size: 50px;
      font-size: 5rem;
      font-style: oblique;
      display: inline-block;
      width: 100%; }
    .page__ttl__wrap h1 .ttl__ja {
      font-size: 14px;
      font-size: 1.4rem;
      display: inline-block;
      width: 100%; }

.ttl01 {
  text-align: center;
  margin: 0 0 50px; }
  .ttl01 .ttl__en {
    font-size: 30px;
    font-size: 3rem;
    font-style: oblique;
    display: inline-block;
    width: 100%; }
  .ttl01 .ttl__ja {
    font-size: 14px;
    font-size: 1.4rem;
    display: inline-block;
    width: 100%; }

/*  home(top)
------------------------------ */
.main-visual {
  margin-bottom: 70px;}
  .main-visual img {
    width: 100%; }

.top__ttl-mission {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  position: relative;
  padding: 50px 45px 60px;
  border: 1px solid #DDD;
  margin: 0;
  margin-bottom: 20px;
  background: url(img/home/top__ttl-mission.png) no-repeat; }
  .top__ttl-mission .ttl__en {
    font-size: 30px;
    font-size: 3rem;
    font-style: oblique; }
  .top__ttl-mission .ttl__ja{
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    font-family: メイリオ,meirio;
    text-decoration: none;
    color: #1F1F1F;
    display: block;
    position: relative; }
    .top__ttl-mission .ttl__ja::after {
      content: url(img/common/icon_angle_r.png);
      margin-left: 15px; }
      .top__ttl-mission a{
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        text-indent: -999px;
        z-index: 2;
      }
      .top__ttl-mission a:hover{
        background-color: rgba(255,255,255,0.3);
      }

.top__ttl-mission.fb{
	background-color: #2F58A7;
	margin-bottom: 60px;
}
 .top__ttl-mission.fb .ttl__en,
  .top__ttl-mission.fb .ttl__ja{
	  color: #FFF;
  }


.top__ttl01__wrap,
.common__ttl__wrap {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  margin-bottom: 45px; }
  .top__ttl01__wrap .top__ttl01,
  .common__ttl__wrap .common__ttl  {
	  padding: 0 40px; }

.top__ttl01,
.common__ttl {
  text-align: center;
  max-width: 375px;
  margin-right: auto;
  margin-left: auto;
  position: relative; }
  .top__ttl01 .ttl__en{
    display: block;
    font-size: 30px;
    font-size: 3rem;
    font-weight: bold;
    font-style: oblique; }

  .common__ttl .ttl__en{
    display: block;
    font-size: 28px;
    font-size: 2.8rem;
    font-weight:bold;
    font-style: oblique;
    margin: 0 0 10px 0; }

  .top__ttl01 .ttl__ja {
    display: block;
    font-family: meirio,メイリオ; }

  .common__ttl .ttl__ja {
    display: block;
    font-family: meirio,メイリオ;
    font-size: 14px; }

  .top__ttl01::before,
  .common__ttl::before{
    content: "";
    width: 1px;
    height: 30px;
    background: #DDD;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -15px; }
  .top__ttl01::after,
  .common__ttl::after {
    content: "";
    width: 1px;
    height: 30px;
    background: #DDD;
    position: absolute;
    top: 50%;
    right: 0;
    margin-top: -15px; }

.f_contact_area{
  background: #000;
  color: #fff;
  padding: 60px 0 15px 0;
  margin: 0 auto 70px;
  max-width: 1130px;
}

.f_contact_area a{
  color: #fff;
  text-decoration: none;
  display: block;
}

.view-more__link {
  max-width: 190px;
  width: 100%;
  margin-left: -190px; }
  .view-more__link a {
    display: block;
    width: 100%;
    text-align: center;
    padding: 7px 0;
    text-decoration: none;
    color: #1F1F1F;
    font-style: oblique;
    border: 1px solid #1F1F1F; }

.line-up__list {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -10px;
  margin-bottom: 120px; }
  .line-up__list li {
    width: 25%;
    padding-left: 10px; }
    .line-up__list li .img {
      width: 100%;
      margin-bottom: 10px; }
    .line-up__list li .txt {
      -js-display: flex;
      display: -webkit-box;
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flexbox;
      display: flex; }
      .line-up__list li .txt .ico {
        width: 50px;
        line-height: 50px; }
      .line-up__list li .txt .desc p {
        margin-bottom: 0; }
      .line-up__list li .txt .desc .ttl__ja {
        font-size: 18px;
        font-size: 1.8rem; }
      .line-up__list li .txt .desc .ttl__en {
        font-size: 12px;
        font-size: 1.2rem;
        font-weight: bold; }

.top-news__list {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex; }
  .top-news__list li {
    width: 25%; }
    .top-news__list li a {
      text-decoration: none;
      color: #1F1F1F; }
      .top-news__list li a .txt {
        padding: 20px; }
        .top-news__list li a .txt .category {
          font-size: 12px;
          font-size: 1.2rem;
          font-weight: bold;
          margin-bottom: 0; }

.top-features .cont{
	margin: 30px 0 50px;
}

.top-features .cont .img_box{
	width: 45%;
}

.top-features .cont .txt_box{
	width: 53%;
}

.top-features .cont h3{
	margin: 0 0 20px;
	padding: 0 10px 10px;
	border-bottom: 2px solid #111;
}

.top-features .cont h3 span{
	display: inline-block;
	font-size: 14px;
	margin-left: 10px;
	color: #666;
}

.top-features .cont p.btn_fb,
.top-features .cont p.btn_movie{
	width: 49%;
}

.top-features .cont p.btn_fb a,
.top-features .cont p.btn_movie a{
	display: block;
	text-align: center;
	padding: 15px;
	color: #FFF;
	text-decoration: none;
	background: #2F58A7;
}

.top-features .cont p.btn_movie a{
	background: #222;
}

.top-features .cont table{
	margin-bottom: 20px;
}

.top-features .cont th{
	padding: 0 0 10px 0;
	width: 100px;
	vertical-align: top;
}

.top-features .cont td{
	padding: 0 0 10px 0;
}

@media screen and (max-width: 767px) {
  .main-visual {
    margin-bottom: 70px; }

  .top__ttl-mission {
    display: block;
    padding: 30px 15px 30px;
    border: 1px solid #DDD;
    margin: 0;
    margin-bottom: 60px;
    text-align: center; }

  .top__ttl01__wrap {
    display: block;
    margin-bottom: 45px; }

  .top__ttl01 {
    padding: 0 15px !important;
    margin-bottom: 20px; }

  .view-more__link {
    margin-right: auto;
    margin-left: auto; }

  .line-up__list li {
    width: 33.333333%;
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3); }

  .top-news__list {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    .top-news__list li {
      width: 50%; }
      .top-news__list li a .txt {
        padding: 10px; }

	.top-features .cont{
		margin: 30px 0 50px;
	}

	.top-features .cont .img_box,
	.top-features .cont .txt_box{
		width: 100%;
	}

	.top-features .cont .img_box{
		text-align: center;
		margin-bottom: 20px;
	}

	.top-features .cont h3{
		padding: 0 0 10px;
	}

	.top-features .cont h3 span{
		display: block;
		font-size: 14px;
		margin-left: 0;
	}

	.top-features .cont p.btn_fb,
	.top-features .cont p.btn_movie{
		width: 100%;
	}

}


@media screen and (max-width: 480px) {
  .main-visual {
    margin-bottom: 70px; }

  .line-up__list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
    margin-left: 0; }
    .line-up__list li {
      width: auto;
      padding-left: 0;
      margin-bottom: 20px; }

  .top-news__list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center; }
    .top-news__list li {
      max-width: 275px;
      width: auto; }

  .top-features__list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center; }
    .top-features__list li {
      width: auto; } }
/*  company
------------------------------ */
.company__circle__wrap {
  -js-display: flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  -webkit-justify-content: space-around;
  -moz-justify-content: space-around;
  justify-content: space-around;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  max-width: 680px;
  margin-right: auto;
  margin-bottom: 60px;
  margin-left: auto; }
  .company__circle__wrap .circle {
    -js-display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    align-items: center;
    border: 1px solid #1F1F1F;
    width: 240px;
    height: 240px;
    -webkit-border-radius: 100%;
    border-radius: 100%;
    text-align: center; }
  .company__circle__wrap .cross {
    position: relative;
    width: 70px;
    height: 70px; }
    .company__circle__wrap .cross::before {
      content: "";
      width: 99px;
      height: 1px;
      position: absolute;
      top: 50%;
      left: -20%;
      background: #1F1F1F;
      -webkit-transform: rotate(45deg);
      -moz-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
      -o-transform: rotate(45deg);
      transform: rotate(45deg); }
    .company__circle__wrap .cross::after {
      content: "";
      width: 99px;
      height: 1px;
      position: absolute;
      top: 50%;
      left: -20%;
      background: #1F1F1F;
      -webkit-transform: rotate(-45deg);
      -moz-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
      -o-transform: rotate(-45deg);
      transform: rotate(-45deg); }

.company__ttl {
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
  margin-bottom: 40px; }

.company__desc {
  text-align: center;
  margin-bottom: 80px; }

.company01 .common__ttl{
  max-width: 575px;
}

.company02{
  margin: 0 0 100px 0;
  padding: 70px 0 100px 0;
  background: url(img/company/bg_company.jpg);
}

.company02 .common__ttl{
  max-width: 445px;
}

.company02 .flexbox{
  padding: 0 15px;
}

.company02 .flexbox .photo{
  width: 33%;
  margin: 0 60px 0 0;
}

.company02 .flexbox .txt{
  width: 65%;
}

.company03{
  margin: 0 0 110px 0;
}

.company03 table{
  width: 100%;
  border-top: 1px solid #DDDDDD;
  margin: 50px 0 100px 0;
}

.company03 table th{
  text-align: left;
  padding: 20px;
  width: 15%;
  min-width: 135px;
  border-bottom: 1px solid #DDDDDD;
  vertical-align: top;
}

.company03 table td{
  padding: 20px;
  width: 85%;
  border-bottom: 1px solid #DDDDDD;
}

.company03 table td span{
  display: inline-block;
  width: 100px;
}

.company03 iframe{
  width: 100%;
  height: 400px;
  margin: 30px 0 0 0;
}

@media screen and (max-width: 767px) {
.company__circle__wrap{
  display: block;
}

.company__circle__wrap .circle{
  margin: 0 auto;
}

.company__circle__wrap .cross{
  margin: 30px auto;
}

.company__desc{
    margin-bottom: 40px;
}

.company02 {
    margin: 0 0 70px 0;
    padding: 70px 0 70px 0;
}

.company02 .flexbox{
  display: block;
}
.company02 .flexbox .photo{
  width: 100%;
  text-align: center;
  margin: 0 0 40px 0;
}

.company02 .flexbox .txt{
  width: 100%;
}

.company03 table{
  margin: 50px 0 70px 0;
}

.company03 table th,
.company03 table td {
  padding: 20px 5px;
}

.company03 table th{
    min-width: 85px;
  }

.company03 iframe{
  margin: 0;
}
}

/*  service
------------------------------ */

.service01{
  margin-top: -100px;
  margin-bottom: 0px;
  padding-top: 100px;
  background: url(img/lineup/bg.png);
}

.service01 div.flexbox{
  margin: 0 0 170px 0;
}

.service01 div.flexbox .txt{
  margin: 10px 0 0 0;
}

.service01 div.flexbox .img{
  width: 100%;
  max-width: 620px;
  margin: 0 40px 0 0;
}

.service02{
  margin: 0 0 100px 0;
}

.service02 ul{
  padding: 0
}

.service02 ul li{
  width: 31%;
  margin: 0 3.5% 40px 0;
  list-style: none;
}

.service02 ul li:nth-child(3n){
  margin: 0 0 40px 0;
}

.service02 ul li img{
  width: 100%;
  display: block;
  margin: 0 0 5px 0;
}

.service02 ul li h4{
	font-weight: bold;
}

.service02 ul li h4 span{
	display: inline-block;
	margin-left: 10px;
	font-size: 14px;
}

.service02 ul li p span{
	display: inline-block;
	border-bottom: 1px solid #36A0DA;
	font-weight: bold;
	margin-top: 5px;
}

@media screen and (max-width: 767px) {
.service01 div.flexbox{
  display: block;
}

.service01 div.flexbox .txt{
  margin: 30px 0 0 0;
}

.service02 ul{
  margin: -50px 0 0 0;
}

.service02 ul li{
  width: 46%;
  margin: 0 2% 30px 2%;
  list-style: none;
}

.service02 ul li:nth-child(3n){
  margin: 0 2% 30px 2%;
}
}

@media screen and (max-width:450px) {

.service02 ul li{
  width: 100%;
  margin: 0 0 30px 0;
  list-style: none;
}

.service02 ul li:nth-child(3n){
  margin: 0 0 30px 0;
}
}


/*  features
------------------------------ */

/*  voice
------------------------------ */
.voice01{
  margin: 0 0 140px 0;
}

.voice01 .flexbox{
  padding: 45px 5px 35px 5px;
  border-bottom: 1px solid #DDDDDD;
}

.voice01 .flexbox .photo{
  width: 200px;
  margin: 0 40px 0 0;
  text-align: center;
}

.voice01 .flexbox .txt{
  width: 100%;
  max-width: 850px;
}

.voice01 .flexbox .txt h2{
  position: relative;
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 20px 0;
  padding: 0 0 0 40px;
}

.voice01 .flexbox .txt h2:before{
  position: absolute;
  top: -3px;
  left: 0;
  content: url(img/voice/voice_icon.png);
}

@media screen and (max-width: 767px) {

.voice01{
  margin: 0 0 100px 0;
}

.voice01 .flexbox{
  display: block;
  padding: 45px 15px 35px 15px;
}

.voice01 .flexbox .photo{
  width: 100%;
  margin: 0 0 30px 0;
}

.voice01 .flexbox .txt{
  max-width: 100%;
}
}


/*  news
------------------------------ */
.news01{
  margin: 0 0 100px 0;
}

.news01 ul{
  padding: 0;
}

.news01 .flex-wrap li{
  width: 25%;
  margin: 0 0 70px 0;
  list-style: none;
}

.news01 .flex-wrap li a {
  color: #000;
  text-decoration: none;
}

.news01 .flex-wrap li a > div{
  padding: 0 8% 0 8%;
}

.news01 .flex-wrap li img{
  width: 100%;
  display: block;
  margin: 0 0 25px 0;
}

.news01 .flex-wrap li h2{
  font-size: 12px;
  font-weight: bold;
  margin: 0 0 10px 0;
}

.news01 .wp-pagenavi{
  margin: 80px 0 0 0;
}

.wp-pagenavi{
    display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
}

.wp-pagenavi a, .wp-pagenavi span {
    font-size: 1.6rem;
    -webkit-border-radius: 100%;
    border-radius: 100%;
    border: 1px solid #DDDDDD;
    color: #000;
    margin: 4px;
    width: 2.4em;
    height: 2.4em;
    line-height: 2.4;
    display: block;
    text-decoration: none;
    padding: 0;
}

.wp-pagenavi span.current {
    border: 0px;
    color: #fff;
    background: #000;
    font-weight: normal;
}

.wp-pagenavi a.previouspostslink {
  margin-right: 25px;
  background: #F6F6F8;
  border: 1px solid #F6F6F8;
}

.wp-pagenavi a.nextpostslink {
  margin-left: 25px;
  background: #F6F6F8;
  border: 1px solid #F6F6F8;
}

.wp-pagenavi a.previouspostslink:hover,
.wp-pagenavi a.nextpostslink:hover{
  border: 1px solid #F6F6F8;
}

.wp-pagenavi a:hover{
  border: 1px solid #DDDDDD;
}

@media screen and (max-width: 767px) {
.news01 .flex-wrap li{
  width: 50%;
  margin: 0 0 50px 0;
  list-style: none;
}

.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink {
  margin:0;
}

.news01 .flex-wrap li a > div{
  padding: 0 5% 0 5%;
}
  }

@media screen and (max-width: 450px) {
.news01 .flex-wrap li{
  width: 100%;
  margin: 0 0 50px 0;
  list-style: none;
}
}

/*  sitemap
------------------------------ */
.sitemap01{
  margin: 0 0 120px 0;
}

.sitemap01 ul{
  padding: 0;
  margin: 0;
  border-top: #DDDDDD 1px solid;
}

.sitemap01 ul li{
  border-bottom: #DDDDDD 1px solid;
  list-style: none;
  margin: 0;
  padding: 50px 0 40px 35px;
  position: relative;
}

.sitemap01 ul li:before{
  position: absolute;
  content: "";
  width: 23px;
  height: 2px;
  left: 0;
  top: 58px;
  background: #000;
}

.sitemap01 ul li h2{
  margin: 0 0 10px 0;
  font-size: 18px;
  font-weight: bold;
}

.sitemap01 ul a{
 color: #000;
 text-decoration:none;
}

.sitemap01 ul li > a{
display: inline-block;
 margin: 10px 0 0 0 ;
}

.sitemap01 ul li.lineup > a{
  width: 140px;
}

.sitemap01 ul li.features > a{
  margin: 10px 30px 0 0;
}

.sitemap01 ul li.official > a{
  margin: 10px 40px 0 0;
}

@media screen and (max-width: 1000px) {
.sitemap01 ul li br{
  display: none;
}
}

@media screen and (max-width: 511px) {
.sitemap01 ul li > a{
  width: 47%!important;
  margin: 10px 2% 0 0!important;
}
}

@media screen and (max-width: 511px) {
.sitemap01 ul li > a{
  width: 100%!important;
  margin: 20px 0 0 0!important;
}
}

/*  privacy
------------------------------ */

.privacy01{
  margin: 0 0 120px 0;
}

.privacy01 .container > p{
  margin: 0 0 40px 0;
}

.privacy01 ul{
  padding: 0;
  margin: 0;
  border-top: #DDDDDD 1px solid;
}

.privacy01 ul li{
  border-bottom: #DDDDDD 1px solid;
  list-style: none;
  margin: 0;
  padding: 50px 0 40px 35px;
  position: relative;
}

.privacy01 ul li:before{
  position: absolute;
  content: "";
  width: 23px;
  height: 2px;
  left: 0;
  top: 58px;
  background: #000;
}

.privacy01 ul li h2{
  margin: 0 0 15px 0;
  font-size: 18px;
  font-weight: bold;
}

.privacy01 ul li p{

}

/*  faq
------------------------------ */

.accordionbox{
  width: 100%;
  margin: 0px auto 40px;
}
.accordionlist dt{
  position: relative;
  font-size: 16px;
  font-weight: bold;
    display:block;
    padding: 40px 0 40px 0px;
    border-top: 1px solid #DFDFDF;
    cursor: pointer;
}
.accordionlist dt:first-child{
    border-top: none !important;
}
.accordionlist dt .title{
  float: left;
}

.accordionlist dt h2{
  font-size: 18px;
  font-weight: bold;
  position: relative;
  margin: 0;
  padding: 0 50px 0 65px;
  line-height: 1.9;
}

.accordionlist dt h2 span{
    position: absolute;
    left: 0;
    top: -4px;
    border-radius: 100%;
    -webkit-border-radius: 100%;
    padding: 12px;
    background: #000;
    line-height: 0.8;
    font-size: 18px;
    color: #fff;
}

.accordionlist dd{
    display:none;
  padding:0 0 40px 65px;
  position: relative;
  line-height: 1.9;
}

.accordionlist dd span{
    position: absolute;
    left: 0;
    border-radius: 100%;
    -webkit-border-radius: 100%;
    padding: 12px;
    background: #F3F3F3;
    line-height: 0.8;
    font-size: 18px;
    font-weight: bold;
    color: #000;
}

.accordionlist{
  margin: 0;
   border-bottom: 1px solid #DFDFDF;
}

.accordion_icon_wrap{
  position: absolute;
  right : 0;
}

.accordion_icon,
.accordion_icon span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.accordion_icon {
  position: relative;
  width: 40px;
  height: 40px;
  float: right;
}
.accordion_icon span {
  position: absolute;
    right: : 6px;
    width: 30px;
  height: 4px;
    background-color: #000;
  border-radius: 4px;
  -webkit-border-radius: 4px;
  -ms-border-radius: 4px;
  -moz-border-radius: 4px;
  -o-border-radius: 4px;
}
.accordion_icon span:nth-of-type(1) {
    top: 13px;
  transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
    -o-transform: rotate(0deg);
}
.accordion_icon span:nth-of-type(2) {
    top: 13px;
  transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
}
/*＋、－切り替え*/
.accordion_icon_wrap.active span:nth-of-type(1) {
  display:none;
}
.accordion_icon_wrap.active span:nth-of-type(2) {
  top: 13px;
  transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
    -o-transform: rotate(180deg);
}

/*  brand
------------------------------ */
.brand01 h2{
  margin: 0 0 35px 0;
  font-size: 18px;
  padding: 0 0 0 35px;
  font-weight: bold;
  position: relative;
}

.brand01 h2:before{
  position: absolute;
  content: "";
  width: 23px;
  height: 2px;
  left: 0;
  top: 8px;
  background: #000;
}

.brand01 ul{
  padding: 0;
  margin: 0 0 80px 0;
}

.brand01 ul li{
  list-style: none;
  margin: 0 2px 0 0;
}

.brand01 ul li:nth-child(4){
  margin: 0 0 0 0;
}

.brand01 .media_area{
  margin: 0 0 70px 0;
}

.video{
  position:relative;
  width:100%;
  padding-top:56.25%;
  margin: 0 0 35px 0;
}
.video iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}

@media screen and (max-width: 767px) {
.brand01 ul{
  display: block;
}

.brand01 ul li{
  width: 49%;
  margin: 0 0.5% 2px 0.5%;
  float: left;
}

.brand01 ul li img{
  width: 100%;
}

.brand01 ul li:nth-child(4){
  margin: 0 0.5% 2px 0.5%;
}
}


@media screen and (max-width: 400px) {

.brand01 ul li{
  width: 99%;
  margin: 0 0.5% 2px 0.5%;
  float: left;
}

.brand01 ul li:nth-child(4){
  margin: 0 0.5% 2px 0.5%;
}
}


/*  contact
------------------------------ */

.contact01{
  margin: 0  0 130px 0;
}

.contact01 h2{
  margin: 0 0 35px 0;
  font-size: 18px;
  padding: 0 0 0 35px;
  font-weight: bold;
  position: relative;
}

.contact01 h2:before{
  position: absolute;
  content: "";
  width: 23px;
  height: 2px;
  left: 0;
  top: 8px;
  background: #000;
}

.contact01 .container > p:first-child{
   margin: 0 0 60px 0;
}

.contact01 .contact_area{
   padding: 20px 25px;
   background: #F6F6F8;
   margin: 0 0 100px 0;
}

.contact01 .contact_area p{
  margin: 0;
}

.contact01 .contact_area p:last-child{
  margin: 0 0 0 30px;
}

.contact01 p span{
    border-radius: 5px;
    -webkit-border-radius: 5px;
    background: #000;
    color: #fff;
    margin: 0 4px;
    padding: 1px 8px;
}

.contact01 table{
  width: 100%;
  border-top: #DDDDDD 1px solid;
  margin: 20px 0 0 0;
}

.contact01 th{
  width: 20%;
  min-width: 230px;
  padding: 20px 20px 20px 70px;
  vertical-align: top;
  position: relative;
  border-bottom: #DDDDDD 1px solid;
}

.contact01 th span{
  position: absolute;
  left: 0;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  background: #000;
  color: #fff;
  font-weight: normal;
  margin: 0 4px;
  padding: 1px 8px;
}

.contact01 td{
  width: 80%;
  padding: 10px;
  border-bottom: #DDDDDD 1px solid;
}

.contact01 input{
  border: solid 1px #DDDDDD;
  padding: 3px;
  width: 100%;
  max-width: 300px;
}

.contact01  textarea{
  border: solid 1px #DDDDDD;
  padding: 3px;
  width: 100%;
  max-width: 500px;
  margin: 10px 0;
}

.contact01 .submit_area{
  margin: 50px 0 0 0;
}

.contact01 .submit_area .back{
  width: 100%;
  max-width: 680px;
  border: 1px solid #000;
  background: #fff;
  margin: 0 30px 0 0;
  position: relative;
  padding: 18px 10px;
}

.contact01 .submit_area .back:before{
    position: absolute;
    content: "";
    top: 50%;
    width: 6px;
    height: 6px;
    margin: -3px 0 0 -13px;
    border-bottom: solid 1px #000;
    border-left: solid 1px #000;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.contact01 .submit_area .com{
  width: 100%;
  max-width: 680px;
  border: 1px solid #000;
  background: #fff;
  margin: 0 30px 0 0;
  position: relative;
  padding: 18px 10px;
}

.contact01 .submit_area .com:after{
    position: absolute;
    content: "";
    top: 50%;
    width: 6px;
    height: 6px;
    margin: -3px 0 0 13px;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.contact01 .submit_area .send{
  width: 100%;
  max-width: 680px;
  border: 1px solid #000;
  background: #000;
  color: #fff;
  position: relative;
  padding: 18px 10px;
}

.contact01 .submit_area .send:after{
    position: absolute;
    content: "";
    top: 50%;
    width: 6px;
    height: 6px;
    margin: -3px 0 0 13px;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);

}

.contact01 .submit_area .back:hover,
.contact01 .submit_area .com:hover,
.contact01 .submit_area .send:hover{
  opacity: 0.8;
}

input:placeholder-shown {
    color: #C9C9C9; }

/* Google Chrome, Safari, Opera 15+, Android, iOS */
input::-webkit-input-placeholder {
    color: #C9C9C9; }

/* Firefox 18- */
input:-moz-placeholder {
    color: #C9C9C9; opacity: 1; }

/* Firefox 19+ */
input::-moz-placeholder {
    color: #C9C9C9; opacity: 1; }

/* IE 10+ */
input:-ms-input-placeholder {
    color: #C9C9C9; }

@media screen and (max-width: 767px) {

.contact01{
  margin: 0  0 120px 0;
}

.contact01 th{
  width: 100%;
  padding: 20px 0px 5px 70px;
  border: none;
  display: block;
}

.contact01 td{
  width: 100%;
  padding: 10px 0px 20px 0px;
  display: block;
  border-bottom: #DDDDDD 1px solid;
}

.contact01 textarea {
  margin: 0;
}

.contact01 .submit_area{
  display: block;
  text-align: center;
}

.contact01 .submit_area .back,
.contact01 .submit_area .com,
.contact01 .submit_area .send{
  margin: 0 auto 15px auto;
}
}


.wp-caption-text,
.wp-caption,
.aligncenter,
.alignleft,
.alignright,
.sticky,
.gallery-caption,
.bypostauthor,
.screen-reader-text {
  font-weight: normal; }



/*# sourceMappingURL=style.css.map */


/*  RECRUIT
------------------------------ */

.recruit01 .cont{
	margin: 50px 0;
}

.recruit01 .cont h2{
	font-size: 22px;
	padding-left: 30px;
	position: relative;
	margin-bottom: 20px;
}

.recruit01 .cont h2::before{
	position: absolute;
	content: "";
	width: 20px;
	height: 2px;
	left: 0;
	top: 11px;
	background-color: #1F1F1F;
}

.recruit01 .cont .img_box{
	width: 30%;
}

.recruit01 .cont .txt_box{
	width: 68%;
}

.recruit01 .cont .txt_box dl dd{
	position: relative;
	margin: 5px 0 10px;
	padding-left: 20px;
}

.recruit01 .cont .txt_box dl dd::before{
	position: absolute;
	content: "";
	width: 10px;
	height: 1px;
	background: #1F1F1F;
	left: 2px;
	top: 9px;
}

.recruit01 .cont .txt_box p span{
	display: block;
	font-weight: bold;
}

.recruit02 h2{
	text-align: center;
	margin-bottom: 50px;
	padding-bottom: 15px;
	position: relative;
}

.recruit02 h2::after{
	position: absolute;
	content: "";
	width: 80px;
	height: 1px;
	background: #1F1F1F;
	bottom: 0;
	left: 50%;
	margin-left: -40px;
}

.recruit02 .cont{
	margin: 50px 0;
}

.recruit02 .cont h3{
	font-size: 24px;
	margin-bottom: 20px;
	padding-left: 10px;
}

.recruit02 .cont h3 span{
	font-size: 16px;
}

.recruit02 table{
  width: 100%;
  border-top: 1px solid #DDDDDD;
  margin: 0 0 100px 0;
}

.recruit02 table th{
  text-align: left;
  padding: 20px;
  width: 15%;
  min-width: 135px;
  border-bottom: 1px solid #DDDDDD;
  vertical-align: top;
}

.recruit02 table td{
  padding: 20px;
  width: 85%;
  border-bottom: 1px solid #DDDDDD;
}

@media screen and (max-width: 767px) {

	.recruit01{
		margin: 0;
	}

	.recruit01 .cont{
		margin: 0 0 50px;
	}

	.recruit01 .cont .img_box{
		width: 100%;
		text-align: center;
		margin-bottom: 30px;
	}

	.recruit01 .cont .txt_box{
		width: 100%;
	}

	.recruit02 .cont{
		margin: 50px 0;
	}

	.recruit02 table{
	  margin: 0 0 50px 0;
	}

	.recruit02 table th{
	  padding: 15px;
	  min-width: 100px;
	}

	.recruit02 table td{
	  padding: 15px;
	}
}

/*  detail
------------------------------ */

.detail01 .news_ttl{
	margin-bottom: 50px;
	border-bottom: 2px solid #EEE;
}

.detail01 .news_ttl h2{
	font-weight: bold;
	padding-left: 35px;
	font-size: 26px;
	position: relative;
	margin-bottom: 20px;
}

.detail01 .news_ttl h2::before{
	content: "";
	width: 25px;
	height: 3px;
	background: #1F1F1F;
	position: absolute;
	top: 13px;
	left: 0;
}

.detail01 .news_ttl p{
	font-weight: bold;
}

.detail01 .news_ttl p span{
	font-weight: normal;
	display: inline-block;
	margin-left: 20px;
	padding-left: 20px;
	position: relative;
}

.detail01 .news_ttl p span::before{
	position: absolute;
	content: "";
	left: 0;
	top: 4px;
	width: 1px;
	height: 15px;
	background: #ccc;
}