/*! Writen  by SCSS */
h1 {
  margin-bottom: 0; }

.p-summary {
  padding-bottom: 30px; }

.contents_wrap {
  position: relative; }
  .contents_wrap .anq {
    position: absolute;
    top: -110px; }
    @media screen and (max-width: 767px) {
      .contents_wrap .anq {
        top: -60px; } }
  .contents_wrap .main {
    position: relative; }
    .contents_wrap .main .copy {
      position: absolute;
      inset: 0;
      width: 100%;
      display: flex;
      justify-content: center;
      align-items: center; }
      .contents_wrap .main .copy .t1 {
        font-size: clamp(20px, calc(44vw / 16), 44px);
        font-weight: 400;
        letter-spacing: 0.15em;
        line-height: 1;
        color: #fff;
        text-shadow: 0 0 4px rgba(0, 0, 0, 0.8), 2px 2px 4px rgba(0, 0, 0, 0.8), -2px 2px 4px rgba(0, 0, 0, 0.8), -2px -2px 4px rgba(0, 0, 0, 0.8), 2px -2px 4px rgba(0, 0, 0, 0.8); }
        @media screen and (max-width: 480px) {
          .contents_wrap .main .copy .t1 {
            font-size: calc(28vw / 3.9); } }
  .contents_wrap .breadlist_wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 50; }
  .contents_wrap .container {
    max-width: 100%;
    padding: 60px 0;
    margin: 0 auto; }
    @media screen and (max-width: 767px) {
      .contents_wrap .container {
        padding: 40px 0; } }
  .contents_wrap .inner {
    width: calc(100% - 40px);
    max-width: 1120px;
    margin: 0 auto; }
  .contents_wrap .inner_1200 {
    max-width: 1200px; }
  .contents_wrap .scr {
    text-align: center; }
    .contents_wrap .scr a {
      display: inline-block;
      text-align: center;
      animation: scr 1s both infinite alternate; }
      @media screen and (max-width: 767px) {
        .contents_wrap .scr a {
          width: 46px; } }
