@charset "UTF-8";
/* ===================================================================
CSS information

 file name  :style.css
 author     :金色時代
 style info :
=================================================================== */
html {
  height: 100%;
  font-size: 100%; }
  @media (max-width: 1280px) {
    html {
      font-size: 1.264vw; } }
  @media (max-width: 1024px) {
    html {
      font-size: 2vw; } }
  @media (max-width: 599px) {
    html {
      font-size: 3.0vw; } }

body {
  font-size: 1rem;
  font-family: Arial, 游ゴシック体, YuGothic, メイリオ, Meiryo, sans-serif;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  color: #000000;
  line-height: 1.41;
  position: relative;
  overflow-x: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  font-feature-settings: "palt"; }

@media (min-width: 1025px) {
  .min1024cut {
    display: none !important; } }
@media (max-width: 1024px) {
  .min1024 {
    display: none !important; } }
@media (min-width: 600px) {
  .sp, .pccut {
    display: none !important; } }
@media (max-width: 599px) {
  .pc, .spcut {
    display: none !important; } }
@media (min-width: 501px) {
  .xs {
    display: none !important; } }
@media (max-width: 500px) {
  .xs-cut {
    display: none !important; } }
.container {
  width: 100%;
  margin: 0 auto;
  padding: 0 8%; }
  @media (min-width: 600px) {
    .container {
      padding: 0 7.8125%; } }
  @media (min-width: 1280px) {
    .container {
      padding: 0;
      max-width: 1080px; } }

.section {
  position: relative;
  padding: 120px 0 0; }
  @media (max-width: 599px) {
    .section {
      padding: 80px 0 0; } }

main > .section:last-child {
  padding: 120px 0; }
  @media (max-width: 599px) {
    main > .section:last-child {
      padding: 80px 0; } }

.en {
  font-family: "EB Garamond", serif; }

.min {
  font-family: "Zen Old Mincho", serif; }

.bold {
  font-weight: 600; }

/* -------------------------------------------------------------
link
------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    /* TEL無効 */ } }
/*--------------------
 header
---------------------*/
#header {
  position: fixed;
  width: 100%;
  height: 120px;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 100;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: .5s ease-in; }
  @media (max-width: 1024px) {
    #header {
      position: fixed;
      height: 80px; } }
  #header .container {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-left: 0;
    padding-right: 80px;
    max-width: none; }
    @media (max-width: 1365px) {
      #header .container {
        padding-right: 5.5%; } }
    @media (max-width: 1024px) {
      #header .container {
        padding-right: 4.5%; } }
  #header .logo {
    height: 120px;
    width: 120px;
    aspect-ratio: 1/1;
    transition: .5s;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #FFF;
    border-radius: 0 0 20px 0; }
    @media (max-width: 1024px) {
      #header .logo {
        height: 80px;
        border-radius: 0 0 10px 0; } }
    #header .logo a {
      display: flex;
      justify-content: center;
      align-items: center;
      background-color: #FFF;
      border-radius: 0 0 20px 0;
      width: 100%;
      height: 100%; }
      @media (max-width: 1024px) {
        #header .logo a {
          border-radius: 0 0 10px 0; } }
    #header .logo img {
      width: 92%;
      height: auto;
      display: block; }
      @media (max-width: 1024px) {
        #header .logo img {
          width: 80%; } }
  #header #top-nav {
    display: flex;
    flex-flow: column;
    align-items: flex-end;
    z-index: 10; }
    @media (max-width: 1024px) {
      #header #top-nav {
        transition: visibility .75s ease, transform .5s ease-out;
        visibility: hidden;
        transform: translateX(100%);
        position: fixed;
        height: 100vh;
        width: 100%;
        top: 0;
        left: 0;
        background-color: #FFF;
        display: flex;
        flex-flow: column-reverse;
        justify-content: center;
        align-items: center;
        margin-top: 0;
        z-index: 1; } }
    #header #top-nav ul.lang-nav {
      display: flex;
      justify-content: flex-end;
      margin-bottom: 20px; }
      #header #top-nav ul.lang-nav li {
        font-family: "Zen Old Mincho", serif; }
      #header #top-nav ul.lang-nav > li:not(:last-child):after {
        content: "|";
        margin: 0 10px; }
      #header #top-nav ul.lang-nav li, #header #top-nav ul.lang-nav li a {
        color: #000000;
        transition: .5s; }
      #header #top-nav ul.lang-nav li a:hover, #header #top-nav ul.lang-nav li.current-lang a {
        color: #CB422A !important; }
    #header #top-nav ul#g-nav {
      display: flex;
      justify-content: flex-end; }
      @media (max-width: 1024px) {
        #header #top-nav ul#g-nav {
          justify-content: center;
          align-items: center;
          flex-flow: column;
          width: 100%;
          padding: 0 60px 80px; } }
      #header #top-nav ul#g-nav li {
        margin-left: 1.75em;
        font-family: "EB Garamond", serif;
        font-size: 1.125em; }
        @media (max-width: 1024px) {
          #header #top-nav ul#g-nav li {
            margin: 1rem 0; } }
        #header #top-nav ul#g-nav li a {
          text-decoration: none;
          color: #000000;
          transition: .5s; }
          @media (max-width: 1024px) {
            #header #top-nav ul#g-nav li a {
              color: #000000 !important; } }
        #header #top-nav ul#g-nav li a:hover {
          color: #CB422A; }

.top #header #top-nav ul li a, .top #header #top-nav ul#g-nav li a, .top #header #top-nav ul li, .top #header #top-nav ul li:after {
  color: #FFF; }

.top #header.active, #header.active {
  background-color: #FFF; }
  .top #header.active #top-nav ul li a, .top #header.active #top-nav ul#g-nav li a, .top #header.active #top-nav ul li, .top #header.active #top-nav ul li:after, #header.active #top-nav ul li a, #header.active #top-nav ul#g-nav li a, #header.active #top-nav ul li, #header.active #top-nav ul li:after {
    color: #000000; }

.loaded #header {
  opacity: 1;
  z-index: 2; }
  @media (max-width: 767px) {
    .loaded #header {
      z-index: 1000; } }

@media (min-width: 1025px) {
  .openbtn {
    display: none; } }
