@charset "UTF-8";
.fz8 {
  font-size: 8px;
}
@media screen and (max-width: 767px) {
  .fz8 {
    font-size: calc(8 / 750 * 100vw);
  }
}

.fz9 {
  font-size: 9px;
}
@media screen and (max-width: 767px) {
  .fz9 {
    font-size: calc(9 / 750 * 100vw);
  }
}

.fz10 {
  font-size: 10px;
}
@media screen and (max-width: 767px) {
  .fz10 {
    font-size: calc(10 / 750 * 100vw);
  }
}

.fz11 {
  font-size: 11px;
}
@media screen and (max-width: 767px) {
  .fz11 {
    font-size: calc(11 / 750 * 100vw);
  }
}

.fz12 {
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .fz12 {
    font-size: calc(12 / 750 * 100vw);
  }
}

.fz13 {
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .fz13 {
    font-size: calc(13 / 750 * 100vw);
  }
}

.fz14 {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .fz14 {
    font-size: calc(14 / 750 * 100vw);
  }
}

.fz15 {
  font-size: 15px;
}
@media screen and (max-width: 767px) {
  .fz15 {
    font-size: calc(15 / 750 * 100vw);
  }
}

.fz16, .copyright {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .fz16, .copyright {
    font-size: calc(16 / 750 * 100vw);
  }
}

.fz17 {
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  .fz17 {
    font-size: calc(17 / 750 * 100vw);
  }
}

.fz18 {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .fz18 {
    font-size: calc(18 / 750 * 100vw);
  }
}

.fz19 {
  font-size: 19px;
}
@media screen and (max-width: 767px) {
  .fz19 {
    font-size: calc(19 / 750 * 100vw);
  }
}

.fz20, footer .txt span, .mv p.read {
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  .fz20, footer .txt span, .mv p.read {
    font-size: calc(20 / 750 * 100vw);
  }
}

.fz21 {
  font-size: 21px;
}
@media screen and (max-width: 767px) {
  .fz21 {
    font-size: calc(21 / 750 * 100vw);
  }
}

.fz22 {
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  .fz22 {
    font-size: calc(22 / 750 * 100vw);
  }
}

.fz23 {
  font-size: 23px;
}
@media screen and (max-width: 767px) {
  .fz23 {
    font-size: calc(23 / 750 * 100vw);
  }
}

.fz24, .sect_ttl .en, body {
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .fz24, .sect_ttl .en, body {
    font-size: calc(24 / 750 * 100vw);
  }
}

.fz25 {
  font-size: 25px;
}
@media screen and (max-width: 767px) {
  .fz25 {
    font-size: calc(25 / 750 * 100vw);
  }
}

.fz26 {
  font-size: 26px;
}
@media screen and (max-width: 767px) {
  .fz26 {
    font-size: calc(26 / 750 * 100vw);
  }
}

.fz27 {
  font-size: 27px;
}
@media screen and (max-width: 767px) {
  .fz27 {
    font-size: calc(27 / 750 * 100vw);
  }
}

.fz28, footer .txt {
  font-size: 28px;
}
@media screen and (max-width: 767px) {
  .fz28, footer .txt {
    font-size: calc(28 / 750 * 100vw);
  }
}

.fz29 {
  font-size: 29px;
}
@media screen and (max-width: 767px) {
  .fz29 {
    font-size: calc(29 / 750 * 100vw);
  }
}

.fz30, .info td, #business .num {
  font-size: 30px;
}
@media screen and (max-width: 767px) {
  .fz30, .info td, #business .num {
    font-size: calc(30 / 750 * 100vw);
  }
}

.fz31 {
  font-size: 31px;
}
@media screen and (max-width: 767px) {
  .fz31 {
    font-size: calc(31 / 750 * 100vw);
  }
}

.fz32, .sub_ttl {
  font-size: 32px;
}
@media screen and (max-width: 767px) {
  .fz32, .sub_ttl {
    font-size: calc(32 / 750 * 100vw);
  }
}

