@charset "UTF-8";
/* ルール
 ly-○○→レイヤー
 bl-〇〇→ブロックの囲み
 el-〇〇→最小単位のスタイル
 パーツのマージンはmargiin-topで取る
*/
html {
  font-size: 62.5%;
  font-family: "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  line-height: 2;
}

body {
  color: #222;
  /*firefox*/
  font-size: 1.6rem;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  /*Chrome,Safari*/
  -ms-text-size-adjust: 100%;
  /*EgdeMobile*/
  -moz-text-size-adjust: 100%;
}

main {
  position: relative;
}

ul li,
ol li {
  list-style-type: none;
  text-decoration: none;
}
ul li a,
ol li a {
  color: #000;
  text-decoration: none;
}

dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

a {
  color: #000;
  text-decoration: none;
  transition: 0.3s ease-out;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

button:focus {
  outline: 0;
}

/* リンクスタイル*/
.el-globallink {
  color: #000;
  font-weight: bold;
  font-size: 14px;
}

.el-txtlink {
  color: #5e4430;
  font-weight: bold;
  font-size: 16px;
}

/*-----サイトカラー-----*/
/* 配色の変数 末尾名称はhtmlcsscolor.com*/
.bg-red-Trinidad {
  background: #c5422a;
}

.bg-green-Jewel {
  background: #1a6a4e;
}

.bg-green-DeepSea {
  background: #207c5c;
}

.bg-beign-WanWhite {
  background: #e2dfd8;
}

.bg-black {
  background: #222;
}

.bg-black-RangoonGreen {
  background: #14170b;
}

.bg-white {
  background: #fff;
}

/* テキスト色*/
.color-red-Trinidad {
  color: #c5422a;
}

.color-green-Jewel {
  color: #1a6a4e;
}

.color-green-DeepSea {
  color: #207c5c;
}

.color-beign-WanWhite {
  color: #e2dfd8;
}

.corlr-grey-Nobel {
  color: #999;
}

.color-black {
  color: #222;
}

.color-white {
  color: #fff;
}

.heading-inc {
  font-weight: bold;
  font-size: 2.6rem;
  line-height: 1.38;
}

.heading-incSub {
  font-size: 1.1rem;
}

.heading-mainCopy {
  text-align: center;
  font-weight: bold;
  font-size: 4rem;
  line-height: 1.4;
}

.heading-lv2Large {
  font-weight: bold;
  font-size: 3.2rem;
  line-height: 1.5;
}

.heading-lv2Medium {
  text-align: center;
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.4;
}
.heading-lv2Medium > p {
  font-size: 1.4rem;
}

.heading-lv1Post {
  text-align: left;
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.4;
}

.heading-lv2Small {
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.2;
}

.heading-lv2-sub {
  color: #999;
  text-transform: uppercase;
  font-weight: 100;
  font-size: 1.2rem;
  font-family: "Montserrat";
  line-height: 2.5;
}

.heading-place {
  font-weight: 700;
  font-size: 6rem;
  font-family: "Montserrat";
  line-height: 0.5;
}

.headingBd-under {
  position: relative;
}
.headingBd-under::after {
  position: absolute;
  bottom: -20px;
  left: 50%;
  display: block;
  width: 60px;
  height: 4px;
  background-color: #c5422a;
  content: "";
  transform: translateX(-50%);
}

.bl-heading-lv2Medium {
  margin-top: 70px;
  text-align: center;
}

.bl-heading-lv2Medium-sub {
  margin-top: 60px;
  text-align: center;
}

.headingBd-underPost {
  position: relative;
}
.headingBd-underPost::after {
  position: absolute;
  bottom: -20px;
  left: 0;
  display: block;
  width: 60px;
  height: 4px;
  background-color: #222;
  content: "";
}

.bl-heading-lv2Medium-post {
  text-align: left;
}

/* 見出し以外で使用のテキストスタイル*/
.fw-bold {
  font-weight: bold;
}

.bl-center {
  text-align: center;
}

/*-------------------*/
/*-----TOPページ-----*/
/*-------------------*/
.ly-header {
  position: absolute;
  top: 0;
  z-index: 1;
  width: 100%;
}

.bl-header {
  width: 100%;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0px 0px 10px #0000001a;
}

.innerHeader {
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding: 24px 0 24px 10.1%;
  max-width: 100%;
  width: 1366px;
  height: 105px;
}

.bl-headerLogo {
  display: flex;
}

.bl-headerLogo-txt {
  margin-left: 16px;
}

.bl-headerLogo-img {
  margin-top: -24px;
  width: 168px;
  height: 168px;
  background: url("/images/logo-hover.png") no-repeat;
  background-size: contain;
}
.bl-headerLogo-img a {
  display: inline-block;
}
.bl-headerLogo-img a:hover,
.bl-headerLogo-img a:focus {
  background-color: transparent;
}
.bl-headerLogo-img a:hover img,
.bl-headerLogo-img a:focus img {
  visibility: hidden;
}

.bl-headerNav {
  display: flex;
  margin-top: 33px;
}
.bl-headerNav li {
  margin-right: 30px;
  font-weight: bold;
  font-size: 1.2rem;
}
.bl-headerNav li:nth-last-child(3) {
  margin-right: 45px;
}
.bl-headerNav li:nth-last-child(2) {
  margin-right: 0;
}
.bl-headerNav li a.hover-bd {
  position: relative;
  display: inline-block;
  text-decoration: none;
  font-weight: bold;
}
.bl-headerNav li a.hover-bd::after {
  position: absolute;
  bottom: -24px;
  left: -16.5px;
  width: 88px;
  height: 3px;
  background: #c5422a;
  content: "";
  transition: transform 0.3s;
  transform: scale(0, 1);
}
.bl-headerNav li a.hover-bd:hover::after,
.bl-headerNav li a.hover-bd:focus::after {
  transform: scale(1, 1);
}

.el-btnContact {
  margin-top: -57px;
  background: #1a6a4e;
}
.el-btnContact a {
  display: block;
  padding-top: 27px;
  width: 105px;
  height: 105px;
  color: #fff;
  text-align: center;
}
.el-btnContact a:hover,
.el-btnContact a:focus {
  background: #207c5c;
}

.icon-mail {
  position: relative;
}
.icon-mail::after {
  position: absolute;
  bottom: 30.5px;
  left: 50%;
  width: 26px;
  height: 21px;
  background: url(/images/icon-mail.png) no-repeat;
  background-size: contain;
  content: "";
  transform: translateX(-50%);
}

.position-contetctMid {
  margin-top: -8.9%;
}

.ly-contents {
  margin: 0 auto;
  max-width: 1088px;
  width: 100%;
}

.ly-keyvisual {
  position: relative;
  margin: 0 auto;
  width: 100%;
  height: 720px;
}

.position-mainCopy {
  position: absolute;
  top: 54%;
  left: 50%;
  z-index: 1;
  width: 100%;
  transform: translate(-50%, -50%);
}

.bg-contetctMid {
  width: 100%;
  height: calc(1326px + 74px);
  background: url(/images/bg-body.jpg) center;
}

.kv-video {
  position: relative;
  width: 100%;
}
.kv-video:before {
  display: block;
  padding-top: 56.25%;
  width: 100%;
  content: "";
}
.kv-video video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.kv-mask {
  position: absolute;
  bottom: -19%;
  left: 50%;
  z-index: 0;
  width: 100%;
  line-height: 1;
  transform: translateX(-50%);
}

/*-----TOPページ about-----*/
.ly-about {
  position: relative;
  z-index: 0;
  margin: 0 auto;
  max-width: 1366px;
  width: 100%;
  height: 547px;
}

.ly-aboutInner {
  position: relative;
  margin-right: 0;
  margin-left: auto;
  height: 547px;
}

.bl-about {
  display: flex;
  align-items: center;
  margin-right: 0;
  margin-left: auto;
  padding: 20px;
  max-width: 923px;
  height: 268px;
}

.bl-aboutTtl {
  margin-left: 30px;
}

.bl-aboutInner {
  display: flex;
}

.bl-aboutTxt {
  margin-right: 0;
  margin-left: auto;
}

.bl-aboutSummary {
  margin-top: 35px;
  margin-left: -88px;
  width: 420px;
}
.bl-aboutSummary > p {
  font-size: 1.4rem;
}

.aboutInner-imgBg {
  position: relative;
}
.aboutInner-imgBg:before {
  position: absolute;
  top: 195px;
  left: -304px;
  z-index: -1;
  width: 352px;
  height: 352px;
  background: url(/images/about-bg.png);
  background-size: contain;
  content: "";
}

.bl-aboutInner-txt {
  margin-right: 90px;
  margin-left: auto;
}

.aboutInner-imgMap {
  position: relative;
}
.aboutInner-imgMap:after {
  position: absolute;
  top: 251px;
  left: 60.5px;
  width: 336px;
  height: 221px;
  background: url(/images/about-hokkaido.png) no-repeat;
  background-size: contain;
  content: "";
}

.aboutInner-ttl {
  position: relative;
  margin-top: -14px;
  margin-right: 97px;
  text-align: right;
}

.ly-btnAbout {
  margin-top: 56px;
}

.btn-right {
  margin-right: 0;
  margin-left: auto;
}

.btn-center {
  margin: 0 auto;
}

.el-btnCommon a {
  position: relative;
  display: inline-block;
  padding: 16px 25px;
  width: 320px;
  background: #c5422a;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1.6;
}
.el-btnCommon a:hover,
.el-btnCommon a:focus {
  background: #fff;
  box-shadow: 0 0 0 3px #c5422a inset;
  color: #c5422a;
}

.arrow-harf {
  position: relative;
}
.arrow-harf::after {
  position: absolute;
  top: 50%;
  display: inline-block;
  margin-left: 20px;
  width: 84px;
  height: 9px;
  background: url(/images/arrowHarf-white.png);
  content: "";
  transform: translateY(-50%);
}
.arrow-harf:hover::after, .arrow-harf:focus::after {
  background: url(/images/arrowHarf-red.png);
}

.el-btnBorder a {
  position: relative;
  display: block;
  width: 320px;
  height: 60px;
  background: transparent;
  box-shadow: 0 0 0 3px #fff inset;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 60px;
}
.el-btnBorder a:hover,
.el-btnBorder a:focus {
  background: rgba(34, 34, 34, 0.7);
}
.el-btnBorder .arrow-harf:hover::after, .el-btnBorder .arrow-harf:focus::after {
  background: url(/images/arrowHarf-white.png);
}

/*-----TOPページ facility——————————*/
.ly-facility {
  margin-top: 100px;
}

.ly-facilityInner {
  display: flex;
  margin: 0 auto;
  width: 1008px;
  height: 648px;
  border: 10px solid #fff;
  border-collapse: collapse;
}

.bl-card {
  position: relative;
  width: 536px;
  height: 628px;
  background: #fff;
}

.bl-cardInner {
  padding: 30px 40px 44px;
}

.card-left {
  position: relative;
  top: -50px;
  left: -50px;
}

.card-right {
  position: relative;
  top: 50px;
  left: -35px;
}
.card-right .bl-cardInner {
  margin-top: -40px;
  padding: 12px 40px 44px;
}

.card-ttl {
  position: relative;
  text-align: left;
}
.card-ttl::after {
  display: block;
  padding-top: 20.5px;
  width: 60px;
  border-bottom: 4px solid #000;
  content: "";
}
.card-ttl .ly-timeschedule-1st {
  margin-top: 50px;
}

.card-txt {
  margin-top: 24px;
  font-size: 1.4rem;
}

.ly-btnFacility {
  margin-top: 35px;
  text-align: center;
}

.ly-txtFacility {
  position: absolute;
  right: 18px;
  bottom: 36px;
  white-space: nowrap;
  line-height: 1;
  writing-mode: vertical-rl;
}

.icon-facility {
  position: relative;
}
.icon-facility::after {
  position: absolute;
  top: -29px;
  left: -29px;
  display: block;
  width: 58px;
  height: 49px;
  background: url(/images/icon-facility.png) no-repeat;
  background-size: cover;
  content: "";
}

.icon-facilitySecond {
  position: relative;
}
.icon-facilitySecond::after {
  position: absolute;
  top: -29px;
  left: 10px;
  display: block;
  width: 58px;
  height: 49px;
  background: url(/images/icon-facility.png) no-repeat;
  background-size: cover;
  content: "";
}

/*-----TOPページ dairy-----*/
.ly-diary {
  padding: 35px 0 60px;
}

.bl-diaryTtl {
  display: flex;
  align-items: center;
}
.bl-diaryTtl p {
  padding-left: 28.5px;
  width: 670px;
  border-left: 3px solid #222;
  line-height: 1.8;
}

.diary-ttl {
  padding-right: 28.5px;
  white-space: nowrap;
  line-height: 1.225;
}

.bg-diary {
  margin: 0 auto;
  max-width: 1088px;
  height: 180px;
  background: url(/images/bg-daiary-ttl.png) no-repeat;
}

.ly-cardDiary {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 49.5px;
}

.bl-cardDiary {
  margin-bottom: 53px;
  width: 32.17%;
  height: 404px;
  border-top: 3px solid #222;
  border-bottom: 3px solid #222;
  background: #fff;
}
.bl-cardDiary:nth-last-child(-n+4) {
  margin-bottom: 0;
}

.diary-ttlInner {
  display: flex;
  align-items: center;
}

.bl-dateandtime {
  display: flex;
  align-items: center;
  margin-top: 3px;
  margin-bottom: 6px;
}
.bl-dateandtime p {
  padding: 8px 0;
  color: #fff;
  font-weight: 400;
  font-size: 1.4rem;
  font-family: "Montserrat";
  line-height: 1;
}
.bl-dateandtime p span {
  padding: 1px 10px;
  background: #222;
}
.bl-dateandtime time {
  margin-left: 14px;
}

.diaryInner-img {
  padding: 13px 0;
  border-top: 2px dotted #666;
  border-bottom: 2px dotted #666;
  text-align: center;
}

.diaryInner-summary {
  margin: 22px auto 27px;
  font-weight: bold;
  font-size: 1.6rem;
  line-height: 1.4;
}

.ly-btnDaiary {
  margin: 52px auto 0;
}

.btn-diary:hover .bl-dateandtime p span,
.btn-diary:focus .bl-dateandtime p span {
  background: #c5422a;
}
.btn-diary:hover .bl-dateandtime time,
.btn-diary:focus .bl-dateandtime time {
  margin-left: 14px;
}
.btn-diary:hover .diaryInner-img img,
.btn-diary:focus .diaryInner-img img {
  background: #e2dfd8;
  opacity: 0.7;
}
.btn-diary:hover .diaryInner-summary,
.btn-diary:focus .diaryInner-summary {
  color: #c5422a;
}

/*-----TOPページ recruit-----*/
.ly-recruit {
  margin: 0 auto;
}

.bg-recruit {
  padding: 50px 0;
  width: 1366px;
  height: 300px;
  background: url(/images/bg-recruit.jpg) no-repeat;
}

.ly-btnRecruit {
  margin-top: 46px;
}

/*-----TOPページ info-----*/
.ly-info {
  margin: 0 auto;
  padding: 60px 0 0;
  width: 904px;
}

.bl-infoTtl {
  height: 127px;
  text-align: center;
}

.icon-info {
  position: relative;
}
.icon-info::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 60px;
  height: 60px;
  background: url(/images/icon-info.png);
  background-size: contain;
  content: "";
  transform: translateX(-50%);
}

