@charset 'UTF-8';

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

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

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

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

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

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

del {
  text-decoration: line-through;
}

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

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

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

input, select {
  vertical-align: middle;
}

img {
  max-width: 100%;
}

/* VARS */
/* PARTS
/////////////////////////////////////////////*/

.cf:before, .cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

.cf {
  zoom: 1;
}

.grid {
  *zoom: 1;
}

.grid>* {
  float: left;
  box-sizing: border-box;
  behavior: url('/js/boxsizing.htc');
}

.grid>* img {
  vertical-align: bottom;
}

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

.grid .grid__col-01 {
  width: 4.16666666667%;
}

.grid .grid__col-02 {
  width: 8.33333333333%;
}

.grid .grid__col-03 {
  width: 12.5%;
}

.grid .grid__col-04 {
  width: 16.6666666667%;
}

.grid .grid__col-05 {
  width: 20.8333333333%;
}

.grid .grid__col-06 {
  width: 25%;
}

.grid .grid__col-07 {
  width: 29.1666666667%;
}

.grid .grid__col-08 {
  width: 33.3333333333%;
}

.grid .grid__col-09 {
  width: 37.5%;
}

.grid .grid__col-10 {
  width: 41.6666666667%;
}

.grid .grid__col-11 {
  width: 45.8333333333%;
}

.grid .grid__col-12 {
  width: 50%;
}

.grid .grid__col-13 {
  width: 54.1666666667%;
}

.grid .grid__col-14 {
  width: 58.3333333333%;
}

.grid .grid__col-15 {
  width: 62.5%;
}

.grid .grid__col-16 {
  width: 66.6666666667%;
}

.grid .grid__col-17 {
  width: 70.8333333333%;
}

.grid .grid__col-18 {
  width: 75%;
}

.grid .grid__col-19 {
  width: 79.1666666667%;
}

.grid .grid__col-20 {
  width: 83.3333333333%;
}

.grid .grid__col-21 {
  width: 87.5%;
}

.grid .grid__col-22 {
  width: 91.6666666667%;
}

.grid .grid__col-23 {
  width: 95.8333333333%;
}

.grid .grid__col-24 {
  width: 100%;
}

.grid--gutter {
  margin-left: -4px;
  margin-right: -4px;
}

.grid--gutter>* {
  padding-left: 4px;
  padding-right: 4px;
  margin-bottom: 8px;
}

.hv {
  transition: all .3s ease;
}

.hv:hover {
  opacity: 0.7;
}

.hv-filter:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0);
  transition: all .3s ease;
}

a:hover .hv-filter:after {
  background: #000000;
  background: rgba(0, 0, 0, .3);
}

.no-opacity a:hover .hv-filter:after {
  background: url(../img/bg_filter.png) 0 0 repeat;
}

.pc-none {
  display: none;
}

.align-c {
  text-align: center;
}

.align-r {
  text-align: right;
}

.align-l {
  text-align: left;
}

.text-l {
  font-size: 16px;
  font-size: 1.6rem;
}

.text-m {
  font-size: 14px;
  font-size: 1.4rem;
}

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

.anchor {
  padding-top: 70px;
  margin-top: -70px;
}

.mb08 {
  margin-bottom: 8px;
}

.mb16 {
  margin-bottom: 16px;
}

.mb24 {
  margin-bottom: 24px;
}

.mb32 {
  margin-bottom: 32px;
}

.mb40 {
  margin-bottom: 40px;
}

.mb48 {
  margin-bottom: 48px;
}

.mb56 {
  margin-bottom: 56px;
}

.mb64 {
  margin-bottom: 64px;
}

.mb72 {
  margin-bottom: 72px;
}

.mb80 {
  margin-bottom: 80px;
}

.mb88 {
  margin-bottom: 88px;
}

.mb106 {
  margin-bottom: 106px;
}

.mb114 {
  margin-bottom: 114px;
}

.mb120 {
  margin-bottom: 120px;
}