.fz33 {
  font-size: 33px;
}
@media screen and (max-width: 767px) {
  .fz33 {
    font-size: calc(33 / 750 * 100vw);
  }
}

.fz34 {
  font-size: 34px;
}
@media screen and (max-width: 767px) {
  .fz34 {
    font-size: calc(34 / 750 * 100vw);
  }
}

.fz35 {
  font-size: 35px;
}
@media screen and (max-width: 767px) {
  .fz35 {
    font-size: calc(35 / 750 * 100vw);
  }
}

.fz36 {
  font-size: 36px;
}
@media screen and (max-width: 767px) {
  .fz36 {
    font-size: calc(36 / 750 * 100vw);
  }
}

.fz37 {
  font-size: 37px;
}
@media screen and (max-width: 767px) {
  .fz37 {
    font-size: calc(37 / 750 * 100vw);
  }
}

.fz38 {
  font-size: 38px;
}
@media screen and (max-width: 767px) {
  .fz38 {
    font-size: calc(38 / 750 * 100vw);
  }
}

.fz39 {
  font-size: 39px;
}
@media screen and (max-width: 767px) {
  .fz39 {
    font-size: calc(39 / 750 * 100vw);
  }
}

.fz40, .mv p.txt {
  font-size: 40px;
}
@media screen and (max-width: 767px) {
  .fz40, .mv p.txt {
    font-size: calc(40 / 750 * 100vw);
  }
}

.fz41 {
  font-size: 41px;
}
@media screen and (max-width: 767px) {
  .fz41 {
    font-size: calc(41 / 750 * 100vw);
  }
}

.fz42 {
  font-size: 42px;
}
@media screen and (max-width: 767px) {
  .fz42 {
    font-size: calc(42 / 750 * 100vw);
  }
}

.fz43 {
  font-size: 43px;
}
@media screen and (max-width: 767px) {
  .fz43 {
    font-size: calc(43 / 750 * 100vw);
  }
}

.fz44 {
  font-size: 44px;
}
@media screen and (max-width: 767px) {
  .fz44 {
    font-size: calc(44 / 750 * 100vw);
  }
}

.fz45 {
  font-size: 45px;
}
@media screen and (max-width: 767px) {
  .fz45 {
    font-size: calc(45 / 750 * 100vw);
  }
}

.fz46 {
  font-size: 46px;
}
@media screen and (max-width: 767px) {
  .fz46 {
    font-size: calc(46 / 750 * 100vw);
  }
}

.fz47 {
  font-size: 47px;
}
@media screen and (max-width: 767px) {
  .fz47 {
    font-size: calc(47 / 750 * 100vw);
  }
}

.fz48 {
  font-size: 48px;
}
@media screen and (max-width: 767px) {
  .fz48 {
    font-size: calc(48 / 750 * 100vw);
  }
}

.fz49 {
  font-size: 49px;
}
@media screen and (max-width: 767px) {
  .fz49 {
    font-size: calc(49 / 750 * 100vw);
  }
}

.fz50, #business .num span, .sect_ttl {
  font-size: 50px;
}
@media screen and (max-width: 767px) {
  .fz50, #business .num span, .sect_ttl {
    font-size: calc(50 / 750 * 100vw);
  }
}

.fz51 {
  font-size: 51px;
}
@media screen and (max-width: 767px) {
  .fz51 {
    font-size: calc(51 / 750 * 100vw);
  }
}

.fz52 {
  font-size: 52px;
}
@media screen and (max-width: 767px) {
  .fz52 {
    font-size: calc(52 / 750 * 100vw);
  }
}

.fz53 {
  font-size: 53px;
}
@media screen and (max-width: 767px) {
  .fz53 {
    font-size: calc(53 / 750 * 100vw);
  }
}

.fz54 {
  font-size: 54px;
}
@media screen and (max-width: 767px) {
  .fz54 {
    font-size: calc(54 / 750 * 100vw);
  }
}

.fz55 {
  font-size: 55px;
}
@media screen and (max-width: 767px) {
  .fz55 {
    font-size: calc(55 / 750 * 100vw);
  }
}

