@charset "UTF-8";
/*--- import -------------------------------------*/
* {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  word-break: break-word;
  box-sizing: border-box;
  vertical-align: baseline;
  background: transparent; }

html, body {
  overflow-x: hidden; }

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

li {
  list-style-type: none; }

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

a {
  text-decoration: none;
  color: inherit; }

img, picture {
  vertical-align: top;
  max-width: 100%; }

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

input, select {
  vertical-align: middle; }

/* safariでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box; }
  input[type="submit"]::-webkit-search-decoration,
  input[type="button"]::-webkit-search-decoration {
    display: none; }
  input[type="submit"]::focus,
  input[type="button"]::focus {
    outline-offset: -2px; }

/*------------------------------------- import ---*/
img {
  -webkit-backface-visibility: hidden; }

body {
  -webkit-text-size-adjust: 100%;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
  text-align: center;
  font-weight: normal;
  background: #000;
  font-size: 16px;
  line-height: 1.8; }

a {
  opacity: 1;
  transition: opacity .3s; }
  a:hover {
    opacity: 0.8; }

a[href^="tel:"] {
  pointer-events: none; }
  a[href^="tel:"]:hover {
    pointer-events: none; }
  @media screen and (max-width: 480px) {
    a[href^="tel:"] {
      pointer-events: inherit; }
      a[href^="tel:"]:hover {
        pointer-events: inherit; } }

.pc {
  display: block; }
  @media screen and (max-width: 750px) {
    .pc {
      display: none; } }

.pc_960 {
  display: block; }
  @media screen and (max-width: 960px) {
    .pc_960 {
      display: none; } }

.pc_480 {
  display: block; }
  @media screen and (max-width: 480px) {
    .pc_480 {
      display: none; } }

.sp_960 {
  display: none; }
  @media screen and (max-width: 960px) {
    .sp_960 {
      display: block; } }

.sp {
  display: none; }
  @media screen and (max-width: 750px) {
    .sp {
      display: block; } }

.sp_480 {
  display: none; }
  @media screen and (max-width: 480px) {
    .sp_480 {
      display: block; } }

.h_box_in {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto; }

.box_in {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto; }
  @media screen and (max-width: 1160px) {
    .box_in {
      padding: 0 40px; } }
  @media screen and (max-width: 960px) {
    .box_in {
      padding: 0 4.1666666667vw; } }
  @media screen and (max-width: 750px) {
    .box_in {
      padding: 0 5.3333333333vw; } }

.center {
  display: flex;
  justify-content: center;
  align-items: center; }

.slider_area {
  width: 980px;
  margin: 0 auto; }
  .slider_area .mv_item {
    width: 100%; }

.more a {
  color: #fff;
  border: 1px solid #fff;
  display: inline-block;
  padding: 15px 40px;
  position: relative; }
  .more a:before, .more a:after {
    content: '';
    width: 15px;
    height: 15px;
    position: absolute; }
  .more a:before {
    border-left: solid 1px #fff;
    border-top: solid 1px #fff;
    top: 4px;
    left: 4px; }
  .more a:after {
    border-right: solid 1px #fff;
    border-bottom: solid 1px #fff;
    bottom: 4px;
    right: 4px; }

section .ttl {
  position: relative;
  display: inline-block;
  margin-bottom: 60px; }
  section .ttl .item {
    position: absolute;
    top: -71px;
    left: -43px; }
  section .ttl .ttl_txt {
    font-size: 48px;
    font-weight: bold;
    line-height: 1.4;
    white-space: nowrap;
    position: relative;
    z-index: 2; }
  section .ttl:after {
    content: '';
    width: 61px;
    height: 6px;
    background: #fff;
    position: absolute;
    bottom: -15px;
    left: 0; }

@media screen and (max-width: 1200px) {
  section .ttl {
    margin-bottom: 5vw; }
    section .ttl .item {
      top: -5.9166666667vw;
      left: -3.5833333333vw; }
    section .ttl .ttl_txt {
      font-size: 4vw; }
    section .ttl:after {
      width: 5.0833333333vw;
      height: 0.5vw;
      bottom: -1.25vw; } }