.btn-tp01 a {
  display: inline-block;
  position: relative;
  font-size: 16px;
  font-size: 1.6rem;
  padding-left: 16px;
}

.btn-tp01 a:before {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 7px;
  height: 12px;
  margin-top: -6px;
  background: url(../img/arrow4.png) center center no-repeat;
  background-size: 5px;
  content: "";
}

.btn-tp02 a {
  display: inline-block;
  position: relative;
  font-size: 14px;
  font-size: 1.4rem;
  padding-right: 16px;
}

.btn-tp02 a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 7px;
  height: 12px;
  margin-top: -6px;
  background: url(../img/arrow4.png) center center no-repeat;
  background-size: 5px;
  content: "";
}

.btn-tp03 a {
  display: inline-block;
  position: relative;
  padding: 16px 48px 16px 24px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5em;
  color: #FFF;
  background: #949494;
  transition: background .3s ease;
}

.btn-tp03 a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  width: 10px;
  height: 17px;
  margin-top: -8px;
  background: url(../img/arrow2.png) center center no-repeat;
  background-size: 10px;
  content: "";
}

.btn-tp03 a:hover {
  background: #555;
  text-decoration: none;
}

.btn-tp03.btn-tp03--line2 a {
  padding: 4px 48px 4px 16px;
}

.btn-tp03.btn-tp03--blank a:after {
  right: 16px;
  width: 16px;
  height: 15px;
  margin-top: -8px;
  background: url(../img/blank3.png) center center no-repeat;
  background-size: 16px;
}

.btn-tp03.btn-tp03--width-fixed a {
  width: 300px;
}

.btn-blank a {
  display: inline-block;
  position: relative;
  font-size: 14px;
  font-size: 1.4rem;
  padding-right: 24px;
}

.btn-blank a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 16px;
  height: 15px;
  margin-top: -8px;
  background: url(../img/blank2.png) center center no-repeat;
  background-size: 16px;
  content: "";
}

/* LAYOUT
///////////////////////////////////////////////////*/
/* base
---------------------------------------------------*/
html {
  font-size: 62.5%;
}

body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 2;
  color: #333;
}

a {
  color: #000;
}

a:hover {
  text-decoration: underline;
}

img {
  max-width: 100%;
}

input[type="text"], input[type="email"], textarea {
  box-sizing: border-box;
  border: 1px solid #B0B0B0;
  font-size: 14px;
  font-size: 1.4rem;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

input[type="text"]:focus, input[type="email"]:focus, textarea:focus {
  outline: 0;
  border-color: #000;
}

input[type="radio"]:focus {
  outline: 0;
  background: #F5F5F5;
}

button:focus {
  outline: 1px solid #000;
}

#wrapper {
  visibility: hidden;
  overflow: hidden;
  position: relative;
}

#header {
  position: fixed;
  z-index: 100;
  width: 100%;
  height: 60px;
  background: #FFF;
}

#menuBtn {
  display: none;
}

#main {
  position: relative;
  background: #FFF;
  padding-top: 60px;
}

#mainContents {
  position: relative;
  z-index: 10;
  background: #FFF;
}

#footer {
  display: block;
  position: relative;
  z-index: 10;
  padding: 20px 0 0;
  background: #FFF;
}

/* header
---------------------------------------------------*/
.hd .hd__inr {
  position: relative;
  padding: 12px 20px 11px;
  margin: 0 auto;
  max-width: 1050px;
}

.hd .hd__inr .hd__logo {
  width: 90px;
}

.hd .hd__inr .hd__logo a {
  display: block;
}

/* gnav
---------------------------------------------------*/
.gnav {
  display: block;
  position: absolute;
  top: 15px;
  right: 20px;
}

.gnav__list {
  overflow: hidden;
}

.gnav__list li {
  float: left;
  margin-left: 15px;
}

