@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=GFS+Didot&display=swap");
/* 30px 見出し文字サイズ */
/* 12px 注意事項など */
/* --------------------------------------------------------------------------------------
 base
--------------------------------------------------------------------------------------- */
a[href^="tel:"] {
  color: #0b62e5;
  text-decoration: underline;
  pointer-events: none; }

html, body {
  font-size: 16px; }
  @media (max-width: 750px) {
    html, body {
      font-size: 3.8vw; } }

body {
  color: #000;
  font-family: "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  line-height: 2.2;
  text-align: center;
  -webkit-text-size-adjust: none; }

input, textarea, select {
  font-size: 100%; }

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

/* reset ------------------------------ */
body, div, section,
h1, h2, h3, h4, h5, h6,
dl, dt, dd, ul, ol, li, figure, picture,
p, blockquote, pre, cite, code, caption,
form, fieldset, legend, input, textarea, select, option, label {
  margin: 0;
  padding: 0;
  box-sizing: border-box; }

main {
  display: block;
  /* IE対策に追加 */ }

img, table {
  border: none; }

img {
  vertical-align: bottom; }

table {
  border-collapse: collapse; }

ul, ol {
  list-style: none; }

li img,
dt img {
  vertical-align: bottom; }

picture {
  display: block; }

/* textlink ------------------------------ */
a {
  transition: all .1s; }

a:link {
  color: #0b62e5;
  text-decoration: underline; }

a:visited {
  color: #0b62e5;
  text-decoration: underline; }

@media screen and (min-width: 751px), print {
  a:hover {
    color: #0b62e5;
    text-decoration: none; }

  a:active {
    color: #0b62e5;
    text-decoration: none; }

  a:hover,
  a:hover picture,
  input[type="submit"]:hover,
  input[type="image"]:hover {
    opacity: 0.7; } }
.linkarea,
.linkarea a {
  transition: opacity .1s ease-out;
  position: relative; }

.linkarea a:hover,
.linkarea:hover {
  opacity: .7; }

.linkarea a {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  font-size: 0;
  text-indent: -9999px;
  overflow: visible;
  z-index: 999; }

/* --------------------------------------------------------------------------------------
 float
--------------------------------------------------------------------------------------- */
.clearfix::after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden; }

/*align
-----------------------------------------------*/
.alright {
  text-align: right !important; }

.alcenter {
  text-align: center !important; }

.alleft {
  text-align: left !important; }

/* FOR smartphone landscape
***************************************************************************/
@media screen and (max-width: 750px) {
  a[href^="tel:"] {
    pointer-events: auto; }

  body {
    line-height: 1.8; } }
/* ----------------------------------- フォームのリセット -------- */
button,
input[type="submit"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent; }

.forpc {
  display: block !important; }

.forsp {
  display: none !important; }

.forpcinline {
  display: inline !important; }

.forspinline {
  display: none !important; }

header {
  width: 100%;
  min-width: 1280px;
  background: rgba(255, 255, 255, 0.75);
  padding: 20px 40px;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10; }
  header .logo {
    width: 80px;
    margin-right: auto; }
  header .navi {
    display: flex;
    justify-content: center; }
    header .navi li {
      font-size: 1.0625rem; }
      header .navi li:first-child a {
        border-left: solid 1px #000; }
      header .navi li a {
        color: #000;
        text-decoration: none;
        border-right: solid 1px #000;
        padding: 0 20px; }
  header .navi2 {
    margin-left: 60px;
    display: flex;
    justify-content: flex-end; }
    header .navi2 li {
      width: 30px;
      margin: 0 0 0 25px; }
  header #menuBtn {
    display: none; }

.bottomBtns {
  background: #fff;
  border-top: solid 2px #ed74ad;
  padding: 60px 0;
  position: relative;
  z-index: 2; }
  .bottomBtns .subContents > div {
    text-align: center; }