@media (max-width: 1024px) {
  .openbtn {
    position: fixed;
    z-index: 9999;
    top: 20px;
    right: 3%;
    cursor: pointer;
    width: 40px;
    height: 40px;
    background-color: #FFF;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: column;
    padding: 0; } }
.openbtn span {
  display: inline-block;
  transition: all .4s;
  height: 1px;
  background-color: #000000;
  width: 70%;
  margin: 2px 0;
  transform-origin: center;
  transition: .3s ease-out; }

.openbtn.active span:nth-of-type(1) {
  transform: translate(0px, 5px) rotate(-9deg); }
.openbtn.active span:nth-of-type(2) {
  opacity: 0; }
.openbtn.active span:nth-of-type(3) {
  transform: translate(0px, -5px) rotate(9deg); }

#header .openbtn.active + #top-nav {
  visibility: visible;
  transform: translateX(0);
  opacity: 1; }

a.nolink {
  pointer-events: none;
  opacity: 0.25;
  position: relative; }

/*--------------------
 footer
---------------------*/
#btn_pagetop {
  position: fixed;
  right: 3.5%;
  bottom: 30px;
  transform: translateY(-50%);
  z-index: 100;
  width: 48px;
  height: 48px;
  opacity: 0;
  transition: bottom .5s ease-in-out;
  border-radius: 50%;
  background-color: #CB422A;
  display: flex;
  justify-content: center;
  align-items: center; }
  @media (min-width: 600px) {
    #btn_pagetop {
      bottom: 60px; } }
  @media (min-width: 1025px) {
    #btn_pagetop {
      width: 60px;
      height: 60px; } }
  #btn_pagetop.active {
    animation: fadeInUp .5s ease-in forwards; }
  #btn_pagetop svg {
    width: 15px;
    height: 15px; }
    @media (min-width: 1025px) {
      #btn_pagetop svg {
        width: 20px;
        height: 20px; } }
  #btn_pagetop #icon_pagetop {
    fill: #fff;
    transition: .5s; }

#btn_pagetop.last {
  bottom: 100px; }
  @media (min-width: 1025px) {
    #btn_pagetop.last {
      bottom: 195px; } }

#btn_pagetop:hover {
  cursor: pointer; }
  #btn_pagetop:hover #icon_pagetop {
    fill: #C8A35F; }

#footer {
  position: relative;
  z-index: 10;
  padding-top: 48px;
  padding-bottom: 48px;
  background-color: #F8F8F7; }
  #footer .container {
    padding-left: 60px;
    padding-right: 60px;
    max-width: 1366px; }
    @media (max-width: 1365px) {
      #footer .container {
        padding-left: 5.5%;
        padding-right: 5.5%; } }
    @media (max-width: 599px) {
      #footer .container {
        padding-left: 3.5%;
        padding-right: 3.5%; } }
  #footer .footer-link {
    width: 100%; }
    #footer .footer-link .fnav ul {
      display: flex;
      justify-content: flex-end;
      flex-wrap: wrap;
      gap: 10px 20px; }
      @media (max-width: 1024px) {
        #footer .footer-link .fnav ul {
          justify-content: center; } }
      #footer .footer-link .fnav ul li {
        line-height: 1;
        display: block;
        font-size: 14px;
        white-space: nowrap;
        margin-bottom: 1rem;
        font-family: "Zen Old Mincho", serif; }
        @media (max-width: 767px) {
          #footer .footer-link .fnav ul li {
            font-size: 14px; } }
        #footer .footer-link .fnav ul li a {
          transition: .5s; }
        #footer .footer-link .fnav ul li a:hover {
          color: #CB422A; }
  #footer .copyright {
    text-align: left;
    font-size: 12px;
    font-family: "EB Garamond", serif;
    margin-top: 60px; }
    @media (max-width: 767px) {
      #footer .copyright {
        font-size: 11px; } }

/*--------------------
　共通
---------------------*/
main {
  position: relative;
  z-index: 1; }
  @media (max-width: 599px) {
    main {
      overflow: hidden; } }

.tac {
  text-align: center; }

.tar {
  text-align: right; }

.tal {
  text-align: left; }

.flexWrap {
  display: flex; }

.flexWrap.rev {
  flex-flow: row-reverse; }

.more {
  display: inline-flex;
  justify-content: space-between;
  padding-bottom: 10px;
  position: relative;
  align-items: center;
  min-width: 200px;
  font-family: "EB Garamond", serif;
  color: #C8A35F;
  font-size: 1.2em; }
  .more img, .more .arw {
    margin-left: 10px;
    width: 16px;
    transition: .5s; }
  .more::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-color: #C8A35F; }
  .more::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 1px;
    background-color: #FFFFFF80;
    transition: .5s ease-in-out; }

a.txtlink {
  text-decoration: underline; }

.more:hover::after {
  width: 100%; }