.gnav__list a {
  overflow: hidden;
  display: block;
  padding: 0 20px;
  height: 30px;
  width: 55px;
  background: center center no-repeat;
  white-space: nowrap;
  text-indent: 200%;
  transition: opacity .3s ease;
  -webkit-backface-visibility: hidden;
}

.gnav__list a:hover {
  opacity: .5;
}

.gnav__info a {
  width: 55px;
  background-image: url(../img/gnav_info.png);
}

.gnav__concept a {
  width: 67px;
  background-image: url(../img/gnav_concept.png);
}

.gnav__produce a {
  width: 83px;
  background-image: url(../img/gnav_produce.png);
}

.gnav__floor a {
  width: 55px;
  background-image: url(../img/gnav_floor.png);
}

.gnav__program a {
  width: 69px;
  background-image: url(../img/gnav_program.png);
}

.gnav__menu a {
  width: 54px;
  background-image: url(../img/gnav_menu.png);
}

.gnav__sales a {
  width: 80px;
  background-image: url(../img/gnav_sales.png);
}

.gnav__access a {
  width: 54px;
  background-image: url(../img/gnav_access.png);
}

.gnav__reservation a {
  width: 28px;
  background-image: url(../img/gnav_reservation.png);
}

/* main
---------------------------------------------------*/
.main-visual {
  overflow: hidden;
  position: relative;
  z-index: 1;
  width: 100%;
  height: 425px;
}

.main-visual .main-visual__bg {
  position: fixed;
  z-index: 2;
  top: 60px;
  left: 0;
  width: 100%;
  height: auto;
}

.main-visual .filter {
  display: block;
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: #000000;
  background: rgba(0, 0, 0, .8);
  opacity: 0;
}

.main-cnts {
  padding-top: 4px;
}

/* footer
---------------------------------------------------*/
.ft__tp {
  margin: 0 auto;
  padding-bottom: 42px;
}

.ft__btm {
  padding: 40px 10px 0px;
  text-align: center;
  border-top: 1px solid #CCC;
}

.ft__btm .organization {
  margin-bottom: 25px;
}

.ft__btm .organization p {
  width: 100px;
  margin: 0 auto 30px;
}

.ft__btm .organization p img {
  display: block;
}

.ft__btm .organization span {
  display: block;
  color: #555;
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1.8;
}

.ft__btm .copyright {
  width: 333px;
  display: inline-block;
  margin: auto;
  font-size: 0.75em;
}

.ft__btm .copyright img {
  width: 100%;
  height: auto;
}

#pageTop {
  display: none;
  position: fixed;
  z-index: 10;
  width: 30px;
  height: 30px;
  bottom: 40px;
  right: 50px;
}

#pageTop img {
  width: 100%;
  height: auto;
}

.ft-nav {
  margin: 10px auto;
}

.ft-nav ul {
  position: relative;
  float: left;
  left: 50%;
}

.ft-nav ul li {
  font-family: "HiraKakuProN-W6";
  position: relative;
  float: left;
  left: -50%;
  margin: 0 10px;
}

.ft-nav ul a {
  display: block;
  overflow: hidden;
  padding: 5px;
  font-size: 12px;
  font-size: 1.2rem;
  text-decoration: none;
  transition: opacity .3s ease;
}

.ft-nav ul a:hover {
  opacity: .5;
}

.ft-nav .fb, .ft-nav .insta {
  margin-top: -6px;
  margin-left: 40px;
}

.ft-nav .fb a, .ft-nav .insta a {
  width: 24px;
  height: 24px;
  background: none;
  text-indent: 0;
}

.ft-nav .insta {
  margin-left: 20px;
}

/* main content
///////////////////////////////////////////////////*/
/* Section
---------------------------------------------------*/
.sec {
  max-width: 800px;
  margin: 0 auto;
  padding: 30px 20px 48px;
}

.sec.sec--fill {
  max-width: none;
  margin-left: -20px;
  margin-right: -20px;
}

.sec .sec__fig {
  margin-bottom: 48px;
}

.sec .sec__fig img {
  width: 100%;
}