.fz56 {
  font-size: 56px;
}
@media screen and (max-width: 767px) {
  .fz56 {
    font-size: calc(56 / 750 * 100vw);
  }
}

.fz57 {
  font-size: 57px;
}
@media screen and (max-width: 767px) {
  .fz57 {
    font-size: calc(57 / 750 * 100vw);
  }
}

.fz58 {
  font-size: 58px;
}
@media screen and (max-width: 767px) {
  .fz58 {
    font-size: calc(58 / 750 * 100vw);
  }
}

.fz59 {
  font-size: 59px;
}
@media screen and (max-width: 767px) {
  .fz59 {
    font-size: calc(59 / 750 * 100vw);
  }
}

.fz60 {
  font-size: 60px;
}
@media screen and (max-width: 767px) {
  .fz60 {
    font-size: calc(60 / 750 * 100vw);
  }
}

.fz61 {
  font-size: 61px;
}
@media screen and (max-width: 767px) {
  .fz61 {
    font-size: calc(61 / 750 * 100vw);
  }
}

.fz62 {
  font-size: 62px;
}
@media screen and (max-width: 767px) {
  .fz62 {
    font-size: calc(62 / 750 * 100vw);
  }
}

.fz63 {
  font-size: 63px;
}
@media screen and (max-width: 767px) {
  .fz63 {
    font-size: calc(63 / 750 * 100vw);
  }
}

.fz64 {
  font-size: 64px;
}
@media screen and (max-width: 767px) {
  .fz64 {
    font-size: calc(64 / 750 * 100vw);
  }
}

.fz65 {
  font-size: 65px;
}
@media screen and (max-width: 767px) {
  .fz65 {
    font-size: calc(65 / 750 * 100vw);
  }
}

.fz66 {
  font-size: 66px;
}
@media screen and (max-width: 767px) {
  .fz66 {
    font-size: calc(66 / 750 * 100vw);
  }
}

.fz67 {
  font-size: 67px;
}
@media screen and (max-width: 767px) {
  .fz67 {
    font-size: calc(67 / 750 * 100vw);
  }
}

.fz68 {
  font-size: 68px;
}
@media screen and (max-width: 767px) {
  .fz68 {
    font-size: calc(68 / 750 * 100vw);
  }
}

.fz69 {
  font-size: 69px;
}
@media screen and (max-width: 767px) {
  .fz69 {
    font-size: calc(69 / 750 * 100vw);
  }
}

.fz70 {
  font-size: 70px;
}
@media screen and (max-width: 767px) {
  .fz70 {
    font-size: calc(70 / 750 * 100vw);
  }
}

.fz71 {
  font-size: 71px;
}
@media screen and (max-width: 767px) {
  .fz71 {
    font-size: calc(71 / 750 * 100vw);
  }
}

.fz72 {
  font-size: 72px;
}
@media screen and (max-width: 767px) {
  .fz72 {
    font-size: calc(72 / 750 * 100vw);
  }
}

.fz73 {
  font-size: 73px;
}
@media screen and (max-width: 767px) {
  .fz73 {
    font-size: calc(73 / 750 * 100vw);
  }
}

.fz74 {
  font-size: 74px;
}
@media screen and (max-width: 767px) {
  .fz74 {
    font-size: calc(74 / 750 * 100vw);
  }
}

.fz75 {
  font-size: 75px;
}
@media screen and (max-width: 767px) {
  .fz75 {
    font-size: calc(75 / 750 * 100vw);
  }
}

.fz76 {
  font-size: 76px;
}
@media screen and (max-width: 767px) {
  .fz76 {
    font-size: calc(76 / 750 * 100vw);
  }
}

.fz77 {
  font-size: 77px;
}
@media screen and (max-width: 767px) {
  .fz77 {
    font-size: calc(77 / 750 * 100vw);
  }
}

.fz78 {
  font-size: 78px;
}
@media screen and (max-width: 767px) {
  .fz78 {
    font-size: calc(78 / 750 * 100vw);
  }
}

