@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;900&family=Montserrat:ital,wght@0,100..900;1,100..900&family=Zen+Kaku+Gothic+New:wght@500;700;900&family=Zen+Kaku+Gothic+Antique:wght@400;500;700&family=Bebas+Neue&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;900&family=Montserrat:ital,wght@0,100..900;1,100..900&family=Zen+Kaku+Gothic+New:wght@500;700;900&family=Zen+Kaku+Gothic+Antique:wght@400;500;700&family=Bebas+Neue&display=swap");
/*reset--------------------------------------*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  box-sizing: border-box;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
  box-sizing: border-box;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  box-sizing: border-box;
}

img {
  width: auto;
  height: auto;
  max-width: 100%;
  border: 0;
  vertical-align: top;
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  -webkit-transform: translateZ(0);
}

a {
  text-decoration: none;
  color: inherit;
}

a:hover img {
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
  opacity: 0.7;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

b,
strong {
  font-weight: bold;
}

address {
  font-style: normal;
}

button {
  display: block;
  border: none;
  outline: none;
  appearance: none;
  background-color: transparent;
}

@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/YakuHanJP/YakuHanJP-Black.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Black.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Black.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: bold;
  src: url("../fonts/YakuHanJP/YakuHanJP-Bold.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Bold.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Bold.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: Medium;
  src: url("../fonts/YakuHanJP/YakuHanJP-Medium.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Medium.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/YakuHanJP/YakuHanJP-Regular.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Regular.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/YakuHanJP/YakuHanJP-DemiLight.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-DemiLight.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-DemiLight.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/YakuHanJP/YakuHanJP-Light.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Light.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Light.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/YakuHanJP/YakuHanJP-Thin.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Thin.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Thin.woff2") format("woff2");
}
/*共通設定*/
body {
  color: #1a1a1a;
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  line-height: 1.8;
  letter-spacing: 0.05rem;
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 14px;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  font-weight: 700;
}

p {
  line-height: 2.2;
}
@media screen and (max-width: 768px) {
  p {
    line-height: 1.7;
  }
}

button,
option,
input {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}

a {
  color: inherit;
}
a:hover {
  color: #e56913;
}

button:hover,
a:hover {
  transition: 0.3s ease-in-out;
}

/*color---------------------------------*/
.fw-300 {
  font-weight: 300;
}

.fw-400 {
  font-weight: 400;
}

.fw-500 {
  font-weight: 500;
}

.fw-600 {
  font-weight: 600;
}

.fw-700 {
  font-weight: 700;
}

.fw-800 {
  font-weight: 800;
}

.fw-900 {
  font-weight: 900;
}

.fs-12 {
  font-size: 12px;
}
@media screen and (max-width: 768px) {
  .fs-12 {
    font-size: 10px;
  }
}

.fs-13 {
  font-size: 13px;
}
@media screen and (max-width: 768px) {
  .fs-13 {
    font-size: 11px;
  }
}

.fs-15 {
  font-size: 15px;
}
@media screen and (max-width: 768px) {
  .fs-15 {
    font-size: 13px;
  }
}

.fs-16 {
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .fs-16 {
    font-size: 13px;
  }
}

.fs-18 {
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  .fs-18 {
    font-size: 15px;
  }
}

.fs-20 {
  font-size: 20px;
}
@media screen and (max-width: 768px) {
  .fs-20 {
    font-size: 18px;
  }
}

.fs-22 {
  font-size: 22px;
}
@media screen and (max-width: 768px) {
  .fs-22 {
    font-size: 18px;
  }
}

.fs-24 {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .fs-24 {
    font-size: 20px;
  }
}

.fs-30 {
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  .fs-30 {
    font-size: 24px;
  }
}

.fs-35 {
  font-size: 35px;
}
@media screen and (max-width: 768px) {
  .fs-35 {
    font-size: 26px;
  }
}

/*text color---------------------------------*/
.fc-w {
  color: #fff;
}

.fc-orange {
  color: #e56913;
}

/*background---------------------------------*/
.bg_white {
  background-color: #fff;
}

/*align---------------------------------*/
.alL {
  text-align: left !important;
}

.alR {
  text-align: right !important;
}

.alC {
  text-align: center !important;
}

/*width---------------------------------*/
.page-width {
  max-width: 1610px;
  width: 100%;
  margin: 0 auto;
  padding: 0 60px;
}
@media screen and (max-width: 768px) {
  .page-width {
    padding: 0 20px;
  }
}

.content-width {
  max-width: 1260px;
  width: 100%;
  margin: 0 auto;
}

/*余白---------------------------------*/
/*margin---------------------------------*/
.mt0 {
  margin-top: 0px !important;
}
@media screen and (max-width: 768px) {
  .mt0 {
    margin-top: 0px !important;
  }
}

.mb0 {
  margin-bottom: 0px !important;
}
@media screen and (max-width: 768px) {
  .mb0 {
    margin-bottom: 0px !important;
  }
}

/*padding---------------------------------*/
.pt0 {
  padding-top: 0px !important;
}
@media screen and (max-width: 768px) {
  .pt0 {
    padding-top: 0px !important;
  }
}

.pb0 {
  padding-bottom: 0px !important;
}
@media screen and (max-width: 768px) {
  .pb0 {
    padding-bottom: 0px !important;
  }
}

/*margin---------------------------------*/
.mt10 {
  margin-top: 10px !important;
}
@media screen and (max-width: 768px) {
  .mt10 {
    margin-top: 5px !important;
  }
}

.mb10 {
  margin-bottom: 10px !important;
}
@media screen and (max-width: 768px) {
  .mb10 {
    margin-bottom: 5px !important;
  }
}

/*padding---------------------------------*/
.pt10 {
  padding-top: 10px !important;
}
@media screen and (max-width: 768px) {
  .pt10 {
    padding-top: 5px !important;
  }
}

.pb10 {
  padding-bottom: 10px !important;
}
@media screen and (max-width: 768px) {
  .pb10 {
    padding-bottom: 5px !important;
  }
}

/*margin---------------------------------*/
.mt20 {
  margin-top: 20px !important;
}
@media screen and (max-width: 768px) {
  .mt20 {
    margin-top: 10px !important;
  }
}

.mb20 {
  margin-bottom: 20px !important;
}
@media screen and (max-width: 768px) {
  .mb20 {
    margin-bottom: 10px !important;
  }
}

/*padding---------------------------------*/
.pt20 {
  padding-top: 20px !important;
}
@media screen and (max-width: 768px) {
  .pt20 {
    padding-top: 10px !important;
  }
}

.pb20 {
  padding-bottom: 20px !important;
}
@media screen and (max-width: 768px) {
  .pb20 {
    padding-bottom: 10px !important;
  }
}

/*margin---------------------------------*/
.mt30 {
  margin-top: 30px !important;
}
@media screen and (max-width: 768px) {
  .mt30 {
    margin-top: 15px !important;
  }
}

.mb30 {
  margin-bottom: 30px !important;
}
@media screen and (max-width: 768px) {
  .mb30 {
    margin-bottom: 15px !important;
  }
}

/*padding---------------------------------*/
.pt30 {
  padding-top: 30px !important;
}
@media screen and (max-width: 768px) {
  .pt30 {
    padding-top: 15px !important;
  }
}

.pb30 {
  padding-bottom: 30px !important;
}
@media screen and (max-width: 768px) {
  .pb30 {
    padding-bottom: 15px !important;
  }
}

/*margin---------------------------------*/
.mt40 {
  margin-top: 40px !important;
}
@media screen and (max-width: 768px) {
  .mt40 {
    margin-top: 20px !important;
  }
}

.mb40 {
  margin-bottom: 40px !important;
}
@media screen and (max-width: 768px) {
  .mb40 {
    margin-bottom: 20px !important;
  }
}

/*padding---------------------------------*/
.pt40 {
  padding-top: 40px !important;
}
@media screen and (max-width: 768px) {
  .pt40 {
    padding-top: 20px !important;
  }
}

.pb40 {
  padding-bottom: 40px !important;
}
@media screen and (max-width: 768px) {
  .pb40 {
    padding-bottom: 20px !important;
  }
}

/*margin---------------------------------*/
.mt50 {
  margin-top: 50px !important;
}
@media screen and (max-width: 768px) {
  .mt50 {
    margin-top: 25px !important;
  }
}

.mb50 {
  margin-bottom: 50px !important;
}
@media screen and (max-width: 768px) {
  .mb50 {
    margin-bottom: 25px !important;
  }
}

/*padding---------------------------------*/
.pt50 {
  padding-top: 50px !important;
}
@media screen and (max-width: 768px) {
  .pt50 {
    padding-top: 25px !important;
  }
}

.pb50 {
  padding-bottom: 50px !important;
}
@media screen and (max-width: 768px) {
  .pb50 {
    padding-bottom: 25px !important;
  }
}

/*margin---------------------------------*/
.mt60 {
  margin-top: 60px !important;
}
@media screen and (max-width: 768px) {
  .mt60 {
    margin-top: 30px !important;
  }
}

.mb60 {
  margin-bottom: 60px !important;
}
@media screen and (max-width: 768px) {
  .mb60 {
    margin-bottom: 30px !important;
  }
}

/*padding---------------------------------*/
.pt60 {
  padding-top: 60px !important;
}
@media screen and (max-width: 768px) {
  .pt60 {
    padding-top: 30px !important;
  }
}

.pb60 {
  padding-bottom: 60px !important;
}
@media screen and (max-width: 768px) {
  .pb60 {
    padding-bottom: 30px !important;
  }
}

/*margin---------------------------------*/
.mt80 {
  margin-top: 80px !important;
}
@media screen and (max-width: 768px) {
  .mt80 {
    margin-top: 40px !important;
  }
}

.mb80 {
  margin-bottom: 80px !important;
}
@media screen and (max-width: 768px) {
  .mb80 {
    margin-bottom: 40px !important;
  }
}

/*padding---------------------------------*/
.pt80 {
  padding-top: 80px !important;
}
@media screen and (max-width: 768px) {
  .pt80 {
    padding-top: 40px !important;
  }
}

.pb80 {
  padding-bottom: 80px !important;
}
@media screen and (max-width: 768px) {
  .pb80 {
    padding-bottom: 40px !important;
  }
}

/*margin---------------------------------*/
.mt100 {
  margin-top: 100px !important;
}
@media screen and (max-width: 768px) {
  .mt100 {
    margin-top: 50px !important;
  }
}

.mb100 {
  margin-bottom: 100px !important;
}
@media screen and (max-width: 768px) {
  .mb100 {
    margin-bottom: 50px !important;
  }
}

/*padding---------------------------------*/
.pt100 {
  padding-top: 100px !important;
}
@media screen and (max-width: 768px) {
  .pt100 {
    padding-top: 50px !important;
  }
}

.pb100 {
  padding-bottom: 100px !important;
}
@media screen and (max-width: 768px) {
  .pb100 {
    padding-bottom: 50px !important;
  }
}

/*margin---------------------------------*/
.mt120 {
  margin-top: 120px !important;
}
@media screen and (max-width: 768px) {
  .mt120 {
    margin-top: 60px !important;
  }
}

.mb120 {
  margin-bottom: 120px !important;
}
@media screen and (max-width: 768px) {
  .mb120 {
    margin-bottom: 60px !important;
  }
}

/*padding---------------------------------*/
.pt120 {
  padding-top: 120px !important;
}
@media screen and (max-width: 768px) {
  .pt120 {
    padding-top: 60px !important;
  }
}

.pb120 {
  padding-bottom: 120px !important;
}
@media screen and (max-width: 768px) {
  .pb120 {
    padding-bottom: 60px !important;
  }
}

/*layout---------------------------------*/
.flex_wrap {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .flex_wrap {
    flex-flow: column wrap;
  }
}

/*displayのレスポンシブ対応*/
.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-grid {
  display: grid !important;
}

.d-inline-grid {
  display: inline-grid !important;
}

.d-table {
  display: table !important;
}

.d-table-row {
  display: table-row !important;
}

.d-table-cell {
  display: table-cell !important;
}

.d-flex {
  display: flex !important;
}

.d-inline-flex {
  display: inline-flex !important;
}

.d-list-item {
  display: list-item !important;
}