.bl-infoBody {
  margin-top: 60px;
  padding: 40px 0;
  border-top: 2px solid #222;
  border-bottom: 2px solid #222;
}
.bl-infoBody .infoInner {
  padding: 41px 0;
  border-bottom: 1px dotted #222;
}
.bl-infoBody .infoInner:first-child {
  padding-top: 0;
}
.bl-infoBody .infoInner:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.infoInner-btn {
  display: flex;
  line-height: 1.6;
}
.infoInner-btn time {
  min-width: 135px;
}
.infoInner-btn p {
  width: calc(100% - 135px);
}
.infoInner-btn:hover, .infoInner-btn:focus {
  color: #c5422a;
}

.el-txtLink-plain {
  font-size: 1.4rem;
}
.el-txtLink-plain a:hover, .el-txtLink-plain a:focus {
  color: #c5422a;
}

.ly-txtLink-info {
  margin-top: 20px;
  margin-right: 50px;
  text-align: right;
}

.arrow-harfPlain {
  position: relative;
}
.arrow-harfPlain::after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: inline-block;
  margin-left: 8px;
  width: 42px;
  height: 8px;
  content: "";
  background: url(/images/arrowHarf-plain.png);
}
.arrow-harfPlain:hover::after, .arrow-harfPlain:focus::after {
  background: url(/images/arrowHarf-plainHover.png);
}

/*-----TOPページ パンくず-----*/
.ly-breadcrumb {
  display: flex;
  align-items: center;
  margin-top: 120px;
  padding: 0 139px;
  min-height: 60px;
  width: 100%;
  color: #fff;
  font-size: 1.4rem;
}
.ly-breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  padding: 10px 13px;
}
.ly-breadcrumb li::after {
  margin: 0 10px;
  content: "／";
}
.ly-breadcrumb li:last-child::after {
  margin-right: 0;
  content: none;
}
.ly-breadcrumb li a {
  color: #fff;
}

/*----- footer -----*/
.bg-footer {
  background: url(/images/bg-footer.jpg);
  background-size: cover;
}

.ly-footer {
  padding: 50px 0 40px;
  color: #fff;
}

.bl-footerLogo {
  text-align: center;
}

.bl-footerLogo-img {
  margin: 0 auto;
  width: 140px;
  height: 140px;
  background: url("/images/logo-hover.png") no-repeat;
  background-size: contain;
}
.bl-footerLogo-img a {
  display: inline-block;
}
.bl-footerLogo-img a:hover,
.bl-footerLogo-img a:focus {
  background-color: transparent;
}
.bl-footerLogo-img a:hover img,
.bl-footerLogo-img a:focus img {
  visibility: hidden;
}

.footerLogo-ttl {
  margin-top: 21px;
  line-height: 1.385;
}

.footerLogo-subttl {
  margin-top: 4px;
}

.hp-mgr1em {
  margin-right: 1em;
}

.hp-mgt1em {
  margin-top: 1em;
}

.bl-footerNav {
  display: flex;
  justify-content: center;
  margin-top: 41px;
}
.bl-footerNav li {
  height: 15px;
  border-right: 1px solid #fff;
  line-height: 1;
}
.bl-footerNav li:last-child {
  border: none;
}
.bl-footerNav a {
  display: block;
  padding: 0 20px;
  color: #fff;
  font-size: 1.4rem;
}

.copy {
  margin-top: 40px;
  text-align: center;
  font-size: 1.2rem;
}

.pc-only {
  display: block;
}

.tabsp-only,
.sp-only {
  display: none;
}

/*-----下層ページ-----*/
.privacy-h1Bg {
  background: url(/images/bg-h1-privacy.jpg) no-repeat center;
}

.company-h1Bg {
  background: url(/images/bg-h1-company.jpg) no-repeat center;
}

.business-h1Bg {
  background: url(/images/bg-h1-business.jpg) no-repeat center;
}

.facilities-h1Bg {
  background: url(/images/bg-h1-facilities.jpg) no-repeat center;
}

.recruit-h1Bg {
  background: url(/images/bg-h1-recruit.jpg) no-repeat center;
}

.info-h1Bg {
  background: url(/images/bg-h1-info.jpg) no-repeat center;
}

.contact-h1Bg {
  background: url(/images/bg-h1-contact.jpg) no-repeat center;
}

.diary-h1Bg {
  background: url(/images/bg-h1-diary.jpg) no-repeat center;
}

.ly-h1Bg {
  padding-top: 34.04%;
  width: 100%;
  height: 0;
  background-size: cover;
  position: relative;
  display: flex;
  justify-content: center;
}
.ly-h1Bg h1,
.ly-h1Bg p {
  position: absolute;
  bottom: -30px;
  padding: 30px 15px;
  background: #000;
  white-space: nowrap;
  letter-spacing: 0.2em;
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 1.143;
  writing-mode: vertical-rl;
}
.ly-h1Bg.privacy-h1Bg h1 {
  bottom: 0;
}
.ly-h1Bg h1.txt-horizontal {
  padding: 8px 30px;
  writing-mode: horizontal-tb;
}

/*-----プライバシーポリシー pc-----*/
.ly-h1Bg-txt {
  margin-top: 60px;
}

.ly-privacy {
  margin-top: 60px;
}
.ly-privacy h2 {
  padding-bottom: 20px;
  border-bottom: 2px solid #222;
}
.ly-privacy p {
  margin-top: 1em;
}
.ly-privacy p:first-child {
  margin-top: 0;
}
.ly-privacy ol.bl-number {
  margin: 0 auto;
  max-width: 1083px;
  list-style-type: none;
  counter-reset: count 0;
}
.ly-privacy ol.bl-number li {
  margin-top: 12px;
  padding-left: 1em;
  text-indent: -1em;
}
.ly-privacy ol.bl-number li:first-child {
  margin-top: 10px;
}
.ly-privacy ol.bl-number li::before {
  content: counter(count) ". ";
  counter-increment: count 1;
}

.hp-mgt30 {
  margin-top: 30px !important;
}

.bl-privacyTxt {
  margin-top: 0px;
}
.bl-privacyTxt a {
  word-wrap: break-word;
}

.ly-privacyContact {
  margin-top: 30px;
  padding: 26px 30px;
  border: 2px solid #e2dfd8;
}
.ly-privacyContact p {
  margin-top: 0;
  line-height: 1.8;
}

.ly-company-bg {
  position: relative;
  margin-top: 80px;
  padding: 100px 0 90px;
}
.ly-company-bg::before {
  position: absolute;
  top: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 440px;
  background: url(/images/bg-body.jpg) center;
  content: "";
}

.ly-company-1st {
  padding: 55px 50px 35px 60px;
  max-width: 100%;
  background: white;
}