@media screen and (max-width: 750px) {
  section .ttl {
    margin-bottom: 8vw; }
    section .ttl .item {
      top: -9.4666666667vw;
      left: -5.7333333333vw; }
    section .ttl .ttl_txt {
      font-size: 6.4vw; }
    section .ttl:after {
      width: 8.1333333333vw;
      height: 0.8vw;
      bottom: -2vw; } }
@media screen and (max-width: 480px) {
  section .ttl {
    margin-bottom: 11vw; }
    section .ttl .item {
      top: -16.466667vw; }
    section .ttl .ttl_txt {
      font-size: 8.4vw; }
    section .ttl:after {
      bottom: -4vw; } }
.t_h {
  background: #000;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  padding: 10px;
  text-align: center;
  position: relative;
  z-index: 5; }
  @media screen and (max-width: 1300px) {
    .t_h {
      text-align: left; } }
  @media screen and (max-width: 1080px) {
    .t_h {
      font-size: 13px; } }

header {
  background: #e6e7e9; }
  header .logo {
    display: inline-block; }
    header .logo h1 {
      margin-top: 20px; }
  @media screen and (max-width: 750px) {
    header .logo {
      left: 50% !important;
      transform: translateX(-50%) !important; }
      header .logo h1 {
        margin-top: 0; }
        header .logo h1 img {
          width: 200px; }
    header .inner #global-nav ul li {
      padding: 0; }
      header .inner #global-nav ul li a {
        padding: 6vw; } }

#head_wrap.fixed .inner {
  display: flex;
  justify-content: center;
  align-items: center; }
#head_wrap.fixed .logo h1 {
  margin-top: 0px;
  padding: 10px 10px 10px 0; }
  #head_wrap.fixed .logo h1 img {
    width: 90%;
    max-width: 302px; }
@media screen and (max-width: 1480px) {
  #head_wrap.fixed .t_h {
    text-align: left; }
  #head_wrap.fixed .inner {
    justify-content: flex-start;
    padding-left: 20px; }
  #head_wrap.fixed .logo h1 img {
    width: 20.4054054054vw; } }
@media screen and (max-width: 1080px) {
  #head_wrap.fixed .inner {
    display: block;
    padding-left: 0px; }
    #head_wrap.fixed .inner #global-nav ul li {
      padding: 10px 15px; }
  #head_wrap.fixed .logo h1 {
    margin-top: 10px;
    padding: 0; }
    #head_wrap.fixed .logo h1 img {
      width: 280px; } }
@media screen and (max-width: 750px) {
  #head_wrap.fixed .inner #global-nav ul li {
    padding: 0; }
    #head_wrap.fixed .inner #global-nav ul li a {
      padding: 6vw; }
  #head_wrap.fixed .logo h1 {
    margin-top: 0px; }
    #head_wrap.fixed .logo h1 img {
      width: 220px; } }

