@charset 'UTF-8';

/* Reset
-------------------------------------------------- */
*,
::before,
::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
@media (prefers-reduced-motion: reduce) {
  *,
  ::before,
  ::after {
    animation-delay: -1ms !important;
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-delay: 0s !important;
    transition-duration: 1ms !important;
    background-attachment: initial !important;
    scroll-behavior: auto !important;
  }
}
html {
  block-size: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  tab-size: 4;
}
body {
  min-block-size: 100%;
  text-rendering: optimizeSpeed;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}
:where(img, iframe) {
  border: none;
}
:where(img, picture, svg) {
  max-inline-size: 100%;
  block-size: auto;
}
:where(img) {
  image-rendering: -webkit-optimize-contrast;
}
:where(svg) {
  stroke: none;
  fill: currentColor;
}
:where(svg):where(:not([fill])) {
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}
:where(h1, h2, h3) {
  line-height: calc(1em + .5rem);
}
ul:where([class]),
ol:where([class]),
nav ul,
nav ol {
  list-style: none;
}
ul:where(:not([class])) {
  margin-left: .875em;
}
ol:where(:not([class])) {
  margin-left: 1.25em;
}
:where(table) {
  border-collapse: collapse;
  border-spacing: 0;
}
:where(sub, sup) {
  font-size: 68.75%;
  line-height: 1.02;
}
:where(sub) {
  vertical-align: baseline;
}
:where(hr) {
  border: none;
  border-block-start: 1px solid;
  color: inherit;
  block-size: 0;
  overflow: visible;
}
:where(template) {
  display: none;
}
:where(a) {
  background: transparent;
  text-decoration-skip: objects;
  -webkit-tap-highlight-color: rgba(0, 0, 0, .25);
}
:where(a:active, a:hover) {
  outline-width: 0;
}
:where(a img) {
  pointer-events: none;
}
:where(a, area, button, input, label[for], select, textarea, summary, [role='button'], [tabindex]:not([tabindex*="-"])) {
  cursor: pointer;
  touch-action: manipulation;
}
:where(summary) {
  list-style: none;
}
:where(summary)::-webkit-details-marker {
  display: none;
}
:where(code, kbd, pre, samp) {
  font-family: Consolas, Monaco, Andale Mono, Ubuntu Mono, monospace;
}
:where(pre) {
  display: block;
  overflow: auto;
}
:where(code) {
  overflow-wrap: break-word;
}
:where(pre code) {
  word-break: normal;
}
:where(dialog) {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1000;
  width: fit-content;
  height: fit-content;
  padding: 1em;
  background: inherit;
  border: solid;
  color: inherit;
  transform: translate(-50%, -50%);
}
:where(dialog:not([open])) {
  display: none;
}
:where(fieldset) {
  border: none;
}
:where(input, textarea, select, button),
:where(input[type="file"])::-webkit-file-upload-button {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  vertical-align: bottom;
  appearance: none;
}
:where(textarea) {
  resize: vertical;
  resize: block;
  overflow: auto;
  overflow-anchor: none;
}
:where(input[type="file"])::-webkit-file-upload-button,
:where(input[type="file"])::file-selector-button {
  cursor: pointer;
}
:where(:disabled, :disabled + label),
:where(input[type="file"]):disabled::-webkit-file-upload-button,
:where(input[type="file"]):disabled::file-selector-button,
:where([disabled], [aria-disabled="true"]) {
  cursor: not-allowed;
}
:where([type="color"])::-webkit-color-swatch-wrapper {
  padding: 0;
}
:where([type="color"])::-webkit-color-swatch {
  border: none;
  border-radius: 0;
}
:where([type="color"])::-moz-color-swatch {
  border: none;
  border-radius: 0;
}
:where([hidden]) {
  display: none;
}
:where([aria-busy="true"]) {
  cursor: progress;
}
:where([aria-controls]) {
  cursor: pointer;
}



/* Foundation
-------------------------------------------------- */
:root {
  --lg-base: 1920 * 100vw;
  --sm-base: 768 * 100vw;

  --color-default          : #333;
  --color-gray             : #ccc;
  --color-primary          : #dc2850;
  --color-secondary        : #002C83;
  --color-tertiary         : #000;
  --color-bg-primary       : #f2f2f2;
  --color-bg-secondary     : #fbe9ed;
  --color-border-primary   : #ccc;
  --color-border-secondary : #d9d9d9;
  --color-border-tertiary  : #e0e0e0;

  --font-sansSerif : 'tot-shizukardgo-stdn', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'BIZ UDPGothic', 'Helvetica Neue', Helvetica, sans-serif;
  --font-serif : 'Noto Serif JP', 'Hiragino Mincho ProN', 'Yu Mincho', Garamond, 'Times New Roman', serif;
  --font-din: 'din-2014', Helvetica, sans-serif;

  --transition          : .25s ease;
  --transition-duration : .25s;
  --hover-opacity       : .6;

  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-cubic: cubic-bezier(0.33, 1, 0.68, 1);
}

body {
  width: 100%;
  background: #fff;
  color: var(--color-default);
  font-family: var(--font-sansSerif);
  font-size: calc(30 / var(--sm-base));
  line-height: 1.5;
  font-weight: 600;
  overflow-x: hidden;
}
a {
  color: var(--color-default);
  text-decoration: none;
  text-underline-offset: .275em;
}
a:where(:not([class])) {
  color: var(--color-default);
  text-decoration: underline;
}
@media (hover: hover) and (pointer: fine) {
  a:where(:not([class])):hover {
    text-decoration: none;
  }
  a img {
    transition: opacity var(--transition);
  }
  a:hover img {
    opacity: var(--hover-opacity);
  }
}
input, textarea, button, select, option, optgroup {
  font-size: min(16px, calc(32 / var(--sm-base)));
}
::selection {
  background-color: var(--color-primary);
  color: #fff;
  text-shadow: none;
}
::placeholder {
  color: #aaa;
  opacity: 1;
}
@media screen and (min-width: 769px), print {
  body {
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  input, textarea, button, select, option, optgroup {
    font-size: calc(20 / var(--lg-base));
  }
}



/* Utility
-------------------------------------------------- */
.u-tl { text-align: left; }
.u-tc { text-align: center; }
.u-tr { text-align: right; }

.u-vt { vertical-align: top; }
.u-vm { vertical-align: middle; }
.u-vb { vertical-align: bottom; }

.u-fwn { font-weight: 400; }
.u-fwb { font-weight: 700; }

.u-visuallyHidden {
  position: absolute !important;
  z-index: -1 !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
}

.smsizes\:hidden,
.xs\:hidden {
  display: none;
}
.mobile\:hidden {
  display: none;
}
@media screen and (min-width: 360px), print {
  .xs\:hidden {
    display: inline;
  }
  .sm\:hidden {
    display: none;
  }
}
@media screen and (min-width: 769px), print {
  .smsizes\:hidden,
  .xs\:hidden,
  .sm\:hidden {
    display: inline;
  }
  .lgsizes\:hidden,
  .md\:hidden {
    display: none;
  }
  .mobile\:hidden {
    display: inline;
  }
  .laptop\:hidden {
    display: none;
  }
}
@media screen and (min-width: 1025px), print {
  .xs\:hidden,
  .sm\:hidden,
  .md\:hidden {
    display: inline;
  }
  .lg\:hidden {
    display: none;
  }
}
@media screen and (min-width: 1281px), print {
  .xs\:hidden,
  .sm\:hidden,
  .md\:hidden,
  .lg\:hidden {
    display: inline;
  }
  .xl\:hidden {
    display: none;
  }
}



/* Modules, Components
-------------------------------------------------- */
.l-inner {
  width: 90%;
  margin-inline: auto;
}
@media screen and (min-width: 769px), print {
  .l-inner {
    width: 65%;
  }
  .l-inner[data-type="wide"] {
    width: 96.8%;
  }
}

.header-logo {
  position: absolute;
  top: calc(20 / var(--sm-base));
  left: calc(40 / var(--sm-base));
  z-index: 100;
  width: calc(140 / var(--sm-base));
}
.header-logo a {
  display: block;
  font-size: 0;
}
@media screen and (min-width: 769px), print {
  .header-logo {
    top: calc(40 / var(--lg-base));
    left: calc(64 / var(--lg-base));
    width: calc(250 / var(--lg-base));
  }
}

.nav-trigger {
  position: fixed;
  top: calc(18 / var(--sm-base));
  right: calc(38 / var(--sm-base));
  z-index: 1000;
  width: calc(114 / var(--sm-base));
  height: calc(114 / var(--sm-base));
  background: #fff;
  border: none;
  border-radius: 50%;
  font-size: 0;
  cursor: pointer;
}
.nav-trigger span:nth-of-type(1)::before,
.nav-trigger span:nth-of-type(1)::after {
  content: '';
}
.nav-trigger span:nth-of-type(1)::before,
.nav-trigger span:nth-of-type(1)::after,
.nav-trigger span:nth-of-type(2) {
  position: absolute;
  left: calc(25 / var(--sm-base));
  width: calc(64 / var(--sm-base));
  height: calc(4 / var(--sm-base));
  background: var(--color-primary);
  border-radius: 100vmax;
}
.nav-trigger span:nth-of-type(1)::before {
  top: calc(37 / var(--sm-base));
  transition: top .3s ease, transform .3s ease;
}
.nav-trigger span:nth-of-type(1)::after {
  top: calc(55 / var(--sm-base));
  transition: opacity .3s ease;
}
.nav-trigger span:nth-of-type(2) {
  top: calc(73 / var(--sm-base));
  transition: top .3s ease, transform .3s ease;
}
.nav-trigger[aria-expanded="true"] span:nth-of-type(1)::before {
  top: calc(54 / var(--sm-base));
  transform: rotate(45deg);
}
.nav-trigger[aria-expanded="true"] span:nth-of-type(1)::after {
  opacity: 0;
}
.nav-trigger[aria-expanded="true"] span:nth-of-type(2) {
  top: calc(54 / var(--sm-base));
  transform: rotate(-45deg);
}
.nav {
  position: fixed;
  top: -5svh;
  right: 0;
  bottom: -5svh;
  left: 0;
  z-index: 999;
  background: var(--color-primary);
  overflow: hidden;
  overflow-y: auto;
  backface-visibility: hidden;
  transform: translateX(100%);
  opacity: 0;
  visibility: hidden;
}
[data-animation="true"] .nav {
  transition: transform .5s ease, opacity .5s ease, visibility .5s ease;
}
.nav[data-open="true"] {
  transform: translateX(0);
  opacity: 1;
  visibility: visible;
}
.nav-inner {
  display: table;
  width: 100vw;
  height: 100%;
  padding: 5svh 0;
}
.nav-body {
  position: relative;
  display: table-cell;
  padding: calc(28 / var(--sm-base)) calc(40 / var(--sm-base)) calc(120 / var(--sm-base));
  vertical-align: top;
}
.nav-body::after {
  content: '';
  position: absolute;
  top: calc(-5 / var(--sm-base));
  right: calc(-4 / var(--sm-base));
  width: calc(698 / var(--sm-base));
  height: calc(711 / var(--sm-base));
  background: url(../images/common/bg_nav_01.svg) 0 0 / contain no-repeat;
  opacity: .15;
  pointer-events: none;
}
.nav-body-inner {
  position: relative;
  z-index: 2;
}
.nav-logo a {
  display: inline-block;
  width: calc(140 / var(--sm-base));
  font-size: 0;
}
.nav-logo img {
  width: 100%;
}
.nav-list {
  margin-top: calc(52 / var(--sm-base));
}
.nav-item:not(:first-child) {
  margin-top: calc(20 / var(--sm-base));
}
.nav-anchor {
  display: block;
  padding: calc(18 / var(--sm-base)) calc(50 / var(--sm-base));
  color: #fff;
  font-size: calc(56 / var(--sm-base));
}
@media (hover: hover) and (pointer: fine) {
  .nav-anchor {
    transition: opacity var(--transition);
  }
  .nav-anchor:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .nav-trigger {
    display: none;
  }
  .nav {
    top: calc(48 / var(--lg-base));
    right: calc(142 / var(--lg-base));
    bottom: auto;
    left: auto;
    background: none;
    overflow: visible;
    transform: none;
    opacity: 1;
    visibility: visible;
  }
  .nav[data-open="true"] {
    transform: none;
    opacity: 1;
    visibility: visible;
  }
  .nav-inner {
    display: block;
    width: auto;
    height: auto;
    padding: 0;
  }
  .nav-body {
    display: block;
    padding: 0;
  }
  .nav-body::after {
    content: none;
  }
  .nav-logo {
    display: none;
  }
  .nav-list {
    display: flex;
    margin: 0;
    padding-inline: calc(14 / var(--lg-base));
    background: #fff;
    border-radius: calc(10 / var(--lg-base));
  }
  .nav-item:not(:first-child) {
    margin: 0;
  }
  .nav-anchor {
    position: relative;
    width: calc(230 / var(--lg-base));
    padding: calc(17 / var(--lg-base)) calc(10 / var(--lg-base));
    color: #000;
    font-size: calc(26 / var(--lg-base));
    font-weight: 700;
    text-align: center;
  }
  .nav-anchor::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(4 / var(--lg-base));
    background: var(--color-primary);
    pointer-events: none;
    opacity: 0;
  }
  .nav-anchor.--current::after {
    opacity: 1;
  }
  @media (hover: hover) and (pointer: fine) {
    .nav-anchor {
      transition: color var(--transition);
    }
    .nav-anchor::after {
      transition: opacity var(--transition);
    }
    .nav-anchor:hover {
      color: var(--color-primary);
      opacity: 1;
    }
    .nav-anchor:hover::after {
      opacity: 1;
    }
  }
}