.bl-company-1st {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.company-Ttl {
  display: flex;
  align-items: center;
  margin-top: -9.5%;
  margin-left: -40px;
  text-align: left;
  font-size: 3.4rem;
  line-height: 1.4;
}
.company-Ttl .heading-cow {
  margin-right: 23.5px;
}

.ly-company-txt {
  margin-right: 5.11%;
  width: 49.49%;
}

.ly-company-img {
  display: flex;
  margin-top: 20px;
}

.posi-company-img2 {
  margin-top: -215px;
  margin-left: -36px;
}

.ly-fixNav {
  position: absolute;
  top: 575px;
  right: 77px;
  z-index: 1000;
  display: flex;
  background: rgba(255, 255, 255, 0.8);
  list-style-type: none;
  writing-mode: vertical-rl;
}
.ly-fixNav li::after {
  margin: 0 10px;
  content: "／";
}
.ly-fixNav li:last-child::after {
  content: none;
}
.ly-fixNav a {
  padding: 10px 0;
  font-size: 1.2rem;
}

.is-fixed {
  position: fixed;
  top: 100px;
  right: 77px;
  z-index: 1000;
}

.ly-company-2nd {
  margin-top: 20px;
  margin-right: 50px;
  margin-left: 50px;
  padding: 10px;
  height: 424px;
  background: url(/images/bg-body.jpg);
}

.bl-company-2nd {
  padding: 50px 0 16px 0;
  height: 404px;
  background: #fff;
}

.bl-company-2ndInner {
  display: flex;
  margin-left: -5.84%;
}

.ly-company-2ndImg {
  margin-right: 5.09%;
  width: 33.07%;
  height: auto;
}

.ly-company-2ndTxt {
  margin-right: 1.75%;
  width: 45.91%;
}

.company-2ndTtl {
  display: flex;
  align-items: center;
  margin-top: -120px;
  margin-right: 1.556%;
  width: 130px;
  color: #fff;
  font-size: 2.4rem;
  writing-mode: vertical-rl;
}
.company-2ndTtl .bl-company-2ndTtl {
  padding: 20px 15px;
  line-height: 1.08;
}

.icon-cow {
  position: relative;
}
.icon-cow::after {
  position: absolute;
  bottom: -102px;
  left: 50%;
  display: inline-block;
  width: 130px;
  height: 72px;
  background: url(/images/icon-cow.png) no-repeat;
  content: "";
  transform: translateX(-50%);
}

.ly-company-3rd {
  display: flex;
  margin: 60px auto 0;
  max-width: 1088px;
}

.bg-company-3rd {
  background: url(/images/company-img-pc.jpg) no-repeat top right;
}

.company-3rdTtl {
  display: flex;
  align-items: center;
  margin-right: 2.94%;
  width: 11.95%;
  font-size: 34px;
  writing-mode: vertical-rl;
}
.company-3rdTtl .heading-cow {
  padding: 30px 0;
  line-height: 1.08;
}
.company-3rdTtl span {
  margin-top: 55px;
}

.icon-quotation {
  position: relative;
  z-index: 1;
}
.icon-quotation:before {
  position: absolute;
  top: 0;
  left: -43px;
  z-index: -1;
  display: inline-block;
  width: 58px;
  height: 49px;
  background: url(/images/icon-quotationUpper.png) no-repeat;
  content: "";
}
.icon-quotation:after {
  position: absolute;
  right: -43px;
  bottom: 0;
  z-index: -1;
  display: inline-block;
  width: 58px;
  height: 49px;
  background: url(/images/icon-quotationLower.png) no-repeat;
  content: "";
}

.bl-company-3rd {
  display: flex;
}

.bl-company-3rdInner {
  position: relative;
  z-index: 1;
  margin-top: 40px;
  width: 52.92%;
}

.ly-company-img3rd {
  position: relative;
  left: -154px;
  width: 590px;
}

.mg-company-img3rd {
  margin-top: 8px;
}

.ly-companyGroupphoto {
  margin-top: 27px;
  text-align: center;
}
.ly-companyGroupphoto h3 {
  font-weight: bold;
  font-size: 2rem;
  line-height: 1.6;
}

.bl-companyGroupphoto-img {
  margin-top: 60px;
}

.bg-companyGroupphoto {
  margin-top: -33vh;
  padding-top: 34.48%;
  width: 100%;
  background: url(/images/bg-companyGroupphoto.png) no-repeat;
  background-size: contain;
}

.ly-companyProfile {
  margin: 30px auto 0;
  width: 42.74%;
}

.ly-stack {
  margin-top: 80px;
  width: 100%;
}

.bl-stack {
  display: flex;
  padding-top: 28px;
  padding-bottom: 30px;
  text-align: left;
  line-height: 1.6;
}
.bl-stack:first-child {
  padding-top: 0;
}
.bl-stack dt {
  font-weight: bold;
}
.bl-stack dt.companyProfile-dt {
  width: 41.29%;
}
.bl-stack dt.history-dt {
  width: 26.21%;
}
.bl-stack dt.recruit-dt {
  width: 18.71%;
}
.bl-stack dd.companyProfile-dd {
  width: 58.71%;
}
.bl-stack dd.history-dd {
  width: 73.79%;
}
.bl-stack dd.recruit-dd {
  width: 81.29%;
}

.bd-dashed {
  position: relative;
}
.bd-dashed::after {
  position: absolute;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #000, #000 2px, transparent 2px, transparent 4px);
  background-size: 4px 1px;
  background-repeat: repeat-x;
  content: "";
}

.ly-company-map {
  margin-top: 50px;
}

.iframe-wrap {
  position: relative;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-top: 36.76%;
  width: 100%;
}
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  border: none;
}

.ly-managementPhilosophy {
  padding-top: 60px;
}
.ly-managementPhilosophy li {
  margin-right: 1.47%;
  width: 25.74%;
}
.ly-managementPhilosophy li:last-child {
  margin-right: 0;
}

.ly-managementPhilosophy-list {
  display: flex;
  justify-content: space-between;
  margin-top: 60px;
}

.ly-hygieneManagement {
  margin-top: 60px;
  padding: 10px;
  background: url(/images/bg-body.jpg);
}

.ly-hygieneManagement-inner {
  padding: 5.62% 14.98% 6.55%;
  max-width: 1068px;
  background: #fff;
}

.ly-hygieneManagement-list {
  margin-top: 60px;
}
.ly-hygieneManagement-list li {
  display: flex;
  align-items: center;
  margin-top: 40px;
  width: 69.76%;
  width: 745px;
}
.ly-hygieneManagement-list li:first-child {
  margin-top: 0;
}

.bl-hygieneManagement-listNumber {
  margin-top: -10px;
  margin-right: 35px;
  color: #ede9e2;
  font-weight: bold;
  font-size: 36px;
  line-height: 1;
}
.bl-hygieneManagement-listNumber span {
  padding: 0 5px;
  border-bottom: 4px solid #ede9e2;
}

.ly-history {
  margin: 60px auto 0;
  width: 53.31%;
}

/*-----事業案内-----*/
.ly-business-bg {
  position: relative;
  margin-top: 80px;
  padding: 100px 0 0;
}
.ly-business-bg::before {
  position: absolute;
  top: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 440px;
  background: url(/images/bg-body.jpg) center;
  content: "";
}

.ly-business-1st {
  display: flex;
  justify-content: center;
  padding: 0 60px 63px 60px;
  max-width: 100%;
  height: 560px;
  background: white;
}

.ly-business-1stImg {
  margin-top: -60px;
  margin-right: 5.17%;
  width: 44.83%;
  height: 560px;
}

.ly-business-1stBody {
  margin-top: -25px;
  width: 50%;
}

.ly-business-1stTxt {
  margin-top: 40px;
}

.business-1stTtl,
.business-2ndTtl {
  font-weight: bold;
  font-size: 3.4rem;
  line-height: 1.4;
}

.ly-business-2nd {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  max-width: 100%;
  width: 968px;
}

.bl-business-2ndBody {
  width: 57.99%;
}

.business-2ndTtl {
  width: 542px;
}

.ly-business-2ndtxt {
  margin-top: 9.17%;
  width: 88.99%;
}

.bl-business-2ndImg {
  width: 44.83%;
}

.ly-business-3rd {
  margin: 110px auto 0;
  max-width: 1088px;
  line-height: 1.8;
}

.bl-business-3rd {
  position: relative;
  display: flex;
  background: #222;
}

.ly-business-3rdImg {
  display: flex;
  flex-wrap: wrap;
  width: 50%;
}

.bl-business-3rdImg-2of3 {
  display: flex;
}

.business-3rdTtl {
  position: absolute;
  top: -30px;
  left: 50%;
  display: flex;
  align-items: center;
  margin-right: 0;
  padding: 8px 17px;
  width: auto;
  background: #fff;
  font-weight: bold;
  font-size: 34px;
  transform: translateX(-50%);
  writing-mode: vertical-rl;
}
.business-3rdTtl .icon-quotation::before {
  top: -36px;
}
.business-3rdTtl .icon-quotation:after {
  bottom: -36px;
}

.business-3rdTtl-lower {
  margin-top: 1.2em;
}

.ly-business-3rdtxt {
  padding: 50px 60px 50px 112px;
  width: 50%;
  color: #fff;
}

.bl-business-3rdsub {
  margin: 0 auto;
  padding: 30px 10px 10px;
  max-width: 1088px;
  width: 100%;
  background: url(/images/bg-body.jpg) center center;
}
.bl-business-3rdsub h3 {
  text-align: center;
  font-weight: bold;
  font-size: 2rem;
  line-height: 1.6;
}

.bl-business-3rdsub-inner {
  display: flex;
  margin-top: 30px;
  padding: 20px 103px;
  width: 100%;
  background: #fff;
}
.bl-business-3rdsub-inner li {
  margin-right: 50px;
}
.bl-business-3rdsub-inner li:last-child {
  margin-right: 0;
}

.bl-business-3rdsub-innerUpper {
  display: flex;
  align-items: center;
}

.bl-business-3rdsub-innerLower {
  display: flex;
  align-items: center;
}

.ly-businessProduction {
  margin-top: 60px;
}

.ly-businessProduction-inner {
  margin-top: 83px;
  padding: 60px 0;
  width: 100%;
  height: 780px;
}

.ly-businessProduction-innerTtl {
  font-weight: bold;
  font-size: 2.4rem;
}

.bg-sandWall {
  background: url(/images/bg-body.jpg) center center;
}

.bl-businessProduction01 {
  display: flex;
  margin-top: 36px;
  line-height: 1.8;
}

.bl-businessProduction01-img {
  margin-right: 4.6%;
  width: 32.35%;
}

.bl-businessProduction01-txt {
  width: 63.05%;
  line-height: 1.8;
}

.bl-businessProduction02 {
  display: flex;
  margin-top: 60px;
  line-height: 1.8;
}

.bl-businessProduction02-inner {
  margin-right: 4.6%;
  width: 54.6%;
}
.bl-businessProduction02-inner .bl-businessProduction02-innerTtl {
  text-align: left;
}
.bl-businessProduction02-inner .bl-businessProduction02-innerTtl + p {
  margin-top: 30px;
}

/*-----施設・技術 facilities -----*/
.ly-facilities-bg {
  position: relative;
}
.ly-facilities-bg::before {
  position: absolute;
  top: 183px;
  z-index: -1;
  display: block;
  width: 100%;
  height: 2945px;
  background: url(/images/bg-body.jpg) center;
  content: "";
}

.ly-facilities-bg2 {
  padding-bottom: 60px;
  width: 100%;
  background: url(/images/bg-body.jpg) center;
}

.ly-headingSummary {
  margin-top: 80px;
  padding: 40px 60px;
  color: #fff;
}

.ly-facilities-common {
  margin: 60px auto 0;
  width: 986px;
}

.ly-facilities-commonBody {
  display: flex;
  margin: 80px auto 0;
}

.ly-facilities-commonImg {
  margin-right: 3.31%;
  padding: 0 18px;
  width: 54.86%;
}

.ly-facilities-commonSection {
  width: 42.9%;
}

.bl-facilities-commonTtl {
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.333;
}

.ly-facilities-commonTxt {
  margin-top: 64px;
}

.odd {
  padding: 40px 0;
}
.odd.ly-facilities-common {
  width: 1088px;
  background: #fff;
}
.odd .ly-facilities-commonBody {
  flex-flow: row-reverse;
  padding: 0 60px;
}
.odd .ly-facilities-commonSection {
  margin-right: 32px;
}
.odd .ly-facilities-commonImg {
  margin-right: -18px;
}
.odd .ly-facilities-commonImg p {
  text-align: center;
}
.odd .ly-facilities-commonTxt {
  margin-top: 30px;
  margin-left: 0;
}

