﻿#contents{
	margin: 50px auto;
}
#contents .sec {
	padding-bottom: 50px;
    margin: 50px auto;
}
@media screen and (max-width:768px) {
  #contents .sec {
    padding-bottom: 0;
  }
}
#contents p {
  font-size: .875rem;
	font-weight: 400;
  line-height: 1.5;
  letter-spacing: .04em;
  margin-bottom: 0;
}
@media screen and (max-width:768px) {
  #contents p {
    line-height: 1.6;
    letter-spacing: 0;
  }
  #contents p.notes {
    margin-bottom: 20px;
  }
}
.note, #contents p.note {
  font-size: 12px;
  line-height: 1.5;
}
#contents p.note {
  margin-top: 10px;
}

/*-------main visual---------*/

.relative {
    position: relative;
}
#mv{
  width: 100%;
  height: calc(100vh - 250px);
  overflow: hidden;
  background: url(../img/safety/main.jpg);
  background-position: center left;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #mv{
  background: url(../img/safety/main-sp.jpg);	  
  background-position: top center;
  background-size: cover;
}
}
#mv .mv_img{
  object-fit: cover;
  object-position: center center;
}
#mv .mv_ttl{
  position: absolute;
  width: 41.33vw;
  top: 14.13vw;
}
#mv .mv_copy{
  position: absolute;
  width: 40.13vw;
  bottom: 10.13vw;
  right: 4.4vw;
}
@media screen and (min-width: 480px) {
#mv .mv_copy{
  width: 40.13vw;
}
}
@media screen and (min-width: 768px) {
  .img_note{
		font-size: 1.21vw;
  }

  #mv{
    height: calc(100vh - 105px);
    background: url(../img/safety/main.jpg);
    background-position: top left;
    background-size: cover;
  }
  #mv .mv_ttl{
    width: 15.71vw;
    top: 6.85vw;
  }
  #mv .mv_copy{
    position: absolute;
    width: 51.78vw;
    bottom: 15px;
    right: 3.92vw;
  }
}
@media screen and (min-width: 1400px) {
  .img_note{
		font-size: 17px;
  }

  #mv .mv_ttl{
    width: 220px;
    top: 96px;
  }
  #mv .mv_copy{
    width: 325px;
    right: 55px;
  }
}
@media screen and (max-height: 700px) and (min-width: 768px) {
  #mv .mv_copy {
    width: 40.78vh;
  }
}
@media screen and (min-height: 700px) and (min-width: 768px) {
  #mv .mv_copy {
    width: 25.78vh;
  }
}
@media screen and (max-width: 768px) and (min-width: 520px) {
  #mv{
    background-position: center center;
  }
}

.subttl {
  color: #958244;
  font-size: 40px;
  letter-spacing: .12em;
  text-align: center;
  margin-bottom: 25px;
  line-height: 1.2;
}
@media screen and (max-width:768px) {
  .subttl {
    font-size: 26px;
    margin-bottom: 15px;
  }
}
h4.lead {
  margin-bottom: 40px;
  font-size: 20px;
  line-height: 1.2;
  text-align: center;
  letter-spacing: 0;
}
@media screen and (max-width:768px) {
  h4.lead {
    margin-bottom: 25px;
    font-size: 16px;
    line-height: 1.6;
  }
}
.hd01 {
  color: #958244;
  font-size: 1.125rem;
  letter-spacing: .04em;
  line-height: 1.5;
  margin-bottom: 5px;
}
@media screen and (max-width:768px) {
  .hd01 {
    font-size: 1rem;
    letter-spacing: 0;
  }
}
.hd02 {
  font-size: 1rem;
  letter-spacing: .04em;
  line-height: 1.5;
  text-align: center;
  background: #EAE6D9;
  padding-block: 8px;
  margin-bottom: 10px;
}
@media screen and (max-width:768px) {
  .hd02 {
    letter-spacing: 0;
    padding: 8px;
  }
}
#contents em {
  color: #958244;
  font-size: 1rem;
}
#contents img {
  object-fit: cover;
  vertical-align: bottom;
}
.img:has(.cap) {
  position: relative;
}
.img > .cap {
  position: absolute;
  bottom: 0;
  right: 5px;
  font-size: .6em;
}
.cap.wh {
  color: #fff;
}
.cap.br{
	color: #B7B7B7;
}
@media screen and (max-width:768px) {
  .img > .cap {
    font-size: .4em;
    bottom: 3px;
  }
}
.nav-local.half li {
  width: 50%;
}
.flex.col-4 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.flex.col-4 > li {
  width: 23.02%;
}
@media screen and (max-width:768px) {
  .flex.col-4 {
    gap: 20px;
  }
}
.flex.col-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
.flex.col-3 > li {
  width: calc(100% / 3 - 20px);
}
@media screen and (max-width:768px) {
  .flex.col-3, .flex.col-4 {
    column-gap: 20px;
    justify-content: space-between;
  }
  .flex.col-3 > li, .flex.col-4 > li {
    width: 46.05%;
  }
}
.flex .img {
  margin: 0;
  margin-bottom: 10px;
}
.flex.col-2 {
  display: flex;
  justify-content: space-between;
}
.flex.col-2:has(>.txt, >.img) {
  row-gap: 20px;
}
.flex.col-2 > div {
  width: 48.44%;
}
@media screen and (max-width:768px) {
  .flex.col-2 {
    flex-direction: column;
    row-gap: 20px;
  }
  .flex.col-2:has(>.txt, >.img) {
   flex-direction: row;
        row-gap: 10px;
        align-items: center;
  }
  .flex.col-2 > div {
    width: 100%;
  }
}
.multimedia {
  width: 85.81%;
}
.flex.col-2.afterservice .txt {
  width: 56.77%;
}
.flex.col-2.afterservice .img {
  width: 39.35%;
}
.flex.col-2.secsystem .txt, .flex.col-2.secsystem > .img {
  width: 48.44%;
}
.flex.col-2.secsystem .txt > .img {
  width: 29.89%;
  margin: 15px auto 0;
}
@media screen and (max-width:768px) {
  .flex.col-2.secsystem {
    flex-direction: column;
  }
  .flex.col-2.secsystem .txt, .flex.col-2.secsystem > .img {
    width: 100%;;
  }
  .flex.col-2.secsystem .txt > .img {
    width: min(150px, 29.89%);
    margin: 15px auto 0;
  }
}
.flex.col-2.handsfreekey .txt {
  width: 100%;
	display: flex;
    justify-content: space-evenly;
    align-items: center;
	margin-bottom: 15px;
}
@media screen and (max-width:768px) {
	.flex.col-2.handsfreekey .txt {
  width: 100%;
}
}