.h_btn_area .h_box_in {
  max-width: 100%;
  position: relative; }
  .h_btn_area .h_box_in ul {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 10; }
    .h_btn_area .h_box_in ul li {
      width: 190px; }
      .h_btn_area .h_box_in ul li a {
        padding: 15px 0;
        display: block;
        font-weight: bold;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        left: -10px; }
        .h_btn_area .h_box_in ul li a .icon {
          margin-right: 10px;
          display: flex;
          align-items: center;
          justify-content: center; }
        .h_btn_area .h_box_in ul li a .arrow {
          position: absolute;
          top: 50%;
          right: 0px;
          transform: translateY(-50%);
          display: flex;
          align-items: center;
          justify-content: center; }
    .h_btn_area .h_box_in ul .shop {
      background: #fff;
      color: #000; }
    .h_btn_area .h_box_in ul .mail {
      background: #000;
      color: #fff; }
@media screen and (max-width: 1300px) {
  .h_btn_area .h_box_in ul {
    display: flex; }
    .h_btn_area .h_box_in ul li {
      width: 14.6153846154vw;
      min-width: 170px; }
      .h_btn_area .h_box_in ul li a {
        padding: 9px 0; } }

footer {
  background: #000;
  padding-top: 80px;
  padding-bottom: 20px;
  color: #fff;
  font-size: 14px;
  font-weight: bold; }
  footer .box_in {
    letter-spacing: 0.08rem; }
  footer .logo {
    margin-top: 60px; }
    footer .logo a {
      display: inline-block; }
  footer .txt_area {
    margin-top: 40px; }
    footer .txt_area .tel {
      margin-top: 15px; }
  footer .f_menu {
    margin-top: 60px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    footer .f_menu li {
      padding: 0 20px; }
      footer .f_menu li a {
        display: inline-block;
        font-size: 16px; }

@media screen and (max-width: 750px) {
  footer {
    padding-top: 10.6666666667vw;
    padding-bottom: 2.6666666667vw; }
    footer .box_in {
      padding: 0 2.6666666667vw; }
    footer .logo {
      margin-top: 8vw; }
      footer .logo a {
        width: 44.8vw;
        min-width: 280px; }
    footer .txt_area {
      margin-top: 5.3333333333vw; }
    footer .f_menu {
      margin-top: 8vw;
      justify-content: flex-start;
      width: 94%;
      margin: 60px auto 0; }
      footer .f_menu li {
        padding: 0;
        width: 50%;
        background: #fff;
        /*
        &:first-child{
        	border-right: none;
        	width: 100%;
        }	
        */ }
        footer .f_menu li a {
          font-size: 13px;
          color: #000;
          width: 100%;
          display: block;
          border-top: 1px solid #000;
          padding: 2.6666666667vw; }
        footer .f_menu li:nth-child(2n+1) {
          border-right: 1px solid #000; } }
.btn_links {
  display: flex;
  justify-content: center; }
  .btn_links li a {
    display: inline-block; }
  .btn_links .shop {
    margin-right: 20px; }

.bottom_footer {
  margin-top: 30px;
  background: #e6e7e9;
  color: #000;
  padding: 15px 40px;
  color: #000;
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 750px) {
    .bottom_footer {
      padding: 1.3333333333vw 0; } }
  .bottom_footer .bottom_footer_menu ul {
    display: flex;
    justify-content: center; }
    .bottom_footer .bottom_footer_menu ul li {
      padding: 0 20px; }
      .bottom_footer .bottom_footer_menu ul li a {
        display: inline-block; }
  @media screen and (max-width: 750px) {
    .bottom_footer .bottom_footer_menu {
      display: none; } }
  @media screen and (max-width: 750px) {
    .bottom_footer .copyright {
      text-align: center;
      width: 100%; } }

#pages main {
  background: #e6e7e8; }

#pages .mv {
  background: url("../images/pages/pages_mv_bg.jpg") no-repeat;
  background-size: cover;
  background-position: center center;
  color: #fff;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center; }
  #pages .mv .box_in {
    max-width: 100%; }
    #pages .mv .box_in h2 {
      font-size: 48px;
      font-weight: bold;
      line-height: 1; }
    #pages .mv .box_in .thumnail {
      margin-top: 20px; }
      #pages .mv .box_in .thumnail ul {
        display: flex;
        justify-content: center;
        align-items: center; }
        #pages .mv .box_in .thumnail ul li a {
          text-decoration: underline; }
        #pages .mv .box_in .thumnail ul .arrow {
          margin: 0 10px;
          display: flex;
          align-items: center;
          justify-content: center; }
  @media screen and (max-width: 750px) {
    #pages .mv {
      height: 40vw;
      min-height: 60vw; }
      #pages .mv .box_in h2 {
        font-size: 30px; }
      #pages .mv .box_in .thumnail {
        margin-top: 2.6666666667vw; } }

.news_copyright a {
  text-align: right !important;
  margin: 0 !important; }
@media screen and (max-width: 480px) {
  .news_copyright a {
    text-align: center !important; } }

.fa-external-link:before {
  color: #000;
  content: '\f35d';
  margin-left: 3px; }

footer .fa-external-link:before {
  color: #fff; }
@media screen and (max-width: 750px) {
  footer .fa-external-link:before {
    color: #000; } }
