/*! 
Theme Name: YAP
Author: Team covs
*/
@import url("https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&display=swap");
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
*::before, *::after {
  box-sizing: inherit;
}

html {
  font-size: 62.5%;
  box-sizing: border-box;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  max-width: 100vw;
  overflow-x: hidden;
  margin: auto;
  -webkit-overflow-scrolling: touch;
  font-family: "Jost";
  scroll-behavior: smooth;
}
html::selection {
  background-color: #30a9d1;
  color: white;
}

.pageName {
  display: none;
}

body {
  width: 100%;
  overflow-x: hidden;
  max-width: 100vw;
  position: relative;
  font-family: "Jost";
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  margin: 0;
  max-width: 100vw;
}

li {
  list-style: none;
}

button {
  padding: 0;
  outline: none;
  border: none;
  background-color: transparent;
  appearance: none;
}

img {
  max-width: 100%;
  border: none;
  vertical-align: top;
  height: auto;
  object-fit: cover;
  object-position: center;
  border-style: none;
}

br.-sp {
  display: none;
}
br.-pc {
  display: block;
}

.pageTop {
  display: none;
}

main {
  display: block;
  line-height: 1.5;
  transition: opacity 0.3s ease;
  transition: all 1s cubic-bezier(0.59, 0, 0.265, 0.995);
  transition-timing-function: cubic-bezier(0.59, 0, 0.265, 0.995);
}
@media (max-width: 767px) {
  main {
    margin-top: 0px !important;
  }
}
main.-show {
  margin-top: 0px !important;
  opacity: 1;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  display: inline-block;
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}
a:hover {
  opacity: 0.7;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
  font-size: 100%;
  line-height: 1.5;
  margin: 0;
}

