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,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-family: inherit;
  font-size: 100%;
  vertical-align: baseline;
}
body {
  line-height: 1;
  color: #000;
  background: #fff;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: separate;
  border-spacing: 0;
  vertical-align: middle;
}
caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
a img {
  border: none;
}
img {
  width: 100%;
  display: block;
  vertical-align: bottom;
}
body {
  font-size: 16px;
  font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', YuGothic, '游ゴシック', Meirio, "メイリオ", sans-serif;
}
p,
a,
ul,
li,
dl,
dt,
dd {
  margin: 0;
}
a {
  transition: opacity 0.3s;
  display: block;
  text-decoration: none;
}
figure {
  margin: 0;
}
html {
  font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', YuGothic, '游ゴシック', Meirio, "メイリオ", sans-serif;
}
.mt0 {
  margin-top: 0 !important;
}
.x-hide {
  display: none !important;
}
.conceptshops-content {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #333;
}
.conceptshops-wrap {
  max-width: 1000px;
  margin: 0 auto;
}
.conceptshops-mv {
  position: relative;
}
.conceptshops-mv h1 {
  background: linear-gradient(to bottom, rgba(137,98,74,0) 32%, #89624a 71%, #734c35 100%);
  display: grid;
  width: 100%;
  height: 3.5em;
  text-align: center;
  font-size: min(calc(30.2 / 375 * min(1440px, 100vw)), calc(90 / 16 * 1em));
  position: absolute;
  left: 0;
  bottom: 0;
}
.conceptshops-mv h1 ruby {
  display: flex;
  flex-direction: column-reverse;
  gap: calc(8.6 / 90 * 1em);
  padding: 0 0 0.06em;
  white-space: nowrap;
  font-family: "Libre Baskerville", serif;
  font-size: 1em;
  letter-spacing: -0.0175em;
  line-height: 1;
  color: #f6f2e3;
}
.conceptshops-mv h1 ruby rt {
  text-align: inherit;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: max(calc(20 / 90 * 1em), calc(12 / 16 * 1rem));
  line-height: 1;
  letter-spacing: 0.03em;
}
.conceptshops-mv .conceptshops-mv-bg {
  width: 100%;
}
.conceptshops-mv .conceptshops-mv-bg img {
  width: 100%;
}
.conceptshops-lead {
  background: #f6f2e3;
  padding: 50px 25px;
  text-align: center;
  word-break: keep-all;
  overflow-wrap: anywhere;
  font-family: "Sawarabi Mincho", serif;
  font-size: calc(20 / 16 * 1em);
  line-height: 2.5;
}
.conceptshops-shops {
  background: #e9e5d7;
  padding: 100px 0 200px;
}
.conceptshops-shops .conceptshops-wrap {
  display: grid;
  gap: 130px;
}
.conceptshops-shops .conceptshops-shops-shop h2 {
  display: grid;
  grid-template-columns: minmax(calc(45 / 375 * 100vw), 1fr) auto minmax(calc(45 / 375 * 100vw), 1fr);
  align-items: center;
  gap: clamp(5px, 20px, calc(20 / 1000 * 100vw));
  text-align: center;
  -webkit-text-stroke: 0.8px;
  word-break: keep-all;
  overflow-wrap: anywhere;
  font-family: "Sawarabi Mincho", serif;
  font-size: clamp(22px, calc(22 / 375 * 100vw), 32px);
  line-height: 1.4;
  letter-spacing: 4%;
  white-space: nowrap;
}
.conceptshops-shops .conceptshops-shops-shop h2 wbr {
  display: contents;
}
.conceptshops-shops .conceptshops-shops-shop h2::before {
  content: "";
  display: block;
  height: 9px;
  border-image: linear-gradient(to right, rgba(139,96,61,0.302) 50%, rgba(139,96,61,0) 100%) 1;
  border-image-width: 2px 0;
}
.conceptshops-shops .conceptshops-shops-shop h2::after {
  content: "";
  display: block;
  height: 9px;
  border-image: linear-gradient(to left, rgba(139,96,61,0.302) 50%, rgba(139,96,61,0) 100%) 1;
  border-image-width: 2px 0;
}
.conceptshops-shops .conceptshops-shops-shop h2 img {
  max-height: clamp(40px, calc(40 / 375 * 100vw), none);
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-columns: repeat(auto-fill, minmax(min(calc((1000px - 25px) / 2), 100%), 1fr));
  align-items: center;
  gap: 25px;
  margin: 50px 0 0;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept p {
  font-weight: 500;
  font-size: calc(18 / 16 * 1em);
  line-height: 2.5;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept .link {
  margin: calc(10 / 16 * 1em) 0 0;
  text-align: right;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept a {
  display: inline-flex;
  align-items: center;
  gap: calc(5 / 16 * 1em);
  margin: 0 0 0 auto;
  font-weight: 500;
  color: #8b603d;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept a svg {
  width: 1em;
  height: 1em;
  font-size: calc(20 / 16 * 1em);
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(calc((1000px - 40px) / 3), 100%), 1fr));
  gap: 20px;
  margin: 20px 0 0;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features .conceptshops-shops-shop-features-feature {
  display: grid;
  gap: calc(5 / 16 * 1em);
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features .conceptshops-shops-shop-features-feature::before {
  content: "";
  background: linear-gradient(to right, rgba(139,96,61,0.302) 50%, rgba(139,96,61,0) 100%);
  display: block;
  height: 2px;
  order: 1;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features .conceptshops-shops-shop-features-feature h3 {
  font-weight: 500;
  font-size: calc(18 / 16 * 1em);
  line-height: 1.7;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features .conceptshops-shops-shop-features-feature h3 ~ * {
  order: 1;
}
.conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features .conceptshops-shops-shop-features-feature p {
  font-size: calc(14 / 16 * 1em);
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .pcOnly {
    display: none;
  }
  .spOnly {
    display: block;
  }
  .conceptshops-lead {
    font-size: 1em;
  }
  .conceptshops-shops {
    padding: 50px 0 100px;
  }
  .conceptshops-shops .conceptshops-wrap {
    gap: 80px;
  }
  .conceptshops-shops .conceptshops-shops-shop h2 {
    white-space: normal;
  }
  .conceptshops-shops .conceptshops-shops-shop h2 wbr {
    display: unset;
  }
}
@media print, screen and (min-width: 768px) {
  .pcOnly {
    display: block;
  }
  .spOnly {
    display: none;
  }
  a:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 1000px) {
  .conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept {
    margin: 30px 25px 0;
  }
  .conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-concept figure {
    margin: 0 -25px;
  }
  .conceptshops-shops .conceptshops-shops-shop .conceptshops-shops-shop-features {
    margin: 30px 25px 0;
    gap: 30px;
  }
}