.sec .sec__fig figcaption {
  text-align: center;
}

.sec-lv2 {
  margin-bottom: 120px;
}

.sec-lv2:last-child {
  margin-bottom: 0;
}

.sec-lv2 .sec-lv2__area01 {
  max-width: 1050px;
  margin: 0 auto;
  padding: 0 20px;
}

.sec-lv2 .sec-lv2__area02 {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px;
}

.sec-lv2 .sec-lv2__ttl {
  margin: 0 auto 32px;
  text-align: center;
  font-size: 15px;
  line-height: 1;
  max-width: 400px;
}

.sec-lv2 .sec-lv2__ttl-02 {
  margin-bottom: 24px;
  font-size: 16px;
  font-size: 1.6rem;
}

.sec-lv2 .sec-lv2__sentence {
  margin-bottom: 48px;
}

.sec-lv2 .sec-lv2__sentence p {
  margin-bottom: 24px;
}

.sec-lv2 .sec-lv2__sentence>*:last-child {
  margin-bottom: 0;
}

.aside {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px 48px;
}

.sentence {
  margin-bottom: 80px;
}

.sentence:last-child {
  margin-bottom: 0;
}

.sentence p {
  margin-bottom: 24px;
  font-size: 1.15em;
}

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

.list-num {
  padding-left: 2em;
}

.list-num>li {
  list-style-type: decimal;
  margin-bottom: 24px;
}

.list-disc {
  padding-left: 1.6em;
}

.list-disc li {
  list-style-type: disc;
}

.iframe-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.92935%;
}

.iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

.list-inline {
  overflow: hidden;
}

.list-inline ul {
  position: relative;
  left: 50%;
  float: left;
}

.list-inline ul li {
  position: relative;
  left: -50%;
  float: left;
  margin: 0 20px;
}

/* haedline
---------------------------------------------------*/
.headline-01 {
  margin: 0 auto 64px;
  text-align: center;
  font-size: 15px;
  line-height: 1;
  max-width: 400px;
}

.headline-01 span {
  display: block;
  font-size: 16px;
  margin: 36px auto auto;
}

.headline-01.headline-01--nowidth {
  max-width: none;
}

.headline-02 {
  font-size: 16px;
  font-size: 1.6rem;
  margin-bottom: 8px;
}

.headline-03 {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 8px;
}

.headline-04 {
  font-size: 16px;
  font-size: 1.6rem;
  margin-bottom: 4px;
}

.lead {
  margin-bottom: 72px;
  font-size: 16px;
  font-size: 1.6rem;
  text-align: center;
}

.lead-02 {
  margin-bottom: 24px;
  font-size: 16px;
  font-size: 1.6rem;
  text-align: center;
}

/* table
---------------------------------------------------*/
.table-tp01 {
  width: 100%;
  margin-bottom: 8px;
}

.table-tp01 td, .table-tp01 th {
  padding: 5px 10px;
  border: 1px solid #B0B0B0;
  text-align: center;
  vertical-align: middle;
  font-weight: normal;
  box-sizing: border-box;
}

.table-tp01 td span {
  color: #ff0000;
  font-weight: 700;
}

.table-tp01 th {
  background: #EEE;
}

.table-tp01 .align-l {
  text-align: left;
}

.table-tp01 .align-r {
  text-align: right;
}

.table-tp01 p {
  margin-bottom: 8px;
}

.table-tp01.table-tp01--sp td, .table-tp01.table-tp01--sp th {
  padding: 2px 10px;
  font-size: 12px;
  font-size: 1.2rem;
}

.table-tp01.table-tp01--w70 {
  width: 70%;
}

/* form
---------------------------------------------------*/
.form-table {
  overflow: hidden;
  display: table;
  width: 100%;
  margin-bottom: 48px;
  border-collapse: collapse;
}

.form-table dl {
  display: table-row;
  overflow: hidden;
}