.slider figure {
  position: relative;
  height: auto;
}
.slider figure figcaption {
  position: absolute;
  bottom: 0;
  left: 0;
  display: flex;
  padding: 1rem 1.2rem;
  width: 100%;
  height: auto;
  background: rgba(34, 34, 34, 0.6);
  color: #fff;
  font-size: 1.2rem;
}

.slick-slider {
  z-index: 0;
}

.slider-thumb figure {
  margin-top: 10px;
  margin-right: 3px;
}

.slick-list {
  position: relative;
}

.prev-arrow {
  position: absolute;
  top: 42%;
  left: -18px;
  z-index: 1;
  transform: translateY(-50%);
}

.next-arrow {
  position: absolute;
  top: 42%;
  right: -18px;
  z-index: 1;
  transform: translateY(-50%);
}

.slick-dots {
  display: flex;
  margin-top: 10px;
}
.slick-dots li {
  display: inline-block;
  margin-right: 3px;
  max-width: 16.16%;
  max-height: 51.72px;
  list-style: none;
}
.slick-dots li img {
  width: 100%;
  height: auto;
  opacity: 0.5;
}
.slick-dots li.slick-active img {
  opacity: 1;
}

.ly-recruitVoice {
  margin-top: 60px;
}

.ly-timeschedule-img {
  margin-right: 2.94%;
  padding: 0 18px;
  width: 48.81%;
}

.ly-recruitVoice-btn {
  display: flex;
  justify-content: space-between;
  margin-top: 80px;
  border-bottom: 6px solid #207c5c;
}

.ly-recruitVoice-body {
  margin: 0 auto;
  padding: 56px 60px 50px;
  max-width: 1088px;
  width: 100%;
  background: #fff;
}

.ly-recruit-bg {
  padding-bottom: 60px;
}

.btnTab {
  padding: 20px 0;
  width: 49.63%;
  background: #254137;
  list-style: none;
  text-align: center;
  cursor: pointer;
}
.btnTab a {
  display: block;
  color: rgba(255, 255, 255, 0.6);
  font-weight: bold;
  font-size: 2.4rem;
}
.btnTab.is-active {
  background: #207c5c;
  font-size: 2.4rem;
  opacity: 1;
  transition: all 0.2s ease-out;
}
.btnTab.is-active a {
  color: #fff;
  font-weight: bold;
}

.tabContents {
  display: none;
}

.tabContents.is-active {
  display: block;
}

.bl-recruitProfire {
  display: flex;
  align-items: center;
  border: 4px solid #e2dfd8;
}
.bl-recruitProfire h3 {
  display: flex;
  margin-right: 20px;
  padding: 34px 6px 34px 10px;
  background: #e2dfd8;
  color: #fff;
  letter-spacing: 0.1em;
  font-weight: bold;
  font-size: 2.4rem;
  font-family: "Montserrat";
  line-height: 1;
  transform: rotate(180deg);
  writing-mode: vertical-rl;
}
.bl-recruitProfire ul {
  display: flex;
}
.bl-recruitProfire li {
  padding: 0 17px;
  border-right: 1px solid #222;
  line-height: 1;
}
.bl-recruitProfire li:first-child {
  padding-left: 0;
}
.bl-recruitProfire li:last-child {
  border-right: none;
}

.bl-recruitProfire-img {
  margin-right: 20px;
  width: 160px;
}

.bl-recruitProfire-inner {
  margin-right: 20px;
  width: 72.21%;
}
.bl-recruitProfire-inner p {
  margin-top: 20px;
  font-size: 1.4rem;
  line-height: 1.6;
}

.ly-recruitTab-body {
  margin-top: 40px;
  font-size: 1.6rem;
  line-height: 1.8;
}

.ly-recruitTab-section-mt {
  margin-top: 40px;
}

.bl-recruitTab-ttl {
  padding: 12px 24px;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.2;
}

.ly-recruitTab-section {
  display: flex;
  margin-top: 40px;
}

.bl-recruitTab-txt {
  margin-right: 5.17%;
  width: 57.85%;
}

.bl-recruitTab-img {
  width: 36.98%;
}
.bl-recruitTab-img p:nth-child(n+2) {
  margin-top: 3px;
}

.bl-recruitTab-02img {
  margin-right: 5.17%;
}

.bl-recruitTab-02txt {
  margin-right: 0;
}

.ly-timeschedule {
  margin-top: 60px;
}

.bl-timeschedule {
  margin-top: 80px;
}

.ly-timeschedule-base {
  display: flex;
  padding: 30px 0 30px 50px;
  border: 10px solid #e2dfd8;
}

.ly-timeschedule-1st {
  margin-top: 60px;
}

.ly-timeschedule-Section {
  margin-right: 2.94%;
}

.bl-timeschedule-Ttl {
  position: relative;
  display: inline-block;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.4;
}
.bl-timeschedule-Ttl span {
  margin-right: 60px;
}
.bl-timeschedule-Ttl span:after {
  position: absolute;
  top: 50%;
  display: inline-block;
  margin-left: 10px;
  width: 40px;
  height: 4px;
  background-color: black;
  content: "";
}

.ly-timeschedule-txt {
  margin-top: 30px;
}

.ly-timeschedule-2nd,
.ly-timeschedule-3rd {
  margin-top: 40px;
}

.odd {
  flex-flow: row-reverse;
}
.odd .ly-timeschedule-img {
  margin-left: -18px;
}

.ly-recruitment {
  margin: 60px auto 0;
  width: 64.34%;
}

/*-----お知らせ info -----*/
.icon-infoGeneral {
  position: relative;
}
.icon-infoGeneral::after {
  position: absolute;
  bottom: -120px;
  left: 50%;
  width: 60px;
  height: 60px;
  background: url(/images/icon-info.png);
  background-size: contain;
  content: "";
  transform: translateX(-50%);
}

.ly-infoGeneral {
  margin-top: 210px;
}

/*-----お知らせ詳細 info post -----*/
.ly-infoPost-lv1ttl {
  margin-top: 210px;
}

.bl-infoPost-time {
  margin-top: 40px;
}

.ly-infoPost-article h2 {
  text-align: left;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.2;
  background: #222;
  color: #ffffff;
  padding: 12px 24px;
  margin-top: 50px;
}
.ly-infoPost-article h3 {
  border-bottom: 2px solid #222;
  padding-bottom: 20px;
  font-size: 2.4rem;
  margin-top: 40px;
  line-height: 1.2;
  font-weight: bold;
}
.ly-infoPost-article h4 {
  font-size: 2rem;
  font-weight: bold;
  line-height: 1.44;
}
.ly-infoPost-article p {
  margin-top: 40px;
}
.ly-infoPost-article p > img {
  margin: 0 auto;
  display: block;
}
.ly-infoPost-article ul li {
  position: relative;
  padding-left: 1.5em;
}
.ly-infoPost-article ul li:before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 4px;
  height: 4px;
  background-color: #222;
  border-radius: 50%;
}
.ly-infoPost-article ol li {
  display: flex;
  padding-left: 1em;
  text-indent: -1em;
  counter-increment: count;
}
.ly-infoPost-article ol li:before {
  content: counter(count) ". ";
  margin-right: 0.5em;
}
.ly-infoPost-article dl {
  line-height: 1.8;
}
.ly-infoPost-article dl dt {
  font-weight: bold;
}
.ly-infoPost-article dl dd {
  margin-top: 10px;
  margin-left: 40px;
}
.ly-infoPost-article .bl-quote {
  width: 96.32%;
  margin-left: 3.68%;
  padding: 30px 33px;
  border: 4px solid #e2dfd8;
  line-height: 1.8;
  position: relative;
  margin-top: 40px;
}
.ly-infoPost-article .bl-quote::before {
  position: absolute;
  top: -33px;
  left: -40px;
  display: block;
  width: 58px;
  height: 49px;
  background: url(/images/icon-quotationUpper.png) center;
  content: "";
}
.ly-infoPost-article .bl-postHorizontal {
  display: flex;
  margin-top: 40px;
}
.ly-infoPost-article .bl-postHorizontal p {
  width: 32.35%;
  margin-right: 4.6%;
  margin-top: 0;
}
.ly-infoPost-article .bl-postHorizontal .bl-postSection {
  width: 63.05%;
}
.ly-infoPost-article .bl-postHorizontal .bl-postSection p {
  width: 100%;
  margin-top: 20px;
}
.ly-infoPost-article .bl-postHorizontal-rev {
  display: flex;
  flex-direction: row-reverse;
  margin-top: 40px;
}
.ly-infoPost-article .bl-postHorizontal-rev p {
  width: 32.35%;
  margin-right: 4.6%;
  margin-top: 0;
}
.ly-infoPost-article .bl-postHorizontal-rev .bl-postSection {
  width: 63.05%;
}
.ly-infoPost-article .bl-postHorizontal-rev .bl-postSection p {
  width: 100%;
  margin-top: 20px;
}

.ly-btnpaging {
  margin-top: 60px;
  border-top: 2px solid #222;
  width: 100%;
  padding-top: 60px;
  display: flex;
  justify-content: space-between;
}
.ly-btnpaging .bl-preview a {
  display: flex;
  align-items: center;
}
.ly-btnpaging .bl-preview p:first-child {
  margin-right: 14px;
}
.ly-btnpaging .bl-next a {
  display: flex;
  align-items: center;
}
.ly-btnpaging .bl-next p:first-child {
  margin-right: 14px;
}

.ly-btnpaging-Number {
  max-width: 100%;
  display: flex;
  justify-content: space-between;
  margin: 60px auto 0;
  width: 500px;
}
.ly-btnpaging-Number .bl-btnpaging-Number {
  display: flex;
  margin: 0 40px;
}
.ly-btnpaging-Number .bl-btnpaging-Number li {
  padding: 7px 13px;
  background: #e2dfd8;
  margin: 0 10px;
  line-height: 1.6;
  font-size: 1.8rem;
}

/*-----お問い合わせ contact -----*/
.ly-contact {
  margin-top: 90px;
}

.bl-contactHeading {
  background: #e2dfd8;
  padding: 40px 0 30px;
  text-align: center;
}
.bl-contactHeading h2 {
  font-size: 2.4rem;
  line-height: 1.2;
  font-weight: bold;
}

.bl-contactForm {
  border: 10px solid #e2dfd8;
  padding: 80px 60px 70px;
  text-align: center;
}
.bl-contactForm .el-btnCommon {
  margin-top: 80px;
}