.flex.col-2.handsfreekey > .img {
  width: 100%;
}
.flex.col-2.handsfreekey .txt > .img {
 /* width: 91.19%;*/
  margin: 15px auto 0;
}
.flex.col-2.spec .txt {
  width: 64.95%;
}
.flex.col-2.spec > .img {
  width: 30.75%;
}
.flex.col-2.hatch .txt {
  width: 54.41%;
}
.flex.col-2.hatch > .img {
  width: 41.51%;
  margin-bottom: 0;
}
@media screen and (max-width:768px) {
  .flex.col-2.afterservice .txt {
    width: calc(63% - 10px);
  }
  .flex.col-2.afterservice .img {
    width: 37%;
  }
}
.mb60 {
  margin-bottom: 60px;
}
.mb30{
	margin-bottom: 50px !important;
}
@media screen and (max-width:768px) {
  .mb30 {
    margin-bottom: 50px !important;
  }
  .mb60 {
    margin-bottom: 30px !important;
  }
}

.flex.col-2.ame {
	gap: 50px;
	margin-bottom: 70px;
}
.flex.col-2.ame p{
	margin-bottom: 20px!important;
}

/*--- 資料請求ボタン ---*/
#entry {
  padding-top: 9.33vw;
  border-top: 1px solid #c9caca;
  text-align: center;
  padding-bottom: 40px;
}
#entry .entry_txt {
  font-size: 3.2vw;
  font-weight: 500;
  color: #000000;
  margin-bottom: 2em;
}
#entry .entry_btn {
  display: block;
  width: 73.33vw;
  margin-left: auto;
  margin-right: auto;
}
#note {
  width: 93.33vw;
  margin-left: auto;
  margin-right: auto;
  font-size: 2.66vw;
  text-align: justify;
  line-height: 1.25;
  letter-spacing: 0;
  margin-top: 13vw;
  margin-bottom: 6.5vw;
}
@media screen and (min-width: 768px) {
  #entry {
    padding-top: 6.42vw;
  }
  #entry .entry_txt {
    font-size: 1.21vw;
    margin-bottom: 1.3em;
  }
  #entry .entry_btn {
    width: 42.85vw;
  }
  #note {
    width: 89vw;
    font-size: 0.85vw;
    margin-top: 6.78vw;
    margin-bottom: 5.35vw;
  }
}
@media screen and (min-width: 1400px) {
  #entry {
    padding-top: 90px;
  }
  #entry .entry_txt {
    font-size: 17px;
  }
  #entry .entry_btn {
    width: 600px;
  }
  #note {
    width: 1246px;
    font-size: 12px;
    margin-top: 95px;
    margin-bottom: 75px;
  }
}
@media screen and (max-width: 768px) {
  #note .note_txt {
    font-size: 2.66vw;
  }
}

.pabbit{
	text-align: center;
	margin-top: 60px!important;
}

.pabbit img{
	width: 80%;
}

.footer{
	text-align: center;
	margin-bottom: 40px;
}
.txt.kagi {
	display: flex;
}
.txt.kagi{
	margin-right: 15px;
}
.img.key{
	margin-top: -20px;
}

.flex.col-2.handsfreekey{
	display: unset;
}

@media screen and (max-width: 768px) {
#security{
	padding: 0 25px;
}

.safe{
	padding: 0 25px;
}
.p{
	padding: 0 25px;
}
	.left{
		margin-bottom: 30px;
	}
	#comfortable{
		padding: 0 25px;
	}
	
}