.btn-box {
  margin-top: 60px;
  display: flex;
  justify-content: center; }
  .btn-box .btn_more {
    display: flex;
    width: 100%;
    max-width: 800px;
    height: 100px;
    background-color: #CB422A;
    color: #FFF;
    font-family: "Zen Old Mincho", serif;
    align-items: center;
    justify-content: center;
    position: relative;
    border-radius: 2px;
    font-size: 2em;
    transition: background-color .5s ease; }
    @media (max-width: 767px) {
      .btn-box .btn_more {
        font-size: 1.5em;
        height: 80px; } }
    .btn-box .btn_more .arw {
      position: absolute;
      right: 40px;
      top: 50%;
      width: 20px;
      height: auto;
      transition: .5s ease;
      transform: translate(0, -50%); }
      @media (max-width: 767px) {
        .btn-box .btn_more .arw {
          width: 15px;
          right: 30px; } }
    .btn-box .btn_more:hover {
      background-color: #ad3824; }
      .btn-box .btn_more:hover .arw {
        transform: translate(10px, -50%); }
  .btn-box .btn_s {
    width: 200px;
    height: 60px;
    line-height: 60px;
    font-size: 1.125em; }

.section .container {
  width: 100%;
  margin-left: auto;
  margin-right: auto; }
  @media (min-width: 1280px) {
    .section .container {
      padding-left: 0;
      padding-right: 0; } }
.section .tit-box {
  margin-bottom: 64px; }
  @media (max-width: 1024px) {
    .section .tit-box {
      margin-bottom: 48px; } }
  @media (max-width: 599px) {
    .section .tit-box {
      margin-bottom: 36px; } }
  .section .tit-box h2 {
    display: flex;
    justify-content: space-between;
    border-bottom: 2px solid #C8A35F; }
    @media (max-width: 767px) {
      .section .tit-box h2 {
        flex-flow: column;
        padding-bottom: 16px;
        border-bottom-width: 1px; } }
    .section .tit-box h2 .en {
      font-family: "EB Garamond", serif;
      font-size: 5.75em;
      line-height: 0.7;
      font-weight: 500;
      color: #C8A35F; }
      @media (max-width: 1366px) {
        .section .tit-box h2 .en {
          font-size: 6.5vw; } }
      @media (max-width: 1024px) {
        .section .tit-box h2 .en {
          font-size: 3.5em; } }
    .section .tit-box h2 .ja {
      font-size: 2.5em;
      color: #000000;
      line-height: 1.5;
      font-family: "Zen Old Mincho", serif; }
      @media (max-width: 1024px) {
        .section .tit-box h2 .ja {
          font-size: 1.375em;
          padding-top: 10px; } }
.section h3 {
  padding-left: 0.5em;
  font-size: 2.25em;
  font-weight: 500;
  font-family: "Zen Old Mincho", serif;
  margin-bottom: 1em; }
  .section h3:before {
    content: "";
    width: 2px;
    height: 1.5em;
    background-color: #C8A35F;
    position: absolute;
    left: 0;
    top: 0; }
  .section h3::after {
    content: "";
    width: 2px;
    height: 0.35em;
    background-color: #DBDBDB;
    position: absolute;
    left: 0;
    top: 0; }
  .section h3 span {
    color: #000000; }
  @media (max-width: 1024px) {
    .section h3 {
      font-size: 1.75em; } }
.section h4 {
  font-size: 2em; }
  @media (max-width: 1024px) {
    .section h4 {
      font-size: 1.5em; } }
.section p {
  line-height: 1.75; }
.section .lead {
  font-size: 1.125em;
  font-family: "Zen Old Mincho", serif; }
  @media (max-width: 599px) {
    .section .lead {
      font-size: 1.0em; } }
.section .tac span {
  transform-origin: center center; }
.section h5 span.en {
  color: #C8A35F;
  font-size: 1.75em;
  font-family: "EB Garamond", serif; }
  @media (max-width: 599px) {
    .section h5 span.en {
      font-size: 22px; } }
.section h6 span {
  font-size: 1.125em;
  transform: scaleX(0.85);
  display: inline-block; }
  @media (max-width: 599px) {
    .section h6 span {
      font-size: 16px; } }
.section p span.ja {
  transform: scaleX(0.85);
  display: inline-block; }
.section ul.maru li {
  padding-left: 1em;
  text-indent: -1em;
  font-weight: 600;
  line-height: 1.75; }
  .section ul.maru li::before {
    content: "";
    width: 0.75em;
    height: 0.75em;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background-color: #000000;
    display: inline-block;
    vertical-align: baseline;
    margin-right: 0.25em; }

.colmns-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 45px; }
  .colmns-wrap.pc-3col .col {
    width: 100%; }
    @media (min-width: 768px) {
      .colmns-wrap.pc-3col .col {
        width: calc((100% - 90px)/3); } }

.border-box {
  border: 1px solid #C8A35F;
  border-radius: 20px;
  padding: 2em 2.5em 2.5em; }
  @media (max-width: 599px) {
    .border-box {
      padding: 1.5em 1.875em 1.875em; } }

.mt-xs {
  margin-top: 20px; }
  @media (max-width: 599px) {
    .mt-xs {
      margin-top: 10px; } }

.mt-s {
  margin-top: 30px; }
  @media (max-width: 599px) {
    .mt-s {
      margin-top: 20px; } }

.mt-m {
  margin-top: 40px; }
  @media (max-width: 599px) {
    .mt-m {
      margin-top: 30px; } }

.mt-l {
  margin-top: 60px; }
  @media (max-width: 599px) {
    .mt-l {
      margin-top: 40px; } }

.mt-xl {
  margin-top: 80px; }
  @media (max-width: 599px) {
    .mt-xl {
      margin-top: 60px; } }

@media (max-width: 599px) {
  .mt-m-sp {
    margin-top: 30px !important; } }

.js-fadeUp, .js-pinfadeUp {
  transform: translateY(60px);
  opacity: 0;
  transition: opacity 1.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s, transform 1.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

.js-fadeUp.on, .js-pinfadeUp.on {
  transform: translateY(0);
  opacity: 1; }

body::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #C8A35F;
  /* 背景カラー */
  z-index: 9999;
  /* 一番手前に */
  pointer-events: none;
  /* 他の要素にアクセス可能にするためにポインターイベントは無効に */
  opacity: 0;
  /* 初期値 : 透過状態 */
  transition: opacity .8s ease;
  visibility: hidden; }

body.fadeout::after {
  opacity: 1;
  visibility: visible; }

/* -------------------------------------------------------------
下層
------------------------------------------------------------- */
#hero {
  width: 100%;
  height: auto;
  aspect-ratio: 18/7;
  position: relative; }
  #hero .bg-img {
    width: 100%;
    height: 100%;
    position: absolute; }
    #hero .bg-img img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  #hero .container {
    display: flex;
    position: relative;
    width: 100%;
    height: 100%;
    flex-flow: column;
    align-items: flex-start;
    justify-content: center;
    padding-top: 120px;
    padding-bottom: 60px; }
    #hero .container h1 {
      display: flex;
      flex-flow: column; }
      #hero .container h1 span.en {
        font-size: 6.25vw;
        color: #C8A35F; }
      #hero .container h1 span.ja {
        font-size: 1.5em;
        font-family: "Zen Old Mincho", serif; }
  #hero .breadcrumb {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    height: 60px;
    padding-right: 80px; }
    #hero .breadcrumb ul {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 10px; }
      #hero .breadcrumb ul li {
        font-family: "EB Garamond", serif; }
        #hero .breadcrumb ul li a {
          display: inline-block; }
          #hero .breadcrumb ul li a::after {
            content: "";
            width: 100%;
            height: 1px;
            background: #000000;
            display: block;
            clip-path: inset(0 0 0 0);
            transition: .5s ease-in-out; }
        #hero .breadcrumb ul li a:hover::after {
          clip-path: inset(0 0 0 100%); }
        #hero .breadcrumb ul li::after {
          content: ">";
          margin-left: 10px; }
      #hero .breadcrumb ul > li:last-child:after {
        display: none; }

