@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Noto+Serif+JP:wght@200..900&display=swap&family=Noto+Sans+JP:wght@100..900&display=swap);
/*==========================================================================
# reset - ブラウザの差異や不要なスタイルを無くすためのスタイル
========================================================================== */
* {
  box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  letter-spacing: 0;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
aside,
figure,
figcaption {
  display: block;
}

a {
  text-decoration: none;
}

img {
  border: none;
  vertical-align: bottom;
}

address {
  font-style: normal;
}

table {
  border-collapse: collapse;
}

input[type=submit] {
  -webkit-appearance: none;
  border-radius: 0;
}

@font-face {
  font-family: "Bodoni72";
  src: url("../fonts/Bodoni 72.ttc") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Noto-M";
  src: url("../fonts/NotoSerifJP-Medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Noto-R";
  src: url("../fonts/NotoSerifJP-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "Noto-B";
  src: url("../fonts/NotoSerifJP-SemiBold.otf") format("opentype");
  font-weight: 600;
  font-style: normal;
}
html,
body {
  overflow-x: hidden;
}

body {
  font-family: "Noto-R", serif;
  color: #000000;
}

a {
  color: #fff;
  text-decoration: none;
}

img {
  width: auto;
  display: inline-block;
  vertical-align: bottom;
}

svg {
  width: auto;
  height: auto;
  overflow: hidden;
}

li {
  list-style: none;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: auto;
}

body {
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: hidden;
}

.background__gradation {
  background: linear-gradient(to right, hsla(0, 0%, 85%, 0), #D9D9D9);
}

fieldset {
  border: none;
  padding: 0;
  margin: 0;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

textarea,
input {
  resize: none;
  border: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.sp_only_md {
  display: none;
}
@media (max-width: 1500px) {
  .sp_only_md {
    display: block;
  }
}

.sp_only {
  display: none;
}
@media (max-width: 1100px) {
  .sp_only {
    display: block;
  }
}

@media (max-width: 1100px) {
  .pc_only {
    display: none;
  }
}

@media (max-width: 950px) {
  .pc_only_md {
    display: none;
  }
}

a[href^="tel:"] {
  pointer-events: none;
}

@media (hover: none) and (pointer: coarse) {
  a[href^="tel:"] {
    pointer-events: auto;
  }
  a:hover,
  .c-button:hover,
  button:hover {
    transform: none !important;
    background-color: inherit !important;
    transition: none !important;
  }
}
.header__logo {
  transition: opacity 0.3s ease;
}
@media (max-width: 1100px) {
  .header__logo {
    z-index: 10000;
    display: inline-block;
  }
}
@media (hover: hover) {
  .header__logo:hover {
    opacity: 0.6;
  }
}
.header__logo a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: clamp(4px, 1.816px + 0.583vw, 13px);
}
@media (max-width: 1100px) {
  .header__logo a {
    width: 100%;
    gap: clamp(4px, 3.029px + 0.259vw, 8px);
  }
}
.header__logo a img {
  width: clamp(88px, 43.097px + 11.974vw, 273px);
  height: auto;
}
@media (max-width: 1100px) {
  .header__logo a img {
    width: clamp(88px, 74.165px + 3.689vw, 145px);
    height: auto;
  }
}
.header__logo a .header__logo--text {
  display: block;
  font-size: clamp(4px, 1.573px + 0.647vw, 14px);
  letter-spacing: clamp(0.4px, 0.012px + 0.104vw, 2px);
  color: #000000;
}
@media (max-width: 1100px) {
  .header__logo a .header__logo--text {
    display: block;
    font-size: clamp(4px, 3.15px + 0.227vw, 7.5px);
    letter-spacing: clamp(0.4px, 0.303px + 0.026vw, 0.8px);
  }
}
.header__logo a .header__logo--top .space {
  margin-left: clamp(0px, -0.485px + 0.129vw, 2px);
  letter-spacing: clamp(0.4px, 0.133px + 0.071vw, 1.5px);
}
@media (max-width: 1100px) {
  .header__logo a .header__logo--top .space {
    margin-left: clamp(0px, -0.485px + 0.129vw, 2px);
    letter-spacing: clamp(0.4px, 0.303px + 0.026vw, 0.8px);
  }
}
.header__logo a .header__logo--bottom {
  width: clamp(41px, 16.243px + 6.602vw, 143px);
  height: clamp(7.6px, 2.649px + 1.32vw, 28px);
  border-radius: clamp(1.5px, -0.199px + 0.453vw, 8.5px);
  background-color: #851218;
  color: #fff;
  font-size: clamp(6px, 3.087px + 0.777vw, 18px);
  letter-spacing: 0.28em;
  line-height: 1;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1100px) {
  .header__logo a .header__logo--bottom {
    font-weight: 400;
    letter-spacing: 1px;
    margin-top: -3px;
    padding: clamp(0px, -0.485px + 0.129vw, 2px) clamp(0px, -2.427px + 0.647vw, 10px);
  }
}

#header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  font-family: "Noto-B", serif;
  font-weight: 600;
}
@media (max-width: 1100px) {
  #header {
    position: relative;
    z-index: 9999;
  }
}
#header .header__top {
  padding: clamp(20px, -20.244px + 3.659vw, 50px) clamp(20px, -20.244px + 3.659vw, 50px) 0 clamp(20px, -26.951px + 4.268vw, 55px);
  display: flex;
  justify-content: space-between;
}
@media (max-width: 1100px) {
  #header .header__top {
    position: relative;
    align-items: center;
    z-index: 9999;
    padding: 10px 10px 10px 20px;
  }
}
#header .header__nav {
  margin-left: auto;
}
@media (max-width: 1100px) {
  #header .header__nav {
    display: none;
  }
}
#header .header__nav .header__menu-group {
  display: flex;
  gap: clamp(5px, -1.707px + 0.61vw, 10px);
}
#header .header__nav .header__menu {
  width: clamp(150px, 42.683px + 9.756vw, 230px);
  height: clamp(30px, 3.171px + 2.439vw, 50px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: clamp(10px, -3.415px + 1.22vw, 20px);
  font-size: clamp(10px, 4.634px + 0.488vw, 14px);
  letter-spacing: clamp(1.5px, -0.512px + 0.183vw, 3px);
  white-space: nowrap;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
#header .header__nav .header__menu--outline {
  border: 1px solid #851218;
  color: #851218;
  background: #fff;
}
@media (hover: hover) {
  #header .header__nav .header__menu--outline:hover {
    background-color: #851218;
    border: 1px solid #851218;
    color: #fff;
  }
}
#header .header__nav .header__menu--red {
  background: #851218;
  color: #fff;
}
@media (hover: hover) {
  #header .header__nav .header__menu--red:hover {
    background-color: #fff;
    border: 1px solid #851218;
    color: #851218;
  }
}
#header .header__nav .header__menu--blue {
  background: #14126f;
  color: #fff;
}
@media (hover: hover) {
  #header .header__nav .header__menu--blue:hover {
    background-color: #fff;
    border: 1px solid #14126f;
    color: #14126f;
  }
}
#header .header__nav .header__menu--right {
  background: #19244d;
  color: #fff;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
@media (hover: hover) {
  #header .header__nav .header__menu--right:hover {
    background-color: #fff;
    border: 1px solid #19244d;
    color: #19244d;
  }
}
#header .sp-toggle {
  margin-left: 10px;
}
@media (max-width: 1100px) {
  #header .sp-toggle {
    margin-left: 0;
  }
}

#header .sp-toggle,
#header-sub .sp-toggle {
  border-radius: 3px;
  background: #851218 !important;
  border: 0;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 50px;
  height: 50px;
  z-index: 20001;
}
@media (max-width: 1100px) {
  #header .sp-toggle,
  #header-sub .sp-toggle {
    gap: 8px;
    width: 40px;
    height: 40px;
    background: #851218 !important;
  }
}
@media (max-width: 1100px) and (max-width: 550px) {
  #header .sp-toggle,
  #header-sub .sp-toggle {
    position: fixed;
    right: 10px;
    gap: 6px;
    width: 35px;
    height: 35px;
  }
}
#header .sp-toggle .sp-toggle__bar,
#header-sub .sp-toggle .sp-toggle__bar {
  display: block;
  width: 30px;
  height: 1.5px;
  background: #fff !important;
  transition: transform 0.25s ease, opacity 0.2s ease;
  backface-visibility: hidden;
  will-change: transform, opacity;
}
@media (max-width: 1100px) {
  #header .sp-toggle .sp-toggle__bar,
  #header-sub .sp-toggle .sp-toggle__bar {
    width: 25px;
  }
}
@media (max-width: 550px) {
  #header .sp-toggle .sp-toggle__bar,
  #header-sub .sp-toggle .sp-toggle__bar {
    width: 22px;
  }
}

.is-open .sp-toggle__bar:nth-child(1) {
  transform: translate3d(0, 12px, 0) rotate(45deg);
}
@media (max-width: 1100px) {
  .is-open .sp-toggle__bar:nth-child(1) {
    transform: translate3d(0, 9.5px, 0) rotate(45deg);
  }
}
@media (max-width: 550px) {
  .is-open .sp-toggle__bar:nth-child(1) {
    transform: translate3d(0, 7.5px, 0) rotate(45deg);
  }
}

.is-open .sp-toggle__bar:nth-child(2) {
  opacity: 0;
}

.is-open .sp-toggle__bar:nth-child(3) {
  transform: translate3d(0, -12px, 0) rotate(-45deg);
}
@media (max-width: 1100px) {
  .is-open .sp-toggle__bar:nth-child(3) {
    transform: translate3d(0, -9.5px, 0) rotate(-45deg);
  }
}
@media (max-width: 550px) {
  .is-open .sp-toggle__bar:nth-child(3) {
    transform: translate3d(0, -7.5px, 0) rotate(-45deg);
  }
}

html.is-open .sp-toggle {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

html.is-open #header .sp-toggle {
  background: #851218 !important;
  z-index: 20001;
}

html.is-open #header-sub .sp-toggle {
  background: #851218 !important;
  z-index: 20001;
}

.sp-menu {
  display: none;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100dvh;
  background: #fff;
  border-bottom-left-radius: 80px;
  border-bottom: 1px solid #851218;
  padding: clamp(94px, 87.689px + 1.683vw, 120px) clamp(34px, 17.981px + 4.272vw, 100px) clamp(97px, 91.417px + 1.489vw, 120px) clamp(40px, 25.437px + 3.883vw, 100px);
  transition: transform 0.3s ease;
  z-index: 10000;
  transform: translateX(110%);
  pointer-events: none;
}
@media (min-width: 1101px) {
  .sp-menu {
    width: 500px;
    max-width: 90vw;
    height: auto;
  }
}
.sp-menu .sp-menu__top {
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 10000;
  display: flex;
  justify-content: flex-start;
}
.sp-menu .sp-menu__logo {
  display: none;
  position: absolute;
  top: clamp(-84px, -80.117px - 1.036vw, -100px);
  left: -20px;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: clamp(4px, 3.029px + 0.259vw, 8px);
}
.sp-menu .sp-menu__logo img {
  width: clamp(78px, 61.738px + 4.337vw, 145px);
  height: auto;
}
.sp-menu .sp-menu__logo .header__logo--text {
  display: block;
  font-size: clamp(4px, 3.15px + 0.227vw, 7.5px);
  letter-spacing: clamp(0.4px, 0.303px + 0.026vw, 0.8px);
  color: #000000;
}
.sp-menu .sp-menu__logo .header__logo--top .space {
  margin-left: 0;
  letter-spacing: clamp(0.4px, 0.133px + 0.071vw, 1.5px);
}
.sp-menu .sp-menu__logo .header__logo--bottom {
  width: clamp(41px, 33.112px + 2.104vw, 73.5px);
  height: clamp(7.6px, 6.144px + 0.388vw, 13.6px);
  font-size: clamp(6px, 4.786px + 0.324vw, 11px);
  line-height: 1;
  padding: 0;
  border-radius: 1.5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #851218;
  color: #fff;
  padding: clamp(0px, -0.485px + 0.129vw, 2px) clamp(0px, -2.427px + 0.647vw, 10px);
}

html.is-open .sp-menu__logo {
  display: flex;
}

html.is-open #header-sub .header__logo {
  opacity: 0;
  pointer-events: none;
}

.sp-menu__nav--list {
  display: flex;
  flex-direction: column;
}
.sp-menu__nav--list li {
  padding: 20px 0 20px 24px;
  border-bottom: 1px solid #851218;
}
@media (max-width: 1100px) {
  .sp-menu__nav--list li {
    padding: 16px 0 16px 24px;
  }
}
.sp-menu__nav--list a {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.4;
  color: #000000;
}
@media (max-width: 1100px) {
  .sp-menu__nav--list a {
    font-size: 1rem;
  }
}

.sp-menu[aria-hidden=false] {
  transform: translateX(0);
  pointer-events: auto;
  display: block;
}

.sp-menu[aria-hidden=true] {
  display: none !important;
}

html.is-open #header-sub .header__top > .header__logo {
  opacity: 0;
  pointer-events: none;
}

