@charset "UTF-8";
/* 
  css設定 @charsetが消されるsass仕様へのハック用コメントです。削除しないでください。新規作成時も必須！
 */
/*==================================================================================
 common
==================================================================================*/
html {
  font-size: .3125vw;
}

.allWrap {
  padding-top: 50rem;
}

main .caption {
  font-size: 10rem;
}

.commonCatch01 {
  font-size: 20rem;
}

.commonCatch02 {
  font-size: 18rem;
}

.commonCatch03 {
  font-size: 16rem;
}

.commonLead01 {
  line-height: 1.7;
  font-size: 14rem;
}
.commonLead01.lineHeightSmall {
  line-height: 1.4;
}

.commonLead02 {
  line-height: 1.7;
  font-size: 13rem;
}
.commonLead02.lineHeightSmall {
  line-height: 1.4;
}

.commonLead03 {
  line-height: 1.9;
  font-size: 12rem;
}
.commonLead03.lineHeightSmall {
  line-height: 1.5;
}

.commonText01 {
  line-height: 1.4;
  font-size: 11rem;
}
.commonText01.lineHeightSmall {
  line-height: 1.2;
}

.commonTitle01 {
  padding-bottom: 25rem;
}
.commonTitle01 img {
  padding-bottom: 10rem;
  height: 18rem;
}
.commonTitle01 .ja {
  font-size: 14rem;
}

.commonTitle02 {
  padding-bottom: 40rem;
}
.commonTitle02.bottomSpaceSmall {
  padding-bottom: 15rem;
}
.commonTitle02 .ja {
  gap: 0 5rem;
  padding-bottom: 12rem;
  font-size: 13rem;
}
.commonTitle02 .ja:before {
  width: 6rem;
  height: 6rem;
}
.commonTitle02 img {
  height: 16rem;
}

.sections:not(:last-of-type) {
  padding-bottom: 80rem;
}
.sections > header {
  padding-bottom: 30rem;
}

/*==================================================================================
 siteHeader
==================================================================================*/
.siteHeader {
  position: fixed;
  padding: 0 10rem;
  height: 50rem;
  background: rgba(245, 245, 237, 0.9);
}
.siteHeader .headerLogo {
  width: 160rem;
  height: 100%;
  background: url("../img/common/logo-blink02.svg") no-repeat center center;
  background-size: 100% auto;
}
.siteHeader .headerLogo img {
  display: none;
}
.siteHeader .menuButton {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 40rem;
  height: 16rem;
}
.siteHeader .menuButton span {
  position: relative;
  width: 100%;
  height: 1rem;
  background: #376C3C;
  transition: transform .3s, opacity .3s, top .3s, left .3s;
}
.siteHeader .menuButton.open span {
  background: #376C3C;
}
.siteHeader .menuButton.open span:first-child {
  top: 8rem;
  transform: rotate(30deg);
}
.siteHeader .menuButton.open span:nth-child(2) {
  left: 100%;
  opacity: 0;
}
.siteHeader .menuButton.open span:last-child {
  top: -7rem;
  transform: rotate(-30deg);
}
.siteHeader .globalNavi {
  display: flex;
  align-items: center;
  display: none;
  position: absolute;
  top: 50rem;
  right: 0;
  left: 0;
  height: calc(100svh - 50rem);
  background: rgba(245, 245, 237, 0.9);
}
.siteHeader .globalNavi .links {
  flex: 0 0 100%;
  flex-direction: column;
  justify-content: center;
  gap: 50rem 0;
  padding-bottom: 30rem;
}
.siteHeader .globalNavi .links li a img {
  height: 18rem;
}

/*==================================================================================
 siteFooter
==================================================================================*/
.siteFooter {
  flex-direction: column;
  align-items: center;
  justify-content: normal;
  gap: 40rem 0;
  margin-top: 80rem;
  padding-top: 40rem;
  padding-bottom: 20rem;
  text-align: center;
}
.siteFooter .logoArea {
  flex: 0 0 auto;
}
.siteFooter .logoArea .logo {
  margin: auto;
  padding-bottom: 15rem;
  width: 100rem;
}
.siteFooter .logoArea address {
  padding-bottom: 20rem;
  font-style: normal;
  line-height: 1;
  font-size: 13rem;
}
.siteFooter .logoArea .numbers {
  flex-direction: column;
  justify-content: normal;
  gap: 15rem 0;
}
.siteFooter .logoArea .numbers li {
  font-size: 12rem;
}
.siteFooter .linksArea {
  flex: 0 0 auto;
}
.siteFooter .linksArea .footerNavi .links {
  display: flex;
  gap: 0 20rem;
  padding-bottom: 40rem;
}
.siteFooter .linksArea .footerNavi .links li a img {
  height: 10rem;
}
.siteFooter .linksArea .informations {
  flex-direction: column;
  align-items: center;
  justify-content: normal;
  gap: 20rem 0;
  padding-left: 0;
}
.siteFooter .linksArea .informations .textArea {
  padding-bottom: 0;
}
.siteFooter .linksArea .informations .textArea .en {
  padding-bottom: 10rem;
}
.siteFooter .linksArea .informations .textArea .en img {
  height: 13rem;
}
.siteFooter .linksArea .informations .links {
  flex: 0 0 auto;
}
.siteFooter .linksArea .informations .links li .text {
  padding-bottom: 5rem;
}
.siteFooter .copyright {
  flex: 0 0 auto;
  padding-top: 0;
  font-size: 10rem;
}