@keyframes scr {
  0% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0); }
  100% {
    -webkit-transform: translate3d(0, 4px, 0);
    transform: translate3d(0, 4px, 0); } }
  .contents_wrap .ttl {
    font-size: clamp(19px, calc(38vw / 11.8), 38px);
    font-feature-settings: "palt";
    letter-spacing: 0.15em;
    color: #333;
    font-weight: 500; }
    @media screen and (max-width: 767px) {
      .contents_wrap .ttl {
        letter-spacing: 0.1em; } }
  .contents_wrap .p_ttl {
    color: #b28247;
    font-size: clamp(19px, calc(44vw / 11.8), 44px);
    letter-spacing: 0.15em;
    font-weight: 300;
    line-height: 1.2;
    margin-bottom: 1em; }
    @media screen and (max-width: 480px) {
      .contents_wrap .p_ttl {
        font-size: calc(20vw / 3.9); } }
  .contents_wrap .cttl {
    font-size: clamp(15px, calc(28vw / 11.8), 28px);
    font-feature-settings: "palt";
    letter-spacing: 0.15em;
    line-height: 1.6;
    color: #333;
    font-weight: 500; }
    .contents_wrap .cttl .c {
      color: #938059; }
    .contents_wrap .cttl.c2 {
      color: #cabb89; }
    .contents_wrap .cttl.c {
      color: #938059; }
    .contents_wrap .cttl.ls {
      letter-spacing: 0.05em; }
    @media screen and (max-width: 767px) {
      .contents_wrap .cttl {
        letter-spacing: 0.05em; } }
    @media screen and (max-width: 480px) {
      .contents_wrap .cttl {
        font-size: calc(18vw / 3.9); } }
  .contents_wrap .read {
    font-size: clamp(13px, calc(18vw / 11.8), 18px);
    font-weight: 500;
    font-feature-settings: "palt";
    letter-spacing: 0.15em;
    line-height: 2.2; }
    @media screen and (max-width: 767px) {
      .contents_wrap .read {
        letter-spacing: 0.05em; } }
    @media screen and (max-width: 480px) {
      .contents_wrap .read {
        font-size: calc(13vw / 3.9);
        line-height: 1.8;
        font-weight: bold; } }
  .contents_wrap .sec_ttl_en {
    font-size: clamp(18px, calc(24vw / 11.8), 24px);
    letter-spacing: 0.15em;
    line-height: 1;
    color: #c9a063;
    font-weight: 500;
    margin-bottom: 0.6em; }
    @media screen and (max-width: 480px) {
      .contents_wrap .sec_ttl_en {
        font-size: calc(17vw / 3.9); } }
  .contents_wrap .sec_ttl_ja {
    font-size: clamp(15px, calc(28vw / 11.8), 28px);
    font-feature-settings: "palt";
    letter-spacing: 0.15em;
    line-height: 1.6;
    color: #333;
    font-weight: 500; }
    @media screen and (max-width: 767px) {
      .contents_wrap .sec_ttl_ja {
        letter-spacing: 0.05em; } }
    @media screen and (max-width: 480px) {
      .contents_wrap .sec_ttl_ja {
        font-size: calc(17vw / 3.9);
        letter-spacing: 0.01em; } }
  .contents_wrap .lead {
    font-weight: 500;
    letter-spacing: 0.1em;
    font-size: clamp(16px, calc(22vw / 11.8), 22px); }
    @media screen and (max-width: 480px) {
      .contents_wrap .lead {
        font-weight: bold; } }
  .contents_wrap .text {
    font-size: clamp(12px, calc(16vw / 11.8), 16px);
    font-weight: 500;
    font-feature-settings: "palt";
    letter-spacing: 0.1em;
    line-height: 2; }
    @media screen and (max-width: 767px) {
      .contents_wrap .text {
        letter-spacing: 0.03em; } }
    @media screen and (max-width: 480px) {
      .contents_wrap .text {
        font-size: calc(13vw / 3.9); } }
  .contents_wrap .text2 {
    font-size: clamp(12px, calc(14vw / 11.8), 14px);
    font-weight: 400;
    font-feature-settings: "palt";
    letter-spacing: 0.08em;
    line-height: 2; }
    @media screen and (max-width: 767px) {
      .contents_wrap .text2 {
        letter-spacing: 0.04em; } }
  @media screen and (max-width: 767px) {
    .contents_wrap .sp_w {
      margin: 0 -20px;
      width: calc(100% + 40px); } }
  .contents_wrap .w_img {
    width: 100%; }
  .contents_wrap .sec0 {
    padding: 70px 0; }
    @media screen and (max-width: 480px) {
      .contents_wrap .sec0 {
        padding: 40px 0; } }
    .contents_wrap .sec0 .ttl {
      margin-bottom: 0.5em;
      font-weight: 500;
      color: #333; }
      @media screen and (max-width: 767px) {
        .contents_wrap .sec0 .ttl {
          margin-bottom: 10px;
          font-weight: 700;
          text-shadow: 0px 0px 0px rgba(255, 255, 255, 0.9), 0px 0px 1px rgba(255, 255, 255, 0.9), 0px 0px 2px rgba(255, 255, 255, 0.9), 0px 0px 3px rgba(255, 255, 255, 0.9), 0px 0px 4px rgba(255, 255, 255, 0.9), 0px 0px 5px rgba(255, 255, 255, 0.9), 0px 0px 6px rgba(255, 255, 255, 0.9); } }
    .contents_wrap .sec0 .read {
      color: #333;
      line-height: 2.5;
      font-weight: 500; }
      @media screen and (max-width: 767px) {
        .contents_wrap .sec0 .read {
          font-weight: 500; } }

.sec_main {
  position: relative; }
  .sec_main::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: rgba(44, 38, 36, 0.78); }
  .sec_main .ttl {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #b28247;
    font-size: clamp(20px, calc(44vw / 11.8), 44px);
    z-index: 1; }
  .sec_main .t_cap {
    z-index: 1; }

.sec_ttl {
  font-size: clamp(20px, calc(36vw / 11.8), 36px);
  font-size: clamp(20px, calc(30vw / 11.8), 30px);
  font-size: clamp(18px, calc(27vw / 11.8), 27px);
  letter-spacing: 0.15em;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 0.6em; }
  @media screen and (max-width: 480px) {
    .sec_ttl {
      letter-spacing: 0.1em;
      font-size: calc(18vw / 3.9);
      line-height: 1.8; } }
  .sec_ttl .sup_box {
    display: inline-block;
    position: relative; }
    .sec_ttl .sup_box sup {
      position: absolute;
      right: 0;
      top: 0.05em; }
      @media screen and (max-width: 480px) {
        .sec_ttl .sup_box sup {
          top: 0.2em; } }

.sec_lead {
  font-size: clamp(12px, calc(198vw / 11.8), 19px);
  letter-spacing: 0.15em;
  line-height: 2.8;
  line-height: 2;
  font-weight: 600; }
  @media screen and (max-width: 480px) {
    .sec_lead {
      letter-spacing: 0.1em;
      font-size: calc(14vw / 3.9);
      line-height: 1.8; } }
  .sec_lead .sup_box {
    display: inline-block;
    position: relative; }
    .sec_lead .sup_box sup {
      position: absolute;
      right: 0;
      top: 1.8em; }
      @media screen and (max-width: 480px) {
        .sec_lead .sup_box sup {
          top: 1.2em; } }

.contents_wrap .sec0 {
  background: #fff;
  margin-bottom: 70px;
  padding: 90px 0; }
  @media screen and (max-width: 480px) {
    .contents_wrap .sec0 {
      padding: 40px 0; } }
  .contents_wrap .sec0 .sec_ttl {
    margin-bottom: 0.6em; }
  .contents_wrap .sec0 .sec_lead {
    line-height: 2.8; }
    @media screen and (max-width: 480px) {
      .contents_wrap .sec0 .sec_lead {
        line-height: 2.2; } }

#design .contents_wrap,
#quality .contents_wrap {
  position: relative;
  clip-path: polygon(0 0, 100% 0%, 100% 100%, 0% 100%); }
  #design .contents_wrap::before,
  #quality .contents_wrap::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    background-image: url("../images/quality/bg.jpg");
    background-repeat: no-repeat; }

.ttl_wrap {
  position: relative;
  letter-spacing: 0.2em;
  font-weight: bold;
  margin-bottom: clamp(30px, calc(50vw / 11.8), 50px); }
  .ttl_wrap .txt01 {
    font-size: clamp(16px, calc(24vw / 11.8), 24px);
    margin-bottom: 40px;
    padding-bottom: 10px;
    border-bottom: 1px solid;
    line-height: 1;
    max-width: 170px;
    margin-inline: auto; }
    @media screen and (max-width: 480px) {
      .ttl_wrap .txt01 {
        margin-bottom: 20px;
        font-weight: bold; } }
    .ttl_wrap .txt01.en_txt {
      font-weight: 400;
      color: #b28247;
      max-width: 100%;
      width: fit-content;
      margin-inline: auto;
      position: relative;
      border: none; }
      @media screen and (max-width: 480px) {
        .ttl_wrap .txt01.en_txt {
          font-weight: bold; } }
      .ttl_wrap .txt01.en_txt::after {
        content: '';
        position: absolute;
        inset: 0;
        height: 1px;
        top: auto;
        background: #b28247;
        width: 90%;
        margin-inline: auto;
        text-align: center;
        margin-inline: auto; }
  @media screen and (max-width: 480px) {
    .ttl_wrap .sec_ttl {
      font-weight: bold; } }

.flex {
  display: flex;
  justify-content: space-between; }

.ls05_n {
  letter-spacing: 0.05em !important; }

.btn_lm a {
  font-size: clamp(12px, calc(19vw / 11.8), 19px);
  line-height: 1;
  display: block;
  background: #363531;
  text-align: center !important;
  padding: 0.6em;
  transition: all 0.3s ease-in-out 0s;
  text-decoration: none; }
  .btn_lm a:hover {
    background: #774f24; }
  .btn_lm a p {
    display: flex;
    justify-content: center;
    gap: 1.2em;
    margin-bottom: 0.6em; }
    @media screen and (max-width: 480px) {
      .btn_lm a p {
        flex-direction: column;
        gap: 0.8em;
        margin-bottom: 0.9em; } }
    .btn_lm a p .en {
      font-size: 150%;
      color: #c9a063;
      text-decoration: none; }
    .btn_lm a p .ja {
      color: #fff;
      font-size: 150%; }
  .btn_lm a img {
    width: 10em; }

/*# sourceMappingURL=inner.css.map */
