@charset "UTF-8";
html {
  scroll-padding-top: 7.5rem;
}
@media only screen and (max-width: 48em) {
  html {
    scroll-padding-top: 0;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  #top.single {
    padding-top: 9.375rem;
    padding-bottom: 15rem;
  }
}
@media only screen and (max-width: 48em) {
  #top.single {
    padding-top: 3.125rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .mv {
    margin-bottom: 10rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .mv {
    margin-bottom: 6.25rem;
  }
}
#top .mv .mv-wrap .mv-block {
  display: flex;
  align-items: center;
  width: 100%;
}
@media only screen and (max-width: 48em) {
  #top .mv .mv-wrap .mv-block {
    height: calc(100vh - 5rem);
    flex-direction: column;
  }
}
#top .mv .mv-wrap .mv-block .mv-img {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .mv .mv-wrap .mv-block .mv-img {
    width: 33.3333333333%;
  }
}
@media only screen and (max-width: 48em) {
  #top .mv .mv-wrap .mv-block .mv-img {
    width: 100%;
    height: 33.3333333333%;
  }
}
#top .mv .mv-wrap .mv-block .mv-img img {
  transition: transform 0.1s linear;
  height: 100vh;
}
@media only screen and (max-width: 48em) {
  #top .mv .mv-wrap .mv-block .mv-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
#top .contact-link {
  border-radius: 50%;
  background: #000;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  position: fixed;
  z-index: 1000;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact-link {
    width: 10rem;
    height: 10rem;
    bottom: 2.5rem;
    right: 2.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact-link {
    width: 6.25rem;
    height: 6.25rem;
    bottom: 0.625rem;
    right: 0.625rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact-link img {
    width: 2.5625rem;
    height: auto;
    margin-bottom: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact-link img {
    width: 1.75rem;
    height: auto;
    margin-bottom: 0.3125rem;
  }
}
#top .contact-link span {
  text-align: center;
  line-height: 1.3;
  font-family: "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact-link span {
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact-link span {
    font-size: 0.6875rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio {
    width: 76.25rem;
    margin: 0 auto 11.875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio {
    margin-bottom: 5rem;
    padding-top: 8rem;
    margin-top: -8rem;
  }
}
#top .portfolio .title-en {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
  text-align: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .title-en {
    font-size: 3.125rem;
    margin-bottom: 3.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .title-en {
    font-size: 1.625rem;
    margin-bottom: 2.5rem;
    text-align: left;
    margin-left: 5vw;
  }
}
#top .portfolio .lead {
  text-align: center;
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .lead {
    font-size: 1.125rem;
    line-height: 2;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .lead {
    font-size: 0.9375rem;
    text-align: left;
    padding: 0 1.25rem;
    line-height: 1.8em;
  }
  #top .portfolio .lead br {
    display: none;
  }
}
#top .portfolio .anchor-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: -webkit-sticky;
  position: sticky;
  z-index: 2;
  top: 0;
  background: rgba(255, 255, 255, 0.95);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .anchor-link {
    margin-top: 5rem;
    margin-bottom: 8.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link {
    position: relative;
    margin: 3.125rem 0;
    flex-wrap: wrap;
  }
}
#top .portfolio .anchor-link li {
  width: 46vw;
  border-right: 1px solid;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .anchor-link li {
    height: 7.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li {
    height: 6.25rem;
    background-color: #eee;
    border-right: 2px solid #fff;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .anchor-link li:first-child {
    border-left: 1px solid;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li:first-child {
    border-bottom: 1px solid #fff;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li:nth-child(2) {
    border-right: none;
    border-bottom: 1px solid #fff;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li:last-child {
    border-right: none;
  }
}
#top .portfolio .anchor-link li a {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .anchor-link li a {
    font-size: 1.125rem;
    padding-top: 1.875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li a {
    text-align: center;
    align-items: center;
    line-height: 1.4;
    font-size: 0.875rem;
    padding-bottom: 6vw;
  }
}
#top .portfolio .anchor-link li a::after {
  display: block;
  content: "";
  background: url(../img/nav-arrow.png) no-repeat center center/100% auto;
  position: absolute;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .anchor-link li a::after {
    width: 1rem;
    height: 0.75rem;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: 1.875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .anchor-link li a::after {
    width: 1rem;
    height: 1rem;
    right: 0;
    left: 0;
    top: auto;
    bottom: 4.5vw;
    margin: auto;
  }
}
#top .portfolio .portfolio-contents {
  border-top: 1px solid #000;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents {
    padding-top: 4.375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents {
    padding-top: 1.875rem;
    margin-left: 4vw;
    margin-right: 4vw;
  }
}
#top .portfolio .portfolio-contents::before {
  display: block;
  content: "";
  width: 1px;
  background: #000;
  position: absolute;
  top: 0;
  right: 0;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents::before {
    height: 9.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents::before {
    display: none;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents + .portfolio-contents {
    margin-top: 7.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents + .portfolio-contents {
    margin-top: 5rem;
  }
}
#top .portfolio .portfolio-contents .portfolio-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .portfolio-title {
    flex-direction: column;
    align-items: flex-start;
    margin-left: 1vw;
  }
}
#top .portfolio .portfolio-contents .portfolio-title span {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .portfolio-title span {
    font-size: 2.25rem;
    margin-right: 1.875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .portfolio-title span {
    font-size: 1.375rem;
    margin-bottom: 0.3125rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .portfolio-title small {
    font-size: 1.125rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .portfolio-title small {
    font-size: 0.875rem;
  }
}
#top .portfolio .portfolio-contents .portfolio-text {
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .portfolio-text {
    font-size: 1rem;
    margin-top: 1.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .portfolio-text {
    font-size: 0.875rem;
    margin-top: 1.875rem;
    padding: 0rem;
    line-height: 1.8em;
  }
}
#top .portfolio .portfolio-contents .grid {
  position: relative;
  display: block;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .grid {
    margin-top: 5rem;
    width: 100%;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid {
    margin-top: 1.875rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .grid .grid-sizer {
    width: 24.375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid .grid-sizer {
    width: 44.5vw !important;
  }
}
#top .portfolio .portfolio-contents .grid .gutter-sizer {
  width: 2%;
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid .gutter-sizer {
    width: 3%;
  }
}
#top .portfolio .portfolio-contents .grid .grid-item {
  box-sizing: border-box;
  display: block;
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .grid .grid-item {
    width: 24.375rem;
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid .grid-item {
    width: 44.5vw !important;
    margin-bottom: 3vw;
  }
}
#top .portfolio .portfolio-contents .grid .grid-item img {
  width: 100%;
  height: auto;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .grid .grid-item.grid-item--l {
    width: 50.375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid .grid-item.grid-item--l {
    width: 44.5vw !important;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .portfolio .portfolio-contents .grid .grid-item.grid-item--s {
    width: 24.375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .portfolio .portfolio-contents .grid .grid-item.grid-item--s {
    width: 44.5vw !important;
  }
}
#top .contents-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contents-inner {
    width: 76.25rem;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 48em) {
  #top .contents-inner {
    padding: 0 1.25rem;
    flex-direction: column;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contents-inner .contents-body {
    width: 51.9375rem;
  }
}
#top .contents-inner .title-en {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contents-inner .title-en {
    font-size: 3.125rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contents-inner .title-en {
    font-size: 1.625rem;
    margin-bottom: 2.5rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile {
    margin-bottom: 12.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile {
    margin-bottom: 7.5rem;
    padding-top: 8rem;
    margin-top: -8rem;
  }
}
#top .profile .contents-body .name-en {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
  margin-top: 0;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body .name-en {
    font-size: 1.75rem;
    margin-bottom: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body .name-en {
    font-size: 1.5rem;
    margin-bottom: 0.3125rem;
  }
}
#top .profile .contents-body .name {
  letter-spacing: 0.2em;
  font-family: "Hiragino Mincho Pro", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Yu Mincho", "MS PMincho", serif;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body .name {
    font-size: 1.3125rem;
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body .name {
    font-size: 1rem;
    margin-bottom: 0.3125rem;
  }
}
#top .profile .contents-body .work {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body .work {
    font-size: 1rem;
    margin-bottom: 3.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body .work {
    font-size: 0.875rem;
    margin-bottom: 3.125rem;
  }
}
#top .profile .contents-body .history {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}
#top .profile .contents-body .history dt {
  line-height: 2.3;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body .history dt {
    font-size: 0.9375rem;
    width: 5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body .history dt {
    font-size: 0.875rem;
    width: 3.75rem;
    flex-basis: 3.75rem;
    flex-shrink: 0;
  }
}
#top .profile .contents-body .history dd {
  line-height: 2.3;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body .history dd {
    font-size: 0.9375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body .history dd {
    font-size: 0.875rem;
  }
}
#top .profile .contents-body p {
  line-height: 2.2;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .profile .contents-body p {
    font-size: 1rem;
    margin-top: 2.25rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .profile .contents-body p {
    font-size: 0.875rem;
    margin-top: 1.25rem;
  }
}
#top .profile .contents-body p + p {
  margin-top: 0;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about {
    margin-bottom: 12.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .about {
    margin-bottom: 2.5rem;
    padding-top: 8rem;
    margin-top: -8rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about .contents-body {
    margin-bottom: 0;
  }
}
#top .about .contents-body .about-data {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  border-bottom: 1px solid #b7b7b7;
}
#top .about .contents-body .about-data:last-child {
  border-bottom: unset;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about .contents-body .about-data {
    padding-bottom: 1.25rem;
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .about .contents-body .about-data {
    padding-bottom: 0.875rem;
    margin-bottom: 0.875rem;
  }
}
#top .about .contents-body .about-data dt {
  line-height: 2.2;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about .contents-body .about-data dt {
    font-size: 1rem;
    width: 12.1875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .about .contents-body .about-data dt {
    font-size: 0.875rem;
    width: 4.375rem;
    flex-shrink: 0;
    line-height: 1.8;
  }
}
#top .about .contents-body .about-data dd {
  line-height: 2.2;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about .contents-body .about-data dd {
    font-size: 1rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .about .contents-body .about-data dd {
    font-size: 0.875rem;
    line-height: 1.8;
  }
  #top .about .contents-body .about-data dd p {
    padding-left: 4em;
    text-indent: -4em;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .about .contents-body .about-data dd small {
    font-size: 0.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .about .contents-body .about-data dd small {
    font-size: 0.75rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .title-en {
    margin-bottom: 3.125rem;
  }
}
#top .contact .form .form-block {
  display: flex;
  align-items: flex-start;
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block + .form-block {
    margin-top: 1.5625rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block + .form-block {
    margin-top: 1.5rem;
  }
}
#top .contact .form .form-block.form-address {
  align-items: baseline;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block.form-address {
    margin-bottom: 3.5rem;
  }
}
#top .contact .form .form-block.form-address dd div {
  display: flex;
}
#top .contact .form .form-block dt {
  font-weight: 400;
  flex-shrink: 0;
  height: 2.875rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dt {
    font-size: 1rem;
    width: 14.6875rem;
    flex-basis: 14.6875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dt {
    width: 100%;
    font-size: 0.875rem;
    margin-bottom: 0.9375rem;
    height: 1.4em;
  }
}
#top .contact .form .form-block dt span {
  font-family: "Hiragino Mincho Pro", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Yu Mincho", "MS PMincho", serif;
  color: #fff;
  background: #900000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dt span {
    font-size: 0.75rem;
    width: 2.1875rem;
    height: 1.25rem;
    margin-left: 0.4375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dt span {
    font-size: 0.75rem;
    padding: 0.0625rem 0.375rem;
    margin-left: 0.625rem;
  }
}
#top .contact .form .form-block dd {
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd {
    font-size: 1rem;
    line-height: 2.8125rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd {
    font-size: 1rem;
    padding: 0;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.half {
    width: 16.5625rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.half {
    width: 45%;
    margin-right: 3vw;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.half + .half {
    margin-left: 1.125rem;
  }
}
#top .contact .form .form-block dd.full {
  width: 100%;
}
#top .contact .form .form-block dd.noneline {
  border: 0px;
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.noneline {
    padding: 0;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.noneline dt {
    width: 5.625rem;
    flex-basis: 5.625rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.noneline dd.half2 {
    width: 16.875rem;
    margin-right: 1.4375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.noneline dd.half2 {
    width: 48%;
  }
}
#top .contact .form .form-block dd.noneline dd.btn {
  border: none;
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.noneline dd.btn {
    width: 45%;
    margin-left: 3vw;
  }
}
#top .contact .form .form-block dd.noneline dd.btn button {
  font-family: "Shippori Mincho", sans-serif;
  color: #fff;
  font-weight: normal;
  line-height: 3rem;
  text-align: center;
  background-color: #969696;
  display: block;
  transition: opacity 0.1s ease;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.noneline dd.btn button {
    font-size: 0.875rem;
    width: 10.375rem;
    height: 2.875rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.noneline dd.btn button {
    width: 100%;
    font-size: 0.875rem;
  }
}
#top .contact .form .form-block dd.noneline dd.btn button.loading {
  opacity: 0.3;
}
#top .contact .form .form-block dd.noneline dd.half3 {
  background: url(/img/arrow-right.png) no-repeat 95% center/0.5625rem auto;
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.noneline dd.half3 {
    width: 100%;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form .form-block dd.full2 {
    width: 100%;
    height: 12.5rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.full2 {
    width: 100%;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form .form-block dd.middle {
    width: 100%;
  }
}
#top .contact .privacy-link {
  color: #595959;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid;
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", sans-serif;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .privacy-link {
    width: 14.375rem;
    height: 2.25rem;
    border-radius: 1.125rem;
    font-size: 0.75rem;
    margin-top: 2.375rem;
    margin-left: auto;
    margin-right: 11.625rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .privacy-link {
    width: 70vw;
    height: 2.5rem;
    border-radius: 1.125rem;
    font-size: 0.8125rem;
    margin-top: 2.375rem;
    margin-left: auto;
    margin-right: auto;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .privacy-link img {
    width: 1.0625rem;
    height: auto;
    margin-left: 0.8125rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .privacy-link img {
    width: 1.125rem;
    height: auto;
    margin-left: 1.25rem;
  }
}
#top .contact .form-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form-buttons {
    padding-left: 14.4375rem;
    margin-top: 3.3125rem;
    margin-bottom: 9.375rem;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form-buttons {
    margin-top: 2.5rem;
    margin-bottom: 5rem;
  }
}
#top .contact .form-buttons .formlib3-button {
  background: #900000;
  color: #fff;
  letter-spacing: 0.2em;
  font-weight: 700;
  font-family: "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top .contact .form-buttons .formlib3-button {
    flex: 1;
    height: 3.75rem;
    font-size: 1.125rem;
    margin-left: auto;
    margin-right: 0;
  }
}
@media only screen and (max-width: 48em) {
  #top .contact .form-buttons .formlib3-button {
    width: 100%;
    height: 3.75rem;
    font-size: 1.125rem;
  }
}
#top .contact .form-buttons .formlib3-button:hover {
  opacity: 0.7;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  #top #contact {
    padding-top: 4.375rem;
    margin-top: -4.375rem;
  }
}

.formlib3-form-errors {
  margin-bottom: 4em;
  text-align: center;
  color: #e00;
}

.formlib3-field {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #c3c3c3;
  padding: 0 0.5em;
}
.formlib3-field ::-webkit-input-placeholder {
  color: #939393;
}
.formlib3-field ::-moz-placeholder {
  color: #939393;
}
.formlib3-field ::placeholder {
  color: #939393;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .formlib3-field {
    font-size: 0.9375rem;
  }
}

.formlib3-input {
  height: 2.875rem;
}

.formlib3-textarea {
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .formlib3-textarea {
    font-size: 0.875rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .formlib3-select {
    width: 16.875rem;
    font-weight: normal;
    height: 2.875rem;
    font-size: 0.9375rem;
    padding: 0 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  .formlib3-select {
    width: 100%;
    background: unset;
    height: 3.2rem;
  }
}

.formlib3-invalid {
  background: #fee;
}

.formlib3-field-error {
  color: #e00;
}

#top .formlib3-is-show .contact .form .form-block dt span {
  display: none;
}

#top .formlib3-is-show .contact .form .form-block dd.noneline dd.btn button {
  display: none;
}

#top .formlib3-is-show .contact .form .form-block dd.noneline dd.half3 {
  background: none;
}

#top .formlib3-is-show .contact .privacy-link {
  display: none;
}

.full2 .formlib3-confirm {
  white-space: pre-wrap;
}

.form-confirm {
  margin-bottom: 4rem;
}

#top .formlib3-is-show .contact .form .form-block dd.half {
  width: auto;
}
@media only screen and (max-width: 48em) {
  #top .formlib3-is-show .contact .form .form-block dd.half {
    margin-right: 1em;
  }
}/*# sourceMappingURL=top.css.map */