@charset "UTF-8";
/* [ 大阪真空機器（日英中） ] products.css */
/* [ 株式会社大阪真空機器製作所 ] setting */
/* [ 株式会社大阪真空機器製作所 ] component */
body {
  overflow-x: hidden;
}

/* [ メイン ] */
@media screen and (min-width: 769px) {
  .company_profile .main-image {
    background: url("../img/company_profile/bg_company_profile.jpg") center/cover no-repeat;
  }
}
@media only screen and (max-width: 768px) {
  .company_profile .main-image {
    background: url("../img/company_profile/bg_company_profile_sp.jpg") center/cover no-repeat;
  }
}
@media screen and (min-width: 769px) {
  .company_profile:has(.detail) .main-image {
    background: url("../img/company_profile/bg_company_profile_d.jpg") center/cover no-repeat;
  }
}
@media only screen and (max-width: 768px) {
  .company_profile:has(.detail) .main-image {
    background: url("../img/company_profile/bg_company_profile_d_sp.jpg") center/cover no-repeat;
  }
}

@media screen and (min-width: 769px) {
  .support .main-image {
    background: url("../img/support/bg_support.jpg") center/cover no-repeat;
  }
}
@media only screen and (max-width: 768px) {
  .support .main-image {
    background: url("../img/support/bg_support_sp.jpg") center/cover no-repeat;
  }
}

/*==================================================*
 *  [ 共通 ]
 *==================================================*/
.aboutus-btn {
  display: flex;
  justify-content: center;
}
.aboutus-btn a {
  text-align: center;
  border-radius: 10px;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.25);
}
.aboutus-btn a img {
  width: 100%;
}
.aboutus-btn a span {
  display: block;
  position: relative;
  padding: 1.25em 0;
}
.aboutus-btn a span::before {
  content: '';
  position: absolute;
  bottom: 1em;
  left: 50%;
  width: 141px;
  height: 3px;
  background: transparent;
  transform: translateX(-50%);
}
.aboutus-btn a span::after {
  content: '';
  display: inline-block;
  width: clamp(22px, 1.46vw, 28px);
  height: auto;
  aspect-ratio: 1 / 1;
  mask-repeat: no-repeat;
  background: #6684A8;
  mask-size: contain;
  mask-image: url("../img/icon_arrow_circle.svg");
  vertical-align: top;
  margin-left: 0.25em;
}
.aboutus-btn a span b {
  color: #6684A8;
  font-size: clamp(1.8rem, 1.25vw, 2.4rem);
  font-weight: 800;
}
@media (hover: hover) {
  .aboutus-btn a:hover {
    background: #E4F4FE;
  }
  .aboutus-btn a:hover span::before {
    background: #B3D5EB;
  }
}
.aboutus-btn.btn-small a span {
  padding: 0.75em 0;
}
.aboutus-btn.btn-small a span::before {
  bottom: 0.6em;
}
@media screen and (min-width: 769px) {
  .aboutus-btn {
    gap: 3.13vw;
  }
  .aboutus-btn a {
    width: calc((100% - (3.13vw * 2)) / 3);
  }
}
@media only screen and (max-width: 768px) {
  .aboutus-btn {
    flex-direction: column;
    align-items: center;
    gap: 6.4vw;
  }
  .aboutus-btn a {
    width: 80%;
    max-width: 303px;
  }
}

.txt-note {
  color: #484848;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 769px) {
  .txt-note {
    font-size: clamp(1.2rem, 0.73vw, 1.4rem);
    line-height: 1.643;
    text-align: right;
  }
}
@media only screen and (max-width: 768px) {
  .txt-note {
    font-size: clamp(1rem, 2.67vw, 1.2rem);
    text-align: left;
  }
}

/*==================================================*
 *  [ 大阪真空について ]
 *==================================================*/
#aboutus .howto {
  display: flex;
}
#aboutus .howto .howto-txt {
  color: #3A4268;
  font-weight: 700;
}
#aboutus .howto .howto-image {
  display: flex;
}
#aboutus .howto .howto-image figure figcaption {
  color: #808080;
}
#aboutus .txt-note {
  text-align: left;
}
#aboutus .nl-txt {
  line-height: 2.0;
}
@media screen and (min-width: 769px) {
  #aboutus .howto {
    gap: min(30px, 1.56vw);
  }
  #aboutus .howto .howto-txt {
    width: calc(100% - (30% + min(30px, 1.56vw)));
    font-size: clamp(1.8rem, 1.15vw, 2.2rem);
    line-height: 2.045;
  }
  #aboutus .howto .howto-image {
    width: 30%;
    gap: min(6px, 0.31vw);
  }
  #aboutus .howto .howto-image figure {
    width: calc((100% - min(6px, 0.31vw)) / 2);
    text-align: center;
  }
  #aboutus .howto .howto-image figure img {
    width: 90%;
  }
  #aboutus .howto .howto-image figure figcaption {
    font-size: clamp(1.2rem, 0.73vw, 1.4rem);
    text-align: left;
  }
}
@media only screen and (max-width: 768px) {
  #aboutus .howto {
    flex-direction: column;
    align-items: center;
    gap: clamp(22px, 5.87vw, 30px);
  }
  #aboutus .howto .howto-txt {
    font-size: clamp(1.2rem, 5.07vw, 1.6rem);
    line-height: 1.75;
  }
  #aboutus .howto .howto-image {
    width: 77%;
    text-align: center;
    gap: min(16px, 4.27vw);
  }
  #aboutus .howto .howto-image figure {
    width: calc((100% - min(16px, 4.27vw)) / 2);
    text-align: center;
  }
  #aboutus .howto .howto-image figure img {
    width: 90%;
  }
  #aboutus .howto .howto-image figure figcaption {
    font-size: clamp(1.2rem, 0.73vw, 1.4rem);
    text-align: left;
  }
}