footer {
  color: #fff;
  min-width: 1280px;
  background: #d89ea8;
  padding: 50px 0 20px;
  position: relative;
  z-index: 2; }
  footer .row {
    display: flex;
    justify-content: space-between; }
    footer .row .left {
      width: 350px;
      display: flex; }
      footer .row .left .logo {
        width: 118px;
        margin: 0 20px 0 0; }
      footer .row .left div.address .kotsu {
        margin-bottom: 10px; }
        footer .row .left div.address .kotsu span {
          font-size: 1.0625rem;
          border: solid 1px #fff;
          padding: 5px 20px; }
      footer .row .left div.address .address {
        font-size: .875rem;
        line-height: 1.86; }
    footer .row .right {
      width: 735px; }
      footer .row .right .fnav {
        display: flex; }
        footer .row .right .fnav li {
          font-size: 1.0875rem;
          line-height: 1.2;
          padding: 0 20px;
          border-right: solid 1px #000; }
          footer .row .right .fnav li:first-child {
            border-left: solid 1px #000; }
          footer .row .right .fnav li a {
            color: #000;
            text-decoration: none; }
      footer .row .right .row2 {
        margin-top: 20px;
        display: flex;
        justify-content: space-between; }
        footer .row .right .row2 .tel {
          line-height: 1; }
          footer .row .right .row2 .tel a[href^="tel:"] {
            color: #fff;
            font-size: 3.5rem;
            text-decoration: none;
            padding-left: 40px;
            position: relative; }
            footer .row .right .row2 .tel a[href^="tel:"]::before {
              content: "";
              width: 26px;
              height: calc(26px / 94 * 150);
              background: url(../images/common/s_tel.svg) no-repeat left top/100% auto;
              position: absolute;
              top: 14px;
              left: 0; }
        footer .row .right .row2 .fnav2 {
          display: flex;
          justify-content: flex-end; }
          footer .row .right .row2 .fnav2 li {
            text-align: center;
            margin: 0 0 0 15px; }
            footer .row .right .row2 .fnav2 li figure {
              width: 30px;
              margin: 0 auto; }
            footer .row .right .row2 .fnav2 li p {
              color: #000;
              font-size: .8125rem; }
  footer .copyright {
    font-size: .75rem;
    text-align: right;
    margin-top: 20px; }

/* FOR smartphone landscape
***************************************************************************/
@media screen and (max-width: 751px) {
  .forpc {
    display: none !important; }

  .forsp {
    display: block !important; }

  .forpcinline {
    display: none !important; }

  .forspinline {
    display: inline !important; }

  img {
    width: 100%; }

  body.fixed {
    width: 100%;
    height: 100%;
    position: fixed; }

  header {
    width: 100vw;
    min-width: initial;
    padding: 3vw 5vw;
    display: flex; }
    header .logo {
      width: 80px;
      margin-right: auto; }
    header .navi {
      width: 100vw;
      height: calc(100vh - 19vw);
      background: white;
      padding: 0 5vw 3vw;
      display: none;
      position: absolute;
      top: 100%;
      left: 0; }
      header .navi li {
        font-size: 1.0625rem; }
        header .navi li:first-child a {
          border-left: none; }
        header .navi li a {
          color: #000;
          text-decoration: none;
          border-right: none;
          border-bottom: solid 1px #5a5a5a;
          padding: 2vw 5vw;
          display: block; }
    header .navi2 {
      margin-left: 0; }
      header .navi2 li {
        width: 8vw;
        margin: 0 0 0 5vw; }
    header #menuBtn, header #menuBtn span {
      display: inline-block;
      transition: all .4s; }
    header #menuBtn {
      width: 36px;
      height: 24px;
      margin-left: 6vw;
      position: relative;
      cursor: pointer; }
      header #menuBtn span {
        width: 100%;
        height: 2px;
        background-color: #000;
        position: absolute;
        left: 0; }
        header #menuBtn span:nth-of-type(1) {
          top: 0; }
        header #menuBtn span:nth-of-type(2) {
          top: 11px; }
        header #menuBtn span:nth-of-type(3) {
          bottom: 0; }
      header #menuBtn.active span:nth-of-type(1) {
        transform: translateY(11px) rotate(-45deg); }
      header #menuBtn.active span:nth-of-type(2) {
        opacity: 0; }
      header #menuBtn.active span:nth-of-type(3) {
        transform: translateY(-11px) rotate(45deg); }
    header.active {
      background: white; }

  .bottomBtns {
    padding: 10vw 0; }
    .bottomBtns .subContents > div {
      text-align: center;
      margin: 0 20vw; }

  footer {
    min-width: initial;
    padding: 8vw 0 6vw; }
    footer .row {
      display: block; }
      footer .row .left {
        width: 100%;
        display: block; }
        footer .row .left .logo {
          width: 30vw;
          margin: 0 auto 5vw; }
        footer .row .left div.address {
          text-align: center; }
          footer .row .left div.address .kotsu {
            margin-bottom: 5vw; }
            footer .row .left div.address .kotsu span {
              padding: 2vw 3rem; }
      footer .row .right {
        width: 100%; }
        footer .row .right .fnav {
          display: none; }
        footer .row .right .row2 {
          margin-top: 5vw;
          display: block; }
          footer .row .right .row2 .tel {
            text-align: center;
            margin: 0 0 10vw; }
            footer .row .right .row2 .tel a[href^="tel:"] {
              font-size: 2.625rem;
              padding-left: 8vw; }
              footer .row .right .row2 .tel a[href^="tel:"]::before {
                content: "";
                width: 5.5vw;
                height: calc(5.5vw / 94 * 150);
                top: 2vw;
                left: 0; }
          footer .row .right .row2 .fnav2 {
            justify-content: center; }
            footer .row .right .row2 .fnav2 li {
              width: 26vw;
              margin: 0; }
              footer .row .right .row2 .fnav2 li figure {
                width: 8vw;
                margin-bottom: 3vw; }
              footer .row .right .row2 .fnav2 li p {
                line-height: 1.4; }
    footer .copyright {
      text-align: center;
      margin-top: 5vw; } }