/***** 1240-1194サイズ *****/
@media print, screen and (max-width: 1240px) {
  .innerHeader {
    padding: 17px 0;
  }

  .heading-incSub {
    margin-top: 0;
    font-size: 1rem;
  }
  .heading-incSub.heading-incSub-footer {
    margin-top: 8px;
  }

  .bl-headerLogo-img {
    margin-left: 30px;
  }

  .navToggle-txt {
    position: absolute;
    top: 20%;
    left: 50%;
    color: #fff;
    font-size: 1.2rem;
    transform: translateX(-50%);
  }

  .position-mainCopy {
    top: 50%;
  }

  .bl-headerNav {
    margin-top: 40px;
  }

  .bl-headerLogo-txt {
    margin-top: 9px;
  }

  .ly-diary {
    margin: 0 auto;
  }

  .bg-diary {
    background-size: contain;
  }

  .bl-diaryTtl p {
    width: 66%;
  }

  .bl-footerNav {
    display: flex;
    flex-wrap: wrap;
    margin: 43px auto 0;
    max-width: 468px;
    line-height: 1;
  }
  .bl-footerNav li:nth-child(5) {
    border-right: none;
  }
  .bl-footerNav li:nth-child(5) a {
    padding-right: 0;
  }
  .bl-footerNav li:nth-child(n+6) {
    margin-top: 13px;
  }
  .bl-footerNav li:first-child a {
    padding-left: 0;
  }
}
/***** tabサイズ *****/
@media screen and (max-width: 1194px) {
  .pc-only {
    display: none;
  }

  .tabsp-only {
    display: block;
  }

  .sp-only {
    display: none;
  }

  .heading-mainCopy {
    letter-spacing: 0.02em;
    font-size: 3.6rem;
    line-height: 1.4;
  }

  .heading-lv2Large {
    font-size: 2.4rem;
  }

  .heading-lv2Medium {
    font-size: 2.2rem;
  }

  .heading-lv2Small {
    font-size: 1.8rem;
  }

  .heading-inc {
    font-size: 1.95rem;
    line-height: 1.846;
  }

  .heading-lv1Post {
    text-align: left;
    font-weight: bold;
    font-size: 2rem;
    line-height: 1.8;
  }

  .innerHeader {
    padding: 17px 0;
    height: 79px;
  }

  .heading-incSub {
    font-size: 1rem;
    line-height: 1;
  }

  .bl-headerLogo-img {
    margin-top: -17px;
    width: 126px;
  }

  .bd-burger {
    border-top: 2px solid #fff;
  }

  .bl-headerLogo-txt {
    margin-top: 0;
  }

  .kv-video {
    position: relative;
    width: 100%;
  }
  .kv-video:before {
    display: block;
    padding-top: 0;
    min-height: 540px;
    width: 100%;
    content: "";
    object-fit: cover;
  }
  .kv-video video {
    position: absolute;
    top: 0;
    left: 0;
    min-height: 540px;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .kv-mask {
    bottom: -12%;
  }

  /*----- バーガーメニュー tab-----*/
  #bl-navToggle {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1000;
    padding: 19px 0;
    width: 79px;
    height: 79px;
    background: #222;
    text-align: center;
    cursor: pointer;
  }
  #bl-navToggle span span {
    position: absolute;
    left: 20px;
    display: block;
    width: 40px;
    height: 2px;
    background: #fff;
    transition: transform 0.6s ease-in-out, top 0.5s ease;
  }
  #bl-navToggle span span:nth-child(1) {
    top: 44.5px;
  }
  #bl-navToggle span span:nth-child(2) {
    top: 54.5px;
  }

  .el-btnContact {
    margin-top: 0;
    background: transparent;
  }
  .el-btnContact a:hover, .el-btnContact a:focus {
    background: transparent;
  }

  #gloval-nav {
    position: absolute;
    top: 0;
    z-index: 999;
    display: none;
    visibility: hidden;
    padding: 70px 9.1%;
    width: 100%;
    background: #222;
  }

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

  /* open */
  .open #gloval-nav {
    visibility: visible;
    opacity: 1;
  }
  .open #bl-navToggle span span {
    background: #fff;
  }
  .open #bl-navToggle span span:nth-child(1) {
    top: 32.5px;
    transform: rotate(45deg);
  }
  .open #bl-navToggle span span:nth-child(2) {
    top: 32.5px;
    transform: rotate(-45deg);
  }
  .open #bl-navToggle {
    width: 70px;
    height: 70px;
    background: transparent;
  }
  .open .bl-headerNav-wrap {
    padding: 58px 34% 76px;
    width: 100%;
    border: 2px solid #fff;
  }
  .open .bl-headerInnerLogo-img {
    margin: 0 auto;
    width: 126px;
  }
  .open .bl-headerNav {
    display: block;
    margin-top: 0;
    margin-top: 52px;
    padding: 38px 0 0;
    height: auto;
    border-top: 2px solid #fff;
  }
  .open .bl-headerNav li {
    margin-right: 0;
    margin-bottom: 30px;
    text-align: center;
    font-weight: bold;
    font-size: 2rem;
    line-height: 1.45;
  }
  .open .bl-headerNav li:last-child {
    margin-top: 40px;
    margin-bottom: 0;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5;
  }
  .open .bl-headerNav li:nth-last-child(2) {
    margin-bottom: 0;
  }
  .open .bl-headerNav li a {
    color: #fff;
  }
  .open .bl-headerNav li a.hover-bd::after {
    position: unset;
  }
  .open .bl-headerNav .el-btnContact a {
    margin-top: 40px;
    padding-top: 35px;
    width: auto;
    height: 65px;
  }
  .open .bl-headerNav .icon-mail::after {
    top: 0;
  }
  .open .position-mainCopy {
    z-index: 0;
  }

  .ly-contents {
    padding: 0 30px;
    width: auto;
  }

  /*-----TOPページ about tab-----*/
  .bg-contetctMid {
    padding-bottom: 100px;
    height: auto;
  }

  .ly-about {
    height: auto;
  }

  .ly-aboutInner {
    max-width: 88%;
    width: auto;
    height: auto;
  }

  .bl-about {
    padding: 0;
    max-width: 653px;
    height: auto;
  }

  .bl-about-img {
    margin: 20px 0 20px 20px;
  }
  .bl-about-img img {
    max-width: 300px;
  }

  .heading-place {
    font-weight: bold;
    font-size: 4.5rem;
  }

  .aboutInner-ttl {
    margin-top: -12px;
    margin-right: 24px;
    margin-left: 0;
  }

  .bl-aboutSummary {
    margin-top: 46px;
    margin-right: 30px;
    margin-left: 0;
    width: 380px;
  }

  .aboutInner-imgMap:after {
    top: 200px;
    left: 44px;
    width: 252px;
    height: 158px;
  }

  .aboutInner-imgBg:before {
    top: 159px;
    left: -243px;
    width: 264px;
    height: 264px;
    background-size: cover;
  }

  .bl-aboutInner-txt {
    position: absolute;
    left: 52.67%;
  }

  .bl-aboutInner-summary {
    margin-right: 29.6px;
    width: auto;
  }

  .ly-btnAbout {
    margin-top: 26px;
  }

  /*-----TOPページ facility tab-----*/
  .ly-facility {
    margin-top: 100px;
  }

  .ly-facilityInner {
    display: block;
    width: auto;
    width: 648px;
    height: 1154px;
  }

  .bl-card {
    height: auto;
  }

  .card-left,
.card-right {
    top: -50px;
    left: 50%;
    transform: translateX(-50%);
  }

  .card-right .bl-cardInner {
    padding: 15px 40px 44px;
  }

  .icon-facility::after,