.form-table dt, .form-table dd {
  display: table-cell;
  border: 1px solid #B0B0B0;
  padding: 16px 16px;
  vertical-align: middle;
  box-sizing: border-box;
}

.form-table dt {
  width: 35%;
  background: #EEE;
}

.form-table dd ul {
  overflow: hidden;
}

.form-table dd ul li {
  display: block;
  float: left;
  width: 48%;
}

.form-table dd ul li:first-child {
  margin-right: 4%;
}

.form-table dd ul li label {
  display: block;
  float: left;
  width: 35px;
  margin-right: -35px;
  padding: 5px 0;
}

.form-table dd ul li .input-text {
  display: block;
  float: right;
  width: 100%;
  margin-left: 35px;
}

.form-table dd ul li .input-text span {
  display: block;
  margin-left: 35px;
}

.form-table .required {
  vertical-align: super;
  font-size: 10px;
  margin-left: 3px;
}

.form-table input[type="text"], .form-table input[type="email"], .form-table textarea {
  width: 100%;
  padding: 8px;
}

.form-table .width-s input[type="text"], .form-table .width-s input[type="email"] {
  width: 200px;
}

.form-table input[type="radio"] {
  margin-right: 6px;
  vertical-align: 1px;
}

.form-table .age label, .form-table .sex label {
  margin-left: 8px;
  white-space: nowrap;
}

.form-table .message dt, .form-table .message dd {
  vertical-align: top;
}

.submit {
  overflow: hidden;
  width: 85%;
  margin: auto;
}

.submit button {
  display: inline-block;
  position: relative;
  padding: 16px 48px 16px 24px;
  width: 300px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5em;
  color: #FFF;
  background: #949494;
  transition: background .3s ease;
  border: 0;
  cursor: pointer;
}

.submit button:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  width: 10px;
  height: 17px;
  margin-top: -8px;
  background: url(../img/arrow2.png) center center no-repeat;
  background-size: 10px;
  content: "";
}

.submit button:hover {
  background: #555;
  text-decoration: none;
}

.submit .submit__right {
  float: right;
}

.submit .submit__left {
  float: left;
  padding: 16px 24px 16px 48px;
}

.submit .submit__left:after {
  right: auto;
  left: 16px;
  background: url(../img/arrow3.png) center center no-repeat;
}

.submit .submit__return {
  background: #BFBFBF;
}

.error-msg {
  margin-bottom: 48px;
  border: 2px solid #b23131;
  padding: 16px 16px 16px 72px;
  background: url(../img/error_ico.png) 16px center no-repeat;
}

.error-msg p {
  color: #b23131;
}

.error-msg .error-msg__ttl {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
}

.error-cnts {
  background: #ffe5e5;
}

.error-cnts .error {
  border: 1px solid #b23131;
}

.error-txt {
  padding-left: 30px;
  color: #b23131;
  background: url(../img/error_ico.png) 0 center no-repeat;
  background-size: 21px;
}

/* ///////////////////////////////////////////////////////////////////////
    max 1200px
///////////////////////////////////////////////////////////////////////*/
@media screen and (max-width: 1200px) {
  .main-visual {
    height: 0;
    padding-top: 35.41667%;
  }
}