#header-sub {
  width: 100%;
  height: auto;
  background: #fff;
  box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.05);
}
@media (max-width: 1100px) {
  #header-sub {
    position: relative;
    z-index: 9999;
  }
}
#header-sub .header-sub__top {
  margin: 0 auto;
  display: flex;
  align-items: center;
  padding-left: 30px;
}
@media (max-width: 1100px) {
  #header-sub .header-sub__top {
    position: relative;
    align-items: center;
    justify-content: space-between;
    z-index: 9999;
    padding: 10px 10px 10px 20px;
  }
}
#header-sub .header__logo a {
  width: 175.44px;
  gap: clamp(4px, 3.029px + 0.259vw, 8px);
}
@media (max-width: 1100px) {
  #header-sub .header__logo a {
    width: 100%;
  }
}
#header-sub .header__logo a img {
  width: clamp(88px, 74.165px + 3.689vw, 145px);
  height: auto;
}
#header-sub .header__logo a .header__logo--text {
  display: block;
  font-size: clamp(4px, 3.15px + 0.227vw, 7.5px);
  letter-spacing: clamp(0.4px, 0.303px + 0.026vw, 0.8px);
}
#header-sub .header__logo a .header__logo--top .space {
  margin-left: clamp(0px, -0.485px + 0.129vw, 2px);
  letter-spacing: clamp(0.4px, 0.303px + 0.026vw, 0.8px);
}
#header-sub .header__logo a .header__logo--bottom {
  width: clamp(41px, 33.112px + 2.104vw, 73.5px);
  height: clamp(7.6px, 6.144px + 0.388vw, 13.6px);
  border-radius: clamp(1.5px, 1.204px + 0.079vw, 2.72px);
  font-size: clamp(6px, 4.786px + 0.324vw, 11px);
  background-color: #851218;
  color: #fff;
  font-weight: 400;
  letter-spacing: 1px;
  margin-top: -3px;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(0px, -0.485px + 0.129vw, 2px) clamp(0px, -2.427px + 0.647vw, 10px);
}
#header-sub .sp-toggle {
  display: none;
}
@media (max-width: 1100px) {
  #header-sub .sp-toggle {
    display: flex;
  }
}
#header-sub .header-sub__nav {
  flex: 1;
}
@media (max-width: 1100px) {
  #header-sub .header-sub__nav {
    display: none;
  }
}
#header-sub .header-sub__nav .header-sub__nav--list {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 30px;
  font-size: clamp(16px, 10.634px + 0.488vw, 20px);
  font-weight: 700;
}
#header-sub .header-sub__nav .header-sub__nav--list a {
  color: #000000;
  text-decoration: none;
  position: relative;
}
#header-sub .header-sub__nav .header-sub__nav--list a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background-color: #851218;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
@media (hover: hover) {
  #header-sub .header-sub__nav .header-sub__nav--list a:hover {
    color: #851218;
  }
  #header-sub .header-sub__nav .header-sub__nav--list a:hover::after {
    transform: scaleX(1);
  }
}
#header-sub .header-sub__cta {
  margin-left: 30px;
  width: clamp(180px, 92.805px + 7.927vw, 245px);
  box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.05);
  background-color: #851218;
  padding: 35.4px 0;
}
@media (max-width: 1100px) {
  #header-sub .header-sub__cta {
    display: none;
  }
}
#header-sub .header-sub__cta a.cta-search {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 100%;
  height: 100%;
  font-size: clamp(18px, 9.951px + 0.732vw, 24px);
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  transition: transform 0.35s ease;
  transform-origin: center center;
}
@media (hover: hover) {
  #header-sub .header-sub__cta:hover a.cta-search {
    animation: tilt-wiggle 0.6s ease forwards;
  }
  @keyframes tilt-wiggle {
    0% {
      transform: rotate(0deg);
    }
    30% {
      transform: rotate(-6deg);
    }
    55% {
      transform: rotate(-4deg);
    }
    75% {
      transform: rotate(-5deg);
    }
    100% {
      transform: rotate(-5deg);
    }
  }
}
#header-sub .header-sub__cta .icon-search img {
  display: block;
  width: clamp(20px, 6.585px + 1.22vw, 30px);
  height: clamp(20px, 6.585px + 1.22vw, 30px);
}

html.is-open,
body.is-open {
  overflow: hidden !important;
}

#footer .footer__nav {
  padding-block: clamp(60px, 10vw, 123px);
  margin: 0 auto;
  background-color: #000000;
}
#footer .footer__nav .footer__nav--list {
  max-width: clamp(345px, 91vw, 1350px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 3vw, 50px);
}
#footer .footer__nav .footer__nav--list .footer__nav--item {
  color: #fff;
  position: relative;
}
#footer .footer__nav .footer__nav--list .footer__nav--item::after {
  content: "";
  position: absolute;
  top: 0;
  right: -6%;
  width: 1px;
  height: 100%;
  background-color: #fff;
}
#footer .footer__nav .footer__nav--list .footer__nav--item:last-child::after {
  display: none;
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--lead {
  font-size: clamp(12px, 3vw, 26px);
  line-height: 1;
  font-weight: 300;
  letter-spacing: clamp(0.01rem, 0.4vw, 0.4rem);
  text-align: center;
  white-space: nowrap;
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--button {
  margin: clamp(11.5px, 3vw, 46px) auto 0;
  width: clamp(160px, 32vw, 420px);
  height: clamp(74px, 16vw, 184px);
  border-radius: clamp(5px, 1.4vw, 20px);
  border: 1px solid #fff;
  text-align: center;
  align-content: center;
  font-weight: 400;
  position: relative;
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--button .footer-nav__link {
  font-size: clamp(14px, 3vw, 40px);
  letter-spacing: clamp(0.01rem, 0.4vw, 0.5rem);
  line-height: 1.3;
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-decoration: none;
  transition: transform 0.35s ease;
  transform-origin: center center;
}
@media (hover: hover) {
  #footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--button:hover .footer-nav__link {
    animation: tilt-wiggle 0.6s ease forwards;
  }
  @keyframes tilt-wiggle {
    0% {
      transform: rotate(0deg);
    }
    30% {
      transform: rotate(-6deg);
    }
    55% {
      transform: rotate(-4deg);
    }
    75% {
      transform: rotate(-5deg);
    }
    100% {
      transform: rotate(-5deg);
    }
  }
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--request {
  background-color: #851218;
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--recruit {
  background-color: #14126f;
}
#footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--partner {
  background-color: #19244d;
}
#footer .footer__brand {
  margin: 35px auto 0;
  text-align: center;
}
#footer .footer__logo img {
  width: clamp(230px, 28vw, 380px);
  height: auto;
}