button,
input {
  overflow: visible;
  -webkit-appearance: none;
  appearance: none;
  border: none;
  -webkit-appearance: none;
  border-radius: 0;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
  -webkit-appearance: none;
  border-radius: 0px;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

@media (max-width: 767px) {
  br.-sp {
    display: inline;
  }
  br.-pc {
    display: none;
  }
}
embed,
iframe,
object {
  max-width: 100%;
}

figure {
  margin: 0;
  position: relative;
  overflow: hidden;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

li > ul,
li > ol {
  margin-bottom: 0;
}

table {
  width: 100%;
  display: inline-flex;
  overflow: hidden;
}

tbody {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
}

tr {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
}

th {
  display: inline-block;
  text-align: left;
  padding-right: 1em;
}

td {
  display: inline-block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  clear: both;
  font-weight: normal;
  font-family: "Jost";
}

p {
  font-size: clamp(1.4rem, 1.1vw, 1.6rem);
}

body,
button,
input,
select,
optgroup,
textarea {
  font-weight: normal;
  font-style: normal;
}

span {
  display: inline-block;
}

.grecaptcha-badge {
  display: none !important;
}

.anchor {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: -150px;
  left: 0;
  width: 1px;
  height: 1px;
  display: block;
}

.burger {
  cursor: pointer;
  position: fixed;
  top: clamp(24px, 24px + (26 - 24) * (100vw - 375px) / 1065, 26px);
  right: clamp(26px, 26px + (88 - 26) * (100vw - 375px) / 1065, 88px);
  z-index: 120;
  padding: 3px;
  display: none;
}
@media (max-width: 767px) {
  .burger {
    display: block;
  }
}

.burgerWrap {
  width: 25px;
  height: 11px;
  position: relative;
}

.burgerBar {
  height: 2px;
  width: 25px;
  background-color: #000;
  position: absolute;
  left: 50%;
  transition: all 0.2s ease;
}
.burgerBar:nth-of-type(1) {
  top: 0%;
  transform: translate(-50%, 0%) rotate(0deg);
}
.burgerBar:nth-of-type(1).-active {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  background-color: white;
}
.burgerBar:nth-of-type(2) {
  top: 100%;
  transform: translate(-50%, -100%) rotate(0deg);
}
.burgerBar:nth-of-type(2).-active {
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  background-color: white;
}

.breadcrumbList {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: row;
  flex-wrap: wrap;
  row-gap: 5px;
  width: 100%;
}

.breadcrumbItem {
  font-size: clamp(1.1rem, 11px + (14 - 11) * (100vw - 375px) / 1065, 1.4rem);
  font-weight: 300;
  line-height: 1.2;
  color: black;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: row;
}
@media (max-width: 767px) {
  .breadcrumbItem {
    line-height: 1.2;
  }
}
.breadcrumbItem:not(:last-of-type)::after {
  color: black;
  content: "/";
  display: inline-block;
  padding-left: 0.5em;
  padding-right: 0.5em;
}

.pagination {
  padding-top: clamp(55px, 55px + (64 - 55) * (100vw - 375px) / 1065, 64px);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  column-gap: clamp(24px, 24px + (60 - 24) * (100vw - 375px) / 1065, 60px);
}

.paginationPrev.-hide,
.paginationNext.-hide {
  pointer-events: none;
  opacity: 0;
}
.paginationPrev::after,
.paginationNext::after {
  content: "";
  display: block;
  width: 13px;
  height: 25px;
  background-image: url(./optimized/news/arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;
}

.paginationPrev::after {
  rotate: 180deg;
}

.paginationInner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  column-gap: clamp(18px, 18px + (48 - 18) * (100vw - 375px) / 1065, 48px);
}

.paginationNumber {
  position: relative;
  font-size: clamp(1.6rem, 16px + (20 - 16) * (100vw - 375px) / 1065, 2rem);
  line-height: 1.2;
}
.paginationNumber.-current::after {
  content: "";
  display: block;
  width: clamp(24px, 24px + (34 - 24) * (100vw - 375px) / 1065, 34px);
  height: 1px;
  background: white;
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
}

.-noSpace {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.headerBg {
  background: linear-gradient(90deg, #FFF 16.35%, #0FB5EB 26.44%);
  mix-blend-mode: screen;
  width: 100vw;
  height: clamp(56px, 56px + (80 - 56) * (100vw - 375px) / 1065, 80px);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}

.headerInner {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 101;
  width: 100vw;
  height: clamp(56px, 56px + (80 - 56) * (100vw - 375px) / 1065, 80px);
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-direction: row;
  padding-right: clamp(16px, 16px + (60 - 16) * (100vw - 375px) / 1065, 60px);
}
@media (max-width: 767px) {
  .headerInner {
    top: 0;
    right: 0;
    transition: all 0.3s ease;
    padding-right: 0;
    transform: translateX(100%);
    width: 100%;
    height: 100lvh;
    background: rgba(61, 64, 68, 0.9);
  }
  .headerInner.-active {
    transform: translateX(0);
  }
}

.headerTtl {
  display: contents;
}

.headerLogo {
  white-space: nowrap;
  position: fixed;
  left: clamp(16px, 16px + (18 - 16) * (100vw - 375px) / 1065, 18px);
  top: clamp(14.7px, 14.7px + (21 - 14.7) * (100vw - 375px) / 1065, 21px);
  z-index: 104;
  width: clamp(140px, 140px + (200 - 140) * (100vw - 375px) / 1065, 200px);
}
.headerLogo img {
  width: 100%;
  object-fit: contain;
}

@media (max-width: 767px) {
  .headerNav {
    overflow-y: scroll;
    max-height: 100%;
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
  }
}

.headerNavList {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-direction: row;
  column-gap: clamp(35px, 35px + (50 - 35) * (100vw - 375px) / 1065, 50px);
}
@media (max-width: 767px) {
  .headerNavList {
    width: 100%;
    display: inline-flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    padding-top: 212px;
    padding-bottom: 212px;
    row-gap: 20px;
  }
}

.headerNavItem {
  position: relative;
}
@media (max-width: 767px) {
  .headerNavItem {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.headerNavLink {
  font-size: clamp(1.63rem, 16.3px + (20 - 16.3) * (100vw - 375px) / 1065, 2rem);
  line-height: 1.5;
  font-weight: 600;
  white-space: nowrap;
  text-align: center;
}
@media (max-width: 767px) {
  .headerNavLink {
    max-width: 100vw;
    color: white;
  }
}

.headerCloseTrigger {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  z-index: 4;
}
.headerCloseTrigger.-active {
  display: block;
}

.headerBook {
  z-index: 50;
  position: fixed;
  bottom: clamp(16px, 16px + (32 - 16) * (100vw - 375px) / 1065, 32px);
  right: clamp(16px, 16px + (32 - 16) * (100vw - 375px) / 1065, 32px);
  background: #FFF538;
  border: 5px solid #DFD73C;
  border-radius: 50%;
  width: clamp(103.8px, 103.8px + (173 - 103.8) * (100vw - 375px) / 1065, 173px);
  height: clamp(103.8px, 103.8px + (173 - 103.8) * (100vw - 375px) / 1065, 173px);
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  row-gap: clamp(5.3px, 5.3px + (9 - 5.3) * (100vw - 375px) / 1065, 9px);
  padding-top: clamp(10.2px, 10.2px + (17 - 10.2) * (100vw - 375px) / 1065, 17px);
  color: #000;
  text-align: center;
  font-size: clamp(1.89rem, 18.9px + (34 - 18.9) * (100vw - 375px) / 1065, 3.4rem);
  line-height: 1;
  font-weight: 600;
  transition: all 0.2s ease;
}
.headerBook.-hide {
  opacity: 0;
  pointer-events: none;
}
.headerBook:hover {
  background: #000;
  color: #FFF538;
  opacity: 1;
}
.headerBook::before {
  content: "";
  display: block;
  width: clamp(33.6px, 33.6px + (56 - 33.6) * (100vw - 375px) / 1065, 56px);
  height: clamp(21.5px, 21.5px + (36 - 21.5) * (100vw - 375px) / 1065, 36px);
  background-image: url(./img/common/logo_symbol.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.error {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (140 - 16) * (100vw - 375px) / 1065, 140px);
  padding-right: clamp(16px, 16px + (140 - 16) * (100vw - 375px) / 1065, 140px);
}
@media (max-width: 767px) {
  .error {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.errorInner {
  width: 100%;
}

.errorBody {
  min-height: 100vh;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding-top: clamp(112px, 112px + (160 - 112) * (100vw - 375px) / 1065, 160px);
  padding-bottom: clamp(112px, 112px + (160 - 112) * (100vw - 375px) / 1065, 160px);
}

.errorBodyTtl {
  font-size: clamp(4.48rem, 44.8px + (64 - 44.8) * (100vw - 375px) / 1065, 6.4rem);
  font-weight: 600;
  line-height: 1.5;
}

.errorBodyTxt {
  margin-top: clamp(11.2px, 11.2px + (16 - 11.2) * (100vw - 375px) / 1065, 16px);
  font-size: clamp(1.67rem, 16.7px + (24 - 16.7) * (100vw - 375px) / 1065, 2.4rem);
  line-height: 1.5;
}

.errorBodyLink {
  margin-top: clamp(11.2px, 11.2px + (16 - 11.2) * (100vw - 375px) / 1065, 16px);
}

.intro {
  padding-top: clamp(77px, 77px + (110 - 77) * (100vw - 375px) / 1065, 110px);
  width: 100%;
  position: relative;
}
.intro::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, #F0F6F7 61.06%, rgba(218, 239, 242, 0) 100%);
  position: absolute;
  top: 0%;
  left: 0%;
  z-index: 1;
}

.introInner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
}
@media (max-width: 767px) {
  .introInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.introBody {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-direction: row;
  column-gap: clamp(16px, 16px + (60 - 16) * (100vw - 375px) / 1065, 60px);
  position: relative;
  z-index: 2;
}
@media (max-width: 1150px) {
  .introBody {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column-reverse;
    row-gap: 64px;
  }
}

.introBodyMedia {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  width: calc(100% - clamp(300px, 300px + (600 - 300) * (100vw - 375px) / 1065, 600px) - clamp(16px, 16px + (60 - 16) * (100vw - 375px) / 1065, 60px));
}
@media (max-width: 1150px) {
  .introBodyMedia {
    width: 100%;
  }
}

.introBodyImg {
  max-width: 90%;
}
.introBodyImg.-first {
  margin-right: auto;
  width: clamp(240.1px, 240.1px + (343 - 240.1) * (100vw - 375px) / 1065, 343px);
  aspect-ratio: 343/389;
}
.introBodyImg.-second {
  margin-left: auto;
  margin-top: calc(-100% + 100% - clamp(61.6px, 61.6px + (88 - 61.6) * (100vw - 375px) / 1065, 88px));
  width: clamp(135.7px, 135.7px + (194 - 135.7) * (100vw - 375px) / 1065, 194px);
  aspect-ratio: 97/106;
}
.introBodyImg.-third {
  margin-top: clamp(21px, 21px + (30 - 21) * (100vw - 375px) / 1065, 30px);
  width: clamp(203.7px, 203.7px + (291 - 203.7) * (100vw - 375px) / 1065, 291px);
  aspect-ratio: 291/227;
}

.introBodyContent {
  margin-top: clamp(32.1px, 32.1px + (46 - 32.1) * (100vw - 375px) / 1065, 46px);
  width: clamp(300px, 300px + (600 - 300) * (100vw - 375px) / 1065, 600px);
  position: relative;
}
.introBodyContent::after {
  content: "";
  display: block;
  width: clamp(98px, 98px + (140 - 98) * (100vw - 375px) / 1065, 140px);
  height: clamp(65.8px, 65.8px + (94 - 65.8) * (100vw - 375px) / 1065, 94px);
  background-image: url(./img/common/logo_symbol.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: relative;
  z-index: 0;
  margin-top: calc(-100% + 100% - clamp(3.5px, 3.5px + (5 - 3.5) * (100vw - 375px) / 1065, 5px));
  margin-left: auto;
}
@media (max-width: 1150px) {
  .introBodyContent::after {
    margin-top: 16px;
  }
}
@media (max-width: 1150px) {
  .introBodyContent {
    width: 100%;
  }
}

.introBodyTtl {
  font-size: clamp(3.2rem, 32px + (65 - 32) * (100vw - 375px) / 1065, 6.5rem);
  line-height: 1.31;
  font-weight: 600;
}

.introBodyTxt {
  margin-top: clamp(52.8px, 52.8px + (88 - 52.8) * (100vw - 375px) / 1065, 88px);
  font-size: clamp(1.91rem, 19.1px + (25 - 19.1) * (100vw - 375px) / 1065, 2.5rem);
  line-height: 1.6;
  font-weight: 600;
}

.introBodyLink {
  margin-top: clamp(37.8px, 37.8px + (54 - 37.8) * (100vw - 375px) / 1065, 54px);
  font-size: clamp(1.85rem, 18.5px + (23.9 - 18.5) * (100vw - 375px) / 1065, 2.39rem);
  line-height: 1.45;
  font-weight: 600;
  border-radius: 35px;
  background: #FFF538;
  padding-top: clamp(12.6px, 12.6px + (18 - 12.6) * (100vw - 375px) / 1065, 18px);
  padding-bottom: clamp(12.6px, 12.6px + (18 - 12.6) * (100vw - 375px) / 1065, 18px);
  padding-left: clamp(47.5px, 47.5px + (68 - 47.5) * (100vw - 375px) / 1065, 68px);
  padding-right: clamp(47.5px, 47.5px + (68 - 47.5) * (100vw - 375px) / 1065, 68px);
  text-align: center;
  transition: all 0.2s ease;
}
.introBodyLink:hover {
  opacity: 1;
  color: #FFF538;
  background: black;
}

.introBg {
  width: 100%;
  position: absolute;
  top: clamp(305.9px, 305.9px + (437 - 305.9) * (100vw - 375px) / 1065, 437px);
  z-index: 0;
  left: 0;
  pointer-events: none;
}

.services {
  margin-top: clamp(79.8px, 79.8px + (114 - 79.8) * (100vw - 375px) / 1065, 114px);
  position: relative;
  z-index: 2;
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
}
@media (max-width: 767px) {
  .services {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.servicesInner {
  width: 100%;
}

.servicesHead {
  width: 100%;
}

.servicesHeadTtl {
  font-size: clamp(4rem, 40px + (80 - 40) * (100vw - 375px) / 1065, 8rem);
  line-height: 1.44;
  font-weight: 600;
  color: #0FB5EB;
}

.servicesBody {
  margin-top: 8px;
  width: 100%;
}

.servicesBodyList {
  width: 100%;
  flex-wrap: wrap;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
  width: 100%;
  row-gap: clamp(44.8px, 44.8px + (64 - 44.8) * (100vw - 375px) / 1065, 64px);
  column-gap: clamp(16px, 16px + (64 - 16) * (100vw - 375px) / 1065, 64px);
  justify-content: center;
}

.servicesBodyItem {
  width: calc((100% - clamp(16px, 16px + (64 - 16) * (100vw - 375px) / 1065, 64px) * 2) / 3);
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
}
@media (max-width: 767px) {
  .servicesBodyItem {
    width: calc((100% - clamp(16px, 16px + (64 - 16) * (100vw - 375px) / 1065, 64px) * 1) / 2);
  }
}
@media (max-width: 540px) {
  .servicesBodyItem {
    width: calc((100% - clamp(16px, 16px + (64 - 16) * (100vw - 375px) / 1065, 64px) * 0) / 1);
  }
}

.servicesBodyImg {
  width: 100%;
  aspect-ratio: 106/109;
}

.servicesBodyTtl {
  margin-top: 10px;
  font-size: clamp(2.27rem, 22.7px + (32 - 22.7) * (100vw - 375px) / 1065, 3.2rem);
  line-height: 1.44;
  font-weight: 600;
}

.servicesBodyTxt {
  margin-top: clamp(15.4px, 15.4px + (22 - 15.4) * (100vw - 375px) / 1065, 22px);
  font-size: clamp(1.63rem, 16.3px + (20 - 16.3) * (100vw - 375px) / 1065, 2rem);
  line-height: 1.5;
  font-weight: 600;
}

.info {
  margin-top: clamp(91px, 91px + (130 - 91) * (100vw - 375px) / 1065, 130px);
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  position: relative;
  z-index: 3;
}
@media (max-width: 767px) {
  .info {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.info::before {
  content: "";
  margin-left: clamp(0px, 0px + (18 - 0) * (100vw - 375px) / 1065, 18px);
  display: block;
  width: clamp(74.8px, 74.8px + (107 - 74.8) * (100vw - 375px) / 1065, 107px);
  height: clamp(47.5px, 47.5px + (68 - 47.5) * (100vw - 375px) / 1065, 68px);
  background-image: url(./img/common/logo_symbol.svg);
  background-repeat: no-repeat;
  background-size: contain;
  position: relative;
  z-index: 0;
}

.infoInner {
  width: 100%;
}

.infoHead {
  margin-top: clamp(14px, 14px + (20 - 14) * (100vw - 375px) / 1065, 20px);
  width: 100%;
}

.infoHeadTtl {
  font-size: clamp(3.2rem, 32px + (65 - 32) * (100vw - 375px) / 1065, 6.5rem);
  line-height: 1.31;
  font-weight: 600;
  color: #FFFFFF;
  background: linear-gradient(transparent 0%, transparent 10%, #0FB5EB 11%, #0FB5EB 90%, transparent 91%, transparent 100%);
  display: inline;
}

.infoHeadRow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row;
  column-gap: clamp(16px, 16px + (77 - 16) * (100vw - 375px) / 1065, 77px);
}
@media (max-width: 767px) {
  .infoHeadRow {
    margin-top: 32px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: column-reverse;
    row-gap: 16px;
  }
}

.infoHeadTxt {
  padding-top: 64px;
  padding-bottom: 64px;
  font-size: clamp(1.72rem, 17.2px + (25 - 17.2) * (100vw - 375px) / 1065, 2.5rem);
  line-height: 1.6;
  font-weight: 600;
}
@media (max-width: 767px) {
  .infoHeadTxt {
    padding-top: 0;
    padding-bottom: 0;
  }
}

.infoHeadImg {
  width: clamp(207px, 207px + (345 - 207) * (100vw - 375px) / 1065, 345px);
  min-width: clamp(207px, 207px + (345 - 207) * (100vw - 375px) / 1065, 345px);
  width: 345px;
  aspect-ratio: 69/97;
  object-position: left center;
}
@media (max-width: 767px) {
  .infoHeadImg {
    width: 100%;
    aspect-ratio: 140/100;
  }
}

.infoBody {
  width: 100%;
}
@media (max-width: 767px) {
  .infoBody {
    margin-top: 40px;
  }
}

.infoBodyTtl.-first {
  font-size: clamp(4rem, 40px + (80 - 40) * (100vw - 375px) / 1065, 8rem);
  line-height: 1.44;
  font-weight: 600;
  color: #0FB5EB;
}
.infoBodyTtl.-second {
  font-size: clamp(2.8rem, 28px + (44 - 28) * (100vw - 375px) / 1065, 4.4rem);
  line-height: 1.5;
  font-weight: 600;
  margin-bottom: -0.2em;
}

.infoBodyTxt {
  font-size: clamp(1.82rem, 18.2px + (32 - 18.2) * (100vw - 375px) / 1065, 3.2rem);
  line-height: 1.25;
  font-weight: 600;
  color: #030303;
}

.infoBodyNote {
  margin-top: 3px;
  font-size: clamp(1.91rem, 19.1px + (25 - 19.1) * (100vw - 375px) / 1065, 2.5rem);
  line-height: 1.5;
  font-weight: 600;
}

.infoBodyRow {
  width: 100%;
  margin-top: clamp(16px, 16px + (20 - 16) * (100vw - 375px) / 1065, 20px);
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  flex-direction: row;
  column-gap: 16px;
  flex-wrap: wrap;
}

.infoMenu {
  margin-top: 16px;
  background: #346F83;
  width: 100%;
  padding: clamp(16px, 16px + (24 - 16) * (100vw - 375px) / 1065, 24px);
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
  column-gap: clamp(32px, 32px + (72 - 32) * (100vw - 375px) / 1065, 72px);
  flex-wrap: wrap;
  row-gap: 16px;
}

.infoMenuList {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
  column-gap: clamp(12px, 12px + (20 - 12) * (100vw - 375px) / 1065, 20px);
}

.infoMenuTtl {
  min-width: clamp(74.3px, 74.3px + (124 - 74.3) * (100vw - 375px) / 1065, 124px);
  border-radius: 21.809px;
  background: #FFF;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  font-size: clamp(1.78rem, 17.8px + (26.2 - 17.8) * (100vw - 375px) / 1065, 2.62rem);
  line-height: 1.44;
  font-weight: 600;
  text-align: center;
  padding-left: clamp(16px, 16px + (22 - 16) * (100vw - 375px) / 1065, 22px);
  padding-right: clamp(16px, 16px + (22 - 16) * (100vw - 375px) / 1065, 22px);
  padding-top: 2px;
  padding-bottom: 1px;
}
.infoMenuTtl h5 {
  font-weight: 600;
}

.infoMenuDesc {
  margin-top: calc(-100% + 100% - clamp(1px, 1px + (5 - 1) * (100vw - 375px) / 1065, 5px));
}

.infoMenuPrice {
  font-size: clamp(2.52rem, 25.2px + (44 - 25.2) * (100vw - 375px) / 1065, 4.4rem);
  line-height: 1.2;
  font-weight: 600;
  color: #FFFFFF;
}

.infoMenuPer {
  font-size: clamp(1.72rem, 17.2px + (25 - 17.2) * (100vw - 375px) / 1065, 2.5rem);
  line-height: 1.6;
  font-weight: 600;
  color: #FFFFFF;
  padding-left: clamp(8px, 8px + (12 - 8) * (100vw - 375px) / 1065, 12px);
}

.infoMenuNote {
  font-size: clamp(1.39rem, 13.9px + (20 - 13.9) * (100vw - 375px) / 1065, 2rem);
  line-height: 1.5;
  font-weight: 600;
  color: #FFFFFF;
}

.infoRental {
  margin-top: clamp(29.4px, 29.4px + (42 - 29.4) * (100vw - 375px) / 1065, 42px);
  width: 100%;
  position: relative;
  background-color: #070707;
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-direction: row;
  column-gap: 8px;
  padding-right: 16px;
}
@media (max-width: 1150px) {
  .infoRental {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    padding-right: 0;
  }
}

.infoRentalTtl.-first {
  position: absolute;
  top: clamp(16px, 16px + (24 - 16) * (100vw - 375px) / 1065, 24px);
  left: clamp(16px, 16px + (24 - 16) * (100vw - 375px) / 1065, 24px);
  min-width: clamp(74.3px, 74.3px + (124 - 74.3) * (100vw - 375px) / 1065, 124px);
  border-radius: 21.809px;
  background: #FFF;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-direction: row;
  font-size: clamp(1.78rem, 17.8px + (26.2 - 17.8) * (100vw - 375px) / 1065, 2.62rem);
  line-height: 1.44;
  font-weight: 600;
  text-align: center;
  padding-left: clamp(16px, 16px + (22 - 16) * (100vw - 375px) / 1065, 22px);
  padding-right: clamp(16px, 16px + (22 - 16) * (100vw - 375px) / 1065, 22px);
  padding-top: 2px;
  padding-bottom: 1px;
  z-index: 2;
}
.infoRentalTtl.-second {
  font-size: clamp(2.58rem, 25.8px + (55 - 25.8) * (100vw - 375px) / 1065, 5.5rem);
  line-height: 1.1;
  font-weight: 600;
  color: #FFFFFF;
}

.infoRentalContent {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  row-gap: 10px;
  padding-top: 16px;
  padding-bottom: 16px;
}
@media (max-width: 1150px) {
  .infoRentalContent {
    padding: 16px clamp(16px, 16px + (32 - 16) * (100vw - 375px) / 1065, 32px);
    width: 100%;
  }
}

.infoRentalPic {
  display: contents;
}

.infoRentalImg {
  width: clamp(200px, 200px + (500 - 200) * (100vw - 375px) / 1065, 500px);
  object-position: right center;
  z-index: 1;
}
@media (max-width: 1150px) {
  .infoRentalImg {
    width: 100%;
  }
}

.infoRentalTxt {
  font-size: clamp(1.55rem, 15.5px + (31 - 15.5) * (100vw - 375px) / 1065, 3.1rem);
  line-height: 1.35;
  font-weight: 600;
  color: #FFFFFF;
}

.faq {
  position: relative;
  margin-top: clamp(105px, 105px + (150 - 105) * (100vw - 375px) / 1065, 150px);
  background: rgba(242, 241, 241, 0.8);
  width: 100%;
  padding-top: clamp(37px, 37px + (53 - 37) * (100vw - 375px) / 1065, 53px);
  padding-bottom: clamp(81.1px, 81.1px + (116 - 81.1) * (100vw - 375px) / 1065, 116px);
}

.faqInner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
}
@media (max-width: 767px) {
  .faqInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.faqHead {
  width: 100%;
}

.faqHeadTtl {
  font-size: clamp(4rem, 40px + (80 - 40) * (100vw - 375px) / 1065, 8rem);
  line-height: 1.44;
  font-weight: 600;
}

.faqBody {
  margin-top: clamp(31.4px, 31.4px + (45 - 31.4) * (100vw - 375px) / 1065, 45px);
  width: 100%;
  flex-wrap: wrap;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: row;
  width: 100%;
  row-gap: 0;
  column-gap: clamp(16px, 16px + (40 - 16) * (100vw - 375px) / 1065, 40px);
}

.faqBodyList {
  width: calc((100% - clamp(16px, 16px + (40 - 16) * (100vw - 375px) / 1065, 40px) * 1) / 2);
  border-top: 1px solid black;
}
@media (max-width: 767px) {
  .faqBodyList {
    width: calc((100% - clamp(16px, 16px + (40 - 16) * (100vw - 375px) / 1065, 40px) * 0) / 1);
  }
  .faqBodyList:nth-of-type(2) {
    border-top: none;
  }
}

.faqBodyItem {
  padding-top: clamp(16px, 16px + (36 - 16) * (100vw - 375px) / 1065, 36px);
  padding-bottom: clamp(16px, 16px + (36 - 16) * (100vw - 375px) / 1065, 36px);
  border-bottom: 1px solid black;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  cursor: pointer;
}
.faqBodyItem:hover {
  opacity: 0.7;
}

.faqBodyQ {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: row;
  column-gap: 10px;
  padding-left: 8px;
  padding-right: 8px;
}

.faqBodyA {
  width: 100%;
  margin-top: clamp(16px, 16px + (32 - 16) * (100vw - 375px) / 1065, 32px);
  overflow: hidden;
  transition: all 0.3s ease;
}
.faqBodyA.-hide {
  margin-top: 0 !important;
  height: 0 !important;
}

.faqBodyIcon {
  width: clamp(13.6px, 13.6px + (17 - 13.6) * (100vw - 375px) / 1065, 17px);
  min-width: clamp(13.6px, 13.6px + (17 - 13.6) * (100vw - 375px) / 1065, 17px);
  height: clamp(13.6px, 13.6px + (17 - 13.6) * (100vw - 375px) / 1065, 17px);
  position: relative;
  transition: transform 0.3s ease;
}
.faqBodyIcon::before {
  content: "";
  display: block;
  width: 3px;
  height: 100%;
  background: #0FB5EB;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.faqBodyIcon.-hide::after {
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  background: #0FB5EB;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.faqBodyTtl {
  font-size: clamp(1.45rem, 14.5px + (17 - 14.5) * (100vw - 375px) / 1065, 1.7rem);
  line-height: 1.5;
  font-weight: 600;
}

.faqBodyTxt {
  font-size: clamp(1.51rem, 15.1px + (18 - 15.1) * (100vw - 375px) / 1065, 1.8rem);
  line-height: 1.5;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  row-gap: 12px;
}
.faqBodyTxt p {
  width: 100%;
}
.faqBodyTxt a {
  color: #0FB5EB;
  text-decoration: underline;
}
.faqBodyTxt img {
  width: 100%;
}

.need {
  width: 100%;
  position: relative;
}
.need::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(./img/home/need01.webp);
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}

.needInner {
  position: relative;
}

.needBody {
  width: 100%;
  position: relative;
  padding-top: clamp(44.8px, 44.8px + (64 - 44.8) * (100vw - 375px) / 1065, 64px);
  padding-bottom: clamp(56px, 56px + (80 - 56) * (100vw - 375px) / 1065, 80px);
}
.needBody::after {
  content: "";
  display: block;
  width: 100%;
  mix-blend-mode: multiply;
  height: 100%;
  background: #0FB5EB;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
}

.needBodyInner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
}
@media (max-width: 767px) {
  .needBodyInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.needBodyTtl {
  font-size: clamp(3.2rem, 32px + (80 - 32) * (100vw - 375px) / 1065, 8rem);
  line-height: 1.2;
  font-weight: 600;
  color: #FFFFFF;
  position: relative;
  z-index: 2;
  text-align: center;
}

.needBodyLink {
  margin-top: clamp(22.4px, 22.4px + (32 - 22.4) * (100vw - 375px) / 1065, 32px);
  position: relative;
  z-index: 2;
  border-radius: 35px;
  background: #FFF538;
  padding-top: clamp(12.6px, 12.6px + (18 - 12.6) * (100vw - 375px) / 1065, 18px);
  padding-bottom: clamp(12.6px, 12.6px + (18 - 12.6) * (100vw - 375px) / 1065, 18px);
  padding-left: clamp(47.5px, 47.5px + (68 - 47.5) * (100vw - 375px) / 1065, 68px);
  padding-right: clamp(47.5px, 47.5px + (68 - 47.5) * (100vw - 375px) / 1065, 68px);
  text-align: center;
  transition: all 0.2s ease;
  font-size: clamp(1.85rem, 18.5px + (23.9 - 18.5) * (100vw - 375px) / 1065, 2.39rem);
  line-height: 1.45;
  font-weight: 600;
}
.needBodyLink:hover {
  opacity: 1;
  color: #FFF538;
  background: black;
}

.needBottom {
  width: 100%;
  position: relative;
  padding-top: clamp(28px, 28px + (40 - 28) * (100vw - 375px) / 1065, 40px);
  padding-bottom: clamp(36.4px, 36.4px + (52 - 36.4) * (100vw - 375px) / 1065, 52px);
}
.needBottom::after {
  content: "";
  display: block;
  width: 100%;
  mix-blend-mode: multiply;
  height: 100%;
  background: #424242;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
}

.needBottomInner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-direction: row;
  flex-wrap: wrap;
  column-gap: clamp(16px, 16px + (32 - 16) * (100vw - 375px) / 1065, 32px);
  z-index: 2;
  position: relative;
}
@media (max-width: 767px) {
  .needBottomInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}
@media (max-width: 767px) {
  .needBottomInner {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: column;
    row-gap: 16px;
  }
}

.needBottomImg {
  width: clamp(169.7px, 169.7px + (283 - 169.7) * (100vw - 375px) / 1065, 283px);
}

.needBottomTxt {
  font-size: clamp(1.39rem, 13.9px + (16 - 13.9) * (100vw - 375px) / 1065, 1.6rem);
  line-height: 1.83;
  font-weight: 600;
  color: #FFFFFF;
  text-align: right;
}
@media (max-width: 767px) {
  .needBottomTxt {
    text-align: center;
  }
}

.mv {
  width: 100%;
}

.mvInner {
  width: 100%;
}

.mvBody {
  width: 100%;
  height: clamp(520.1px, 520.1px + (743 - 520.1) * (100vw - 375px) / 1065, 743px);
  overflow: hidden;
  position: relative;
}

.mvBodyContent {
  position: absolute;
  top: 50%;
  left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  transform: translate(0%, -50%);
  z-index: 2;
}
@media (max-width: 767px) {
  .mvBodyContent {
    left: 16px;
  }
}

.mvBodyTxt {
  width: clamp(505.4px, 505.4px + (722 - 505.4) * (100vw - 375px) / 1065, 722px);
  mix-blend-mode: multiply;
}

.mvBodyImg {
  width: 100%;
  height: 100%;
  object-position: 70% 50%;
  transition: opacity 1s ease, transform 1s ease;
  opacity: 1;
  transform: scale(1);
}

.mvSlider {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
  opacity: 0;
  transition: opacity 1s ease;
  position: relative;
  z-index: 4;
}
.mvSlider.-active {
  opacity: 1;
}

.mvSliderInner {
  width: calc(clamp(180px, 180px + (360 - 180) * (100vw - 375px) / 1065, 360px) * 9);
  position: relative;
}

@keyframes slider {
  0% {
    transform: translateX(calc((clamp(180px, 180px + (360 - 180) * (100vw - 375px) / 1065, 360px)) * 8));
    opacity: 0;
  }
  2% {
    opacity: 1;
  }
  98% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: translateX(0);
  }
}
.mvSliderSrc {
  display: none;
}

.mvSliderWrap {
  position: absolute;
  top: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: row;
  width: clamp(180px, 180px + (360 - 180) * (100vw - 375px) / 1065, 360px);
  left: 0;
  pointer-events: none;
}
.mvSliderWrap.-first {
  animation: slider 32s linear infinite -30s;
}
.mvSliderWrap.-second {
  animation: slider 32s linear infinite -26s;
}
.mvSliderWrap.-third {
  animation: slider 32s linear infinite -22s;
}
.mvSliderWrap.-fourth {
  animation: slider 32s linear infinite -18s;
}
.mvSliderWrap.-fifth {
  animation: slider 32s linear infinite -14s;
}
.mvSliderWrap.-sixth {
  animation: slider 32s linear infinite -10s;
}
.mvSliderWrap.-seventh {
  animation: slider 32s linear infinite -6s;
}
.mvSliderWrap.-eighth {
  animation: slider 32s linear infinite -2s;
}

.mvSliderBase {
  width: 100%;
  height: clamp(114.5px, 114.5px + (229 - 114.5) * (100vw - 375px) / 1065, 229px);
  margin-left: auto;
  margin-right: auto;
}

.mvSliderImg {
  pointer-events: none;
  width: 100%;
  height: clamp(114.5px, 114.5px + (229 - 114.5) * (100vw - 375px) / 1065, 229px);
}

.mvBodyBg {
  position: absolute;
  top: 265px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  z-index: 1;
  mix-blend-mode: multiply;
}
@media (max-width: 767px) {
  .mvBodyBg {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.mvBodyBg svg {
  width: clamp(284.9px, 284.9px + (770 - 284.9) * (100vw - 375px) / 1065, 770px);
  height: clamp(111px, 111px + (300 - 111) * (100vw - 375px) / 1065, 300px);
  margin-left: -2.5%;
}

.mvBodyTtl {
  position: absolute;
  top: 265px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  z-index: 2;
}
@media (max-width: 767px) {
  .mvBodyTtl {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.mvBodyTtl svg {
  width: clamp(267.1px, 267.1px + (722 - 267.1) * (100vw - 375px) / 1065, 722px);
  height: clamp(107.6px, 107.6px + (291 - 107.6) * (100vw - 375px) / 1065, 291px);
}

.mvBodySub {
  position: absolute;
  top: clamp(356px, 356px + (520 - 356) * (100vw - 375px) / 1065, 520px);
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (240 - 16) * (100vw - 375px) / 1065, 240px);
  padding-right: clamp(16px, 16px + (240 - 16) * (100vw - 375px) / 1065, 240px);
  z-index: 4;
}
@media (max-width: 767px) {
  .mvBodySub {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.mvBodySub svg {
  width: clamp(189.9px, 189.9px + (422 - 189.9) * (100vw - 375px) / 1065, 422px);
  height: clamp(35.1px, 35.1px + (78 - 35.1) * (100vw - 375px) / 1065, 78px);
}

.cal {
  margin-top: clamp(125.9px, 125.9px + (180 - 125.9) * (100vw - 375px) / 1065, 180px);
  width: 100%;
  position: relative;
  overflow: hidden;
  padding-top: clamp(56px, 56px + (80 - 56) * (100vw - 375px) / 1065, 80px);
  padding-bottom: clamp(56px, 56px + (80 - 56) * (100vw - 375px) / 1065, 80px);
}

.calInner {
  margin-left: auto;
  margin-right: auto;
  max-width: 1440px;
  width: 100%;
  padding-left: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
  padding-right: clamp(16px, 16px + (180 - 16) * (100vw - 375px) / 1065, 180px);
}
@media (max-width: 767px) {
  .calInner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

.calBody {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-direction: column;
}
.calBody iframe {
  margin-top: clamp(42px, 42px + (60 - 42) * (100vw - 375px) / 1065, 60px);
  width: 100%;
  height: 1200px;
}

.calBodyTtl {
  font-size: clamp(4rem, 40px + (80 - 40) * (100vw - 375px) / 1065, 8rem);
  line-height: 1.5;
  font-weight: 600;
  color: white;
  text-align: center;
}

.calBg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}