.icon-facilitySecond::after {
    content: none;
  }

  /*-----TOPページ diary tab-----*/
  .ly-diary {
    margin: 0;
    padding: 60px 0;
  }

  .bg-diary {
    align-items: flex-start;
    padding-top: 16.5%;
    width: 100%;
    height: 0;
    background-size: contain;
  }

  .ly-cardDiary {
    margin: 49.5px auto 0;
    max-width: 696px;
  }

  .bl-diaryTtl p {
    padding-left: 21px;
  }

  .diary-ttl {
    padding-right: 21px;
  }

  .bl-cardDiary {
    width: 48.9%;
    height: auto;
  }
  .bl-cardDiary:nth-last-child(-n+4) {
    margin-bottom: auto;
  }

  .bl-dateandtime {
    margin-top: 4px;
    margin-bottom: 5px;
  }

  .diary-ttlInner {
    align-items: center;
    margin-top: -16%;
    padding: 0 3%;
    min-height: 82px;
    width: auto;
    width: 100%;
    height: auto;
  }

  .diaryInner-summary {
    margin: 28px auto 31px;
  }

  /*-----TOPページ recruit tab-----*/
  .bg-recruit {
    width: auto;
    height: auto;
    background: url(/images/bg-recruit.jpg) no-repeat right 39% bottom;
    background-size: cover;
  }

  .ly-btnRecruit {
    margin-top: 21px;
  }

  .bl-infoTtl {
    height: 118px;
  }

  .ly-breadcrumb {
    margin-top: 100px;
    padding: 0 30px;
  }

  /*-----TOPページ info tab-----*/
  .ly-info {
    width: auto;
  }

  /*-----TOPページ footer tab-----*/
  .bl-footerLogo-img {
    width: 105px;
    height: 105px;
  }

  .footerLogo-ttl {
    margin-top: 8px;
  }

  .copy {
    font-size: 1.2rem;
  }

  /*-----下層ページ-----*/
  .ly-h1Bg h1 {
    padding: 20px 15px;
    font-size: 2.2rem;
  }

  .ly-h1Bg-txt {
    margin-top: 50px;
  }

  .ly-privacy {
    margin-top: 50px;
  }
  .ly-privacy h2 {
    padding-bottom: 12px;
  }

  .ly-privacyContact {
    padding: 16px 20px;
  }

  .bl-privacyTxt {
    margin-top: 30px;
  }

  /*-----会社案内 tab-----*/
  .ly-fixNav {
    top: 301px;
    right: 15px;
  }

  .is-fixed {
    position: fixed;
    top: 101px;
    right: 15px;
  }

  .bl-heading-lv2Medium {
    margin-top: 63px;
  }

  .bl-heading-lv2Medium-sub {
    margin-top: 50px;
  }

  .ly-sandpaper-bg {
    margin-top: 60px;
    padding: 50px 0 90px;
  }

  .bl-company-1st {
    display: block;
  }

  .ly-company-txt {
    margin-right: 0;
    width: 100%;
  }

  .ly-company-1st {
    padding: 30px;
  }

  .company-Ttl {
    margin-top: 0;
    margin-left: 0;
    font-size: 27px;
  }
  .company-Ttl span {
    max-width: 104px;
  }

  .ly-company-img {
    justify-content: center;
    margin-top: 30px;
  }

  .posi-company-img2 {
    margin-top: 0;
    margin-left: 20px;
  }

  .ly-company-2nd {
    margin-top: 60px;
    margin-right: 0;
    margin-left: 0;
    padding: 10px;
    height: auto;
  }

  .bl-company-2nd {
    padding: 30px 0;
    height: auto;
  }

  .bl-company-2ndInner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-left: 0;
  }

  .ly-company-2ndTxt {
    width: 69.48%;
  }

  .ly-company-2ndImg {
    order: 3;
    margin: 30px 35px 0;
    width: auto;
    height: auto;
  }

  .company-2ndTtl {
    margin-top: -96px;
  }
  .company-2ndTtl span {
    margin-top: 30px;
    max-width: 130px;
  }

  .company-3rdTtl {
    position: relative;
    top: -17px;
    margin-right: 0;
    margin-left: 11.72%;
    width: auto;
    height: 485px;
    font-size: 27px;
  }
  .company-3rdTtl .heading-cow {
    padding: 20px 0 0;
    position: relative;
    z-index: 1;
  }
  .company-3rdTtl span {
    margin-top: 40px;
  }

  .icon-quotation:before {
    top: -20px;
    left: -18px;
    width: 44px;
    height: 38px;
    background-size: contain;
  }

  .icon-quotation:after {
    right: -18px;
    bottom: -20px;
    width: 44px;
    height: 38px;
    background-size: contain;
  }

  .bg-company-3rd {
    background: url(/images/company-img.jpg) no-repeat top right;
    background-size: auto;
  }

  .ly-company-3rd {
    position: relative;
    display: block;
    margin-top: 67px;
  }

  .bl-company-3rdInner {
    margin-top: 30px;
    margin-right: 3.91%;
    margin-left: 14.32%;
    width: 81.77%;
  }

  .ly-companyGroupphoto {
    margin-top: 60px;
  }

  .ly-companyGroupphoto {
    margin-top: 60px;
    padding: 0 30px;
    width: auto;
  }

  .bg-companyGroupphoto {
    margin-top: -18vh;
  }

  .ly-companyProfile {
    margin: 42px auto 0;
    width: 65.68%;
  }

  .bl-stack dd.recruit-dd {
    padding-right: 9.57%;
    width: 72.86%;
  }

  .ly-managementPhilosophy {
    margin-top: 60px;
  }

  .ly-managementPhilosophy-list {
    flex-wrap: wrap;
    justify-content: center;
    margin: 60px auto 0;
    width: 77.01%;
  }

  .ly-managementPhilosophy li {
    margin-right: 16px;
    width: 260px;
    height: 280px;
  }
  .ly-managementPhilosophy li:nth-child(2n) {
    margin-right: 0;
  }
  .ly-managementPhilosophy li:nth-last-child(-n+2) {
    margin-top: 16px;
  }

  .ly-hygieneManagement {
    padding: 10px;
  }

  .ly-hygieneManagement-list li {
    width: auto;
  }

  .ly-hygieneManagement-inner {
    padding: 50px 6.48% 70px;
  }

  .ly-history {
    width: 75.52%;
  }

  /*-----事業案内 tab-----*/
  .ly-business-bg {
    margin-top: 60px;
  }

  .ly-business-1st {
    padding: 0 0 30px 0px;
    height: auto;
    background: #fff;
  }

  .ly-business-1stBody {
    width: 52.36%;
  }

  .business-1stTtl {
    font-size: 2.7rem;
  }

  .ly-business-1st {
    height: auto;
  }

  .ly-business-1stImg {
    margin-right: 3.91%;
    margin-left: -90px;
  }

  .ly-business-2nd {
    margin-top: 20px;
    padding: 0 0 0 30px;
  }

  .bl-business-2ndBody {
    width: 55.99%;
  }

  .business-2ndTtl {
    width: auto;
    font-size: 2.7rem;
  }

  .ly-business-2ndtxt {
    margin-right: 11.11%;
    width: 86%;
  }

  .bl-business-2ndImg {
    margin-right: -100px;
    width: auto;
  }

  .ly-business-3rd {
    margin-top: 60px;
    padding: 0 30px;
  }

  .bl-business-3rd {
    display: block;
  }

  .ly-business-3rdImg {
    width: 100%;
  }
  .ly-business-3rdImg .bl-business-3rdImg-1of3 {
    max-width: 100%;
    width: 100%;
  }
  .ly-business-3rdImg img {
    width: 100%;
    object-fit: cover;
  }

  .bl-business-3rdImg-2of3 {
    width: 100%;
  }
  .bl-business-3rdImg-2of3 p {
    max-width: 100%;
    width: 50%;
  }
  .bl-business-3rdImg-2of3 img {
    width: 100%;
    object-fit: cover;
  }

  .business-3rdTtl {
    top: -40px;
    right: 43px;
    left: auto;
    padding: 17px 8px;
    font-size: 27px;
    transform: unset;
  }

  .ly-business-3rdtxt {
    padding: 30px;
    width: 100%;
  }

  .bl-business-3rdsub {
    margin: 0 30px;
    max-width: 100%;
    width: auto;
  }

  .bl-business-3rdsub-inner {
    flex-wrap: wrap;
    justify-content: space-around;
    padding: 20px 125px;
  }

  .bl-business-3rdsub-innerUpper {
    justify-content: space-between;
  }

  .bl-business-3rdsub-innerLower {
    justify-content: space-around;
    margin-top: 20px;
  }

  .ly-business-3rdtxt {
    margin-top: 0;
  }

  .ly-businessProduction-inner {
    margin-top: 70px;
    height: auto;
  }

  .ly-businessProduction-innerTtl {
    text-align: center;
    font-size: 2rem;
  }

  .bl-businessProduction01 {
    display: block;
    margin-top: 30px;
  }

  .bl-businessProduction01-img {
    margin: 0 auto;
    width: 100%;
    text-align: center;
  }

  .bl-businessProduction01-txt {
    margin-top: 30px;
    width: 100%;
  }

  .bl-businessProduction02 {
    display: block;
  }

  .bl-businessProduction02-inner {
    margin-right: 0;
    width: auto;
  }
  .bl-businessProduction02-inner .bl-businessProduction02-innerTtl {
    text-align: center;
    font-size: 2rem;
  }
  .bl-businessProduction02-inner .bl-businessProduction02-innerTtl + p {
    margin-top: 30px;
  }

  .bl-businessProduction02-innerImg {
    margin-top: 30px;
    text-align: center;
  }

  /*-----施設・設備 tab-----*/
  .ly-facilities-common {
    margin: 5.51% auto 0;
    width: 90.63%;
  }

  .ly-facilities-commonImg {
    margin-right: 3.25%;
    padding: 0 18px;
    width: 53.85%;
  }

  .ly-facilities-commonSection {
    width: 42.9%;
  }

  .ly-headingSummary {
    margin-top: 60px;
    padding: 40px;
  }

  .ly-facilities-commonBody {
    display: block;
    margin-top: 60px;
  }

  .ly-facilities-commonImg {
    margin: 0 auto;
    max-width: 531px;
    width: 100%;
  }

  .ly-facilities-commonSection {
    margin: 30px auto 0;
    max-width: 495px;
    width: auto;
  }

  .bl-facilities-commonTtl {
    text-align: center;
    font-size: 2rem;
  }

  .ly-facilities-commonTxt {
    margin: 30px 18px 0;
  }

  .odd {
    padding: 40px;
  }
  .odd.ly-facilities-common {
    margin: 50px auto 0;
    max-width: 611px;
    width: auto;
  }
  .odd .ly-facilities-commonBody {
    padding: 0;
  }
  .odd .ly-facilities-commonImg {
    margin-right: 0;
    width: auto;
  }
  .odd .ly-facilities-commonSection {
    width: auto;
  }
  .odd .bl-facilities-commonTtl {
    text-align: center;
    font-size: 2rem;
  }
  .odd .ly-facilities-commonTxt {
    margin: 30px 0 0;
  }

  .ly-recruitVoice-btn {
    margin: 60px 0 0;
  }

  .ly-recruit-bg {
    padding: 0 30px 50px;
  }

  .ly-recruitVoice-body {
    padding: 30px;
  }

  .btnTab a {
    font-size: 2rem;
  }

  .bl-recruitProfire h3 {
    padding: 24px 5px 10px;
  }

  .bl-recruitProfire-inner {
    margin: 50px 30px 20px 0;
    width: 60.03%;
  }

  .bl-recruitProfire-img {
    width: 140px;
  }

  .ly-recruitTab-section {
    flex-direction: column-reverse;
    margin-top: 30px;
  }

  .bl-recruitTab-img {
    display: flex;
    width: 100%;
  }
  .bl-recruitTab-img p:nth-child(n+2) {
    margin-top: 0;
  }
  .bl-recruitTab-img p {
    width: 50%;
  }
  .bl-recruitTab-img p img {
    width: 100%;
    object-fit: cover;
  }

  .bl-recruitTab-txt {
    margin-top: 30px;
    margin-right: 0;
    width: 100%;
  }

  .ly-recruitTab-section-mt {
    margin-top: 30px;
  }

  .bl-recruitTab-02txt {
    margin-top: 0;
  }

  .bl-recruitTab-02img {
    margin-top: 30px;
    margin-right: 0;
  }

  .ly-recruitment {
    width: 100%;
  }

  .ly-timeschedule-base {
    display: block;
    padding: 40px 88.5px 60px;
  }

  .ly-timeschedule-Section {
    margin-right: 0;
  }

  .bl-timeschedule-Ttl {
    left: 50%;
    transform: translateX(-50%);
  }

  .ly-timeschedule-txt {
    padding: 0 18px;
    line-height: 1.8;
  }

  .ly-timeschedule-img {
    margin-top: 30px;
    margin-right: 0;
    width: 100%;
  }

  .slider figure figcaption {
    padding: 1rem 1.3rem;
  }

  .ly-recruitment {
    margin: 50px auto 0;
  }

  .icon-infoGeneral::after {
    bottom: -72px;
    width: 42px;
    height: 42px;
  }

  .ly-infoGeneral {
    margin-top: 140px;
  }

  .ly-infoPost-lv1ttl {
    margin-top: 140px;
  }

  .ly-infoPost-article h2 {
    font-size: 1.8rem;
    line-height: 1.6;
    margin-top: 60px;
  }
  .ly-infoPost-article h3 {
    font-size: 1.8rem;
    padding-bottom: 12px;
  }
  .ly-infoPost-article h4 {
    font-size: 1.6rem;
    line-height: 1.4;
    margin-top: 20px;
  }
  .ly-infoPost-article p {
    margin-top: 30px;
    line-height: 1.8;
  }
  .ly-infoPost-article .bl-postHorizontal {
    display: block;
    margin-top: 30px;
  }
  .ly-infoPost-article .bl-postHorizontal p {
    width: 100%;
    margin-right: 0;
  }
  .ly-infoPost-article .bl-postHorizontal .bl-postSection {
    width: 100%;
  }
  .ly-infoPost-article .bl-postHorizontal .bl-postSection p {
    margin-top: 20px;
  }
  .ly-infoPost-article .bl-postHorizontal-rev {
    display: block;
    flex-direction: inherit;
    margin-top: 50px;
  }
  .ly-infoPost-article .bl-postHorizontal-rev p {
    width: 100%;
    margin-top: 20px;
    margin-right: 0;
  }
  .ly-infoPost-article .bl-postHorizontal-rev .bl-postSection {
    width: 100%;
  }
  .ly-infoPost-article .bl-postHorizontal-rev .bl-postSection p {
    width: 100%;
    margin-top: 20px;
  }

  .ly-btnpaging {
    margin-top: 50px;
    padding-top: 50px;
  }

  /*-----お問い合わせ contact -----*/
  .ly-contact {
    margin-top: 70px;
  }

  .bl-contactHeading {
    padding: 40px 66px 30px;
  }
  .bl-contactHeading h2 {
    font-size: 2.4rem;
    line-height: 1.2;
  }

  .bl-contactForm {
    padding: 50px 40px;
  }
  .bl-contactForm .el-btnCommon {
    margin-top: 70px;
  }
}
/***** spサイズ *****/
@media screen and (max-width: 767px) {
  html {
    line-height: 1.8;
  }

  .wrapper {
    overflow: hidden;
  }

  .pc-only {
    display: none;
  }

  .pctab-only {
    display: none;
  }

  .sp-only {
    display: block;
  }

  .heading-inc {
    font-weight: bold;
    font-size: 1.4rem;
  }

  .heading-mainCopy {
    letter-spacing: 0.02em;
    font-size: 1.8rem;
  }

  .heading-lv2Large {
    font-size: 1.8rem;
  }

  .heading-lv2-sub {
    font-size: 1rem;
    transform: scale(0.8);
    transform-origin: left top;
  }

  .heading-place {
    font-weight: bold;
    font-size: 2.6rem;
    line-height: 1.153;
  }

  .heading-lv2Medium {
    font-size: 2rem;
  }

  /*-----TOPページ sp-----*/
  .innerHeader {
    padding: 10px 0;
    height: 40px;
  }

  .bl-headerLogo-img {
    margin-top: -10px;
    margin-left: 15px;
    width: 63px;
  }

  .bl-headerLogo-txt {
    margin-left: 8px;
    display: flex;
    align-items: center;
  }

  .kv-video {
    min-height: 270px;
    height: 270px;
    object-fit: cover;
  }
  .kv-video video {
    min-height: 270px;
    object-fit: cover;
  }

  #gloval-nav {
    padding: 40px;
  }

  #bl-navToggle {
    width: 40px;
    height: 40px;
  }
  #bl-navToggle span span {
    left: 10px;
    width: 20px;
    height: 1px;
  }
  #bl-navToggle span span:nth-child(1) {
    top: 22px;
  }
  #bl-navToggle span span:nth-child(2) {
    top: 28px;
  }

  .navToggle-txt {
    top: 10%;
    font-size: 1rem;
    transform: translateX(-50%) scale(0.6);
  }

  /* open */
  .open #bl-navToggle {
    width: 40px;
    height: 40px;
  }
  .open #bl-navToggle span span:nth-child(1) {
    top: 22px;
  }
  .open #bl-navToggle span span:nth-child(2) {
    top: 22px;
  }
  .open .bl-headerNav-wrap {
    padding: 30px 25%;
    border: 1px solid #fff;
  }
  .open .bl-headerInnerLogo-img {
    width: 63px;
  }
  .open .bl-headerNav {
    margin-top: 32px;
    padding: 16px 0 0;
    min-width: 120px;
    border-top: 1px solid #fff;
  }
  .open .bl-headerNav li {
    margin-bottom: 16px;
    font-size: 1.4rem;
  }
  .open .bl-headerNav li:last-child {
    margin-top: 18px;
    font-size: 12px;
  }
  .open .bl-headerNav li:nth-last-child(2) {
    margin-bottom: 0;
  }
  .open .bl-headerNav li a {
    color: #fff;
  }
  .open .bl-headerNav li a.hover-bd::after {
    position: unset;
  }
  .open .bl-headerNav .el-btnContact a {
    margin-top: 27px;
    padding-top: 16px;
    height: auto;
  }
  .open .bl-headerNav .icon-mail::after {
    top: 0;
    width: 20px;
    height: 16px;
  }

  .bd-burger {
    border-top: 1px solid #fff;
  }

  .ly-keyvisual {
    margin-top: 0;
    padding-top: 40px;
    height: 248px;
  }
  .ly-keyvisual::after {
    content: none;
  }

  /*-----TOPページ about sp-----*/
  .bg-contetctMid {
    padding-bottom: 0;
  }

  .position-contetctMid {
    margin-top: -12%;
  }

  .ly-about {
    height: auto;
  }

  .ly-aboutInner {
    margin: 0 auto;
    max-width: 90.63%;
  }

  .about-ttl {
    margin-top: 9px;
  }

  .bl-about {
    display: block;
    margin: 0 auto;
    padding: 10px 10px 38px 10px;
    min-width: 290px;
    max-width: 400px;
    width: auto;
  }

  .bl-about-img {
    margin: 0;
    text-align: center;
  }
  .bl-about-img img {
    max-width: 100%;
    height: 154px;
  }

  .bl-aboutInner {
    display: block;
    width: 100%;
  }

  .bl-aboutTtl {
    margin-left: 0;
  }

  .aboutInner-imgMap:after {
    top: 252px;
    left: -11px;
    width: 145px;
    height: 91px;
  }

  .aboutInner-imgBg:before {
    content: none;
  }

  .bl-aboutInner-txt {
    position: inherit;
    margin: 0 auto;
    max-width: 400px;
  }

  .aboutInner-ttl {
    margin-top: -13px;
    margin-right: 4px;
    text-align: right;
  }

  .bl-aboutSummary {
    margin: 42px 0 0 0;
    max-width: 400px;
    width: auto;
  }

  .bl-aboutTxt {
    margin-right: auto;
    margin-left: auto;
    max-width: 400px;
  }

  .el-btnCommon a {
    margin: 0 auto;
    max-width: 320px;
    width: 100%;
    font-size: 1.6rem;
  }

  .ly-btnAbout {
    margin-top: 30px;
  }

  /*-----TOPページ facility sp-----*/
  .ly-contents {
    padding: 0 15px;
  }

  .ly-facility {
    display: block;
    margin-top: 30px;
    padding-bottom: 30px;
  }

  .ly-facilityInner {
    width: auto;
    height: auto;
    border: none;
  }

  .card-left,