@media (max-width: 1380px) {
  #footer .footer__nav .footer__nav--list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas: "a b" "c c";
    gap: 54px 20.8px;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item:nth-child(1) {
    grid-area: a;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item:nth-child(2) {
    grid-area: b;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item:nth-child(3) {
    grid-area: c;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item:not(:last-child)::after {
    display: none;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item {
    position: relative;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item::after {
    content: "";
    position: absolute;
    top: -27px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #fff;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item:last-child::after {
    display: block;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item .footer__nav--button {
    display: block;
    margin-inline: auto;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item.last .footer__nav--lead {
    font-size: clamp(14px, 3vw, 26px);
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item.last .footer__nav--request {
    width: clamp(347px, 32vw, 420px);
    height: clamp(74px, 16vw, 184px);
    border-radius: clamp(5px, 1.4vw, 20px);
    justify-self: center;
    margin-inline: auto;
  }
  #footer .footer__nav .footer__nav--list .footer__nav--item.last .footer__nav--request .footer-nav__link {
    font-size: clamp(20px, 3.2vw, 40px);
  }
}
.contact-page .c-page-hero__eyebrow {
  text-transform: capitalize;
  margin-top: clamp(0px, -2.913px + 0.777vw, 12px);
}

.contact {
  max-width: clamp(900px, 296.341px + 54.878vw, 1350px);
  width: 100%;
  margin: 0 auto;
  padding: clamp(30px, 13.01px + 4.531vw, 100px) 0 clamp(50px, 37.864px + 3.236vw, 100px);
}
@media (max-width: 1100px) {
  .contact {
    max-width: clamp(345px, 57.931px + 76.552vw, 900px);
  }
}
.contact .contact__grid {
  display: grid;
  grid-template-columns: 1fr clamp(425px, 82.927px + 31.098vw, 680px);
  gap: clamp(30px, -23.659px + 4.878vw, 70px);
}
@media (max-width: 1100px) {
  .contact .contact__grid {
    grid-template-columns: 1fr;
  }
}
.contact .contact__grid .contact__intro {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: clamp(20px, -6.214px + 6.99vw, 128px);
}
.contact .contact__grid .contact__intro .contact__intro--lead,
.contact .contact__grid .contact__intro .contact__intro--body {
  display: flex;
  flex-direction: column;
  gap: clamp(18.7px, 15.957px + 0.731vw, 30px);
}
.contact .contact__grid .contact__intro #contact-title,
.contact .contact__grid .contact__intro .contact__subtitle {
  font-family: "Noto-B", serif;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
}
.contact .contact__grid .contact__intro #contact-title {
  font-size: clamp(24px, 20.117px + 1.036vw, 40px);
  line-height: 1.5;
}
.contact .contact__grid .contact__intro .contact__subtitle {
  font-size: clamp(16px, 14.544px + 0.388vw, 22px);
  line-height: 2;
}
.contact .contact__grid .contact__intro .contact__text,
.contact .contact__grid .contact__intro .contact__annotation {
  font-family: "Noto-M", serif;
  font-weight: 500;
  word-break: normal;
  overflow-wrap: break-word;
  line-break: strict;
}
.contact .contact__grid .contact__intro .contact__text {
  font-size: clamp(14px, 12.058px + 0.518vw, 22px);
  line-height: 2;
}
@media (max-width: 1100px) {
  .contact .contact__grid .contact__intro .contact__text {
    line-height: 1.5;
  }
  .contact .contact__grid .contact__intro .contact__text .nowrap {
    white-space: nowrap;
  }
}
.contact .contact__grid .contact__intro .contact__annotation {
  font-size: clamp(12px, 10.058px + 0.518vw, 20px);
  line-height: 1.5;
  padding-left: 1.2em;
  position: relative;
}
.contact .contact__grid .contact__intro .contact__annotation .contact__annotation--mark {
  position: absolute;
  left: 0;
  top: 0;
}
.contact .contact__grid .contact__intro .contact__annotation a {
  color: #000000;
}

.contact__form {
  padding: 42px clamp(15px, 11.359px + 0.971vw, 30px) 40px;
  background-color: #fff;
  box-shadow: 3px 3px 13px 0px rgba(0, 0, 0, 0.25);
}
@media (max-width: 1100px) {
  .contact__form {
    width: 100%;
  }
}
.contact__form #form-title {
  font-size: 1.5rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: clamp(50px, 49.272px + 0.194vw, 53px);
  text-align: center;
}
.contact__form .form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.contact__form .form .form__row input::-moz-placeholder .form__row textarea::-moz-placeholder {
  color: #6D6A6A;
}
.contact__form .form .form__row input::placeholder .form__row textarea::placeholder {
  color: #6D6A6A;
}
.contact__form .form .form__legend,
.contact__form .form .form__label {
  display: flex;
  justify-content: flex-start;
  gap: 16px;
  font-size: 1.125rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  margin: 3.5px 0;
}
.contact__form .form .form__req,
.contact__form .form .form__any {
  padding: 0 12px 2px;
  color: #fff;
  border-radius: 5px;
  font-size: 0.75rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
.contact__form .form .form__req {
  background-color: #851218;
}
.contact__form .form .form__any {
  background-color: #6D6A6A;
}
.contact__form .form .form__radios {
  display: flex;
  flex-direction: column;
  gap: 3px;
  line-height: 1.5;
  margin: 4px 20px 0;
}
.contact__form .form .form__radios .radio {
  display: flex;
  align-items: center;
  gap: 10px;
}
.contact__form .form .form__radios input {
  width: 18px;
  height: 18px;
  cursor: pointer;
}
@media (hover: hover) {
  .contact__form .form .form__radios input:hover {
    transform: scale(1.1);
  }
}
.contact__form .form .form__input,
.contact__form .form .form__textarea {
  background-color: #F2F2F2;
  margin-top: 5px;
  border-radius: 5px;
  font-size: 1rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}
@media (hover: hover) {
  .contact__form .form .form__input:hover,
  .contact__form .form .form__textarea:hover {
    border: 2px solid #000000;
  }
}
.contact__form .form .form__input {
  padding: 13px 20px;
  width: 100%;
  height: 50px;
}
.contact__form .form .form__textarea {
  width: 100%;
  height: 200px;
  padding: 10px 20px;
}
.contact__form .form .form__footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 50px;
  margin: 0 auto;
}
.contact__form .form .form__footer .check__text {
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1.5;
  text-wrap: nowrap;
}
.contact__form .form .form__footer .check__text a {
  display: inline-block;
  color: #000000;
  border-bottom: 1px solid #000000;
}
@media (hover: hover) {
  .contact__form .form .form__footer .check__text a:hover {
    font-weight: 700;
    color: #851218;
    border-bottom: 1px solid #851218;
  }
}
.contact__form .form .form__footer .check {
  display: flex;
  align-items: center;
  gap: 16px;
}
.contact__form .form .form__footer .check input {
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 5px;
  padding: 0;
  margin: 0;
  cursor: pointer;
}
@media (hover: hover) {
  .contact__form .form .form__footer .check input:hover {
    transform: scale(1.1);
  }
}
.contact__form .form .form__footer .form__submit {
  background-color: #851218;
  color: #fff;
  width: clamp(315px, 311.117px + 1.036vw, 331px);
  height: 60px;
  font-size: 1.5rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  margin: 0 auto;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}
@media (hover: hover) {
  .contact__form .form .form__footer .form__submit:hover {
    background-color: #fff;
    border-color: #851218;
    color: #851218;
  }
}
.contact__form .form-field .file {
  font-size: 1rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  margin: 5px 0;
}

.contact-confirm-page .contact .contact__grid #contact-title,
.craftsman-entry-page .contact .contact__grid #contact-title {
  font-size: clamp(24px, 22.058px + 0.518vw, 32px);
}

.contact-confirm {
  padding: clamp(40px, 39.515px + 0.129vw, 42px) clamp(15px, 11.359px + 0.971vw, 30px) 60px;
  background-color: #fff;
  box-shadow: 3px 3px 13px 0px rgba(0, 0, 0, 0.25);
}
.contact-confirm #form-title {
  font-size: 1.5rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: clamp(30px, 25.146px + 1.294vw, 50px);
  text-align: center;
}
.contact-confirm .form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.contact-confirm .form .form__groupInner,
.contact-confirm .form .form__row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
@media (max-width: 1500px) {
  .contact-confirm .form .form__groupInner,
  .contact-confirm .form .form__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
.contact-confirm .form .form__groupInner {
  gap: clamp(10px, 6.602px + 0.906vw, 24px);
}
.contact-confirm .form .form__row.last {
  margin-bottom: clamp(20px, 18.544px + 0.388vw, 26px);
}
.contact-confirm .form .form__legend,
.contact-confirm .form .form__label {
  display: flex;
  justify-content: flex-start;
  gap: 16px;
  font-size: 1.125rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  margin: 3.5px 0;
}
.contact-confirm .form .form__legend {
  width: 190px;
  text-wrap: nowrap;
}
.contact-confirm .form .form__label {
  max-width: 190px;
  min-width: 185px;
  width: 100%;
}
.contact-confirm .form .form__req,
.contact-confirm .form .form__any {
  padding: 0 12px 2px;
  color: #fff;
  border-radius: 5px;
  font-size: 0.75rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  text-align: center;
  line-height: 1.5;
}
.contact-confirm .form .form__req {
  background-color: #851218;
}
.contact-confirm .form .form__any {
  background-color: #6D6A6A;
}
.contact-confirm .form .form__radios {
  line-height: 1.5;
  margin: clamp(0px, -0.971px + 0.259vw, 4px) clamp(0px, -4.854px + 1.294vw, 20px) 0;
}
.contact-confirm .form .form__radios .radio {
  display: flex;
  align-items: center;
  gap: 10px;
}
.contact-confirm .form .form__radios input {
  width: 18px;
  height: 18px;
  margin: 0;
}
.contact-confirm .form .form__input,
.contact-confirm .form .form__textarea {
  font-size: 1rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}
.contact-confirm .form .form__input {
  padding: 0 clamp(0px, -4.854px + 1.294vw, 20px);
  height: 50px;
  align-content: center;
}
@media (max-width: 1500px) {
  .contact-confirm .form .form__input {
    height: auto;
  }
}
.contact-confirm .form .form__textarea {
  padding: 0 clamp(0px, -4.854px + 1.294vw, 20px);
}
.contact-confirm .form .form__footer {
  margin: 0 auto;
}
.contact-confirm .form .form__footer .form__submit {
  background-color: #851218;
  color: #fff;
  width: clamp(315px, 311.117px + 1.036vw, 331px);
  height: 60px;
  font-size: 1.5rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  margin: 0 auto;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}
@media (hover: hover) {
  .contact-confirm .form .form__footer .form__submit:hover {
    background-color: #fff;
    border-color: #851218;
    color: #851218;
  }
}
.contact-confirm .form .form-field {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  /* 見た目の箱（画像のUI） */
  /* 左：ファイル名表示 */
  /* 右：ボタン部分 */
  /* フォーカス可視化（アクセシビリティ） */
  /* hover（任意） */
}
.contact-confirm .form .form-field .form__label {
  text-wrap: nowrap;
  font-size: clamp(16px, 15.515px + 0.129vw, 18px);
}
@media (max-width: 1100px) {
  .contact-confirm .form .form-field .form__label {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}
.contact-confirm .form .form-field .file-field {
  width: 100%;
}
@media (max-width: 1100px) {
  .contact-confirm .form .form-field .file-field {
    gap: 4px;
    margin-bottom: 6px;
  }
}
.contact-confirm .form .form-field .file-field__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
.contact-confirm .form .form-field .file-field__ui {
  display: flex;
  align-items: stretch;
  width: 100%;
  height: 50px;
  border-radius: 5px;
  overflow: hidden;
  background: #f2f2f2;
  border: 1px solid transparent;
  box-sizing: border-box;
  cursor: pointer;
  transition: border 0.3s ease;
}
@media (hover: hover) {
  .contact-confirm .form .form-field .file-field__ui:hover {
    border: 1px solid #000000;
  }
}
.contact-confirm .form .form-field .file-field__name {
  flex: 1;
  display: flex;
  align-items: center;
  color: #6D6A6A;
  line-height: 1;
  padding: 13px 0 13px 20px;
}
.contact-confirm .form .form-field .file-field__btn {
  font-size: clamp(11px, 9.786px + 0.324vw, 16px);
  flex: 0 0 clamp(102px, 87.922px + 3.754vw, 160px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #D9D9D9;
  color: #6D6A6A;
  border-left: 1px solid #cfcfcf;
  transition: background-color 0.3s ease, color 0.3s ease;
}
@media (hover: hover) {
  .contact-confirm .form .form-field .file-field__btn:hover {
    background-color: #6D6A6A;
    color: #fff;
  }
}
.contact-confirm .form .form-field .file-field__input:focus-visible + .file-field__ui {
  outline: 2px solid #111;
  outline-offset: 2px;
}
@media (hover: hover) {
  .contact-confirm .form .form-field .file-field__ui:hover .file-field__btn {
    filter: brightness(0.98);
  }
}
.contact-confirm .confirm-radio {
  display: flex;
  align-items: center;
  gap: 10px;
}
.contact-confirm .confirm-radio__mark {
  width: 18px;
  height: 18px;
  border-radius: 9999px;
  border: 1px solid #1A99E8;
  position: relative;
  flex: 0 0 18px;
}
.contact-confirm .confirm-radio__mark::after {
  content: "";
  position: absolute;
  inset: 50%;
  width: 10px;
  height: 10px;
  border-radius: 9999px;
  background: #1A99E8;
  transform: translate(-50%, -50%);
}

.craftsman-entry-page .c-page-hero__eyebrow {
  text-transform: capitalize;
  margin-top: clamp(0px, -2.913px + 0.777vw, 12px);
}

.craftsman-entry {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto;
  padding: clamp(30px, 13.01px + 4.531vw, 100px) 0 clamp(50px, 33.01px + 4.531vw, 120px);
}
.craftsman-entry .craftsman-entry__intro {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: clamp(20px, -4.272px + 6.472vw, 120px);
  margin: 0 0 30px;
}
@media (max-width: 1100px) {
  .craftsman-entry .craftsman-entry__intro {
    margin: 0 0 40px;
  }
}
.craftsman-entry .craftsman-entry__intro .craftsman-entry__intro--lead,
.craftsman-entry .craftsman-entry__intro .craftsman-entry__intro--body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(18.7px, 15.957px + 0.731vw, 30px);
}
.craftsman-entry .craftsman-entry__intro #craftsman-entry-title,
.craftsman-entry .craftsman-entry__intro .craftsman-entry__subtitle {
  font-family: "Noto-B", serif;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}
.craftsman-entry .craftsman-entry__intro #craftsman-entry-title {
  font-size: clamp(24px, 20.117px + 1.036vw, 40px);
}
.craftsman-entry .craftsman-entry__intro .craftsman-entry__subtitle {
  font-size: clamp(16px, 14.544px + 0.388vw, 22px);
}
.craftsman-entry .craftsman-entry__intro .craftsman-entry__text,
.craftsman-entry .craftsman-entry__intro .craftsman-entry__annotation {
  font-family: "Noto-M", serif;
  font-weight: 500;
}
.craftsman-entry .craftsman-entry__intro .craftsman-entry__text {
  font-size: clamp(14px, 12.058px + 0.518vw, 22px);
  line-height: 2;
  text-align: center;
}
@media (max-width: 1100px) {
  .craftsman-entry .craftsman-entry__intro .craftsman-entry__text {
    line-height: 1.5;
    text-align: left;
  }
}
.craftsman-entry .craftsman-entry__intro .craftsman-entry__annotation {
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  line-height: 1.5;
}
.craftsman-entry .craftsman-entry__grid {
  display: grid;
  grid-template-columns: clamp(345px, 273.398px + 19.094vw, 640px) clamp(345px, 268.544px + 20.388vw, 660px);
  align-items: start;
  justify-content: center;
  gap: 70px;
}
@media (max-width: 1460px) {
  .craftsman-entry .craftsman-entry__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
.craftsman-entry .craftsman-entry__grid--left {
  padding: 40px clamp(15px, 13.786px + 0.324vw, 20px) 60px;
  background-color: #fff;
  box-shadow: 3px 3px 13px 0px rgba(0, 0, 0, 0.25);
}
.craftsman-entry .craftsman-entry__grid--left #job-requirements-title {
  font-size: 1.5rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: clamp(30px, 24.417px + 1.489vw, 53px);
  text-align: center;
}
.craftsman-entry .craftsman-entry__grid--left .job-requirements__list {
  display: grid;
  grid-template-columns: 137px 1fr;
  text-align: left;
}
@media (max-width: 1100px) {
  .craftsman-entry .craftsman-entry__grid--left .job-requirements__list {
    grid-template-columns: 1fr;
  }
}
.craftsman-entry .craftsman-entry__grid--left .job-requirements__list dt {
  font-size: 1.125rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  padding: 18px 0 16px 5px;
  border-bottom: 2px solid #851218;
  letter-spacing: 2.52px;
}
@media (max-width: 1100px) {
  .craftsman-entry .craftsman-entry__grid--left .job-requirements__list .job-requirements__term {
    display: inline-block;
    justify-self: start;
    padding: 20px 18px 2px 0;
    position: relative;
    border-bottom: none;
  }
  .craftsman-entry .craftsman-entry__grid--left .job-requirements__list .job-requirements__term::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background: #851218;
  }
}
.craftsman-entry .craftsman-entry__grid--left dd {
  font-size: clamp(16px, 15.515px + 0.129vw, 18px);
  font-weight: 400;
  line-height: 1.5;
  padding: clamp(8px, 5.087px + 0.777vw, 20px) 0 clamp(12px, 11.029px + 0.259vw, 16px) 10px;
  border-bottom: 2px solid #D9D9D9;
}
@media (max-width: 1100px) {
  .craftsman-entry .craftsman-entry__grid--left dd {
    border-bottom: none;
  }
}

.artisan__list {
  margin: clamp(40px, 31.505px + 2.265vw, 75px) 0 clamp(40px, 35.146px + 1.294vw, 60px);
  overflow: hidden;
}
.artisan__list .artisan__card {
  position: relative;
  width: clamp(280px, 236.311px + 11.65vw, 460px);
  padding: 0 clamp(16px, 10.175px + 1.553vw, 40px);
  box-sizing: border-box;
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .artisan__list .artisan__card:hover {
    opacity: 0.6;
  }
}
.artisan__list .artisan__card::after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: #851218;
  position: absolute;
  top: 0;
  right: 0;
}
.artisan__list .artisan__card .artisan__card--inner {
  position: relative;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--number {
  position: absolute;
  top: clamp(10px, 8.058px + 0.518vw, 18px);
  left: clamp(10px, 8.058px + 0.518vw, 18px);
  width: clamp(40px, 32.718px + 1.942vw, 70px);
  height: clamp(40px, 32.718px + 1.942vw, 70px);
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  background-color: #851218;
  font-weight: 700;
  font-size: clamp(14px, 11.573px + 0.647vw, 24px);
  line-height: 1;
  color: #fff;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--image {
  width: 100%;
  aspect-ratio: 383/515;
  border: 1px solid #851218;
  border-radius: clamp(24px, 15.262px + 2.33vw, 60px);
  overflow: hidden;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body {
  margin-top: clamp(24px, 15.505px + 2.265vw, 59px);
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item {
  display: flex;
  justify-content: flex-start;
  gap: 10px;
  position: relative;
  color: #000000;
  padding: clamp(8px, 7.029px + 0.259vw, 12px) 0 clamp(8px, 7.029px + 0.259vw, 12px);
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item:last-child::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item .item__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(4px, 3.515px + 0.129vw, 6px) clamp(8px, 7.515px + 0.129vw, 10px);
  min-width: clamp(56px, 52.602px + 0.906vw, 70px);
  border-radius: clamp(3px, 2.515px + 0.129vw, 5px);
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  line-height: 1;
  background-color: #851218;
  color: #fff;
  white-space: nowrap;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item .item__label--name {
  justify-content: space-between;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__meta .item .item__value {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  font-weight: 700;
  text-align: left;
  line-height: 1.2;
  align-content: center;
}
.artisan__list .artisan__card .artisan__card--inner .artisan__card--body .artisan__card--area {
  margin-top: clamp(10px, 8.544px + 0.388vw, 16px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(48px, 42.66px + 1.424vw, 70px);
  height: 22px;
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  font-weight: 700;
  line-height: 1;
  border-radius: clamp(3px, 2.515px + 0.129vw, 5px);
  border: 1px solid #851218;
  color: #851218;
}

.c-button {
  width: clamp(280px, 246.748px + 8.867vw, 417px);
  height: clamp(56px, 49.447px + 1.748vw, 83px);
  border-radius: 60px;
  margin: 8px auto 0;
  background-color: #000000;
  border: 1px solid transparent;
  font-size: clamp(18px, 15.087px + 0.777vw, 30px);
  font-weight: 400;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.c-button a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  letter-spacing: 0.08em;
  color: #fff;
  text-decoration: none;
  transition: color 0.3s ease;
  letter-spacing: 1.2px;
  cursor: pointer;
}
@media (hover: hover) {
  .c-button:hover {
    background-color: #fff;
    border: 1px solid #000000;
  }
  .c-button:hover a {
    color: #000000;
  }
}

.c-page-hero {
  position: relative;
  width: 100%;
}
.c-page-hero .c-page-hero__image {
  height: clamp(200px, 151.456px + 12.945vw, 400px);
}
.c-page-hero .c-page-hero__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-page-hero .c-page-hero__image::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}
.c-page-hero .c-page-hero__body {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -53%);
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.c-page-hero .c-page-hero__body .c-page-hero__title {
  font-size: clamp(32px, 20.35px + 3.107vw, 80px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  color: #fff;
  margin-bottom: clamp(-3px, 4.524px - 2.006vw, -34px);
}
.c-page-hero .c-page-hero__body .c-page-hero__eyebrow {
  font-size: clamp(32px, 25.204px + 1.812vw, 60px);
  font-family: "Crimson Text", serif;
  font-weight: 600;
  transform: skew(-25deg);
  line-height: 1;
  color: hsla(0, 0%, 100%, 0.5);
}

#c-breadcrumb {
  width: 100%;
  padding: clamp(10px, 6.359px + 0.971vw, 25px) 0 0 clamp(16px, -49.291px + 17.411vw, 285px);
  color: #000000;
}
#c-breadcrumb .c-breadcrumb__list {
  white-space: normal;
  max-width: 100%;
  font-size: clamp(12px, 9.087px + 0.777vw, 24px);
  font-weight: 400;
  line-height: 1;
  text-align: left;
}
@media screen and (max-width: 1100px) {
  #c-breadcrumb .c-breadcrumb__list {
    overflow-wrap: break-word;
  }
}
#c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item {
  display: inline;
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: break-word;
}
#c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a {
  color: #000000;
  text-decoration: none;
  position: relative;
}
#c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background-color: #851218;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
@media (hover: hover) {
  #c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a:hover {
    color: #851218;
  }
  #c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item a:hover::after {
    transform: scaleX(1);
  }
}
#c-breadcrumb .c-breadcrumb__list .c-breadcrumb__item + .c-breadcrumb__item::before {
  content: "/";
  margin: 0 0.5em;
  color: #000000;
}
#c-breadcrumb .c-breadcrumb__list .js-dynamic-category[aria-hidden=true] {
  display: none;
}