/* ///////////////////////////////////////////////////////////////////////
    max 1050px
///////////////////////////////////////////////////////////////////////*/
@media screen and (max-width: 1050px) {
  #menuBtn {
    display: block;
    position: absolute;
    top: 12px;
    right: 20px;
    width: 50px;
    height: 35px;
    cursor: pointer;
  }

  .menu-btn {
    display: block;
  }

  .menu-btn span {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 7px;
    width: 50px;
    background: #000;
    transition: all .5s ease-out;
  }

  .menu-btn .line-2 {
    top: 14px;
  }

  .menu-btn .line-3 {
    top: 28px;
  }

  .menu-btn.active .line-1 {
    top: 14px;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  .menu-btn.active .line-2 {
    opacity: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  .menu-btn.active .line-3 {
    top: 14px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  #navigation {
    display: none;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    position: fixed;
    top: 60px;
    right: 0;
    z-index: 100;
    width: 100%;
    background: url(../img/bg_menu.png) 0 0 repeat;
  }

  .gnav__inr {
    overflow-y: auto;
    position: relative;
    height: 100%;
  }

  .gnav__list {
    /* display: -webkit-flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: flex;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 20px 0; */

    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
  }

  .gnav__list li {
    float: none;
    margin-left: 0;
    text-align: center;
  }

  .gnav__list li a {
    display: block;
    text-indent: 0;
    width: auto;
    padding: 20px;
    background: none;
    font-size: 18px;
    font-size: 1.8rem;
    text-decoration: none;
  }

  .gnav__list li.gnav__reservation {
    -webkit-order: -1;
    -ms-flex-order: -1;
    order: -1;
  }

  .gnav__list .fb {
    padding: 20px 0;
    margin: 0 auto;
  }

  .gnav__list .fb a {
    padding: 0;
    width: 24px;
    height: 24px;
    margin: 0 auto;
  }

  .gnav__list .close {
    position: relative;
    padding: 20px 0;
    cursor: pointer;
  }

  .gnav__list .close img {
    width: 20px;
    margin-right: 16px;
    vertical-align: middle;
  }

  .gnav .pc-none {
    display: block;
  }

  .ft-nav {
    display: none;
  }

  #pageTop {
    right: 10px;
  }
}

