@charset "UTF-8";
@import url(//use.fontawesome.com/releases/v5.12.0/css/all.css);
* {
   box-sizing: border-box;
   margin: 0;
   padding: 0;
}
.pc {
   display: block;
}
.tablet {
   display: none;
}
.sp {
   display: none;
}
img {
   max-width: 100%;
   height: auto;
   vertical-align: bottom;
}
a {
   text-decoration: none;
   color: inherit;
   -webkit-transition: all 0.5s ease;
   -moz-transition: all 0.5s ease;
   -o-transition: all 0.5s ease;
   transition: opacity 0.5s ease;
}
a:hover {
   opacity: 0.8;
}
html {
   font-size: 62.5%;
   height: 100%;
}
h1, h2, h3, h4, h5 {
   line-height: 1em;
}
body {
   color: #4d4d4d;
   height: 100%;
   font-weight: 500;
   font-size: 1.6rem;
   font-size: clamp(1.4rem, 1.351rem + 0.129vw, 1.6rem);
   font-feature-settings: "palt";
   line-height: 1.75;
   letter-spacing: 0.1em;
   font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "Helvetica Neue", HelveticaNeue, Helvetica, Arial, "Segoe UI", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}
.container {
   margin: 0 auto;
   max-width: 1280px;
   padding: 0 20px;
}
.flex {
   display: flex;
}
.os {
   font-family: 'Oswald', sans-serif;
   font-weight: 500;
}
.red {
   color: #e60012;
}
.wh {
   color: #fff;
}
.bg-w {
   background-color: #fff;
}
.bg-r {
   background-color: #e60012;
}
.bg-g {
   background-color: #f2f2f2;
}
.center {
   margin: 0 auto;
   text-align: center;
}
.wrapper {
   width: 1280px;
   padding: 0 2rem;
   margin: 0 auto;
   position: relative;
}
.basic-pd {
   padding: 18rem 0;
   padding: clamp(6.5rem, 3.709rem + 7.443vw, 18rem) 0;
}
.flex-e {
   display: flex;
   justify-content: flex-end;
}
main {
   display: block;
   background-color: #f2f2f2;
   overflow: hidden;
}
li {
   list-style: none;
}
address {
   font-style: normal;
}
.linkBT {
   position: relative;
   padding-left: 4rem;
}
.linkBT::before {
   content: "";
   position: absolute;
   top: 56%;
   transform: translateY(-50%);
   left: -1rem;
   background: url("../img/maru-w.webp")no-repeat center center/contain;
   width: 3.2rem;
   height: 3.2rem;
}
/* ====================================================================
-------------------------------
==================================================================== */
.half {
   width: calc((100% - 8rem) / 2);
}
.ttl-01 {
   writing-mode: vertical-rl;
   margin-bottom: 9rem;
}
.ttl-01 h2 {
   letter-spacing: 0.05em;
   margin-right: 3.5rem;
   font-size: clamp(3.5rem, 2.408rem + 2.913vw, 8rem);
}
.ttl-01 p {
   display: flex;
   align-items: center;
   font-size: clamp(1.4rem, 1.351rem + 0.129vw, 1.6rem);
}
.ttl-01 p img {
   margin-top: 2rem;
}
.under .ttl-01 h2 {
   font-size: 5rem;
   margin-right: 2rem;
}
.ttl-02 {
   position: relative;
}
.ttl-02 h2 {
   padding-top: 3.5rem;
   margin-bottom: 1rem;
   font-size: 5rem;
   font-size: clamp(2.8rem, 2.266rem + 1.424vw, 5rem);
}
.ttl-02 h2 + p {
   font-size: clamp(1.4rem, 1.351rem + 0.129vw, 1.6rem);
}
.ttl-02::before {
   content: "";
   position: absolute;
   top: 0;
   left: 0;
   width: 8rem;
   height: 2rem;
}
.ttl-02.center::before {
   left: 50%;
   transform: translateX(-50%);
}
.ttl-02.red::before {
   background: url("../img/yoko-r.webp")no-repeat center center/contain;
}
.ttl-02.wh::before {
   background: url("../img/yoko-w.webp")no-repeat center center/contain;
}
.ttl-02.gr::before {
   background: url("../img/yoko-g.webp")no-repeat center center/contain;
}
.ttl-03 {
   margin-bottom: 3rem;
}
.ttl-03 p {
   display: flex;
   align-items: center;
   font-size: 1.4rem;
}
.ttl-03 p img {
   margin-left: 1rem;
}
.ttl-03 h3 {
   letter-spacing: 0.05em;
   font-size: clamp(2.8rem, 2.63rem + 0.453vw, 3.5rem);
}
/* ====================================================================
-------------------------------
==================================================================== */
.contents2Wrap.over, .contents2Wrap.over2 {
   align-items: center;
   width: 99.1vw;
}
.contents2Wrap.over .flexL, .contents2Wrap.over2 .flexL {
   width: 82rem;
   margin-right: 0;
}
/*.contents2Wrap.over .flexR {
  position: relative;
  left: -12.5rem;
  z-index: 1;
  width: calc(100% - 82rem);
}*/
.contents2Wrap.over .flexR img, .contents2Wrap.over2 .flexR img {
   max-width: calc(50% + 50vw);
}
.contents2Wrap.over2 {
   flex-direction: row-reverse;
}
.contents2Wrap.over2 .flexL {
   display: flex;
}
.contents2Wrap.over2 .flexR {
   position: relative;
   left: 0.5rem;
   z-index: 1;
   width: 34%;
}
.contents2Wrap.type2 .flexL {
   position: relative;
   width: 65.3%;
}
.contents2Wrap.type2 .flexR {
   width: 30.7%;
   margin-right: 5rem;
}
.contents2Wrap.type3 .flexL {
   width: 30.7%;
   margin-right: 5rem;
}
.contents2Wrap.type3 .flexR {
   position: relative;
   width: 65.3%;
}
/* ====================================================================
-------------------------------
==================================================================== */
.under-mv .flex {
   align-items: center;
}
.under-mv .img-ab {
   position: relative;
   right: -20.9vw;
}
/* ====================================================================
-------------------------------drawer
==================================================================== */
.drawer--right .drawer-nav {
   width: 100%;
   right: -100%;
   z-index: 500;
   margin-top: 0;
   background-color: #fff;
   padding: 55px 6%;
   /*  background: rgba(255, 255, 255, 0.8);
  padding: 80px 6%;*/
}
/*drawer*/
.drawer--top.drawer-open .drawer-nav {
   top: 0;
   overflow: auto;
   -webkit-overflow-scrolling: touch;
}
.drawer--right.drawer-open .drawer-nav {
   right: 0;
   overflow: auto;
   -webkit-overflow-scrolling: touch;
}
.drawer--right .drawer-hamburger, .drawer--right.drawer-open .drawer-hamburger {
   top: 0;
   right: 0;
   z-index: 8888;
   padding: 0 3%;
   height: 6rem;
}
.drawer-hamburger, .drawer-hamburger:hover {
   width: 3.2rem;
   height: 6rem;
   background: #e60012;
}
.drawer--right.drawer-open .drawer-nav {
   /*    top: 0;
    left: 0;
    z-index: 150;
    height: 100vh;*/
   padding: 0;
}
.drawer-nav .logo {
   display: flex;
   align-items: center;
   height: 6rem;
}
.drawer-nav ul {
   padding: 2rem 6% 0;
}
.drawer-hamburger-icon, .drawer-hamburger-icon::after, .drawer-hamburger-icon::before {
   background: #fff;
}
.drawer-hamburger-icon {
   top: -5px;
}
.drawer-hamburger-icon::after {
   top: -10px;
}
.drawer-hamburger-icon::before {
   top: 10px;
}
.drawer--right .drawer-nav ul li {
   position: relative;
   padding: 0;
   margin-right: 0;
   margin-bottom: 1rem;
}
.drawer--right .drawer-nav ul li.ac::after {
   position: absolute;
   top: 50%;
   right: 10px;
   display: inline-block;
   width: 30px;
   height: 4px;
   content: "";
   background: url("../images/common/hdr-arrow-right.webp") no-repeat center center;
   background-size: cover;
   transform: translateY(-50%);
}
.drawer--right .drawer-nav ul li a {
   padding: 0;
   font-size: 1.6rem;
   color: #4d4d4d;
   ;
   text-align: center;
}
.drawer--right .drawer-nav ul li a span {
   display: none;
}
.drawer--right .drawer-nav ul + .flex {
   flex-direction: row;
   margin: 15px 0;
}
.drawer--right .drawer-nav p.icon {
   width: 43px;
   margin-right: 25px;
}
.drawer--right .drawer-nav .company-info {
   width: calc(100% - 78px);
}
.drawer--right .drawer-nav address {
   font-size: 1.2rem;
   line-height: 1.4;
}
.drawer--right .drawer-nav p.tel {
   font-size: 2.6rem;
   letter-spacing: 0.15rem;
}
.drawer--right .drawer-nav p.tel img {
   position: relative;
   top: -8px;
   width: 14px;
   height: 27px;
   margin-right: 10px;
}
.drawer--right .drawer-nav ul.sub {
   display: none;
   width: 100%;
   padding: 0 20px;
   margin: 10px auto 0;
   overflow: hidden;
   background: #fff;
}
.drawer--right .drawer-nav ul.sub a {
   font-size: 1.4rem;
}
/* 開閉メニュー */
.drawer--right .drawer-nav ul li + ul.sub li {
   border-bottom: solid 1px #674201;
}
.drawer--right .drawer-nav ul li + ul.sub li:last-child {
   border: none;
}
.drawer--right .drawer-nav ul.main li.ac a {
   position: relative;
   text-decoration: none;
   opacity: 1;
}
.drawer--right .drawer-nav ul.sub.is-open {
   display: block;
}
small {
   background-color: #e60012;
   display: block;
   text-align: center;
   padding: 2rem 0;
   letter-spacing: 0.2em;
   font-size: 1.4rem;
}
.drawer--right .drawer-nav ul li a {
   font-size: 2rem;
   letter-spacing: 0.1em;
   border-bottom: 1px solid #e60012;
   padding: 1rem;
   display: block;
   text-align: left;
   margin-right: 0;
}
/* ====================================================================
-------------------------------pprivacy-policy
==================================================================== */
.privacy_title {
  /*font-size:1.2em;*/
  font-weight: bold;
  margin-bottom: 5px;
  font-size: clamp(1.8rem, 2.2vw, 2.5rem);
}
.privacy dl {
  margin-bottom: 30px;
}
.privacy_text {
  padding-left: 1em;
  /*	font-size:0.875em;*/
}
.privacy_text_small {
  padding-left: 1.5em;
  /*		font-size:0.875em;*/
}
.text_small_title {
  margin-bottom: 5px;
}
.privacy_companyname {
  display: block;
  /*	font-size:1.2em;*/
  margin: 20px 0 5px;
}
.privacy p {
  margin-top: 2rem;
}
.privacy_page_title {
  /*		font-size:1.62em;*/
  font-weight: bold;
  margin-bottom: 40px;
  font-size: clamp(2.5rem, 3.75vw, 4rem);
  margin-top: 4.5rem;
}