.single #hero {
  aspect-ratio: 18/3; }
.single .breadcrumb {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 60px;
  margin-top: 60px;
  background: url("/wp-content/themes/gacanet/img/bg_hero.png") no-repeat;
  background-size: 100% auto; }
  .single .breadcrumb ul {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin: auto;
    max-width: 1080px;
    width: 100%;
    gap: 10px; }
    .single .breadcrumb ul li {
      font-family: "EB Garamond", serif; }
      .single .breadcrumb ul li a {
        display: inline-block; }
        .single .breadcrumb ul li a::after {
          content: "";
          width: 100%;
          height: 1px;
          background: #000000;
          display: block;
          clip-path: inset(0 0 0 0);
          transition: .5s ease-in-out; }
      .single .breadcrumb ul li a:hover::after {
        clip-path: inset(0 0 0 100%); }
      .single .breadcrumb ul li::after {
        content: ">";
        margin-left: 10px; }
    .single .breadcrumb ul > li:last-child:after {
      display: none; }

/* -------------------------------------------------------------
animation
------------------------------------------------------------- */
.slide-in {
  overflow: hidden;
  display: inline-block; }

.slide-in_inner {
  display: inline-block; }

/*左右のアニメーション*/
.leftAnime {
  opacity: 0;
  /*事前に透過0にして消しておく*/ }

.slideAnimeLeftRight {
  animation-name: slideTextX100;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideTextX100 {
  0% {
    transform: translateX(-100%);
    /*要素を左の枠外に移動*/
    opacity: 0; }
  100% {
    transform: translateX(0);
    /*要素を元の位置に移動*/
    opacity: 1; } }
.slideAnimeRightLeft {
  animation-name: slideTextX-100;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideTextX-100 {
  from {
    transform: translateX(100%);
    /*要素を右の枠外に移動*/
    opacity: 0; }
  to {
    transform: translateX(0);
    /*要素を元の位置に移動*/
    opacity: 1; } }
.js-shuffleText {
  opacity: 0; }

.js-shuffleText.is-show {
  animation-name: fadeIn;
  animation-duration: .3s;
  animation-fill-mode: forwards; }

@keyframes maskInLeft {
  0% {
    clip-path: inset(0 100% 0 0); }
  100% {
    clip-path: inset(0 0 0 0); } }
@keyframes fadeOut {
  0% {
    opacity: 1;
    visibility: visible; }
  100% {
    opacity: 0;
    visibility: hidden; } }
@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translateY(30px);
    transform: translateY(30px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0); } }
@-moz-keyframes fadeInUp {
  0% {
    opacity: 0;
    -moz-transform: translateY(30px);
    transform: translateY(30px); }
  100% {
    opacity: 1;
    -moz-transform: translateY(0);
    transform: translateY(0); } }
@-ms-keyframes fadeInUp {
  0% {
    opacity: 0;
    -ms-transform: translateY(30px);
    transform: translateY(30px); }
  100% {
    opacity: 1;
    -ms-transform: translateY(0);
    transform: translateY(0); } }
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
@keyframes blurIn {
  0% {
    opacity: 0;
    filter: blur(10px); }
  100% {
    opacity: 1;
    filter: blur(0px); } }
@keyframes zoomOut {
  0% {
    transform: scale(1.1); }
  100% {
    transform: scale(1); } }
.fadeInUp {
  -webkit-animation: fadeInUp 0.6s ease;
  -moz-animation: fadeInUp 0.6s ease;
  -ms-animation: fadeInUp 0.6s ease;
  animation: fadeInUp 0.6s ease;
  -webkit-animation-fill-mode: both;
  -moz-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both; }

.fade, .blur-in {
  opacity: 0; }

.blur-in.active {
  animation: blurIn 1.5s ease;
  animation-fill-mode: both; }

.js-zoomout img {
  transform-origin: center;
  transform: scale(1.1); }

.js-zoomout.on img {
  animation: zoomOut 1.0s ease-in-out forwards; }

.delay1 {
  animation-delay: 0.2s;
  -moz-animation-delay: 0.2s;
  -webkit-animation-delay: 0.2s;
  -o-animation-delay: 0.2s; }

.delay2 {
  animation-delay: 0.35s;
  -moz-animation-delay: 0.35s;
  -webkit-animation-delay: 0.35s;
  -o-animation-delay: 0.35s; }
  .delay2 * {
    animation-delay: 0.35s;
    -moz-animation-delay: 0.35s;
    -webkit-animation-delay: 0.35s;
    -o-animation-delay: 0.35s; }

.delay3 {
  animation-delay: 0.5s;
  -moz-animation-delay: 0.5s;
  -webkit-animation-delay: 0.5s;
  -o-animation-delay: 0.5s; }
  .delay3 * {
    animation-delay: 0.5s;
    -moz-animation-delay: 0.5s;
    -webkit-animation-delay: 0.5s;
    -o-animation-delay: 0.5s; }

.delay4 {
  animation-delay: 0.65s;
  -moz-animation-delay: 0.65s;
  -webkit-animation-delay: 0.65s;
  -o-animation-delay: 0.65s; }

.delay5 {
  animation-delay: 0.8s;
  -moz-animation-delay: 0.8s;
  -webkit-animation-delay: 0.8s;
  -o-animation-delay: 0.8s; }

.delay6 {
  animation-delay: 0.95s;
  -moz-animation-delay: 0.95s;
  -webkit-animation-delay: 0.95s;
  -o-animation-delay: 0.95s; }

/* -------------------------------------------------------------
class
------------------------------------------------------------- */
.fit {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center; }

.mbnone {
  margin-bottom: 0 !important; }

.mb1 {
  margin-bottom: 1em !important; }

.mb2 {
  margin-bottom: 2em !important; }

.mb3 {
  margin-bottom: 3em !important; }