.fz79 {
  font-size: 79px;
}
@media screen and (max-width: 767px) {
  .fz79 {
    font-size: calc(79 / 750 * 100vw);
  }
}

.fz80, .mv p.txt_en {
  font-size: 80px;
}
@media screen and (max-width: 767px) {
  .fz80, .mv p.txt_en {
    font-size: calc(80 / 750 * 100vw);
  }
}

.fz81 {
  font-size: 81px;
}
@media screen and (max-width: 767px) {
  .fz81 {
    font-size: calc(81 / 750 * 100vw);
  }
}

.fz82 {
  font-size: 82px;
}
@media screen and (max-width: 767px) {
  .fz82 {
    font-size: calc(82 / 750 * 100vw);
  }
}

.fz83 {
  font-size: 83px;
}
@media screen and (max-width: 767px) {
  .fz83 {
    font-size: calc(83 / 750 * 100vw);
  }
}

.fz84 {
  font-size: 84px;
}
@media screen and (max-width: 767px) {
  .fz84 {
    font-size: calc(84 / 750 * 100vw);
  }
}

.fz85 {
  font-size: 85px;
}
@media screen and (max-width: 767px) {
  .fz85 {
    font-size: calc(85 / 750 * 100vw);
  }
}

.fz86 {
  font-size: 86px;
}
@media screen and (max-width: 767px) {
  .fz86 {
    font-size: calc(86 / 750 * 100vw);
  }
}

.fz87 {
  font-size: 87px;
}
@media screen and (max-width: 767px) {
  .fz87 {
    font-size: calc(87 / 750 * 100vw);
  }
}

.fz88 {
  font-size: 88px;
}
@media screen and (max-width: 767px) {
  .fz88 {
    font-size: calc(88 / 750 * 100vw);
  }
}

.fz89 {
  font-size: 89px;
}
@media screen and (max-width: 767px) {
  .fz89 {
    font-size: calc(89 / 750 * 100vw);
  }
}

.fz90 {
  font-size: 90px;
}
@media screen and (max-width: 767px) {
  .fz90 {
    font-size: calc(90 / 750 * 100vw);
  }
}

.fz91 {
  font-size: 91px;
}
@media screen and (max-width: 767px) {
  .fz91 {
    font-size: calc(91 / 750 * 100vw);
  }
}

.fz92 {
  font-size: 92px;
}
@media screen and (max-width: 767px) {
  .fz92 {
    font-size: calc(92 / 750 * 100vw);
  }
}

.fz93 {
  font-size: 93px;
}
@media screen and (max-width: 767px) {
  .fz93 {
    font-size: calc(93 / 750 * 100vw);
  }
}

.fz94 {
  font-size: 94px;
}
@media screen and (max-width: 767px) {
  .fz94 {
    font-size: calc(94 / 750 * 100vw);
  }
}

.fz95 {
  font-size: 95px;
}
@media screen and (max-width: 767px) {
  .fz95 {
    font-size: calc(95 / 750 * 100vw);
  }
}

.fz96 {
  font-size: 96px;
}
@media screen and (max-width: 767px) {
  .fz96 {
    font-size: calc(96 / 750 * 100vw);
  }
}

.fz97 {
  font-size: 97px;
}
@media screen and (max-width: 767px) {
  .fz97 {
    font-size: calc(97 / 750 * 100vw);
  }
}

.fz98 {
  font-size: 98px;
}
@media screen and (max-width: 767px) {
  .fz98 {
    font-size: calc(98 / 750 * 100vw);
  }
}

.fz99 {
  font-size: 99px;
}
@media screen and (max-width: 767px) {
  .fz99 {
    font-size: calc(99 / 750 * 100vw);
  }
}

.fz100 {
  font-size: 100px;
}
@media screen and (max-width: 767px) {
  .fz100 {
    font-size: calc(100 / 750 * 100vw);
  }
}

.txt_center {
  text-align: center;
}

