@charset "UTF-8";
/*======================================
text
/*======================================*/
.desc p {
  text-align: justify;
}
.desc p:not(:last-of-type) {
  margin-bottom: .5em;
}
.hidden {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.block-center {
  text-align: center;
}
.block-center p {
  text-align: center;
}
.num {
  font-size: 130%;
  vertical-align: -0.05em;
}
/*======================================
common
/*======================================*/
.title-wrap h1 {
  text-align: center;
}
.about .title-wrap h1, .service .title-wrap h1 {
  text-align: left;
}
.title-wrap h1 .type {
  font-size: 140%;
  letter-spacing: 3px;
}
.title-wrap h2, .title-wrap h3 {
  text-align: left;
}
.title-wrap h2 .EN, .title-wrap h2 .EN, .title-wrap h3 .EN {
  display: block;
  font-size: 100%;
  letter-spacing: 3px;
}
.title-wrap h1 .main, .title-wrap h2 .main, .title-wrap h3 .main {
  display: block;
  font-size: 150%;
  font-weight: 600;
  letter-spacing: 6px;
  margin-top: .4em;
}
/*======================================
aside
/*======================================*/
aside.CMN {
  font-size: 13px;
  letter-spacing: 1px;
}
aside li a {
  display: inline;
  text-decoration: underline;
}
.grecaptcha-badge {
  visibility: hidden;
}
/*======================================
under-line
/*======================================*/
.under {
  display: inline;
  text-decoration: none;
  background: linear-gradient(transparent 60%, rgb(var(--orange-rgb) / .7) 60%);
  background-repeat: no-repeat;
}
/* =========================
  type
========================= */
.typewriter {
  display: flow-root;
  min-height: 1.2em;
  line-height: 1.2;
}
.js-type-common {
  opacity: 0;
  transition: opacity 1.5s ease-out .5s forwards;
  display: inline-block;
  min-height: 1.2em;
}
.js-type-common.is-typing {
  opacity: 1;
  animation: none;
}
.js-type-common.is-typingEND {
  opacity: 1;
}
/* caret  */
.js-type-common.is-caret::after {
  content: "";
  display: inline-block;
  width: 2px;
  height: 1em;
  margin-left: .1em;
  vertical-align: -0.15em;
  background: currentColor;
  opacity: .3;
}
.js-type-common.is-typing::after {
  animation: none;
}
.js-type-common.is-typingEND::after {
  animation: caretBlink .9s steps(1) infinite;
}
@keyframes caretBlink {
  0% {
    opacity: 0;
  }
  50% {
    opacity: .7;
  }
}
/*======================================
#page-404
/*======================================*/
#page-404 {
  text-align: center;
  padding: 7em 0
}
#page-404 p {
  font-size: 90%;
}
/*======================================
waiting
/*======================================*/
#waiting {
  text-align: center;
  padding: 8em 0 8em;
  margin: 0 auto !important;
}
/*======================================
table
/*======================================*/
table {
  table-layout: fixed;
  font-size: 100%;
  width: 100%;
  max-width: 850px;
  border-collapse: collapse;
  margin: 0 auto;
  letter-spacing: 1px;
}
table th, table td {
  text-align: left;
  padding: 1em .5em;
  line-height: 1.4em;
  vertical-align: middle;
}
table tr:first-of-type th, table tr:first-of-type td {
  padding-top: 0;
}
table th {
  font-weight: bold;
  border-bottom: 3px solid rgb(var(--orange-rgb) / .5);
}
table td {
  width: auto;
  padding-right: 0;
  border-bottom: 3px solid rgb(var(--gray-rgb) / .5);
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
table.th-50 th {
  width: 50%;
}
table th.txt-left, table td.txt-left {
  text-align: left;
}
table th.txt-right, table td.txt-right {
  text-align: right;
}
table th.txt-center, table td.txt-center {
  text-align: center;
}
table td p, table td li, table td .list-style ul li {
  line-height: 1.4em;
}
table td p:not(:last-of-type), table td li:not(:last-of-type), table td .list-style ul li:not(:last-of-type) {
  margin-bottom: .3em;
}
table td p + .list-style, table td p + ul {
  margin-top: 1em;
}
table td .list-style ul {
  display: block;
}
table td a {
  display: inline;
  color: rgb(var(--orange-rgb) / 1);
  letter-spacing: 1px;
}
table.w-20 th {
  width: 20%;
}
table.w-30 th {
  width: 30%;
}
table.w-40 th {
  width: 40%;
}
table.w-50 th {
  width: 50%;
}
table.w-free th {
  width: auto;
}
@media screen and (min-width:768px) {
  table.w-20 th, table.w-30 th, table.w-40 th {
    width: 25%;
  }
  table.w-50 th {
    width: 50%;
  }
  table.w-free th {
    width: auto;
  }
  table th, table td {
    padding: 1.5em;
  }
  table th {
    text-align: center;
  }
} /*END query*/ /*======================================
dpth
/*======================================*/
.sec-lg {
  min-height: 80vh;
}
.sec-md {
  min-height: 60vh;
}
.sec-sm {
  min-height: 40vh;
}
/* --- container --- */
.dpth-CMN {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
/* --- background layer  --- */
.dpth-CMN > .dpth-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  will-change: transform;
  transform: translate3d(0, 0, 0);
}
/* --- shift：のりしろ（PAD） --- */ :root {
  --dpth-shift-pad: 120px;
}
@media (max-width: 768px) {
  :root {
    --dpth-shift-pad: 50px;
  }
}
/* shift は上下に余白を作って白露出を防ぐ */
.dpth-CMN.dpth-shift > .dpth-bg {
  top: calc(var(--dpth-shift-pad) * -1);
  bottom: calc(var(--dpth-shift-pad) * -1);
  left: 0;
  right: 0;
  transition: none !important; /* transform競合防止 */
}
/* --- scale：ズーム用の余白（好みで調整） --- */
.dpth-CMN.dpth-scale > .dpth-bg {
  inset: -25%;
}
/* --- contents --- */
.dpth-contents {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* --- blur layer --- */
.dpth-CMN > .bg-blur {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
/* --- color overlay (画像を消さないように ::before で重ねる) --- */
.dpth-bg-navy::before, .dpth-bg-white::before, .dpth-bg-orange::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
/* navy */
.dpth-bg-navy::before {
  background: rgb(var(--navy-rgb));
  mix-blend-mode: multiply;
  opacity: .4;
}
/* white */
.dpth-bg-white::before {
  background: rgb(var(--white-rgb));
  mix-blend-mode: screen;
  opacity: .45;
}
/* orange */
.dpth-bg-orange::before {
  background: rgb(var(--orange-rgb));
  mix-blend-mode: overlay;
  opacity: .45; /* 0.35〜0.55で調整 */
}
/* --- card (重複を統一) --- */
.dpth-contents .card {
  background: rgb(var(--white-rgb) / .7);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  isolation: isolate;
  border-radius: 10px;
  padding: 1em;
}
/* --- spacer --- */
.bg-spacer {
  position: relative;
  width: 100%;
  aspect-ratio: 7 / 3;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .bg-spacer {
    aspect-ratio: 7 / 2;
  }
} /*END query*/
/*======================================
background image classes
/*======================================*/
.dpth-bg-office {
  background-image: url(../../img/CMN/bg-office.jpg);
}
/*//////////////////////*/
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.video-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin: 0 auto;
}
.center-img {
  overflow: hidden;
  position: relative;
}
.center-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (min-width:768px) {
  /*
  .center-img img {
    height: auto;
    object-fit: contain;
  }
    */
} /*END query*/
/*======================================
submitBtn
/*======================================*/
@keyframes reflection {
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  85% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  86% {
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
.reflection {
  position: relative;
  overflow: hidden;
}
.reflection:after {
  position: absolute;
  content: "";
  height: 100%;
  width: 30px;
  top: -180px;
  left: 0;
  background-color: rgb(var(--white-rgb) / .5);
  opacity: 0;
  transform: rotate(45deg);
  animation: reflection 3s ease-in-out infinite;
}
/*======================================
.list-style
/*======================================*/
.list-style {
  text-align: center;
}
.list-style.list-style-left {
  text-align: left;
}
.list-style ul {
  display: inline-block;
}
.list-style ul li {
  position: relative;
  text-align: justify;
  line-height: 1.6em;
  margin-left: 1em;
}
.list-style ul li:not(:last-of-type) {
  margin-bottom: 0.5em;
}
.list-style ul li:before {
  display: block;
  position: absolute;
  margin-left: -1em;
}
.list-style.list-style01 ul li:before {
  content: "※";
}
.list-style.list-style02 ul li:before {
  content: "◎";
}
.list-style.list-style03 ul li, .list-style.list-style05 ul li {
  position: relative;
  text-align: left;
  padding-left: 2em;
  line-height: 1.5em;
  margin-left: 0;
}
.list-style.list-style03 ul li:not(:last-of-type), .list-style.list-style05 ul li:not(:last-of-type) {
  margin-bottom: 1em;
}
.list-style.list-style03 ul li:before, .list-style.list-style03 ul li:after, .list-style.list-style05 ul li:before, .list-style.list-style05 ul li:after {
  position: absolute;
  content: "";
  font-size: .9em;
  line-height: .9em;
}
.list-style.list-style03 ul li:before, .list-style.list-style05 ul li:before {
  margin: 0;
  background: rgb(var(--orange-rgb) / .15);
  border: none;
  width: 1.8em;
  height: 1.8em;
  top: -0.1em;
  left: 0;
}
.list-style.list-style03 ul li:after, .list-style.list-style05 ul li:after {
  border-left: 2px solid rgb(var(--orange-rgb) / 1);
  border-bottom: 2px solid rgb(var(--orange-rgb) / 1);
  width: 0.9em;
  height: 0.45em;
  transform: rotate(-45deg);
  left: 0.5em;
  top: 0.45em;
}
.list-style.list-style04 ul li {
  text-align: left;
  margin-bottom: 1em;
  margin: 0 0 0 2em;
}
.list-style.list-style04 ul li:before {
  position: absolute;
  content: "";
  margin: 0;
  background: url(../img/check.png) no-repeat center;
  background-size: 100%;
  width: 1.7em;
  height: 1.7em;
  left: -2em;
  top: 0;
}
.list-style.list-style04 ul li:not(:last-of-type) {
  margin-bottom: 1em;
}
.check-list {
  display: inline-block;
}
.check-list li {
  position: relative;
  text-align: left;
  padding-left: 2em;
  line-height: 1.5em;
}
.check-list li:before, .check-list li:after {
  position: absolute;
  content: "";
  font-size: 1em;
  line-height: 1em;
}
.check-list li:before {
  background: rgb(var(--white-rgb));
  border: 1px solid rgb(var(--orange-rgb) / .3);
  width: 1.2em;
  height: 1.2em;
  width: 1.5em;
  height: 1.5em;
  font-size: 1em;
  line-height: 1em;
  top: -0.1em;
  left: 0;
}
.check-list li:after {
  border-left: 2px solid rgb(var(--orange-rgb) / 1);
  border-bottom: 2px solid rgb(var(--orange-rgb) / 1);
  width: 0.8em;
  height: 0.4em;
  transform: rotate(-45deg);
  left: 0.35em;
  top: 0.35em;
}
.check-list li:not(:last-of-type) {
  margin-bottom: 1em;
}
/*======================================
glass card
/*======================================*/
.glass-card {
  position: relative;
  display: inline-block;
  /* border: 1px solid rgba(240, 110, 0, 1); */
  border-radius: 1em;
  will-change: transform;
  backdrop-filter: blur(18px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35), 0 8px 20px rgba(0, 0, 0, 0.5);
  transition: transform 0.3s ease;
}
.glass-card > * {
  position: relative;
  z-index: 1;
}
/* ------------------------------
  panel-area
------------------------------ */
.panel-area {
  margin: 2em auto 0;
}
@media screen and (min-width: 769px) {
  .panel-area {
    margin: 3em auto 0;
  }
} /*END query*/
.panel {
  display: none;
  opacity: 0;
}
.panel.active {
  display: block;
  opacity: 1;
  animation: fadeIn .3s ease-in 0s forwards;
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}