.mb4 {
  margin-bottom: 4em !important; }

.mb5 {
  margin-bottom: 5em !important; }

.mb6 {
  margin-bottom: 6em !important; }

.mb7 {
  margin-bottom: 7em !important; }

.mb8 {
  margin-bottom: 8em !important; }

/*--------------------
 
---------------------*/
.form-wrap form {
  margin: 0 auto;
  max-width: 1024px; }
.form-wrap dl {
  margin-bottom: 40px; }
  .form-wrap dl dt {
    width: 100%;
    font-weight: 500;
    color: #000000;
    font-weight: 600;
    padding-bottom: 10px; }
    .form-wrap dl dt .req {
      display: inline-block;
      font-size: 0.7em;
      color: #FFF;
      padding: 0 10px;
      border-radius: 8px;
      background-color: #ad2444;
      height: 16px;
      line-height: 16px;
      margin-left: 10px; }
  .form-wrap dl dt.req:after {
    content: "必須";
    color: #CB422A;
    margin-left: 1em;
    font-weight: 600; }
  .form-wrap dl dd {
    width: 100%; }
    .form-wrap dl dd input, .form-wrap dl dd textarea {
      background-color: #F8F8F7;
      padding: 16px;
      width: 100%; }
      .form-wrap dl dd input::placeholder, .form-wrap dl dd textarea::placeholder {
        color: #999; }
      @media (max-width: 767px) {
        .form-wrap dl dd input, .form-wrap dl dd textarea {
          max-width: 100%; } }
    .form-wrap dl dd textarea {
      width: 100%; }
.form-wrap .privacy-scroll-box {
  width: 100%;
  height: 200px;
  overflow-y: auto;
  border: #DBDBDB 1px solid; }
  .form-wrap .privacy-scroll-box .inner {
    padding: 30px 20px; }
    .form-wrap .privacy-scroll-box .inner .cont-box h3 {
      font-size: 1.2em; }
    .form-wrap .privacy-scroll-box .inner .cont-box h4 {
      font-size: 1em; }
    .form-wrap .privacy-scroll-box .inner .cont-box p, .form-wrap .privacy-scroll-box .inner .cont-box li {
      font-size: 0.9em; }
    .form-wrap .privacy-scroll-box .inner .cont-box + .cont-box {
      margin-top: 30px; }
.form-wrap .privacy-box {
  text-align: center;
  margin-top: 20px; }
  .form-wrap .privacy-box .mwform-checkbox-field label {
    display: flex;
    align-items: center;
    justify-content: center; }
    .form-wrap .privacy-box .mwform-checkbox-field label a.underline {
      text-decoration: underline; }
.form-wrap .btn_form {
  background: #CB422A;
  border-radius: 2px;
  height: 80px;
  width: 100%;
  max-width: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2em;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  color: #FFF;
  transition: .5s; }
  @media (max-width: 767px) {
    .form-wrap .btn_form {
      height: 60px;
      font-size: 1.75em; } }
  @media (max-width: 599px) {
    .form-wrap .btn_form {
      height: 50px;
      font-size: 1.5em; } }
  .form-wrap .btn_form:hover {
    background-color: #C8A35F; }
.form-wrap .btn_back {
  display: flex;
  align-items: center;
  max-width: 200px;
  width: 100%;
  height: 40px;
  padding: 0 36px;
  position: relative;
  background-color: #69798D;
  font-size: 1.2em;
  color: #FFF;
  position: relative;
  z-index: 3;
  transition: .5s;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  margin-top: 20px; }
  .form-wrap .btn_back:hover {
    background-color: #C8A35F; }

.wpcf7-mail-sent-ok, .wpcf7-validation-errors,
.wpcf7-acceptance-missing, .wpcf7-response-output {
  display: none; }

body.over-hidden {
  width: 100%;
  height: 100vh;
  overflow: hidden; }

body.loaded::before {
  opacity: 1; }

body .wrap {
  opacity: 0; }

body.loaded .wrap {
  animation: fadeIn 1s cubic-bezier(0.55, 0.055, 0.675, 0.19) 0.5s forwards; }

.bg-top-wrap {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1; }
  .bg-top-wrap #bg_top {
    width: 100%;
    height: 100%;
    position: absolute !important; }

/*--------------------
 loading
---------------------*/
.loader-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  height: 100svh;
  z-index: 9999;
  background-color: #FFFFFF;
  opacity: 0.7; }

#loader.js-blackOut {
  animation: loadingOut 1.5s cubic-bezier(0.55, 0.055, 0.675, 0.19) forwards; }

@keyframes loadingOut {
  0% {
    opacity: 0.7; }
  99% {
    opacity: 1; }
  100% {
    opacity: 0;
    visibility: hidden; } }
body main {
  background-color: rgba(248, 248, 247, 0.95); }

/*--------------------
　mv
---------------------*/
#mv {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center; }
  @media (max-width: 1024px) {
    #mv {
      flex-flow: column; } }
  #mv .kv-img {
    width: 100%;
    height: 100vh;
    overflow: hidden; }
    #mv .kv-img::after {
      content: "";
      width: 100%;
      height: 100%;
      position: absolute;
      left: 0;
      top: 0;
      background-color: #000000;
      opacity: 0.5; }
    #mv .kv-img video {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translateX(-50%) translateY(-50%);
      min-width: 100%;
      min-height: 100%; }
  #mv .container {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    height: 100svh;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    max-width: none; }
    @media (max-width: 1024px) {
      #mv .container {
        padding-bottom: 4vw;
        padding-top: 4vw; } }
    @media (max-width: 599px) {
      #mv .container {
        padding-left: 5.5%;
        padding-right: 5.5%;
        padding-bottom: 40px; } }
    #mv .container .mv-txt {
      transform-origin: top center;
      padding-bottom: 4em;
      display: flex;
      flex-flow: column;
      align-items: stretch; }
      @media (max-width: 1024px) {
        #mv .container .mv-txt {
          padding-bottom: 0; } }
      #mv .container .mv-txt h1 {
        text-align: center;
        color: #C8A35F; }
        #mv .container .mv-txt h1 > span {
          display: block;
          line-height: 1; }
        #mv .container .mv-txt h1 .ja {
          font-size: 4.72vw;
          letter-spacing: 0.1em;
          overflow: hidden;
          display: flex;
          justify-content: center;
          font-family: "Zen Old Mincho", serif;
          font-weight: 500; }
          @media (max-width: 1024px) {
            #mv .container .mv-txt h1 .ja {
              font-size: 7vw; } }
          @media (max-width: 599px) {
            #mv .container .mv-txt h1 .ja {
              font-size: 9vw; } }
          #mv .container .mv-txt h1 .ja span {
            transform: translateY(110%);
            /*デフォルトで下に隠す*/
            transition: 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
            display: block;
            /*ブロック要素に*/ }
        #mv .container .mv-txt h1 .en {
          font-size: 2.22vw;
          opacity: 0;
          transform: translateY(110%);
          transition: 0.75s;
          transition-delay: 1.0s;
          color: #FFF;
          margin-top: 30px;
          font-weight: 400;
          letter-spacing: 0.05em; }
          @media (max-width: 1024px) {
            #mv .container .mv-txt h1 .en {
              font-size: 3vw; } }
          @media (max-width: 599px) {
            #mv .container .mv-txt h1 .en {
              font-size: 4vw; } }
    #mv .container .apper h1 .ja span {
      transform: translateY(0%);
      opacity: 1; }
    #mv .container .apper h1 .en {
      transform: translateY(0%);
      opacity: 1; }
  #mv .scroll-txt {
    position: absolute;
    right: 5.5%;
    bottom: 48px;
    display: flex;
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
    opacity: 0;
    transition: 1s ease; }
    #mv .scroll-txt span.txt {
      display: block;
      margin-bottom: 5px;
      writing-mode: vertical-lr;
      font-family: "EB Garamond", serif;
      text-transform: uppercase;
      font-size: 14px;
      color: #FFF; }
    #mv .scroll-txt span.line {
      width: 1px;
      height: 72px;
      position: relative;
      background: #DBDBDB;
      opacity: 0.6;
      overflow: hidden; }
      #mv .scroll-txt span.line::after {
        content: "";
        position: absolute;
        width: 1px;
        height: 24px;
        background: #C8A35F;
        display: block;
        animation: pathmove 2s ease-in-out infinite; }