/* ///////////////////////////////////////////////////////////////////////
    max 768px
///////////////////////////////////////////////////////////////////////*/
@media screen and (max-width: 768px) {
  #wrapper {
    visibility: visible;
    opacity: 0;
  }

  /* PARTS
/////////////////////////////////////////////*/
  .grid>* {
    float: none;
    width: auto !important;
  }

  .pc-none {
    display: block;
  }

  .sp-none {
    display: none;
  }

  .hv:hover {
    opacity: 1;
  }

  /* btn
---------------------------------------------------*/
  .btn-tp03 a {
    font-size: 12px;
    font-size: 1.2rem;
  }

  .btn-tp03.btn-tp03--width-fixed a {
    width: 100%;
    box-sizing: border-box;
  }

  .btn-tp03.btn-tp03--line2 a {
    padding: 7px 48px 7px 16px;
  }

  /* LAYOUT
///////////////////////////////////////////////////*/
  /* base
---------------------------------------------------*/
  #header {
    height: 50px;
  }

  #main {
    padding-top: 50px;
  }

  /* header
---------------------------------------------------*/
  .hd .hd__inr {
    position: relative;
    padding: 9px 10px;
  }

  .hd .hd__inr .hd__logo {
    width: 78px;
    height: 32px;
  }

  .hd .hd__inr .hd__logo a {
    display: block;
  }

  #menuBtn {
    top: 16px;
    right: 10px;
    width: 25px;
    height: 17px;
  }

  .menu-btn span {
    height: 3px;
    width: 25px;
  }

  .menu-btn .line-2 {
    top: 7px;
  }

  .menu-btn .line-3 {
    top: 14px;
  }

  .menu-btn.active .line-1, .menu-btn.active .line-3 {
    top: 7px;
  }

  #navigation {
    top: 50px;
  }

  /* footer
---------------------------------------------------*/
  #footer {
    padding: 40px 0 0;
  }

  .ft .ft__tp {
    margin: 20px auto;
    padding-bottom: 0px;
  }

  .ft__btm .organization p {
    width: 80px;
    margin: 0 auto 20px;
  }

  .ft__btm .organization p img {
    display: block;
  }

  .ft__btm .organization span {
    display: block;
    color: #555;
    font-size: 13px;
    font-size: 1.3rem;
    line-height: 1.8;
  }

  .ft__btm .copyright {
    width: 333px;
    display: inline-block;
    margin: auto;
  }

  .ft__btm .copyright img {
    width: 100%;
    height: auto;
  }

  .ft .copyright {
    width: 100%;
    font-size: 0.75em;
    text-decoration: none;
  }

  .ft-nav ul {
    position: relative;
    float: none;
    left: 0;
  }

  .ft-nav ul li {
    position: relative;
    float: none;
    left: 0;
    width: 50%;
    height: 0;
    margin: 0 auto 16px !important;
    padding-top: 9.375%;
  }

  .ft-nav ul a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100%;
    background-position: 0 0 !important;
    background-size: 100%;
  }

  .ft-nav ul .guide a {
    background-image: url(../img/snav_guide.png);
  }

  .ft-nav ul .faq a {
    background-image: url(../img/snav_faq.png);
  }

  .ft-nav ul .recruit a {
    background-image: url(../img/snav_recruit.png);
  }

  .ft-nav ul .privacypolicy a {
    background-image: url(../img/snav_privacy.png);
  }

  .ft-nav ul .sitemap a {
    background-image: url(../img/snav_sitemap.png);
  }

  .ft-nav ul .contact a {
    background-image: url(../img/snav_contact.png);
  }

  .ft-nav ul .fb, .ft-nav ul .insta {
    width: 24px;
    height: 24px;
    margin-bottom: 0 !important;
  }

  .ft-nav ul .fb a, .ft-nav ul .insta a {
    width: 24px;
    height: 24px;
    background: none;
    text-indent: 0;
  }

  /* main content
///////////////////////////////////////////////////*/
  /* main
---------------------------------------------------*/
  .main-visual {
    padding-top: 46.875%;
  }

  .main-visual .main-visual__bg {
    position: absolute;
    top: 0 !important;
    left: -13.38673% !important;
    max-width: none;
    width: 136.5625%;
  }

  /* Section
---------------------------------------------------*/
  .sec {
    padding: 48px 10px 24px;
  }

  .sec.sec--fill {
    margin-left: 0;
    margin-right: 0;
  }

  .sec .sec__fig {
    margin-left: -10px;
    margin-right: -10px;
  }

  .sec-lv2 {
    margin-bottom: 72px;
  }

  .sec-lv2:last-child {
    margin-bottom: 0;
  }

  .sec-lv2 .sec-lv2__area01 {
    padding: 0;
  }

  .sec-lv2 .sec-lv2__area02 {
    padding: 0;
  }

  .aside {
    padding: 0 10px 48px;
  }

  /* haedline
---------------------------------------------------*/
  .headline-01 {
    margin: 0 auto 48px;
    text-align: center;
    font-size: 15px;
    line-height: 1;
  }

  .headline-01 span {
    display: block;
    font-size: 16px;
    margin: 16px auto auto;
  }

  .headline-02 {
    font-size: 1.6rem;
    margin-bottom: 40px;
  }

  /* form
---------------------------------------------------*/
  .form-table {
    overflow: hidden;
    display: block;
    margin-bottom: 24px;
    border-bottom: 1px solid #B0B0B0;
  }

  .form-table dl {
    display: block;
    width: 100%;
  }

  .form-table dt, .form-table dd {
    display: block;
    width: 100%;
    border: 1px solid #B0B0B0;
    border-bottom: 0;
    padding: 8px;
  }

  .form-table dt {
    width: 100%;
    border-bottom: 0;
  }

  .form-table dd ul li {
    overflow: hidden;
    float: none;
    width: auto;
    margin-bottom: 8px;
  }

  .form-table dd ul li:first-child {
    margin-right: 0;
  }

  .submit button {
    width: 100%;
    box-sizing: border-box;
    font-size: 14px;
    font-size: 1.4rem;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .submit .submit__left, .submit .submit__right {
    float: none;
    margin-bottom: 8px;
    padding: 8px 24px 8px 24px;
  }
}

.organization span a {
  font-weight: bold;
  color: #00F;
  text-decoration: none;
}

.organization span a:hover {
  font-weight: bold;
  color: #F00;
  text-decoration: none;
}

.organization .telephone {
  color: #F00;
}