#advantage .adv-wrap .adv-ttl {
  position: relative;
  color: #3A4268;
  font-weight: 700;
  padding-left: 1.4em;
}
#advantage .adv-wrap .adv-ttl::before {
  content: '';
  position: absolute;
  left: 0;
  height: auto;
  aspect-ratio: 1 / 1;
  background: url("../img/icon_crown.svg") center/contain no-repeat;
}
#advantage .nl-txt {
  line-height: 2.0;
}
@media screen and (min-width: 769px) {
  #advantage .adv-wrap .adv-ttl {
    font-size: clamp(1.6rem, 1.04vw, 2rem);
    padding-left: calc(clamp(33px, 1.93vw, 37px) + 0.75em);
  }
  #advantage .adv-wrap .adv-ttl::before {
    top: 50%;
    width: clamp(33px, 1.93vw, 37px);
    transform: translateY(-50%);
  }
}
@media only screen and (max-width: 768px) {
  #advantage .adv-wrap .adv-ttl {
    font-size: clamp(1.6rem, 4.27vw, 2rem);
    padding-left: calc(clamp(22px, 6.13vw, 27px) + 0.5em);
  }
  #advantage .adv-wrap .adv-ttl::before {
    top: -2px;
    width: clamp(22px, 6.13vw, 27px);
  }
}

#message .msg-wrap > img {
  width: 100%;
  height: auto;
  aspect-ratio: 289 / 192;
}
#message .msg-wrap .msg-txt {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
#message .msg-wrap .msg-txt img {
  height: auto;
  aspect-ratio: 291 / 32;
}
#message .brief-history {
  width: 100%;
}
#message .brief-history .bh-wrap {
  width: 100%;
  border-top: 1px solid #D9D9D9;
  border-bottom: 1px solid #D9D9D9;
}
#message .brief-history .bh-wrap summary {
  display: flex;
  justify-content: flex-start;
  position: relative;
  width: 100%;
  cursor: pointer;
  box-sizing: border-box;
}
#message .brief-history .bh-wrap summary::-webkit-details-marker {
  display: none !important;
}
#message .brief-history .bh-wrap summary .bh-ttl {
  color: #3A4268;
  font-weight: 700;
}
#message .brief-history .bh-wrap summary::after {
  content: '';
  display: inline-block;
  width: 28px;
  height: auto;
  aspect-ratio: 1 / 1;
  mask-repeat: no-repeat;
  background: #3A4268;
  mask-size: contain;
  mask-image: url("../img/icon_arrow_circle.svg");
  transform: rotate(0);
  transition: transform .3s;
}
@media (hover: hover) {
  #message .brief-history .bh-wrap summary:hover {
    background: #4D6B92;
  }
  #message .brief-history .bh-wrap summary:hover .bh-ttl {
    color: #fff;
  }
  #message .brief-history .bh-wrap summary:hover::after {
    background: #fff;
  }
}
#message .brief-history .bh-wrap .nl-txt {
  opacity: 0;
  margin: 0;
  transform: translateY(-10px);
  transition: transform .5s, opacity .5s;
}
#message .brief-history .bh-wrap .nl-txt img {
  display: block;
  width: 229px;
  height: auto;
  aspect-ratio: 60 / 7;
  margin-top: 1.5em;
  margin-left: auto;
}
#message .brief-history .bh-wrap[open] summary {
  background: #EDEDED;
}
#message .brief-history .bh-wrap[open] summary::after {
  transform: rotate(90deg);
}
@media (hover: hover) {
  #message .brief-history .bh-wrap[open] summary:hover .bh-ttl {
    color: #3A4268;
  }
  #message .brief-history .bh-wrap[open] summary:hover::after {
    background: #3A4268;
  }
}
#message .brief-history .bh-wrap[open] .nl-txt {
  transform: none;
  opacity: 1;
  background: #EDEDED;
}
@media screen and (min-width: 769px) {
  #message .msg-wrap {
    display: flex;
    align-items: flex-start;
    gap: 37px;
  }
  #message .msg-wrap > img {
    max-width: 289px;
  }
  #message .msg-wrap .msg-txt {
    flex: 1;
  }
  #message .msg-wrap .msg-txt img {
    max-width: 291px;
  }
  #message .brief-history .bh-wrap summary {
    align-items: center;
    padding: 0.5em 0.5em 0.25em 0.5em;
  }
  #message .brief-history .bh-wrap summary .bh-ttl {
    font-size: clamp(2.6rem, 1.77vw, 3.4rem);
  }
  #message .brief-history .bh-wrap summary::after {
    margin-left: 0.25em;
  }
  #message .brief-history .bh-wrap .nl-txt {
    padding: 2em 3em 3em;
  }
}
@media only screen and (max-width: 768px) {
  #message .msg-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
  }
  #message .msg-wrap > img {
    max-width: 238px;
  }
  #message .msg-wrap .msg-txt img {
    max-width: 238px;
  }
  #message .brief-history .bh-wrap summary {
    align-items: flex-start;
    padding: 0.75em 0.5em 0.25em;
  }
  #message .brief-history .bh-wrap summary .bh-ttl {
    font-size: 2.4rem;
  }
  #message .brief-history .bh-wrap summary::after {
    margin-left: 0.5em;
  }
  #message .brief-history .bh-wrap .nl-txt {
    padding: 1em 1.5em 1.5em;
  }
}