.c-pagination .pagination__list {
  text-align: center;
  font-size: clamp(20px, 4vw, 40px);
  font-weight: 700;
}
.c-pagination .pagination__list bottom {
  text-decoration: none;
}
.c-pagination .pagination__list .current,
.c-pagination .pagination__list .total {
  letter-spacing: 0.08em;
  transition: opacity 0.3s ease;
  cursor: pointer;
  color: #000000 !important;
}
@media (hover: hover) {
  .c-pagination .pagination__list .current:hover,
  .c-pagination .pagination__list .total:hover {
    opacity: 0.6;
  }
}
.c-pagination .pagination__list .pagination__next {
  width: clamp(36px, 4vw, 60px);
  height: clamp(36px, 4vw, 60px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: clamp(12px, 3vw, 20px);
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .c-pagination .pagination__list .pagination__next:hover {
    opacity: 0.6;
  }
}
.c-pagination .pagination__list .pagination__next img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

#fv {
  position: relative;
  width: 100%;
  height: auto;
  z-index: 5;
  font-family: "Noto-B", serif;
  font-weight: 600;
}

.fv__top {
  position: relative;
  width: 100%;
  height: clamp(210px, -0.922px + 56.246vw, 1079px);
  z-index: 1;
}
.fv__top .fv__slider img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
  overflow: hidden;
}
.fv__top .js-fv-slider {
  position: relative;
  width: 100%;
  margin: 0 auto;
}
.fv__top .js-fv-slider .slick-dots {
  position: absolute;
  left: 50%;
  bottom: -55px;
  transform: translateX(-50%);
  display: flex;
  gap: 3px;
  margin: 0;
  padding: 0;
  list-style: none;
  width: auto;
}
@media (max-width: 1460px) {
  .fv__top .js-fv-slider .slick-dots {
    display: none !important;
  }
}
.fv__top .slick-dots li button:before {
  display: none;
}
.fv__top .slick-dots li button {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid #851218;
  background-color: transparent;
  transition: all 0.3s ease;
  cursor: pointer;
  padding: 0;
}
.fv__top .slick-dots li.slick-active button {
  background-color: #851218;
}
.fv__top .js-fv-slider .slick-list,
.fv__top .js-fv-slider .slick-track {
  width: 100%;
}
.fv__top .fv__text {
  position: absolute;
  top: 50%;
  transform: translate(0, -39%);
  padding-left: clamp(20px, 10vw, 200px);
  pointer-events: none;
}
@media (max-width: 1100px) {
  .fv__top .fv__text {
    top: 50%;
    transform: translate(0, -50%);
    padding-left: clamp(10px, 6.3vw, 200px);
  }
}
.fv__top .fv__text h2 {
  writing-mode: vertical-rl;
  font-size: clamp(18px, 3.2vw, 56px);
  line-height: 1.8;
  letter-spacing: 0.18em;
}
@media (max-width: 1100px) {
  .fv__top .fv__text h2 {
    line-height: 1.5;
    letter-spacing: 0.18em;
  }
}
.fv__top .fv__text h2 .space {
  margin-top: -0.5em;
  letter-spacing: 13px;
}
@media (max-width: 1100px) {
  .fv__top .fv__text h2 .space {
    letter-spacing: 0.2em;
  }
}
.fv__top .fv__text h2 .color {
  color: #851218;
  letter-spacing: 12px;
}
@media (max-width: 1100px) {
  .fv__top .fv__text h2 .color {
    letter-spacing: 0.3em;
  }
}

.fv__bottom {
  position: relative;
  z-index: 20;
}
.fv__bottom .fv-stats__list {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #851218;
  overflow: hidden;
  background-color: #fff;
  color: #851218;
  position: absolute;
  top: clamp(-70px, 32vw, -100px);
  right: clamp(12px, 4vw, 75px);
  transform: translate(-50%, -75%);
  width: clamp(160px, 30vw, 400px);
  height: clamp(50px, 10vw, 125px);
  border-radius: clamp(10px, 1.4vw, 20px);
}
@media (max-width: 768px) {
  .fv__bottom .fv-stats__list {
    transform: translate(-10%, 0);
  }
}
.fv__bottom .fv-stats__list .fv-stats__item {
  flex: 1;
  text-align: center;
}
.fv__bottom .fv-stats__list .fv-stats__item .font {
  letter-spacing: clamp(1px, 1vw, 5px);
}
.fv__bottom .fv-stats__list .fv-stats__item .fv-stats__label {
  display: block;
  font-size: clamp(10px, 1.8vw, 18px);
  margin-bottom: 8px;
}
.fv__bottom .fv-stats__list .fv-stats__item .fv-stats__value {
  font-size: clamp(16px, 3.2vw, 32px);
  display: flex;
  align-items: baseline;
  justify-content: center;
}
.fv__bottom .fv-stats__list .fv-stats__item .fv-stats__number {
  font-size: clamp(20px, 3.2vw, 46px);
  font-weight: 600;
  letter-spacing: 1px;
  padding-left: 10px;
}
.fv__bottom .fv-stats__list .fv-stats__item:not(:first-child)::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  background-color: #851218;
}
.fv__bottom .fv__lead {
  font-size: clamp(16px, 3.2vw, 34px);
  font-weight: 700;
  line-height: 2.4;
  letter-spacing: 0.2rem;
  text-align: center;
  max-width: clamp(345px, 72vw, 1380px);
  width: 100%;
  margin: clamp(40px, 10vw, 100px) auto 0;
}
@media (max-width: 768px) {
  .fv__bottom .fv__lead {
    line-height: 1.8;
  }
}

#artisan {
  padding: clamp(80px, 12vw, 200px) 0 clamp(100px, 9vw, 135px);
}
#artisan .artisan__title {
  font-size: clamp(48px, 8vw, 108px);
  letter-spacing: clamp(3px, 0.6vw, 6px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: #851218;
}

.is-artisan-noimage .artisan__card--image {
  display: none;
}

.is-artisan-noimage .artisan__card--top {
  width: 100%;
  height: clamp(40px, 37.573px + 0.647vw, 50px);
  background: #fff;
}

#area {
  text-align: center;
  max-width: clamp(350px, 76vw, 1380px);
  margin: 0 auto;
}
#area .area__title {
  font-size: clamp(32px, 8vw, 48px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.2rem;
  color: #851218;
}
#area .area__primary {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: clamp(14px, 3vw, 45px) clamp(14px, 3vw, 30px);
  margin: clamp(24px, 4vw, 63px) 0 clamp(20px, 4vw, 63px);
}
#area .area__regions {
  width: 100%;
  display: grid;
  margin: 0 auto;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(16px, 2vw, 20px) clamp(20px, 4vw, 70px);
}
#area .area__regions .region {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: clamp(12px, 2vw, 30px);
  font-size: clamp(13px, 1.1vw, 18px);
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0.4rem;
  position: relative;
  padding-bottom: clamp(10px, 1.4vw, 14px);
  border-bottom: 1px solid #851218;
}
#area .area__regions .region .region__title {
  width: 110px;
  flex-shrink: 0;
  text-align: left;
}
#area .area__regions .region .region__list {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 20px;
  white-space: nowrap;
}
#area .area__regions .region .region__list a {
  color: #851218;
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  #area .area__regions .region .region__list a:hover {
    opacity: 0.6;
  }
}
#area .area__button {
  background-color: #851218;
  margin: 0 auto;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
#area .area__button .area-pill {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 45px;
  transition: color 0.3s ease;
}
@media (hover: hover) {
  #area .area__button:hover {
    background-color: #fff;
    border: 1px solid #851218;
  }
  #area .area__button:hover .area-pill {
    color: #851218;
  }
}

@media (max-width: 1760px) {
  .region__list {
    flex-wrap: wrap;
  }
}
@media (max-width: 1380px) {
  .area__regions {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 900px) {
  .region {
    flex-wrap: wrap;
  }
}
#blog {
  padding: clamp(80px, 12vw, 180px) 0 clamp(50px, 9vw, 80px);
}
#blog .blog__title {
  font-size: clamp(48px, 8vw, 108px);
  font-family: "Bodoni72", sans-serif;
  line-height: 1;
  letter-spacing: 0.5rem;
  text-align: center;
  text-transform: uppercase;
  color: #851218;
}
#blog .blog__categories {
  margin-top: clamp(18px, 6vw, 20px);
}
#blog .blog__categories .blog__category-list {
  display: flex;
  justify-content: center;
  gap: clamp(8px, 3vw, 15px);
}
#blog .blog__categories .blog__category-list li {
  padding: 0;
  font-size: clamp(12px, 2.6vw, 20px);
  font-weight: 600;
  line-height: 1;
}
#blog .blog__categories .blog__category-list .blog__category {
  display: flex;
  width: clamp(75px, 12vw, 127px);
  height: clamp(25px, 6vw, 40px);
  border: 1px solid #851218;
  border-radius: 5px;
  align-items: center;
  justify-content: center;
  color: #851218;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
@media (hover: hover) {
  #blog .blog__categories .blog__category-list .blog__category:hover {
    background-color: #851218;
    color: #fff;
  }
}

.blog__list {
  margin: clamp(30px, 8vw, 57px) 0;
  overflow: hidden;
}
.blog__list.slick-initialized .slick-track {
  display: flex;
  align-items: stretch;
}
.blog__list.slick-initialized .slick-slide {
  height: auto;
}
.blog__list .blog__item {
  padding: 0 clamp(16px, 3vw, 40px);
  position: relative;
  width: clamp(280px, 42vw, 460px);
  display: flex;
  box-sizing: border-box;
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .blog__list .blog__item:hover {
    opacity: 0.6;
  }
}
.blog__list .blog__item::after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: #851218;
  position: absolute;
  top: 0;
  right: 0;
}
.blog__list .blog__item .blog-card {
  position: relative;
  display: flex;
  width: 100%;
}
.blog__list .blog__item .blog-card .blog-card__link {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.blog__list .blog__item .blog-card .blog-card__badge {
  position: absolute;
  top: clamp(10px, 1.5vw, 30px);
  left: clamp(10px, 1.5vw, 20px);
  width: clamp(40px, 6vw, 70px);
  height: clamp(40px, 6vw, 70px);
  display: grid;
  place-items: center;
  border-radius: 50%;
  background-color: #851218;
  font-size: clamp(14px, 2.2vw, 20px);
  font-family: "Bodoni72", sans-serif;
  line-height: 1;
  text-align: center;
  align-content: center;
  color: #fff;
}
.blog__list .blog__item .blog-card .blog-card__thumb {
  width: 100%;
  aspect-ratio: 383/385;
  border: 1px solid #851218;
  border-radius: clamp(24px, 6vw, 60px);
  overflow: hidden;
}
.blog__list .blog__item .blog-card .blog-card__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.blog__list .blog__item .blog-card .blog-card__body {
  margin-top: clamp(15px, 4vw, 30px);
  display: flex;
  flex: 1;
  flex-direction: column;
}
.blog__list .blog__item .blog-card .blog-card__body .blog-card__date {
  font-size: clamp(11px, 1.6vw, 16px);
  font-family: "Bodoni72", sans-serif;
  font-weight: 600;
  color: #000000;
}
.blog__list .blog__item .blog-card .blog-card__body .blog-card__title {
  margin: clamp(6px, 2.2vw, 10px) 0 clamp(12px, 3.2vw, 18px);
  font-size: clamp(14px, 1.6vw, 24px);
  font-weight: 600;
  line-height: 1.4;
  color: #851218;
  white-space: normal;
  overflow-wrap: anywhere;
}
.blog__list .blog__item .blog-card .blog-card__body .blog-card__tags {
  display: flex;
  gap: clamp(5px, 1.1vw, 10px);
  margin-top: auto;
}
.blog__list .blog__item .blog-card .blog-card__body .blog-card__tags li {
  width: clamp(38px, 10vw, 67px);
  height: clamp(16px, 4vw, 22px);
  text-align: center;
  align-content: center;
  border-radius: clamp(3px, 0.8vw, 5px);
  font-size: clamp(8px, 1.6vw, 12px);
  line-height: 1;
  color: #851218;
  border: 1px solid #851218;
}

.is-search-page.search-page--has-result {
  background: linear-gradient(to right, hsla(0, 0%, 76%, 0.12), #fff);
}

/* 検索前は結果エリア丸ごと非表示 */
.search-page--no-result .search-page__section--result {
  display: none;
}

.search-page--has-result #search-form.search-page__section--form {
  padding: clamp(30px, 13.01px + 4.531vw, 100px) 0 clamp(30px, 17.864px + 3.236vw, 80px);
}
.search-page--has-result #search-form.search-page__section--form .search-form__subtitle {
  margin-top: -45px;
  transform: skew(-25deg);
}
.search-page--has-result #search-form.search-page__section--form .search-form {
  margin: clamp(0px, -4.854px + 1.294vw, 20px) 0 0;
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-row.top {
  margin: clamp(40px, 46.068px - 1.618vw, 15px) 0 15px;
}
@media (max-width: 1100px) {
  .search-page--has-result #search-form.search-page__section--form .search-form .search-row.top {
    width: auto;
    gap: 10px;
  }
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-row__title {
  width: 234px;
}
@media (max-width: 1100px) {
  .search-page--has-result #search-form.search-page__section--form .search-form .search-row__title {
    width: auto;
  }
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-row.bottom {
  margin: 16px 0 0;
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-row.bottom .search-row__list {
  gap: clamp(12px, 9.087px + 0.777vw, 24px);
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-group--service {
  margin: clamp(0px, -3.641px + 0.971vw, 15px) 0 clamp(50px, 43.932px + 1.618vw, 75px);
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-group--service .search-row.top {
  margin: clamp(30px, 33.641px - 0.971vw, 15px) 0 15px;
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-group--service .search-row__list {
  gap: clamp(12px, 9.087px + 0.777vw, 24px);
}
.search-page--has-result #search-form.search-page__section--form .search-form .search-form__submit .search-button {
  padding: 0 clamp(78px, 75.087px + 0.777vw, 90px) 0 clamp(68px, 72.126px - 1.1vw, 51px);
}

#search-form {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  padding: clamp(60px, 50.291px + 2.589vw, 100px) 0 clamp(30px, 5.728px + 6.472vw, 130px);
  margin: 0 auto;
  text-align: center;
}
#search-form .search-form__title {
  font-size: clamp(40px, 29.32px + 2.848vw, 84px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
}
#search-form .search-form__subtitle {
  margin: -15px 0 0;
  font-size: 5.25rem;
  font-family: "Crimson Text", serif;
  font-style: italic;
  transform: skew(-20deg);
  font-weight: 600;
  line-height: 1;
  text-transform: capitalize;
  color: hsla(0, 0%, 0%, 0.1);
}
@media (max-width: 1100px) {
  #search-form .search-form__subtitle {
    display: none;
  }
}
#search-form .search-form__subtitle span {
  text-transform: none;
}
#search-form .search-form {
  margin: 4px 10% 0;
}
@media (max-width: 1100px) {
  #search-form .search-form {
    margin: 0;
  }
}
#search-form .search-form .search-row__title {
  width: 195px;
  text-align: left;
  font-size: 1.25rem;
  line-height: 1.4;
}
#search-form .search-form .search-row.top {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: clamp(70px, 83.35px - 3.56vw, 15px) 0 15px;
}
#search-form .search-form .search-row.top .search-row__title {
  font-family: "Noto-B", serif;
  font-weight: 700;
  font-size: clamp(24px, 24.971px - 0.259vw, 20px);
}
#search-form .search-form .search-row.bottom {
  max-width: 100%;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, max-content);
  margin: 20px 0 0;
}
@media (max-width: 1380px) {
  #search-form .search-form .search-row.bottom {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}
#search-form .search-form .search-row.bottom .search-row__title {
  font-family: "Noto-M", serif;
  font-weight: 500;
  padding: 0 0 0 9px;
}
#search-form .search-form .search-row.bottom .search-row__list {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  white-space: nowrap;
  margin: 0 75px 0 0;
}
@media (max-width: 1100px) {
  #search-form .search-form .search-row.bottom .search-row__list {
    margin: 0;
  }
}
#search-form .search-form .search-group--service {
  margin: clamp(60px, 55.146px + 1.294vw, 80px) 0;
}
#search-form .search-form .search-group--service .search-row.top {
  margin: 0;
}
#search-form .search-form .search-group--service .search-row__title {
  width: 235px;
}
#search-form .search-form .pill {
  position: relative;
  display: inline-block;
  transition: all 0.2s;
}
@media (hover: hover) {
  #search-form .search-form .pill:hover span {
    background: #851218;
    border-color: #851218;
    color: #fff;
  }
}
#search-form .search-form .pill input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}
#search-form .search-form .pill span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 15px;
  border: 0.5px solid #851218;
  border-radius: 5px;
  background: #fff;
  color: #851218;
  font-size: 1.25rem;
  font-family: "Noto-M", serif;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}