.card-right {
    top: 0;
    max-width: 400px;
    width: auto;
  }

  .card-ttl::after {
    padding-top: 18px;
  }

  .card-txt {
    margin-top: 14px;
  }

  .bl-cardInner {
    padding: 20px;
  }

  .card-right .bl-cardInner {
    margin-top: -29px;
    padding: 20px;
  }

  .ly-txtFacility {
    top: 25vh;
    right: 6px;
  }

  .ly-btnFacility {
    margin-top: 20px;
  }

  /*-----TOPページ diary sp-----*/
  .ly-diary {
    margin: 0;
    padding: 30px 0 50px;
  }

  .bl-diaryTtl p {
    padding-left: 0;
    width: auto;
    border-left: none;
    font-size: 14px;
    line-height: 1.6;
  }

  .bg-diary {
    padding-bottom: 33.4%;
    height: 0;
    background: url(/images/bg-daiary-ttl-sp2x.png) no-repeat;
    background-size: contain;
  }

  .diary-ttl {
    margin: 48px auto 13vw;
    max-width: 400px;
  }

  .diary-ttlInner {
    display: block;
    margin-top: -18%;
    padding: 0 15px;
  }

  .diary-txt {
    margin: -44px auto 0;
    padding: 0 15px;
    max-width: 400px;
    font-size: 14px;
    line-height: 1.6;
  }

  .ly-cardDiary {
    display: block;
    margin: 25px auto 0;
    max-width: 400px;
  }

  .bl-cardDiary {
    margin-bottom: 25px;
    width: 100%;
  }
  .bl-cardDiary:nth-last-child(-n+4) {
    margin-bottom: 25px;
  }
  .bl-cardDiary:last-child {
    margin-bottom: 0;
  }
  .bl-cardDiary .bl-dateandtime {
    margin-top: 0;
    margin-bottom: 3px;
  }
  .bl-cardDiary .bl-dateandtime dt {
    padding: 8px 0px;
    font-size: 1rem;
    line-height: 1;
  }
  .bl-cardDiary .bl-dateandtime dt span {
    padding: 2.5px 6px;
  }
  .bl-cardDiary .bl-dateandtime dd {
    margin-left: 10px;
    font-size: 1.2rem;
  }
  .bl-cardDiary .diaryInner-img {
    padding: 9px 0;
  }
  .bl-cardDiary .diaryInner-img img {
    min-height: 236px;
    object-fit: none;
  }
  .bl-cardDiary .diaryInner-summary {
    margin: 12px auto 23px;
    font-size: 1.4rem;
    line-height: 1.6;
  }

  .ly-btnDaiary {
    margin: 29.5px auto 0;
    max-width: 250px;
  }

  .el-btnCommon a {
    max-width: 100%;
    width: 100%;
  }

  /*-----TOPページ recruit sp-----*/
  .bg-recruit {
    padding: 20px 0;
    height: 120px;
    background: url(/images/bg-recruit-sp.jpg) no-repeat;
    background-size: cover;
  }

  .ly-btnRecruit {
    margin: 20px auto 0;
  }

  .arrow-harf::after {
    margin-left: 10px;
    width: 74px;
    height: 9px;
    background: url(/images/arrowHarf-white-sp.png);
  }
  .arrow-harf:hover::after {
    margin-left: 10px;
    width: 74px;
    height: 9px;
    background: url(/images/arrowHarf-red-sp.png);
  }

  .el-btnBorder a {
    margin: 0 auto;
    max-width: 250px;
    width: auto;
    box-shadow: 0 0 0 3px #222 inset;
    color: #222;
    font-size: 1.6rem;
    line-height: 60px;
  }
  .el-btnBorder a:hover,