.footer {
  position: relative;
  overflow: hidden;
}
.footer::before {
  content: '';
  position: absolute;
  bottom: calc(417 / var(--sm-base));
  right: calc(-240 / var(--sm-base));
  width: calc(924 / var(--sm-base));
  height: calc(924 / var(--sm-base));
  background: url(../images/common/bg_footer_01.webp) 0 0 / contain no-repeat;
  pointer-events: none;
}
.footer::after {
  content: '';
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  height: auto;
  background: url(../images/common/bg_footer_02.webp) 100% 0 / cover no-repeat;
  aspect-ratio: 1536/670;
}
.footer-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  width: 90%;
  margin-inline: auto;
  padding-block: calc(130 / var(--sm-base)) calc(175 / var(--sm-base));
}
.footer-contents {
  order: 2;
  margin-top: calc(80 / var(--sm-base));
}
.footer-logo {
  width: calc(250 / var(--sm-base));
}
.footer-logo a {
  display: block;
  font-size: 0;
}
.footer-name {
  margin-top: calc(45 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
}
.footer-address {
  margin-top: calc(6 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  line-height: 1.8;
}
.footer-number {
  margin-top: calc(35 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
}
.footer-nav {
  order: 1;
}
.footer-nav-list:nth-of-type(2) {
  margin-top: calc(30 / var(--sm-base));
}
.footer-nav-list > li {
  position: relative;
  padding-left: calc(56 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
}
.footer-nav-list > li:not(:first-child) {
  margin-top: calc(30 / var(--sm-base));
}
.footer-nav-list > li::before {
  content: '';
  position: absolute;
  top: calc(3.5 / var(--sm-base));
  left: calc(5 / var(--sm-base));
  width: calc(36.5 / var(--sm-base));
  height: calc(36.5 / var(--sm-base));
  background: var(--color-default);
  -webkit-mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
}
.footer-nav-list a {
  text-decoration: none;
}
.footer-nav-sublist {
  margin-top: calc(25 / var(--sm-base));
}
.footer-nav-sublist > li {
  position: relative;
  padding-left: calc(54 / var(--sm-base));
}
.footer-nav-sublist > li::before {
  content: '';
  position: absolute;
  top: calc(22 / var(--sm-base));
  left: calc(14 / var(--sm-base));
  width: calc(25 / var(--sm-base));
  height: calc(1.5 / var(--sm-base));
  background: var(--color-default);
  pointer-events: none;
}
.footer-nav-sublist > li:not(:first-child) {
  margin-top: calc(30 / var(--sm-base));
}
.footer-copyright {
  order: 3;
  margin-top: calc(35 / var(--sm-base));
  color: var(--color-gray);
  font-size: calc(20 / var(--sm-base));
}
.footer-pagetop {
  position: absolute;
  right: calc(40 / var(--sm-base));
  bottom: calc(260 / var(--sm-base));
  z-index: 3;
  display: block;
  width: calc(150 / var(--sm-base));
  height: calc(150 / var(--sm-base));
  padding: calc(58 / var(--sm-base)) calc(20 / var(--sm-base)) 0;
  background: #000;
  border-radius: 50%;
  color: #fff;
  font-family: var(--font-din);
  font-size: calc(24 / var(--sm-base));
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: .025em;
  text-decoration: none;
  text-align: center;
}
.footer-pagetop::after {
  content: '';
  position: absolute;
  top: calc(25 / var(--sm-base));
  left: 50%;
  width: calc(23 / var(--sm-base));
  height: calc(22 / var(--sm-base));
  background: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
  pointer-events: none;
  transform: translateX(-50%) rotate(-90deg);
}
@media (hover: hover) and (pointer: fine) {
  .footer-nav-list a,
  .footer-pagetop {
    transition: opacity var(--transition);
  }
  .footer-nav-list a:hover,
  .footer-pagetop:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .footer::before {
    top: calc(-10 / var(--lg-base));
    right: calc(40 / var(--lg-base));
    bottom: auto;
    width: calc(1005 / var(--lg-base));
    height: calc(1005 / var(--lg-base));
  }
  .footer::after {
    background-image: url(../images/common/bg_footer_02_lg.webp);
    aspect-ratio: 3840/740;
  }
  .footer-inner {
    flex-direction: row;
    flex-wrap: wrap;
    width: 65%;
    padding-block: calc(120 / var(--lg-base)) calc(115 / var(--lg-base));
  }
  .footer-contents {
    order: 1;
    width: 42%;
    margin: 0;
  }
  .footer-logo {
    width: calc(250 / var(--lg-base));
  }
  .footer-name {
    margin-top: calc(45 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .footer-address {
    margin-top: calc(5 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .footer-number {
    margin-top: calc(40 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.4;
  }
  .footer-nav {
    order: 2;
    flex: 1;
    display: flex;
  }
  .footer-nav-list:nth-of-type(1) {
    flex: 1;
  }
  .footer-nav-list:nth-of-type(2) {
    width: 24.5%;
    margin: 0;
  }
  .footer-nav-list > li {
    padding-left: calc(42 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .footer-nav-list > li:not(:first-child) {
    margin-top: calc(15 / var(--lg-base));
  }
  .footer-nav-list > li::before {
    top: calc(4 / var(--lg-base));
    left: 0;
    width: calc(27.5 / var(--lg-base));
    height: calc(27.5 / var(--lg-base));
  }
  .footer-nav-sublist {
    margin-top: calc(20 / var(--lg-base));
  }
  .footer-nav-sublist > li {
    padding-left: calc(40 / var(--lg-base));
  }
  .footer-nav-sublist > li::before {
    top: calc(18 / var(--lg-base));
    left: calc(6 / var(--lg-base));
    width: calc(18 / var(--lg-base));
    height: calc(1.5 / var(--lg-base));
  }
  .footer-nav-sublist > li:not(:first-child) {
    margin-top: calc(15 / var(--lg-base));
  }
  .footer-copyright {
    width: 100%;
    margin-top: calc(35 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
  }
  .footer-pagetop {
    right: calc(80 / var(--lg-base));
    bottom: calc(300 / var(--lg-base));
    width: calc(150 / var(--lg-base));
    height: calc(150 / var(--lg-base));
    padding: calc(58 / var(--lg-base)) calc(20 / var(--lg-base)) 0;
    font-size: calc(24 / var(--lg-base));
  }
  .footer-pagetop::after {
    top: calc(27 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(21 / var(--lg-base));
  }
}

.fixed-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 100;
  display: flex;
  width: 100%;
  padding: calc(30 / var(--sm-base)) calc(32 / var(--sm-base));
  background: #858585;
  border-radius: calc(20 / var(--sm-base)) calc(20 / var(--sm-base)) 0 0;
}
body:has(.fixed-cta) {
  padding-bottom: calc(165 / var(--sm-base));
}
.fixed-cta-contact {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  border: calc(3 / var(--sm-base)) solid #fff;
  border-radius: calc(24 / var(--sm-base));
  color: #fff;
  font-size: calc(48 / var(--sm-base));
  letter-spacing: .05em;
  text-align: center;
}
.fixed-cta-line,
.fixed-cta-instagram {
  position: relative;
  display: block;
  width: calc(118 / var(--sm-base));
  margin-left: calc(26 / var(--sm-base));
  font-size: 0;
  text-decoration: none;
}
@media (hover: hover) and (pointer: fine) {
  .fixed-cta-contact {
    transition: opacity var(--transition);
  }
  .fixed-cta-contact:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .fixed-cta {
    top: calc(120 / var(--lg-base));
    right: 0;
    bottom: auto;
    left: auto;
    flex-direction: column;
    width: auto;
    height: auto;
    padding: 0;
    background: none;
  }
  body:has(.fixed-cta) {
    padding-bottom: 0;
  }
  .fixed-cta-contact {
    padding: calc(40 / var(--lg-base)) calc(8 / var(--lg-base)) calc(28 / var(--lg-base)) 0;
    background: var(--color-primary) url(../images/common/bg_fixed-cta_01.webp) 50% 50% / contain no-repeat;
    border: none;
    border-radius: calc(10 / var(--lg-base)) 0 0 calc(10 / var(--lg-base));
    font-size: calc(22 / var(--lg-base));
    letter-spacing: .1175em;
  }
  .fixed-cta-contact span {
    display: inline-block;
    writing-mode: vertical-rl;
  }
  .fixed-cta-line {
    width: calc(70 / var(--lg-base));
    margin: calc(15 / var(--lg-base)) calc(15 / var(--lg-base)) 0 0;
  }
  .fixed-cta-instagram {
    width: calc(70 / var(--lg-base));
    margin: calc(10 / var(--lg-base)) calc(15 / var(--lg-base)) 0 0;
  }
}

.m-page-header {
  background: var(--color-primary);
}
.m-page-image {
  position: relative;
  aspect-ratio: 1536/360;
}
.m-page-image::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: rgba(51, 51, 51, .2);
  pointer-events: none;
}
.m-page-image img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.m-page-title {
  display: flex;
  align-items: center;
  min-height: calc(220 / var(--sm-base));
  padding-block: calc(80 / var(--sm-base));
  color: #fff;
  font-size: calc(48 / var(--sm-base));
  font-weight: 600;
  line-height: 1.5;
}
.m-page-title span span {
  display: block;
  margin-bottom: calc(15 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
}
.m-page-title:has(span span) {
  padding-block: calc(70 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .m-page-image {
    aspect-ratio: 3886/960;
  }
  .m-page-title {
    min-height: calc(330 / var(--lg-base));
    padding-block: calc(40 / var(--lg-base));
    font-size: calc(56 / var(--lg-base));
  }
  .m-page-title span span {
    margin-bottom: calc(25 / var(--lg-base));
    font-size: calc(36 / var(--lg-base));
  }
  .m-page-title:has(span span) {
    padding-block: calc(70 / var(--lg-base));
  }
}

.m-pagination {
  margin-top: calc(90 / var(--sm-base));
  text-align: center;
}
.m-pagination-inner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0;
}
.m-pagination-number,
.m-pagination-prev,
.m-pagination-next {
  border: calc(1 / var(--sm-base)) solid var(--color-primary);
  border-radius: 50%;
  line-height: 1;
}
.m-pagination-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(93 / var(--sm-base));
  height: calc(93 / var(--sm-base));
  margin-inline: calc(16 / var(--sm-base));
  padding-bottom: calc(4 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(40 / var(--sm-base));
  font-family: var(--font-din);
  font-weight: 400;
}
.m-pagination-current {
  background: var(--color-primary);
  color: #fff;
}
.m-pagination-prev,
.m-pagination-next {
  position: relative;
  display: inline-block;
  width: calc(60 / var(--sm-base));
  height: calc(60 / var(--sm-base));
}
.m-pagination-prev::before,
.m-pagination-next::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(28 / var(--sm-base));
  height: calc(26 / var(--sm-base));
  background: var(--color-primary);
  -webkit-mask: url(../images/common/icn_arrow_03.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_03.svg) 0 0 / contain no-repeat;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.m-pagination-prev {
  margin-right: calc(28 / var(--sm-base));
}
.m-pagination-prev::before {
  transform: translate(-50%, -50%) scaleX(-1);
}
.m-pagination-next {
  margin-left: calc(28 / var(--sm-base));
}
@media (hover: hover) and (pointer: fine) {
  .m-pagination-number:not(.m-pagination-current),
  .m-pagination-prev,
  .m-pagination-next {
    transition: opacity var(--transition);
  }
  .m-pagination-number:not(.m-pagination-current):hover,
  .m-pagination-prev:hover,
  .m-pagination-next:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .m-pagination {
    margin-top: calc(150 / var(--lg-base));
    text-align: left;
  }
  .m-pagination-number,
  .m-pagination-prev,
  .m-pagination-next {
    border-width: calc(1 / var(--lg-base));
  }
  .m-pagination-number {
    width: calc(60 / var(--lg-base));
    height: calc(60 / var(--lg-base));
    margin-inline: calc(10 / var(--lg-base));
    padding-bottom: calc(2 / var(--lg-base));
    font-size: calc(28 / var(--lg-base));
  }
  .m-pagination-inner > *:first-child {
    margin-left: 0;
  }
  .m-pagination-prev,
  .m-pagination-next {
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
  .m-pagination-prev::before,
  .m-pagination-next::before {
    width: calc(18 / var(--lg-base));
    height: calc(17 / var(--lg-base));
  }
  .m-pagination-prev {
    margin-right: calc(20 / var(--lg-base));
  }
  .m-pagination-next {
    margin-left: calc(20 / var(--lg-base));
  }
}

.m-cta {
  position: relative;
  padding-block: calc(200 / var(--sm-base)) calc(230 / var(--sm-base));
  overflow: hidden;
}
.m-cta-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.m-cta-bg::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 130%;
  background: url(../images/common/bg_cta_01.webp) 50% 50% / cover no-repeat;
  transform: translateY(-50%);
}
.m-cta-inner {
  position: relative;
  z-index: 2;
  width: 90%;
  margin-inline: auto;
  padding: calc(90 / var(--sm-base)) calc(40 / var(--sm-base)) calc(110 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  box-shadow: 0 0 calc(10 / var(--sm-base)) rgba(51, 51, 51, .4);
}
.m-cta-heading {
  font-size: calc(56 / var(--sm-base));
  font-weight: 600;
}
.m-cta-lead {
  margin-top: calc(38 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  line-height: 1.6;
}
.m-cta-lead br {
  display: none;
}
.m-cta-action {
  margin-top: calc(45 / var(--sm-base));
}
.m-cta-button {
  position: relative;
  display: block;
  padding: calc(42 / var(--sm-base)) calc(90 / var(--sm-base)) calc(42 / var(--sm-base)) calc(34 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.m-cta-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
.m-cta-button.--line {
  background: #06c655;
}
.m-cta-notice {
  margin: calc(10 / var(--sm-base)) 0 calc(35 / var(--sm-base)) 0;
  font-size: calc(24 / var(--sm-base));
  line-height: 1.6;
  text-indent: -.5em;
}
@media (hover: hover) and (pointer: fine) {
  .m-cta-button {
    transition: opacity var(--transition);
  }
  .m-cta-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .m-cta {
    padding-block: calc(245 / var(--lg-base));
  }
  .m-cta-bg::before {
    background-image: url(../images/common/bg_cta_01_lg.webp);
  }
  .m-cta-inner {
    width: 65%;
    padding: calc(105 / var(--lg-base)) calc(74 / var(--lg-base)) calc(110 / var(--lg-base)) calc(80 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    box-shadow: 0 0 calc(10 / var(--lg-base)) rgba(51, 51, 51, .4);
  }
  .m-cta-row {
    display: flex;
    align-items: center;
  }
  .m-cta-contents {
    flex: 1;
  }
  .m-cta-heading {
    font-size: calc(60 / var(--lg-base));
  }
  .m-cta-lead {
    margin: calc(40 / var(--lg-base)) 0 0 calc(5 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .m-cta-lead br {
    display: inline;
  }
  .m-cta-action {
    width: calc(560 / var(--lg-base));
    margin: 0;
  }
  .m-cta-button {
    padding: calc(37 / var(--lg-base)) calc(90 / var(--lg-base)) calc(37 / var(--lg-base)) calc(34 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .m-cta-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
  .m-cta-notice {
    margin: calc(18 / var(--lg-base)) 0 calc(32 / var(--lg-base)) 0;
    font-size: calc(16 / var(--lg-base));
    text-indent: 0;
  }
}

.c-heading {
  color: var(--color-primary);
  font-size: calc(44 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
  text-align: center;
}
@media screen and (min-width: 769px), print {
  .c-heading {
    font-size: calc(40 / var(--lg-base));
  }
}

.js-animation-element {
  opacity: 0;
  translate: 0 3vw;
}
.js-animation-element.--show {
  opacity: 1;
  translate: 0;
  transition-duration: .7s;
  transition-timing-function: opacity var(--ease-out-cubic), translate var(--ease-out-quint);
}


/* Index
-------------------------------------------------- */
.index-mv {
  position: relative;
  width: 100%;
  height: calc(791 / var(--sm-base));
  background: url(../images/index/bg_mv_01.webp) 50% 50% / cover no-repeat;
}
.index-mv-message {
  position: absolute;
  bottom: calc(13 / var(--sm-base));
  left: calc(15 / var(--sm-base));
  z-index: 2;
  width: calc(642 / var(--sm-base));
}
.index-nav-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(2 / var(--sm-base));
  margin-top: calc(2 / var(--sm-base));
}
.index-nav-item {
  width: calc(50% - (1 / var(--sm-base)));
}
.index-nav-anchor {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(240 / var(--sm-base));
  padding-bottom: calc(12 / var(--sm-base));
  background-position: 50% 50%;
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
  line-height: 1.4;
  text-decoration: none;
  text-align: center;
}
.index-nav-item:nth-of-type(1) .index-nav-anchor {
  background-image: url(../images/index/img_nav_01.webp);
}
.index-nav-item:nth-of-type(2) .index-nav-anchor {
  background-image: url(../images/index/img_nav_02.webp);
}
.index-nav-item:nth-of-type(3) .index-nav-anchor {
  background-image: url(../images/index/img_nav_03.webp);
}
.index-nav-item:nth-of-type(4) .index-nav-anchor {
  background-image: url(../images/index/img_nav_04.webp);
}
.index-nav-anchor::after {
  content: '';
  position: absolute;
  bottom: calc(30 / var(--sm-base));
  left: 50%;
  width: calc(32 / var(--sm-base));
  height: calc(32 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateX(-50%) rotate(90deg);
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .index-nav-anchor {
    transition: opacity var(--transition);
  }
  .index-nav-anchor:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .index-mv-message {
    bottom: calc(52 / var(--lg-base));
    left: calc(10 / var(--lg-base));
    width: calc(926 / var(--lg-base));
  }
  .index-mv {
    height: calc(1076 / var(--lg-base));
    background-image: url(../images/index/bg_mv_01_lg.webp);
  }
  .index-nav-list {
    gap: calc(2 / var(--lg-base));
    margin-top: calc(2 / var(--lg-base));
  }
  .index-nav-item {
    width: calc(25% - (1.5 / var(--lg-base)));
  }
  .index-nav-anchor {
    height: calc(270 / var(--lg-base));
    padding-bottom: calc(18 / var(--lg-base));
    font-size: calc(34 / var(--lg-base));
  }
  .index-nav-item:nth-of-type(1) .index-nav-anchor {
    background-image: url(../images/index/img_nav_01_lg.webp);
  }
  .index-nav-item:nth-of-type(2) .index-nav-anchor {
    background-image: url(../images/index/img_nav_02_lg.webp);
  }
  .index-nav-item:nth-of-type(3) .index-nav-anchor {
    background-image: url(../images/index/img_nav_03_lg.webp);
  }
  .index-nav-item:nth-of-type(4) .index-nav-anchor {
    background-image: url(../images/index/img_nav_04_lg.webp);
  }
  .index-nav-anchor::after {
    bottom: calc(30 / var(--lg-base));
    width: calc(34 / var(--lg-base));
    height: calc(34 / var(--lg-base));
  }
}

.index-section-heading {
  color: var(--color-primary);
  font-size: calc(56 / var(--sm-base));
  font-weight: 600;
  text-align: center;
}
.index-section-more-anchor {
  position: relative;
  display: block;
  padding: calc(36 / var(--sm-base)) calc(22 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  text-decoration: none;
}
.index-section-more-anchor::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(25 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .index-section-more-anchor {
    transition: opacity var(--transition);
  }
  .index-section-more-anchor:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .index-section-heading {
    font-size: calc(80 / var(--lg-base));
  }
  .index-section-more-anchor {
    padding: calc(22 / var(--lg-base)) calc(28 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .index-section-more-anchor::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}

.index-reason {
  position: relative;
  padding-block: calc(186 / var(--sm-base)) calc(133 / var(--sm-base));
  background: var(--color-bg-primary);
}
.index-reason::before,
.index-reason::after {
  content: '';
  position: absolute;
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
.index-reason::before {
  top: calc(103 / var(--sm-base));
  left: 0;
  width: calc(470 / var(--sm-base));
  height: calc(312 / var(--sm-base));
  background-image: url(../images/index/bg_reason_01.webp);
}
.index-reason::after {
  top: calc(775 / var(--sm-base));
  right: 0;
  width: calc(450 / var(--sm-base));
  height: calc(377 / var(--sm-base));
  background-image: url(../images/index/bg_reason_02.webp);
}
.index-reason-inner {
  position: relative;
  z-index: 2;
}
.index-reason-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(58 / var(--sm-base)) calc(18 / var(--sm-base));
  margin-top: calc(140 / var(--sm-base));
}
.index-reason-item {
  width: calc(50% - (9 / var(--sm-base)));
}
.index-reason-anchor {
  position: relative;
  display: block;
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  line-height: 1.4;
  letter-spacing: .05em;
  text-decoration: none;
}
.index-reason-anchor::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: calc(150 / var(--sm-base));
  height: calc(150 / var(--sm-base));
  background: linear-gradient(-45deg, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, 0) 85%);
  pointer-events: none;
}
.index-reason-anchor span {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(240 / var(--sm-base));
  padding: calc(10 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  text-align: center;
}
.index-reason-anchor span::before,
.index-reason-anchor span::after {
  content: '';
  position: absolute;
  pointer-events: none;
}
.index-reason-anchor span::before {
  right: calc(20 / var(--sm-base));
  bottom: calc(-25 / var(--sm-base));
  z-index: 2;
  width: calc(60 / var(--sm-base));
  height: calc(60 / var(--sm-base));
  background: #000;
  border-radius: 50%;
}
.index-reason-anchor span::after {
  right: calc(41 / var(--sm-base));
  bottom: calc(-2 / var(--sm-base));
  z-index: 3;
  width: calc(16 / var(--sm-base));
  height: calc(15 / var(--sm-base));
  background: #fff;
  -webkit-mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
}
.index-reason-more {
  width: calc(460 / var(--sm-base));
  margin: calc(85 / var(--sm-base)) auto 0;
}
.index-reason-more-anchor {
  position: relative;
  display: block;
  padding: calc(36 / var(--sm-base)) calc(22 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  text-decoration: none;
}
.index-reason-more-anchor::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(25 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .index-reason-anchor,
  .index-reason-anchor span::before,
  .index-reason-anchor span::after {
    transition: background var(--transition);
  }
  .index-reason-anchor:hover {
    background: #e66884;
  }
  .index-reason-anchor:hover span::before {
    background: var(--color-gray);
  }
  .index-reason-anchor:hover span::after {
    background: var(--color-primary);
  }
  .index-reason-more-anchor {
    transition: opacity var(--transition);
  }
  .index-reason-more-anchor:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .index-reason {
    padding-block: calc(230 / var(--lg-base)) calc(216 / var(--lg-base));
  }
  .index-reason::before {
    top: calc(195 / var(--lg-base));
    width: calc(760 / var(--lg-base));
    height: calc(515 / var(--lg-base));
    background-image: url(../images/index/bg_reason_01_lg.webp);
  }
  .index-reason::after {
    top: auto;
    bottom: calc(120 / var(--lg-base));
    width: calc(960 / var(--lg-base));
    height: calc(630 / var(--lg-base));
    background-image: url(../images/index/bg_reason_02_lg.webp);
  }
  .index-reason-list {
    gap: calc(46 / var(--lg-base)) calc(26 / var(--lg-base));
    margin-top: calc(170 / var(--lg-base));
  }
  .index-reason-item {
    width: calc(25% - (19.5 / var(--lg-base)));
  }
  .index-reason-anchor {
    border-radius: calc(10 / var(--lg-base));
    line-height: 1.45;
  }
  .index-reason-anchor::before {
    width: calc(195 / var(--lg-base));
    height: calc(195 / var(--lg-base));
  }
  .index-reason-anchor span {
    min-height: calc(320 / var(--lg-base));
    padding: calc(10 / var(--lg-base));
    font-size: calc(40 / var(--lg-base));
  }
  .index-reason-anchor span::before {
    right: calc(20 / var(--lg-base));
    bottom: calc(-33 / var(--lg-base));
    width: calc(80 / var(--lg-base));
    height: calc(80 / var(--lg-base));
  }
  .index-reason-anchor span::after {
    right: calc(49 / var(--lg-base));
    bottom: calc(-2 / var(--lg-base));
    width: calc(19 / var(--lg-base));
    height: calc(18 / var(--lg-base));
  }
  .index-reason-more {
    width: calc(380 / var(--lg-base));
    margin: calc(100 / var(--lg-base)) auto 0;
  }
  .index-reason-more-anchor {
    padding: calc(22 / var(--lg-base)) calc(28 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .index-reason-more-anchor::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}

.index-services {
  position: relative;
  background: var(--color-primary);
  overflow: hidden;
}
.index-services-inner {
  position: relative;
  z-index: 2;
  padding-block: calc(150 / var(--sm-base)) calc(200 / var(--sm-base));
}
.index-services-heading {
  color: #fff;
}
.index-services-list {
  margin: calc(230 / var(--sm-base)) calc(44 / var(--sm-base)) 0;
}
.index-services-item {
  position: relative;
  margin-top: calc(180 / var(--sm-base));
  counter-increment: index-services;
}
.index-services-anchor {
  position: relative;
  display: block;
  height: 100%;
}
.index-services-anchor::before,
.index-services-anchor::after {
  content: '';
  position: absolute;
  pointer-events: none;
}
.index-services-anchor::before {
  right: calc(32 / var(--sm-base));
  bottom: calc(-46 / var(--sm-base));
  z-index: 2;
  width: calc(90 / var(--sm-base));
  height: calc(90 / var(--sm-base));
  background: #000;
  border-radius: 50%;
}
.index-services-anchor::after {
  right: calc(65 / var(--sm-base));
  bottom: calc(-12 / var(--sm-base));
  z-index: 3;
  width: calc(22 / var(--sm-base));
  height: calc(21 / var(--sm-base));
  background: #fff;
  -webkit-mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
}
.index-services-item-inner {
  position: relative;
  height: 100%;
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
}
.index-services-item-inner::before {
  content: counter(index-services, decimal-leading-zero);
  position: absolute;
  top: calc(-110 / var(--sm-base));
  left: calc(14 / var(--sm-base));
  z-index: 2;
  color: #fff;
  font-family: var(--font-din);
  font-size: calc(160 / var(--sm-base));
  font-weight: 600;
  line-height: 1;
  pointer-events: none;
}
.index-services-image {
  display: block;
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
}
.index-services-description {
  padding: calc(32 / var(--sm-base)) calc(46 / var(--sm-base)) 0;
  font-size: calc(26 / var(--sm-base));
}
.index-services-subheading {
  min-height: 3.575em;
  padding: calc(2 / var(--sm-base)) calc(12 / var(--sm-base)) calc(32 / var(--sm-base)) calc(46 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: .05em;
}
.index-services-bg {
  position: absolute;
  top: calc(-30 / var(--sm-base));
  left: 0;
  width: calc(100% + (30 / var(--sm-base)));
  height: 100%;
  background: url(../images/index/bg_services_all.webp) 0 0 / 100% auto repeat-y;
  pointer-events: none;
}
.index-services-bg:is(.--bg02, .--bg03, .--bg04) {
  display: none;
}
@media (hover: hover) and (pointer: fine) {
  .index-services-anchor::before,
  .index-services-anchor::after {
    transition: background var(--transition);
  }
  .index-services-item-inner {
    transition: opacity var(--transition);
  }
  .index-services-anchor:hover::before {
    background: var(--color-gray);
  }
  .index-services-anchor:hover::after {
    background: var(--color-primary);
  }
  .index-services-anchor:hover .index-services-item-inner {
    opacity: var(--hover-opacity);
  }
  .index-services-anchor:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .index-services-inner {
    padding-block: calc(280 / var(--lg-base)) calc(340 / var(--lg-base));
  }
  .index-services-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(215 / var(--lg-base)) calc(40 / var(--lg-base));
    margin: calc(285 / var(--lg-base)) 0 0;
  }
  .index-services-item {
    width: calc(33.33334% - (26.75 / var(--lg-base)));
    margin: 0;
  }
  .index-services-anchor::before {
    right: calc(32 / var(--lg-base));
    bottom: calc(-46 / var(--lg-base));
    width: calc(90 / var(--lg-base));
    height: calc(90 / var(--lg-base));
  }
  .index-services-anchor::after {
    right: calc(65 / var(--lg-base));
    bottom: calc(-12 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(21 / var(--lg-base));
  }
  .index-services-item-inner {
    min-height: calc(640 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .index-services-item-inner::before {
    top: calc(-132 / var(--lg-base));
    left: calc(14 / var(--lg-base));
    font-size: calc(180 / var(--lg-base));
  }
  .index-services-image {
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
  }
  .index-services-description {
    padding: calc(34 / var(--lg-base)) calc(48 / var(--lg-base)) 0;
    font-size: calc(20 / var(--lg-base));
  }
  .index-services-subheading {
    padding: calc(6 / var(--lg-base)) calc(24 / var(--lg-base)) calc(32 / var(--lg-base)) calc(48 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
    line-height: 1.5;
  }
  .index-services-bg {
    background: 0 0 / contain no-repeat;
  }
  .index-services-bg:is(.--bg02, .--bg03, .--bg04) {
    display: block;
  }
  .index-services-bg.--bg01 {
    top: calc(-10 / var(--lg-base));
    left: calc(-10 / var(--lg-base));
    width: calc(1060 / var(--lg-base));
    height: calc(820 / var(--lg-base));
    background-image: url(../images/index/bg_services_01.webp);
  }
  .index-services-bg.--bg02 {
    top: calc(620 / var(--lg-base));
    right: calc(52 / var(--lg-base));
    left: auto;
    width: calc(940 / var(--lg-base));
    height: calc(940 / var(--lg-base));
    background-image: url(../images/index/bg_services_02.webp);
  }
  .index-services-bg.--bg03 {
    top: auto;
    right: calc(65 / var(--lg-base));
    bottom: calc(-410 / var(--lg-base));
    left: auto;
    width: calc(650 / var(--lg-base));
    height: calc(650 / var(--lg-base));
    background-image: url(../images/index/bg_services_03.webp);
  }
  .index-services-bg.--bg04 {
    top: auto;
    bottom: calc(-415 / var(--lg-base));
    left: 0;
    width: calc(1070 / var(--lg-base));
    height: calc(1070 / var(--lg-base));
    background-image: url(../images/index/bg_services_04.webp);
  }
}

.index-careers {
  padding-block: calc(190 / var(--sm-base)) calc(175 / var(--sm-base));
  background: #666;
  overflow: hidden;
}
.index-careers-heading {
  color: #fff;
}
.index-careers-description {
  width: 90%;
  margin: calc(90 / var(--sm-base)) auto 0;
  color: #fff;
  font-size: calc(32 / var(--sm-base));
}
.index-careers-more {
  width: calc(364 / var(--sm-base));
  margin: calc(45 / var(--sm-base)) auto 0;
}
.index-careers-images {
  display: flex;
  margin-top: calc(60 / var(--sm-base));
  overflow: hidden;
  pointer-events: none;
  user-select: none;
}
.index-careers-images.js-animation-element {
  translate: 2vw 0;
}
.index-careers-images.js-animation-element.--show {
  translate: 0;
  transition-duration: 2s;
}
.index-careers-images div {
  padding-inline: calc(20 / var(--sm-base));
  animation: index-careers-carousel 40s infinite linear both;
}
@keyframes index-careers-carousel {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}
.index-careers-images picture {
  display: block;
  width: calc(1102 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .index-careers {
    padding-block: calc(215 / var(--lg-base)) calc(260 / var(--lg-base));
  }
  .index-careers-description {
    margin: calc(75 / var(--lg-base)) auto 0;
    font-size: calc(20 / var(--lg-base));
    text-align: center;
    line-height: 1.9;
  }
  .index-careers-more {
    width: calc(380 / var(--lg-base));
    margin: calc(50 / var(--lg-base)) auto 0;
  }
  .index-careers-images {
    margin-top: calc(80 / var(--lg-base));
  }
  .index-careers-images div {
    padding-inline: calc(30 / var(--lg-base));
  }
  .index-careers-images picture {
    width: calc(1901 / var(--lg-base));
  }
}

.index-news {
  position: relative;
  padding-block: calc(220 / var(--sm-base)) calc(180 / var(--sm-base));
  overflow: hidden;
}
.index-news::before,
.index-news::after {
  content: '';
  position: absolute;
  width: calc(556 / var(--sm-base));
  height: calc(360 / var(--sm-base));
  background: url(../images/index/bg_news_01.webp) 0 0 / contain no-repeat;
  pointer-events: none;
}
.index-news::before {
  top: calc(-64 / var(--sm-base));
  right: calc(-98 / var(--sm-base));
}
.index-news::after {
  bottom: calc(-14 / var(--sm-base));
  left: calc(-118 / var(--sm-base));
}
.index-news-list {
  margin-top: calc(100 / var(--sm-base));
}
.index-news-item {
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-default);
}
.index-news-anchor {
  position: relative;
  display: flex;
  align-items: flex-start;
  padding: calc(40 / var(--sm-base)) calc(45 / var(--sm-base)) calc(40 / var(--sm-base)) 0;
}
.index-news-anchor::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: #b2b2b2;
  -webkit-mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
  pointer-events: none;
}
.index-news-thumbnail {
  width: calc(300 / var(--sm-base));
}
.index-news-thumbnail.--none {
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
}
.index-news-thumbnail img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: calc(10 / var(--sm-base));
  aspect-ratio: 640/360;
  object-fit: cover;
}
.index-news-detail {
  flex: 1;
  margin: calc(-3 / var(--sm-base)) 0 0 calc(40 / var(--sm-base));
}
.index-news-date {
  display: inline-block;
  min-width: calc(180 / var(--sm-base));
  padding: calc(12 / var(--sm-base)) calc(6 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-family: var(--font-din);
  font-size: calc(22 / var(--sm-base));
  font-weight: 700;
  letter-spacing: .075em;
  line-height: 1;
  text-align: center;
}
.index-news-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-top: calc(12 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  font-weight: 600;
}
.index-news-more {
  width: calc(364 / var(--sm-base));
  margin: calc(35 / var(--sm-base)) 0 0 auto;
}
.index-news-none {
  margin-top: calc(80 / var(--sm-base));
  text-align: center;
}
@media (hover: hover) and (pointer: fine) {
  .index-news-anchor {
    transition: opacity var(--transition);
  }
  .index-news-anchor:hover {
    opacity: var(--hover-opacity);
  }
  .index-news-anchor:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .index-news {
    padding-block: calc(245 / var(--lg-base)) calc(250 / var(--lg-base));
  }
  .index-news::before,
  .index-news::after {
    width: calc(722 / var(--lg-base));
    height: calc(468 / var(--lg-base));
  }
  .index-news::before {
    top: calc(-77 / var(--lg-base));
    right: calc(-55 / var(--lg-base));
  }
  .index-news::after {
    bottom: calc(-16 / var(--lg-base));
    left: calc(-116 / var(--lg-base));
  }
  .index-news-list {
    margin-top: calc(120 / var(--lg-base));
  }
  .index-news-item {
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .index-news-anchor {
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) 0;
  }
  .index-news-anchor::after {
    right: calc(24 / var(--lg-base));
    width: calc(42 / var(--lg-base));
    height: calc(42 / var(--lg-base));
  }
  .index-news-thumbnail {
    width: calc(320 / var(--lg-base));
  }
  .index-news-thumbnail.--none,
  .index-news-thumbnail img {
    border-radius: calc(10 / var(--lg-base));
  }
  .index-news-detail {
    margin: calc(-2 / var(--lg-base)) 0 0 calc(50 / var(--lg-base));
  }
  .index-news-date {
    min-width: calc(200 / var(--lg-base));
    padding: calc(11 / var(--lg-base)) calc(6 / var(--lg-base)) calc(10 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(22 / var(--lg-base));
  }
  .index-news-title {
    margin-top: calc(12 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .index-news-more {
    width: calc(380 / var(--lg-base));
    margin: calc(50 / var(--lg-base)) 0 0 auto;
  }
  .index-news-more-anchor {
    padding: calc(22 / var(--lg-base)) calc(28 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .index-news-more-anchor::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
  .index-news-none {
    margin-top: calc(160 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
}

.index-instagram {
  padding-block: calc(175 / var(--sm-base)) calc(240 / var(--sm-base));
  background: var(--color-primary);
}
.index-instagram-heading {
  color: #fff;
}
.index-instagram-contents {
  margin: calc(150 / var(--sm-base)) calc(45 / var(--sm-base)) 0;
}
.index-instagram-contents .sb_instagram_header,
.index-instagram-contents #sbi_load {
  display: none;
}
.index-instagram-contents #sb_instagram {
  margin: 0 !important;
}
.index-instagram-contents #sb_instagram #sbi_images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(36 / var(--sm-base)) calc(40 / var(--sm-base)) !important;
  padding: 0;
}
.index-instagram-contents .sbi_photo {
  display: block;
  border-radius: calc(10 / var(--sm-base));
  overflow: hidden;
  opacity: 1 !important;
}
.index-instagram-contents .sbi_photo img {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .index-instagram-contents #sb_instagram .sbi_photo img {
    transition: opacity var(--transition) !important;
  }
  .index-instagram-contents #sb_instagram .sbi_photo:hover img {
    opacity: var(--hover-opacity) !important;
  }
}
@media screen and (min-width: 769px), print {
  .index-instagram {
    padding-block: calc(215 / var(--lg-base)) calc(240 / var(--lg-base));
  }
  .index-instagram-contents {
    margin: calc(110 / var(--lg-base)) 0 0;
  }
  .index-instagram-contents .sbi_photo {
    border-radius: calc(10 / var(--lg-base));
  }
  .index-instagram-contents #sb_instagram #sbi_images {
    grid-template-columns: repeat(4, 1fr);
    gap: calc(40 / var(--lg-base)) !important;
  }
}


/* Elderly welfare, Disability welfare, Elderly supporters, Disability supporters
-------------------------------------------------- */
.m-message-prologue {
  margin-top: calc(90 / var(--sm-base));
}
.m-message-prologue-text {
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.m-message-prologue-text p:not(:first-child) {
  margin-top: calc(15 / var(--sm-base));
}
.m-message-prologue-image {
  margin-top: calc(70 / var(--sm-base));
}
.m-message-prologue-image img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .m-message-prologue {
    margin-top: calc(130 / var(--lg-base));
  }
  .m-message-prologue-row {
    display: flex;
  }
  .m-message-prologue-text {
    flex: 1;
    margin-top: calc(-3 / var(--sm-base));;
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-prologue-text p:not(:first-child) {
    margin-top: calc(15 / var(--lg-base));
  }
  .m-message-prologue-image {
    width: calc(615 / var(--lg-base));
    margin: 0 0 0 calc(35 / var(--lg-base));
  }
  .m-message-prologue-image img {
    border-radius: calc(10 / var(--lg-base));
  }
}

.m-message-heading {
  letter-spacing: .075em;
  line-height: 1.7;
}
@media screen and (min-width: 769px), print {
  .m-message-heading {
    letter-spacing: 0;
  }
}


.m-message-trouble {
  margin-top: calc(160 / var(--sm-base));
}
.m-message-trouble-list {
  margin: calc(85 / var(--sm-base)) 0 0;
  list-style: none;
}
.m-message-trouble-list li {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(145 / var(--sm-base));
  margin-top: calc(40 / var(--sm-base));
  padding: calc(15 / var(--sm-base)) calc(65 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
  text-align: center;
}
.m-message-trouble-comment {
  margin-top: calc(60 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  text-align: center;
}
@media screen and (min-width: 769px), print {
  .m-message-trouble {
    margin-top: calc(110 / var(--lg-base));
  }
  .m-message-trouble-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(15 / var(--lg-base)) calc(20 / var(--lg-base));
    margin: calc(60 / var(--lg-base)) 0 0;
  }
  .m-message-trouble-list li {
    width: calc(25% - (15 / var(--lg-base)));
    min-height: calc(145 / var(--lg-base));
    margin: 0;
    padding: calc(15 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .m-message-trouble-comment {
    margin-top: calc(50 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
}

.m-message-flow {
  margin-top: calc(140 / var(--sm-base));
  padding-block: calc(170 / var(--sm-base)) calc(180 / var(--sm-base));
  background: var(--color-bg-primary) url(../images/common/bg_crane_02.webp) 50% 0 / 100% auto repeat-y;
}
.m-message-flow-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(120 / var(--sm-base)) calc(60 / var(--sm-base));
  margin: calc(130 / var(--sm-base)) 0 0;
  list-style: none;
}
.m-message-flow-list li {
  position: relative;
  width: calc(50% - (30 / var(--sm-base)));
  counter-increment: message;
}
.m-message-flow-list li::before {
  content: counter(message, decimal-leading-zero);
  position: absolute;
  top: calc(-75 / var(--sm-base));
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(80 / var(--sm-base));
  height: calc(80 / var(--sm-base));
  background: #000;
  border-radius: 50%;
  color: #fff;
  font-family: var(--font-din);
  font-size: calc(36 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  text-align: center;
  pointer-events: none;
}
.m-message-flow-icon {
  width: calc(194 / var(--sm-base));
  margin-inline: auto;
}
.m-message-flow-subheading {
  margin-top: calc(35 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
}
.m-message-flow-description {
  margin: calc(15 / var(--sm-base)) calc(-5 / var(--sm-base)) 0;
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.m-message-flow-description a {
  color: var(--color-primary);
}
@media screen and (min-width: 769px), print {
  .m-message-flow {
    margin-top: calc(120 / var(--lg-base));
    padding-block: calc(150 / var(--lg-base)) calc(110 / var(--lg-base));
    background-image: url(../images/common/bg_crane_02_lg.webp);
  }
  .m-message-flow-list {
    gap: calc(100 / var(--lg-base)) calc(60 / var(--lg-base));
    margin: calc(130 / var(--lg-base)) 0 0;
  }
  .m-message-flow-list li {
    width: calc(33.33334% - (40 / var(--lg-base)));
  }
  .m-message-flow-list li::before {
    top: calc(-45 / var(--lg-base));
    width: calc(70 / var(--lg-base));
    height: calc(70 / var(--lg-base));
    font-size: calc(32 / var(--lg-base));
  }
  .m-message-flow-icon {
    width: calc(190 / var(--lg-base));
  }
  .m-message-flow-subheading {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-flow-description {
    margin: calc(15 / var(--lg-base)) 0 0;
    font-size: calc(20 / var(--lg-base));
  }
}

.m-message-services {
  padding-block: calc(180 / var(--sm-base));
  background: var(--color-bg-secondary);
}
.m-message-consultation-heading {
  margin-top: calc(90 / var(--sm-base));
  padding: calc(35 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
  color: #fff;
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
}
.m-message-consultation-contents {
  padding: calc(60 / var(--sm-base)) calc(40 / var(--sm-base));
  background: #fff;
  border-radius: 0 0 calc(10 / var(--sm-base)) calc(10 / var(--sm-base));
}
.m-message-consultation-name {
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
}
.m-message-consultation-name span {
  display: block;
  margin-bottom: calc(10 / var(--sm-base));
  color: var(--color-default);
  font-size: calc(26 / var(--sm-base));
  letter-spacing: 0;
}
.m-message-consultation-description {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.m-message-consultation-location {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
}
.m-message-consultation-contact > div {
  margin-top: calc(30 / var(--sm-base));
  padding-bottom: calc(40 / var(--sm-base));
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.m-message-consultation-contact dt {
  font-size: calc(32 / var(--sm-base));
}
.m-message-consultation-number {
  margin-top: calc(3 / var(--sm-base));
  font-family: var(--font-din);
  font-size: calc(80 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  letter-spacing: .025em;
}
.m-message-consultation-number a {
  text-decoration: none;
}
.m-message-consultation-hour {
  margin-top: calc(5 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
}
.m-message-consultation-note {
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
}
.m-message-consultation-cta {
  margin-top: calc(40 / var(--sm-base));
}
.m-message-consultation-button {
  position: relative;
  display: block;
  padding: calc(41 / var(--sm-base)) calc(90 / var(--sm-base)) calc(41 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.m-message-consultation-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
.m-message-consultation-line .m-message-consultation-button {
  background: #06c655;
}
.m-message-consultation-line p {
  margin-top: calc(15 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
}
.m-message-consultation-form {
  margin-top: calc(40 / var(--sm-base));
}
.m-message-consultation-image {
  margin-top: calc(60 / var(--sm-base));
}
.m-message-consultation-button.--more {
  margin-top: calc(60 / var(--sm-base));
  padding: calc(45 / var(--sm-base)) calc(90 / var(--sm-base)) calc(45 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-primary);
}
@media (hover: hover) and (pointer: fine) {
  .m-message-consultation-button {
    transition: opacity var(--transition);
  }
  .m-message-consultation-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .m-message-services {
    padding-block: calc(140 / var(--lg-base)) calc(160 / var(--lg-base));
  }
  .m-message-consultation-heading {
    margin-top: calc(100 / var(--lg-base));
    padding: calc(46 / var(--lg-base)) calc(80 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
    font-size: calc(40 / var(--lg-base));
  }
  .m-message-consultation-contents {
    padding: calc(55 / var(--lg-base)) calc(80 / var(--lg-base)) calc(70 / var(--lg-base));
    border-radius: 0 0 calc(10 / var(--lg-base)) calc(10 / var(--lg-base));
  }
  .m-message-consultation-name {
    font-size: calc(30 / var(--lg-base));
  }
  .m-message-consultation-name span {
    margin-bottom: calc(2 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-consultation-description {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-consultation-location {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-consultation-contact {
    margin-top: calc(10 / var(--lg-base));
  }
  .m-message-consultation-contact > div {
    display: flex;
    margin-top: calc(25 / var(--lg-base));
    padding-bottom: calc(25 / var(--lg-base));
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .m-message-consultation-contact dt {
    width: calc(420 / var(--lg-base));
    padding: calc(10 / var(--lg-base)) calc(20 / var(--lg-base)) 0 0;
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-consultation-contact dd {
    flex: 1;
  }
  .m-message-consultation-number {
    margin: 0;
    font-size: calc(62 / var(--lg-base));
  }
  .m-message-consultation-number a {
    pointer-events: none;
  }
  .m-message-consultation-hour {
    margin-top: 0;
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-consultation-note {
    font-size: calc(16 / var(--lg-base));
  }
  .m-message-consultation-cta {
    display: flex;
    justify-content: space-between;
    margin-top: calc(50 / var(--lg-base));
  }
  .m-message-consultation-line,
  .m-message-consultation-form {
    width: calc(50% - (15 / var(--lg-base)));
  }
  .m-message-consultation-line p {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
  }
  .m-message-consultation-form {
    margin: 0;
  }
  .m-message-consultation-button {
    padding: calc(37 / var(--lg-base)) calc(90 / var(--lg-base)) calc(37 / var(--lg-base)) calc(32 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-consultation-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
  .m-message-consultation-image {
    margin-top: calc(40 / var(--lg-base));
  }
  .m-message-consultation-button.--more {
    width: calc(380 / var(--lg-base));
    margin: calc(40 / var(--lg-base)) auto 0;
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) calc(32 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-consultation-button.--more::after {
    right: calc(24 / var(--lg-base));
  }
}

.m-message-other-heading {
  position: relative;
  margin-block: calc(80 / var(--sm-base)) calc(50 / var(--sm-base));
  padding: calc(40 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: .05em;
  text-align: center;
}
.m-message-other-heading.--disability-welfare,
.m-message-other-heading.--elderly-supporters,
.m-message-other-heading.--disability-supporters {
  padding: calc(50 / var(--sm-base)) calc(10 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
}
.m-message-other-heading::after {
  content: '';
  position: absolute;
  top: 99.5%;
  left: 50%;
  width: calc(64 / var(--sm-base));
  height: calc(34 / var(--sm-base));
  background: var(--color-primary);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  transform: translateX(-50%);
  pointer-events: none;
}
.m-message-other-item {
  background: #fff;
  margin-top: calc(40 / var(--sm-base));
  border-radius: calc(10 / var(--sm-base));
  overflow: hidden;
}
.m-message-other-detail {
  padding: calc(50 / var(--sm-base)) calc(40 / var(--sm-base)) calc(40 / var(--sm-base));
}
.m-message-other-name {
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
  line-height: 1.3;
}
.m-message-other-name span {
  display: block;
  margin-bottom: calc(20 / var(--sm-base));
  color: var(--color-default);
  font-size: calc(26 / var(--sm-base));
  letter-spacing: 0;
}
.m-message-other-description {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.m-message-other-image {
  position: relative;
}
.m-message-other-more {
  position: absolute;
  bottom: calc(40 / var(--sm-base));
  left: calc(40 / var(--sm-base));
  z-index: 2;
  width: calc(100% - (80 / var(--sm-base)));
  display: block;
  padding: calc(45 / var(--sm-base)) calc(90 / var(--sm-base)) calc(45 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.m-message-other-more::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(35 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .m-message-other-more {
    transition: opacity var(--transition);
  }
  .m-message-other-more:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .m-message-other-heading {
    margin-block: calc(110 / var(--lg-base)) calc(70 / var(--lg-base));
    padding: calc(33 / var(--lg-base)) calc(60 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
  }
  .m-message-other-heading.--disability-welfare,
  .m-message-other-heading.--elderly-supporters,
  .m-message-other-heading.--disability-supporters {
    padding: calc(33 / var(--lg-base)) calc(60 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
  }
  .m-message-other-heading::after {
    width: calc(50 / var(--lg-base));
    height: calc(24 / var(--lg-base));
  }
  .m-message-other-item {
    display: flex;
    margin-top: calc(40 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .m-message-other-detail {
    flex: 1;
    padding: calc(50 / var(--lg-base)) calc(60 / var(--lg-base)) calc(40 / var(--lg-base));
  }
  .m-message-other-name {
    font-size: calc(30 / var(--lg-base));
  }
  .m-message-other-name span {
    margin-bottom: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-other-description {
    margin-top: calc(30 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-other-image {
    width: calc(575 / var(--lg-base));
  }
  .m-message-other-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .m-message-other-more {
    right: calc(45 / var(--lg-base));
    bottom: calc(35 / var(--lg-base));
    left: auto;
    width: calc(380 / var(--lg-base));
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) calc(28 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .m-message-other-more::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}

.m-message-strengths {
  position: relative;
  padding-block: calc(180 / var(--sm-base)) calc(790 / var(--sm-base));
}
.m-message-strengths::before,
.m-message-strengths::after {
  content: '';
  position: absolute;
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
.m-message-strengths::after {
  right: 0;
  bottom: calc(150 / var(--sm-base));
  width: 100%;
  height: auto;
  aspect-ratio: 1500/990;
  background-image: url(../images/common/img_strengths_01.webp);
}
.m-message-strengths-description {
  margin-top: calc(50 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.m-message-strengths-description p {
  margin-top: calc(15 / var(--sm-base));
}
.m-message-strengths-more {
  position: relative;
  display: block;
  margin-top: calc(80 / var(--sm-base));
  padding: calc(38 / var(--sm-base)) calc(45 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  text-decoration: none;
}
.m-message-strengths-more::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(25 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .m-message-strengths-more {
    transition: opacity var(--transition);
  }
  .m-message-strengths-more:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .m-message-strengths {
    padding-block: calc(240 / var(--lg-base)) calc(260 / var(--lg-base));
  }
  .m-message-strengths::before,
  .m-message-strengths::after {
    top: calc(120 / var(--lg-base));
    width: calc(477 / var(--lg-base));
    height: calc(777 / var(--lg-base));
  }
  .m-message-strengths::before {
    left: 0;
    background-image: url(../images/common/img_strengths_01_lg.webp);
  }
  .m-message-strengths::after {
    bottom: auto;
    aspect-ratio: auto;
    background-image: url(../images/common/img_strengths_02_lg.webp);
  }
  .m-message-strengths-description {
    margin-top: calc(50 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .m-message-strengths-description p {
    margin-top: calc(15 / var(--lg-base));
  }
  .m-message-strengths-more {
    width: calc(526 / var(--lg-base));
    margin: calc(70 / var(--lg-base)) auto 0;
    padding: calc(27 / var(--lg-base)) calc(35 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .m-message-strengths-more::after {
    right: calc(30 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}


/* Services
-------------------------------------------------- */
.services-body {
  position: relative;
  padding-block: calc(80 / var(--sm-base)) calc(200 / var(--sm-base));
  background: var(--color-primary);
  overflow: hidden;
}
.services-list {
  position: relative;
  z-index: 2;
  margin-top: calc(-100 / var(--sm-base));
}
.services-item {
  position: relative;
  margin-top: calc(100 / var(--sm-base));
}
.services-anchor {
  position: relative;
  display: block;
  height: 100%;
}
.services-anchor::before,
.services-anchor::after {
  content: '';
  position: absolute;
  pointer-events: none;
}
.services-anchor::before {
  right: calc(34 / var(--sm-base));
  bottom: calc(-50 / var(--sm-base));
  z-index: 2;
  width: calc(100 / var(--sm-base));
  height: calc(100 / var(--sm-base));
  background: #000;
  border-radius: 50%;
}
.services-anchor::after {
  right: calc(70 / var(--sm-base));
  bottom: calc(-12 / var(--sm-base));
  z-index: 3;
  width: calc(24 / var(--sm-base));
  height: calc(23 / var(--sm-base));
  background: #fff;
  -webkit-mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
}
.services-item-inner {
  position: relative;
  height: 100%;
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
}
.services-image {
  display: block;
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
}
.services-description {
  padding: calc(32 / var(--sm-base)) calc(46 / var(--sm-base)) 0;
  font-size: calc(26 / var(--sm-base));
}
.services-subheading {
  padding: calc(6 / var(--sm-base)) calc(12 / var(--sm-base)) 0 calc(46 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.3;
}
.services-detail {
  padding: calc(6 / var(--sm-base)) calc(46 / var(--sm-base)) calc(68 / var(--sm-base));
  font-size: calc(26 / var(--sm-base));
}
.services-detail p {
  margin-top: calc(16 / var(--sm-base));
  line-height: 1.7;
}
.services-bg {
  position: absolute;
  top: calc(600 / var(--sm-base));
  left: 0;
  width: calc(100% + (30 / var(--sm-base)));
  height: 110%;
  background: url(../images/services/bg_all.webp) 0 0 / 100% auto repeat-y;
  pointer-events: none;
}
.services-bg:is(.--bg02, .--bg03, .--bg04) {
  display: none;
}
@media (hover: hover) and (pointer: fine) {
  .services-anchor::before,
  .services-anchor::after {
    transition: background var(--transition);
  }
  .services-item-inner {
    transition: opacity var(--transition);
  }
  .services-anchor:hover::before {
    background: var(--color-gray);
  }
  .services-anchor:hover::after {
    background: var(--color-primary);
  }
  .services-anchor:hover .services-item-inner {
    opacity: var(--hover-opacity);
  }
  .services-anchor:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .services-body {
    padding-block: calc(145 / var(--lg-base)) calc(200 / var(--lg-base));
  }
  .services-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(80 / var(--lg-base)) calc(80 / var(--lg-base));
    margin-top: 0;
  }
  .services-item {
    width: calc(50% - (40 / var(--lg-base)));
    margin: 0;
  }
  .services-anchor::before {
    right: calc(42 / var(--lg-base));
    bottom: calc(-42 / var(--lg-base));
    width: calc(90 / var(--lg-base));
    height: calc(90 / var(--lg-base));
  }
  .services-anchor::after {
    right: calc(75 / var(--lg-base));
    bottom: calc(-8 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(21 / var(--lg-base));
  }
  .services-item-inner {
    min-height: calc(640 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .services-item-inner::before {
    top: calc(-132 / var(--lg-base));
    left: calc(14 / var(--lg-base));
    font-size: calc(180 / var(--lg-base));
  }
  .services-image {
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
  }
  .services-description {
    padding: calc(40 / var(--lg-base)) calc(40 / var(--lg-base)) 0;
    font-size: calc(20 / var(--lg-base));
  }
  .services-subheading {
    padding: calc(6 / var(--lg-base)) calc(40 / var(--lg-base)) 0;
    font-size: calc(32 / var(--lg-base));
    line-height: 1.5;
    letter-spacing: .05em;
  }
  .services-detail {
    padding: calc(6 / var(--lg-base)) calc(40 / var(--lg-base)) calc(46 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail p {
    margin-top: calc(16 / var(--lg-base));
    line-height: 1.8;
  }
  .services-bg {
    background: 0 0 / contain no-repeat;
  }
  .services-bg:is(.--bg02, .--bg03, .--bg04) {
    display: block;
  }
  .services-bg.--bg01 {
    top: calc(140 / var(--lg-base));
    left: calc(20 / var(--lg-base));
    width: calc(1060 / var(--lg-base));
    height: calc(820 / var(--lg-base));
    background-image: url(../images/services/bg_01.webp);
  }
  .services-bg.--bg02 {
    top: calc(1100 / var(--lg-base));
    right: calc(0 / var(--lg-base));
    left: auto;
    width: calc(940 / var(--lg-base));
    height: calc(940 / var(--lg-base));
    background-image: url(../images/services/bg_02.webp);
  }
  .services-bg.--bg03 {
    top: auto;
    right: calc(15 / var(--lg-base));
    bottom: 0;
    left: auto;
    width: calc(650 / var(--lg-base));
    height: calc(650 / var(--lg-base));
    background-image: url(../images/services/bg_03.webp);
  }
  .services-bg.--bg04 {
    top: auto;
    bottom: 0;
    left: 0;
    width: calc(1070 / var(--lg-base));
    height: calc(1070 / var(--lg-base));
    background-image: url(../images/services/bg_04.webp);
  }
}


/* Services detail
-------------------------------------------------- */
.services-detail-prologue {
  margin-top: calc(90 / var(--sm-base));
}
.services-detail-prologue-text {
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-prologue-text p:not(:first-child) {
  margin-top: calc(15 / var(--sm-base));
}
.services-detail-prologue-image {
  margin-top: calc(70 / var(--sm-base));
}
.services-detail-prologue-image img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .services-detail-prologue {
    margin-top: calc(130 / var(--lg-base));
  }
  .services-detail-prologue-row {
    display: flex;
  }
  .services-detail-prologue-text {
    flex: 1;
    margin-top: calc(-3 / var(--sm-base));;
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-prologue-text p:not(:first-child) {
    margin-top: calc(15 / var(--lg-base));
  }
  .services-detail-prologue-image {
    width: calc(615 / var(--lg-base));
    margin: 0 0 0 calc(35 / var(--lg-base));
  }
  .services-detail-prologue-image img {
    border-radius: calc(10 / var(--lg-base));
  }
}

.services-detail-heading {
  font-size: calc(48 / var(--sm-base));
  line-height: 1.5;
  letter-spacing: .05em;
}
@media screen and (min-width: 769px), print {
  .services-detail-heading {
    font-size: calc(40 / var(--lg-base));
    letter-spacing: 0;
  }
}

.services-detail-target {
  margin-top: calc(140 / var(--sm-base));
}
.services-detail-target-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(35 / var(--sm-base));
  margin: calc(100 / var(--sm-base)) 0 0;
  list-style: none;
}
.services-detail-target-list li {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: calc(140 / var(--sm-base));
  padding: calc(40 / var(--sm-base));
  background: #f5f5f5;
  border: calc(3 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
  text-align: center;
}
.services-detail-target-note {
  margin-top: calc(30 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
.services-detail-target-note + .services-detail-target-note {
  margin-top: calc(20 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .services-detail-target {
    margin-top: calc(130 / var(--lg-base));
  }
  .services-detail-target-list {
    gap: calc(26 / var(--lg-base)) calc(30 / var(--lg-base));
    margin: calc(65 / var(--lg-base)) 0 0;
  }
  .services-detail-target-list li {
    width: calc(50% - (15 / var(--lg-base)));
    min-height: calc(130 / var(--lg-base));
    padding: calc(25 / var(--lg-base));
    border-width: calc(2 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.4;
  }
  .services-detail-target-note {
    margin-top: calc(20 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
  }
  .services-detail-target-note + .services-detail-target-note {
    margin-top: calc(10 / var(--lg-base));
  }
}

.services-detail-trouble {
  margin-top: calc(160 / var(--sm-base));
}
.services-detail-trouble-list {
  margin: calc(65 / var(--sm-base)) 0 0;
  list-style: none;
}
.services-detail-trouble-list li {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(145 / var(--sm-base));
  margin-top: calc(40 / var(--sm-base));
  padding: calc(15 / var(--sm-base)) calc(65 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
  text-align: center;
}
.services-detail-trouble-comment {
  margin-top: calc(60 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  text-align: center;
}
@media screen and (min-width: 769px), print {
  .services-detail-trouble {
    margin-top: calc(130 / var(--lg-base));
  }
  .services-detail-trouble-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(15 / var(--lg-base)) calc(20 / var(--lg-base));
    margin: calc(60 / var(--lg-base)) 0 0;
  }
  .services-detail-trouble-list li {
    width: calc(25% - (15 / var(--lg-base)));
    min-height: calc(145 / var(--lg-base));
    margin: 0;
    padding: calc(15 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .services-detail-trouble-comment {
    margin-top: calc(50 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
}

.services-detail-provid-flow {
  margin-top: calc(140 / var(--sm-base));
  padding-block: calc(170 / var(--sm-base)) calc(120 / var(--sm-base));
  background: var(--color-bg-primary) url(../images/common/bg_crane_02.webp) 50% 0 / 100% auto repeat-y;
}
.services-detail-provid-item {
  margin-top: calc(70 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  overflow: hidden;
}
.services-detail-provid-detail {
  padding: calc(35 / var(--sm-base)) calc(35 / var(--sm-base)) calc(50 / var(--sm-base));
}
.services-detail-provid-subheading {
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
  line-height: 1.3;
}
.services-detail-provid-description {
  margin-top: calc(10 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-provid-summary {
  margin-top: calc(60 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
@media screen and (min-width: 769px), print {
  .services-detail-provid-flow {
    margin-top: calc(120 / var(--lg-base));
    padding-block: calc(150 / var(--lg-base)) calc(140 / var(--lg-base));
    background-image: url(../images/common/bg_crane_02_lg.webp);
  }
  .services-detail-provid-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(44 / var(--lg-base)) calc(48 / var(--lg-base));
    margin-top: calc(90 / var(--lg-base));
  }
  .services-detail-provid-item {
    width: calc(50% - (24 / var(--lg-base)));
    margin-top: 0;
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-provid-detail {
    padding: calc(40 / var(--lg-base)) calc(45 / var(--lg-base)) calc(25 / var(--lg-base));
  }
  .services-detail-provid-subheading {
    font-size: calc(30 / var(--lg-base));
  }
  .services-detail-provid-description {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-provid-summary {
    margin-top: calc(40 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
}

.services-detail-flow {
  padding-top: calc(160 / var(--sm-base));
}
.services-detail-flow-lead {
  margin-top: calc(50 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: .025em;
}
.services-detail-flow-lead p {
  margin-top: calc(20 / var(--sm-base));
}
.services-detail-flow-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(120 / var(--sm-base)) calc(60 / var(--sm-base));
  margin: calc(160 / var(--sm-base)) 0 0;
  list-style: none;
}
.services-detail-flow-list li {
  position: relative;
  width: calc(50% - (30 / var(--sm-base)));
  counter-increment: message;
}
.services-detail-flow-list li::before {
  content: counter(message, decimal-leading-zero);
  position: absolute;
  top: calc(-75 / var(--sm-base));
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(80 / var(--sm-base));
  height: calc(80 / var(--sm-base));
  background: #000;
  border-radius: 50%;
  color: #fff;
  font-family: var(--font-din);
  font-size: calc(36 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  text-align: center;
  pointer-events: none;
}
.services-detail-flow-icon {
  width: calc(194 / var(--sm-base));
  margin-inline: auto;
}
.services-detail-flow-subheading {
  margin-top: calc(35 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
  line-height: 1.4;
  text-align: center;
}
.services-detail-flow-description {
  margin: calc(15 / var(--sm-base)) calc(-5 / var(--sm-base)) 0;
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-flow-description a {
  color: var(--color-primary);
}
.services-detail-flow-more {
  position: relative;
  display: block;
  margin-top: calc(60 / var(--sm-base));
  padding: calc(24 / var(--sm-base)) calc(35 / var(--sm-base)) calc(24 / var(--sm-base)) calc(45 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
  text-decoration: none;
}
.services-detail-flow-more::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(30 / var(--sm-base));
  width: calc(50 / var(--sm-base));
  height: calc(50 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-flow-more {
    transition: opacity var(--transition);
  }
  .services-detail-flow-more:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-flow {
    padding-top: calc(160 / var(--lg-base));
  }
  .services-detail-flow-lead {
    margin-top: calc(80 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .services-detail-flow-lead p {
    margin-top: calc(10 / var(--lg-base));
  }
  .services-detail-flow-list {
    gap: calc(130 / var(--lg-base)) calc(60 / var(--lg-base));
    margin: calc(130 / var(--lg-base)) 0 0;
  }
  .services-detail-flow-list li {
    width: calc(33.33334% - (40 / var(--lg-base)));
  }
  .services-detail-flow-list li::before {
    top: calc(-45 / var(--lg-base));
    width: calc(70 / var(--lg-base));
    height: calc(70 / var(--lg-base));
    font-size: calc(32 / var(--lg-base));
  }
  .services-detail-flow-icon {
    width: calc(190 / var(--lg-base));
  }
  .services-detail-flow-subheading {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-flow-description {
    margin: calc(15 / var(--lg-base)) 0 0;
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-flow-more {
    width: fit-content;
    margin: calc(30 / var(--lg-base)) auto 0;
    padding: calc(27 / var(--lg-base)) calc(110 / var(--lg-base)) calc(27 / var(--lg-base)) calc(40 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.4;
  }
  .services-detail-flow-more::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}

.services-detail-access {
  padding-block: calc(160 / var(--sm-base));
  background: var(--color-bg-secondary);
}
.services-detail-access-heading {
  padding: calc(35 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
  color: #fff;
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
}
.services-detail-access-contents {
  padding: calc(60 / var(--sm-base)) calc(40 / var(--sm-base));
  background: #fff;
  border-radius: 0 0 calc(10 / var(--sm-base)) calc(10 / var(--sm-base));
}
.services-detail-access-name {
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
  line-height: 1.3;
}
.services-detail-access-name span {
  display: block;
  margin-bottom: calc(15 / var(--sm-base));
  color: var(--color-default);
  font-size: calc(26 / var(--sm-base));
  letter-spacing: 0;
}
.services-detail-access-location {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
}
.services-detail-access-contact > div {
  margin-top: calc(30 / var(--sm-base));
  padding-bottom: calc(40 / var(--sm-base));
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.services-detail-access-contact dt {
  font-size: calc(32 / var(--sm-base));
}
.services-detail-access-number {
  margin-top: calc(3 / var(--sm-base));
  font-family: var(--font-din);
  font-size: calc(80 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  letter-spacing: .025em;
}
.services-detail-access-number a {
  text-decoration: none;
}
.services-detail-access-hour {
  margin-top: calc(5 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
}
.services-detail-access-note {
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
}
.services-detail-access-cta {
  margin-top: calc(40 / var(--sm-base));
}
.services-detail-access-button {
  position: relative;
  display: block;
  padding: calc(41 / var(--sm-base)) calc(90 / var(--sm-base)) calc(41 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.services-detail-access-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
.services-detail-access-line .services-detail-access-button {
  background: #06c655;
}
.services-detail-access-line p {
  margin-top: calc(15 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
}
.services-detail-access-form {
  margin-top: calc(40 / var(--sm-base));
}
.services-detail-access-map {
  margin-top: calc(60 / var(--sm-base));
}
.services-detail-access-map iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 610/360;
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-access-button {
    transition: opacity var(--transition);
  }
  .services-detail-access-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-access {
    padding-block: calc(160 / var(--lg-base)) calc(170 / var(--lg-base));
  }
  .services-detail-access-heading {
    padding: calc(46 / var(--lg-base)) calc(80 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
    font-size: calc(40 / var(--lg-base));
  }
  .services-detail-access-contents {
    padding: calc(55 / var(--lg-base)) calc(80 / var(--lg-base)) calc(70 / var(--lg-base));
    border-radius: 0 0 calc(10 / var(--lg-base)) calc(10 / var(--lg-base));
  }
  .services-detail-access-name {
    font-size: calc(30 / var(--lg-base));
  }
  .services-detail-access-name span {
    margin-bottom: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-access-description {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-access-location {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-access-contact {
    margin-top: calc(-5 / var(--lg-base));
  }
  .services-detail-access-contact > div {
    display: flex;
    margin-top: calc(25 / var(--lg-base));
    padding-bottom: calc(25 / var(--lg-base));
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .services-detail-access-contact dt {
    width: calc(420 / var(--lg-base));
    padding: calc(10 / var(--lg-base)) calc(20 / var(--lg-base)) 0 0;
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-access-contact dd {
    flex: 1;
  }
  .services-detail-access-number {
    margin: 0;
    font-size: calc(62 / var(--lg-base));
  }
  .services-detail-access-number a {
    pointer-events: none;
  }
  .services-detail-access-hour {
    margin-top: 0;
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-access-note {
    font-size: calc(16 / var(--lg-base));
  }
  .services-detail-access-cta {
    display: flex;
    justify-content: space-between;
    margin-top: calc(50 / var(--lg-base));
  }
  .services-detail-access-line,
  .services-detail-access-form {
    width: calc(50% - (15 / var(--lg-base)));
  }
  .services-detail-access-line p {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
  }
  .services-detail-access-form {
    margin: 0;
  }
  .services-detail-access-button {
    padding: calc(37 / var(--lg-base)) calc(90 / var(--lg-base)) calc(37 / var(--lg-base)) calc(32 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-access-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
  .services-detail-access-map {
    margin-top: calc(40 / var(--lg-base));
  }
  .services-detail-access-map iframe {
    aspect-ratio: 1090/360;
  }
}

.services-detail-faq {
  padding-block: calc(160 / var(--sm-base));
  background: var(--color-bg-primary);
}
.services-detail-faq-item {
  margin-top: calc(60 / var(--sm-base));
  overflow: hidden;
}
.services-detail-faq-item:first-of-type {
  margin-top: calc(80 / var(--sm-base));
}
.services-detail-faq-head {
  position: relative;
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  cursor: pointer;
}
.services-detail-faq-head::before {
  content: 'Q.';
  position: absolute;
  top: calc(34 / var(--sm-base));
  left: calc(25 / var(--sm-base));
  font-family: var(--font-din);
  font-size: calc(42 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}
.services-detail-faq-head div {
  position: relative;
  padding: calc(30 / var(--sm-base)) calc(90 / var(--sm-base)) calc(30 / var(--sm-base)) calc(80 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
}
.services-detail-faq-head div::before,
.services-detail-faq-head div::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(34 / var(--sm-base));
  width: calc(30 / var(--sm-base));
  height: calc(2 / var(--sm-base));
  background: var(--color-primary);
  pointer-events: none;
  transform: translateY(-50%);
}
.services-detail-faq-head div::after {
  transform: translateY(-50%) rotate(90deg);
}
.services-detail-faq-item[open] .services-detail-faq-head div::after {
  opacity: 0;
}
.services-detail-faq-body {
  height: 0;
}
.services-detail-faq-body div {
  padding: calc(36 / var(--sm-base)) calc(30 / var(--sm-base)) 0;
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
@media screen and (min-width: 769px), print {
  .services-detail-faq {
    padding-block: calc(160 / var(--lg-base));
  }
  .services-detail-faq-item {
    margin-top: calc(60 / var(--lg-base));
  }
  .services-detail-faq-item:first-of-type {
    margin-top: calc(80 / var(--lg-base));
  }
  .services-detail-faq-head {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-faq-head::before {
    top: calc(18 / var(--lg-base));
    left: calc(28 / var(--lg-base));
    font-size: calc(32 / var(--lg-base));
  }
  .services-detail-faq-head div {
    padding: calc(15 / var(--lg-base)) calc(80 / var(--lg-base)) calc(15 / var(--lg-base)) calc(80 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.6;
  }
  .services-detail-faq-head div::before,
  .services-detail-faq-head div::after {
    right: calc(30 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(2 / var(--lg-base));
  }
  .services-detail-faq-body div {
    padding: calc(25 / var(--lg-base)) calc(40 / var(--lg-base)) 0;
    font-size: calc(20 / var(--lg-base));
  }
}

.services-detail-attempt {
  padding-block: calc(160 / var(--sm-base));
  background: url(../images/services/bg_attempt_01.webp) 50% 50% / cover no-repeat;
}
.services-detail-attempt-body {
  padding: calc(60 / var(--sm-base)) calc(35 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  box-shadow: 0 0 calc(10 / var(--sm-base)) rgba(51, 51, 51, .4);
}
.services-detail-attempt-lead {
  margin-top: calc(50 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: .025em;
}
.services-detail-attempt-list {
  margin: calc(30 / var(--sm-base)) 0 0;
  list-style: none;
}
.services-detail-attempt-list li {
  position: relative;
  margin-top: calc(20 / var(--sm-base));
  padding-left: calc(75 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
  letter-spacing: .025em;
}
.services-detail-attempt-list li::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: calc(54 / var(--sm-base));
  height: calc(54 / var(--sm-base));
  background: url(../images/services/icn_attempt_01.webp) 0 0 / contain no-repeat;
}
@media screen and (min-width: 769px), print {
  .services-detail-attempt {
    padding-block: calc(160 / var(--lg-base));
    background-image: url(../images/services/bg_attempt_01_lg.webp);
  }
  .services-detail-attempt-body {
    padding: calc(85 / var(--lg-base)) calc(80 / var(--lg-base)) calc(70 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    box-shadow: 0 0 calc(10 / var(--lg-base)) rgba(51, 51, 51, .4);
  }
  .services-detail-attempt-lead {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-attempt-list {
    margin: calc(50 / var(--lg-base)) 0 0;
  }
  .services-detail-attempt-list li {
    margin-top: calc(30 / var(--lg-base));
    padding-left: calc(70 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
    line-height: 1.6;
    letter-spacing: 0;
  }
  .services-detail-attempt-list li::before {
    top: calc(-5 / var(--lg-base));
    left: calc(-5 / var(--lg-base));
    width: calc(50 / var(--lg-base));
    height: calc(50 / var(--lg-base));
  }
}

.services-detail-other {
  padding-block: calc(140 / var(--sm-base));
  background: var(--color-primary);
  color: #fff;
}
.services-detail-other-heading {
  color: #fff;
  font-size: calc(48 / var(--sm-base));
  line-height: 1.5;
}
.services-detail-other-lead {
  margin-top: calc(60 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-other-list {
  display: flex;
  flex-wrap: wrap;
  margin: calc(100 / var(--sm-base)) 0 0;
  gap: calc(60 / var(--sm-base)) calc(32 / var(--sm-base));
  list-style: none;
}
.services-detail-other-list:not(:has(.services-detail-other-item:nth-child(2))) {
  justify-content: center;
}
.services-detail-other-item {
  width: calc(50% - (16 / var(--sm-base)));
}
.services-detail-other-anchor {
  position: relative;
  display: block;
  height: 100%;
}
.services-detail-other-anchor::before,
.services-detail-other-anchor::after {
  content: '';
  position: absolute;
  pointer-events: none;
}
.services-detail-other-anchor::before {
  right: calc(20 / var(--sm-base));
  bottom: calc(-38 / var(--sm-base));
  z-index: 2;
  width: calc(80 / var(--sm-base));
  height: calc(80 / var(--sm-base));
  background: #000;
  border-radius: 50%;
}
.services-detail-other-anchor::after {
  right: calc(48 / var(--sm-base));
  bottom: calc(-6 / var(--sm-base));
  z-index: 3;
  width: calc(20 / var(--sm-base));
  height: calc(19 / var(--sm-base));
  background: #fff;
  -webkit-mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_02.svg) 0 0 / contain no-repeat;
}
.services-detail-other-item-inner {
  position: relative;
  height: 100%;
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
}
.services-detail-other-image {
  display: block;
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
}
.services-detail-other-subheading {
  padding: calc(35 / var(--sm-base)) calc(30 / var(--sm-base)) calc(60 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(26 / var(--sm-base));
  font-weight: 600;
}
.services-detail-other-subheading span {
  display: block;
  margin-bottom: calc(10 / var(--sm-base));
  color: var(--color-default);
  line-height: 1.4;
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-other-anchor::before,
  .services-detail-other-anchor::after {
    transition: background var(--transition);
  }
  .services-detail-other-item-inner {
    transition: opacity var(--transition);
  }
  .services-detail-other-anchor:hover::before {
    background: var(--color-gray);
  }
  .services-detail-other-anchor:hover::after {
    background: var(--color-primary);
  }
  .services-detail-other-anchor:hover .services-detail-other-item-inner {
    opacity: var(--hover-opacity);
  }
  .services-detail-other-anchor:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-other {
    padding-block: calc(140 / var(--lg-base));
  }
  .services-detail-other-heading {
    font-size: calc(40 / var(--lg-base));
    letter-spacing: 0;
  }
  .services-detail-other-lead {
    margin-top: calc(40 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .services-detail-other-list {
    margin: calc(50 / var(--lg-base)) auto 0;
    gap: calc(54 / var(--lg-base)) calc(26 / var(--lg-base));
  }
  .services-detail-other-list:not(:has(.services-detail-other-item:nth-child(3))),
  .services-detail-other-list:has(.services-detail-other-item:nth-child(4)) {
    width: min(100%, calc(816 / var(--lg-base)));
  }
  .services-detail-other-item {
    width: calc(33.33334% - (17.5 / var(--lg-base)));
  }
  .services-detail-other-list:not(:has(.services-detail-other-item:nth-child(3))) .services-detail-other-item,
  .services-detail-other-list:has(.services-detail-other-item:nth-child(4)) .services-detail-other-item {
    width: calc(50% - (13 / var(--lg-base)));
  }
  .services-detail-other-anchor::before {
    right: calc(30 / var(--lg-base));
    bottom: calc(-30 / var(--lg-base));
    width: calc(60 / var(--lg-base));
    height: calc(60 / var(--lg-base));
  }
  .services-detail-other-anchor::after {
    right: calc(52 / var(--lg-base));
    bottom: calc(-8 / var(--lg-base));
    width: calc(16 / var(--lg-base));
    height: calc(15 / var(--lg-base));
  }
  .services-detail-other-item-inner {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-other-image {
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
  }
  .services-detail-other-subheading {
    padding: calc(45 / var(--lg-base)) calc(30 / var(--lg-base)) calc(40 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
    line-height: 1.6;
  }
  .services-detail-other-subheading span {
    margin: calc(5 / var(--lg-base)) calc(-5 / var(--lg-base)) 0 0;
    font-size: calc(20 / var(--lg-base));
  }
}

.services-detail-careers {
  position: relative;
  padding-block: calc(150 / var(--sm-base)) calc(740 / var(--sm-base));
  background: #666;
  color: #fff;
}
.services-detail-careers::before,
.services-detail-careers::after {
  content: '';
  position: absolute;
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
.services-detail-careers::after {
  right: 0;
  bottom: calc(120 / var(--sm-base));
  width: 100%;
  height: auto;
  aspect-ratio: 1500/990;
  background-image: url(../images/common/img_careers_01.webp);
}
.services-detail-careers-heading {
  color: #fff;
  font-size: calc(48 / var(--sm-base));
  letter-spacing: .075em;
}
.services-detail-careers-description {
  margin-top: calc(70 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-careers-more {
  position: relative;
  display: block;
  margin-top: calc(60 / var(--sm-base));
  padding: calc(24 / var(--sm-base)) calc(35 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
  text-decoration: none;
}
.services-detail-careers-more::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(25 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-careers-more {
    transition: opacity var(--transition);
  }
  .services-detail-careers-more:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-careers {
    padding-block: calc(170 / var(--lg-base)) calc(215 / var(--lg-base));
  }
  .services-detail-careers::before,
  .services-detail-careers::after {
    top: calc(90 / var(--lg-base));
    width: calc(515 / var(--lg-base));
    height: calc(601 / var(--lg-base));
  }
  .services-detail-careers::before {
    left: 0;
    background-image: url(../images/common/img_careers_01_lg.webp);
  }
  .services-detail-careers::after {
    bottom: auto;
    aspect-ratio: auto;
    background-image: url(../images/common/img_careers_02_lg.webp);
  }
  .services-detail-careers-heading {
    font-size: calc(60 / var(--lg-base));
    letter-spacing: .025em;
  }
  .services-detail-careers-description {
    margin-top: calc(100 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .services-detail-careers-more {
    width: fit-content;
    margin: calc(50 / var(--lg-base)) auto 0;
    padding: calc(22 / var(--lg-base)) calc(110 / var(--lg-base)) calc(22 / var(--lg-base)) calc(30 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-careers-more::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}

.services-detail-photo {
  margin-top: calc(160 / var(--sm-base));
}
.services-detail-photo-lead {
  margin-top: calc(50 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-photo-list {
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(60 / var(--sm-base));
  gap: calc(40 / var(--sm-base));
}
.services-detail-photo-item {
  position: relative;
  width: calc(50% - (20 / var(--sm-base)));
}
.services-detail-photo-item button {
  position: relative;
  display: block;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  appearance: none;
}
.services-detail-photo-item button:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: calc(66 / var(--sm-base));
  height: calc(66 / var(--sm-base));
  background: url(../images/common/icn_zoom_01.svg) 0 0 / contain no-repeat;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.services-detail-photo-item img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 640/422;
  border-radius: calc(10 / var(--sm-base));
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-photo-item button {
    transition: opacity var(--transition);
  }
  .services-detail-photo-item button:hover {
    opacity: var(--hover-opacity);
  }
  .services-detail-photo-item button:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-photo {
    margin-top: calc(160 / var(--lg-base));
  }
  .services-detail-photo-lead {
    margin-top: calc(80 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .services-detail-photo-list {
    margin-top: calc(60 / var(--lg-base));
    gap: calc(25 / var(--lg-base)) calc(28 / var(--lg-base));
  }
  .services-detail-photo-item {
    width: calc(33.33334% - (19 / var(--lg-base)));
  }
  .services-detail-photo-item button:before {
    width: calc(70 / var(--lg-base));
    height: calc(70 / var(--lg-base));
  }
  .services-detail-photo-item img {
    aspect-ratio: 790/444;
    border-radius: calc(10 / var(--lg-base));
  }
}

.services-detail-instagram {
  padding-block: calc(160 / var(--sm-base));
}
.services-detail-instagram-contents {
  margin: calc(70 / var(--sm-base)) calc(40 / var(--sm-base)) 0;
}
.services-detail-instagram-contents .sb_instagram_header,
.services-detail-instagram-contents #sbi_load {
  display: none;
}
.services-detail-instagram-contents #sb_instagram {
  margin: 0 !important;
}
.services-detail-instagram #sb_instagram #sbi_images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(36 / var(--sm-base)) calc(40 / var(--sm-base));
  padding: 0;
}
.services-detail-instagram .sbi_photo {
  display: block;
  border-radius: calc(10 / var(--sm-base));
  overflow: hidden;
  opacity: 1 !important;
}
.services-detail-instagram .sbi_photo img {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-instagram-contents #sb_instagram .sbi_photo img {
    transition: opacity var(--transition) !important;
  }
  .services-detail-instagram-contents #sb_instagram .sbi_photo:hover img {
    opacity: var(--hover-opacity) !important;
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-instagram {
    padding-block: calc(160 / var(--lg-base));
  }
  .services-detail-instagram-contents {
    margin: calc(80 / var(--lg-base)) 0 0;
  }
  .services-detail-instagram .sbi_photo {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-instagram #sb_instagram #sbi_images {
    grid-template-columns: repeat(4, 1fr);
    gap: calc(40 / var(--lg-base)) !important;
  }
}

.services-detail-price {
  margin-top: calc(160 / var(--sm-base));
}
.services-detail-price-contents {
  margin-top: calc(80 / var(--sm-base));
  padding: calc(50 / var(--sm-base)) calc(40 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
}
.services-detail-price-image button {
  position: relative;
  display: block;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  appearance: none;
}
.services-detail-price-image button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: calc(66 / var(--sm-base));
  height: calc(66 / var(--sm-base));
  background: url(../images/common/icn_zoom_01.svg) 0 0 / contain no-repeat;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.services-detail-price-image img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
.services-detail-price-detail {
  margin-top: calc(10 / var(--sm-base));
}
.services-detail-price-detail > div {
  display: flex;
  padding-block: calc(30 / var(--sm-base));
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.services-detail-price-detail > div > dt {
  width: calc(160 / var(--sm-base));
  padding-left: calc(5 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
}
.services-detail-price-detail > div > dd {
  flex: 1;
  padding-top: calc(5 / var(--sm-base));
}
.services-detail-price-label {
  display: inline-block;
  padding: calc(13 / var(--sm-base)) calc(25 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(24 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
}
.services-detail-price-num {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
}
.services-detail-price-items > div {
  display: flex;
  font-size: calc(32 / var(--sm-base));
  font-weight: 400;
  line-height: 1;
}
.services-detail-price-items > div:not(:first-child) {
  margin-top: calc(20 / var(--sm-base));
}
.services-detail-price-items > div dt {
  width: calc(115 / var(--sm-base));
}
.services-detail-price-items > div dd {
  flex: 1;
}
.services-detail-price-note {
  margin: 0;
  list-style: none;
}
.services-detail-price-note li {
  position: relative;
  margin-top: calc(20 / var(--sm-base));
  padding-left: 1em;
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.services-detail-price-note li::before {
  content: '※';
  position: absolute;
  top: 0;
  left: 0;
}
.services-detail-price-images {
  display: flex;
  flex-wrap: wrap;
  gap: calc(30 / var(--sm-base)) calc(36 / var(--sm-base));
  margin-top: calc(60 / var(--sm-base));
}
.services-detail-price-images button {
  position: relative;
  display: block;
  width: calc(50% - (18 / var(--sm-base)));
  background: none;
  border: none;
  border-radius: 0;
  cursor: pointer;
}
.services-detail-price-images button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: calc(52 / var(--sm-base));
  height: calc(52 / var(--sm-base));
  background: url(../images/common/icn_zoom_01.svg) 0 0 / contain no-repeat;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.services-detail-price-images picture {
  display: block;
}
.services-detail-price-images img {
  border-radius: calc(10 / var(--sm-base));
}
.services-detail-price-comment {
  margin-top: calc(30 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
}
@media (hover: hover) and (pointer: fine) {
  .services-detail-price-image button,
  .services-detail-price-images button {
    transition: opacity var(--transition);
  }
  .services-detail-price-image button:hover,
  .services-detail-price-images button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .services-detail-price {
    margin-top: calc(120 / var(--lg-base));
  }
  .services-detail-price-contents {
    margin-top: calc(100 / var(--lg-base));
    padding: calc(70 / var(--lg-base)) calc(45 / var(--lg-base)) calc(60 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-price-row {
    display: flex;
    align-items: flex-start;
  }
  .services-detail-price-image {
    width: calc(580 / var(--lg-base));
  }
  .services-detail-price-image button::before {
    width: calc(72 / var(--lg-base));
    height: calc(72 / var(--lg-base));
  }
  .services-detail-price-image img {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-price-text {
    flex: 1;
    margin: calc(-50 / var(--lg-base)) 0 0 calc(50 / var(--lg-base));
  }
  .services-detail-price-detail > div {
    padding-block: calc(20 / var(--lg-base));
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .services-detail-price-detail > div > dt {
    width: calc(160 / var(--lg-base));
    margin-top: calc(-5 / var(--lg-base));
    padding-left: 0;
    font-size: calc(28 / var(--lg-base));
  }
  .services-detail-price-detail > div > dd {
    padding-top: calc(5 / var(--lg-base));
  }
  .services-detail-price-label {
    padding: calc(13 / var(--lg-base)) calc(30 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-price-num {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.6;
  }
  .services-detail-price-items > div {
    font-size: calc(20 / var(--lg-base));
  }
  .services-detail-price-items > div:not(:first-child) {
    margin-top: calc(15 / var(--lg-base));
  }
  .services-detail-price-items > div dt {
    width: calc(115 / var(--lg-base));
  }
  .services-detail-price-note {
    margin: calc(20 / var(--lg-base)) 0 0;
  }
  .services-detail-price-note li {
    margin-top: calc(12 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
    line-height: 1.8;
  }
  .services-detail-price-images {
    gap: calc(26 / var(--lg-base));
    margin-top: calc(40 / var(--lg-base));
  }
  .services-detail-price-images button {
    width: calc(33.33334% - (18 / var(--lg-base)));
  }
  .services-detail-price-images button::before {
    width: calc(60 / var(--lg-base));
    height: calc(60 / var(--lg-base));
  }
  .services-detail-price-images img {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-price-comment {
    margin-top: calc(20 / var(--lg-base));
    font-size: calc(22 / var(--lg-base));
  }
}

.services-detail-kitchencar-menu-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(70 / var(--sm-base)) calc(40 / var(--sm-base));
  margin-top: calc(70 / var(--sm-base));
}
.services-detail-kitchencar-menu-item {
  width: calc(50% - (20 / var(--sm-base)));
}
.services-detail-kitchencar-menu-image img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
.services-detail-kitchencar-menu-name {
  margin-top: calc(25 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  text-align: center;
}
.services-detail-kitchencar-menu-note {
  margin-top: calc(40 / var(--sm-base));
}
.services-detail-kitchencar-menu-note p {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
@media screen and (min-width: 769px), print {
  .services-detail-kitchencar-menu-list {
    justify-content: center;
    gap: calc(30 / var(--lg-base)) calc(26 / var(--lg-base));
    margin-top: calc(80 / var(--lg-base));
  }
  .services-detail-kitchencar-menu-item {
    width: calc(33.33334% - (18 / var(--lg-base)));
  }
  .services-detail-kitchencar-menu-image img {
    border-radius: calc(10 / var(--lg-base));
  }
  .services-detail-kitchencar-menu-name {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .services-detail-kitchencar-menu-note {
    margin-top: calc(20 / var(--lg-base));
  }
  .services-detail-kitchencar-menu-note p {
    margin-top: calc(5 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.6;
  }
  .services-detail-kitchencar-menu-note p br {
    display: none;
  }
}


/* Strengths
-------------------------------------------------- */
.strengths-body {
  padding-block: calc(75 / var(--sm-base)) calc(180 / var(--sm-base));
  background: url(../images/common/bg_crane_01.webp) 50% 0 / 100% auto repeat-y;
}
.strengths-lead {
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.strengths-list {
  margin-top: calc(75 / var(--sm-base));
}
.strengths-item {
  margin-top: calc(80 / var(--sm-base));
}
.strengths-image img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
.strengths-heading {
  margin-top: calc(60 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(44 / var(--sm-base));
  font-weight: 600;
  line-height: 1.6;
}
.strengths-subheading {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.7;
}
.strengths-description {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .025em;
}
.strengths-description p {
  margin-top: calc(20 / var(--sm-base));
}
.strengths-description a {
  color: var(--color-primary);
}
@media screen and (min-width: 769px), print {
  .strengths-body {
    padding-block: calc(120 / var(--lg-base)) calc(240 / var(--lg-base));
    background-image: url(../images/common/bg_crane_01_lg.webp);
  }
  .strengths-lead {
    font-size: calc(20 / var(--lg-base));
  }
  .strengths-list {
    display: flex;
    flex-wrap: wrap;
    margin-top: calc(130 / var(--lg-base));
    gap: calc(90 / var(--lg-base)) calc(80 / var(--lg-base));
  }
  .strengths-item {
    width: calc(50% - (40 / var(--lg-base)));
    margin-top: 0;
  }
  .strengths-item:nth-of-type(even) {
    padding-top: calc(160 / var(--lg-base));
  }
  .strengths-image img {
    border-radius: calc(10 / var(--lg-base));
  }
  .strengths-heading {
    margin-top: calc(35 / var(--lg-base));
    font-size: calc(40 / var(--lg-base));
    line-height: 1.5;
  }
  .strengths-subheading {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .strengths-description {
    margin-top: calc(25 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .strengths-description p {
    margin-top: calc(20 / var(--lg-base));
  }
}


/* About
-------------------------------------------------- */
.about-greeting {
  margin-top: calc(100 / var(--sm-base));
}
.about-greeting-head {
  position: relative;
  margin-top: calc(60 / var(--sm-base));
}
.about-greeting-copy {
  position: absolute;
  bottom: calc(30 / var(--sm-base));
  left: calc(36 / var(--sm-base));
  z-index: 2;
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.6;
}
.about-greeting-head img {
  display: block;
  border-radius: calc(10 / var(--sm-base));
}
.about-greeting-comment {
  margin-top: calc(70 / var(--sm-base));
}
.about-greeting-comment p {
  margin-top: calc(15 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.7;
}
.about-greeting-name {
  margin-top: calc(50 / var(--sm-base));
  font-size: calc(36 / var(--sm-base));
  text-align: right;
}
.about-greeting-name span {
  display: block;
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
}
.about-contents {
  position: relative;
  margin-top: calc(140 / var(--sm-base));
  padding-block: calc(180 / var(--sm-base));
  background: var(--color-primary);
}
.about-contents-section {
  position: relative;
  z-index: 2;
}
.about-contents-section:not(:first-of-type) {
  margin-top: calc(95 / var(--sm-base));
}
.about-contents-detail {
  width: 95%;
  margin-left: auto;
  padding: calc(70 / var(--sm-base)) 5% calc(125 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
}
.about-contents-section:nth-of-type(even) .about-contents-detail {
  margin-right: auto;
  margin-left: 0;
  border-radius: 0 calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0;
}
.about-contents-heading {
  margin-bottom: calc(25 / var(--sm-base));
}
.about-contents-detail p {
  margin: calc(15 / var(--sm-base)) 0 0 calc(3 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.75;
}
.about-contents-detail ul {
  margin: 0;
  font-size: calc(32 / var(--sm-base));
  line-height: 1.75;
  list-style: none;
}
.about-contents-detail ul li {
  position: relative;
  margin: calc(15 / var(--sm-base)) 0 0 0;
  padding-left: calc(44 / var(--sm-base));
}
.about-contents-detail ul li::before {
  content: '';
  position: absolute;
  top: calc(15 / var(--sm-base));
  left: calc(4 / var(--sm-base));
  width: calc(28 / var(--sm-base));
  height: calc(28 / var(--sm-base));
  background: var(--color-primary);
  border-radius: 50%;
}
.about-contents-image {
  width: 89.3%;
  margin: calc(-75 / var(--sm-base)) auto 0 0;
}
.about-contents-image img {
  border-radius: 0 calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0;
}
.about-contents-section:nth-of-type(even) .about-contents-image {
  margin: calc(-75 / var(--sm-base)) 0 0 auto;
}
.about-contents-section:nth-of-type(even) .about-contents-image img {
  border-radius: calc(10 / var(--sm-base)) 0 0 calc(10 / var(--sm-base));
}
.about-contents-bg {
  position: absolute;
  top: calc(70 / var(--sm-base));
  left: 0;
  width: 100%;
  height: 110%;
  background: url(../images/about/bg_all.webp) 0 0 / 100% auto repeat-y;
  pointer-events: none;
}
.about-contents-bg:is(.--bg02, .--bg03, .--bg04) {
  display: none;
}
.about-overview {
  margin-top: calc(140 / var(--sm-base));
}
.about-history {
  margin-block: calc(170 / var(--sm-base));
}
.about-overview-list,
.about-history-list {
  margin-top: calc(25 / var(--sm-base));
}
.about-overview-list > div,
.about-history-list > div {
  padding-block: calc(30 / var(--sm-base)) calc(25 / var(--sm-base));
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  font-size: calc(32 / var(--sm-base));
}
.about-overview-list dd,
.about-history-list dd {
  font-weight: 500;
  line-height: 1.7;
}
.about-overview-list ul {
  margin: calc(5 / var(--sm-base)) 0 0;
  list-style: none;
}
.about-overview-list li:not(:first-child) {
  margin-top: calc(22 / var(--sm-base));
}
@media screen and (min-width: 769px), print {
  .about-greeting {
    margin-top: calc(120 / var(--lg-base));
  }
  .about-greeting-head {
    margin-top: calc(100 / var(--lg-base));
  }
  .about-greeting-copy {
    bottom: 50%;
    left: calc(40 / var(--lg-base));
    font-size: calc(36 / var(--lg-base));
    transform: translateY(50%);
  }
  .about-greeting-head img {
    border-radius: calc(10 / var(--lg-base));
  }
  .about-greeting-comment {
    margin-top: calc(45 / var(--lg-base));
  }
  .about-greeting-comment p {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .about-greeting-name {
    margin-top: calc(20 / var(--lg-base));
    font-size: calc(27 / var(--lg-base));
    line-height: 1.6;
  }
  .about-greeting-name span {
    font-size: calc(20 / var(--lg-base));
  }
  .about-contents {
    margin-top: calc(130 / var(--lg-base));
    padding-block: calc(160 / var(--lg-base)) calc(190 / var(--lg-base));
  }
  .about-contents-section:not(:first-of-type) {
    margin-top: calc(95 / var(--lg-base));
  }
  .about-contents-section:not(:first-of-type) {
    margin-top: calc(160 / var(--lg-base));
  }
  .about-contents-detail {
    width: 58.2%;
    padding: calc(95 / var(--lg-base)) calc(120 / var(--lg-base)) calc(100 / var(--lg-base)) calc(210 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
  }
  .about-contents-section:nth-of-type(even) .about-contents-detail {
    width: 60.9%;
    padding: calc(95 / var(--lg-base)) calc(230 / var(--lg-base)) calc(110 / var(--lg-base)) calc(145 / var(--lg-base));
    border-radius: 0 calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0;
  }
  .about-contents-heading {
    margin-bottom: calc(35 / var(--lg-base));
    text-align: left;
  }
  .about-contents-detail p {
    margin: calc(15 / var(--lg-base)) 0 0 calc(3 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .about-contents-detail ul {
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .about-contents-detail ul li {
    margin: calc(15 / var(--lg-base)) 0 0 0;
    padding-left: calc(28 / var(--lg-base));
  }
  .about-contents-detail ul li::before {
    top: calc(10 / var(--lg-base));
    left: calc(4 / var(--lg-base));
    width: calc(17 / var(--lg-base));
    height: calc(17 / var(--lg-base));
  }
  .about-contents-image {
    width: 49.2%;
    margin-top: calc(-435 / var(--lg-base));
  }
  .about-contents-image img {
    border-radius: 0 calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0;
  }
  .about-contents-section:nth-of-type(even) .about-contents-image {
    width: 46.4%;
    margin-top: calc(-455 / var(--lg-base));
  }
  .about-contents-section:nth-of-type(even) .about-contents-image img {
    border-radius: calc(10 / var(--lg-base)) 0 0 calc(10 / var(--lg-base));
  }
  .about-contents-bg {
    background: 0 0 / contain no-repeat;
  }
  .about-contents-bg:is(.--bg02, .--bg03, .--bg04) {
    display: block;
  }
  .about-contents-bg.--bg01 {
    top: calc(-140 / var(--lg-base));
    left: calc(20 / var(--lg-base));
    width: calc(1060 / var(--lg-base));
    height: calc(820 / var(--lg-base));
    background-image: url(../images/about/bg_01.webp);
  }
  .about-contents-bg.--bg02 {
    top: calc(520 / var(--lg-base));
    right: calc(0 / var(--lg-base));
    left: auto;
    width: calc(940 / var(--lg-base));
    height: calc(940 / var(--lg-base));
    background-image: url(../images/about/bg_02.webp);
  }
  .about-contents-bg.--bg03 {
    top: auto;
    bottom: calc(-800 / var(--lg-base));
    left: 0;
    width: calc(1070 / var(--lg-base));
    height: calc(1070 / var(--lg-base));
    background-image: url(../images/about/bg_04.webp);
  }
  .about-overview {
    margin-top: calc(160 / var(--lg-base));
  }
  .about-history {
    margin-block: calc(130 / var(--lg-base)) calc(210 / var(--lg-base));
  }
  .about-overview-list,
  .about-history-list {
    margin-top: calc(70 / var(--lg-base));
  }
  .about-overview-list > div,
  .about-history-list > div {
    display: flex;
    padding-block: calc(32 / var(--lg-base)) calc(27 / var(--lg-base));
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .about-overview-list dt,
  .about-history-list dt {
    width: calc(320 / var(--lg-base));
    padding-inline: calc(5 / var(--lg-base)) calc(20 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .about-overview-list dd,
  .about-history-list dd {
    flex: 1;
    padding-top: calc(3 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .about-overview-list ul {
    margin: 0;
  }
  .about-overview-list li:not(:first-child) {
    margin-top: calc(2 / var(--lg-base));
  }
}


/* Careers
-------------------------------------------------- */
.careers-prologue {
  position: relative;
  padding-block: calc(90 / var(--sm-base)) calc(740 / var(--sm-base));
}
.careers-prologue::before,
.careers-prologue::after {
  content: '';
  position: absolute;
  background-position: 0 0;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
.careers-prologue::after {
  right: 0;
  bottom: calc(165 / var(--sm-base));
  width: 100%;
  height: auto;
  aspect-ratio: 1500/990;
  background-image: url(../images/careers/img_prologue_01.webp);
}
.careers-prologue-heading {
  margin-bottom: calc(40 / var(--sm-base));
  line-height: 1.6;
  text-align: left;
}
.careers-prologue p {
  margin-top: calc(15 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.careers-heading {
  position: relative;
  font-size: calc(48 / var(--sm-base));
  line-height: 1.6;
}
.careers-heading::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(320 / var(--sm-base));
  height: calc(193 / var(--sm-base));
  background: url(../images/careers/icn_heading_01.svg) 0 0 / contain no-repeat;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.careers-heading span {
  position: relative;
  z-index: 2;
}
.careers-point {
  position: relative;
  padding-block: calc(170 / var(--sm-base)) calc(140 / var(--sm-base));
  background: linear-gradient(90deg, #dc2850, #f482a0);
}
.careers-point::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/careers/bg_01.webp) 0 0 / 100% auto repeat-y;
  pointer-events: none;
}
.careers-point-inner {
  position: relative;
  z-index: 2;
}
.careers-point-heading {
  color: #fff;
}
.careers-point-list {
  margin-top: calc(110 / var(--sm-base));
}
.careers-point-item {
  margin-top: calc(90 / var(--sm-base));
  color: #fff;
}
.careers-point-subheading {
  padding: calc(16 / var(--sm-base)) calc(24 / var(--sm-base));
  border: calc(3 / var(--sm-base)) solid #fff;
  border-radius: calc(10 / var(--sm-base));
  font-size: calc(40 / var(--sm-base));
  font-weight: 600;
}
.careers-point-copy {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: .05em;
}
.careers-point-description {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: .05em;
}
.careers-point-description a {
  color: #fff;
}
.careers-desired {
  padding-block: calc(170 / var(--sm-base)) calc(190 / var(--sm-base));
  background: #fff url(../images/careers/bg_desired_01.webp) 0 0 / 100% auto no-repeat;
}
.careers-desired-list {
  margin-top: calc(90 / var(--sm-base));
  list-style: none;
}
.careers-desired-list li {
  position: relative;
  counter-increment: careers-desired;
  margin-top: calc(45 / var(--sm-base));
  padding: calc(3 / var(--sm-base)) 0 0 calc(100 / var(--sm-base));
  font-size: calc(36 / var(--sm-base));
  line-height: 1.8;
}
.careers-desired-list li span {
  font-size: calc(24 / var(--sm-base));
}
.careers-desired-list li::before {
  content: counter(careers-desired, decimal-leading-zero);
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(72 / var(--sm-base));
  height: calc(72 / var(--sm-base));
  border: calc(4 / var(--sm-base)) solid var(--color-default);
  border-radius: 50%;
  font-family: var(--font-din);
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
  line-height: 1;
}
.careers-desired-credo {
  margin-top: calc(160 / var(--sm-base));
  padding: calc(90 / var(--sm-base)) calc(40 / var(--sm-base)) calc(70 / var(--sm-base));
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  box-shadow: 0 0 calc(10 / var(--sm-base)) rgba(51, 51, 51, .4);
}
.careers-desired-credo-heading {
  color: var(--color-primary);
  font-size: calc(48 / var(--sm-base));
  font-weight: 600;
  letter-spacing: .05em;
  text-align: center;
}
.careers-desired-credo-list {
  margin-top: calc(35 / var(--sm-base));
}
.careers-desired-credo-list li {
  position: relative;
  counter-increment: careers-credo;
  margin-top: calc(15 / var(--sm-base));
  padding-left: calc(75 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.careers-desired-credo-list li::before {
  content: counter(careers-credo) '.';
  position: absolute;
  top: calc(10 / var(--sm-base));
  left: 0;
  color: var(--color-primary);
  font-family: var(--font-din);
  font-size: calc(42 / var(--sm-base));
  font-weight: 600;
  line-height: 1;
}
.careers-environment {
  padding-block: calc(140 / var(--sm-base));
  background: #fef2f5;
}
.careers-environment-subheading {
  margin-top: calc(50 / var(--sm-base));
  padding-bottom: calc(12 / var(--sm-base));
  border-bottom: calc(3 / var(--sm-base)) solid var(--color-primary);
  color: var(--color-primary);
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
}
.careers-environment-detail {
  margin-top: calc(70 / var(--sm-base));
}
.careers-environment-detail > div {
  margin-top: calc(55 / var(--sm-base));
}
.careers-environment-detail dt {
  padding: calc(7 / var(--sm-base));
  background: #fff;
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
  text-align: center;
}
.careers-environment-detail dd {
  margin-top: calc(35 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.careers-recruitment {
  padding-block: calc(190 / var(--sm-base));
}
.careers-recruitment-item {
  margin-top: calc(30 / var(--sm-base));
  overflow: hidden;
}
.careers-recruitment-item:first-of-type {
  margin-top: calc(150 / var(--sm-base));
}
.careers-recruitment-head {
  position: relative;
  background: #fef2f5;
  border-radius: calc(10 / var(--sm-base));
  cursor: pointer;
}
.careers-recruitment-head div {
  position: relative;
  padding: calc(30 / var(--sm-base)) calc(90 / var(--sm-base)) calc(30 / var(--sm-base)) calc(30 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
}
.careers-recruitment-head div::before,
.careers-recruitment-head div::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(34 / var(--sm-base));
  width: calc(30 / var(--sm-base));
  height: calc(2 / var(--sm-base));
  background: var(--color-primary);
  pointer-events: none;
  transform: translateY(-50%);
}
.careers-recruitment-head div::after {
  transform: translateY(-50%) rotate(90deg);
}
.careers-recruitment-item[open] .careers-recruitment-head div::after {
  opacity: 0;
}
.careers-recruitment-body {
  height: 0;
}
.careers-recruitment-body dl {
  padding: calc(10 / var(--sm-base)) calc(20 / var(--sm-base)) 0;
  font-size: calc(32 / var(--sm-base));
}
.careers-recruitment-body dl > div {
  padding-block: calc(30 / var(--sm-base));
}
.careers-recruitment-body dl > div:not(:first-child) {
  border-top: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.careers-recruitment-body dl dt {
  font-weight: 600;
}
.careers-recruitment-body dl dd {
  font-weight: 500;
  line-height: 1.8;
}
.careers-recruitment-body dl dd p:not(:first-child) {
  margin-top: calc(15 / var(--sm-base));
}
.careers-recruitment-none {
  margin-top: calc(180 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  text-align: center;
}
.careers-faq {
  padding-block: calc(160 / var(--sm-base));
  background: var(--color-bg-primary);
}
.careers-faq-item {
  margin-top: calc(60 / var(--sm-base));
  overflow: hidden;
}
.careers-faq-item:first-of-type {
  margin-top: calc(80 / var(--sm-base));
}
.careers-faq-head {
  position: relative;
  background: #fff;
  border-radius: calc(10 / var(--sm-base));
  cursor: pointer;
}
.careers-faq-head::before {
  content: 'Q.';
  position: absolute;
  top: calc(34 / var(--sm-base));
  left: calc(25 / var(--sm-base));
  font-family: var(--font-din);
  font-size: calc(42 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  pointer-events: none;
}
.careers-faq-head div {
  position: relative;
  padding: calc(30 / var(--sm-base)) calc(90 / var(--sm-base)) calc(30 / var(--sm-base)) calc(80 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  line-height: 1.6;
}
.careers-faq-head div::before,
.careers-faq-head div::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(34 / var(--sm-base));
  width: calc(30 / var(--sm-base));
  height: calc(2 / var(--sm-base));
  background: var(--color-primary);
  pointer-events: none;
  transform: translateY(-50%);
}
.careers-faq-head div::after {
  transform: translateY(-50%) rotate(90deg);
}
.careers-faq-item[open] .careers-faq-head div::after {
  opacity: 0;
}
.careers-faq-body {
  height: 0;
}
.careers-faq-body div {
  padding: calc(26 / var(--sm-base)) calc(30 / var(--sm-base)) 0;
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.careers-apply {
  position: relative;
  padding-block: calc(170 / var(--sm-base)) calc(180 / var(--sm-base));
  background: linear-gradient(90deg, #dc2850, #f482a0);
}
.careers-apply::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/careers/bg_01.webp) 0 calc(-60 / var(--sm-base)) / 100% auto repeat-y;
  pointer-events: none;
}
.careers-apply-inner {
  position: relative;
  z-index: 2;
}
.careers-apply-heading {
  padding: calc(35 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base)) calc(10 / var(--sm-base)) 0 0;
  color: #fff;
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
}
.careers-apply-contents {
  padding: calc(55 / var(--sm-base)) calc(40 / var(--sm-base)) calc(70 / var(--sm-base));
  background: #fff;
  border-radius: 0 0 calc(10 / var(--sm-base)) calc(10 / var(--sm-base));
}
.careers-apply-lead {
  font-size: calc(32 / var(--sm-base));
  line-height: 1.8;
  letter-spacing: .025em;
}
.careers-apply-contact {
  margin-top: calc(30 / var(--sm-base));
  border-top: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.careers-apply-contact > div {
  margin-top: calc(40 / var(--sm-base));
  padding-bottom: calc(30 / var(--sm-base));
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
}
.careers-apply-contact dt {
  font-size: calc(32 / var(--sm-base));
}
.careers-apply-number {
  margin-top: calc(3 / var(--sm-base));
  font-family: var(--font-din);
  font-size: calc(80 / var(--sm-base));
  font-weight: 700;
  line-height: 1;
  letter-spacing: .025em;
}
.careers-apply-number a {
  text-decoration: none;
}
.careers-apply-hour {
  margin-top: calc(10 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
}
.careers-apply-cta {
  margin-top: calc(40 / var(--sm-base));
}
.careers-apply-button {
  position: relative;
  display: block;
  padding: calc(41 / var(--sm-base)) calc(90 / var(--sm-base)) calc(41 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(32 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.careers-apply-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
.careers-apply-line .careers-apply-button {
  background: #06c655;
}
.careers-apply-line p {
  margin-top: calc(15 / var(--sm-base));
  font-size: calc(24 / var(--sm-base));
  font-weight: 500;
}
.careers-apply-form {
  margin-top: calc(40 / var(--sm-base));
}
@media (hover: hover) and (pointer: fine) {
  .careers-apply-button {
    transition: opacity var(--transition);
  }
  .careers-apply-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .careers-prologue {
    padding-block: calc(190 / var(--lg-base)) calc(220 / var(--lg-base));
  }
  .careers-prologue::before,
  .careers-prologue::after {
    top: calc(160 / var(--lg-base));
    width: calc(475 / var(--lg-base));
    height: calc(778 / var(--lg-base));
  }
  .careers-prologue::before {
    left: 0;
    background-image: url(../images/careers/img_prologue_01_lg.webp);
  }
  .careers-prologue::after {
    bottom: auto;
    aspect-ratio: auto;
    background-image: url(../images/careers/img_prologue_02_lg.webp);
  }
  .careers-prologue-inner {
    width: 41.7%;
  }
  .careers-prologue-heading {
    margin-bottom: calc(70 / var(--lg-base));
    line-height: 1.7;
  }
  .careers-prologue p {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    font-weight: 500;
    line-height: 1.8;
  }
  .careers-heading {
    font-size: calc(40 / var(--lg-base));
    line-height: 1.6;
  }
  .careers-heading::before {
    width: calc(252 / var(--lg-base));
    height: calc(152 / var(--lg-base));
  }
  .careers-point {
    padding-block: calc(150 / var(--lg-base)) calc(165 / var(--lg-base));
  }
  .careers-point::before {
    background-image: url(../images/careers/bg_01_lg.webp);
    background-repeat: no-repeat;
  }
  .careers-point-list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(140 / var(--lg-base)) calc(76 / var(--lg-base));
    margin-top: calc(120 / var(--lg-base));
  }
  .careers-point-item {
    width: calc(50% - (38 / var(--lg-base)));
    margin: 0;
  }
  .careers-point-subheading {
    padding: calc(15 / var(--lg-base)) calc(20 / var(--lg-base));
    border-width: calc(2 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(32 / var(--lg-base));
  }
  .careers-point-copy {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.7;
  }
  .careers-point-description {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    letter-spacing: 0;
  }
  .careers-desired {
    padding-block: calc(140 / var(--lg-base)) calc(160 / var(--lg-base));
    background-image: url(../images/careers/bg_desired_01_lg.webp);
  }
  .careers-desired-inner {
    width: 41.7%;
  }
  .careers-desired-list {
    margin-top: calc(140 / var(--lg-base));
  }
  .careers-desired-list li {
    margin-top: calc(45 / var(--lg-base));
    padding: calc(2 / var(--lg-base)) 0 0 calc(84 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
  }
  .careers-desired-list li span {
    font-size: calc(20 / var(--lg-base));
  }
  .careers-desired-list li br {
    display: none;
  }
  .careers-desired-list li::before {
    width: calc(60 / var(--lg-base));
    height: calc(60 / var(--lg-base));
    border-width: calc(3 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .careers-desired-credo {
    margin-top: calc(60 / var(--lg-base));
    padding: calc(60 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    box-shadow: 0 0 calc(10 / var(--lg-base)) rgba(51, 51, 51, .4);
  }
  .careers-desired-credo-heading {
    font-size: calc(30 / var(--lg-base));
  }
  .careers-desired-credo-list {
    margin-top: calc(40 / var(--lg-base));
  }
  .careers-desired-credo-list li {
    margin-top: calc(15 / var(--lg-base));
    padding-left: calc(45 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.7;
  }
  .careers-desired-credo-list li::before {
    top: calc(2 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
  }
  .careers-environment {
    padding-block: calc(140 / var(--lg-base));
  }
  .careers-environment-subheading {
    margin-top: calc(70 / var(--lg-base));
    padding-bottom: calc(15 / var(--lg-base));
    border-bottom-width: calc(2 / var(--lg-base));
    font-size: calc(30 / var(--lg-base));
  }
  .careers-environment-subheading:nth-of-type(1) {
    margin-top: calc(110 / var(--lg-base));
  }
  .careers-environment-detail {
    display: flex;
    flex-wrap: wrap;
    gap: calc(40 / var(--lg-base)) calc(46 / var(--lg-base));
    margin-top: calc(40 / var(--lg-base))
  }
  .careers-environment-detail > div {
    width: calc(33.33334% - (31 / var(--lg-base)));
    margin: 0;
  }
  .careers-environment-detail dt {
    padding: calc(5 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .careers-environment-detail dd {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .careers-recruitment {
    padding-block: calc(140 / var(--lg-base));
  }
  .careers-recruitment-item {
    margin-top: calc(30 / var(--lg-base));
    overflow: hidden;
  }
  .careers-recruitment-item:first-of-type {
    margin-top: calc(130 / var(--lg-base));
  }
  .careers-recruitment-head {
    border-radius: calc(10 / var(--lg-base));
  }
  .careers-recruitment-head div {
    padding: calc(15 / var(--lg-base)) calc(80 / var(--lg-base)) calc(15 / var(--lg-base)) calc(30 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.6;
  }
  .careers-recruitment-head div::before,
  .careers-recruitment-head div::after {
    right: calc(30 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(2 / var(--lg-base));
  }
  .careers-recruitment-body dl {
    padding: 0 calc(50 / var(--lg-base)) 0;
    font-size: calc(20 / var(--lg-base));
  }
  .careers-recruitment-body dl > div {
    display: flex;
    padding-block: calc(30 / var(--lg-base));
  }
  .careers-recruitment-body dl > div:not(:first-child) {
    border-top-width: calc(1 / var(--lg-base));
  }
  .careers-recruitment-body dl dt {
    width: calc(190 / var(--lg-base));
    padding-right: calc(20 / var(--lg-base));
  }
  .careers-recruitment-body dl dd {
    flex: 1;
  }
  .careers-recruitment-body dl dd p:not(:first-child) {
    margin-top: 0;
  }
  .careers-recruitment-none {
    margin-top: calc(160 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
  .careers-faq {
    padding-block: calc(140 / var(--lg-base));
  }
  .careers-faq-item {
    margin-top: calc(60 / var(--lg-base));
  }
  .careers-faq-item:first-of-type {
    margin-top: calc(120 / var(--lg-base));
  }
  .careers-faq-head {
    border-radius: calc(10 / var(--lg-base));
  }
  .careers-faq-head::before {
    top: calc(18 / var(--lg-base));
    left: calc(28 / var(--lg-base));
    font-size: calc(32 / var(--lg-base));
  }
  .careers-faq-head div {
    padding: calc(15 / var(--lg-base)) calc(80 / var(--lg-base)) calc(15 / var(--lg-base)) calc(80 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
    line-height: 1.6;
  }
  .careers-faq-head div::before,
  .careers-faq-head div::after {
    right: calc(30 / var(--lg-base));
    width: calc(22 / var(--lg-base));
    height: calc(2 / var(--lg-base));
  }
  .careers-faq-body div {
    padding: calc(25 / var(--lg-base)) calc(40 / var(--lg-base)) 0;
    font-size: calc(20 / var(--lg-base));
  }
  .careers-apply {
    padding-block: calc(160 / var(--lg-base));
  }
  .careers-apply::before {
    background-image: url(../images/careers/bg_01_lg.webp);
    background-position: 0 0;
    background-repeat: no-repeat;
  }
  .careers-apply-heading {
    padding: calc(46 / var(--lg-base)) calc(80 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base)) calc(10 / var(--lg-base)) 0 0;
    font-size: calc(40 / var(--lg-base));
  }
  .careers-apply-contents {
    padding: calc(55 / var(--lg-base)) calc(80 / var(--lg-base)) calc(60 / var(--lg-base));
    border-radius: 0 0 calc(10 / var(--lg-base)) calc(10 / var(--lg-base));
  }
  .careers-apply-lead {
    font-size: calc(20 / var(--lg-base));
  }
  .careers-apply-contact {
    margin-top: calc(30 / var(--lg-base));
    border-top-width: calc(1 / var(--lg-base));
  }
  .careers-apply-contact > div {
    display: flex;
    margin-top: calc(30 / var(--lg-base));
    padding-bottom: calc(30 / var(--lg-base));
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .careers-apply-contact dt {
    width: calc(420 / var(--lg-base));
    padding: calc(10 / var(--lg-base)) calc(20 / var(--lg-base)) 0 0;
    font-size: calc(26 / var(--lg-base));
  }
  .careers-apply-contact dd {
    flex: 1;
  }
  .careers-apply-number {
    margin: 0;
    font-size: calc(62 / var(--lg-base));
  }
  .careers-apply-number a {
    pointer-events: none;
  }
  .careers-apply-hour {
    margin-top: 0;
    font-size: calc(26 / var(--lg-base));
  }
  .careers-apply-cta {
    display: flex;
    justify-content: space-between;
    margin-top: calc(40 / var(--lg-base));
  }
  .careers-apply-line,
  .careers-apply-form {
    width: calc(50% - (15 / var(--lg-base)));
  }
  .careers-apply-line p {
    margin-top: calc(15 / var(--lg-base));
    font-size: calc(16 / var(--lg-base));
  }
  .careers-apply-form {
    margin: 0;
  }
  .careers-apply-button {
    padding: calc(37 / var(--lg-base)) calc(90 / var(--lg-base)) calc(37 / var(--lg-base)) calc(32 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .careers-apply-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}


/* News
-------------------------------------------------- */
.news-body {
  position: relative;
  padding-block: calc(40 / var(--sm-base)) calc(160 / var(--sm-base));
}
.news-item {
  border-bottom: calc(1 / var(--sm-base)) solid var(--color-default);
}
.news-anchor {
  position: relative;
  display: flex;
  align-items: flex-start;
  padding: calc(40 / var(--sm-base)) calc(45 / var(--sm-base)) calc(40 / var(--sm-base)) 0;
}
.news-anchor::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: #b2b2b2;
  -webkit-mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
  pointer-events: none;
}
.news-thumbnail {
  width: calc(300 / var(--sm-base));
}
.news-thumbnail.--none {
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
}
.news-thumbnail img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: calc(10 / var(--sm-base));
  aspect-ratio: 640/360;
  object-fit: cover;
}
.news-detail {
  flex: 1;
  margin: calc(-3 / var(--sm-base)) 0 0 calc(40 / var(--sm-base));
}
.news-date {
  display: inline-block;
  min-width: calc(180 / var(--sm-base));
  padding: calc(12 / var(--sm-base)) calc(6 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-family: var(--font-din);
  font-size: calc(22 / var(--sm-base));
  font-weight: 700;
  letter-spacing: .075em;
  line-height: 1;
  text-align: center;
}
.news-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-top: calc(12 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  font-weight: 600;
}
.news-side,
.news-side-block + .news-side-block {
  margin-top: calc(100 / var(--sm-base));
}
.news-side-heading {
  position: relative;
  padding-top: calc(24 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
}
.news-side-heading::before,
.news-side-heading::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: calc(3 / var(--sm-base));
  pointer-events: none;
}
.news-side-heading::before {
  width: 100%;
  background: var(--color-border-primary);
}
.news-side-heading::after {
  z-index: 2;
  width: calc(90 / var(--sm-base));
  background: var(--color-primary);
}
.news-side-category {
  margin-top: calc(36 / var(--sm-base));
}
.news-side-category li:not(:first-child) {
  margin-top: calc(26 / var(--sm-base));
}
.news-side-category a {
  display: block;
  padding: calc(28 / var(--sm-base)) calc(40 / var(--sm-base));
  background: #fff;
  border: calc(2 / var(--sm-base)) solid var(--color-border-secondary);
  border-radius: calc(10 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  text-decoration: none;
}
.news-side-category a.--current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.news-none {
  padding-block: calc(40 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
}
@media (hover: hover) and (pointer: fine) {
  .news-anchor,
  .news-side-category a {
    transition: opacity var(--transition);
  }
  .news-anchor:hover,
  .news-side-category a:hover {
    opacity: var(--hover-opacity);
  }
  .news-anchor:hover img {
    opacity: 1;
  }
}
@media screen and (min-width: 769px), print {
  .news-body {
    padding-block: calc(100 / var(--lg-base)) calc(180 / var(--lg-base));
    background: url(../images/common/bg_crane_01_lg.webp) 50% 0 / 100% auto repeat-y;
  }
  .news-body.--article {
    background: none;
  }
  .news-container {
    display: flex;
    flex-direction: row-reverse;
  }
  .news-main {
    flex: 1;
    margin-top: calc(-30 / var(--lg-base));
  }
  .news-item {
    border-bottom-width: calc(1 / var(--lg-base));
  }
  .news-anchor {
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) 0;
  }
  .news-anchor::after {
    right: calc(24 / var(--lg-base));
    width: calc(42 / var(--lg-base));
    height: calc(42 / var(--lg-base));
  }
  .news-thumbnail {
    width: calc(320 / var(--lg-base));
  }
  .news-thumbnail.--none,
  .news-thumbnail img {
    border-radius: calc(10 / var(--lg-base));
  }
  .news-detail {
    margin: calc(-2 / var(--lg-base)) 0 0 calc(30 / var(--lg-base));
  }
  .news-date {
    min-width: calc(180 / var(--lg-base));
    padding: calc(11 / var(--lg-base)) calc(6 / var(--lg-base)) calc(10 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .news-title {
    margin-top: calc(12 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .news-side {
    width: calc(350 / var(--lg-base));
    margin: calc(5 / var(--lg-base)) calc(60 / var(--lg-base)) 0 0;
  }
  .news-side-block + .news-side-block {
    margin-top: calc(60 / var(--lg-base));
  }
  .news-side-heading {
    padding-top: calc(18 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
  .news-side-heading::before,
  .news-side-heading::after {
    height: calc(2 / var(--lg-base));
  }
  .news-side-heading::after {
    width: calc(30 / var(--lg-base));
  }
  .news-side-category {
    margin-top: calc(28 / var(--lg-base));
  }
  .news-side-category li:not(:first-child) {
    margin-top: calc(20 / var(--lg-base));
  }
  .news-side-category a {
    padding: calc(16 / var(--lg-base)) calc(30 / var(--lg-base));
    border-width: calc(2 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .news-none {
    padding-block: calc(20 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
}

.news-article-header {
  height: calc(200 / var(--sm-base));
  background: var(--color-primary);
}
.news-article-date {
  display: inline-block;
  min-width: calc(200 / var(--sm-base));
  padding: calc(12 / var(--sm-base)) calc(6 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-bg-secondary);
  border-radius: calc(10 / var(--sm-base));
  color: var(--color-primary);
  font-family: var(--font-din);
  font-size: calc(24 / var(--sm-base));
  font-weight: 700;
  letter-spacing: .075em;
  line-height: 1;
  text-align: center;
}
.news-article-title {
  margin-top: calc(20 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 600;
  line-height: 1.75;
}
.news-article-contents {
  margin-top: calc(25 / var(--sm-base));
  padding-top: calc(50 / var(--sm-base));
  border-top: calc(1/ var(--sm-base)) solid var(--color-border-primary);
  font-size: calc(24 / var(--sm-base));
  line-height: 1.8;
}
.news-article-contents > *:first-child {
  margin-top: 0;
}
.news-article-contents > *:last-child {
  margin-bottom: 0;
}
.news-article-contents p {
  margin-top: calc(32 / var(--sm-base));
}
.news-article-contents ul {
  margin: calc(48 / var(--sm-base)) 0 calc(48 / var(--sm-base)) calc(26 / var(--sm-base));
  list-style: disc;
}
.news-article-contents ol {
  margin: calc(48 / var(--sm-base)) 0 calc(48 / var(--sm-base)) calc(32 / var(--sm-base));
  list-style: decimal;
}
.news-article-contents .wp-block-image {
  margin-block: calc(48 / var(--sm-base));
}
.news-article-contents .wp-block-image img {
  width: 100%;
  height: auto;
  border-radius: calc(10 / var(--sm-base));
}
.news-article-back {
  margin-top: calc(90 / var(--sm-base));
  text-align: right;
}
.news-article-back-anchor {
  position: relative;
  display: inline-block;
  min-width: calc(500 / var(--sm-base));
  padding: calc(35 / var(--sm-base)) calc(100 / var(--sm-base)) calc(35 / var(--sm-base)) calc(32 / var(--sm-base));
  background: #fff;
  border: calc(1 / var(--sm-base)) solid var(--color-border-primary);
  border-radius: calc(10 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  text-align: left;
  text-decoration: none;
}
.news-article-back-anchor::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(30 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: var(--color-border-primary);
  -webkit-mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  mask: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .news-article-back-anchor {
    transition: opacity var(--transition);
  }
  .news-article-back-anchor:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .news-article-header {
    height: calc(330 / var(--lg-base));
  }
  .news-article-date {
    min-width: calc(200 / var(--lg-base));
    margin-top: calc(35 / var(--lg-base));
    padding: calc(12 / var(--lg-base)) calc(6 / var(--lg-base)) calc(10 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .news-article-title {
    margin-top: calc(30 / var(--lg-base));
    font-size: calc(40 / var(--lg-base));
    line-height: 1.4;
  }
  .news-article-contents {
    margin-top: calc(40 / var(--lg-base));
    padding-top: calc(60 / var(--lg-base));
    border-top-width: calc(1 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    line-height: 1.8;
  }
  .news-article-contents p {
    margin-top: calc(16 / var(--lg-base));
  }
  .news-article-contents ul {
    margin: calc(32 / var(--lg-base)) 0 calc(32 / var(--lg-base)) calc(24 / var(--lg-base));
  }
  .news-article-contents ol {
    margin: calc(32 / var(--lg-base)) 0 calc(32 / var(--lg-base)) calc(30 / var(--lg-base));
  }
  .news-article-contents .wp-block-image {
    margin-block: calc(60 / var(--lg-base));
  }
  .news-article-contents .wp-block-image img {
    border-radius: calc(10 / var(--lg-base));
  }
  .news-article-back {
    margin-block: calc(80 / var(--lg-base)) calc(-60 / var(--lg-base));
  }
  .news-article-back-anchor {
    min-width: calc(320 / var(--lg-base));
    padding: calc(22 / var(--lg-base)) calc(32 / var(--lg-base));
    border-width: calc(1 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .news-article-back-anchor::after {
    right: calc(25 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}


/* Contact
-------------------------------------------------- */
.contact-body .mw_wp_form {
  padding-block: calc(80 / var(--sm-base)) calc(160 / var(--sm-base));
}
.contact-lead {
  margin-bottom: calc(75 / var(--sm-base));
}
.mw_wp_form_input .contact-lead.--confirm,
.mw_wp_form_confirm .contact-lead.--input {
  display: none;
}
.contact-lead p {
  display: inline;
  font-size: calc(28 / var(--sm-base));
  font-weight: 500;
}
.contact-lead br {
  display: none;
}
.contact-form-row {
  margin-top: calc(45 / var(--sm-base));
}
.contact-form-head label {
  display: inline-block;
  font-size: calc(32 / var(--sm-base));
}
.contact-form-head .required,
.contact-form-head .optional {
  position: relative;
  top: calc(-2 / var(--sm-base));
  display: inline-block;
  min-width: calc(128 / var(--sm-base));
  margin-right: calc(18 / var(--sm-base));
  padding: calc(13.5 / var(--sm-base)) calc(6 / var(--sm-base));
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  font-weight: 400;
  line-height: 1;
  text-align: center;
}
.contact-form-head .required {
  background: var(--color-primary);
}
.contact-form-head .optional {
  background: #ababab;
}
.contact-form-body {
  margin-top: calc(20 / var(--sm-base));
}
.contact-form-body input[type="text"],
.contact-form-body input[type="email"] {
  width: 100%;
  padding: calc(16 / var(--sm-base)) calc(26 / var(--sm-base));
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
  font-weight: 500;
}
.contact-form-body textarea {
  width: 100%;
  height: calc(360 / var(--sm-base));
  min-height: calc(360 / var(--sm-base));
  padding: calc(16 / var(--sm-base)) calc(26 / var(--sm-base));
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
  font-weight: 500;
}
.contact-form-select {
  position: relative;
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
}
.contact-form-select::after {
  content: '';
  position: absolute;
  top: 45%;
  right: calc(24 / var(--sm-base));
  width: calc(20 / var(--sm-base));
  height: calc(20 / var(--sm-base));
  border-right: calc(3 / var(--sm-base)) solid var(--color-primary);
  border-bottom: calc(3 / var(--sm-base)) solid var(--color-primary);
  transform: translateY(-50%) rotate(45deg);
}
.contact-form-select select {
  width: 100%;
  padding: calc(16 / var(--sm-base)) calc(72 / var(--sm-base)) calc(16 / var(--sm-base)) calc(26 / var(--sm-base));
  font-weight: 500;
}
.contact-privacy-lead {
  margin-top: calc(80 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  font-weight: 500;
}
.contact-privacy-contents {
  margin-top: calc(80 / var(--sm-base));
  padding: calc(18 / var(--sm-base)) calc(14 / var(--sm-base));
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  border-radius: calc(10 / var(--sm-base));
}
.contact-privacy-contents-inner {
  height: calc(690 / var(--sm-base));
  overflow-y: auto;
  padding: calc(45 / var(--sm-base)) calc(50 / var(--sm-base)) calc(26 / var(--sm-base)) calc(26 / var(--sm-base));
}
.contact-privacy-heading {
  font-size: calc(32 / var(--sm-base));
  text-align: center;
}
.contact-privacy-detail {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  font-weight: 500;
}
.contact-privacy-agree {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  text-align: center;
}
.contact-privacy-agree label {
  position: relative;
  display: inline-block;
  padding: calc(4 / var(--sm-base)) 0 calc(4 / var(--sm-base)) calc(62 / var(--sm-base));
  font-weight: 600;
  cursor: pointer;
}
.contact-privacy-agree label::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  border: calc(1 / var(--sm-base)) solid var(--color-border-tertiary);
  transform: translateY(-50%);
}
.contact-privacy-agree label::after {
  content: '';
  position: absolute;
  top: 43%;
  left: calc(10 / var(--sm-base));
  z-index: 2;
  width: calc(20 / var(--sm-base));
  height: calc(13 / var(--sm-base));
  border-bottom: calc(5 / var(--sm-base)) solid var(--color-primary);
  border-left: calc(5 / var(--sm-base)) solid var(--color-primary);
  transform: translateY(-50%) rotate(-45deg);
  opacity: 0;
  transition: opacity var(--transition);
}
.contact-privacy-agree input[type="checkbox"] {
  position: absolute;
  z-index: -1;
}
.contact-privacy-agree:has(input[type="checkbox"]:checked) label::after {
  opacity: 1;
}
.contact-form-action {
  margin-top: calc(80 / var(--sm-base));
  text-align: center;
}
.contact-form-button {
  min-width: calc(420 / var(--sm-base));
  padding: calc(36 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-primary);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  text-align: center;
}
.contact-form-button.--back {
  min-width: calc(280 / var(--sm-base));
  margin-top: calc(60 / var(--sm-base));
  padding: calc(28 / var(--sm-base)) calc(10 / var(--sm-base));
  background: var(--color-default);
}
.mw_wp_form .error {
  margin-top: calc(20 / var(--sm-base));
  color: var(--color-primary);
  font-size: calc(28 / var(--sm-base));
}
.mw_wp_form_confirm .contact-form-row {
  margin-top: calc(60 / var(--sm-base));
}
.mw_wp_form_confirm .contact-form-select {
  border: none;
  border-radius: 0;
}
.mw_wp_form_confirm .contact-form-select::after {
  content: none;
}
.mw_wp_form_confirm .contact-privacy-lead,
.mw_wp_form_confirm .contact-privacy-contents,
.mw_wp_form_confirm .contact-privacy-agree {
  display: none;
}
.contact-thanks-heading {
  font-size: calc(36 / var(--sm-base));
  font-weight: 600;
}
.contact-thanks-text {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(28 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.contact-thanks-button {
  position: relative;
  display: block;
  margin-top: calc(80 / var(--sm-base));
  padding: calc(41 / var(--sm-base)) calc(90 / var(--sm-base)) calc(41 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.contact-thanks-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .contact-form-button,
  .contact-thanks-button {
    transition: opacity var(--transition);
  }
  .contact-form-button:hover,
  .contact-thanks-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .contact-body .mw_wp_form {
    padding-block: calc(120 / var(--lg-base)) calc(160 / var(--lg-base));
  }
  .contact-lead {
    margin-bottom: calc(110 / var(--lg-base));
  }
  .contact-lead p {
    display: block;
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .contact-lead p:not(:first-child) {
    margin-top: calc(16 / var(--lg-base));
  }
  .contact-lead br {
    display: inline;
  }
  .contact-form-row {
    display: flex;
    align-items: center;
    margin-top: calc(28 / var(--lg-base));
  }
  .contact-form-row.--detail {
    align-items: flex-start;
  }
  .contact-form-head {
    width: calc(460 / var(--lg-base));
    padding-right: calc(40 / var(--lg-base));
  }
  .contact-form-row.--detail .contact-form-head {
    padding-top: calc(20 / var(--lg-base));
  }
  .contact-form-head label {
    font-size: calc(26 / var(--lg-base));
  }
  .contact-form-head .required,
  .contact-form-head .optional {
    top: 0;
    min-width: calc(104 / var(--lg-base));
    margin-right: calc(24 / var(--lg-base));
    padding: calc(9.5 / var(--lg-base)) calc(6 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .contact-form-body {
    flex: 1;
    margin: 0;
  }
  .contact-form-body input[type="text"],
  .contact-form-body input[type="email"] {
    padding: calc(21 / var(--lg-base)) calc(30 / var(--lg-base));
    border-width: calc(1 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .contact-form-body textarea {
    height: calc(290 / var(--lg-base));
    min-height: calc(290 / var(--lg-base));
    padding: calc(21 / var(--lg-base)) calc(30 / var(--lg-base));
    border-width: calc(1 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .contact-form-select {
    border-width: calc(1 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .contact-form-select::after {
    right: calc(32 / var(--lg-base));
    width: calc(15 / var(--lg-base));
    height: calc(15 / var(--lg-base));
    border-right-width: calc(2 / var(--lg-base));
    border-bottom-width: calc(2 / var(--lg-base));
  }
  .contact-form-select select {
    padding: calc(21 / var(--lg-base)) calc(72 / var(--lg-base)) calc(21 / var(--lg-base)) calc(30 / var(--lg-base));
  }
  .contact-privacy-lead {
    margin-top: calc(95 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
    text-align: center;
  }
  .contact-privacy-contents {
    margin-top: calc(55 / var(--lg-base));
    padding: calc(25 / var(--lg-base)) calc(15 / var(--lg-base));
    border-width: calc(1 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
  }
  .contact-privacy-contents-inner {
    height: calc(270 / var(--lg-base));
    padding: calc(20 / var(--lg-base)) calc(50 / var(--lg-base)) calc(25 / var(--lg-base)) calc(25 / var(--lg-base));
  }
  .contact-privacy-heading {
    font-size: calc(26 / var(--lg-base));
  }
  .contact-privacy-detail {
    margin-top: calc(30 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .contact-privacy-agree {
    margin-top: calc(60 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .contact-privacy-agree label {
    padding: calc(4 / var(--lg-base)) 0 calc(4 / var(--lg-base)) calc(62 / var(--lg-base));
  }
  .contact-privacy-agree label::before {
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
    border-width: calc(1 / var(--lg-base));
  }
  .contact-privacy-agree label::after {
    left: calc(10 / var(--lg-base));
    width: calc(20 / var(--lg-base));
    height: calc(13 / var(--lg-base));
    border-bottom-width: calc(4 / var(--lg-base));
    border-left-width: calc(4 / var(--lg-base));
  }
  .contact-form-action {
    margin-top: calc(95 / var(--lg-base));
  }
  .contact-form-button {
    min-width: calc(420 / var(--lg-base));
    padding: calc(24 / var(--lg-base)) calc(10 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(26 / var(--lg-base));
  }
  .contact-form-button.--back {
    position: absolute;
    top: 50%;
    left: 0;
    min-width: calc(200 / var(--lg-base));
    margin-top: 0;
    padding: calc(18 / var(--lg-base)) calc(10 / var(--lg-base));
    transform: translateY(-50%);
  }
  .mw_wp_form .error {
    margin-top: calc(12 / var(--lg-base));
    font-size: calc(22 / var(--lg-base));
  }
  .mw_wp_form_confirm .contact-form-row {
    margin-top: calc(45 / var(--lg-base));
  }
  .mw_wp_form_confirm .contact-form-row.--detail .contact-form-head {
    padding-top: 0;
  }
  .mw_wp_form_confirm .contact-form-action {
    position: relative;
  }
  .contact-thanks-heading {
    font-size: calc(32 / var(--lg-base));
  }
  .contact-thanks-text {
    margin-top: calc(40 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .contact-thanks-button {
    width: calc(480 / var(--lg-base));
    margin-top: calc(60 / var(--lg-base));
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) calc(32 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
  .contact-thanks-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}


/* モーダルアニメーション */
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(15%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-10%);
  }
}
@keyframes mmscaleIn {
  from {
    transform: scale(.95);
  }
  to {
    transform: scale(1);
  }
}
@keyframes mmscaleOut {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(.95);
  }
}
.micromodal-slide {
  display: none;
}
.micromodal-slide.is-open {
  display: block;
}
.micromodal-slide[aria-hidden="false"] .modal-overlay {
  animation: mmfadeIn .3s cubic-bezier(.0, .0, .2, 1);
}
.micromodal-slide[aria-hidden="false"] .modal-container {
  animation: mmscaleIn .3s cubic-bezier(0, 0, .2, 1);
}
.micromodal-slide[aria-hidden="true"] .modal-overlay {
  animation: mmfadeOut .3s cubic-bezier(.0, .0, .2, 1);
}
.micromodal-slide[aria-hidden="true"] .modal-container {
  animation: mmscaleOut .3s cubic-bezier(0, 0, .2, 1);
}
.micromodal-slide .modal-container,
.micromodal-slide .modal-overlay {
  will-change: transform;
}
html.modal-open {
  overflow: hidden;
}

.modal-overlay {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1000;
  display: flex;
  justify-content: center;
  align-items: center;
  background: rgba(0, 0, 0, .3);
}
.modal-container {
  max-height: 90vh;
  width: 90%;
  overflow-y: auto;
}
.modal-contents img {
  width: 100%;
}
.modal-close {
  position: absolute;
  top: calc(15 / var(--sm-base));
  right: calc(15 / var(--sm-base));
  z-index: 2;
  width: calc(64 / var(--sm-base));
  height: calc(64 / var(--sm-base));
  border: calc(3 / var(--sm-base)) solid #fff;
  border-radius: 50%;
  font-size: 0;
  cursor: pointer;
}
.modal-close::before,
.modal-close::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(32 / var(--sm-base));
  height: calc(3 / var(--sm-base));
  border-radius: 100vmax;
  background: #fff;
  pointer-events: none;
}
.modal-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modal-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media (hover: hover) and (pointer: fine) {
  .modal-close {
    transition: opacity var(--transition);
  }
  .modal-close:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .modal-container {
    width: 80%;
  }
  .modal-close {
    top: calc(30 / var(--lg-base));
    right: calc(30 / var(--lg-base));
    width: calc(80 / var(--lg-base));
    height: calc(80 / var(--lg-base));
    border-width: calc(4 / var(--lg-base));
  }
  .modal-close::before,
  .modal-close::after {
    width: calc(40 / var(--lg-base));
    height: calc(4 / var(--lg-base));
  }
}

.error404-header {
  height: calc(200 / var(--sm-base));
  background: var(--color-primary);
}
.error404-body {
  padding-block: calc(160 / var(--sm-base));
}
.error404-heading {
  font-size: calc(48 / var(--sm-base));
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: .05em;
}
.error404-text {
  margin-top: calc(40 / var(--sm-base));
  font-size: calc(32 / var(--sm-base));
  font-weight: 500;
  line-height: 1.8;
}
.error404-button {
  position: relative;
  display: block;
  margin-top: calc(80 / var(--sm-base));
  padding: calc(41 / var(--sm-base)) calc(90 / var(--sm-base)) calc(41 / var(--sm-base)) calc(40 / var(--sm-base));
  background: var(--color-default);
  border-radius: calc(10 / var(--sm-base));
  color: #fff;
  font-size: calc(28 / var(--sm-base));
  line-height: 1;
  letter-spacing: .05em;
  text-decoration: none;
}
.error404-button::after {
  content: '';
  position: absolute;
  top: 50%;
  right: calc(28 / var(--sm-base));
  width: calc(40 / var(--sm-base));
  height: calc(40 / var(--sm-base));
  background: url(../images/common/icn_arrow_01.svg) 0 0 / contain no-repeat;
  transform: translateY(-50%);
}
@media (hover: hover) and (pointer: fine) {
  .error404-button {
    transition: opacity var(--transition);
  }
  .error404-button:hover {
    opacity: var(--hover-opacity);
  }
}
@media screen and (min-width: 769px), print {
  .error404-header {
    height: calc(330 / var(--lg-base));
  }
  .error404-body {
    padding-block: calc(160 / var(--lg-base));
  }
  .error404-heading {
    font-size: calc(32 / var(--lg-base));
  }
  .error404-text {
    margin-top: calc(40 / var(--lg-base));
    font-size: calc(20 / var(--lg-base));
  }
  .error404-button {
    width: calc(480 / var(--lg-base));
    margin-top: calc(60 / var(--lg-base));
    padding: calc(30 / var(--lg-base)) calc(90 / var(--lg-base)) calc(30 / var(--lg-base)) calc(32 / var(--lg-base));
    border-radius: calc(10 / var(--lg-base));
    font-size: calc(24 / var(--lg-base));
  }
  .error404-button::after {
    right: calc(32 / var(--lg-base));
    width: calc(40 / var(--lg-base));
    height: calc(40 / var(--lg-base));
  }
}