/*==================================================================================
 top
==================================================================================*/
#top .mainVisual {
  margin-bottom: 80rem;
  padding-left: 0;
}
#top .mainVisual h2 {
  top: 24.609375vw;
  left: 10vw;
}
#top .mainVisual h2 img {
  width: 70vw;
}
#top .mainVisual h2 .ja {
  font-size: 3vw;
}
#top section.aboutUs .image {
  padding-bottom: 15rem;
}
#top section.aboutUs .textArea {
  flex-direction: column;
  align-items: normal;
  justify-content: normal;
  gap: 15rem 0;
}
#top section.aboutUs .textArea .texts {
  flex: 0 0 auto;
}
#top section.aboutUs .textArea .texts .catch {
  padding-bottom: 8rem;
}
#top section.aboutUs .textArea .button {
  flex: 0 0 auto;
  margin: auto;
  width: 160rem;
}
#top section.aboutUs .textArea .button img {
  width: 100%;
}
#top section.ourBusiness {
  margin-bottom: 80rem;
  padding: 80rem 0;
}
#top section.ourBusiness .button {
  margin: auto;
  width: 160rem;
}
#top section.ourBusiness .button img {
  width: 100%;
}
#top section.ourBusiness .businesses li:not(:last-child) {
  padding-bottom: 60rem;
}
#top section.ourBusiness .businesses li .image {
  padding-bottom: 20rem;
  height: 48vw;
}
#top section.ourBusiness .businesses li .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#top section.ourBusiness .businesses li .text01 {
  padding-bottom: 10rem;
}
#top section.ourBusiness .businesses li .text01 img {
  height: 8rem;
}
#top section.ourBusiness .businesses li .text02 {
  padding-bottom: 15rem;
}

/*==================================================================================
 lower common
==================================================================================*/
.lower .commonPageTitle01 {
  display: block;
  margin-bottom: 80rem;
  padding: 30rem 0 0;
  height: auto;
}
.lower .commonPageTitle01 .image {
  position: static;
  width: 100%;
}

/*==================================================================================
 aboutUs
==================================================================================*/
#aboutUs section.profile .tableArea {
  max-width: none;
}
#aboutUs section.profile .tableArea dl {
  flex-direction: column;
  gap: 8rem 0;
  align-items: normal;
  margin-bottom: 15rem;
  padding-bottom: 15rem;
}
#aboutUs section.profile .tableArea dt,
#aboutUs section.profile .tableArea dd {
  padding: 0 10rem;
  line-height: 1.5;
}
#aboutUs section.profile .tableArea dt {
  flex: 0 0 auto;
  font-size: 14rem;
}
#aboutUs section.profile .tableArea dd {
  flex: 0 0 auto;
  flex-direction: column;
  gap: 10rem 0;
  align-items: normal;
  justify-content: normal;
  font-weight: normal;
  font-size: 13rem;
}
#aboutUs section.profile .tableArea .googleMapButton {
  width: 120rem;
}
#aboutUs section.philosophy .philosophys {
  margin-left: 0;
  max-width: none;
}
#aboutUs section.philosophy .philosophys li {
  flex-direction: column;
  gap: 15rem 0;
  align-items: normal;
}
#aboutUs section.philosophy .philosophys li:not(:last-child) {
  padding-bottom: 60rem;
}
#aboutUs section.philosophy .philosophys .image {
  flex: 0 0 auto;
  margin: auto;
  width: 50%;
}
#aboutUs section.philosophy .philosophys .image img {
  width: 100%;
}
#aboutUs section.philosophy .philosophys dl {
  flex: 1 1 auto;
}
#aboutUs section.philosophy .philosophys dt {
  margin-bottom: 15rem;
  padding-bottom: 8rem;
}

/*==================================================================================
 ourBusiness
==================================================================================*/
#ourBusiness section.security,
#ourBusiness section.automobile {
  padding-right: 12rem;
  padding-left: 12rem;
}
#ourBusiness section.security h2,
#ourBusiness section.automobile h2 {
  margin-left: 0;
}
#ourBusiness section.security .image,
#ourBusiness section.automobile .image {
  padding-bottom: 20rem;
}
#ourBusiness section.security .lead + .lead,
#ourBusiness section.automobile .lead + .lead {
  padding-top: 1.25em;
}

/*==================================================================================
 contact
==================================================================================*/
#contact form {
  font-size: 14rem;
}
#contact form .lead {
  padding-bottom: 30rem;
}
#contact form dl {
  flex-direction: column;
  gap: 10rem 0;
}
#contact form dl + .lead {
  margin-top: 30rem;
  padding-top: 40rem;
}
#contact form dt,
#contact form dd {
  font-size: 14rem;
}
#contact form dt {
  padding-bottom: 15rem;
}
#contact form dd + dd {
  padding-top: 15rem;
}
#contact form dd .annotation {
  font-size: 12rem;
}
#contact select {
  height: 40rem;
  text-indent: .5em;
  font-size: 14rem;
}
#contact input[type="text"],
#contact input[type="email"],
#contact input[type="tel"],
#contact textarea {
  padding: 0 .5em;
  height: 40rem;
  font-size: 14rem;
}
#contact textarea {
  padding: .5em;
  min-height: 180rem;
}
#contact .privacy {
  margin-top: 30rem;
  padding-top: 40rem;
}
#contact .privacy .text01 {
  padding-bottom: 12rem;
}
#contact .privacy .checkArea {
  margin-bottom: 10rem;
  padding: 25rem 10rem;
}
#contact .privacy label {
  font-size: 14rem;
}
#contact .buttons {
  flex-direction: column;
  justify-content: normal;
  gap: 15rem 0;
  padding-top: 30rem;
}
#contact .buttons button[type="submit"],
#contact .buttons input[type="submit"],
#contact .buttons a {
  width: 80%;
  height: 50rem;
  line-height: 48rem;
  font-size: 14rem;
}

/*# sourceMappingURL=smartphone.css.map */