@keyframes pathmove {
  0% {
    transform: scaleY(0);
    top: -24px;
    opacity: 1; }
  50% {
    transform: scaleY(1);
    opacity: 1; }
  100% {
    top: 100%;
    opacity: 1; } }
.loaded #mv .mv-h1 span {
  opacity: 1; }
.loaded #mv .scroll-txt {
  opacity: 1; }

/*--------------------
　about
---------------------*/
#about {
  background: url(../img/bg_top_about.png) right top no-repeat;
  background-size: auto 100%;
  padding-bottom: 100px; }
  #about::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: linear-gradient(to right, #F8F8F7 30%, rgba(255, 255, 255, 0.2) 100%); }
  #about .container {
    position: relative; }
  #about .about-cont-box {
    display: flex;
    gap: 60px; }
    @media (max-width: 767px) {
      #about .about-cont-box {
        gap: 40px; } }
    @media (max-width: 599px) {
      #about .about-cont-box {
        gap: 24px; } }
    #about .about-cont-box h4 {
      color: #C8A35F;
      font-family: "EB Garamond", serif;
      writing-mode: vertical-lr;
      text-indent: 0.15em;
      font-weight: 600; }
    #about .about-cont-box ul.inline-num-list {
      counter-reset: number 0;
      display: flex;
      gap: 10px;
      flex-wrap: wrap; }
      #about .about-cont-box ul.inline-num-list li {
        background-color: #FFF;
        border-radius: 8px;
        padding: 10px; }
        @media (max-width: 599px) {
          #about .about-cont-box ul.inline-num-list li {
            width: 100%; } }
        #about .about-cont-box ul.inline-num-list li::before {
          counter-increment: number 1;
          content: counter(number) ".";
          font-size: 1.2em;
          color: #C8A35F; }
  #about .about-cont-box + .about-cont-box {
    margin-top: 40px; }
  #about .message-box {
    margin-top: 60px; }
    #about .message-box .name {
      margin-top: 1em;
      font-size: 1.125em; }
      @media (min-width: 1025px) {
        #about .message-box .name {
          text-align: right; } }

/*--------------------
　service
---------------------*/
.service-index-wrap .service-index-box .img-box {
  width: 100%;
  height: auto;
  aspect-ratio: 33/26;
  overflow: hidden; }
  .service-index-wrap .service-index-box .img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center; }
.service-index-wrap .service-index-box .txt-box {
  padding-top: 20px; }
  .service-index-wrap .service-index-box .txt-box h4 {
    display: flex;
    align-items: center;
    font-size: 1.5em;
    margin-bottom: 16px; }
    .service-index-wrap .service-index-box .txt-box h4::before {
      content: "";
      width: 20px;
      height: 2px;
      background-color: #C8A35F;
      margin-right: 10px; }
  .service-index-wrap .service-index-box .txt-box .more {
    margin: 1em 0 0 auto;
    width: 200px;
    display: flex; }

/*--------------------
　members
---------------------*/
.member-index-wrap .member-index-box {
  background-color: #FFF;
  padding: 48px; }
  @media (max-width: 1024px) {
    .member-index-wrap .member-index-box {
      padding: 40px; } }
  @media (max-width: 599px) {
    .member-index-wrap .member-index-box {
      padding: 24px; } }
  .member-index-wrap .member-index-box .inner {
    display: flex;
    flex-flow: wrap;
    align-items: flex-start;
    gap: 40px; }
    .member-index-wrap .member-index-box .inner .img-box {
      width: 25%;
      height: auto;
      aspect-ratio: 140/159; }
      @media (max-width: 767px) {
        .member-index-wrap .member-index-box .inner .img-box {
          width: 100%;
          max-width: 280px;
          margin: 0 auto; } }
      .member-index-wrap .member-index-box .inner .img-box img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
    .member-index-wrap .member-index-box .inner .txt-box {
      width: calc(75% - 40px); }
      @media (max-width: 767px) {
        .member-index-wrap .member-index-box .inner .txt-box {
          width: 100%;
          margin-top: 40px; } }
      .member-index-wrap .member-index-box .inner .txt-box h4 {
        font-family: "Zen Old Mincho", serif;
        line-height: 1.2; }
        .member-index-wrap .member-index-box .inner .txt-box h4 small {
          display: block;
          font-size: 0.625em; }
        .member-index-wrap .member-index-box .inner .txt-box h4 span {
          font-size: 0.875em; }
      .member-index-wrap .member-index-box .inner .txt-box .prof-list {
        margin-top: 40px; }
        .member-index-wrap .member-index-box .inner .txt-box .prof-list dl {
          display: flex;
          gap: 20px; }
          @media (max-width: 599px) {
            .member-index-wrap .member-index-box .inner .txt-box .prof-list dl {
              gap: 16px; } }
          .member-index-wrap .member-index-box .inner .txt-box .prof-list dl dt {
            width: 6em; }
            @media (max-width: 599px) {
              .member-index-wrap .member-index-box .inner .txt-box .prof-list dl dt {
                width: 5em; } }
          .member-index-wrap .member-index-box .inner .txt-box .prof-list dl dd {
            width: calc(100% - 6em - 20px); }
        .member-index-wrap .member-index-box .inner .txt-box .prof-list dl + dl {
          margin-top: 1em; }