/*==================================================*
 *  [ 会社概要 ]
 *==================================================*/
.profile .profile-table {
  width: 100%;
}
.profile .profile-table tr {
  border-bottom: 1px solid #D9D9D9;
}
.profile .profile-table tr th {
  width: 7.75em;
  font-weight: 600;
  text-align: left;
}
.profile .profile-table .exec-list-wrap .exec-list {
  list-style: none;
}
.profile .profile-table .exec-list-wrap .exec-list li {
  display: flex;
}
.profile .profile-table .exec-list-wrap .exec-list li .exec-name::before {
  content: "：";
  display: inline-block;
}
.profile .profile-table .aff-list-wrap .aff-list {
  list-style: none;
}
@media screen and (min-width: 769px) {
  .profile .profile-table tr th {
    font-size: clamp(1.4rem, 0.83vw, 1.6rem);
  }
  .profile .profile-table tr td {
    font-size: clamp(1.4rem, 0.83vw, 1.6rem);
    line-height: 2.125;
    padding: 1.5em 0.75em 1.25em;
  }
  .profile .profile-table .exec-list-wrap {
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
  }
  .profile .profile-table .exec-list-wrap .exec-list:first-child {
    margin-right: min(60px, 3.13vw);
  }
  .profile .profile-table .exec-list-wrap .exec-list li .exec-posi {
    width: 18em;
  }
  .profile .profile-table .aff-list-wrap {
    display: flex;
    align-items: stretch;
    gap: min(100px, 5.21vw);
  }
}
@media only screen and (max-width: 768px) {
  .profile .profile-table tr th, .profile .profile-table tr td {
    display: block;
    width: 100%;
  }
  .profile .profile-table tr th {
    font-size: clamp(1.2rem, 3.2vw, 1.4rem);
    padding-top: 1em;
  }
  .profile .profile-table tr td {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
    line-height: 1.571;
    padding: 0.5em 0 0.75em;
  }
  .profile .profile-table .exec-list-wrap .exec-list:first-child {
    margin-right: min(60px, 3.13vw);
  }
  .profile .profile-table .exec-list-wrap .exec-list li .exec-posi {
    min-width: 12em;
  }
}
.profile #definition .section-ttl span {
  position: relative;
  display: inline-block;
  font-family: "Jost", sans-serif;
  color: #CFCFCF;
}
.profile #definition .section-ttl span::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0.5em;
  height: 3px;
  background: #CFCFCF;
}
@media screen and (min-width: 769px) {
  .profile #definition .section-ttl span {
    font-size: clamp(3.2rem, 2.19vw, 4.2rem);
    padding-left: calc(min(124px, 6.46vw) + 1em);
  }
  .profile #definition .section-ttl span::before {
    width: min(124px, 6.46vw);
  }
}
@media only screen and (max-width: 768px) {
  .profile #definition .section-ttl span {
    font-size: clamp(1.8rem, 4.8vw, 2.4rem);
    letter-spacing: -0.03em;
    padding-left: calc(min(23px, 6.13vw) + 1em);
  }
  .profile #definition .section-ttl span::before {
    width: min(23px, 6.13vw);
  }
}
.profile #definition .def-wrap .def-item .def-ttl {
  position: relative;
  color: #3A4268;
  font-weight: 700;
}
.profile #definition .def-wrap .def-item .def-ttl span {
  margin-right: 0.75em;
}
.profile #definition .def-wrap .def-item .def-ttl b {
  display: inline-block;
  font-family: "Jost", sans-serif;
  color: #ADCADD;
  font-size: 2.1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.profile #definition .def-wrap .def-item .def-ttl::before {
  position: absolute;
  left: 0;
  bottom: -0.5em;
  content: '';
  width: 100%;
  height: 5px;
  background: #ADCADD;
}
@media screen and (min-width: 769px) {
  .profile #definition .def-wrap {
    display: flex;
    align-items: stretch;
    gap: 2.4vw;
  }
  .profile #definition .def-wrap .def-item {
    width: calc((100% - (2.4vw * 2)) / 3);
  }
  .profile #definition .def-wrap .def-item .def-ttl {
    font-size: clamp(2rem, 1.35vw, 2.6rem);
  }
}
@media only screen and (max-width: 768px) {
  .profile #definition .def-wrap {
    padding: 0 1.33vw;
  }
  .profile #definition .def-wrap .def-item {
    width: 100%;
  }
  .profile #definition .def-wrap .def-item .def-ttl {
    font-size: clamp(2rem, 5.33vw, 2.6rem);
  }
  .profile #definition .def-wrap .def-item .nl-txt {
    padding: 0 1.87vw;
  }
}

/*==================================================*
 *  [ 業績 ]
 *==================================================*/
.performance .sales-table {
  width: 100%;
  color: #3A4268;
  table-layout: fixed;
}
.performance .sales-table th {
  font-weight: 400;
}
.performance .sales-table th:first-child {
  width: 20%;
}
.performance .sales-table thead tr th {
  background: #ADCADD;
  padding: 0.25em 0;
}
.performance .sales-table thead::after {
  content: "";
  display: block;
  height: 1rem;
}
.performance .sales-table tbody tr {
  border-bottom: 1px solid #3A4268;
}
.performance .sales-table tbody tr:last-child {
  border-bottom: none;
}
.performance .sales-table tbody tr th {
  padding: 0.75em 0 0.5em;
}
.performance .sales-table tbody tr td {
  text-align: center;
  border-left: 1px solid #3A4268;
  padding: 0.75em 0 0.5em;
}
@media screen and (min-width: 769px) {
  .performance .sales-table th {
    font-size: clamp(1.4rem, 0.83vw, 1.6rem);
  }
}
@media only screen and (max-width: 768px) {
  .performance #sales-trend picture img, .performance #equity picture img {
    max-width: calc(100% + 30px);
    margin: 0 -15px;
  }
  .performance #sales-trend > p.nl-txt {
    font-size: clamp(1.2rem, 3.2vw, 1.4rem) !important;
  }
  .performance .sales-table th {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
  }
  .performance .sales-table tbody tr th {
    font-size: clamp(1.2rem, 3.2vw, 1.4rem);
    font-weight: 600;
  }
  .performance .sales-table tbody tr td {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
  }
}