i {
  font-size: 75%;
  font-style: normal;
  vertical-align: top; }

.subContents {
  width: 1085px;
  text-align: left;
  margin: 0 auto; }

.subContentsS {
  width: 885px;
  text-align: left;
  margin: 0 auto; }

@media screen and (max-width: 751px) {
  .subContents,
  .subContentsS {
    width: 100vw;
    padding: 0 5vw; } }
.h-type01 {
  line-height: 1.4;
  margin: 0 0 50px; }
  .h-type01 .en {
    font-family: 'GFS Didot', serif;
    font-weight: 400;
    font-size: 4.75rem;
    font-style: italic;
    letter-spacing: 2px; }
  .h-type01 .ja {
    font-size: 1.25rem;
    font-weight: bold; }

.h-type02 {
  font-size: 1.875rem;
  text-align: center;
  border-bottom: solid 1px #000;
  margin: 0 0 50px; }

@media screen and (max-width: 751px) {
  .h-type01 {
    margin: 0 0 10vw; }
    .h-type01 .en {
      font-family: 'GFS Didot', serif;
      font-weight: 400;
      font-size: 3.6rem;
      letter-spacing: 1px; }

  .h-type02 {
    font-size: 1.5rem;
    margin: 0 0 8vw;
    padding: 0 0 2vw; } }
.more {
  width: 108px;
  margin: 60px auto 0; }

@media screen and (max-width: 751px) {
  .more {
    width: 30vw;
    margin: 10vw auto 0; } }
#flright {
  width: 90px;
  position: fixed;
  top: 180px;
  right: 0; }

@media screen and (max-width: 751px) {
  #flright {
    display: none; } }
.disclist li {
  list-style: disc;
  line-height: 2;
  margin: 0 0 5px 20px; }

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