.f_normal {
  font-weight: normal;
}

.f_mid {
  font-weight: 500;
}

.f_bold {
  font-weight: bold;
}

* {
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

/* 大枠 */
html,
body {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: none;
  -webkit-overflow-scrolling: touch !important;
  -moz-osx-font-smoothing: grayscale;
}

body {
  letter-spacing: 0.02em;
  line-height: 1.6;
  color: #484848;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
@media screen and (max-width: 767px) {
  body.wrap {
    overflow: hidden;
  }
}

#wrapper {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  #wrapper {
    width: 100%;
  }
}

body > #wrapper {
  height: auto;
}

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

@media print {
  html,
  html body {
    overflow: visible !important;
  }
}
/* アクセシビリティ */
.guidance {
  left: -999px;
  position: absolute;
  width: 990px;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  pointer-events: none;
} /* レスポンシブ対応 */
img {
  vertical-align: bottom;
  -webkit-box-shadow: #000 0 0 0;
          box-shadow: #000 0 0 0; /* ロールオーバー対応 */
}

img,
x:-moz-any-link,
x:default {
  box-shadow: #000 0 0 0; /* IE7対応 */
}

/* Windows Chrome 画像ぼやけ防止 */
@media screen and (max-width: 767px) {
  img {
    image-rendering: -webkit-optimize-contrast;
  }
}
/* リンク */
a {
  display: inline-block;
}

a:link,
a:visited,
a:active {
  color: currentColor;
  text-decoration: none;
}

a:hover {
  color: inherit;
  opacity: 0.7;
  text-decoration: none !important;
}

.noto-serif, footer .txt, #business .num, .mv p.txt, .sect_ttl {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.abhaya, footer .txt span, #business .num span, .mv p.txt_en {
  font-family: "Abhaya Libre", serif;
  font-style: normal;
}

/* CLEARFIX */
.container:after,
.row:after,
.col:after {
  content: "";
  display: table;
  clear: both;
}

.container {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

.sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  #header_inner,
  #main, #contents, #side,
  footer, #footer_inner {
    float: none;
    width: 100%;
  }
}
/* ▼▼▼ ヘッダー
====================================================== */
header {
  width: min(100%, 750px);
  margin: 0 auto;
  padding: 20px 38px 0;
  overflow: hidden;
  line-height: 1;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: 0;
  left: 50%;
  z-index: 1;
}
header img {
  width: min(37.33vw, 280px);
}
@media screen and (max-width: 767px) {
  header {
    padding: 2.53vw 5vw 0;
  }
}

.float_btn {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9;
}

.float_btn a:hover {
  opacity: 0.7;
}

/* float_btn01 */
.float_btn01 a:nth-child(1) {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.float_btn01 a:nth-child(2) {
  -webkit-box-flex: 1.5;
      -ms-flex: 1.5;
          flex: 1.5;
}

.menu {
  display: none;
}

/* ▼▼▼ メイン 「コンテンツとサイドを囲む要素」
====================================================== */
#main {
  width: min(100%, 750px);
  margin: 0 auto;
  clear: both;
  overflow: hidden;
}

section {
  padding: 110px 40px 0;
}
@media screen and (max-width: 767px) {
  section {
    padding: 14.66vw 5.33vw 0;
  }
}

.sect_ttl {
  margin-bottom: 75px;
  color: #2771CC;
  font-weight: normal;
  line-height: 1;
}
.sect_ttl .en {
  display: block;
  margin-top: 0.6em;
  color: #BEBEBE;
}
@media screen and (max-width: 767px) {
  .sect_ttl {
    margin-bottom: 10vw;
  }
}

.sub_ttl {
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .sub_ttl {
    margin-bottom: 2.66vw;
  }
}