#search-form .search-form .pill input:checked + span {
  background: #851218;
  border-color: #851218;
  color: #fff;
}
#search-form .search-form .search-button {
  width: clamp(270px, 233.592px + 9.709vw, 420px);
  height: clamp(56.7px, 49.103px + 2.026vw, 88px);
  border-radius: clamp(32px, 25.204px + 1.812vw, 60px);
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(11.7px, -1.237px + 3.45vw, 65px);
  padding: 0 clamp(97px, 96.272px + 0.194vw, 100px) 0 clamp(68px, 72.126px - 1.1vw, 51px);
  background-color: #851218;
  color: #fff;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color 0.3s ease, border-color 0.3s ease;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  margin: 0 auto;
}
#search-form .search-form .search-button .search-button__text {
  font-size: clamp(18px, 14.602px + 0.906vw, 32px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  color: currentColor;
  transition: color 0.3s ease;
}
#search-form .search-form .search-button .search-icon {
  width: clamp(19px, 16.33px + 0.712vw, 30px);
  height: clamp(19px, 16.33px + 0.712vw, 30px);
  display: block;
  color: currentColor;
}
@media (hover: hover) {
  #search-form .search-form .search-button:hover {
    background-color: #fff;
    border-color: #851218;
    color: #851218;
  }
}

@media (hover: hover) {
  #search-form .pill.is-nohover span {
    background: #fff !important;
    border-color: #851218 !important;
    color: #851218 !important;
  }
}
#search-result {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto clamp(30px, 5.728px + 6.472vw, 130px);
}
#search-result .artisan__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(20px, 5.437px + 3.883vw, 80px) clamp(25px, 20.146px + 1.294vw, 45px);
  margin: 0 0 clamp(60px, 55.146px + 1.294vw, 80px);
}
#search-result .artisan__list .artisan__card {
  width: clamp(160px, 96.893px + 16.828vw, 420px);
  height: clamp(316px, 197.311px + 31.65vw, 805px);
  background-color: #fff;
  padding: 0;
  border: none;
}
#search-result .artisan__list .artisan__card::after {
  display: none;
}
#search-result .artisan__list .artisan__card--link {
  color: #000000;
}
#search-result .artisan__list .result__img {
  width: clamp(160px, 96.893px + 16.828vw, 420px);
  height: clamp(107px, 60.155px + 12.492vw, 300px);
  border-radius: 0;
  position: relative;
  border: none;
  overflow: visible;
}
#search-result .artisan__list .result__img .artisan-card__photo {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0;
}
#search-result .artisan__list .result__img .artisan-card__avatar {
  position: absolute;
  bottom: -69px;
  right: clamp(17px, 15.058px + 0.518vw, 25px);
  width: clamp(49.3px, 27.771px + 5.741vw, 138px);
  height: clamp(49.3px, 27.771px + 5.741vw, 138px);
  border-radius: 999px;
}
@media (max-width: 1350px) {
  #search-result .artisan__list .result__img .artisan-card__avatar {
    bottom: -54px;
  }
}
@media (max-width: 1100px) {
  #search-result .artisan__list .result__img .artisan-card__avatar {
    bottom: -24.5px;
  }
}
#search-result .artisan__list .result__img .artisan-card__avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 999px;
}
#search-result .artisan__list .artisan__card--body {
  margin: 10px clamp(5px, 2.573px + 0.647vw, 15px) 0;
}
#search-result .artisan__list .artisan__card--area {
  width: auto;
  height: auto;
  padding: clamp(1px, 0.029px + 0.259vw, 5px) clamp(5.7px, 3.2px + 0.667vw, 16px);
  font-size: clamp(6px, 3.573px + 0.647vw, 16px);
  margin-top: clamp(0px, -3.883px + 1.036vw, 16px);
}
#search-result .artisan__list .artisan-card__skills {
  max-width: clamp(107.5px, 60.777px + 12.46vw, 300px);
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.7px, 0.899px + 0.214vw, 5px) clamp(3.5px, 1.922px + 0.421vw, 10px);
  margin-top: clamp(7px, 3.845px + 0.841vw, 20px);
  justify-content: flex-start;
}
#search-result .artisan__list .artisan-card__skills .pill {
  display: inline-flex;
  align-items: center;
  border-radius: clamp(1.7px, 0.899px + 0.214vw, 5px);
  font-size: clamp(6px, 3.573px + 0.647vw, 16px);
  font-weight: 500;
  text-align: center;
  line-height: 1;
  border: 1px solid #851218;
  color: #851218;
  padding: clamp(1px, 0.029px + 0.259vw, 5px) clamp(5.7px, 3.2px + 0.667vw, 16px);
}
#search-result .artisan__list .artisan-card__skills > li {
  margin: 0;
  padding: 0;
  line-height: 0; /* pillのみを内包するため行高を潰す */
}
#search-result .artisan__list .artisan__meta {
  margin-top: clamp(4.7px, 2.443px + 0.602vw, 14px);
}
#search-result .artisan__list .artisan__meta .item {
  gap: clamp(7px, 3.845px + 0.841vw, 20px);
  padding: clamp(6px, 3.573px + 0.647vw, 16px) 0 clamp(6px, 3.573px + 0.647vw, 16px);
}
#search-result .artisan__list .artisan__meta .item::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
}
#search-result .artisan__list .artisan__meta .item::before {
  display: none;
}
#search-result .artisan__list .artisan__meta .item .item__label {
  min-width: clamp(30px, 20.291px + 2.589vw, 70px);
  font-size: clamp(8px, 5.573px + 0.647vw, 18px);
  padding: clamp(0.36px, -0.766px + 0.3vw, 5px) clamp(3px, 1.786px + 0.324vw, 8px) clamp(0.7px, -0.829px + 0.408vw, 7px);
}
#search-result .artisan__list .artisan__meta .item .item__value {
  font-size: clamp(8px, 5.573px + 0.647vw, 18px);
  line-height: clamp(8px, 4.699px + 0.88vw, 21.6px);
}
#search-result .artisan-card__message {
  font-size: clamp(8px, 5.573px + 0.647vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  margin-top: clamp(5.7px, 3.2px + 0.667vw, 16px);
}
#search-result .artisan-card__message .artisan-card__message-title {
  display: inline-block;
  justify-content: space-between;
  padding: clamp(0.36px, -1.009px + 0.365vw, 6px) clamp(3px, 0.087px + 0.777vw, 15px) clamp(0.7px, -0.829px + 0.408vw, 7px) clamp(3px, 1.786px + 0.324vw, 8px);
  border-radius: clamp(1.8px, 1.023px + 0.207vw, 5px);
  background-color: #851218;
  color: #fff;
  text-align: center;
  align-items: center;
  margin-bottom: clamp(3.5px, 1.922px + 0.421vw, 10px);
}
#search-result .artisan-card__message .artisan-card__message-text {
  line-height: 1.5;
}
#search-result .c-button {
  width: clamp(270px, 233.592px + 9.709vw, 420px);
  height: clamp(56.7px, 49.103px + 2.026vw, 88px);
}

.search-result__empty {
  font-size: clamp(18px, 14.602px + 0.906vw, 32px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
}

.partner-company-page {
  margin-bottom: -145px;
}
@media (max-width: 1100px) {
  .partner-company-page {
    margin-bottom: -35px;
  }
}

.partner-company-hero {
  width: 100%;
  max-height: clamp(300px, 226.456px + 19.612vw, 603px);
  height: 100%;
  position: relative;
  margin-top: 7px;
}
@media (max-width: 1100px) {
  .partner-company-hero {
    margin-top: 30px;
  }
}
.partner-company-hero img {
  width: 100%;
  max-height: clamp(300px, 226.456px + 19.612vw, 603px);
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}
.partner-company-hero .partner-company-hero__widget {
  position: absolute;
  top: clamp(22px, 17.146px + 1.294vw, 42px);
  right: clamp(10.84px, 3.277px + 2.017vw, 42px);
  width: clamp(177px, 147.146px + 7.961vw, 300px);
  height: clamp(152px, 110.617px + 11.036vw, 322.5px);
  background: #F7F7F7;
  border-radius: clamp(14.2px, 11.579px + 0.699vw, 25px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.partner-company-hero #partner-company-rating-graph {
  width: 80%;
  height: 80%;
  background: #fff;
  border-radius: 6px;
}

.partner-company-card {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto clamp(30px, 13.01px + 4.531vw, 100px);
  background-color: #fff;
  border-radius: 100px;
  box-shadow: 2px 2px 20px rgba(0, 0, 0, 0.25);
  position: relative;
  top: -149px;
  padding: 80px 91px;
}
@media (max-width: 1100px) {
  .partner-company-card {
    top: -40px;
    background: transparent;
    box-shadow: none;
    padding: 0;
  }
}

@media (max-width: 1100px) {
  .partner-company-profile__inner {
    padding: 30px 15px;
    background: #fff;
    border-radius: 30px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  }
}

.partner-company-profile__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  justify-content: space-between;
  position: relative;
}
@media (max-width: 1380px) {
  .partner-company-profile__header {
    grid-template-columns: 1fr;
  }
}
.partner-company-profile__header:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
  position: absolute;
  bottom: 0;
  left: 0;
}
.partner-company-profile__header .partner-company-profile__name {
  font-size: clamp(28px, 23.146px + 1.294vw, 48px);
  line-height: 1;
  padding-bottom: clamp(16px, 13.573px + 0.647vw, 26px);
}
.partner-company-profile__header .partner-company-profile__summary {
  align-self: end;
  justify-self: end;
  padding-bottom: 16px;
}
@media (max-width: 1100px) {
  .partner-company-profile__header .partner-company-profile__summary {
    justify-self: start;
  }
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating {
  display: flex;
  flex-wrap: wrap;
  font-size: clamp(16px, 14.544px + 0.388vw, 22px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
}
@media (max-width: 1100px) {
  .partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating {
    gap: 6px;
  }
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__rating-label {
  margin-right: 30px;
}
@media (max-width: 1100px) {
  .partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__rating-label {
    margin-right: 0;
    flex: 0 0 100%;
  }
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__score-value,
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__rating-separator {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__score-stars .star-yellow {
  color: #ffcd29;
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__score-stars .star-gray {
  color: #bfb6b6;
}
.partner-company-profile__header .partner-company-profile__summary .partner-company-profile__rating .partner-company-profile__rating-count {
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
}

.partner-company-profile__section--about {
  position: relative;
  padding-bottom: 16px;
}
.partner-company-profile__section--about:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
  position: absolute;
  bottom: 0;
  left: 0;
}
.partner-company-profile__section--about .partner-company-profile__section-title {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  padding: 4.5px 8px;
  background-color: #851218;
  color: #fff;
  border-radius: 5px;
  margin: 16px 0 clamp(10px, 6.359px + 0.971vw, 25px);
}
.partner-company-profile__section--about .partner-company-profile__section-title .partner-company-profile__section-title-sub::before {
  content: " ";
}
.partner-company-profile__section--about .partner-company-profile__about {
  display: flex;
  flex-direction: column;
  gap: 16px;
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  font-family: "Noto-M", serif;
  line-height: 1.5;
}

.partner-company-profile__section--info .partner-company-profile__info-grid {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 16px 0 16px;
  position: relative;
}
@media (max-width: 1720px) {
  .partner-company-profile__section--info .partner-company-profile__info-grid {
    flex-direction: column;
    gap: 20px;
  }
}
.partner-company-profile__section--info .partner-company-profile__info-grid:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
  position: absolute;
  bottom: 0;
  left: 0;
}
.partner-company-profile__section--info .partner-company-profile__info {
  display: grid;
  grid-template-columns: 132px 1fr;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 20px;
}
@media (max-width: 1100px) {
  .partner-company-profile__section--info .partner-company-profile__info {
    grid-template-columns: 1fr;
    row-gap: 5px;
  }
}
.partner-company-profile__section--info .partner-company-profile__info--ceo {
  position: relative;
  padding: 16px 0;
}
.partner-company-profile__section--info .partner-company-profile__info--ceo::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media (max-width: 1100px) {
  .partner-company-profile__section--info .partner-company-profile__info dt,
  .partner-company-profile__section--info .partner-company-profile__info dd {
    margin: 0;
  }
  .partner-company-profile__section--info .partner-company-profile__info dd {
    padding-bottom: 16px;
  }
  .partner-company-profile__section--info .partner-company-profile__info dd:last-of-type {
    padding-bottom: 0;
  }
}
.partner-company-profile__section--info .partner-company-profile__info dt {
  width: clamp(120px, 117.087px + 0.777vw, 132px);
  height: 26px;
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  font-weight: 700;
  background-color: #851218;
  color: #fff;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  text-align: center;
  align-items: center;
}
.partner-company-profile__section--info .partner-company-profile__info dd {
  font-size: clamp(16px, 15.515px + 0.129vw, 18px);
  align-self: center;
}
.partner-company-profile__section--info .partner-company-profile__info dd a {
  color: #000000;
}
.partner-company-profile__section--info .partner-company-profile__map {
  margin: 0;
}
.partner-company-profile__section--info .partner-company-profile__map iframe {
  width: clamp(315px, 257.233px + 15.405vw, 553px);
  height: clamp(200px, 170.874px + 7.767vw, 320px);
  display: block;
}

#partner-company-members {
  padding: 0 0 clamp(60px, 50.291px + 2.589vw, 100px);
  margin: 0 auto;
  max-width: clamp(345px, 145.243px + 53.269vw, 1168px);
  width: 100%;
  align-content: center;
}
#partner-company-members .partner-company-members__header {
  text-align: center;
  max-width: 749.84px;
  width: 100%;
  margin: clamp(50px, 37.864px + 3.236vw, 100px) auto clamp(30px, 25.146px + 1.294vw, 50px);
}
@media (max-width: 1100px) {
  #partner-company-members .partner-company-members__header {
    max-width: 100%;
  }
}
#partner-company-members .partner-company-members__header .partner-company-members__title {
  font-size: clamp(24px, 19.631px + 1.165vw, 42px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  letter-spacing: clamp(11.7px, 10.899px + 0.214vw, 15px);
  padding-bottom: clamp(20px, 19.272px + 0.194vw, 23px);
  position: relative;
}
#partner-company-members .partner-company-members__header .partner-company-members__title:after {
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  background-color: #14126f;
  position: absolute;
  bottom: 0;
  left: 0;
}
#partner-company-members .partner-company-members__header .partner-company-members__lead {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: clamp(5px, 2.573px + 0.647vw, 15px);
  font-size: clamp(16px, 15.515px + 0.129vw, 18px);
  line-height: 1;
}
@media (max-width: 1100px) {
  #partner-company-members .partner-company-members__header .partner-company-members__lead {
    text-align: left;
    line-height: 1.3;
  }
}
#partner-company-members .partner-company-members__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  -moz-column-gap: 16px;
       column-gap: 16px;
  row-gap: clamp(28.5px, 23.524px + 1.327vw, 49px);
}
@media (max-width: 1100px) {
  #partner-company-members .partner-company-members__list {
    -moz-column-gap: 25px;
         column-gap: 25px;
  }
}
#partner-company-members .partner-company-members__list .partner-company-member-card {
  width: clamp(160px, 130.874px + 7.767vw, 280px);
  height: auto;
}
#partner-company-members .partner-company-members__list .partner-company-member-card__image {
  width: clamp(160px, 130.874px + 7.767vw, 280px);
  height: clamp(179.6px, 150.377px + 7.793vw, 300px);
}
#partner-company-members .partner-company-members__list .partner-company-member-card__image img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
#partner-company-members .partner-company-members__list .partner-company-member-card__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  margin-top: 5px;
  color: #000000;
  font-family: "Noto-M", serif;
  line-height: 1.5;
}
#partner-company-members .partner-company-members__list .partner-company-member-card__body h3 {
  font-size: clamp(14px, 12.544px + 0.388vw, 20px);
}
#partner-company-members .partner-company-members__list .partner-company-member-card__body p {
  font-size: clamp(12px, 11.515px + 0.129vw, 14px);
}
@media (max-width: 1100px) {
  #partner-company-members .partner-company-members__list .partner-company-member-card__body p {
    line-height: 1;
  }
}