@media screen and (max-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-inline {
    display: inline !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-inline-block {
    display: inline-block !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-block {
    display: block !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-grid {
    display: grid !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-inline-grid {
    display: inline-grid !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-table {
    display: table !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-table-row {
    display: table-row !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-table-cell {
    display: table-cell !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
}

@media screen and (max-width: 576px) {
  .d-sm-list-item {
    display: list-item !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-none {
    display: none !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-inline {
    display: inline !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-inline-block {
    display: inline-block !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-block {
    display: block !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-grid {
    display: grid !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-inline-grid {
    display: inline-grid !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-table {
    display: table !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-table-row {
    display: table-row !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-table-cell {
    display: table-cell !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-inline-flex {
    display: inline-flex !important;
  }
}

@media screen and (max-width: 768px) {
  .d-md-list-item {
    display: list-item !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-inline {
    display: inline !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-inline-block {
    display: inline-block !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-block {
    display: block !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-grid {
    display: grid !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-inline-grid {
    display: inline-grid !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-table {
    display: table !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-table-row {
    display: table-row !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-table-cell {
    display: table-cell !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
}

@media screen and (max-width: 992px) {
  .d-lg-list-item {
    display: list-item !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-inline {
    display: inline !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-inline-block {
    display: inline-block !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-block {
    display: block !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-grid {
    display: grid !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-inline-grid {
    display: inline-grid !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-table {
    display: table !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-table-row {
    display: table-row !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-table-cell {
    display: table-cell !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
}

@media screen and (max-width: 1200px) {
  .d-xl-list-item {
    display: list-item !important;
  }
}

/*ヘッダー*/
header {
  z-index: 100;
  position: fixed;
  transition: top 0.5s;
  width: 100%;
}
header.disable_header_transition {
  transition: 0s;
}
header .h_top {
  z-index: 10;
  top: 0;
  background-color: #fff;
  width: 100%;
  padding: 30px 50px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 768px) {
  header .h_top {
    padding: 15px;
    height: 60px;
  }
}
header .h_logo .photo {
  position: relative;
}
@media screen and (max-width: 768px) {
  header .h_logo .photo {
    max-width: 212px;
  }
}
header .h_logo .photo .logo_img_b {
  opacity: 1;
}
header .h_logo .photo .logo_img_w {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
header .h_logo a:hover .photo .logo_img_b,
header .h_logo a .photo .logo_img_b {
  transition: all 0.3s;
}
header .h_logo a:hover .photo .logo_img_b {
  opacity: 0.7 !important;
}
@media screen and (max-width: 992px) {
  header .h_nav {
    padding: 30px 30px 100px;
    position: absolute;
    width: 100%;
    height: calc(100vh - 60px);
    top: 100%;
    left: 0;
    background-color: rgba(229, 105, 19, 0.95);
    color: #fff;
    overflow-y: scroll;
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  header .h_nav::-webkit-scrollbar-track {
    background: transparent;
  }
  header .h_nav::-webkit-scrollbar-thumb {
    background: rgba(249, 246, 239, 0.4);
    border: 5px solid transparent;
    background-clip: content-box;
  }
}
header .h_nav .nav_list {
  display: flex;
  gap: clamp(0.625rem, 0.1699029126rem + 1.9417475728vw, 2.5rem);
  font-size: clamp(0.75rem, 0.6589805825rem + 0.3883495146vw, 1.125rem);
  font-weight: 700;
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list {
    flex-direction: column;
    gap: 0;
  }
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list > li {
    padding: 20px 0;
    border-bottom: solid 1px rgba(249, 246, 239, 0.2);
  }
  header .h_nav .nav_list > li:first-child {
    padding-top: 0;
  }
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list > li > a {
    position: relative;
    display: block;
    padding-right: 20px;
  }
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list > li > a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 10px;
    height: 10px;
    border-style: solid;
    border-color: #fff;
    border-width: 3px 3px 0 0;
    transform: rotate(45deg) translateY(-50%);
    transition: transform 0.3s ease;
    transform-origin: right;
  }
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list a:hover {
    color: #fff;
  }
}
header .h_nav .nav_list .drawer_only,
header .h_nav .nav_list .en,
header .h_nav .nav_list .sub_nav {
  display: none;
}
@media screen and (max-width: 992px) {
  header .h_nav .nav_list .drawer_only,
  header .h_nav .nav_list .en,
  header .h_nav .nav_list .sub_nav {
    display: block;
  }
}
header .h_nav .nav_list .en {
  font-size: 24px;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
header .h_nav .nav_list .sub_nav {
  margin-top: 20px;
}
header .h_nav .nav_list .sub_nav li {
  padding-left: 30px;
  position: relative;
  font-size: 14px;
}
header .h_nav .nav_list .sub_nav li::before {
  content: "－";
  position: absolute;
  left: 0;
  color: #fff;
}
header .h_nav .nav_list .sub_nav li + li {
  margin-top: 10px;
}
header .header_drawer {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  aspect-ratio: 1/1;
}
header .header_drawer #drawer_button {
  background: linear-gradient(315deg, #fb7e00 0%, #f8b400 100%);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
}
header .header_drawer #drawer_button::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #fb7e00 0%, #f8b400 100%);
  transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  opacity: 0;
}
header .header_drawer #drawer_button span,
header .header_drawer #drawer_button span::before,
header .header_drawer #drawer_button span::after {
  display: block;
  width: 25px;
  height: 2px;
  background-color: #fff;
  transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}
header .header_drawer #drawer_button span {
  position: relative;
}
header .header_drawer #drawer_button span::before, header .header_drawer #drawer_button span::after {
  content: "";
  position: absolute;
}
header .header_drawer #drawer_button span::before {
  top: -7px;
}
header .header_drawer #drawer_button span::after {
  bottom: -7px;
}
header .header_drawer #drawer_button.active::before {
  opacity: 1;
}
header .header_drawer #drawer_button.active span {
  background-color: transparent;
}
header .header_drawer #drawer_button.active span::before {
  transform: rotate(135deg);
  top: 0;
}
header .header_drawer #drawer_button.active span::after {
  transform: rotate(-135deg);
  bottom: 0;
}

.nav-open .h_nav {
  opacity: 1;
  visibility: visible;
}

/*フッター*/
footer {
  padding: clamp(2.1875rem, -0.0121359223rem + 9.3851132686vw, 11.25rem) 0 0;
  background-color: #333;
  color: #fff;
  position: relative;
  z-index: 95;
}
footer .footer_wrap {
  width: 100%;
  max-width: 1570px;
  padding: 0 20px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 120px;
  gap: clamp(0.0625rem, -1.7427184466rem + 7.7022653722vw, 7.5rem);
}
footer .footer_wrap a {
  text-decoration: none;
}
footer .company_info_area {
  flex: 0 0 22%;
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 22%;
}
@media screen and (max-width: 576px) {
  footer .company_info_area {
    flex-basis: 100%;
    margin-top: clamp(2.5rem, 1.8932038835rem + 2.5889967638vw, 5rem);
    gap: clamp(2.0625rem, 1.3495145631rem + 3.0420711974vw, 5rem);
  }
}
footer .company_info_area .company_basic_info .company_logo {
  margin-bottom: clamp(2.1875rem, 2.0509708738rem + 0.5825242718vw, 2.75rem);
}
footer .company_info_area .company_basic_info .company_logo a {
  width: 100%;
}
footer .company_info_area .company_basic_info .company_logo a img {
  height: auto;
}
@media screen and (max-width: 576px) {
  footer .company_info_area .company_basic_info .company_logo a img {
    max-width: 333px;
    width: 90%;
  }
}
footer .company_address {
  margin-bottom: 5rem;
}
@media screen and (max-width: 576px) {
  footer .company_address {
    margin-bottom: clamp(2.0625rem, 1.3495145631rem + 3.0420711974vw, 5rem);
  }
}
footer .company_address p {
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  line-height: 1.8;
  margin: 0;
}
footer .company_sns a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
}
footer .company_sns a:hover {
  color: #999;
}
footer .company_sns a::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  background-color: #fff;
  -webkit-mask: url("../images/common/icon_insta.svg") no-repeat center/contain;
  mask: url("../images/common/icon_insta.svg") no-repeat center/contain;
  flex: 0 0 24px;
}
footer .company_sns a:hover::before {
  background-color: #999;
  transition: 0.3s ease-in-out;
}
footer .company_privacy {
  margin-top: auto;
}
footer .company_privacy a {
  display: inline-block;
  background: linear-gradient(#fff, #fff) left bottom/0 1px no-repeat;
  transition: background-size 0.3s ease-in-out;
  will-change: background-size;
  font-size: clamp(0.75rem, 0.6893203883rem + 0.2588996764vw, 1rem);
}
@media screen and (max-width: 576px) {
  footer .company_privacy a {
    margin-bottom: clamp(2.8125rem, 2.2815533981rem + 2.2653721683vw, 5rem);
    text-decoration: underline;
  }
}
footer .company_privacy a:hover {
  background-size: 100% 1px;
  color: #fff;
}
@media screen and (max-width: 576px) {
  footer .company_privacy a:hover {
    background-size: 0 1px;
  }
}
footer .site_nav_area {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.0625rem, -2.5770631068rem + 11.2621359223vw, 10.9375rem);
}
@media screen and (max-width: 576px) {
  footer .site_nav_area {
    order: -1;
    gap: 0;
  }
}
footer .site_nav_area .nav_column {
  flex: 1;
}
footer .site_nav_area .nav_column.nav_column_main {
  flex: 0 0 16%;
}
@media screen and (max-width: 992px) {
  footer .site_nav_area .nav_column.nav_column_main {
    flex-basis: 100%;
  }
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_column.brand_nav_column {
    margin-bottom: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  }
}
footer .site_nav_area .nav_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
footer .site_nav_area .nav_item {
  line-height: 1;
  margin-bottom: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item {
    padding-bottom: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
    border-bottom: 2px solid #6B6B6B;
  }
}
footer .site_nav_area .nav_item > a,
footer .site_nav_area .nav_item > button.nav_toggle,
footer .site_nav_area .nav_item .nav_head .nav_link,
footer .site_nav_area .nav_item .nav_head .nav_toggle {
  font-size: clamp(1rem, 0.9089805825rem + 0.3883495146vw, 1.375rem);
  font-weight: bold;
  background: none;
  border: none;
  color: inherit;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 20px;
  cursor: pointer;
}
footer .site_nav_area .nav_item > a:hover,
footer .site_nav_area .nav_item > button.nav_toggle:hover,
footer .site_nav_area .nav_item .nav_head .nav_link:hover,
footer .site_nav_area .nav_item .nav_head .nav_toggle:hover {
  color: #999;
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item .nav_head button.nav_link.nav_toggle:hover {
    color: #fff;
  }
}
footer .site_nav_area .nav_item .nav_head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
footer .site_nav_area .nav_item .nav_head .nav_link {
  flex-grow: 1;
}
footer .site_nav_area .nav_item .nav_head .nav_toggle:not(.nav_link) {
  padding: 0 4px 0 8px;
  flex-shrink: 0;
}
footer .site_nav_area .nav_item button.nav_toggle:not(.nav_link):focus-visible {
  outline: 2px solid #fff;
  outline-offset: 4px;
}
footer .site_nav_area .nav_item .chevron {
  position: relative;
  width: 18px;
  height: 12px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
}
footer .site_nav_area .nav_item .chevron_bar {
  position: absolute;
  top: 50%;
  width: 10px;
  height: 2.5px;
  border-radius: 2px;
  background: #e56913;
  transition: transform 0.25s ease;
}
footer .site_nav_area .nav_item .chevron_bar--1 {
  right: 33%;
  transform-origin: center;
  transform: translateX(50%) rotate(-45deg);
}
footer .site_nav_area .nav_item .chevron_bar--2 {
  left: 33%;
  transform-origin: center;
  transform: translateX(-50%) rotate(45deg);
}
footer .site_nav_area .nav_item.nav_item--accordion[aria-expanded=true] .chevron_bar--1 {
  transform: translateX(50%) rotate(45deg);
}
footer .site_nav_area .nav_item.nav_item--accordion[aria-expanded=true] .chevron_bar--2 {
  transform: translateX(-50%) rotate(-45deg);
}
footer .site_nav_area .nav_item .sub_nav_list {
  list-style: none;
  padding: 0;
  margin: clamp(0.75rem, 0.4769417476rem + 1.1650485437vw, 1.875rem) 0 0 0;
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item .sub_nav_list {
    margin-top: clamp(0.75rem, 0.4769417476rem + 1.1650485437vw, 1.875rem);
    overflow: hidden;
    opacity: 1;
    transition: height 0.3s ease, opacity 0.3s ease;
    will-change: height, opacity;
    margin-top: 0;
  }
}
footer .site_nav_area .nav_item .sub_nav_list.is-closed {
  height: 0;
  opacity: 0;
}
footer .site_nav_area .nav_item .sub_nav_list.is-animating {
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) {
  footer .site_nav_area .nav_item .sub_nav_list {
    transition: none;
  }
}
footer .site_nav_area .nav_item .sub_nav_item {
  margin-bottom: clamp(0.5rem, 0.3786407767rem + 0.5177993528vw, 1rem);
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item .sub_nav_item {
    margin-bottom: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  }
  footer .site_nav_area .nav_item .sub_nav_item:first-child {
    margin-top: clamp(1.5rem, 1.2572815534rem + 1.0355987055vw, 2.5rem);
  }
  footer .site_nav_area .nav_item .sub_nav_item:last-child {
    margin-bottom: clamp(0.5rem, 0.4696601942rem + 0.1294498382vw, 0.625rem);
  }
}
footer .site_nav_area .nav_item .sub_nav_item a {
  opacity: 0.8;
}
footer .site_nav_area .nav_item .sub_nav_item a:hover {
  color: #999;
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item .sub_nav_item a {
    position: relative;
    padding-left: 2.2rem;
  }
  footer .site_nav_area .nav_item .sub_nav_item a::before {
    content: "";
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 0.5rem;
    height: 1px;
    background-color: #fff;
    border-radius: 2px;
  }
  footer .site_nav_area .nav_item .sub_nav_item a:hover::before {
    background-color: #999;
  }
}
footer .site_nav_area .nav_item.brand_nav_item {
  margin-bottom: 0;
}
footer .site_nav_area .nav_item.brand_nav_item .sub_nav_list {
  display: grid;
  grid-template-columns: repeat(3, auto);
  column-gap: clamp(0.3125rem, -0.4459951456rem + 3.2362459547vw, 3.4375rem);
  grid-auto-columns: min-content;
}
@media screen and (max-width: 992px) {
  footer .site_nav_area .nav_item.brand_nav_item .sub_nav_list {
    grid-template-columns: repeat(2, auto);
  }
}
@media screen and (max-width: 576px) {
  footer .site_nav_area .nav_item.brand_nav_item .sub_nav_list {
    grid-template-columns: repeat(1, auto);
  }
}
footer .page_top_button_wrap {
  position: relative;
  width: 100%;
  height: 40px;
  overflow: hidden;
}
@media screen and (max-width: 576px) {
  footer .page_top_button_wrap {
    height: 30px;
    overflow: visible;
  }
}
footer .page_top_button_wrap a {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #fff;
  border-radius: 50%;
  position: relative;
  transition: background-color 0.3s ease;
  cursor: pointer;
  left: calc(50% - 40px);
}
footer .page_top_button_wrap a::before, footer .page_top_button_wrap a::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 3.5px;
  background-color: #E15A00;
  border-radius: 2px;
}
@media screen and (max-width: 576px) {
  footer .page_top_button_wrap a::before, footer .page_top_button_wrap a::after {
    width: 14px;
  }
}
footer .page_top_button_wrap a::before {
  transform: translate(-80%, -10px) rotate(-45deg);
}
footer .page_top_button_wrap a::after {
  transform: translate(-20%, -10px) rotate(45deg);
}
footer .page_top_button_wrap a:hover {
  background-color: #f0f0f0;
}
footer .copyright {
  width: 100%;
  text-align: center;
  padding: 30px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  background-color: #fff;
}
@media screen and (max-width: 576px) {
  footer .copyright {
    padding: 40px 0;
  }
}
footer .copyright p {
  font-size: 12px;
  color: #999;
  margin: 0;
  z-index: 10;
  position: relative;
}

/*ドロワー*/
/*--------------トップ---------------- */
.top_page::before {
  content: "";
  display: block;
  position: fixed;
  width: 100%;
  height: 100%;
  z-index: 9999;
  background-color: #fff;
  opacity: 1;
  transition: opacity 1s ease-in;
}
.top_page.page-open::before {
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .top_page footer {
    padding-top: clamp(4.0625rem, 2.317961165rem + 7.4433656958vw, 11.25rem);
  }
}
.top_page header.top_header_at_top {
  position: absolute;
}
.top_page header.top_header_at_top .h_top {
  background-color: transparent;
  color: #fff;
  transition: background-color 0.3s, color 0.3s;
}
.top_page header.top_header_at_top .h_top .h_logo .photo .logo_img_b {
  opacity: 0;
}
.top_page header.top_header_at_top .h_top .h_logo .photo .logo_img_w {
  transition: opacity 0.3s;
  opacity: 1;
}
.top_page header.top_header_at_top .h_top .h_logo a:hover .photo .logo_img_w {
  opacity: 0.7 !important;
}
.top_page .top_fv {
  position: relative;
}
.top_page .top_fv .fv_slider .splide__list .splide__slide {
  position: relative;
  height: 1018px;
}
@media screen and (max-width: 768px) {
  .top_page .top_fv .fv_slider .splide__list .splide__slide {
    height: 700px;
  }
}
.top_page .top_fv .fv_slider .splide__list .splide__slide::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(26, 26, 26, 0.3);
  mix-blend-mode: multiply;
  z-index: 1;
}
.top_page .top_fv .fv_slider .splide__list .splide__slide img {
  max-width: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1);
}
.top_page .top_fv .fv_slider .splide__list .splide__slide.is-active img, .top_page .top_fv .fv_slider .splide__list .splide__slide.is-prev img {
  animation: zoomout 5s linear forwards;
}
@keyframes zoomout {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
.top_page .top_fv .fv_slider .splide__pagination {
  padding: 0 50px;
  justify-content: flex-start;
  bottom: 30px;
}
@media screen and (max-width: 768px) {
  .top_page .top_fv .fv_slider .splide__pagination {
    padding: 0 20px;
    bottom: 0;
  }
}
.top_page .top_fv .fv_slider .splide__pagination .splide__pagination__page {
  width: 10px;
  height: 10px;
  margin: 3px 8px;
}
@media screen and (max-width: 768px) {
  .top_page .top_fv .fv_slider .splide__pagination .splide__pagination__page {
    width: 6px;
    height: 6px;
    margin: 3px 5px;
  }
}
.top_page .top_fv .fv_slider .splide__pagination .splide__pagination__page.is-active {
  background-color: #e56913;
  transform: scale(1);
  opacity: 1;
}
.top_page .top_fv .text_box {
  width: 100%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .top_page .top_fv .text_box {
    top: auto;
    bottom: 100px;
    transform: none;
  }
}
.top_page .top_fv .text_box .top_fv_catch {
  font-size: clamp(2rem, 1.5145631068rem + 2.071197411vw, 4rem);
  color: #fff;
}
.top_page .top_fv .text_box .en {
  margin-top: clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-size: clamp(0.8125rem, 0.645631068rem + 0.71197411vw, 1.5rem);
  color: #e56913;
  font-weight: 700;
}
.top_page .top_fv .text_box .en.fadein-text {
  opacity: 0;
  filter: blur(10px);
  transition: 0.6s ease-out;
}
.top_page .top_fv .text_box .en.fadein-text.page-open {
  filter: blur(0);
  opacity: 1;
}
.top_page .top_fv .text_box .fade-text span {
  display: inline-block;
  white-space: nowrap;
  clip-path: inset(0 100% 0 0); /* 最初は全て隠す */
}
.top_page .top_fv .text_box .fade-text span.is-visible {
  animation: clipReveal 1s ease forwards;
}
@keyframes clipReveal {
  to {
    clip-path: inset(0 0 0 0); /* 完全表示 */
  }
}
.top_page .top_fv .main_visual_scroll {
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
  position: absolute;
  z-index: 2;
  bottom: 130px;
  left: 20px;
  transform: translateX(-50%);
}
.top_page .top_fv .main_visual_scroll > div {
  writing-mode: vertical-lr;
}
.top_page .top_fv .main_visual_scroll .scrolldown {
  width: 6px;
  height: 50px;
  margin: 10px auto;
  position: relative;
}
.top_page .top_fv .main_visual_scroll .scrolldown .line {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  border-style: solid;
  border-width: 0 0 1px 1px;
  border-color: #fff;
  transform: skewY(-45deg);
  animation: scrolldown 2s cubic-bezier(0.25, 0.1, 0.25, 1) forwards infinite;
}
@keyframes scrolldown {
  0% {
    height: 0;
    width: 0;
    bottom: 100%;
  }
  20% {
    width: 100%;
  }
  40% {
    height: 80%;
  }
  60% {
    height: 80%;
    bottom: 0;
  }
  80% {
    width: 100%;
  }
  100% {
    height: 0;
    width: 0;
    bottom: 0;
  }
}
.top_page .top_about {
  padding: clamp(3.125rem, 2.6699029126rem + 1.9417475728vw, 5rem) 0 0;
}
.top_page .top_about .cont {
  display: flex;
  gap: 25px 9.1503267974%;
}
@media screen and (max-width: 768px) {
  .top_page .top_about .cont {
    flex-wrap: wrap;
  }
}
.top_page .top_about .cont p {
  flex: 1;
  margin-bottom: clamp(1rem, 1rem + 0vw, 1rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_about .cont p {
    flex: auto;
    width: 100%;
  }
}
.top_page .top_about .cont .link {
  width: 100%;
  max-width: clamp(14.0625rem, 11.3319174757rem + 11.6504854369vw, 25.3125rem);
  margin: 0 auto;
}
.top_page .top_about .about_slider {
  margin-top: clamp(3.125rem, 2.6699029126rem + 1.9417475728vw, 5rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_about .about_slider {
    clip-path: polygon(0 15px, 100% 0, 100% 100%, 0 100%);
    margin-bottom: 0;
  }
}
.top_page .top_about .about_slider .splide__list .splide__slide {
  position: relative;
  height: 700px;
}
@media screen and (max-width: 768px) {
  .top_page .top_about .about_slider .splide__list .splide__slide {
    height: 215px;
  }
}
.top_page .top_about .about_slider .splide__list .splide__slide img {
  width: 100%;
  height: 100%;
  width: auto;
  height: 700px;
}
@media screen and (max-width: 768px) {
  .top_page .top_about .about_slider .splide__list .splide__slide img {
    height: 215px;
  }
}
.top_page .top_brand {
  padding: clamp(4.375rem, 2.7063106796rem + 7.1197411003vw, 11.25rem) 0;
  background-color: #fff7e5;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .top_page .top_brand {
    margin: 0;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    padding: clamp(11.25rem, 9.4296116505rem + 7.7669902913vw, 18.75rem) 0;
  }
}
.top_page .top_brand .slider_wrap {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  gap: clamp(18.4375rem, 7.7427184466rem + 45.6310679612vw, 62.5rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .slider_wrap {
    flex-direction: column;
    justify-content: space-between;
    gap: clamp(1.25rem, 0.3398058252rem + 3.8834951456vw, 5rem);
  }
}
.top_page .top_brand .slider_wrap .box {
  display: flex;
  gap: clamp(1.25rem, 0.3398058252rem + 3.8834951456vw, 5rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .slider_wrap .box {
    flex-direction: column;
    gap: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
    margin-top: clamp(1.25rem, 0.3398058252rem + 3.8834951456vw, 5rem);
  }
  .top_page .top_brand .slider_wrap .box:last-child {
    margin-bottom: clamp(1.25rem, 0.3398058252rem + 3.8834951456vw, 5rem);
  }
  .top_page .top_brand .slider_wrap .box img {
    height: clamp(4.0625rem, 3.8349514563rem + 0.9708737864vw, 5rem);
  }
}
.top_page .top_brand .slider_wrap .box .splide__slide {
  margin-bottom: 40px;
  margin-bottom: clamp(0.93125rem, 0.5504854369rem + 1.6245954693vw, 2.5rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .slider_wrap .box .splide__slide {
    margin-bottom: 0;
    margin-right: clamp(0.9375rem, 0.9241504854rem + 0.0569579288vw, 0.9925rem);
  }
}
.top_page .top_brand .cont {
  text-align: center;
  max-width: clamp(18.4375rem, 12.2936893204rem + 26.213592233vw, 43.75rem);
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .cont {
    padding: 0 15px;
  }
}
@media screen and (max-width: 576px) {
  .top_page .top_brand .cont {
    max-width: 100%;
  }
}
.top_page .top_brand .total {
  margin-bottom: 0;
  color: #b59570;
  font-size: clamp(1.25rem, 0.8252427184rem + 1.8122977346vw, 3rem);
  font-weight: 900;
}
.top_page .top_brand .mid {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 0;
  color: #e56913;
  font-weight: 900;
}
.top_page .top_brand .mid .num {
  font-family: "Bebas Neue", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-size: clamp(10.625rem, 5.9223300971rem + 20.0647249191vw, 30rem);
  font-weight: 500;
  line-height: 0.8;
  margin-top: -8px;
  transform: translateY(13%);
}
.top_page .top_brand .mid .unit {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: clamp(1.125rem, 0.5788834951rem + 2.3300970874vw, 3.375rem);
  letter-spacing: 0.7rem;
  transform: translateY(10%);
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .mid .unit {
    letter-spacing: 0.2rem;
  }
}
.top_page .top_brand .desc {
  margin-top: clamp(1.875rem, 1.1165048544rem + 3.2362459547vw, 5rem);
  padding: 0 clamp(0rem, -0.7584951456rem + 3.2362459547vw, 3.125rem);
  font-size: clamp(0.875rem, 0.7233009709rem + 0.6472491909vw, 1.5rem);
}
.top_page .top_brand .link {
  margin-top: clamp(1.875rem, 1.2682038835rem + 2.5889967638vw, 4.375rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_brand .link {
    margin-top: clamp(0.9375rem, 0.7099514563rem + 0.9708737864vw, 1.875rem);
    margin-bottom: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  }
}
.top_page .top_brand .link a {
  margin: 0 auto;
}
.top_page .top_mission {
  padding: clamp(4.375rem, 2.7063106796rem + 7.1197411003vw, 11.25rem) 0 clamp(9.375rem, 8.0097087379rem + 5.8252427184vw, 15rem);
  background-color: #e56913;
  color: #fff;
  position: relative;
}
@media screen and (max-width: 768px) {
  .top_page .top_mission {
    margin-top: 0;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}
.top_page .top_mission .sec_ttl .en {
  color: #fff;
}
.top_page .top_mission .cont p {
  font-size: clamp(1rem, 0.8786407767rem + 0.5177993528vw, 1.5rem);
}
.top_page .top_mission .cont p + P {
  margin-top: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
}
.top_page .top_mission .link {
  margin-top: clamp(1.875rem, 1.4199029126rem + 1.9417475728vw, 3.75rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_mission .link a {
    margin: clamp(0.9375rem, 0.7099514563rem + 0.9708737864vw, 1.875rem) auto 0;
  }
}
.top_page .top_mission .mission_name_slider {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
}
.top_page .top_mission .mission_name_slider .name_slider .splide__slide {
  font-size: clamp(9.375rem, 7.0995145631rem + 9.7087378641vw, 18.75rem);
  line-height: 1;
  font-family: "Bebas Neue", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  opacity: 0.1;
  display: block;
  transform: translateY(15%);
}
@media screen and (max-width: 768px) {
  .top_page .top_mission .mission_name_slider .name_slider .splide__slide {
    line-height: 0.8;
    transform: translateY(10%);
  }
}
.top_page .top_value {
  padding: clamp(5rem, 3.9381067961rem + 4.5307443366vw, 9.375rem) 0 clamp(5rem, 3.9381067961rem + 4.5307443366vw, 9.375rem);
  background-color: #f9f6ef;
}
.top_page .top_value .sec_ttl {
  margin-bottom: clamp(2.6875rem, 2.5813106796rem + 0.4530744337vw, 3.125rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_value .sec_ttl {
    margin-bottom: clamp(4.375rem, 3.9199029126rem + 1.9417475728vw, 6.25rem);
  }
}
.top_page .top_value .sec_ttl .ja {
  font-size: clamp(1.75rem, 1.2949029126rem + 1.9417475728vw, 3.625rem);
}
.top_page .top_value .list ol {
  display: flex;
  flex-flow: row-reverse;
  justify-content: center;
  gap: clamp(3.75rem, 3.75rem + 0vw, 3.75rem);
  counter-reset: value-counter;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol {
    flex-flow: column;
  }
}
.top_page .top_value .list ol li {
  flex: 1;
  max-width: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  writing-mode: vertical-rl;
  font-size: clamp(1.25rem, 1.1286407767rem + 0.5177993528vw, 1.75rem);
  font-weight: 700;
  text-orientation: mixed;
  position: relative;
  padding-top: calc(250px + clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem));
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li {
    padding-top: 0;
    padding-left: calc(clamp(0.9375rem, 0.5582524272rem + 1.6181229773vw, 2.5rem) + calc(clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2 + clamp(2.1875rem, 1.9599514563rem + 0.9708737864vw, 3.125rem)) + clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2);
    writing-mode: unset;
    max-width: none;
  }
}
.top_page .top_value .list ol li .value_badge {
  position: absolute;
  top: 141px;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  height: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  border-radius: 50%;
  overflow: visible;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e56913;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li .value_badge {
    top: 0;
    top: calc(50% - clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2);
    left: calc(clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2 + clamp(2.1875rem, 1.9599514563rem + 0.9708737864vw, 3.125rem));
  }
}
.top_page .top_value .list ol li .value_badge__inner_top, .top_page .top_value .list ol li .value_badge__inner_bottom {
  width: 100%;
  height: calc(15% + clamp(11.9375rem, 10.9969660194rem + 4.0129449838vw, 15.8125rem));
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  position: absolute;
  bottom: 0;
}
.top_page .top_value .list ol li .value_badge__inner_top img, .top_page .top_value .list ol li .value_badge__inner_bottom img {
  width: 100%;
  height: auto;
  object-fit: cover;
  transform: scale(1.4) translateY(30%);
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li .value_badge__inner_top img, .top_page .top_value .list ol li .value_badge__inner_bottom img {
    transform: scale(1.35) translateY(-6%);
  }
}
.top_page .top_value .list ol li .value_badge__inner_top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  overflow: visible;
}
.top_page .top_value .list ol li .value_badge__inner_top img {
  height: 150%;
  max-width: 100%;
  display: block;
  position: static;
  margin: 0;
  clip-path: inset(0 0 50% 0);
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li .value_badge__inner_top img {
    height: 116%;
  }
}
.top_page .top_value .list ol li .value_badge__inner_bottom {
  clip-path: circle(50% at 50% 50%);
  height: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  width: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
}
.top_page .top_value .list ol li .text {
  display: block;
  line-height: 1.4;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li .text {
    letter-spacing: 0.4px;
  }
}
@keyframes valueBadgeRiseDrop {
  0% {
    transform: scale(1.4) translateY(4%);
  }
  100% {
    transform: scale(1.4) translateY(-14%);
  }
}
@keyframes valueBadgeRiseDropSmp {
  0% {
    transform: scale(1.35) translateY(-18%);
  }
  100% {
    transform: scale(1.35) translateY(-24%);
  }
}
.top_page .top_value .list ol li.is-visible .value_badge__inner_top img, .top_page .top_value .list ol li.is-visible .value_badge__inner_bottom img {
  animation: valueBadgeRiseDrop 0.35s cubic-bezier(0.25, 0.8, 0.25, 1) forwards;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li.is-visible .value_badge__inner_top img, .top_page .top_value .list ol li.is-visible .value_badge__inner_bottom img {
    animation: valueBadgeRiseDropSmp 0.35s cubic-bezier(0.25, 0.8, 0.25, 1) forwards;
  }
}
.top_page .top_value .list ol li::before {
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  counter-increment: value-counter;
  content: "0" counter(value-counter);
  position: absolute;
  top: 141px;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  height: clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.75rem, 1.5376213592rem + 0.9061488673vw, 2.625rem);
  font-weight: 700;
  background-color: transparent;
  color: #fff;
  writing-mode: horizontal-tb;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .top_page .top_value .list ol li::before {
    top: calc(50% - clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2);
    left: calc(clamp(5rem, 4.3932038835rem + 2.5889967638vw, 7.5rem) / 2 + clamp(2.1875rem, 1.9599514563rem + 0.9708737864vw, 3.125rem));
  }
}
.top_page .top_value .list ol li .kigou {
  text-combine-upright: all;
  text-orientation: upright;
  display: inline-block;
  transform: translateX(-0.03em);
}
.top_page .top_news {
  padding: clamp(3.125rem, 1.4563106796rem + 7.1197411003vw, 10rem) 0 0;
}
.top_page .top_news .news_wrap {
  display: flex;
  column-gap: clamp(5.625rem, 4.1080097087rem + 6.4724919094vw, 11.875rem);
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap {
    flex-wrap: wrap;
  }
}
.top_page .top_news .news_wrap .ttl_wrap .sec_ttl {
  white-space: nowrap;
  margin-bottom: clamp(1.5625rem, 0.7281553398rem + 3.5598705502vw, 5rem);
}
.top_page .top_news .news_wrap .cont {
  display: flex;
  gap: 25px 9.1503267974%;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap .cont {
    width: 100%;
    justify-content: flex-end;
  }
}
.top_page .top_news .news_wrap .cont .link a {
  display: flex;
  align-items: center;
  gap: clamp(1.25rem, 1.1893203883rem + 0.2588996764vw, 1.5rem);
  border: 2px solid #fff;
  border-radius: 50rem;
  position: relative;
  height: 55px;
  padding: 0 clamp(3.125rem, 2.8216019417rem + 1.2944983819vw, 4.375rem) 0 0;
  color: inherit;
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap .cont .link a {
    font-weight: 700;
  }
}
.top_page .top_news .news_wrap .cont .link a::before {
  background: none;
}
.top_page .top_news .news_wrap .cont .link a::after {
  content: none;
  right: 0;
}
.top_page .top_news .news_wrap .cont .link a:hover .arrow {
  transform: scale(1.3);
}
.top_page .top_news .news_wrap .cont .link a:hover .news_arrow_btn::after {
  transform: translateY(-50%);
}
.top_page .top_news .news_wrap .cont .link a .news_arrow_btn {
  display: inline-block;
  position: initial;
}
.top_page .top_news .news_wrap .cont .link a .news_arrow_btn::after {
  right: calc(clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem) / 2 - 8px);
}
.top_page .top_news .news_wrap .cont .link a .arrow {
  transition: background 0.3s, border 0.3s;
  display: inline-block;
  width: clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem);
  height: clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem);
  border-radius: 50%;
  position: absolute;
  top: calc(50% - clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem) / 2);
  right: 0;
  background: linear-gradient(270deg, #fb7e00 0%, #f8b400 100%);
  transition: transform 0.3s ease;
}
.top_page .top_news .news_wrap .list_wrap {
  flex: 1 1 100%;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap .list_wrap {
    margin-bottom: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  }
}
.top_page .top_news .news_wrap .list_wrap .news_list a {
  border-bottom: 2px solid #e5e5e5;
  display: block;
  margin-bottom: clamp(0.5rem, 0.3786407767rem + 0.5177993528vw, 1rem);
  padding-bottom: clamp(0.5rem, 0.3786407767rem + 0.5177993528vw, 1rem);
  position: relative;
  padding-right: 40px;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap .list_wrap .news_list a {
    margin-bottom: clamp(1.25rem, 1.1741504854rem + 0.3236245955vw, 1.5625rem);
    padding-bottom: clamp(1.25rem, 1.1741504854rem + 0.3236245955vw, 1.5625rem);
    padding-right: 20px;
  }
}
.top_page .top_news .news_wrap .list_wrap .news_list a::after {
  content: "";
  position: absolute;
  right: 27px;
  top: calc(50% - clamp(0.5rem, 0.3786407767rem + 0.5177993528vw, 1rem) / 2 - 6px);
  width: clamp(0.5625rem, 0.5169902913rem + 0.1941747573vw, 0.75rem);
  height: clamp(0.5625rem, 0.5169902913rem + 0.1941747573vw, 0.75rem);
  border-top: clamp(0.125rem, 0.1098300971rem + 0.0647249191vw, 0.1875rem) solid #e56913;
  border-right: clamp(0.125rem, 0.1098300971rem + 0.0647249191vw, 0.1875rem) solid #e56913;
  transform: rotate(45deg);
  transition: right 0.3s ease;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_wrap .list_wrap .news_list a::after {
    right: 5px;
  }
}
.top_page .top_news .news_wrap .list_wrap .news_list a:hover {
  color: inherit;
  border-color: #f2b489;
}
.top_page .top_news .news_wrap .list_wrap .news_list a:hover::after {
  right: 15px;
}
.top_page .top_news .news_wrap .list_wrap .news_list a .date {
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  font-weight: 600;
  color: #999;
}
.top_page .top_news .news_wrap .list_wrap .news_list a .title {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.top_page .top_news .news_slider_wrap {
  margin-top: clamp(1.5625rem, 0.7281553398rem + 3.5598705502vw, 5rem);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.top_page .top_news .news_slider_wrap .news_slider {
  overflow: visible;
}
.top_page .top_news .news_slider_wrap .news_slider .splide__track {
  overflow: visible;
}
.top_page .top_news .news_slider_wrap .news_slider:nth-child(2) .splide__track {
  transform: translateX(-418px);
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_slider_wrap .news_slider:nth-child(2) .splide__track {
    transform: translateX(-179px);
  }
}
.top_page .top_news .news_slider_wrap .news_slider .splide__list .splide__slide {
  position: relative;
  height: auto;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_slider_wrap .news_slider .splide__list .splide__slide {
    height: auto;
    height: 250px;
  }
}
.top_page .top_news .news_slider_wrap .news_slider .splide__list .splide__slide img {
  width: 100%;
  height: 100%;
  width: auto;
}
@media screen and (max-width: 768px) {
  .top_page .top_news .news_slider_wrap .news_slider .splide__list .splide__slide img {
    height: 250px;
  }
}

/*---------------- 共通設定 ---------------- */
.no-copy {
  user-select: none;
}

.no-scroll {
  overflow: hidden;
  height: 100vh;
  position: fixed;
  width: 100%;
}

main {
  z-index: 90;
  position: relative;
}

.mask_hidari_sita {
  margin: 0 0 -80px;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 80px));
}
@media screen and (max-width: 768px) {
  .mask_hidari_sita {
    margin: 0 0 -30px;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 30px));
  }
}

.mask_hidari_ue_sita {
  margin: -80px 0;
  clip-path: polygon(0 80px, 100% 0, 100% 100%, 0 calc(100% - 80px));
}
@media screen and (max-width: 768px) {
  .mask_hidari_ue_sita {
    margin: -30px 0;
    clip-path: polygon(0 30px, 100% 0, 100% 100%, 0 calc(100% - 30px));
  }
}

.mask_migi_sita {
  margin: 0 0 -80px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 80px), 0 100%);
}
@media screen and (max-width: 768px) {
  .mask_migi_sita {
    margin: 0 0 -30px;
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 30px), 0 100%);
  }
}

.mask_migi_ue_sita {
  margin: -80px 0;
  clip-path: polygon(0 0, 100% 80px, 100% calc(100% - 80px), 0 100%);
}
@media screen and (max-width: 768px) {
  .mask_migi_ue_sita {
    margin: -30px 0;
    clip-path: polygon(0 0, 100% 30px, 100% calc(100% - 30px), 0 100%);
  }
}

.mask_hidari_naname {
  margin: -80px 0;
  clip-path: polygon(0 80px, 100% 0, 100% calc(100% - 80px), 0 100%);
}
@media screen and (max-width: 768px) {
  .mask_hidari_naname {
    margin: -30px 0;
    clip-path: polygon(0 30px, 100% 0, 100% calc(100% - 30px), 0 100%);
  }
}

.sec_ttl {
  margin-bottom: clamp(1.5625rem, 1.1832524272rem + 1.6181229773vw, 3.125rem);
}
.sec_ttl .en {
  margin-bottom: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
  color: #e56913;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
  font-size: clamp(0.8125rem, 0.7366504854rem + 0.3236245955vw, 1.125rem);
}
.sec_ttl .en::before {
  content: "/";
  padding-right: 0.3em;
}
.sec_ttl .ja {
  font-size: clamp(1.75rem, 1.4466019417rem + 1.2944983819vw, 3rem);
  font-weight: 900;
}

.left_line_ttl {
  padding-left: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem);
  font-size: clamp(1.25rem, 1.1286407767rem + 0.5177993528vw, 1.75rem);
  margin-bottom: clamp(0.625rem, 0.3974514563rem + 0.9708737864vw, 1.5625rem);
  border-left: solid #e56913 3px;
}
@media screen and (max-width: 768px) {
  .left_line_ttl {
    border-color: #fb9900;
  }
}

.slash_ttl {
  margin-bottom: clamp(1.25rem, 0.7949029126rem + 1.9417475728vw, 3.125rem);
  color: #e56913;
  font-size: clamp(1.125rem, 0.9733009709rem + 0.6472491909vw, 1.75rem);
}
.slash_ttl::before {
  content: "/";
  padding-right: 0.3em;
}

.arrow_btn {
  padding: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem) clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  display: block;
  color: #fff;
  font-size: clamp(0.875rem, 0.7536407767rem + 0.5177993528vw, 1.375rem);
  font-weight: 700;
  width: 100%;
  max-width: clamp(14.0625rem, 11.3319174757rem + 11.6504854369vw, 25.3125rem);
  position: relative;
  z-index: 0;
}
.arrow_btn::before, .arrow_btn::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  z-index: -1;
  transition: 0.3s ease;
}
.arrow_btn::before {
  background: linear-gradient(270deg, #fb7e00 0%, #f8b400 100%);
}
.arrow_btn::after {
  background: linear-gradient(90deg, #fb7e00 0%, #f8b400 100%);
}
.arrow_btn .text {
  position: relative;
}
@media screen and (max-width: 768px) {
  .arrow_btn .text {
    line-height: 2.1;
  }
}
.arrow_btn .text::after {
  content: "";
  display: block;
  background: url(../images/common/icon_arrow-right-w.svg) no-repeat center;
  background-size: contain;
  width: 17px;
  height: 13px;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  transition: 0.3s ease;
}
.arrow_btn:hover {
  color: #fff;
}
.arrow_btn:hover::after {
  opacity: 0;
}
.arrow_btn:hover .text::after {
  transform: translateY(-50%) translateX(3px);
}

.prev_btn {
  display: flex;
  align-items: center;
  gap: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem);
  position: relative;
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.prev_btn::before {
  width: clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem);
  height: clamp(2.5rem, 2.3483009709rem + 0.6472491909vw, 3.125rem);
  background: linear-gradient(315deg, #fb7e00 0%, #f8b400 100%);
  content: "";
  border-radius: 50%;
  transition: 0.3s ease;
}
.prev_btn::after {
  content: "";
  background-image: url(../images/common/icon_arrow-right-w.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  width: clamp(0.75rem, 0.7196601942rem + 0.1294498382vw, 0.875rem);
  height: clamp(0.625rem, 0.6098300971rem + 0.0647249191vw, 0.6875rem);
  z-index: 1;
  transform: translateY(-50%) scale(-1);
  transition: 0.3s ease;
}
.prev_btn:hover::before {
  transform: scale(1.2);
}

/*---------------- 下層 共通設定---------------- */
.kaso_header {
  position: relative;
  /*-----下層タイトル部分------*/
  /*-----パンくずリスト------*/
}
.kaso_header .kaso_ttl {
  background-color: #f9f6ef;
  height: clamp(16.25rem, 12.609223301rem + 15.5339805825vw, 31.25rem);
  display: flex;
  align-items: center;
  position: relative;
}
.kaso_header .kaso_ttl .photo {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.kaso_header .kaso_ttl .photo img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.kaso_header .kaso_ttl picture {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.kaso_header .kaso_ttl picture img,
.kaso_header .kaso_ttl picture source {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.kaso_header .bread {
  padding: 0 clamp(1.25rem, 0.7949029126rem + 1.9417475728vw, 3.125rem);
  position: absolute;
  bottom: 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .kaso_header .bread {
    bottom: auto;
    top: 100%;
  }
}
.kaso_header .bread ul {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.kaso_header .bread ul li {
  font-size: clamp(0.625rem, 0.5946601942rem + 0.1294498382vw, 0.75rem);
  color: #999999;
}
.kaso_header .bread ul li:not(:first-child)::before {
  content: "";
  margin: 0 clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem) 0.1em;
  display: inline-block;
  width: 6px;
  height: 6px;
  border-top: solid 1.5px #cccccc;
  border-right: solid 1.5px #cccccc;
  transform: rotate(45deg);
}
.kaso_header .bread ul li a {
  color: #e56913;
  text-decoration: underline;
  text-underline-offset: 0.1em;
}
.kaso_header .bread ul li a.top {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.kaso_header .bread ul li a.top::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 14px;
  background: url(../images/common/icon_home.svg) no-repeat center bottom;
}
.kaso_header .bread ul li a:hover {
  text-decoration: none;
}

.kaso_block {
  padding: clamp(6.25rem, 5.036407767rem + 5.1779935275vw, 11.25rem) 0 clamp(6.25rem, 3.9745145631rem + 9.7087378641vw, 15.625rem);
}

/*-----2カラム------*/
.col2_wrap {
  display: flex;
  gap: clamp(1.875rem, 1.875rem + 0vw, 1.875rem);
  position: relative;
}
@media screen and (max-width: 768px) {
  .col2_wrap {
    flex-direction: column;
  }
}
.col2_wrap .col2_side {
  width: 240px;
}
@media screen and (max-width: 768px) {
  .col2_wrap .col2_side {
    width: 100%;
  }
}
.col2_wrap .col2_side .box {
  position: sticky;
  top: 150px;
}
.col2_wrap .col2_side .toc li + li {
  margin-top: clamp(0.9375rem, 0.6341019417rem + 1.2944983819vw, 2.1875rem);
}
.col2_wrap .col2_side .toc a {
  display: block;
  padding-left: 30px;
  font-size: clamp(1rem, 0.9393203883rem + 0.2588996764vw, 1.25rem);
  font-weight: 500;
  position: relative;
}
.col2_wrap .col2_side .toc a::before {
  content: "";
  width: 10px;
  height: 10px;
  background-color: #e6e6e6;
  border-radius: 50%;
  position: absolute;
  top: 0.6em;
  left: 0;
  transition: 0.3s ease;
}
.col2_wrap .col2_side .toc a.current, .col2_wrap .col2_side .toc a:hover {
  color: #e56913;
  font-weight: 700;
}
.col2_wrap .col2_side .toc a.current::before, .col2_wrap .col2_side .toc a:hover::before {
  background-color: #e56913;
}
.col2_wrap .col2_main {
  padding-right: 10%;
  flex: 1;
}
@media screen and (max-width: 1200px) {
  .col2_wrap .col2_main {
    padding-right: 0;
  }
}

/*-----ページ番号------*/
.page_navi .screen-reader-text {
  display: none;
}
.page_navi .nav-links {
  margin-top: clamp(2.8125rem, 2.5091019417rem + 1.2944983819vw, 4.0625rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1.875rem, 1.7991504854rem + 0.3236245955vw, 2.1875rem);
}
.page_navi .nav-links .page-numbers {
  font-size: clamp(1rem, 0.9393203883rem + 0.2588996764vw, 1.25rem);
  color: #999999;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
}
.page_navi .nav-links .page-numbers.current, .page_navi .nav-links .page-numbers:hover {
  color: #e56913;
}
.page_navi .nav-links .page-numbers.prev, .page_navi .nav-links .page-numbers.next {
  font-size: 0.8em;
}

/*--------------プライバシーポリシー---------------- */
.policy_content .policy_box + .policy_box {
  margin-top: clamp(2.5rem, 1.5898058252rem + 3.8834951456vw, 6.25rem);
}
.policy_content .policy_box .left_line_ttl {
  border-width: clamp(0.1875rem, 0.1419902913rem + 0.1941747573vw, 0.375rem);
}
.policy_content .policy_box p {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  line-height: 2;
  letter-spacing: 0.1em;
}

/*--------------プライバシーポリシー---------------- */
.contact_content .intro {
  margin-bottom: clamp(3.75rem, 3.4466019417rem + 1.2944983819vw, 5rem);
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  text-align: center;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .contact_content .intro {
    line-height: 1.7;
  }
}
.contact_content .contact_block .box {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
.contact_content .contact_block .box + .box {
  margin-top: clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
}
.contact_content .contact_block .box .left {
  padding: 10px 30px 0 0;
  width: 400px;
  font-size: clamp(1rem, 0.9089805825rem + 0.3883495146vw, 1.375rem);
  font-weight: 700;
}
@media screen and (max-width: 992px) {
  .contact_content .contact_block .box .left {
    width: 100%;
    padding: 0 0 10px;
  }
}
.contact_content .contact_block .box .left.required {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.contact_content .contact_block .box .left.required::after {
  padding: 5px 10px;
  display: flex;
  align-items: center;
  content: "必須";
  background-color: #e56913;
  color: #fff;
  font-size: clamp(0.6875rem, 0.5813106796rem + 0.4530744337vw, 1.125rem);
  font-weight: 700;
  line-height: 1;
}
.contact_content .contact_block .box .right {
  width: calc(100% - 400px);
  font-size: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
}
@media screen and (max-width: 992px) {
  .contact_content .contact_block .box .right {
    width: 100%;
  }
}
.contact_content .contact_block .box .right input[type=radio] {
  appearance: none;
  -webkit-appearance: none;
  background: #fff;
  border: 1px solid #cccccc;
  border-radius: 50%;
  width: clamp(1.25rem, 1.1893203883rem + 0.2588996764vw, 1.5rem);
  height: clamp(1.25rem, 1.1893203883rem + 0.2588996764vw, 1.5rem);
  position: relative;
  cursor: pointer;
  vertical-align: middle;
  transition: border-color 0.2s;
}
.contact_content .contact_block .box .right input[type=radio]::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: #e56913;
  border-radius: 50%;
  position: absolute;
  top: clamp(0.25rem, 0.2196601942rem + 0.1294498382vw, 0.375rem);
  left: clamp(0.25rem, 0.2196601942rem + 0.1294498382vw, 0.375rem);
  transform: scale(0);
  transition: 0.3s all;
}
.contact_content .contact_block .box .right input[type=radio]:checked::after {
  transform: scale(1);
}
.contact_content .contact_block .box .right input[type=text],
.contact_content .contact_block .box .right input[type=tel],
.contact_content .contact_block .box .right input[type=email],
.contact_content .contact_block .box .right textarea {
  padding: 15px;
  width: 100%;
  background-color: #f0f0f0;
  font-size: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  border: none;
}
.contact_content .contact_block .box .right input[type=text]:focus,
.contact_content .contact_block .box .right input[type=tel]:focus,
.contact_content .contact_block .box .right input[type=email]:focus,
.contact_content .contact_block .box .right textarea:focus {
  outline: none;
  background-color: #fff7e5;
}
.contact_content .contact_block .box .right textarea {
  min-height: clamp(8.125rem, 7.0631067961rem + 4.5307443366vw, 12.5rem);
}
.contact_content .contact_block .box .right .cate {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
}
.contact_content .contact_block .box .right .cate label {
  display: flex;
  align-items: center;
  gap: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .contact_content .contact_block .box .right .cate label {
    width: 100%;
  }
}
.contact_content .contact_block .policy {
  margin-top: clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem);
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.contact_content .contact_block .policy label {
  display: flex;
  align-items: center;
  justify-content: center;
}
.contact_content .contact_block .policy input[type=checkbox] {
  margin-right: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem);
  appearance: none;
  -webkit-appearance: none;
  width: 27px;
  height: 27px;
  border: 1px solid #ccc;
  background: #fff;
  vertical-align: middle;
  position: relative;
  transition: border-color 0.2s, background 0.2s;
  cursor: pointer;
}
.contact_content .contact_block .policy input[type=checkbox]:checked {
  border-color: #e56913;
  background: #e56913;
}
.contact_content .contact_block .policy input[type=checkbox]:checked::after {
  content: "";
  position: absolute;
  left: 9px;
  top: 3px;
  width: 8px;
  height: 14px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
  pointer-events: none;
}
.contact_content .contact_block .policy a {
  text-decoration: underline;
  text-underline-offset: 0.1em;
}
.contact_content .contact_block .submit {
  margin-top: clamp(2.5rem, 1.8932038835rem + 2.5889967638vw, 5rem);
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  text-align: center;
}
.contact_content .contact_block .submit .arrow_btn {
  margin: 55px auto 0;
  padding: 0;
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .contact_content .contact_block .submit .arrow_btn {
    max-width: 295px;
  }
}
.contact_content .contact_block .submit .arrow_btn .text::after {
  right: clamp(1.25rem, 1.1741504854rem + 0.3236245955vw, 1.5625rem);
}
.contact_content .contact_block .submit .arrow_btn input {
  width: 100%;
  padding: clamp(1.25rem, 1.1741504854rem + 0.3236245955vw, 1.5625rem);
  text-align: center;
  background: none;
  border: none;
  font-size: clamp(1rem, 0.9089805825rem + 0.3883495146vw, 1.375rem);
  color: #fff;
  cursor: pointer;
}
.contact_content .contact_block .submit .arrow_btn .wpcf7-spinner {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%) translateY(10px);
  margin: 0;
}

.wpcf7 form.init .contact_pop,
.wpcf7 form.resetting .contact_pop,
.wpcf7 form.submitting .contact_pop {
  display: none;
}

.wpcf7 form .contact_pop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: rgba(26, 26, 26, 0.1);
  gap: 10px;
  justify-content: center;
  align-items: center;
  z-index: 1;
  transition: 0.3s ease-out;
}
.wpcf7 form .contact_pop::after {
  content: "×";
  font-weight: 700;
  font-size: 30px;
}
.wpcf7 form .contact_pop .wpcf7-response-output {
  margin: 0 20px;
  padding: 50px;
  background-color: #fff;
}
.wpcf7 form .contact_pop.hidden {
  opacity: 0;
  visibility: hidden;
}

/*--------------プレスリリース---------------- */
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate {
    display: flex;
    gap: 1px;
  }
}
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate li {
    flex: 1;
  }
}
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate li + li {
    margin-top: 0;
  }
}
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate li a {
    padding-left: 0;
    padding-bottom: 5px;
    border-bottom: solid 3px #e6e6e6;
    display: block;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate li a::before {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .news_list_page .col2_side .news_cate li a.current {
    border-color: #e56913;
  }
}
.news_list_page .news_list li {
  padding: clamp(1.25rem, 1.25rem + 0vw, 1.25rem) 0;
  border-bottom: solid 1px #cccccc;
}
.news_list_page .news_list li:first-child {
  padding-top: 0;
}
.news_list_page .news_list li a {
  display: block;
  padding-right: clamp(2.1875rem, 2.1116504854rem + 0.3236245955vw, 2.5rem);
  position: relative;
}
.news_list_page .news_list li a::after {
  content: "";
  display: block;
  width: clamp(0.5rem, 0.4089805825rem + 0.3883495146vw, 0.875rem);
  height: clamp(0.3125rem, 0.2669902913rem + 0.1941747573vw, 0.5rem);
  background: url(../images/common/icon_arrow_pageup.svg) no-repeat center center;
  background-size: contain;
  top: 50%;
  right: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  position: absolute;
  transform: translateY(-50%) rotate(90deg);
  transition: 0.3s ease;
}
.news_list_page .news_list li a:hover::after {
  transform: translateY(-50%) translateX(2px) rotate(90deg);
}
.news_list_page .news_list li .date {
  margin-bottom: clamp(0.3125rem, 0.3125rem + 0vw, 0.3125rem);
  font-size: clamp(0.8125rem, 0.7366504854rem + 0.3236245955vw, 1.125rem);
  font-weight: 700;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  color: #999999;
}
.news_list_page .news_list li .ttl {
  font-weight: 500;
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  line-height: 1.7;
}

.news_detail_page .news_detail_top {
  margin-bottom: clamp(1.25rem, 0.3398058252rem + 3.8834951456vw, 5rem);
  padding-bottom: clamp(1.25rem, 0.7949029126rem + 1.9417475728vw, 3.125rem);
  border-bottom: solid 1px #cccccc;
}
.news_detail_page .news_detail_top .info {
  margin-bottom: clamp(0.9375rem, 0.6341019417rem + 1.2944983819vw, 2.1875rem);
  display: flex;
  gap: clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
}
@media screen and (max-width: 768px) {
  .news_detail_page .news_detail_top .info {
    justify-content: space-between;
  }
}
.news_detail_page .news_detail_top .date {
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  font-weight: 700;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  color: #999999;
  letter-spacing: 0.1em;
}
.news_detail_page .news_detail_top .tag {
  display: flex;
  align-items: center;
  gap: 5px;
}
.news_detail_page .news_detail_top .tag a {
  padding: clamp(0.25rem, 0.2044902913rem + 0.1941747573vw, 0.4375rem) clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  background-color: #e56913;
  color: #fff;
  font-weight: 700;
  font-size: clamp(0.75rem, 0.6893203883rem + 0.2588996764vw, 1rem);
  line-height: 1;
  display: inline-block;
}
.news_detail_page .news_detail_top .tag a:hover {
  background-color: #999;
}
.news_detail_page .news_detail_top .news_detail_ttl {
  font-size: clamp(1.125rem, 0.8519417476rem + 1.1650485437vw, 2.25rem);
}
.news_detail_page .cont img {
  margin-bottom: clamp(1.25rem, 0.4915048544rem + 3.2362459547vw, 4.375rem);
  border-radius: 10px;
}
.news_detail_page .cont h3 {
  margin-top: clamp(2.5rem, 1.286407767rem + 5.1779935275vw, 7.5rem);
  margin-bottom: clamp(0.9375rem, 0.5582524272rem + 1.6181229773vw, 2.5rem);
  padding: clamp(0.9375rem, 0.7858009709rem + 0.6472491909vw, 1.5625rem) clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  background-color: #fff7e5;
  font-size: clamp(1rem, 0.8786407767rem + 0.5177993528vw, 1.5rem);
}
.news_detail_page .cont p {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  line-height: 2;
}
.news_detail_page .cont p + p {
  margin-top: 2em;
}
.news_detail_page .cont a {
  color: #e56913;
  text-decoration: underline;
  text-underline-offset: 0.1em;
}
.news_detail_page .cont a:hover {
  text-decoration: none;
}
.news_detail_page .news_detail_bot {
  margin-top: clamp(3.75rem, 3.1432038835rem + 2.5889967638vw, 6.25rem);
  padding-top: clamp(1.875rem, 0.8131067961rem + 4.5307443366vw, 6.25rem);
  border-top: solid 1px #cccccc;
}

.message_page .kaso_block,
.company_page .kaso_block,
.approach_page .kaso_block,
.activity_page .kaso_block {
  padding: clamp(7.5rem, 6.5898058252rem + 3.8834951456vw, 11.25rem) 0 clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem);
}
@media screen and (max-width: 768px) {
  .message_page .kaso_block,
  .company_page .kaso_block,
  .approach_page .kaso_block,
  .activity_page .kaso_block {
    padding: clamp(4.375rem, 3.9199029126rem + 1.9417475728vw, 6.25rem) 0 clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
  }
}
.message_page .kaso_header .kaso_ttl .ja,
.company_page .kaso_header .kaso_ttl .ja,
.approach_page .kaso_header .kaso_ttl .ja,
.activity_page .kaso_header .kaso_ttl .ja {
  color: #fff;
}
.message_page .col2_wrap,
.company_page .col2_wrap,
.approach_page .col2_wrap,
.activity_page .col2_wrap {
  gap: clamp(0.625rem, 0.0182038835rem + 2.5889967638vw, 3.125rem) clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
}
@media screen and (max-width: 768px) {
  .message_page .col2_wrap .col2_side,
  .company_page .col2_wrap .col2_side,
  .approach_page .col2_wrap .col2_side,
  .activity_page .col2_wrap .col2_side {
    margin: 0 -20px;
    width: auto;
  }
}
.message_page .col2_wrap .col2_side .box,
.company_page .col2_wrap .col2_side .box,
.approach_page .col2_wrap .col2_side .box,
.activity_page .col2_wrap .col2_side .box {
  display: flex;
}
.message_page .col2_wrap .col2_side .box .en,
.company_page .col2_wrap .col2_side .box .en,
.approach_page .col2_wrap .col2_side .box .en,
.activity_page .col2_wrap .col2_side .box .en {
  color: #e56913;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
  line-height: 0.8;
  font-size: clamp(0.75rem, 0.7348300971rem + 0.0647249191vw, 0.8125rem);
  margin-bottom: clamp(0.9375rem, 0.6341019417rem + 1.2944983819vw, 2.1875rem);
}
.message_page .col2_wrap .col2_side .box .toc a,
.company_page .col2_wrap .col2_side .box .toc a,
.approach_page .col2_wrap .col2_side .box .toc a,
.activity_page .col2_wrap .col2_side .box .toc a {
  padding-left: 20px;
  line-height: 1.4;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .toc_wrap,
  .company_page .col2_wrap .col2_side .box .toc_wrap,
  .approach_page .col2_wrap .col2_side .box .toc_wrap,
  .activity_page .col2_wrap .col2_side .box .toc_wrap {
    display: none;
  }
}
.message_page .col2_wrap .col2_side .box .decotxt_wrap,
.company_page .col2_wrap .col2_side .box .decotxt_wrap,
.approach_page .col2_wrap .col2_side .box .decotxt_wrap,
.activity_page .col2_wrap .col2_side .box .decotxt_wrap {
  position: relative;
  width: calc(clamp(4.375rem, 3.6165048544rem + 3.2362459547vw, 7.5rem) - 18px);
  height: 100%;
}
@media screen and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap {
    width: 100%;
    height: auto;
    overflow: hidden;
  }
}
.message_page .col2_wrap .col2_side .box .decotxt_wrap > div,
.company_page .col2_wrap .col2_side .box .decotxt_wrap > div,
.approach_page .col2_wrap .col2_side .box .decotxt_wrap > div,
.activity_page .col2_wrap .col2_side .box .decotxt_wrap > div {
  position: absolute;
  left: 0;
  bottom: 0;
  transform: rotate(90deg);
  transform-origin: left bottom;
  display: block;
  white-space: nowrap;
  font-size: clamp(4.375rem, 3.6165048544rem + 3.2362459547vw, 7.5rem);
  line-height: 0.8;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
  color: #e56913;
  opacity: 0.05;
}
@media screen and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap > div,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap > div,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap > div,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap > div {
    position: relative;
    transform: none;
    font-size: 17vw;
    text-align: center;
    display: flex;
    justify-content: center;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap > div.MESSAGE,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap > div.MESSAGE,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap > div.MESSAGE,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap > div.MESSAGE {
    font-size: 20vw;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap > div.COMPANY,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap > div.COMPANY,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap > div.COMPANY,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap > div.COMPANY {
    font-size: 19vw;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap > div.APPROACH,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap > div.APPROACH,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap > div.APPROACH,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap > div.APPROACH {
    font-size: 17vw;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .message_page .col2_wrap .col2_side .box .decotxt_wrap > div.ACTIVITY,
  .company_page .col2_wrap .col2_side .box .decotxt_wrap > div.ACTIVITY,
  .approach_page .col2_wrap .col2_side .box .decotxt_wrap > div.ACTIVITY,
  .activity_page .col2_wrap .col2_side .box .decotxt_wrap > div.ACTIVITY {
    font-size: 20vw;
    letter-spacing: 0.05em;
  }
}
.message_page .col2_wrap .col2_side .box .decotxt_wrap svg,
.company_page .col2_wrap .col2_side .box .decotxt_wrap svg,
.approach_page .col2_wrap .col2_side .box .decotxt_wrap svg,
.activity_page .col2_wrap .col2_side .box .decotxt_wrap svg {
  display: none;
  width: 100%;
  max-width: 100%;
  height: auto;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 700;
  fill: #e56913;
  opacity: 0.05;
  pointer-events: none;
}
.message_page .col2_wrap .col2_side .box .decotxt_wrap svg .decotxt,
.company_page .col2_wrap .col2_side .box .decotxt_wrap svg .decotxt,
.approach_page .col2_wrap .col2_side .box .decotxt_wrap svg .decotxt,
.activity_page .col2_wrap .col2_side .box .decotxt_wrap svg .decotxt {
  font-size: 80px;
  text-anchor: start;
  dominant-baseline: middle;
}
.message_page .col2_wrap .col2_main,
.company_page .col2_wrap .col2_main,
.approach_page .col2_wrap .col2_main,
.activity_page .col2_wrap .col2_main {
  padding-right: 0;
}
.message_page h2,
.company_page h2,
.approach_page h2,
.activity_page h2 {
  font-size: clamp(1.375rem, 1.2233009709rem + 0.6472491909vw, 2rem);
  font-weight: 700;
  padding-bottom: clamp(1.125rem, 0.942961165rem + 0.7766990291vw, 1.875rem);
  margin-bottom: clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
  position: relative;
}
.message_page h2::before, .message_page h2::after,
.company_page h2::before,
.company_page h2::after,
.approach_page h2::before,
.approach_page h2::after,
.activity_page h2::before,
.activity_page h2::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
}
.message_page h2::after,
.company_page h2::after,
.approach_page h2::after,
.activity_page h2::after {
  right: 0;
  background: #e6e6e6;
  width: 100%;
  z-index: 0;
}
.message_page h2::before,
.company_page h2::before,
.approach_page h2::before,
.activity_page h2::before {
  width: 60px;
  background: #e56913;
  z-index: 1;
}
.message_page p,
.company_page p,
.approach_page p,
.activity_page p {
  margin-bottom: clamp(1rem, 0.7572815534rem + 1.0355987055vw, 2rem);
}

.message_page .fc_orange {
  color: #e56913;
}
.message_page section {
  margin-bottom: clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem);
}
.message_page section .description {
  font-size: clamp(1.125rem, 0.9126213592rem + 0.9061488673vw, 2rem);
  font-weight: 700;
  line-height: 1.4;
}
.message_page section .detail {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.message_page section img {
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
}
.message_page .section_philosophy .cont .description {
  font-size: clamp(1.75rem, 1.567961165rem + 0.7766990291vw, 2.5rem);
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .message_page .section_philosophy .cont .description {
    line-height: 1.4;
    margin-bottom: clamp(1.25rem, 1.067961165rem + 0.7766990291vw, 2rem);
  }
}
.message_page .section_philosophy .cont .description .pc_line {
  letter-spacing: 0.09em;
}
@media screen and (max-width: 768px) {
  .message_page .section_philosophy .cont .description .pc_line {
    letter-spacing: unset;
  }
}
.message_page .section_guideline .cont {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.9375rem, 0.7858009709rem + 0.6472491909vw, 1.5625rem);
  margin-bottom: clamp(4.375rem, 2.4029126214rem + 8.4142394822vw, 12.5rem);
}
@media screen and (max-width: 768px) {
  .message_page .section_guideline .cont {
    flex-direction: column;
  }
}
.message_page .section_guideline .cont .text_wrap {
  flex: 1 1 calc(52.5% - clamp(0.9375rem, 0.9375rem + 0vw, 0.9375rem));
}
.message_page .section_guideline .cont .img_wrap {
  flex: 1 1 calc(47.5% - clamp(0.9375rem, 0.9375rem + 0vw, 0.9375rem));
  text-align: center;
}
.message_page .section_guideline .cont .img_wrap img {
  max-width: 100%;
  height: auto;
}
.message_page .section_message .cont .img_wrap {
  position: relative;
  margin-bottom: clamp(0.9375rem, 0.4065533981rem + 2.2653721683vw, 3.125rem);
}
.message_page .section_message .cont .img_wrap img:nth-child(2) {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.message_page .section_message .cont .img_wrap.active img:nth-child(2) {
  opacity: 1;
}
.message_page .section_message .cont .img_wrap_02 {
  text-align: center;
}
.message_page .section_message .cont .img_wrap_02 img {
  width: clamp(18.75rem, 15.1850728155rem + 15.2103559871vw, 33.4375rem);
}
.message_page .section_message .cont .description {
  font-size: clamp(1.375rem, 1.2233009709rem + 0.6472491909vw, 2rem);
}
.message_page .section_message .cont .detail {
  margin-bottom: clamp(1.5625rem, 1.4563106796rem + 0.4530744337vw, 2rem);
}
.message_page .section_manager .cont ul {
  display: flex;
  flex-wrap: wrap;
  column-gap: clamp(0.9375rem, 0.0273058252rem + 3.8834951456vw, 4.6875rem);
  row-gap: clamp(2.5rem, 2.0449029126rem + 1.9417475728vw, 4.375rem);
  justify-content: flex-start;
}
.message_page .section_manager .cont ul li {
  flex: 1 1 calc(33.3333333333% - clamp(0.9375rem, 0.0273058252rem + 3.8834951456vw, 4.6875rem) * 2 / 3);
  max-width: calc(33.3333333333% - clamp(0.9375rem, 0.0273058252rem + 3.8834951456vw, 4.6875rem) * 2 / 3);
  box-sizing: border-box;
}
@media screen and (max-width: 992px) {
  .message_page .section_manager .cont ul li {
    flex: 1 1 calc(50% - clamp(0.9375rem, 0.0273058252rem + 3.8834951456vw, 4.6875rem) / 2);
    max-width: calc(50% - clamp(0.9375rem, 0.0273058252rem + 3.8834951456vw, 4.6875rem) / 2);
  }
}
.message_page .section_manager .cont ul li.active .img_wrap .photo-a {
  opacity: 0;
}
.message_page .section_manager .cont ul li.active .img_wrap .photo-b {
  opacity: 1;
}
.message_page .section_manager .cont ul li .img_wrap {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 4/5;
}
.message_page .section_manager .cont ul li .img_wrap .photo-a {
  display: block;
}
.message_page .section_manager .cont ul li .img_wrap .photo-a,
.message_page .section_manager .cont ul li .img_wrap .photo-b {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  transition: opacity 0.1s linear;
  pointer-events: none;
}
.message_page .section_manager .cont ul li .img_wrap .photo-b {
  opacity: 0;
}
.message_page .section_manager .cont ul li .img_wrap .kana {
  margin: 0;
  padding: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
  width: 100%;
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  position: absolute;
  bottom: 0;
  left: 0;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 500;
  font-size: clamp(1rem, 0.817961165rem + 0.7766990291vw, 1.75rem);
  color: #fff;
  line-height: 1.2;
  background: linear-gradient(0deg, #1a1a1a 0%, transparent 100%);
}
.message_page .section_manager .cont ul li .position {
  font-size: clamp(0.75rem, 0.6589805825rem + 0.3883495146vw, 1.125rem);
  font-weight: 500;
  margin: clamp(0.75rem, 0.75rem + 0vw, 0.75rem) 0 0;
  line-height: 1;
  color: #999;
}
.message_page .section_manager .cont ul li .name {
  font-size: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  font-weight: 500;
  margin: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem) 0 0;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .activity_page .activity_block,
  .approach_page .activity_block {
    overflow: hidden;
  }
}
.activity_page h2,
.approach_page h2 {
  margin-bottom: 0;
}
@media screen and (max-width: 992px) {
  .activity_page h2,
  .approach_page h2 {
    margin-bottom: 30px;
  }
}
.activity_page .activity,
.approach_page .activity {
  margin-bottom: calc(clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem) * -1);
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 992px) {
  .activity_page .activity,
  .approach_page .activity {
    flex-direction: column-reverse;
  }
}
.activity_page .activity .left,
.approach_page .activity .left {
  margin-top: clamp(1.875rem, 1.4199029126rem + 1.9417475728vw, 3.75rem);
  margin-bottom: clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem);
  width: 53.3333333333%;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .left,
  .approach_page .activity .left {
    width: 100%;
  }
}
.activity_page .activity .left .cont + .cont,
.approach_page .activity .left .cont + .cont {
  margin-top: clamp(3.125rem, 2.3665048544rem + 3.2362459547vw, 6.25rem);
}
.activity_page .activity .left .cont .description,
.approach_page .activity .left .cont .description {
  font-size: clamp(1.125rem, 0.9733009709rem + 0.6472491909vw, 1.75rem);
  font-weight: 700;
  color: #e56913;
  line-height: 1.6;
}
.activity_page .activity .left .cont .detail,
.approach_page .activity .left .cont .detail {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.activity_page .activity .right,
.approach_page .activity .right {
  width: 42.2222222222%;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .right,
  .approach_page .activity .right {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .activity_page .activity .right,
  .approach_page .activity .right {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
}
.activity_page .activity .right .activity_slider,
.approach_page .activity .right .activity_slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .right .activity_slider,
  .approach_page .activity .right .activity_slider {
    position: relative;
  }
}
.activity_page .activity .right .activity_slider .splide__slide,
.approach_page .activity .right .activity_slider .splide__slide {
  padding: 3.5% 3%;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .right .activity_slider .splide__slide,
  .approach_page .activity .right .activity_slider .splide__slide {
    padding: 2%;
  }
}
.activity_page .activity .right .activity_slider .splide__slide.slide01,
.approach_page .activity .right .activity_slider .splide__slide.slide01 {
  padding-right: 10%;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .right .activity_slider .splide__slide.slide01,
  .approach_page .activity .right .activity_slider .splide__slide.slide01 {
    padding-bottom: 5%;
    padding-right: 2%;
  }
}
.activity_page .activity .right .activity_slider .splide__slide.slide01 img,
.approach_page .activity .right .activity_slider .splide__slide.slide01 img {
  transform: rotate(5deg);
}
.activity_page .activity .right .activity_slider .splide__slide.slide02,
.approach_page .activity .right .activity_slider .splide__slide.slide02 {
  padding-left: 10%;
}
@media screen and (max-width: 992px) {
  .activity_page .activity .right .activity_slider .splide__slide.slide02,
  .approach_page .activity .right .activity_slider .splide__slide.slide02 {
    padding-top: 5%;
    padding-left: 2%;
  }
}
.activity_page .activity .right .activity_slider .splide__slide.slide02 img,
.approach_page .activity .right .activity_slider .splide__slide.slide02 img {
  transform: rotate(-5deg);
}
.activity_page .activity .right .activity_slider .splide__slide img,
.approach_page .activity .right .activity_slider .splide__slide img {
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
}

/*--------------店舗情報---------------- */
.shop_detail_page .brand_list_block {
  padding: clamp(6.25rem, 5.036407767rem + 5.1779935275vw, 11.25rem) 0 clamp(3.75rem, 2.6122572816rem + 4.854368932vw, 8.4375rem);
  background-color: #fff7e5;
}
.shop_detail_page .brand_list_block .intro {
  margin-bottom: clamp(2.1875rem, 1.5048543689rem + 2.9126213592vw, 5rem);
  text-align: center;
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_list_block .intro {
    text-align: left;
  }
}
.shop_detail_page .brand_list_block .all {
  margin-top: clamp(5rem, 3.6347087379rem + 5.8252427184vw, 10.625rem);
}
.shop_detail_page .brand_list_block .all .all_top {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: clamp(1.25rem, 1.0983009709rem + 0.6472491909vw, 1.875rem);
}
.shop_detail_page .brand_list_block .all .all_top .sec_ttl {
  margin-bottom: 0;
}
.shop_detail_page .brand_list_block .all .all_top .cate_tab {
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_list_block .all .all_top .cate_tab {
    width: 100%;
    margin-left: 0;
  }
}
.shop_detail_page .brand_list_block .all .all_top .cate_tab ul {
  display: flex;
  gap: clamp(1.25rem, 0.7949029126rem + 1.9417475728vw, 3.125rem);
}
.shop_detail_page .brand_list_block .all .all_top .cate_tab ul li a {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  display: flex;
  align-items: center;
}
.shop_detail_page .brand_list_block .all .all_top .cate_tab ul li a::before {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-right: solid 3px #e56913;
  border-bottom: solid 3px #e56913;
  transform: rotate(45deg);
  margin-right: clamp(0.25rem, 0.1893203883rem + 0.2588996764vw, 0.5rem);
  transition: 0.3s ease;
}
.shop_detail_page .brand_list_block .all .all_top .cate_tab ul li a:hover::before {
  transform: translateY(2px) rotate(45deg);
}
.shop_detail_page .brand_list_block .all .box {
  margin-top: clamp(2.5rem, 0.8313106796rem + 7.1197411003vw, 9.375rem);
}
.shop_detail_page .brand_list_block .brand_list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.875rem, 1.4199029126rem + 1.9417475728vw, 3.75rem) 5.3968253968%;
}
@media screen and (max-width: 992px) {
  .shop_detail_page .brand_list_block .brand_list {
    gap: 30px;
  }
}
@media screen and (max-width: 576px) {
  .shop_detail_page .brand_list_block .brand_list {
    gap: 30px 20px;
  }
}
.shop_detail_page .brand_list_block .brand_list li {
  width: 20.9523809524%;
  text-align: center;
}
@media screen and (max-width: 992px) {
  .shop_detail_page .brand_list_block .brand_list li {
    width: calc((100% - 60px) / 3);
  }
}
@media screen and (max-width: 576px) {
  .shop_detail_page .brand_list_block .brand_list li {
    width: calc((100% - 20px) / 2);
  }
}
.shop_detail_page .brand_list_block .brand_list li a {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.shop_detail_page .brand_list_block .brand_list li a:hover .photo img {
  opacity: 1;
}
.shop_detail_page .brand_list_block .brand_list li a:hover .photo::after {
  box-shadow: inset 0 0 0 2px #e56913;
}
.shop_detail_page .brand_list_block .brand_list li .photo {
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  overflow: hidden;
  position: relative;
}
.shop_detail_page .brand_list_block .brand_list li .photo::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  transition: 0.3s ease;
}
.shop_detail_page .brand_list_block .brand_list li .text {
  margin-top: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
  margin-bottom: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  line-height: 1.4;
}
.shop_detail_page .brand_list_block .brand_list li .tag {
  margin-top: auto;
  padding-top: 5px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem);
}
.shop_detail_page .brand_list_block .brand_list li .tag span {
  padding: 0 clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  display: block;
  border: solid 1px #e56913;
  color: #e56913;
  font-size: clamp(0.75rem, 0.6893203883rem + 0.2588996764vw, 1rem);
  font-weight: 700;
  white-space: nowrap;
}
.shop_detail_page .brand_detail_info {
  padding: clamp(6.25rem, 5.036407767rem + 5.1779935275vw, 11.25rem) 0 clamp(3.75rem, 2.6122572816rem + 4.854368932vw, 8.4375rem);
  background-color: #fff7e5;
}
.shop_detail_page .brand_detail_info .top {
  display: flex;
  align-items: flex-start;
  gap: clamp(0.9375rem, 0.4065533981rem + 2.2653721683vw, 3.125rem);
  position: relative;
}
.shop_detail_page .brand_detail_info .top .photo {
  max-width: clamp(6.25rem, 3.7621359223rem + 10.6148867314vw, 16.5rem);
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  overflow: hidden;
  border: solid 1px #e6e6e6;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .top .photo {
    position: absolute;
    height: auto;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .top .text .info {
    margin-left: clamp(6.25rem, 3.7621359223rem + 10.6148867314vw, 16.5rem);
    padding-left: 15px;
    min-height: clamp(6.25rem, 3.7621359223rem + 10.6148867314vw, 16.5rem);
  }
}
.shop_detail_page .brand_detail_info .top .text .cate {
  display: flex;
  gap: clamp(0.625rem, 0.5491504854rem + 0.3236245955vw, 0.9375rem);
}
.shop_detail_page .brand_detail_info .top .text .cate span {
  padding: 0 clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  display: block;
  border: solid 1px #e56913;
  color: #e56913;
  font-size: clamp(0.75rem, 0.6893203883rem + 0.2588996764vw, 1rem);
  font-weight: 700;
}
.shop_detail_page .brand_detail_info .top .text .desc {
  margin-top: 30px;
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .top .text .desc {
    line-height: 1.7;
  }
}
.shop_detail_page .brand_detail_info .concept {
  margin-top: clamp(3.75rem, 2.6881067961rem + 4.5307443366vw, 8.125rem);
}
.shop_detail_page .brand_detail_info .concept .box {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .concept .box {
    flex-direction: column-reverse;
  }
}
.shop_detail_page .brand_detail_info .concept .box .text {
  width: 46.0317460317%;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .concept .box .text {
    width: 100%;
  }
}
.shop_detail_page .brand_detail_info .concept .box .text .copy {
  margin-bottom: clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
  font-size: clamp(1.25rem, 1.0072815534rem + 1.0355987055vw, 2.25rem);
}
.shop_detail_page .brand_detail_info .concept .box .text p {
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .concept .box .text p {
    line-height: 1.7;
  }
}
.shop_detail_page .brand_detail_info .concept .box .photo {
  width: 47.619047619%;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .brand_detail_info .concept .box .photo {
    width: 100%;
  }
}
.shop_detail_page .brand_detail_menu {
  padding: clamp(3.75rem, 2.6881067961rem + 4.5307443366vw, 8.125rem) 0 0;
}
.shop_detail_page .brand_detail_menu .menu {
  display: flex;
  gap: clamp(1.875rem, 1.4199029126rem + 1.9417475728vw, 3.75rem) clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
  flex-wrap: wrap;
}
.shop_detail_page .brand_detail_menu .menu li {
  width: calc((100% - clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem)) / 2);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 15px 4.132231405%;
}
@media screen and (max-width: 576px) {
  .shop_detail_page .brand_detail_menu .menu li {
    width: 100%;
  }
}
.shop_detail_page .brand_detail_menu .menu li:nth-child(1) .photo {
  clip-path: polygon(10% 15%, 0 50%, 15% 95%, 80% 100%, 100% 80%, 97% 30%, 80% 0%);
}
.shop_detail_page .brand_detail_menu .menu li:nth-child(2) .photo {
  clip-path: polygon(7% 15%, 0% 80%, 25% 100%, 90% 95%, 100% 60%, 90% 10%, 35% 0%);
}
.shop_detail_page .brand_detail_menu .menu li:nth-child(3) .photo {
  clip-path: polygon(5% 10%, 0% 60%, 10% 95%, 80% 100%, 97% 75%, 100% 20%, 75% 0%);
}
.shop_detail_page .brand_detail_menu .menu li:nth-child(4) .photo {
  clip-path: polygon(0% 20%, 8% 90%, 35% 100%, 95% 90%, 100% 45%, 90% 10%, 25% 0%);
}
.shop_detail_page .brand_detail_menu .menu li .photo {
  width: 59.5041322314%;
  aspect-ratio: 360/240;
}
@media screen and (max-width: 992px) {
  .shop_detail_page .brand_detail_menu .menu li .photo {
    width: 100%;
  }
}
.shop_detail_page .brand_detail_menu .menu li .text {
  width: 36.3636363636%;
}
@media screen and (max-width: 992px) {
  .shop_detail_page .brand_detail_menu .menu li .text {
    width: 100%;
    padding: 0 clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  }
}
.shop_detail_page .brand_detail_menu .menu li .text .name {
  margin-bottom: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem);
  color: #e56913;
  font-weight: 700;
  font-size: clamp(1rem, 0.9089805825rem + 0.3883495146vw, 1.375rem);
}
.shop_detail_page .shop_detail_info .top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 1200px) {
  .shop_detail_page .shop_detail_info .top {
    align-items: flex-start;
  }
}
.shop_detail_page .shop_detail_info .top .name {
  display: flex;
  align-items: center;
  gap: clamp(1.25rem, 1.0983009709rem + 0.6472491909vw, 1.875rem);
}
.shop_detail_page .shop_detail_info .top .name .photo {
  max-width: clamp(3.75rem, 2.3847087379rem + 5.8252427184vw, 9.375rem);
  border-radius: 10px;
  border: solid 1px #e6e6e6;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .name .photo {
    border-radius: 0;
  }
}
.shop_detail_page .shop_detail_info .top .name .text {
  font-size: clamp(1.375rem, 1.2233009709rem + 0.6472491909vw, 2rem);
  line-height: 1.3;
}
.shop_detail_page .shop_detail_info .top .button_wrap {
  width: 100%;
  max-width: clamp(14.0625rem, 5.3398058252rem + 37.216828479vw, 50rem);
  display: flex;
  justify-content: flex-end;
  gap: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
}
@media screen and (max-width: 1200px) {
  .shop_detail_page .shop_detail_info .top .button_wrap {
    max-width: 300px;
    flex-wrap: wrap;
    gap: 5px;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap {
    position: fixed;
    bottom: 0;
    left: 0;
    max-width: 100%;
    justify-content: space-between;
    gap: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .official_site {
    max-width: 100%;
    flex: 1 1 40%;
  }
}
.shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn {
  color: #1a1a1a;
  border: solid 1px #e56913;
  border-radius: 5px;
  padding-left: clamp(0.75rem, 0.5983009709rem + 0.6472491909vw, 1.375rem);
  padding-right: clamp(0.75rem, 0.5983009709rem + 0.6472491909vw, 1.375rem);
  background-color: #fff;
  min-width: clamp(7.5rem, 6.286407767rem + 5.1779935275vw, 12.5rem);
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn {
    max-width: 100%;
    min-width: none;
    border-radius: 0;
  }
}
.shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn::after, .shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn::before {
  content: none;
}
.shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn .text {
  padding-right: clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn .text {
    text-align: center;
  }
}
.shop_detail_page .shop_detail_info .top .button_wrap .official_site .arrow_btn .text::after {
  background: url(../images/common/icon_arrow-right-or.svg) no-repeat center/contain;
}
.shop_detail_page .shop_detail_info .top .button_wrap .reserve {
  max-width: clamp(14.0625rem, 11.3319174757rem + 11.6504854369vw, 25.3125rem);
  flex: 1 1 clamp(14.0625rem, 11.3319174757rem + 11.6504854369vw, 25.3125rem);
}
@media screen and (max-width: 1200px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .reserve {
    flex: auto;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .reserve {
    max-width: 100%;
    flex: 1 1 60%;
  }
}
.shop_detail_page .shop_detail_info .top .button_wrap .reserve a {
  height: 100%;
  min-width: 240px;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .top .button_wrap .reserve a {
    max-width: 100%;
    min-width: none;
    text-align: center;
  }
  .shop_detail_page .shop_detail_info .top .button_wrap .reserve a::before, .shop_detail_page .shop_detail_info .top .button_wrap .reserve a::after {
    border-radius: 0;
  }
}
.shop_detail_page .shop_detail_info .bot {
  margin-top: clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
  display: flex;
  gap: clamp(3.125rem, 2.9733009709rem + 0.6472491909vw, 3.75rem);
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot {
    flex-direction: column-reverse;
  }
}
.shop_detail_page .shop_detail_info .bot .info {
  flex: 1;
}
.shop_detail_page .shop_detail_info .bot .info dl {
  display: flex;
  flex-wrap: wrap;
}
.shop_detail_page .shop_detail_info .bot .info dl dt,
.shop_detail_page .shop_detail_info .bot .info dl dd {
  padding: clamp(1.25rem, 1.0983009709rem + 0.6472491909vw, 1.875rem) 0;
  border-bottom: solid 1px #cccccc;
}
.shop_detail_page .shop_detail_info .bot .info dl dt:nth-child(-n+2),
.shop_detail_page .shop_detail_info .bot .info dl dd:nth-child(-n+2) {
  padding-top: 0;
}
.shop_detail_page .shop_detail_info .bot .info dl dt {
  width: 130px;
  font-size: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .info dl dt {
    width: 100%;
    border-bottom: none;
    padding-bottom: 10px;
  }
}
.shop_detail_page .shop_detail_info .bot .info dl dd {
  width: calc(100% - 130px);
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .info dl dd {
    padding-top: 0;
    width: 100%;
  }
}
.shop_detail_page .shop_detail_info .bot .info dl dd a {
  color: #e56913;
  text-decoration: underline;
  text-underline-offset: 0.1em;
}
.shop_detail_page .shop_detail_info .bot .info dl dd a:not(:last-child) {
  margin-right: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
}
.shop_detail_page .shop_detail_info .bot .info dl dd a:hover {
  text-decoration: none;
}
.shop_detail_page .shop_detail_info .bot .info dl .tel {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-weight: 500;
  font-size: clamp(1.125rem, 1.0643203883rem + 0.2588996764vw, 1.375rem);
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}
.shop_detail_page .shop_detail_info .bot .info dl .tel::before {
  display: block;
  content: "";
  width: 15px;
  height: 20px;
  background: url(../images/brand/shoplist/icon_tel.svg) no-repeat center;
}
.shop_detail_page .shop_detail_info .bot .info dl .tel a {
  text-decoration: none;
  color: #1a1a1a;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .info dl .link {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .info dl .link a:not(:last-child) {
    margin-right: 0;
  }
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .info dl .link a {
    padding: 10px;
    background-color: #fff7e5;
    color: #e56913;
    width: calc((100% - 15px) / 2);
    border-radius: 45px;
    text-decoration: none;
    display: inline-block;
    text-align: center;
    font-weight: 700;
    text-decoration: none;
  }
}
.shop_detail_page .shop_detail_info .bot .info dl .sns a {
  display: inline-block;
  max-width: 50px;
}
.shop_detail_page .shop_detail_info .bot .info dl .app {
  display: flex;
}
.shop_detail_page .shop_detail_info .bot .info dl .app a {
  height: 100%;
  min-height: 40px;
}
.shop_detail_page .shop_detail_info .bot .info dl .app a img {
  height: 100%;
}
.shop_detail_page .shop_detail_info .bot .info dl .epark > div {
  width: 100% !important;
}
.shop_detail_page .shop_detail_info .bot .map {
  flex: 1;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_info .bot .map {
    aspect-ratio: 335/225;
  }
}
.shop_detail_page .shop_detail_info .bot .map iframe {
  border-radius: 5px;
  width: 100%;
  height: 100%;
}
.shop_detail_page .shop_detail_list {
  margin-top: clamp(3.75rem, 2.3847087379rem + 5.8252427184vw, 9.375rem);
  padding: clamp(3.125rem, 2.8216019417rem + 1.2944983819vw, 4.375rem) 0 clamp(3.125rem, 0.8495145631rem + 9.7087378641vw, 12.5rem);
  background-color: #fafafa;
}
.shop_detail_page .shop_detail_list .list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.9375rem, 0.4065533981rem + 2.2653721683vw, 3.125rem) clamp(0.9375rem, 0.2548543689rem + 2.9126213592vw, 3.75rem);
}
.shop_detail_page .shop_detail_list .list li {
  width: calc((100% - clamp(0.9375rem, 0.2548543689rem + 2.9126213592vw, 3.75rem)) / 2);
}
.shop_detail_page .shop_detail_list .list li a {
  padding: clamp(0.625rem, 0.4733009709rem + 0.6472491909vw, 1.25rem) clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
  display: flex;
  align-items: center;
  gap: 1em;
  background-color: #fff;
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  border: solid 1px #e56913;
  font-size: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem);
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_list .list li a {
    gap: 0.5em;
  }
}
.shop_detail_page .shop_detail_list .list li a::before {
  content: "";
  display: block;
  width: clamp(0.875rem, 0.7233009709rem + 0.6472491909vw, 1.5rem);
  height: clamp(1.125rem, 0.942961165rem + 0.7766990291vw, 1.875rem);
  background: url(../images/brand/shoplist/icon_location.svg) no-repeat center;
  background-size: contain;
}
.shop_detail_page .shop_detail_list .list li a::after {
  margin-left: auto;
  content: "";
  display: block;
  width: 20px;
  height: 15px;
  background: url(../images/common/icon_arrow-right-or.svg) no-repeat center;
  transition: 0.3s ease;
}
@media screen and (max-width: 768px) {
  .shop_detail_page .shop_detail_list .list li a::after {
    display: none;
  }
}
.shop_detail_page .shop_detail_list .list li a:hover {
  box-shadow: 0 0 0 2px #e56913;
  color: #1a1a1a;
}
.shop_detail_page .shop_detail_list .list li a:hover::after {
  transform: translateX(3px);
}

@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/YakuHanJP/YakuHanJP-Black.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Black.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Black.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: bold;
  src: url("../fonts/YakuHanJP/YakuHanJP-Bold.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Bold.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Bold.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: Medium;
  src: url("../fonts/YakuHanJP/YakuHanJP-Medium.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Medium.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/YakuHanJP/YakuHanJP-Regular.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Regular.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/YakuHanJP/YakuHanJP-DemiLight.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-DemiLight.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-DemiLight.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/YakuHanJP/YakuHanJP-Light.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Light.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Light.woff2") format("woff2");
}
@font-face {
  font-family: "YakuHanJP";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/YakuHanJP/YakuHanJP-Thin.eot?") format("eot"), url("../fonts/YakuHanJP/YakuHanJP-Thin.woff") format("woff"), url("../fonts/YakuHanJP/YakuHanJP-Thin.woff2") format("woff2");
}
/*共通設定*/
body {
  color: #1a1a1a;
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  line-height: 1.8;
  letter-spacing: 0.05rem;
  font-weight: normal;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 14px;
  }
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  font-weight: 700;
}

p {
  line-height: 2.2;
}

@media screen and (max-width: 768px) {
  p {
    line-height: 1.7;
  }
}
button,
option,
input {
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}

a {
  color: inherit;
}

a:hover {
  color: #e56913;
}

button:hover,
a:hover {
  transition: 0.3s ease-in-out;
}

/*color---------------------------------*/
.fw-300 {
  font-weight: 300;
}

.fw-400 {
  font-weight: 400;
}

.fw-500 {
  font-weight: 500;
}

.fw-600 {
  font-weight: 600;
}

.fw-700 {
  font-weight: 700;
}

.fw-800 {
  font-weight: 800;
}

.fw-900 {
  font-weight: 900;
}

.fs-12 {
  font-size: 12px;
}

@media screen and (max-width: 768px) {
  .fs-12 {
    font-size: 10px;
  }
}
.fs-13 {
  font-size: 13px;
}

@media screen and (max-width: 768px) {
  .fs-13 {
    font-size: 11px;
  }
}
.fs-15 {
  font-size: 15px;
}

@media screen and (max-width: 768px) {
  .fs-15 {
    font-size: 13px;
  }
}
.fs-16 {
  font-size: 16px;
}

@media screen and (max-width: 768px) {
  .fs-16 {
    font-size: 13px;
  }
}
.fs-18 {
  font-size: 18px;
}

@media screen and (max-width: 768px) {
  .fs-18 {
    font-size: 15px;
  }
}
.fs-20 {
  font-size: 20px;
}

@media screen and (max-width: 768px) {
  .fs-20 {
    font-size: 18px;
  }
}
.fs-22 {
  font-size: 22px;
}

@media screen and (max-width: 768px) {
  .fs-22 {
    font-size: 18px;
  }
}
.fs-24 {
  font-size: 24px;
}

@media screen and (max-width: 768px) {
  .fs-24 {
    font-size: 20px;
  }
}
.fs-30 {
  font-size: 30px;
}

@media screen and (max-width: 768px) {
  .fs-30 {
    font-size: 24px;
  }
}
.fs-35 {
  font-size: 35px;
}

@media screen and (max-width: 768px) {
  .fs-35 {
    font-size: 26px;
  }
}
/*text color---------------------------------*/
.fc-w {
  color: #fff;
}

.fc-orange {
  color: #e56913;
}

/*background---------------------------------*/
.bg_white {
  background-color: #fff;
}

/*align---------------------------------*/
.alL {
  text-align: left !important;
}

.alR {
  text-align: right !important;
}

.alC {
  text-align: center !important;
}

/*width---------------------------------*/
.page-width {
  max-width: 1610px;
  width: 100%;
  margin: 0 auto;
  padding: 0 60px;
}

@media screen and (max-width: 768px) {
  .page-width {
    padding: 0 20px;
  }
}
.content-width {
  max-width: 1260px;
  width: 100%;
  margin: 0 auto;
}

/*余白---------------------------------*/
/*margin---------------------------------*/
.mt0 {
  margin-top: 0px !important;
}

@media screen and (max-width: 768px) {
  .mt0 {
    margin-top: 0px !important;
  }
}
.mb0 {
  margin-bottom: 0px !important;
}

@media screen and (max-width: 768px) {
  .mb0 {
    margin-bottom: 0px !important;
  }
}
/*padding---------------------------------*/
.pt0 {
  padding-top: 0px !important;
}

@media screen and (max-width: 768px) {
  .pt0 {
    padding-top: 0px !important;
  }
}
.pb0 {
  padding-bottom: 0px !important;
}

@media screen and (max-width: 768px) {
  .pb0 {
    padding-bottom: 0px !important;
  }
}
/*margin---------------------------------*/
.mt10 {
  margin-top: 10px !important;
}

@media screen and (max-width: 768px) {
  .mt10 {
    margin-top: 5px !important;
  }
}
.mb10 {
  margin-bottom: 10px !important;
}

@media screen and (max-width: 768px) {
  .mb10 {
    margin-bottom: 5px !important;
  }
}
/*padding---------------------------------*/
.pt10 {
  padding-top: 10px !important;
}

@media screen and (max-width: 768px) {
  .pt10 {
    padding-top: 5px !important;
  }
}
.pb10 {
  padding-bottom: 10px !important;
}

@media screen and (max-width: 768px) {
  .pb10 {
    padding-bottom: 5px !important;
  }
}
/*margin---------------------------------*/
.mt20 {
  margin-top: 20px !important;
}

@media screen and (max-width: 768px) {
  .mt20 {
    margin-top: 10px !important;
  }
}
.mb20 {
  margin-bottom: 20px !important;
}

@media screen and (max-width: 768px) {
  .mb20 {
    margin-bottom: 10px !important;
  }
}
/*padding---------------------------------*/
.pt20 {
  padding-top: 20px !important;
}

@media screen and (max-width: 768px) {
  .pt20 {
    padding-top: 10px !important;
  }
}
.pb20 {
  padding-bottom: 20px !important;
}

@media screen and (max-width: 768px) {
  .pb20 {
    padding-bottom: 10px !important;
  }
}
/*margin---------------------------------*/
.mt30 {
  margin-top: 30px !important;
}

@media screen and (max-width: 768px) {
  .mt30 {
    margin-top: 15px !important;
  }
}
.mb30 {
  margin-bottom: 30px !important;
}

@media screen and (max-width: 768px) {
  .mb30 {
    margin-bottom: 15px !important;
  }
}
/*padding---------------------------------*/
.pt30 {
  padding-top: 30px !important;
}

@media screen and (max-width: 768px) {
  .pt30 {
    padding-top: 15px !important;
  }
}
.pb30 {
  padding-bottom: 30px !important;
}

@media screen and (max-width: 768px) {
  .pb30 {
    padding-bottom: 15px !important;
  }
}
/*margin---------------------------------*/
.mt40 {
  margin-top: 40px !important;
}

@media screen and (max-width: 768px) {
  .mt40 {
    margin-top: 20px !important;
  }
}
.mb40 {
  margin-bottom: 40px !important;
}

@media screen and (max-width: 768px) {
  .mb40 {
    margin-bottom: 20px !important;
  }
}
/*padding---------------------------------*/
.pt40 {
  padding-top: 40px !important;
}

@media screen and (max-width: 768px) {
  .pt40 {
    padding-top: 20px !important;
  }
}
.pb40 {
  padding-bottom: 40px !important;
}

@media screen and (max-width: 768px) {
  .pb40 {
    padding-bottom: 20px !important;
  }
}
/*margin---------------------------------*/
.mt50 {
  margin-top: 50px !important;
}

@media screen and (max-width: 768px) {
  .mt50 {
    margin-top: 25px !important;
  }
}
.mb50 {
  margin-bottom: 50px !important;
}

@media screen and (max-width: 768px) {
  .mb50 {
    margin-bottom: 25px !important;
  }
}
/*padding---------------------------------*/
.pt50 {
  padding-top: 50px !important;
}

@media screen and (max-width: 768px) {
  .pt50 {
    padding-top: 25px !important;
  }
}
.pb50 {
  padding-bottom: 50px !important;
}

@media screen and (max-width: 768px) {
  .pb50 {
    padding-bottom: 25px !important;
  }
}
/*margin---------------------------------*/
.mt60 {
  margin-top: 60px !important;
}

@media screen and (max-width: 768px) {
  .mt60 {
    margin-top: 30px !important;
  }
}
.mb60 {
  margin-bottom: 60px !important;
}

@media screen and (max-width: 768px) {
  .mb60 {
    margin-bottom: 30px !important;
  }
}
/*padding---------------------------------*/
.pt60 {
  padding-top: 60px !important;
}

@media screen and (max-width: 768px) {
  .pt60 {
    padding-top: 30px !important;
  }
}
.pb60 {
  padding-bottom: 60px !important;
}

@media screen and (max-width: 768px) {
  .pb60 {
    padding-bottom: 30px !important;
  }
}
/*margin---------------------------------*/
.mt80 {
  margin-top: 80px !important;
}

@media screen and (max-width: 768px) {
  .mt80 {
    margin-top: 40px !important;
  }
}
.mb80 {
  margin-bottom: 80px !important;
}

@media screen and (max-width: 768px) {
  .mb80 {
    margin-bottom: 40px !important;
  }
}
/*padding---------------------------------*/
.pt80 {
  padding-top: 80px !important;
}

@media screen and (max-width: 768px) {
  .pt80 {
    padding-top: 40px !important;
  }
}
.pb80 {
  padding-bottom: 80px !important;
}

@media screen and (max-width: 768px) {
  .pb80 {
    padding-bottom: 40px !important;
  }
}
/*margin---------------------------------*/
.mt100 {
  margin-top: 100px !important;
}

@media screen and (max-width: 768px) {
  .mt100 {
    margin-top: 50px !important;
  }
}
.mb100 {
  margin-bottom: 100px !important;
}

@media screen and (max-width: 768px) {
  .mb100 {
    margin-bottom: 50px !important;
  }
}
/*padding---------------------------------*/
.pt100 {
  padding-top: 100px !important;
}

@media screen and (max-width: 768px) {
  .pt100 {
    padding-top: 50px !important;
  }
}
.pb100 {
  padding-bottom: 100px !important;
}

@media screen and (max-width: 768px) {
  .pb100 {
    padding-bottom: 50px !important;
  }
}
/*margin---------------------------------*/
.mt120 {
  margin-top: 120px !important;
}

@media screen and (max-width: 768px) {
  .mt120 {
    margin-top: 60px !important;
  }
}
.mb120 {
  margin-bottom: 120px !important;
}

@media screen and (max-width: 768px) {
  .mb120 {
    margin-bottom: 60px !important;
  }
}
/*padding---------------------------------*/
.pt120 {
  padding-top: 120px !important;
}

@media screen and (max-width: 768px) {
  .pt120 {
    padding-top: 60px !important;
  }
}
.pb120 {
  padding-bottom: 120px !important;
}

@media screen and (max-width: 768px) {
  .pb120 {
    padding-bottom: 60px !important;
  }
}
/*layout---------------------------------*/
.flex_wrap {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: 20px;
}

@media screen and (max-width: 768px) {
  .flex_wrap {
    flex-flow: column wrap;
  }
}
/*displayのレスポンシブ対応*/
.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-grid {
  display: grid !important;
}

.d-inline-grid {
  display: inline-grid !important;
}

.d-table {
  display: table !important;
}

.d-table-row {
  display: table-row !important;
}

.d-table-cell {
  display: table-cell !important;
}

.d-flex {
  display: flex !important;
}

.d-inline-flex {
  display: inline-flex !important;
}

.d-list-item {
  display: list-item !important;
}

@media screen and (max-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-inline {
    display: inline !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-inline-block {
    display: inline-block !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-block {
    display: block !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-grid {
    display: grid !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-inline-grid {
    display: inline-grid !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-table {
    display: table !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-table-row {
    display: table-row !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-table-cell {
    display: table-cell !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-flex {
    display: flex !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
}
@media screen and (max-width: 576px) {
  .d-sm-list-item {
    display: list-item !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-none {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-inline {
    display: inline !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-inline-block {
    display: inline-block !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-block {
    display: block !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-grid {
    display: grid !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-inline-grid {
    display: inline-grid !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-table {
    display: table !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-table-row {
    display: table-row !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-table-cell {
    display: table-cell !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-flex {
    display: flex !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-inline-flex {
    display: inline-flex !important;
  }
}
@media screen and (max-width: 768px) {
  .d-md-list-item {
    display: list-item !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-inline {
    display: inline !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-inline-block {
    display: inline-block !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-block {
    display: block !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-grid {
    display: grid !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-inline-grid {
    display: inline-grid !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-table {
    display: table !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-table-row {
    display: table-row !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-table-cell {
    display: table-cell !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-flex {
    display: flex !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
}
@media screen and (max-width: 992px) {
  .d-lg-list-item {
    display: list-item !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-inline {
    display: inline !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-inline-block {
    display: inline-block !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-block {
    display: block !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-grid {
    display: grid !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-inline-grid {
    display: inline-grid !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-table {
    display: table !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-table-row {
    display: table-row !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-table-cell {
    display: table-cell !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-flex {
    display: flex !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
}
@media screen and (max-width: 1200px) {
  .d-xl-list-item {
    display: list-item !important;
  }
}
.company_page .company_profile table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: clamp(5rem, 3.9381067961rem + 4.5307443366vw, 9.375rem);
  font-size: clamp(0.875rem, 0.7839805825rem + 0.3883495146vw, 1.25rem);
}
.company_page .company_profile table tr {
  border-top: 1px solid #ececec;
  border-bottom: 1px solid #ececec;
}
.company_page .company_profile table th,
.company_page .company_profile table td {
  text-align: left;
  vertical-align: top;
}
.company_page .company_profile table th {
  padding: clamp(1.25rem, 1.1286407767rem + 0.5177993528vw, 1.75rem) clamp(0.625rem, 0.3216019417rem + 1.2944983819vw, 1.875rem);
  background-color: #fafafa;
  width: clamp(5rem, 1.6626213592rem + 14.2394822006vw, 18.75rem);
  font-weight: 700;
}
.company_page .company_profile table td {
  padding: clamp(1.25rem, 1.1286407767rem + 0.5177993528vw, 1.75rem) clamp(0.9375rem, 0.7099514563rem + 0.9708737864vw, 1.875rem);
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  line-height: 1.6;
}
.company_page .company_profile table a {
  color: #e56913;
  text-decoration: underline;
  text-underline-offset: 0.1em;
}
.company_page .company_profile table a:hover {
  text-decoration: none;
}
.company_page .company_history {
  margin-bottom: calc(clamp(6.25rem, 4.7330097087rem + 6.4724919094vw, 12.5rem) - clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem) - clamp(1.875rem, 0.8131067961rem + 4.5307443366vw, 6.25rem));
}
.company_page .company_history .fc_accent {
  color: #e56913;
}
.company_page .company_history .accordion_item:first-child .accordion_body .timeline li:first-child .timeline-dot::before {
  content: none;
}
.company_page .company_history .accordion_item .accordion_header {
  padding: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem) clamp(1.625rem, 1.4126213592rem + 0.9061488673vw, 2.5rem) clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem) clamp(1.25rem, 0.9466019417rem + 1.2944983819vw, 2.5rem);
  font-size: clamp(1rem, 0.9089805825rem + 0.3883495146vw, 1.375rem);
  display: flex;
  align-items: center;
  gap: clamp(1.25rem, 0.5673543689rem + 2.9126213592vw, 4.0625rem);
  background: #f9f6ef;
  border-radius: clamp(0.3125rem, 0.2366504854rem + 0.3236245955vw, 0.625rem);
  width: 100%;
  margin-bottom: clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem);
  cursor: pointer;
  color: #1a1a1a;
}
.company_page .company_history .accordion_item .accordion_header .header_cont {
  display: flex;
  text-align: left;
  margin-bottom: 0;
  column-gap: clamp(1.25rem, 0.5673543689rem + 2.9126213592vw, 4.0625rem);
  display: flex;
  align-items: center;
  font-weight: 700;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .company_page .company_history .accordion_item .accordion_header .header_cont {
    flex-wrap: wrap;
  }
}
.company_page .company_history .accordion_item .accordion_header .arrow {
  width: 4px;
  border-radius: 2px;
  height: 19px;
  background: #e56913;
  position: relative;
  display: inline-block;
  margin-left: auto;
  vertical-align: middle;
  transition: transform 0.3s;
  flex-shrink: 0;
}
.company_page .company_history .accordion_item .accordion_header .arrow::before, .company_page .company_history .accordion_item .accordion_header .arrow::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 10px;
  height: 4px;
  background: #e56913;
  transform-origin: left center;
  border-radius: 2px;
}
.company_page .company_history .accordion_item .accordion_header .arrow::before {
  transform: rotate(-45deg);
}
.company_page .company_history .accordion_item .accordion_header .arrow::after {
  left: auto;
  right: 50%;
  transform-origin: right center;
  transform: rotate(45deg);
}
.company_page .company_history .accordion_item .accordion_header .header_year {
  font-size: clamp(1rem, 0.7572815534rem + 1.0355987055vw, 2rem);
  color: #e56913;
  font-weight: 700;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  display: inline-flex;
  align-items: center;
  line-height: 1;
}
.company_page .company_history .accordion_item .accordion_header .header_year::after {
  content: "";
  display: block;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(0.625rem, 0.5036407767rem + 0.5177993528vw, 1.125rem);
  height: clamp(0.0625rem, 0.0473300971rem + 0.0647249191vw, 0.125rem);
  background: #e56913;
  margin-left: 0.27em;
}
.company_page .company_history .accordion_item.active .arrow {
  transform: rotate(-180deg);
}
.company_page .company_history .accordion_item .accordion_body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.company_page .company_history .accordion_item .accordion_body .timeline {
  position: relative;
  margin: 0;
  padding: 0 0 clamp(1.875rem, 1.5716019417rem + 1.2944983819vw, 3.125rem) clamp(0rem, -0.4854368932rem + 2.071197411vw, 2rem);
  list-style: none;
}
.company_page .company_history .accordion_item .accordion_body .timeline li {
  position: relative;
  padding: clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem) 0 clamp(0.9375rem, 0.8616504854rem + 0.3236245955vw, 1.25rem) clamp(0rem, -0.1516990291rem + 0.6472491909vw, 0.625rem);
  min-height: 2.5rem;
  display: flex;
  overflow: hidden;
}
.company_page .company_history .accordion_item .accordion_body .timeline li:first-child {
  padding-top: 0;
}
.company_page .company_history .accordion_item .accordion_body .timeline li:last-child {
  padding-bottom: clamp(3.75rem, 2.8398058252rem + 3.8834951456vw, 7.5rem);
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-year {
  font-size: clamp(1rem, 0.8786407767rem + 0.5177993528vw, 1.5rem);
  font-weight: 700;
  font-family: "Montserrat", "Zen Kaku Gothic New", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Lucida Grande", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  min-width: 2.8em;
  display: inline-block;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-year.hidden-year {
  visibility: hidden;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-date {
  font-weight: bold;
  margin-right: 1rem;
  color: #333;
  display: flex;
  align-items: stretch;
  gap: calc(clamp(0.3125rem, -0.3398058252rem + 2.783171521vw, 3rem) - 0.5rem);
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  align-self: stretch;
  width: 1rem;
  height: 100%;
  margin: 0 0.5rem;
  position: relative;
  z-index: 1;
  overflow: visible;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot .timeline-dot-inner {
  width: 1rem;
  height: 1rem;
  background: #e56913;
  border: 3px solid #e56913;
  border-radius: 50%;
  z-index: 2;
  position: relative;
  margin-top: clamp(0.375rem, 0.2991504854rem + 0.3236245955vw, 0.6875rem);
  margin-bottom: auto;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot::before, .company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 2px;
  background: #e56913;
  transform: translateX(-50%);
  z-index: 0;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot:not(:first-child):not(:last-child)::before {
  top: -9999px;
  height: calc(50% + 9999px);
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot:not(:first-child):not(:last-child)::after {
  top: clamp(0.5rem, 0.4544902913rem + 0.1941747573vw, 0.6875rem);
  height: 9999px;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot:first-child::after {
  top: 50%;
  height: 9999px;
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-dot:last-child::before {
  top: -9999px;
  height: calc(50% + 9999px);
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap {
  display: flex;
  column-gap: clamp(1.25rem, 0.5370145631rem + 3.0420711974vw, 4.1875rem);
  row-gap: clamp(0.125rem, 0.0036407767rem + 0.5177993528vw, 0.625rem);
  margin-bottom: 0;
  font-size: clamp(0.875rem, 0.8143203883rem + 0.2588996764vw, 1.125rem);
  margin-left: clamp(0rem, -0.2730582524rem + 1.1650485437vw, 1.125rem);
}
@media screen and (max-width: 768px) {
  .company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap {
    flex-wrap: wrap;
    margin-top: 0.1rem;
  }
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap .timeline-month {
  white-space: nowrap;
  font-weight: 900;
  width: 2rem;
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap .timeline-month {
    width: auto;
  }
}
.company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap .timeline-content {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .company_page .company_history .accordion_item .accordion_body .timeline li .timeline-cont-wrap .timeline-content {
    flex-basis: 100%;
  }
}/*# sourceMappingURL=style.css.map */