/*==================================================*
 *  [ 沿革 ]
 *==================================================*/
.history .history-link ul {
  display: flex;
  list-style: none;
}
.history .history-link ul li a {
  display: block;
  width: 100%;
  color: #fff;
  font-weight: 700;
  text-align: center;
  background: #D9D9D9;
  box-shadow: 3px 3px 4px 0 rgba(0, 0, 0, 0.25);
}
@media (hover: hover) {
  .history .history-link ul li a:hover {
    border-color: #4D6B92;
    background: #4D6B92;
  }
}
.history .history-link ul li.current a {
  pointer-events: none;
  color: #4D6B92;
  border-color: #4D6B92;
  background: #fff;
}
@media screen and (min-width: 769px) {
  .history .history-link ul {
    gap: 14px;
  }
  .history .history-link ul li {
    width: calc((100% - (14px * 3)) / 4);
  }
  .history .history-link ul li a {
    font-size: clamp(2.2rem, 1.77vw, 3.4rem);
    letter-spacing: 0.02em;
    border: 3px solid #D9D9D9;
    padding: 10px 0 5px;
  }
}
@media only screen and (max-width: 768px) {
  .history .history-link ul {
    flex-wrap: wrap;
    gap: 8px;
  }
  .history .history-link ul li {
    width: calc((100% - 8px) / 2);
  }
  .history .history-link ul li a {
    font-size: 2.2rem;
    border: 2px solid #D9D9D9;
    padding: 6px 0 2px;
  }
}
.history .history-wrap {
  position: relative;
}
@media screen and (min-width: 769px) {
  .history .history-wrap::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: #F8F8F8;
    z-index: -1;
  }
}
.history .history-wrap .history-head {
  display: flex;
}
.history .history-wrap .history-head > div {
  width: 50%;
  text-align: center;
}
.history .history-wrap .history-head > div .head-ttl {
  font-size: clamp(1.6rem, 0.94vw, 1.8rem);
  font-weight: 700;
  padding: 0.25em 0;
}
.history .history-wrap .history-head > div:nth-child(1) {
  color: #fff;
  background: #4D6B92;
}
.history .history-wrap .history-head > div:nth-child(2) {
  color: #3A4268;
  background: #D9D9D9;
}
@media only screen and (max-width: 768px) {
  .history .history-wrap .history-head {
    display: none;
  }
}
.history .history-wrap .history-content-wrap {
  position: relative;
  width: 100%;
}
.history .history-wrap .history-content-wrap .history-item {
  position: relative;
  width: 100%;
}
.history .history-wrap .history-content-wrap .history-item span {
  position: absolute;
  transform: translateX(-50%);
  color: #3A4268;
  font-weight: 700;
  line-height: 2.059;
  z-index: +1;
}
.history .history-wrap .history-content-wrap .history-item span::after {
  content: '';
  position: absolute;
  top: 0;
  height: auto;
  aspect-ratio: 1 / 1;
  background: #D9D9D9;
  border-radius: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.history .history-wrap .history-content-wrap .history-item span:has(img)::after {
  content: none;
}
.history .history-wrap .history-content-wrap .history-item .right, .history .history-wrap .history-content-wrap .history-item .left {
  position: relative;
}
.history .history-wrap .history-content-wrap .history-item .right:has(.history-content)::before, .history .history-wrap .history-content-wrap .history-item .left:has(.history-content)::before {
  content: '';
  position: absolute;
  height: 2px;
}
.history .history-wrap .history-content-wrap .history-item .right .history-content, .history .history-wrap .history-content-wrap .history-item .left .history-content {
  position: relative;
  z-index: +1;
}
.history .history-wrap .history-content-wrap .history-item .right .history-content p + p, .history .history-wrap .history-content-wrap .history-item .left .history-content p + p {
  margin-top: 0.5em;
}
.history .history-wrap .history-content-wrap .history-item .right .history-content > div:has(img) img, .history .history-wrap .history-content-wrap .history-item .left .history-content > div:has(img) img {
  margin: 0.5em 0;
}
.history .history-wrap .history-content-wrap .history-item .right .history-content .nl-txt.full, .history .history-wrap .history-content-wrap .history-item .left .history-content .nl-txt.full {
  width: 100% !important;
}
.history .history-wrap .history-content-wrap .history-item .right .history-content {
  background: #fff;
}
@media screen and (min-width: 769px) {
  .history .history-wrap .history-content-wrap {
    padding-bottom: 5em;
  }
  .history .history-wrap .history-content-wrap .history-item {
    min-height: clamp(45px, 3.65vw, 70px);
    display: table;
    table-layout: fixed;
    margin: 2em 0;
  }
  .history .history-wrap .history-content-wrap .history-item:first-child {
    margin-top: 4em;
  }
  .history .history-wrap .history-content-wrap .history-item span {
    left: 50%;
    font-size: clamp(2.2rem, 1.77vw, 3.4rem);
  }
  .history .history-wrap .history-content-wrap .history-item span::after {
    left: 50%;
    width: clamp(45px, 3.65vw, 70px);
  }
  .history .history-wrap .history-content-wrap .history-item .right, .history .history-wrap .history-content-wrap .history-item .left {
    display: table-cell;
    width: 50%;
    vertical-align: top;
    padding-top: 1.25vw;
  }
  .history .history-wrap .history-content-wrap .history-item .right:has(.history-content)::before, .history .history-wrap .history-content-wrap .history-item .left:has(.history-content)::before {
    top: 1.88vw;
    width: calc(100% - clamp(35px, 3.13vw, 60px));
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content, .history .history-wrap .history-content-wrap .history-item .left .history-content {
    padding: 0 1em;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content:nth-of-type(n+2), .history .history-wrap .history-content-wrap .history-item .left .history-content:nth-of-type(n+2) {
    margin-top: 1em;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content .item-flex, .history .history-wrap .history-content-wrap .history-item .left .history-content .item-flex {
    display: flex;
    justify-content: start;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content .item-flex:nth-of-type(n+2), .history .history-wrap .history-content-wrap .history-item .left .history-content .item-flex:nth-of-type(n+2) {
    margin-top: 0.5em;
  }
  .history .history-wrap .history-content-wrap .history-item .right {
    padding-left: clamp(30px, 3.13vw, 60px);
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content {
    display: flex;
    gap: 0.83vw;
    width: 82%;
    margin-left: auto;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content .nl-txt {
    width: 60%;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content > div {
    width: calc(40% - 0.83vw);
  }
  .history .history-wrap .history-content-wrap .history-item .right::before {
    right: 0;
    background: #CFCFCF;
  }
  .history .history-wrap .history-content-wrap .history-item .left {
    padding-right: clamp(30px, 3.13vw, 60px);
  }
  .history .history-wrap .history-content-wrap .history-item .left .history-content {
    width: fit-content;
    max-width: 320px;
    background: #F8F8F8;
  }
  .history .history-wrap .history-content-wrap .history-item .left::before {
    left: 0;
    background: #4D6B92;
  }
  .history .history-wrap .history-content-wrap #y1991, .history .history-wrap .history-content-wrap #y1990, .history .history-wrap .history-content-wrap #y1962, .history .history-wrap .history-content-wrap #logo2 {
    margin-top: clamp(-130px, -6.77vw, -50px);
  }
  .history .history-wrap .history-content-wrap #y1971, .history .history-wrap .history-content-wrap #logo1 {
    margin-top: clamp(-100px, -5.21vw, -50px);
  }
  .history .history-wrap .history-content-wrap #y2022 .left .history-content {
    max-width: 440px;
  }
  .history .history-wrap .history-content-wrap #y2015 .left .history-content {
    max-width: 440px;
  }
  .history .history-wrap .history-content-wrap #y2015 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
  }
  .history .history-wrap .history-content-wrap #y2015 .left .history-content .item-flex img {
    max-width: 219px;
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y2001 .left .history-content, .history .history-wrap .history-content-wrap #y2000 .left .history-content {
    max-width: 390px;
  }
  .history .history-wrap .history-content-wrap #y2001 .left .history-content .item-flex, .history .history-wrap .history-content-wrap #y2000 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
  }
  .history .history-wrap .history-content-wrap #y2001 .left .history-content .item-flex img, .history .history-wrap .history-content-wrap #y2000 .left .history-content .item-flex img {
    width: 50%;
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y1972 .left .history-content {
    max-width: 380px;
  }
  .history .history-wrap .history-content-wrap #y1972 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
    word-break: auto-phrase;
  }
  .history .history-wrap .history-content-wrap #y1972 .left .history-content .item-flex img {
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y1993 .right .history-content:first-child p {
    width: 45%;
  }
  .history .history-wrap .history-content-wrap #y1993 .right .history-content:first-child div {
    width: 55%;
  }
  .history .history-wrap .history-content-wrap #y1991 .left .history-content, .history .history-wrap .history-content-wrap #y1989 .left .history-content, .history .history-wrap .history-content-wrap #y1969 .left .history-content {
    max-width: 410px;
  }
  .history .history-wrap .history-content-wrap #y1991 .left .history-content .item-flex, .history .history-wrap .history-content-wrap #y1989 .left .history-content .item-flex, .history .history-wrap .history-content-wrap #y1969 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
  }
  .history .history-wrap .history-content-wrap #y1991 .left .history-content .item-flex img, .history .history-wrap .history-content-wrap #y1989 .left .history-content .item-flex img, .history .history-wrap .history-content-wrap #y1969 .left .history-content .item-flex img {
    width: 50%;
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y1988 .left .history-content, .history .history-wrap .history-content-wrap #y1962 .left .history-content {
    max-width: 350px;
  }
  .history .history-wrap .history-content-wrap #y1988 .left .history-content .item-flex, .history .history-wrap .history-content-wrap #y1962 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
    word-break: auto-phrase;
  }
  .history .history-wrap .history-content-wrap #y1988 .left .history-content .item-flex img, .history .history-wrap .history-content-wrap #y1962 .left .history-content .item-flex img {
    width: 65%;
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y1950 .left .history-content {
    max-width: 380px;
  }
  .history .history-wrap .history-content-wrap #y1950 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
    word-break: auto-phrase;
  }
  .history .history-wrap .history-content-wrap #y1950 .left .history-content .item-flex img {
    width: 65%;
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap #y1986 .left .history-content, .history .history-wrap .history-content-wrap #y1985 .left .history-content {
    max-width: 400px;
  }
  .history .history-wrap .history-content-wrap #y1986 .left .history-content .item-flex, .history .history-wrap .history-content-wrap #y1985 .left .history-content .item-flex {
    flex-direction: row-reverse;
    gap: 12px;
  }
  .history .history-wrap .history-content-wrap #y1986 .left .history-content .item-flex img, .history .history-wrap .history-content-wrap #y1985 .left .history-content .item-flex img {
    width: 40%;
    margin-top: 0;
  }
}
@media only screen and (max-width: 768px) {
  .history .history-wrap .history-content-wrap::after {
    content: '';
    position: absolute;
    top: 2px;
    left: clamp(18.5px, 4.93vw, 25px);
    width: 6px;
    height: 100%;
    background: #3A4268;
  }
  .history .history-wrap .history-content-wrap .history-item {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 2em;
  }
  .history .history-wrap .history-content-wrap .history-item:first-child {
    margin-top: 0;
  }
  .history .history-wrap .history-content-wrap .history-item span {
    top: 0;
    left: 1em;
    font-size: clamp(2.2rem, 5.87vw, 2.8rem);
    order: 1;
  }
  .history .history-wrap .history-content-wrap .history-item span::after {
    left: 1.25em;
    width: clamp(45px, 12vw, 60px);
  }
  .history .history-wrap .history-content-wrap .history-item .right, .history .history-wrap .history-content-wrap .history-item .left {
    padding-top: min(4%, 1.25em);
    padding-left: clamp(82px, 21.87vw, 100px);
  }
  .history .history-wrap .history-content-wrap .history-item .right:has(.history-content)::before, .history .history-wrap .history-content-wrap .history-item .left:has(.history-content)::before {
    top: clamp(1.4em, 5.87vw, 2em);
    left: clamp(56px, 14.93vw, 74px);
    width: calc(100% - clamp(56px, 14.93vw, 74px));
    background: #4D6B92;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content, .history .history-wrap .history-content-wrap .history-item .left .history-content {
    background: #fff;
    padding: 0 0.5em;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content:nth-of-type(n+2), .history .history-wrap .history-content-wrap .history-item .left .history-content:nth-of-type(n+2) {
    margin-top: max(1em, 4.27vw);
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content > div:has(img), .history .history-wrap .history-content-wrap .history-item .left .history-content > div:has(img) {
    display: flex;
    justify-content: flex-end;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content > div:has(img) img, .history .history-wrap .history-content-wrap .history-item .left .history-content > div:has(img) img {
    margin: 0.5em 0;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content .item-flex, .history .history-wrap .history-content-wrap .history-item .left .history-content .item-flex {
    flex-direction: column;
  }
  .history .history-wrap .history-content-wrap .history-item .right .history-content .item-flex img, .history .history-wrap .history-content-wrap .history-item .left .history-content .item-flex img {
    max-width: fit-content;
    align-self: end;
  }
  .history .history-wrap .history-content-wrap .history-item .right {
    order: 2;
  }
  .history .history-wrap .history-content-wrap .history-item .left {
    order: 1;
  }
  .history .history-wrap .history-content-wrap #logo3, .history .history-wrap .history-content-wrap #logo2, .history .history-wrap .history-content-wrap #logo1 {
    margin-top: -2em;
    margin-bottom: 6em;
  }
  .history .history-wrap .history-content-wrap #y2020 .left .history-content > div, .history .history-wrap .history-content-wrap #y2017 .left .history-content > div, .history .history-wrap .history-content-wrap #y2015 .left .history-content > div, .history .history-wrap .history-content-wrap #2001 .left .history-content > div, .history .history-wrap .history-content-wrap #2000 .left .history-content > div {
    flex-direction: column;
  }
  .history .history-wrap .history-content-wrap #y2020 .left .history-content > div img, .history .history-wrap .history-content-wrap #y2017 .left .history-content > div img, .history .history-wrap .history-content-wrap #y2015 .left .history-content > div img, .history .history-wrap .history-content-wrap #2001 .left .history-content > div img, .history .history-wrap .history-content-wrap #2000 .left .history-content > div img {
    align-self: end;
  }
}

@media only screen and (max-width: 768px) {
  .history-item:not(.history-item:has(div.spnone)) .left::before {
    content: none !important;
  }
}
/*==================================================*
 *  [ サポート / 国内拠点 ]
 *==================================================*/
.support .bl-ttl span, .base .bl-ttl span {
  display: inline-block;
  color: #6875B1;
  font-weight: 500;
}
.support .map, .base .map {
  display: flex;
  justify-content: center;
  width: 100%;
}
.support .offices-ttl, .base .offices-ttl {
  display: block;
  width: 100%;
  color: #fff;
  font-weight: 700;
  background: #337CCF;
}
.support .offices-list, .base .offices-list {
  display: flex;
  flex-flow: column;
  width: 100%;
}
.support .offices-list .offices-item, .base .offices-list .offices-item {
  display: flex;
}
.support .offices-list .offices-item .offices-name, .base .offices-list .offices-item .offices-name {
  color: #337CCF;
  font-weight: 700;
}
.support .offices-list .offices-item .offices-name p, .base .offices-list .offices-item .offices-name p {
  word-break: auto-phrase;
}
.support .offices-list .offices-item .offices-address p:has(span), .base .offices-list .offices-item .offices-address p:has(span) {
  font-weight: 500;
}
.support .offices-list .offices-item .offices-address p:has(.web-link) b, .base .offices-list .offices-item .offices-address p:has(.web-link) b {
  margin-right: 1em;
}
.support .offices-list .offices-item .offices-address .web-link, .base .offices-list .offices-item .offices-address .web-link {
  vertical-align: text-top;
}
.support .offices-list .offices-item .offices-address .map-link, .base .offices-list .offices-item .offices-address .map-link {
  display: block;
  height: auto;
  aspect-ratio: 145 / 23;
  background: #FF7653;
  transition: none;
}
.support .offices-list .offices-item .offices-address .map-link::before, .base .offices-list .offices-item .offices-address .map-link::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  mask-repeat: no-repeat;
  background: #fff;
  mask-size: contain;
  mask-image: url("../img-ja/btn_map.svg");
  transition: none;
}
@media (hover: hover) {
  .support .offices-list .offices-item .offices-address .map-link:hover, .base .offices-list .offices-item .offices-address .map-link:hover {
    background: #fff;
    outline: 2px solid #FF7653;
  }
  .support .offices-list .offices-item .offices-address .map-link:hover::before, .base .offices-list .offices-item .offices-address .map-link:hover::before {
    background: #FF7653;
  }
}
.support .offices-list .offices-item .offices-contact, .base .offices-list .offices-item .offices-contact {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: fit-content;
}
.support .offices-list .offices-item .offices-contact > div, .base .offices-list .offices-item .offices-contact > div {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: fit-content;
}
.support .offices-list .offices-item .offices-contact > div > p, .base .offices-list .offices-item .offices-contact > div > p {
  width: 100%;
  text-align: left;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap, .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap {
  display: grid;
  grid-template-columns: max-content auto;
  grid-template-rows: min-content;
  grid-column-gap: 0.5em;
  grid-row-gap: 0.5em;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(1), .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(1) {
  grid-area: 1 / 1 / 2 / 2;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(2), .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(2) {
  grid-area: 1 / 2 / 2 / 3;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(3), .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(3) {
  grid-area: 2 / 1 / 3 / 2;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(4), .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div:nth-child(4) {
  grid-area: 2 / 2 / 3 / 3;
  text-align: center;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div p:has(b) b, .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div p:has(b) b {
  font-family: "Jost", sans-serif;
  font-weight: 500;
}
.support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div a, .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div a {
  font-family: "Jost", sans-serif;
  color: #fff;
  font-weight: 500;
  background: #1046A0;
  border-radius: 16.83px;
  transition: none;
}
@media (hover: hover) {
  .support .offices-list .offices-item .offices-contact > div .offices-contact-wrap div a:hover, .base .offices-list .offices-item .offices-contact > div .offices-contact-wrap div a:hover {
    color: #1046A0;
    background: #fff;
    outline: 3px solid #1046A0;
  }
}
.support .offices-list .offices-item .web-link, .base .offices-list .offices-item .web-link {
  display: inline-block;
  height: auto;
  aspect-ratio: 111 / 23;
  background: #1046A0;
  border-radius: 30px;
  transition: none;
}
.support .offices-list .offices-item .web-link::before, .base .offices-list .offices-item .web-link::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  mask-repeat: no-repeat;
  background: #fff;
  mask-size: contain;
  mask-image: url("../img-ja/btn_website.svg");
  transition: none;
}
@media (hover: hover) {
  .support .offices-list .offices-item .web-link:hover, .base .offices-list .offices-item .web-link:hover {
    background: #337CCF;
  }
}
.support .contact-btn, .base .contact-btn {
  display: flex;
  justify-content: center;
}
.support .contact-btn a, .base .contact-btn a {
  display: flex;
  justify-content: center;
  position: relative;
  width: 100%;
  background: #425672;
  border-radius: 50px;
  border: 2px solid transparent;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.25);
  transition: all .4s ease;
}
.support .contact-btn a span, .base .contact-btn a span {
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.1em;
  transition: all .4s ease;
}
.support .contact-btn a::before, .base .contact-btn a::before {
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  height: auto;
  aspect-ratio: 1 / 1;
  border: 1px solid #425672;
  border-radius: 50%;
  background: #fff;
  transition: background .4s ease;
  transform: translateY(-50%);
}
.support .contact-btn a::after, .base .contact-btn a::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: 50%;
  height: auto;
  aspect-ratio: 12 / 17;
  mask-repeat: no-repeat;
  background: #425672;
  mask-size: contain;
  mask-image: url("../img/icon_arrow.svg");
  transform: translateY(-50%);
  transition: background .4s ease;
  z-index: +1;
}
@media (hover: hover) {
  .support .contact-btn a:hover, .base .contact-btn a:hover {
    background: #fff;
    border-color: #425672;
  }
  .support .contact-btn a:hover span, .base .contact-btn a:hover span {
    color: #425672;
  }
  .support .contact-btn a:hover::before, .base .contact-btn a:hover::before {
    background: #425672;
    box-shadow: 0 0 6.8px rgba(57, 113, 141, 0.8);
  }
  .support .contact-btn a:hover::after, .base .contact-btn a:hover::after {
    background: #fff;
  }
}
@media screen and (min-width: 769px) {
  .support .bl-ttl span, .base .bl-ttl span {
    margin-left: 2em;
  }
  .support .offices-ttl, .base .offices-ttl {
    font-size: clamp(1.8rem, 1.04vw, 2rem);
    padding: 10px 32px 8px;
  }
  .support .offices-list, .base .offices-list {
    gap: 5px;
  }
  .support .offices-list .offices-item, .base .offices-list .offices-item {
    gap: 10px;
  }
  .support .offices-list .offices-item > [class^="offices-"], .base .offices-list .offices-item > [class^="offices-"] {
    padding: 27px 1.15vw 22px;
  }
  .support .offices-list .offices-item .offices-name, .base .offices-list .offices-item .offices-name {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-flow: column;
    width: 15%;
    min-width: 9em;
    padding: 27px 12px 22px;
  }
  .support .offices-list .offices-item .offices-name p, .base .offices-list .offices-item .offices-name p {
    width: fit-content;
    font-size: clamp(1.6rem, 0.94vw, 1.8rem);
    text-align: center;
  }
  .support .offices-list .offices-item .offices-address, .base .offices-list .offices-item .offices-address {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: calc(100% - (20px + 15% + 37%));
  }
  .support .offices-list .offices-item .offices-address p, .base .offices-list .offices-item .offices-address p {
    font-size: clamp(1.4rem, 0.83vw, 1.6rem);
  }
  .support .offices-list .offices-item .offices-address p:has(b), .base .offices-list .offices-item .offices-address p:has(b) {
    font-size: clamp(1.6rem, 0.94vw, 1.8rem);
  }
  .support .offices-list .offices-item .offices-address .map-link, .base .offices-list .offices-item .offices-address .map-link {
    width: 145px;
  }
  .support .offices-list .offices-item .offices-contact, .base .offices-list .offices-item .offices-contact {
    justify-content: center;
    width: 37%;
  }
  .support .offices-list .offices-item .offices-contact p, .base .offices-list .offices-item .offices-contact p {
    font-size: clamp(1.4rem, 0.94vw, 1.8rem);
  }
  .support .offices-list .offices-item .offices-contact p:has(b) b, .base .offices-list .offices-item .offices-contact p:has(b) b {
    font-size: clamp(1.6rem, 1.04vw, 2rem);
  }
  .support .offices-list .offices-item .offices-contact a, .base .offices-list .offices-item .offices-contact a {
    font-size: clamp(1.6rem, 1.04vw, 2rem);
    padding: 4px 1.56vw 1px;
  }
  .support .offices-list .offices-item:nth-of-type(odd) [class^="offices-"], .base .offices-list .offices-item:nth-of-type(odd) [class^="offices-"] {
    background: #F5F5F5;
  }
  .support .offices-list .offices-item .web-link, .base .offices-list .offices-item .web-link {
    width: 111px;
  }
  .support .contact-btn, .base .contact-btn {
    width: clamp(350px, 24.48vw, 470px);
  }
  .support .contact-btn a, .base .contact-btn a {
    padding: 1.25em 0 1em;
  }
  .support .contact-btn a span, .base .contact-btn a span {
    font-size: clamp(1.8rem, 1.04vw, 2rem);
  }
  .support .contact-btn a::before, .base .contact-btn a::before {
    width: 40px;
    right: 2.25em;
  }
  .support .contact-btn a::after, .base .contact-btn a::after {
    width: 16px;
    right: 3em;
  }
}
@media only screen and (max-width: 768px) {
  .support .bl-ttl span, .base .bl-ttl span {
    margin-left: 1em;
  }
  .support .offices-ttl, .base .offices-ttl {
    font-size: clamp(1.8rem, 4.8vw, 2.2rem);
    padding: 10px 5.33vw 8px;
  }
  .support .offices-list, .base .offices-list {
    gap: 10px;
  }
  .support .offices-list .offices-item, .base .offices-list .offices-item {
    flex-direction: column;
    gap: 1em;
    padding: 1em;
  }
  .support .offices-list .offices-item .offices-name p, .base .offices-list .offices-item .offices-name p {
    display: inline-block;
    width: fit-content;
    font-size: clamp(1.6rem, 4.27vw, 1.8rem);
  }
  .support .offices-list .offices-item .offices-address, .base .offices-list .offices-item .offices-address {
    width: 100%;
  }
  .support .offices-list .offices-item .offices-address p, .base .offices-list .offices-item .offices-address p {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
    margin-bottom: 0.25em;
  }
  .support .offices-list .offices-item .offices-address p:has(b), .base .offices-list .offices-item .offices-address p:has(b) {
    font-size: clamp(1.6rem, 4.27vw, 1.8rem);
  }
  .support .offices-list .offices-item .offices-address p:last-child, .base .offices-list .offices-item .offices-address p:last-child {
    margin-bottom: 0;
  }
  .support .offices-list .offices-item .offices-address .map-link, .base .offices-list .offices-item .offices-address .map-link {
    width: 120px;
  }
  .support .offices-list .offices-item .offices-contact, .base .offices-list .offices-item .offices-contact {
    width: 100%;
    margin-top: 0.75em;
  }
  .support .offices-list .offices-item .offices-contact p, .base .offices-list .offices-item .offices-contact p {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
  }
  .support .offices-list .offices-item .offices-contact p:has(b) b, .base .offices-list .offices-item .offices-contact p:has(b) b {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
  }
  .support .offices-list .offices-item .offices-contact a, .base .offices-list .offices-item .offices-contact a {
    font-size: clamp(1.4rem, 3.73vw, 1.6rem);
    padding: 4px 20px 1px;
  }
  .support .offices-list .offices-item:nth-of-type(odd), .base .offices-list .offices-item:nth-of-type(odd) {
    background: #F5F5F5;
  }
  .support .offices-list .offices-item .web-link, .base .offices-list .offices-item .web-link {
    vertical-align: top;
    width: 111px;
  }
  .support .contact-btn, .base .contact-btn {
    width: 80%;
  }
  .support .contact-btn a, .base .contact-btn a {
    padding: 15px 45px 10px;
  }
  .support .contact-btn a::before, .base .contact-btn a::before {
    width: 25px;
    right: 2.25em;
  }
  .support .contact-btn a::after, .base .contact-btn a::after {
    width: 12px;
    right: 2.55em;
  }
}

#affiliated .offices-ttl {
  background: #B4B4B4;
}