.artisan-page {
  padding: 0 0 clamp(30px, 13.01px + 4.531vw, 100px);
}

.artisan-header__title {
  margin: clamp(-15px, 0.777px - 4.207vw, -80px) clamp(0px, -13.35px + 3.56vw, 55px) 0 0;
  font-size: clamp(78px, 43.534px + 9.191vw, 220px);
  font-family: "Crimson Text", serif;
  font-style: italic;
  font-weight: 600;
  color: hsla(0, 0%, 0%, 0.1);
  text-align: right;
  transform-origin: center right;
  transform: skewX(-25deg) scaleY(0.9);
  pointer-events: none;
}

.artisan-page__cta {
  width: clamp(270px, 233.592px + 9.709vw, 420px);
  height: clamp(56.7px, 49.103px + 2.026vw, 88px);
  background-color: #851218;
  margin: 0 auto;
}
@media (hover: hover) {
  .artisan-page__cta:hover {
    background-color: #fff;
    border: 1px solid #851218;
  }
  .artisan-page__cta:hover a {
    color: #851218;
  }
}

.artisan-hero {
  max-width: clamp(345px, 166.602px + 47.573vw, 1080px);
  width: 100%;
  margin: clamp(-17px, -12.631px - 1.165vw, -35px) auto 0;
  /* 顔＋リード */
}
.artisan-hero .artisan-hero__head {
  display: flex;
  align-items: center;
  gap: clamp(17px, 13.845px + 0.841vw, 30px);
  margin-bottom: 16px;
}
.artisan-hero .artisan-hero__head .artisan-hero__avatar {
  flex: 0 0 auto;
  width: clamp(83px, 74.019px + 2.395vw, 120px);
  height: clamp(83px, 74.019px + 2.395vw, 120px);
  border-radius: 50%;
  overflow: hidden;
}
.artisan-hero .artisan-hero__head .artisan-hero__avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.artisan-hero .artisan-hero__head .artisan-hero__lead {
  font-size: clamp(14px, 11.573px + 0.647vw, 24px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
}

/* 画像＋レーダーチャート */
.artisan-hero__media {
  display: grid;
  grid-template-columns: minmax(0, 680px) 1fr;
  gap: clamp(15px, 10.631px + 1.165vw, 33px);
}
@media (max-width: 1100px) {
  .artisan-hero__media {
    grid-template-columns: 1fr;
  }
}
.artisan-hero__media .artisan-hero__photo {
  height: clamp(215.5px, 171.689px + 11.683vw, 396px);
  border-radius: 20px;
  overflow: hidden;
}
.artisan-hero__media .artisan-hero__photo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.artisan-hero__media .artisan-hero__widget {
  width: 100%;
  height: auto;
  aspect-ratio: 367/396;
  background: #F7F7F7;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.artisan-hero__media #artisan-hero-rating-graph {
  width: 80%;
  height: 80%;
  background: #fff;
  border-radius: 6px;
}

.artisan-hero__widget.sp_only {
  display: none;
}

@media (max-width: 1100px) {
  .artisan-hero__widget.pc_only {
    display: none;
  }
  .artisan-hero__widget.sp_only {
    display: flex;
  }
}
/* レーダーチャートがない時は1カラムになる */
.artisan-hero__media > :only-child {
  grid-column: 1/-1;
}

/* ▼ 詳細ゾーン */
.artisan-detail {
  max-width: clamp(345px, 166.602px + 47.573vw, 1080px);
  width: 100%;
  margin: 32px auto;
  display: grid;
  grid-template-columns: minmax(0, 680px) minmax(260px, 1fr);
  gap: 32px;
  align-items: flex-start;
}
@media (max-width: 1100px) {
  .artisan-detail {
    gap: 53px;
    grid-template-columns: 1fr;
  }
}
.artisan-detail .artisan-detail__main {
  font-size: clamp(14px, 13.515px + 0.129vw, 16px);
  font-family: "Noto-M", serif;
  line-height: clamp(14px, 11.573px + 0.647vw, 24px);
  padding: clamp(0px, -7.282px + 1.942vw, 30px) clamp(0px, -4.854px + 1.294vw, 20px) 0;
}
.artisan-detail .artisan-detail__main .artisan-section {
  /* 手順リスト全体 */
  /* 各ステップ */
  /* 左の赤丸＋番号 */
  /* タイトル */
  /* 説明文 */
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-section__title {
  font-size: clamp(16.9px, 16.633px + 0.071vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: clamp(16.9px, 14.449px + 0.654vw, 27px);
  color: #851218;
  position: relative;
  padding: 0 clamp(3.4px, 2.769px + 0.168vw, 6px) 4px clamp(5.3px, 4.159px + 0.304vw, 10px);
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-section__title:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
  position: absolute;
  bottom: 0;
  left: 0;
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-section__body,
.artisan-detail .artisan-detail__main .artisan-section .artisan-list {
  margin: clamp(4.3px, 3.887px + 0.11vw, 6px) clamp(3.4px, 2.769px + 0.168vw, 6px) clamp(20px, 17.573px + 0.647vw, 30px) clamp(5.3px, 4.159px + 0.304vw, 10px);
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  -moz-column-gap: 15px;
       column-gap: 15px;
  margin-bottom: -2px;
}
@media (max-width: 1100px) {
  .artisan-detail .artisan-detail__main .artisan-section .artisan-dl {
    margin-bottom: 0px;
  }
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-dl dd {
  margin-bottom: 0px;
}
@media (max-width: 1100px) {
  .artisan-detail .artisan-detail__main .artisan-section .artisan-dl dd {
    margin-bottom: 5px;
  }
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-section__body {
  line-height: 1.5;
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-section__body--message {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  line-height: 1.5;
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-step-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: step;
  margin-bottom: clamp(20px, 17.573px + 0.647vw, 30px);
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-step-list li {
  position: relative;
  padding-left: clamp(22px, 14.913px + 1.89vw, 51.2px);
  margin: clamp(4.3px, 3.402px + 0.239vw, 8px) 0 clamp(12px, 10.786px + 0.324vw, 17px);
  counter-increment: step;
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-step-list li::before {
  content: counter(step);
  position: absolute;
  left: clamp(0px, -2.718px + 0.725vw, 11.2px);
  top: 0;
  width: clamp(14px, 11.573px + 0.647vw, 24px);
  height: clamp(14px, 11.573px + 0.647vw, 24px);
  border-radius: 50%;
  background-color: #851218;
  color: #fff;
  font-size: clamp(8px, 6.544px + 0.388vw, 14px);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-step-list h3 {
  margin: 0 0 clamp(2px, 1.029px + 0.259vw, 6px);
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-step-list p {
  font-size: clamp(10px, 9.029px + 0.259vw, 14px);
}
.artisan-detail .artisan-detail__main .artisan-section .artisan-list li {
  margin-bottom: 0;
}
@media (max-width: 1100px) {
  .artisan-detail .artisan-detail__main .artisan-section .artisan-list li {
    margin-bottom: 5px;
  }
}
.artisan-detail .artisan-detail__side {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
}
.artisan-detail .artisan-detail__side .artisan-profile {
  padding: 20px clamp(10px, 8.786px + 0.324vw, 15px) 31px;
  background-color: #F7F7F7;
  border-radius: clamp(10px, 7.573px + 0.647vw, 20px);
}
.artisan-detail .artisan-detail__side .artisan-profile__title {
  font-family: "Crimson Text", serif;
  font-style: italic;
  font-size: 2.5rem;
  font-weight: 600;
  letter-spacing: 2.8px;
  text-align: center;
  margin: 5px 0 5px;
  line-height: 1;
  color: #851218;
  transform: skewX(-25deg) scaleY(0.8);
}
@media (max-width: 1100px) {
  .artisan-detail .artisan-detail__side .artisan-profile__title {
    font-size: 3.5rem;
  }
}
.artisan-detail .artisan-detail__side .artisan-profile__avatar {
  width: clamp(120px, 115.631px + 1.165vw, 138px);
  height: clamp(120px, 115.631px + 1.165vw, 138px);
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 5px;
}
.artisan-detail .artisan-detail__side .artisan-profile__avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
.artisan-detail .artisan-detail__side .artisan-profile__info {
  margin: clamp(15px, 13.786px + 0.324vw, 20px) 0 0;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item {
  display: flex;
  justify-content: flex-start;
  gap: 20px;
  padding: clamp(12px, 11.029px + 0.259vw, 16px) 0;
  position: relative;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item .item__label {
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  width: 64px;
  height: auto;
  padding: 4.5px 8px;
  border-radius: 5px;
  font-size: 1rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  background-color: #851218;
  color: #fff;
  text-align: center;
  align-items: center;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item .item__value {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  font-weight: 700;
  text-align: left;
  line-height: 1.2;
  align-content: center;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--star {
  gap: 27px;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--star .item__value {
  letter-spacing: 2px;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--star .item__value .star-yellow {
  color: #ffcd29;
  font-size: 1.25rem;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--star .item__value .star-gray {
  font-size: 1.25rem;
  color: #bfb6b6;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--qualification {
  flex-direction: column;
  gap: 14px;
}
.artisan-detail .artisan-detail__side .artisan-profile__info .item--qualification .item__label {
  padding: 4.5px 8px;
  width: 112px;
}
.artisan-detail .artisan-detail__side .artisan-profile__block {
  padding: clamp(12px, 11.029px + 0.259vw, 16px) 0;
  position: relative;
}
.artisan-detail .artisan-detail__side .artisan-profile__block::after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #851218;
}
.artisan-detail .artisan-detail__side .artisan-profile__block .artisan-profile__subtitle {
  font-size: 1rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  display: inline-block;
  justify-content: space-between;
  padding: 4.5px 8px;
  border-radius: 5px;
  background-color: #851218;
  color: #fff;
  text-align: center;
  align-items: center;
  margin: 0 0 10px;
}
.artisan-detail .artisan-detail__side .artisan-profile__block .artisan-profile__text {
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}

#reviews {
  max-width: clamp(345px, 166.602px + 47.573vw, 1080px);
  width: 100%;
  margin: 32px auto clamp(30px, 13.01px + 4.531vw, 100px);
  /* コンテナ */
  /* 閉じているときの本文（高さ制限） */
  /* 開いているとき（制限解除） */
}
@media (max-width: 1100px) {
  #reviews {
    margin-top: 40px;
  }
}
#reviews .reviews__main {
  padding: clamp(0px, -4.854px + 1.294vw, 20px) 0 clamp(16px, 12.602px + 0.906vw, 30px) clamp(0px, -4.854px + 1.294vw, 20px);
}
@media (max-width: 1100px) {
  #reviews .reviews__main {
    display: grid;
    grid-template-columns: 205.6px 1fr;
    /* レーダーチャートがない時は1カラムになる */
  }
  #reviews .reviews__main > :only-child {
    grid-column: 1/-1;
  }
}
#reviews .reviews__main .reviews-summary {
  display: flex;
  justify-content: flex-start;
  gap: clamp(9px, 3.903px + 1.359vw, 30px);
}
@media (max-width: 1100px) {
  #reviews .reviews__main .reviews-summary {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
#reviews .reviews__main .reviews-summary #reviews-title {
  font-size: clamp(20px, 19.515px + 0.129vw, 22px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
}
#reviews .reviews__main .reviews-summary .reviews-summary__score {
  display: flex;
  font-size: 1.125rem;
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
}
@media (max-width: 1100px) {
  #reviews .reviews__main .reviews-summary .reviews-summary__score {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 4px;
  }
  #reviews .reviews__main .reviews-summary .reviews-summary__score .reviews-summary__score-count {
    font-size: 0.79375rem;
  }
}
#reviews .reviews__main .reviews-summary .reviews-summary__score .reviews-summary__score-stars {
  letter-spacing: 2px;
}
#reviews .reviews__main .reviews-summary .reviews-summary__score .reviews-summary__score-separator::before {
  content: " ";
}
#reviews .reviews__main .reviews-summary .reviews-summary__score .reviews-summary__score-separator::after {
  content: "  ";
}
#reviews .reviews__main .artisan-hero__widget {
  width: 100%;
  height: auto;
  aspect-ratio: 139/149;
}
#reviews .reviews__main .artisan-hero__widget #artisan-hero-rating-graph {
  width: 100%;
  height: 100%;
  background: #F7F7F7;
}
#reviews .star-yellow {
  color: #ffcd29;
  font-size: 1.25rem;
}
#reviews .star-gray {
  color: #bfb6b6;
  font-size: 1.25rem;
}
#reviews .review-list__item {
  width: 100%;
  min-height: 185px;
  background-color: #FFF4F4;
  margin-bottom: clamp(13.2px, 6.695px + 1.735vw, 40px);
  padding: clamp(10.6px, 8.804px + 0.479vw, 18px) clamp(10.6px, 8.318px + 0.608vw, 20px);
}
#reviews .review-list__item .star-yellow {
  color: #ffcd29;
  font-size: clamp(16px, 15.029px + 0.259vw, 20px);
}
#reviews .review-list__item .star-gray {
  color: #bfb6b6;
  font-size: clamp(16px, 15.029px + 0.259vw, 20px);
}
#reviews .review-list__item .review__header {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: clamp(10px, 5.146px + 1.294vw, 30px);
}
#reviews .review-list__item .review__header .review__meta {
  color: #6D6A6A;
  font-size: clamp(10px, 8.544px + 0.388vw, 16px);
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}
#reviews .review-list__item .review__title {
  font-size: clamp(12.7px, 11.414px + 0.343vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  margin: clamp(1.3px, 0.645px + 0.175vw, 4px) 0 clamp(4.6px, 2.318px + 0.608vw, 14px);
}
#reviews .review-list__item .review__body p {
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}
#reviews .review__content {
  position: relative;
}
#reviews .review__body {
  overflow: hidden;
  line-height: 1.5;
}
#reviews .review__content.is-clamped .review__body {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
@media (max-width: 1100px) {
  #reviews .review__content.is-clamped .review__body {
    -webkit-line-clamp: 5;
  }
}
#reviews .review__content.is-open .review__body {
  -webkit-line-clamp: unset;
  display: block;
}
#reviews .review__toggle {
  margin-top: clamp(3.6px, 1.804px + 0.479vw, 11px);
  cursor: pointer;
  padding: 0;
  color: #6D6A6A;
  display: block;
  width: 100%;
  text-align: right;
  background-color: #FFF4F4;
  font-size: clamp(10.6px, 9.289px + 0.35vw, 16px);
  line-height: 1.5;
}
#reviews .review__content.is-clamped .review__toggle {
  display: block;
}
#reviews .review__toggle-less {
  display: none;
}
#reviews .review__content.is-open .review__toggle-more {
  display: none;
}
#reviews .review__content.is-open .review__toggle-less {
  display: inline;
}

