@charset "UTF-8";

*, *::before, *::after {
  box-sizing: border-box;
}

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, main, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  /* background: transparent; */
  border: 0;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}

main, article, aside, details, figcaption, figure, img, video, footer, header, hgroup, menu, nav, section {
  display: block;
}

ul, ol, li {
  list-style: none;
}

a {
  color: inherit;
  margin: 0;
  padding: 0;
  text-decoration: none;
  transition: opacity .5s ease;
}

a:hover {
  opacity: .6;
}

a:link img, a:visited img, a:hover img, a img {
  border: none;
  text-decoration: none;
}

sup {
  font-size: 12px;
  line-height: 1;
  vertical-align: top;
}

sup.sup--heading {
  font-size: clamp(14px, calc(1.1538vw + 10.3077px), 23px);
}

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

video, img {
  height: auto;
  max-width: 100%;
}

body {
  background: #fff;
  color: #000;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 18px;
  line-height: 1.7;
}

:root {
  --background-color: #f7efe2;
  --main-color: #801c21;
  --margin-center: 0 auto;
}

.sns-wrap {
  left: 20px;
  position: absolute;
  top: 5px;
}

.social_buttons {
  list-style-type: none;
  margin: 0;
  padding: 0;
  text-align: left;
}

.social_buttons:before, .social_buttons:after {
  clear: both;
  content: "";
  display: table;
}

.social_buttons li {
  float: left;
  font-size: 12px;
  margin-left: 0;
  margin-right: 10px;
}

.social_buttons li:last-child {
  margin-right: 0;
}

.social_buttons li .fb_iframe_widget > span {
  vertical-align: baseline;
}

.wrapper .main {
  position: relative;
}

.wrapper .main:after {
  background: url("../image/back.png") repeat center top / contain;
  content: "";
  display: block;
  height: 100vh;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: -1;
}

.wrapper .main .article {
  background-color: #fff;
  border-left: 5px solid var(--main-color);
  border-right: 5px solid var(--main-color);
  margin: var(--margin-center);
  overflow: hidden;
  padding-bottom: clamp(27px, calc(9.302vw + 10.233px), 45px);
  width: min(1010px, 95%);
}

.wrapper .main .article .article__header {
  position: relative;
}

.wrapper .main .article .article__header .main-visual {
  margin: 0 0 0 auto;
}

.wrapper .main .article .article__body .section {
  margin: var(--margin-center);
  width: min(800px, 90%);
}

.wrapper .main .article .article__body .section h1 {
  font-size: clamp(27px, calc(1.026vw + 23.717px), 35px);
  line-height: 1.4;
  margin-top: 15px;
  position: relative;
}

.wrapper .main .article .article__body .section h1 span {
  display: block;
}

.wrapper .main .article .article__body .customer-satisfaction {
  margin: 15px 0 22px;
  padding-right: 30px;
  position: relative;
}

.wrapper .main .article .article__body .section .text {
  font-size: clamp(16px, calc(.465vw + 14.512px), 18px);
  margin-bottom: 30px;
  text-indent: 1em;
}

.wrapper .main .article .article__body .section .text.text--lead {
  margin-top: 40px;
  text-indent: 0;
}

.wrapper .main .article .article__body .section .section__header {
  background-color: #f7efe2;
  margin-bottom: 40px;
}

.wrapper .main .article .article__body .section .section__header h2 {
  color: var(--main-color);
  font-family: "Times New Roman", "Hiragino Mincho ProN", "Yu Mincho", serif;
  font-size: clamp(21px, calc(1.795vw + 15.256px), 35px);
  font-weight: bold;
  padding: 21px;
  text-align: center;
}

.wrapper .main .article .article__body .section .section__header h2 span {
  display: block;
  font-weight: bold;
  line-height: 1.2;
}

.wrapper .main .article .article__body .section .section__body .photo {
  max-width: 100%;
  width: 350px;
}

.wrapper .main .article .article__body .section .section__body .photo.photo--right {
  float: right;
  margin-bottom: 27px;
  margin-left: 27px;
}

.wrapper .main .article .article__body .section .section__body .photo .photo__caption {
  background-color: var(--main-color);
  color: #fff;
  padding: 15px;
  text-align: center;
}

.wrapper .main .article .article__body .section .section__body .illust.illust--margin-bottom {
  margin-bottom: 30px;
}

.wrapper .main .article .article__body .section .section__body .illust .illust__caption {
  font-size: 14px;
  margin-top: 10px;
}

.wrapper .main .article .article__body .section .section__body .photo2 {
  margin: var(--margin-center);
  width: min(600px, 90%);
}

.wrapper .main .article .article__body .section .section__body .photo .photo__caption p.name span, .wrapper .main .article .article__body .section .section__body .photo .photo__caption p {
  font-size: 15px;
}

.wrapper .main .article .article__body .section .section__body .photo .photo__caption p.name {
  font-size: 20px;
  margin-top: 30px;
}

.wrapper .main .article .article__body .section .section__body {
  margin-bottom: 60px;
}

.wrapper .main .article .article__body .section .section__body.section__body-margin-bottom0 {
  margin-bottom: 0;
}

.wrapper .main .article .article__body .section .section__body .text:last-child {
  margin-bottom: 0;
}

.wrapper .main .aside {
  background-color: #fff;
}

.wrapper .main .aside .aside__inner {
  margin: var(--margin-center);
  overflow: hidden;
  padding-bottom: 45px;
  width: min(800px, 80%);
}

.wrapper .main .aside .aside__inner .aside__header h2 {
  color: var(--main-color);
  font-size: 15px;
  margin-bottom: 30px;
}

.wrapper .main .aside .aside__inner .aside__header h2 span {
  position: relative;
}

.wrapper .main .aside .aside__inner .aside__header h2 span:after {
  background-color: var(--main-color);
  content: "";
  height: 1px;
  left: 113px;
  position: absolute;
  top: 10px;
  width: 100vw;
}

.wrapper .main .aside .aside__inner .aside__body p {
  font-size: clamp(18px, calc(.465vw + 16.512px), 20px);
}

.wrapper .main .aside .aside__inner .aside__body p.company {
  font-size: clamp(23px, calc(.465vw + 21.512px), 25px);
}

.wrapper .main .aside .aside__inner .aside__body p span {
  display: inline-block;
}

.wrapper .main .aside .aside__inner .aside__body p a {
  color: #00f;
  text-decoration: underline;
}

.wrapper .footer {
  background-color: #fff;
}

@media screen and (min-width: 768px) and (max-width: 900px) {
  .wrapper .main .article .article__body .section .section__body .photo {
    width: 43%;
  }
}

@media screen and (max-width: 767.9px) {
  .wrapper .main .article .article__body .section .section__body .photo {
    max-width: 300px;
    width: 90%;
  }

  .wrapper .main .article .article__body .section .section__body .photo.photo--right {
    float: none;
    margin-left: auto;
    margin-right: auto;
  }
}


@media screen and (max-width: 640px) {
  .sns-wrap {
    left: 0;
    margin: 0 auto;
    position: relative;
    width: 95%;
  }
}