.el-btnBorder a:focus {
    background: rgba(34, 34, 34, 0.7);
    color: #fff;
  }
  .el-btnBorder .arrow-harf::after {
    width: 74px;
    height: 9px;
    background: url(/images/arrowHarf-black-sp.png);
  }
  .el-btnBorder .arrow-harf:hover::after {
    width: 74px;
    height: 9px;
    background: url(/images/arrowHarf-white-sp.png);
  }

  /*-----TOPページ info sp-----*/
  .ly-info {
    padding: 40px 0 0;
  }

  .bl-infoTtl {
    height: 86px;
  }

  .icon-info::after {
    width: 40px;
    height: 40px;
  }

  .bl-infoBody {
    margin: 54px auto 0;
    padding: 20px 0;
    max-width: 400px;
  }
  .bl-infoBody .infoInner {
    padding: 20px 0;
  }

  .infoInner-btn {
    display: block;
    line-height: 1.6;
  }
  .infoInner-btn p {
    margin-top: 8px;
    width: 100%;
  }

  .ly-txtLink-info {
    margin: 10px auto 0;
    padding-right: 50px;
    max-width: 400px;
    line-height: 1.6;
  }

  .ly-breadcrumb {
    margin-top: 50px;
    padding: 0 15px;
    min-height: 38px;
    font-weight: normal;
    font-size: 1.2rem;
  }

  /*----- footer sp-----*/
  .ly-footer {
    padding: 30px 0 40px;
  }

  .bl-footerLogo-img {
    width: 52px;
    height: 52px;
  }

  .footerLogo-ttl {
    margin-top: 6px;
  }

  .bl-footerNav {
    margin-top: 30px;
    text-align: center;
  }
  .bl-footerNav li {
    margin-top: 27px;
    width: 100%;
    border-right: none;
  }
  .bl-footerNav li:first-child {
    margin-top: 0;
  }
  .bl-footerNav li:nth-child(n+6) {
    margin-top: 27px;
  }
  .bl-footerNav a {
    padding: 0;
  }

  .copy {
    font-size: 1rem;
  }

  /*-----下層ページ-----*/
  .ly-h1Bg {
    padding-top: 50%;
  }
  .ly-h1Bg h1 {
    padding: 10px 8px;
    font-size: 1.8rem;
  }
  .ly-h1Bg .privacy-h1Bg h1 {
    padding: 8px 10px;
    font-size: 1.8rem;
  }
  .ly-h1Bg p {
    padding: 10px 8px;
    font-size: 1.8rem;
  }

  .ly-privacyContact {
    padding: 20px;
  }
  .ly-privacyContact h2 {
    padding-bottom: 10px;
  }

  .bl-privacyTxt {
    margin-top: 30px;
  }

  .ly-fixNav {
    display: none;
  }

  .ly-company-bg {
    margin-top: 50px;
    padding: 50px 0 90px;
  }
  .ly-company-bg::before {
    height: 50px;
  }

  .ly-company-1st {
    padding: 30px 0;
  }

  .company-Ttl {
    display: block;
    text-align: center;
    font-size: 2rem;
  }
  .company-Ttl .heading-cow img {
    margin-bottom: 20px;
    width: 78px;
  }

  .ly-company-2nd {
    padding: 10px 0;
  }

  .ly-company-img {
    margin: 30px 20px;
  }

  .ly-company-2ndTxt {
    order: 2;
    margin: 74px 15px 0;
    width: auto;
  }

  .company-2ndTtl {
    order: 1;
    margin-top: -70px;
    font-size: 1.8rem;
  }

  .bl-company-2nd {
    padding: 0 0 40px;
  }

  .ly-contentsNone {
    padding: 0;
  }

  .icon-cow::after {
    bottom: -53px;
    width: 79px;
    height: 43px;
    background-size: contain;
  }

  .ly-company-3rd {
    padding: 0 15px;
  }

  .company-3rdTtl {
    top: 0;
    margin-top: 0;
    margin-left: 0;
    height: auto;
    font-size: 2rem;
    white-space: nowrap;
  }
  .company-3rdTtl.heading-cow {
    padding: 17px 0 0;
  }

  .icon-quotation {
    padding: 20px 0;
  }
  .icon-quotation:before {
    left: -17px;
    top: 3px;
    width: 38px;
    height: 29px;
    background-size: contain;
  }
  .icon-quotation:after {
    right: -22px;
    bottom: 3px;
    width: 38px;
    height: 29px;
    background-size: contain;
  }

  .company-imgSp {
    position: absolute;
    top: 0;
    right: 0;
    margin-top: 30px;
    max-height: 240px;
    height: 240px;
  }
  .company-imgSp img {
    width: auto;
    height: 243px;
  }

  .bg-company-3rd {
    background: none;
    background-size: contain;
  }

  .heading-cow {
    padding: 17px 0 0;
  }
  .heading-cow img {
    margin-bottom: 0;
    width: 78px;
    height: 43px;
  }

  .bl-company-3rd {
    margin-top: 20px;
  }

  .bl-company-3rdInner {
    margin-top: 0;
    margin-right: 0;
    margin-left: 0;
    max-width: 100%;
    width: 100%;
  }

  .ly-companyGroupphoto {
    margin-top: 30px;
    padding: 0 15px;
  }
  .ly-companyGroupphoto h3 {
    font-size: 1.6rem;
  }

  .bl-companyGroupphoto-img {
    margin-top: 30px;
  }

  .bg-companyGroupphoto {
    margin-top: -13vh;
  }

  .ly-companyProfile {
    margin: 32px auto 0;
    width: 100%;
  }

  .ly-stack {
    margin-top: 50px;
  }

  .bl-stack {
    display: block;
  }
  .bl-stack.bl-stack-centerSp {
    text-align: center;
  }
  .bl-stack dt.companyProfile-dt, .bl-stack dt.history-dt, .bl-stack dt.recruit-dt {
    width: 100%;
  }
  .bl-stack dd.companyProfile-dd, .bl-stack dd.history-dd, .bl-stack dd.recruit-dd {
    display: inline-block;
    margin-top: 10px;
    width: 100%;
  }
  .bl-stack dd.recruit-dd {
    padding-right: 0;
  }

  .ly-company-map {
    margin-top: 40px;
  }

  .iframe-wrap {
    padding-top: 62.07%;
  }

  .ly-managementPhilosophy {
    margin-top: 50px;
  }

  .headingBd-under::after {
    bottom: -10px;
    width: 40px;
    height: 3px;
  }

  .ly-managementPhilosophy-list {
    display: block;
    width: auto;
    text-align: center;
  }
  .ly-managementPhilosophy-list li {
    margin-top: 20px;
    margin-right: 0;
    width: 100%;
  }
  .ly-managementPhilosophy-list li:first-child {
    margin-top: 0;
  }

  .ly-hygieneManagement {
    margin-top: 50px;
  }

  .ly-hygieneManagement {
    padding: 8px;
  }

  .ly-hygieneManagement-inner {
    padding: 42px 32px;
  }
  .ly-hygieneManagement-inner li {
    display: inline-block;
    text-align: left;
  }

  .bl-hygieneManagement-listNumber {
    margin-right: 0;
    margin-bottom: 40px;
    text-align: center;
  }
  .bl-hygieneManagement-listNumber span {
    padding: 0 5px 10px;
  }

  .ly-history {
    margin: 50px auto 0;
    width: 100%;
  }

  /*-----事業案内 sp-----*/
  .ly-business-bg {
    margin-top: 60px;
    padding: 50px 0 0;
  }
  .ly-business-bg::before {
    height: 50px;
  }

  .ly-business-1st {
    display: block;
    padding: 0;
  }

  .ly-business-1stImg {
    position: relative;
    top: -20px;
    margin: 0 auto;
    max-width: 62.5%;
    width: 100%;
    height: auto;
  }

  .ly-business-1stBody {
    width: auto;
  }

  .business-1stTtl {
    margin-top: 30px;
    text-align: center;
    font-size: 2rem;
  }

  .ly-business-1stTxt {
    margin-top: 30px;
  }

  .ly-business-2nd {
    display: block;
    margin-top: 50px;
    padding: 0;
  }

  .bl-business-2ndBody {
    width: auto;
  }

  .business-2ndTtl {
    text-align: center;
    font-size: 2rem;
  }

  .ly-business-2ndtxt {
    margin: 30px 15px 0;
    width: auto;
  }

  .bl-business-2ndImg {
    margin: 30px 15px 0;
    width: auto;
    height: auto;
  }
  .bl-business-2ndImg img {
    width: 100%;
  }

  .ly-business-3rd {
    margin-top: 50px;
    padding: 0 15px;
  }

  .ly-business-3rdImg {
    max-height: 320px;
  }

  .business-3rdTtl {
    top: 8.5%;
    right: auto;
    left: 50%;
    padding: 0 4px;
    font-size: 20px;
    transform: translateX(-50%);
  }
  .business-3rdTtl .icon-quotation::before {
    top: -18px;
    left: -24px;
  }
  .business-3rdTtl .icon-quotation:after {
    right: -25px;
    bottom: -18px;
  }

  .ly-business-3rdtxt {
    margin-top: 52%;
    padding: 0 20px 30px;
  }

  .bl-business-3rdsub {
    margin: 0 15px;
    padding: 8px;
  }

  .bl-business-3rdsub-inner {
    display: block;
    padding: 20px 25px;
    text-align: center;
  }
  .bl-business-3rdsub-inner li {
    margin-top: 20px;
    margin-right: 0;
  }
  .bl-business-3rdsub-inner li:first-child {
    margin-top: 0;
  }

  .bl-business-3rdsub-innerUpper,
.bl-business-3rdsub-innerLower {
    display: block;
  }

  .ly-businessProduction-inner {
    margin-top: 50px;
    padding: 40px 0;
  }

  .ly-businessProduction,
.bl-businessProduction02 {
    margin-top: 50px;
  }

  .ly-businessProduction-innerTtl,
.bl-businessProduction02-innerTtl {
    line-height: 1.6;
  }

  /*-----施設・設備 sp-----*/
  .ly-headingSummary {
    margin-top: 50px;
    padding: 20px;
  }

  .ly-facilities-common {
    margin: 50px 15px 0;
  }

  .prev-arrow {
    left: 0;
    width: 24px;
  }

  .next-arrow {
    right: 0;
    width: 24px;
  }

  .ly-facilities-commonImg {
    padding: 0;
  }

  .bl-facilities-commonTtl {
    font-size: 1.8rem;
  }

  .ly-facilities-commonTxt {
    margin: 20px 0 0;
  }

  .odd {
    padding: 40px 15px 30px;
  }
  .odd .ly-facilities-commonSection {
    margin-top: 20px;
    margin-right: 0;
  }

  .slider-main figure figcaption {
    padding: 0.6rem 1rem;
    font-size: 1rem;
  }

  .ly-recruit-bg {
    padding: 0 15px 50px;
  }

  .btnTab {
    padding: 8px 0 9px;
    margin-bottom: -1px;
    width: 50%;
  }
  .btnTab a {
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1.4;
  }

  .bl-recruitProfire {
    display: block;
    align-items: unset;
  }
  .bl-recruitProfire h3 {
    display: block;
    margin-right: 0;
    margin-top: -1px;
    padding: 11px 90px 10px;
    text-align: center;
    font-size: 1.6rem;
    transform: rotate(0deg);
    writing-mode: unset;
  }

  .ly-recruitVoice-body {
    padding: 10px 15px 30px;
  }

  .bl-recruitProfire-img {
    margin: 15px auto 0;
  }

  .bl-recruitProfire-inner {
    margin: 8px 3.44% 3.44%;
    max-width: 100%;
    width: auto;
  }

  .bl-recruitProfire ul {
    display: block;
  }
  .bl-recruitProfire li {
    padding: 0;
    border-right: none;
    text-align: center;
    line-height: 1.625;
  }

  .bl-recruitProfire-inner p {
    margin-top: 20px;
  }

  .ly-recruitTab-body {
    margin-top: 20px;
  }

  .bl-recruitTab-ttl {
    padding: 10px 15px;
    color: #fff;
    font-size: 1.6rem;
    line-height: 1.6;
  }

  .ly-recruitTab-section {
    margin-top: 20px;
  }

  .bl-recruitTab-img {
    display: block;
  }
  .bl-recruitTab-img p {
    width: 100%;
  }

  .bl-recruitTab-txt,
.ly-recruitTab-section-mt {
    margin-top: 20px;
  }

  .ly-timeschedule {
    margin-top: 50px;
  }

  p.bl-timeschedule img {
    padding: 0 15px;
    width: 100%;
  }

  .bl-timeschedule {
    margin-top: 40px;
  }

  .ly-timeschedule-base {
    display: block;
    padding: 0;
    border: none;
  }

  .ly-timeschedule-1st {
    margin-top: 50px;
  }

  .ly-timeschedule-txt {
    margin-top: 20px;
    padding: 0;
  }

  .ly-timeschedule-img {
    margin-top: 20px;
    padding: 0;
  }

  .slick-dots {
    margin-top: 6px;
  }

  .ly-timeschedule-2nd,
.ly-timeschedule-3rd {
    margin-top: 50px;
  }

  .odd .ly-timeschedule-img {
    margin-left: 0;
  }

  .icon-infoGeneral::after {
    bottom: -64px;
    width: 34px;
    height: 34px;
  }

  .ly-infoGeneral {
    margin-top: 124px;
  }
  .ly-infoGeneral .bl-infoBody {
    max-width: 100%;
  }

  .ly-infoPost-lv1ttl {
    margin-top: 124px;
  }

  .heading-lv1Post {
    font-size: 1.8rem;
    line-height: 1.4;
  }

  .bl-infoPost-time {
    font-size: 1.4rem;
  }

  .ly-infoPost-article h2 {
    font-size: 1.6rem;
    margin-top: 50px;
  }
  .ly-infoPost-article h3 {
    font-size: 1.6rem;
    padding-bottom: 10px;
    margin-top: 30px;
  }
  .ly-infoPost-article h4 {
    margin-top: 30px;
  }
  .ly-infoPost-article .bl-postHorizontal-rev {
    margin-top: 30px;
  }
  .ly-infoPost-article .bl-quote {
    width: auto;
    margin-left: 0;
    padding: 20px;
    border: 3px solid #e2dfd8;
  }
  .ly-infoPost-article .bl-quote::before {
    top: -30px;
    left: 20px;
  }
  .ly-infoPost-article .ly-btnpaging {
    padding-top: 40px;
    font-size: 14px;
  }
  .ly-infoPost-article .ly-btnpaging .bl-preview p,
.ly-infoPost-article .ly-btnpaging .bl-next p {
    margin-top: 0;
  }
  .ly-infoPost-article .ly-btnpaging .bl-preview p:first-child,
.ly-infoPost-article .ly-btnpaging .bl-next p:first-child {
    margin-right: 10px;
  }

  .ly-diaryPage {
    padding: 0 15px;
    margin-top: 90px;
  }

  .ly-btnpaging-Number {
    width: auto;
  }
  .ly-btnpaging-Number .bl-btnpaging-Number {
    margin: 0;
  }

  /*-----お問い合わせ contact -----*/
  .ly-contact {
    margin-top: 60px;
  }

  .bl-contactHeading {
    padding: 20px 10px 14px;
  }
  .bl-contactHeading h2 {
    font-size: 1.8rem;
    line-height: 1.4;
  }

  .bl-contactForm {
    border: 8px solid #e2dfd8;
    padding: 12px 10px;
  }
  .bl-contactForm .el-btnCommon {
    margin-top: 50px;
  }
}