.member-index-wrap .member-index-box + .member-index-box {
  margin-top: 40px; }

/*--------------------
　topics
---------------------*/
.topics-box .img-box {
  width: 100%;
  height: auto;
  aspect-ratio: 33/26;
  border-radius: 16px;
  overflow: hidden; }
  .topics-box .img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
.topics-box .txt-box {
  margin-top: 20px; }
  .topics-box .txt-box .spec {
    display: flex;
    gap: 20px;
    font-size: 0.85em;
    padding-bottom: 10px; }
    .topics-box .txt-box .spec .cat-icon::before {
      content: "|";
      margin-right: 20px; }
  .topics-box .txt-box h5 {
    font-weight: 600;
    font-size: 1.2em; }
  .topics-box .txt-box p {
    margin-top: 1em;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; }
  .topics-box .txt-box .more {
    margin: 1em 0 0 auto;
    width: 200px;
    display: flex; }

.swiper-contoroler {
  margin-top: 20px;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-end; }
  .swiper-contoroler .arw-box {
    display: flex;
    gap: 10px; }
    .swiper-contoroler .arw-box .swiper-button-next, .swiper-contoroler .arw-box .swiper-button-prev {
      color: #C8A35F; }
    .swiper-contoroler .arw-box .swiper-button-next.swiper-button-disabled, .swiper-contoroler .arw-box .swiper-button-prev.swiper-button-disabled {
      color: #000000;
      opacity: 0.3; }
    .swiper-contoroler .arw-box .swiper-button-next.swiper-button-disabled, .swiper-contoroler .arw-box .swiper-button-prev.swiper-button-disabled, .swiper-contoroler .arw-box .swiper-button-prev, .swiper-contoroler .arw-box .swiper-rtl .swiper-button-next {
      position: relative;
      top: auto;
      left: auto;
      margin: 0; }
    .swiper-contoroler .arw-box .swiper-button-next, .swiper-contoroler .arw-box .swiper-rtl .swiper-button-prev {
      position: relative;
      top: auto;
      right: auto;
      margin: 0; }
  .swiper-contoroler .swiper-pagination {
    position: relative;
    text-align: right; }
    .swiper-contoroler .swiper-pagination .swiper-pagination-bullet {
      background: #DBDBDB;
      opacity: 0.8; }
    .swiper-contoroler .swiper-pagination .swiper-pagination-bullet-active {
      background: #C8A35F; }

/*--------------------
　news
---------------------*/
.newsList-wrap {
  margin: 0 auto; }
  .newsList-wrap .newsList li {
    padding-bottom: 1.5em; }
    .newsList-wrap .newsList li a {
      display: flex;
      gap: 40px; }
      @media (max-width: 1024px) {
        .newsList-wrap .newsList li a {
          display: block; } }
      .newsList-wrap .newsList li a .time {
        font-size: 14px;
        color: #C8A35F;
        display: block; }
        @media (max-width: 1024px) {
          .newsList-wrap .newsList li a .time {
            margin-bottom: 1rem; } }
      .newsList-wrap .newsList li a .txt {
        font-size: 1rem;
        transition: .5s;
        font-weight: 300; }
      .newsList-wrap .newsList li a:hover .txt {
        color: #C8A35F; }

/*--------------------
　partners
---------------------*/
.partners-cont-box {
  display: flex;
  flex-wrap: wrap;
  gap: 20px; }
  .partners-cont-box h4 {
    width: 25%;
    font-family: "Zen Old Mincho", serif;
    color: #C8A35F;
    font-weight: 600; }
    @media (max-width: 599px) {
      .partners-cont-box h4 {
        width: 100%; } }
  .partners-cont-box p {
    width: calc(75% - 20px); }
    @media (max-width: 599px) {
      .partners-cont-box p {
        width: 100%; } }

/*--------------------
　company
---------------------*/
#company {
  padding-bottom: 100px; }
  @media (max-width: 599px) {
    #company {
      padding-bottom: 60px; } }
  #company .container > .img-box {
    margin-bottom: 40px;
    aspect-ratio: 16/7; }
    @media (max-width: 767px) {
      #company .container > .img-box {
        aspect-ratio: 5/3; } }
    #company .container > .img-box img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  #company .corp-cont-box {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 45px; }
    @media (max-width: 1024px) {
      #company .corp-cont-box {
        gap: 30px; } }
    #company .corp-cont-box .img-box {
      width: 28%; }
      @media (max-width: 768px) {
        #company .corp-cont-box .img-box {
          width: 100%;
          max-width: 290px; } }
      #company .corp-cont-box .img-box img {
        width: 100%; }
    #company .corp-cont-box .txt-box {
      width: auto;
      padding-top: 1em; }
      @media (max-width: 768px) {
        #company .corp-cont-box .txt-box {
          width: 100%; } }
      #company .corp-cont-box .txt-box table {
        border: none; }
        #company .corp-cont-box .txt-box table th, #company .corp-cont-box .txt-box table td {
          padding: 10px 0;
          border: none; }
          #company .corp-cont-box .txt-box table th a, #company .corp-cont-box .txt-box table td a {
            text-decoration: underline; }
        #company .corp-cont-box .txt-box table tr th, #company .corp-cont-box .txt-box table tr > td:nth-of-type(1) {
          padding-right: 2em;
          font-weight: 600; }