.business-overview {
  text-align: center;
}
.business-overview .business-overview__header {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: clamp(30px, 13.01px + 4.531vw, 100px) auto clamp(40px, 25.437px + 3.883vw, 100px);
  font-size: clamp(20px, 15.146px + 1.294vw, 40px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  text-wrap: normal;
}
.business-overview .business-overview__header .md_only {
  display: none;
}
@media (max-width: 1760px) {
  .business-overview .business-overview__header .md_only {
    display: block;
  }
}
.business-overview .business-overview__header .sp_only {
  display: none;
}
@media (max-width: 768px) {
  .business-overview .business-overview__header .sp_only {
    display: block;
  }
}

.business-metrics {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto;
}
.business-metrics .business-metrics__head {
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
}
.business-metrics .business-metrics__head .business-overview__lead {
  font-size: clamp(20px, 13.204px + 1.812vw, 48px);
  margin-bottom: clamp(11px, 1.534px + 2.524vw, 50px);
}
.business-metrics .business-metrics__head .business-overview__text {
  font-size: clamp(14px, 9.631px + 1.165vw, 32px);
}
.business-metrics .business-metrics__list {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(13px, 0.379px + 3.366vw, 65px) clamp(12px, 5.689px + 1.683vw, 38px);
  margin: clamp(24px, 17.689px + 1.683vw, 50px) 0 clamp(40px, 20.583px + 5.178vw, 120px);
}
.business-metrics .business-metrics__list .business-metrics__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: clamp(107px, 57.971px + 13.074vw, 309px);
  height: clamp(107px, 57.971px + 13.074vw, 309px);
  background-color: #fff;
  box-shadow: 0px 3px 61.6px 0px rgba(0, 0, 0, 0.25);
  padding-bottom: clamp(7px, 3.845px + 0.841vw, 20px);
}
.business-metrics .business-metrics__list .business-metrics__item .business-metrics__value {
  color: #851218;
  font-size: clamp(9.7px, 6.229px + 0.926vw, 24px);
  font-family: "kozuka-gothic-pro", sans-serif;
  font-weight: 700;
  line-height: 1.7;
}
.business-metrics .business-metrics__list .business-metrics__item .business-metrics__value .bg {
  font-size: clamp(32px, 20.35px + 3.107vw, 80px);
  background: linear-gradient(180deg, #AA0810, #720D12);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 0.9;
}
.business-metrics .business-metrics__list .business-metrics__item .business-metrics__value .md {
  font-size: clamp(22px, 14.718px + 1.942vw, 52px);
  line-height: 1.2;
}
.business-metrics .business-metrics__list .business-metrics__item .business-metrics__label {
  font-size: clamp(9.7px, 5.258px + 1.184vw, 28px);
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.5;
}
.business-metrics .business-metrics__list .business-metrics__item--attachment {
  padding-top: clamp(10.5px, 5.767px + 1.262vw, 30px);
}
.business-metrics .business-metrics__list .business-metrics__item--attachment .business-metrics__figure img {
  width: clamp(59px, 32.301px + 7.12vw, 169px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--artisan {
  padding-top: clamp(12.7px, 6.729px + 1.592vw, 37.3px);
}
.business-metrics .business-metrics__list .business-metrics__item--artisan .business-metrics__figure {
  margin-bottom: clamp(5.8px, 3.082px + 0.725vw, 17px);
}
.business-metrics .business-metrics__list .business-metrics__item--artisan .business-metrics__figure img {
  width: clamp(68px, 36.689px + 8.35vw, 197px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--time {
  padding-top: clamp(10px, 5.388px + 1.23vw, 29px);
}
.business-metrics .business-metrics__list .business-metrics__item--time .business-metrics__figure {
  display: flex;
  align-items: flex-start;
  gap: clamp(10px, 3.932px + 1.618vw, 35px);
  position: relative;
}
.business-metrics .business-metrics__list .business-metrics__item--time .business-metrics__figure .artisan {
  width: clamp(33.4px, 18.109px + 4.078vw, 96.4px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--time .business-metrics__figure .clock {
  width: clamp(31.1px, 16.804px + 3.812vw, 90px);
  height: auto;
  align-content: center;
  margin: clamp(3px, 1.786px + 0.324vw, 8px) 0 0 clamp(0px, -2.427px + 0.647vw, 10px);
}
.business-metrics .business-metrics__list .business-metrics__item--time .business-metrics__figure::before {
  content: "";
  width: clamp(0.5px, 0.257px + 0.065vw, 1.5px);
  height: clamp(33px, 17.854px + 4.039vw, 95.4px);
  background-color: #000;
  transform: rotate(25deg);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-5%, -53%) rotate(31deg);
}
.business-metrics .business-metrics__list .business-metrics__item--contact {
  padding-top: clamp(5.5px, 2.951px + 0.68vw, 16px);
}
.business-metrics .business-metrics__list .business-metrics__item--contact .business-metrics__figure {
  margin-bottom: clamp(3.7px, 2.171px + 0.408vw, 10px);
}
.business-metrics .business-metrics__list .business-metrics__item--contact .business-metrics__figure img {
  width: clamp(55.4px, 30.254px + 6.706vw, 159px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--map {
  padding-top: clamp(1.5px, 0.65px + 0.227vw, 5px);
  position: relative;
  /* 共通：ピン */
  /* ピン位置調整（ざっくり例） */
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__map {
  margin-right: 8px;
  width: clamp(81.2px, 43.87px + 9.955vw, 235px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__pin {
  position: absolute;
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__pin--1 {
  width: clamp(20px, 10.898px + 2.427vw, 57.5px);
  top: 12%;
  left: 40%;
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__pin--2 {
  width: clamp(13.6px, 7.435px + 1.644vw, 39px);
  top: 25%;
  right: 10%;
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__pin--3 {
  width: clamp(10.7px, 5.773px + 1.314vw, 31px);
  top: 28%;
  left: 23%;
}
.business-metrics .business-metrics__list .business-metrics__item--map .business-metrics__value {
  position: absolute;
  top: 45%;
  left: 18%;
  font-size: clamp(6.9px, 3.72px + 0.848vw, 20px);
  line-height: 1.5;
}
.business-metrics .business-metrics__list .business-metrics__item--corporation {
  padding-top: clamp(5.6px, 2.954px + 0.706vw, 16.5px);
}
.business-metrics .business-metrics__list .business-metrics__item--corporation .business-metrics__figure {
  margin-bottom: clamp(6px, 1.388px + 1.23vw, 25px);
}
.business-metrics .business-metrics__list .business-metrics__item--corporation .business-metrics__figure img {
  width: clamp(54.7px, 29.943px + 6.602vw, 156.7px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--corporation .business-metrics__value {
  letter-spacing: -3px;
}
.business-metrics .business-metrics__list .business-metrics__item--corporation .business-metrics__value .bg {
  letter-spacing: -2px;
}
.business-metrics .business-metrics__list .business-metrics__item--speed {
  padding-top: clamp(2.4px, 0.07px + 0.621vw, 12px);
}
.business-metrics .business-metrics__list .business-metrics__item--speed .business-metrics__figure img {
  width: clamp(40.9px, 21.968px + 5.049vw, 118.9px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--speed .business-metrics__value {
  line-height: 1;
}
.business-metrics .business-metrics__list .business-metrics__item--speed .business-metrics__value .bg {
  margin: 0 clamp(3px, 1.908px + 0.291vw, 7.5px);
}
.business-metrics .business-metrics__list .business-metrics__item--speed .business-metrics__value .md {
  font-size: clamp(7px, 3.845px + 0.841vw, 20px);
  line-height: 1;
  margin-left: clamp(0px, -3.883px + 1.036vw, 16px);
}
.business-metrics .business-metrics__list .business-metrics__item--speed .business-metrics__label {
  line-height: 1.2;
}
.business-metrics .business-metrics__list .business-metrics__item--hours {
  padding-top: clamp(22px, 12.049px + 2.654vw, 63px);
  position: relative;
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__badge {
  position: absolute;
  top: -12%;
  right: -10%;
  transform: translateX(-10%);
}
@media (max-width: 500px) {
  .business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__badge {
    top: -9%;
  }
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__badge img {
  width: clamp(32.9px, 18.07px + 3.955vw, 94px);
  height: auto;
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours {
  line-height: 1;
  background: linear-gradient(180deg, #AA0810, #720D12);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  min-width: 0;
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours .hours-line--main {
  display: block;
  font-size: clamp(10px, 5.631px + 1.165vw, 28px);
  margin-bottom: clamp(5px, 3.786px + 0.324vw, 10px);
  white-space: nowrap;
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours .hours-line--main .hours-num {
  font-size: clamp(18px, 8.291px + 2.589vw, 58px);
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours .hours-line--time {
  display: block;
  font-size: clamp(14px, 6.233px + 2.071vw, 46px);
  margin-bottom: 3px;
  white-space: nowrap;
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours .hours-line--note {
  display: block;
  font-size: clamp(8.3px, 4.489px + 1.016vw, 24px);
}
.business-metrics .business-metrics__list .business-metrics__item--hours .business-metrics__value--hours .hours-line--note .hours-note-small {
  font-size: clamp(6.9px, 3.72px + 0.848vw, 20px);
}

.operators {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto;
  padding: 0 0 clamp(59px, 44.194px + 3.948vw, 120px);
  text-align: center;
}
.operators .operators__heading {
  font-size: clamp(24px, 18.175px + 1.553vw, 48px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: clamp(8.4px, 6.361px + 0.544vw, 16.8px);
  margin-bottom: clamp(16px, 9.689px + 1.683vw, 42px);
}

.operators__inner {
  display: flex;
  gap: clamp(24px, 21.087px + 0.777vw, 36px);
  justify-content: center;
  align-items: start;
}
@media (max-width: 980px) {
  .operators__inner {
    flex-direction: column;
    align-items: center;
  }
}
.operators__inner .operator-card {
  width: clamp(345px, 283.107px + 16.505vw, 600px);
  background-color: #fff;
  box-shadow: 3px 3px 13px 0px rgba(0, 0, 0, 0.25);
  height: auto;
}
.operators__inner .operator-card__media {
  position: relative;
  height: clamp(230px, 188.738px + 11.003vw, 400px);
  overflow: hidden;
}
.operators__inner .operator-card__bg {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.operators__inner .operator-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, hsla(0, 2%, 8%, 0.8), hsla(0, 2%, 8%, 0.5));
  pointer-events: none;
  z-index: 1;
}
.operators__inner .logo-banner {
  position: absolute;
  top: clamp(57.5px, 47.184px + 2.751vw, 100px);
  left: 50%;
  transform: translateX(-50%);
  padding: clamp(8px, 6.058px + 0.518vw, 16px) clamp(58px, 47.806px + 2.718vw, 100px) clamp(10px, 8.544px + 0.388vw, 16px);
  z-index: 2;
  background: linear-gradient(180deg, #CCCCCC, #FFFFFF, #999999);
  clip-path: polygon(6% 0%, 100% 0%, 94% 100%, 0% 100%);
}
.operators__inner .logo-banner img {
  width: clamp(152px, 125.786px + 6.99vw, 260px);
  height: auto;
}
.operators__inner .operator-card__catch {
  position: absolute;
  z-index: 2;
  bottom: clamp(59px, 47.835px + 2.977vw, 105px);
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  font-size: clamp(18.4px, 15.099px + 0.88vw, 32px);
  line-height: 1.5;
  text-align: center;
  white-space: nowrap;
}
.operators__inner .operator-card--right .logo-banner {
  padding: clamp(8px, 6.544px + 0.388vw, 14px) clamp(20px, 16.117px + 1.036vw, 36px) clamp(9px, 7.301px + 0.453vw, 16px);
  background: linear-gradient(180deg, #0B63BA, #83BFFF, #0B63BA);
}
.operators__inner .operator-card--right .logo-banner img {
  width: clamp(227px, 185.981px + 10.939vw, 396px);
  height: auto;
}
.operators__inner .operator-card--right .operator-card__catch {
  bottom: clamp(55px, 44.078px + 2.913vw, 100px);
}
.operators__inner .operators__divider {
  margin: clamp(0px, -38.835px + 10.356vw, 160px) 0;
}
.operators__inner .operators__divider svg {
  width: clamp(50px, 43.447px + 1.748vw, 77px);
  height: auto;
}
.operators__inner .operator-card__info {
  padding: clamp(12.5px, 10.194px + 0.615vw, 22px) clamp(26.5px, 22.738px + 1.003vw, 42px) clamp(29px, 23.417px + 1.489vw, 52px) clamp(17px, 13.845px + 0.841vw, 30px);
  display: grid;
  grid-template-columns: clamp(104px, 85.311px + 4.984vw, 181px) 1fr;
  text-align: left;
}
.operators__inner .operator-card__info dt {
  font-size: clamp(12px, 10.544px + 0.388vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  padding: clamp(11.5px, 9.922px + 0.421vw, 18px) 0 clamp(9px, 7.301px + 0.453vw, 16px) clamp(3px, 2.515px + 0.129vw, 5px);
  border-bottom: 2px solid #851218;
}
.operators__inner .operator-card__info dd {
  font-size: clamp(12px, 10.544px + 0.388vw, 18px);
  font-weight: 400;
  line-height: 1.5;
  padding: clamp(11.5px, 9.437px + 0.55vw, 20px) 0 clamp(9px, 7.301px + 0.453vw, 16px) clamp(5.7px, 4.656px + 0.278vw, 10px);
  border-bottom: 2px solid #D9D9D9;
  text-wrap: nowrap;
}
.operators__inner .operator-card__info dd a {
  color: #000000;
}

.operator-card__section--offices {
  text-align: left;
  padding: 0 clamp(15px, 11.359px + 0.971vw, 30px) clamp(30px, 24.66px + 1.424vw, 52px);
}
.operator-card__section--offices .operator-card__section-title {
  border-bottom: 2px solid #14126f;
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  padding: 0 0 clamp(9px, 7.301px + 0.453vw, 16px) clamp(3px, 2.515px + 0.129vw, 5px);
}
.operator-card__section--offices .operator-card__office {
  padding: clamp(4.6px, 3.775px + 0.22vw, 8px) 0 clamp(7.5px, 5.68px + 0.485vw, 15px);
  margin-left: clamp(11.5px, 9.437px + 0.55vw, 20px);
  border-bottom: 1px solid #D9D9D9;
}
.operator-card__section--offices .operator-card__office .operator-card__office-name {
  font-size: clamp(12px, 10.544px + 0.388vw, 18px);
  font-weight: 700;
  line-height: 1.5;
}
.operator-card__section--offices .operator-card__office .operator-card__office-body {
  font-size: clamp(10px, 8.058px + 0.518vw, 18px);
  font-weight: 400;
  line-height: 1.4;
}

.operator-card__section--business {
  text-align: left;
  padding: 0 clamp(15px, 11.359px + 0.971vw, 30px) clamp(32px, 22.534px + 2.524vw, 71px);
}
.operator-card__section--business .operator-card__section-title {
  border-bottom: 2px solid #14126f;
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.5;
  padding: 0 0 clamp(9px, 7.301px + 0.453vw, 16px) clamp(3px, 2.515px + 0.129vw, 5px);
}
.operator-card__section--business .operator-card__business-list {
  margin: clamp(4.6px, 3.289px + 0.35vw, 10px) 0 0 clamp(12px, 10.058px + 0.518vw, 20px);
  padding: 0 0 clamp(9px, 7.544px + 0.388vw, 15px);
  border-bottom: 1px solid #D9D9D9;
}
.operator-card__section--business .operator-card__business-list li {
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  font-weight: 400;
  line-height: 1.5;
}

.blog-archive {
  max-width: clamp(345px, 101.068px + 65.049vw, 1350px);
  width: 100%;
  margin: 0 auto;
  padding: clamp(20px, 0.583px + 5.178vw, 100px) 0 clamp(50px, 37.864px + 3.236vw, 100px);
}

.archive-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 1100px) {
  .archive-head {
    flex-direction: column;
    gap: 30px;
  }
}
.archive-head .archive-head__title {
  font-size: clamp(42px, 21.126px + 5.566vw, 128px);
  font-family: "Bodoni72", sans-serif;
  font-weight: 400;
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 1100px) {
  .archive-head .archive-head__title {
    line-height: 1.5;
  }
}
.archive-head .archive-head__navList {
  display: flex;
  justify-content: center;
  gap: clamp(11px, 8.816px + 0.583vw, 20px);
}
.archive-head .archive-head__navList li {
  width: clamp(78px, 67.806px + 2.718vw, 120px);
  height: clamp(40px, 37.573px + 0.647vw, 50px);
  border: 1px solid #851218;
  background-color: #fff;
  border-radius: clamp(5px, 3.786px + 0.324vw, 10px);
  font-size: clamp(16px, 14.786px + 0.324vw, 21px);
  font-weight: 500;
  line-height: 1;
  position: relative;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.archive-head .archive-head__navList li .archive-head__navLink {
  width: 100%;
  height: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: #851218;
  line-height: 1;
  cursor: pointer;
  transition: color 0.3s ease;
}
.archive-head .archive-head__navList li.is-current {
  background-color: #851218;
  border-color: #851218;
}
.archive-head .archive-head__navList li.is-current .archive-head__navLink {
  color: #fff;
}
@media (hover: hover) {
  .archive-head .archive-head__navList li:hover {
    background-color: #851218;
    border-color: #851218;
  }
  .archive-head .archive-head__navList li:hover .archive-head__navLink {
    color: #fff;
  }
  .archive-head .archive-head__navList li.is-nohover:hover {
    background-color: #fff;
    border-color: #851218;
  }
  .archive-head .archive-head__navList li.is-nohover:hover .archive-head__navLink {
    color: #851218;
  }
}

.post-grid__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 20.117px + 1.036vw, 40px) clamp(15px, 7.718px + 1.942vw, 45px);
  margin: clamp(30px, 17.864px + 3.236vw, 80px) 0 30px;
  justify-content: center;
  justify-items: center;
}
@media (max-width: 1100px) {
  .post-grid__list {
    grid-template-columns: repeat(2, minmax(0, 420px));
  }
}
.post-grid__list .post-grid__item {
  transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .post-grid__list .post-grid__item:hover {
    opacity: 0.6;
  }
}
.post-grid__list .post-grid__item .post-card {
  width: clamp(165px, 103.107px + 16.505vw, 420px);
  height: auto;
}
.post-grid__list .post-grid__item .post-card .post-card__media {
  width: clamp(165px, 103.107px + 16.505vw, 420px);
  height: clamp(163px, 110.33px + 14.045vw, 380px);
  border-radius: clamp(5px, 1.359px + 0.971vw, 20px);
  overflow: hidden;
}
.post-grid__list .post-grid__item .post-card .post-card__media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.post-grid__list .post-grid__item .post-card .post-card__body {
  margin: clamp(10.3px, 5.518px + 1.275vw, 30px) 0 clamp(12.9px, 8.75px + 1.107vw, 30px);
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__meta {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: clamp(12.9px, 8.75px + 1.107vw, 30px);
  font-weight: 500;
  font-family: "Noto-M", serif;
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__meta .post-card__date {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: clamp(1.7px, 1.142px + 0.149vw, 4px);
  font-size: clamp(8px, 4.845px + 0.841vw, 21px);
  color: #6D6A6A;
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__meta .post-card__date img {
  width: clamp(9px, 6.087px + 0.777vw, 21px);
  height: clamp(9px, 6.087px + 0.777vw, 21px);
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__meta .post-card__cat {
  width: clamp(42px, 33.748px + 2.201vw, 76px);
  height: clamp(11px, 7.845px + 0.841vw, 24px);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: clamp(3px, 2.272px + 0.194vw, 6px);
  font-size: clamp(8px, 6.714px + 0.343vw, 13.3px);
  color: #851218;
  border: 0.631px solid #851218;
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__title {
  margin: clamp(4px, 2.544px + 0.388vw, 10px) 0 clamp(10px, 6.602px + 0.906vw, 24px);
  font-size: clamp(14px, 11.573px + 0.647vw, 24px);
  font-weight: 700;
  font-family: "Noto-B", serif;
  line-height: 1;
  color: #851218;
}
@media (max-width: 1100px) {
  .post-grid__list .post-grid__item .post-card .post-card__body .post-card__title {
    line-height: 1.5;
  }
}
.post-grid__list .post-grid__item .post-card .post-card__body .post-card__excerpt {
  font-size: clamp(10px, 8.544px + 0.388vw, 16px);
  font-weight: 500;
  line-height: 1;
  color: #851218;
}
@media (max-width: 1100px) {
  .post-grid__list .post-grid__item .post-card .post-card__body .post-card__excerpt {
    line-height: 1.5;
  }
}

.blog-single {
  max-width: clamp(345px, 166.602px + 47.573vw, 1080px);
  width: 100%;
  margin: 0 auto;
  padding: clamp(30px, 13.01px + 4.531vw, 100px) 0 clamp(50px, 37.864px + 3.236vw, 100px);
}

.blog-article__title {
  font-size: clamp(18px, 14.602px + 0.906vw, 32px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1;
  color: #851218;
}

.blog-article__meta {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 30px;
  margin: clamp(11px, 9.665px + 0.356vw, 16.5px) 0 clamp(30px, 22.597px + 1.974vw, 60.5px);
  font-weight: 500;
  font-family: "Noto-M", serif;
}
.blog-article__meta .blog-article__modified {
  font-size: clamp(14px, 11.573px + 0.647vw, 24px);
  color: #6D6A6A;
}
.blog-article__meta .blog-article__cat {
  width: clamp(72px, 70.058px + 0.518vw, 80px);
  height: clamp(24px, 22.544px + 0.388vw, 30px);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  font-size: clamp(12px, 11.029px + 0.259vw, 16px);
  color: #851218;
  border: 0.631px solid #851218;
}

.blog-article__eyecatch {
  width: 100%;
  height: 380px;
  border-radius: 20px;
  overflow: hidden;
}
.blog-article__eyecatch img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}

.blog-article__content {
  margin: clamp(36px, 22.65px + 3.56vw, 91px) 0 clamp(30px, 13.01px + 4.531vw, 100px);
  display: flex;
  flex-direction: column;
  gap: clamp(34px, 27.689px + 1.683vw, 60px);
}

.blog-article__content-block {
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 11.573px + 0.647vw, 24px);
}

.blog-article__content-title {
  padding-left: clamp(14px, 12.544px + 0.388vw, 20px);
  border-left: 4px solid #851218;
  font-size: clamp(18px, 15.087px + 0.777vw, 30px);
  font-family: "Noto-B", serif;
  font-weight: 700;
  line-height: 1.45;
  color: #851218;
}

.blog-article__content p,
.blog-article__content-body {
  font-size: clamp(14px, 13.029px + 0.259vw, 18px);
  font-family: "Noto-M", serif;
  font-weight: 500;
  line-height: 1.8;
  color: #851218;
}

.contact__form .form .wpcf7-form-control.radio {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 3px;
  line-height: 1.5;
}
.contact__form .form .wpcf7-form-control.radio .wpcf7-list-item {
  margin: 0;
}
.contact__form .form .wpcf7-form-control.radio .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 10px;
}
.contact__form .form .wpcf7-form-control.radio input {
  margin: 0;
}
.contact__form .form .check {
  display: flex;
  align-items: center;
  gap: 16px;
}
.contact__form .form .check label {
  display: flex;
  align-items: center;
  gap: 16px;
}
.contact__form .form .wpcf7-list-item {
  margin: 0;
}

.privacy-policy__container {
  max-width: clamp(345px, 210.291px + 35.922vw, 900px);
  margin: 0 auto 50px;
  line-height: 1.9;
  font-size: 16px;
}

.privacy-policy__container h2 {
  font-size: 22px;
  margin: 56px 0 24px;
}

.privacy-policy__container p {
  margin-bottom: 16px;
}

.privacy-policy__container ul {
  margin: 16px 0 16px 20px;
}

#thanks {
  padding: 100px 14.8%;
  height: 100%;
}
@media screen and (max-width: 1100px) {
  #thanks {
    padding: 86px 7% 80px;
  }
}
#thanks h1 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  #thanks h1 {
    font-size: 1.5rem;
  }
}
#thanks .thanks__message {
  font-size: 1.375rem;
  font-weight: 400;
  line-height: 2;
  color: #000000;
  margin: 30px 0 60px;
}
@media screen and (max-width: 768px) {
  #thanks .thanks__message {
    font-size: 1rem;
    margin: 16px 0 40px;
  }
}
#thanks .thanks__caution {
  font-size: 1.25rem;
  line-height: 1.8;
  padding: 0 0 60px;
}
@media screen and (max-width: 768px) {
  #thanks .thanks__caution {
    font-size: 0.875rem;
    padding: 0 0 40px;
  }
}/*# sourceMappingURL=style.css.map */