.mv {
  background: url(../img/mv.webp) no-repeat center/100%;
  aspect-ratio: 1/1.64;
  padding-top: min(51.5vw, 383px);
}
.mv p {
  text-align: center;
}
.mv p.txt_en {
  margin-bottom: 35px;
  line-height: 1;
  letter-spacing: 0.02em;
  -webkit-filter: drop-shadow(0 0 15px white);
          filter: drop-shadow(0 0 15px white);
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.6);
}
@media screen and (max-width: 767px) {
  .mv p.txt_en {
    margin-bottom: 4.66vw;
  }
}
.mv p.txt {
  margin-bottom: 40px;
  color: #22BF73;
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
  .mv p.txt {
    margin-bottom: 5.33vw;
  }
}
.mv p.read {
  line-height: 1.8;
}

/* ▼ philosophy
--------------------------------------- */
#philosophy {
  background: url(../img/philosophy_bg.webp) no-repeat center bottom/100%;
  padding-bottom: 85px;
}
#philosophy p {
  width: 59%;
}
@media screen and (max-width: 767px) {
  #philosophy {
    padding-bottom: 11.33vw;
  }
}

/* ▼ business
--------------------------------------- */
#business .inner:not(:first-of-type) {
  padding-top: 96px;
}
@media screen and (max-width: 767px) {
  #business .inner:not(:first-of-type) {
    padding-top: 12.8vw;
  }
}
#business .num {
  display: inline-block;
  border: 2px solid currentColor;
  border-radius: 40px;
  padding: 10px 30px;
  margin-bottom: 40px;
  color: #22BF73;
  font-weight: normal;
  line-height: 1;
}
#business .num span {
  display: inline-block;
  margin-right: 16px;
}
@media screen and (max-width: 767px) {
  #business .num {
    border-width: 1px;
    padding: 1.33vw 4vw;
    margin-bottom: 5.33vw;
  }
  #business .num span {
    margin-right: 2.13vw;
  }
}
#business .col2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 40px 34px;
  margin: 50px 0;
}
#business .col2 li {
  width: calc((100% - 34px) / 2);
}
#business .col2 li p {
  margin-top: 22px;
  line-height: 1.2;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #business .col2 {
    gap: 5.33vw 4.53vw;
    margin: 6.66vw 0;
  }
  #business .col2 li {
    width: calc((100% - 4.53vw) / 2);
  }
  #business .col2 li p {
    margin-top: 2.93vw;
  }
}
#business .img {
  margin-top: 45px;
}
@media screen and (max-width: 767px) {
  #business .img {
    margin-top: 6vw;
  }
}

/* ▼ company
--------------------------------------- */
#company {
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  #company {
    padding-bottom: 16vw;
  }
}

.info {
  display: block;
  width: 100%;
}
.info tbody, .info tr, .info th, .info td {
  display: block;
  width: 100%;
}
.info th {
  padding-top: 20px;
  font-weight: normal;
}
.info td p {
  border-bottom: 2px solid #D6D6D6;
  padding: 0 20px 20px;
}
.info .map {
  aspect-ratio: 1/0.92;
  font-size: 0;
}
.info .map iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .info th {
    padding-top: 2.66vw;
  }
  .info td p {
    border-width: 1px;
    padding: 0 2.66vw 2.66vw;
  }
}

/* ▼▼▼ フッター
===================================== */
footer {
  background: #22BF73;
  width: min(100%, 750px);
  margin: 0 auto;
  color: #fff;
  position: relative;
}
footer .footer_inner {
  padding: 117px 0;
}
footer .f_logo {
  width: min(42.66vw, 320px);
  display: block;
  margin: 0 auto 16px;
  text-align: center;
}
footer .txt {
  text-align: center;
}
footer .txt span {
  display: block;
  text-align: center;
}
@media screen and (max-width: 767px) {
  footer .footer_inner {
    padding: 15.6vw 0;
  }
  footer .f_logo {
    margin-bottom: 2.13vw;
  }
}

/* ▼ コピーライト */
.copyright {
  background: #666;
  padding: 20px;
  color: #A6A6A6;
  text-align: center;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .copyright {
    padding: 2.66vw;
  }
}

/* ▼ ページ上部へ戻る
--------------------------------------- */
.pagetop {
  cursor: pointer;
}