body main {
  background-color: rgba(248, 248, 247, 0.95); }

/*--------------------
　service
---------------------*/
#service main .section, #service-en main .section, #service-zh main .section {
  padding-top: 0;
  padding-bottom: 120px; }
  @media (max-width: 767px) {
    #service main .section, #service-en main .section, #service-zh main .section {
      padding-bottom: 80px; } }
  @media (max-width: 599px) {
    #service main .section, #service-en main .section, #service-zh main .section {
      padding-bottom: 60px; } }
  #service main .section .head-img-box, #service-en main .section .head-img-box, #service-zh main .section .head-img-box {
    width: 100%;
    height: auto;
    aspect-ratio: 3/1;
    overflow: hidden; }
    @media (max-width: 767px) {
      #service main .section .head-img-box, #service-en main .section .head-img-box, #service-zh main .section .head-img-box {
        aspect-ratio: 3/2; } }
    #service main .section .head-img-box figure, #service-en main .section .head-img-box figure, #service-zh main .section .head-img-box figure {
      display: flex;
      width: 100%;
      height: 100%; }
      #service main .section .head-img-box figure img, #service-en main .section .head-img-box figure img, #service-zh main .section .head-img-box figure img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center; }
  #service main .section .head-img-box + .container, #service-en main .section .head-img-box + .container, #service-zh main .section .head-img-box + .container {
    padding-top: 100px; }
    @media (max-width: 767px) {
      #service main .section .head-img-box + .container, #service-en main .section .head-img-box + .container, #service-zh main .section .head-img-box + .container {
        padding-top: 80px; } }
    @media (max-width: 599px) {
      #service main .section .head-img-box + .container, #service-en main .section .head-img-box + .container, #service-zh main .section .head-img-box + .container {
        padding-top: 60px; } }
    #service main .section .head-img-box + .container .service-tit-box h2, #service-en main .section .head-img-box + .container .service-tit-box h2, #service-zh main .section .head-img-box + .container .service-tit-box h2 {
      display: flex;
      flex-flow: column;
      justify-content: flex-start;
      align-items: center; }
      #service main .section .head-img-box + .container .service-tit-box h2 .num, #service-en main .section .head-img-box + .container .service-tit-box h2 .num, #service-zh main .section .head-img-box + .container .service-tit-box h2 .num {
        color: #C8A35F;
        font-size: 4.5em; }
      #service main .section .head-img-box + .container .service-tit-box h2 .ja, #service-en main .section .head-img-box + .container .service-tit-box h2 .ja, #service-zh main .section .head-img-box + .container .service-tit-box h2 .ja {
        font-size: 3em;
        font-family: "Zen Old Mincho", serif; }
  #service main .section .service-img-wrap .service-img-box, #service-en main .section .service-img-wrap .service-img-box, #service-zh main .section .service-img-wrap .service-img-box {
    height: auto;
    aspect-ratio: 4/3; }
    #service main .section .service-img-wrap .service-img-box img, #service-en main .section .service-img-wrap .service-img-box img, #service-zh main .section .service-img-wrap .service-img-box img {
      width: 100%;
      height: 100%;
      object-fit: cover; }

/*--------------------
　汎用ページ
---------------------*/
.section .container .cont-box + .cont-box {
  margin-top: 60px; }
.section .container .cont-box h4 {
  font-size: 1.75em;
  font-family: "Zen Old Mincho", serif;
  margin-bottom: 1em; }
  .section .container .cont-box h4::before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 1em;
    height: 2px;
    background: #C8A35F;
    margin: auto 8px 0.25em 0; }
.section .container .cont-box ul.maru {
  margin-top: 1em; }

#privacy main, #contact main {
  background-color: #FFF; }

/*--------------------
　works
---------------------*/
.topics-list {
  display: flex;
  gap: 45px;
  flex-wrap: wrap; }
  @media (max-width: 599px) {
    .topics-list {
      gap: 24px; } }
  .topics-list .topics-box {
    width: calc((100% - 90px)/3); }
    @media (max-width: 1024px) {
      .topics-list .topics-box {
        width: calc((100% - 45px)/2); } }
    @media (max-width: 599px) {
      .topics-list .topics-box {
        width: 100%; } }

.category-nav {
  display: flex;
  margin-bottom: 48px;
  gap: 20px; }
  .category-nav li a {
    display: block;
    background: #DBDBDB;
    padding: 10px;
    border-radius: 8px;
    transition: all .5s ease; }
  .category-nav li .current, .category-nav li a:hover {
    background: #C8A35F;
    color: #FFF; }

.navigation.pagination {
  margin-top: 60px; }
  .navigation.pagination ul.page-numbers {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px; }
    .navigation.pagination ul.page-numbers li .page-numbers {
      background-color: #DBDBDB;
      width: 30px;
      height: 30px;
      border-radius: 50%;
      display: flex;
      justify-content: center;
      align-items: center;
      text-decoration: none;
      transition: all .5s ease; }
    .navigation.pagination ul.page-numbers li .page-numbers.current, .navigation.pagination ul.page-numbers li .page-numbers:hover {
      background-color: #C8A35F;
      color: #FFF; }

/*--------------------
　single
---------------------*/
.single main {
  background-color: #F8F8F7; }
.single .main-section {
  margin-top: -200px; }
  .single .main-section .contens-box {
    background-color: #FFF;
    border-radius: 30px;
    padding: 60px 40px; }
    .single .main-section .contens-box .single-tit {
      margin-bottom: 40px;
      padding-bottom: 30px;
      border-bottom: 2px solid #C8A35F; }
      .single .main-section .contens-box .single-tit h1 .info {
        display: flex;
        gap: 10px;
        font-size: 0.85em; }
        .single .main-section .contens-box .single-tit h1 .info .cat-icon::before {
          content: "|";
          margin-right: 20px; }
      .single .main-section .contens-box .single-tit h1 .ja {
        font-size: 2em;
        font-family: "Zen Old Mincho", serif;
        margin-top: 20px; }
.single .related-post-wrap {
  padding-bottom: 80px; }
