@charset "UTF-8";

html {
  font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
}

label {
  display: none;
}

.link {
  color: #4f7ee0;
}

.link:hover {
  color: #83a6ee;
  transition: 0.6s;
}

/*-------------------------------
ヘッダー
-------------------------------*/
.header__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 10px 0;
  background: #fff;
}

.header__logo a {
  display: block;
  width: 300px;
}

.header__logo img {
  width: 300px;
}

.header__wrap {
  /*display: flex;*/
  position: relative;
  top: -40px;
  max-width: 1200px;
  margin: 0 auto 20px;
  /*justify-content: flex-end;*/
}

.header__button1 {
  position: absolute;
  right: 1vw;
	top:0;
	margin:-10px 0px 0px 0px;
	padding:0;
}
.header__button1 a {
  padding: 8px 20px 8px 10px;
  border: #c50029 2px solid;
  background: #fff;
	font-size:12px;
	font-weight:bold;
}

.header__button1 a:hover {
  background: #c50029;
  color: #fff;
  transition: 0.6s;
}

.header__button1 a::before {
	vertical-align:middle;
  content: "";
  display: inline-block;
  width: 16px;
  height: 20px;
  margin-right: 10px;
  transition: .2s linear;
  background: url(../img/ico_people.png) no-repeat left 0;
  background-size: 100% 100%;
}

.header__button2 {
  position: absolute;
  right: 200px;
	top:0;
	margin:-10px 0px 0px 0px;
	padding:0;
}
.header__button2 a {
  width: 300px;
	font-size:12px;
	font-weight:bold;
  padding: 10px 20px 10px 10px;
  margin-right: 10px;
  background: #174c8c;
  color: #fff;
}
.header__button2 a:hover {
  background: #f5c32c;
  color: #174c8c;
  transition: 0.6s;
}
.header__button2 a::before {
	vertical-align:middle;
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 10px;
  transition: .2s linear;
  background: url(../img/ico_yen.png) no-repeat left 0;
  background-size: 100% 100%;
}

.header__button3 {
  position: absolute;
  right: 420px;
	text-align:center;
	margin:-20px 0px 0px 0px;
	padding:0px;
}

.header__button3 .contact__tel__number {
	margin:2px 0px 0px;
	font-size:20px;
	font-weight:bold;
	line-height:1;
}

.header__button3 .contact__tel__number:before {
  content: "";
  display: inline-block;
  width: 0.8em;
  height: 0.8em;
  background: url(../img/phone.png) no-repeat;
  background-size: contain;
}

.contact-text{
	font-size:13px;
	line-height:1;
}
.contact-tel{
	font-weight:bold;
	margin:2px 0px;
	line-height:1;
}

.contact-data{
	font-size:11px;
	line-height:1;
}

.contact-data span{
	font-size:10px;
}


@media screen and (max-width:820px) {
.header__logo a {
  width: 200px;
}
.header__logo img {
  width: 200px;
}
.header__button3 {
	margin:-10px 0px 0px 0px;
}
}

@media screen and (max-width:800px) {
  .header__inner {
    max-width: 1200px;
    margin: 0;
    padding: 0px;
  }

  .header__logo, .header__button1, .header__button2 {
    display: none;
  }
}

@media screen and (max-width:480px) {}

/*--- dropdown menu ---*/
.sp__nav {
  display: none;
}

.dropdwn {
	font-size: 12px;
  display: flex;
  position: relative;
  top: -10px;
  max-width: 1200px;
}

nav ul {
  text-align: center;
  list-style-type: none;
  margin: 0 auto;
  padding: 0;
  color: #222;
}

nav li {
	border-left:1px solid #174c8c;
  display: block;
  position: relative;
  max-width: calc(1200px/6);
  /*padding-bottom: 3px;*/
  cursor: pointer;
	color:#014694;
}
nav li.car-sale {
	border-left:none;
	background:#c50029;
	color:#fff;
}
.dropdwn>li {
	display: inline;
	width: 1200px;
	padding: 10px 5px 0px;
	background: #fff;
	z-index: 3;
	font-size: 12px;
}

.dropdwn>li a {
  display: block;
}

.dropdwn>li:after {
  content: '';
  width: 0;
  padding-top: 10px;
  transition: all 0.3s ease;
  border-bottom: 3px solid #174c8c;
  display: block;
}

.dropdwn>li:hover:after {
  width: 100%;
  border-bottom: 3px solid #174c8c;
}

.dropdwn>li.on:after {
  content: '';
  width: 100%;
  padding-top: 10px;
  border-bottom: 3px solid #174c8c;
  display: block;
}
.nav-about a[href*=about],
.company a[href*=company],
.business a[href*=business],
.news a[href*=news],
.contact a[href*=contact] {
  
  border-bottom: 3px solid #174c8c;

}
.dropdwn_menu {
  width: 95%;
  display: none;
  position: absolute;
  margin-top: 10px;
  padding: 0;
	color:#fff;
  background: #174c8c;
}

.dropdwn_menu li {
  width: 100%;
  margin-top: -1px;
  border-top: #fff solid 1px;
	border-left:none;
}

.dropdwn_menu li:last-child {
	border-right:none
}

.dropdwn_menu li a {
  padding: 15px 5px;
  margin: 0;
  display: block;
  color: #fff;
}

.dropdwn_menu li a:hover {
  margin: 0;
  background: rgba(247, 250, 252, 0.8);
  color: rgb(65, 65, 65);
}

.Toggle {
  display: none;
}
@media screen and (max-width:820px) {

.dropdwn>li {
	font-size: 11px;
	line-height:12px;
	padding: 10px 0px 0px;
}
.dropdwn>li:nth-child(1) {
	width:13%
}
.dropdwn>li:nth-child(2) {
	width:17%
}
.dropdwn>li:nth-child(3) {
	width:13%
}
.dropdwn>li:nth-child(4) {
	width:14%
}
.dropdwn>li:nth-child(5) {
	width:14%
}
.dropdwn>li:nth-child(6) {
	width:14%
}
.dropdwn>li:nth-child(7) {
	width:15%
}
}

@media screen and (max-width:800px) {
  .pc__nav {
    display: none;
  }

  .sp__nav {
    display: block;
    position: fixed;
    width: 100%;
    z-index: 999;
  }

  #logo img {
    width: 200px;
  }

  nav {
    width: 100%;
    height: 70px;
    position: relative;
    background: #fff;
  }

  nav li {
    max-width: none;
  }

  .drawer {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    position: relative;
    height: 80px;
    padding: 0 1em;
    background: #fff;
    border-bottom: #e6edf2 1px solid;
    z-index: 999;
  }

  /*ナビゲーション部分*/
  .menu ul li .menu__contact__btn {
    padding: 15px;
    background: #014694;
  }
  .menu__contact__tel {
		color:#fff;
		margin:0px;
	}
	.contact-text{
		margin:5px auto;
	}

  .menu__contact__tel .contact__tel__number {
	margin:2px 0px 0px;
	font-size:24px;
	font-weight:bold;
	line-height:1;
	}
  .menu__contact__tel .contact__tel__number:before {
		content: "";
		display: inline-block;
		width: 0.8em;
		height: 0.8em;
		background: url(../img/phone_sp.png) no-repeat;
		background-size: contain;
	}
	.contact-data{
		margin:5px auto;
	}

  .menu__contact__btn a {
    display: block;
    margin: 5px auto 0;
    padding: 5px 10px;
    background-color: #fff;
    color: #014694;
    font-size: 16px;
    width: 220px;
    line-height: 20px;
    border-radius: 5px;
  }

  .menu ul li .menu__contact {
    background: #014694;
    border-bottom: #274073 2px solid;
  }

  .menu ul li .menu__contact a {
    padding: 1em;
    color: #fff;
  }

  .menu ul li p a {
    display: block;
    margin: -1px 0 0 0;
    padding: 1em 0 1em 3em;
    border: 1px solid #014694;
    color: #333;
    text-decoration: none;
  }

  .menu {
    text-align: center;
    background-color: #fff;
    transition: 0.5s ease;
    /*滑らかに表示*/
    -webkit-transform: translateY(-125%);
    /*画面より100%外へ押し出し非表示にさせる*/
    /*  transform: translateX(-100%);/*右から出す場合は、マイナス100%としてください*/
  }

  /*OPEN時の動き*/
  .menu.open {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    /*メニューを元の位置へ戻す*/
  }

  /*トグルボタンのスタイルを指定*/
  .Toggle {
    display: block;
    position: fixed;
    /* bodyに対しての絶対位置指定 */
    right: 6vw;
    width: 42px;
    height: 42px;
    cursor: pointer;
    z-index: 3;
  }

  .Toggle span {
    display: block;
    position: absolute;
    width: 50px;
    border-bottom: solid 4px #014694;
    -webkit-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    transition: .35s ease-in-out;
    /*変化の速度を指定*/
  }

  /*各ボーダー少しずつずらす*/
  .Toggle span:nth-child(1) {
    top: 5px;
  }

  .Toggle span:nth-child(2) {
    top: 18px;
  }

  .Toggle span:nth-child(3) {
    top: 32px;
  }

  .Toggle.active span:nth-child(1) {
    top: 18px;
    /* 1番目のspanをマイナス45度に */
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  /* 2番目と3番目のspanを45度に */
  .Toggle.active span:nth-child(2),
  .Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  .Toggle .Toggle_label {
    position: absolute;
    top: 35px;
    left: 4px;
    border-bottom: none;
		color:#014694;
  }

  /*アコーディオンメニュー*/
  .menu-container .menu-title {
    position: relative;
    margin: -2px 0 0 0;
    padding: 1em;
    background-color: #fff;
    font-size: 1em;
    font-weight: normal;
    color: #222;
    cursor: pointer;
    border: 1px solid #014694;
    text-align: left;
  }

  .menu-container .menu-title::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    width: 15px;
    height: 2px;
    /*縦線に*/
    transform: rotate(90deg);
    background: #222;
    transition: all .3s ease-in-out;
  }

  .menu-container .menu-title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    /*横線*/
    width: 15px;
    height: 2px;
    background: #222;
    transition: all .2s ease-in-out;
  }

  .menu-container .menu-title.open::before {
    transform: rotate(180deg);
  }

  .menu-container .menu-title.open::after {
    opacity: 0;
  }

  li .menu-title a {
    display: block;
    margin: -1px 0 0 0;
    padding: 1em;
    border: 1px solid #014694;
    color: #333;
    text-decoration: none;
    text-align: left;
  }
  .menu-content {
    margin-top: -1px;
    background: #fff;
    text-align: left;
  }
}

@media screen and (max-width:480px) {
  .drawer {
    height: 60px;
  }

  .Toggle {
    display: block;
    position: fixed;
    /* bodyに対しての絶対位置指定 */
    top: 3vw;
    width: 30px;
    height: 30px;
    cursor: pointer;
    z-index: 3;
  }

  .Toggle span {
    display: block;
    position: absolute;
    width: 35px;
    border-bottom: solid 4px #014694;
    -webkit-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    transition: .35s ease-in-out;
    /*変化の速度を指定*/
  }

  /*各ボーダー少しずつずらす*/
  .Toggle span:nth-child(1) {
    top: 5px;
  }

  .Toggle span:nth-child(2) {
    top: 16px;
  }

  .Toggle span:nth-child(3) {
    top: 27px;
  }

  .Toggle.active span:nth-child(1) {
    top: 18px;
    /* 1番目のspanをマイナス45度に */
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  /* 2番目と3番目のspanを45度に */
  .Toggle.active span:nth-child(2),
  .Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  .Toggle .Toggle_label {
    position: absolute;
    top: 33px;
    left: 0px;
    font-size: 0.8em;
    border-bottom: none;
		color:#014694;
  }
}

/*-----------------------------
PCスクロール固定
-----------------------------*/
#header {
  position: relative;
  height: 165px;
}

.header {
  height: 165px;
  background: #fff;
}

.sticky-header {
  position: fixed;
  width: 100%;
  height: 50px;
  z-index: 11;
  transition: 0.25s;
  background: #fff;
  border-bottom: #e6edf2 1px solid;
}

.sticky-header__inner {
  display: flex;
  position: relative;
  top: -38px;
  max-width: 1200px;
  margin: 0 auto;
}

.sticky-header .header__logo {
  position: relative;
	margin:0px;
  padding: 0px;
  order: 1;
  width: 150px;
}
.sticky-header .header__logo img {
  width: 9vw;
}

.sticky-header__inner .dropdwn-wrap {
  position: absolute;
  top: 40px;
  left: 9vw;
  order: 2;
}

.sticky-header .header__button2 {
  position: absolute;
  top: 40px;
  right: 0;
}

.sticky-header .header__button2 a {
  position: relative;
  top: 9px;
  padding: 10px;
  font-size: 11px;
	line-height:0;
}

.sticky-header .dropdwn {
  top: 9px;
  align-items: center;
}

.sticky-header nav li {
  max-width: calc(749px/7);
  line-height: 1.2em;
}

.sticky-header .dropdwn>li {
  width: 750px;
  font-size: 11px;
}


.sticky-header .dropdwn>li.on:after {
  content: '';
  width: 100%;
  padding-top: 15px;
  border-bottom: 3px solid #174c8c;
  display: block;
}

.sticky-header .dropdwn_menu {
  width: 93%;
}

.sticky-header .dropdwn_menu li a {
  padding: 10px 5px;
}

.sticky-header .item1 {
  flex: 1 3 160px;
}

.sticky-header .item2 {
  flex: 3 1 800px;
}

.sticky-header .item3 {
  flex: 2 2 120px;
}

@media screen and (min-width:1500px) {
  .sticky-header__inner {
    top: -55px;
  }

  .sticky-header .header__logo{
    top: 60px;
  }
  .sticky-header .header__logo img {
    width: 160px;
  }
  .sticky-header .header__button2 {
    top: 65px;
  }
}

@media screen and (max-width:1500px) and (min-width:1094px) {
  .sticky-header .header__logo {
    top: 60px;
  }

  .sticky-header .header__logo img {
    width: 9vw;
  }

  .sticky-header .dropdwn {
    top: 0px;
  }
	.sticky-header__inner .dropdwn-wrap {
		left: 9vw;
	}

}

@media screen and (max-width:1093px) and (min-width:900px) {
  .sticky-header .header__logo {
    top: 60px;
  }

  .sticky-header nav li {
  max-width: calc(749px/7);
  }

  .sticky-header .dropdwn>li {
    font-size: 1.1rem;
  }

  .sticky-header .dropdwn {
    top: 3px;
  }

  /*  .sticky-header .header__button2 a {
    width: 80px;
  }
  */
}

@media screen and (max-width:900px) and (min-width:800px) {
  .sticky-header .header__logo {
    top:30px;
  }

  .sticky-header .dropdwn {
    top: 3px;
  }
	
  .sticky-header nav li {
  max-width: calc(549px/7);
  }

  .sticky-header .dropdwn>li {
    font-size: 10px;
  }


}

}

@media screen and (max-width:800px) {
  #header {
    height: auto;
  }
}

@media screen and (max-width:480px) {}

/*-----------------------------
sub nav
-----------------------------*/
.subnav {
  padding: 10px;
  background: #f7fafc;
}

.subnav__inner {
  max-width: 1200px;
  margin: 0 auto;
  font-size: 11px;
}

@media screen and (max-width:800px) {
  .subnav {
    display: none;
  }
}

@media screen and (max-width:480px) {}



/*-----------------------------
pagename
-----------------------------*/
.pagename__h2 {
  max-width: 1200px;
  margin: 20px auto;
  padding: 0.25em 0.5em;
  /*上下 左右の余白*/
  background: transparent;
  /*背景透明に*/
  font-weight: bold;
  font-size: 1.5rem;
	line-height:180%;
	letter-spacing:5px;
}
.pagename__h2 span {
  font-size: 2.2rem;
	color:#fff;
	padding:5px 10px;
	letter-spacing:0px;
	line-height:180%;
}
.h3_no {
  padding: 8px;
  font-size: 4rem;
	margin-bottom:15px;
}
@media screen and (max-width:800px) {
  .h2__inner {
		margin-top:-100px;
    padding-top: 0px;
  }
.pagename__h2 {
	line-height:200%;
}
.pagename__h2 span {
  font-size: 2rem;
	padding:5px;
}
.h3_no {
  font-size: 3rem;
	margin-bottom:5px;
}
}

@media screen and (max-width:480px) {
  .h2__inner {
    padding-top: 0px;
  }
	.pagename__h2 {
		line-height:150%;
	}
	.pagename__h2 span {
		font-size: 1.2rem;
	}
	.h3_no {
			font-size: 2.5rem;
	}
}


/*-----------------------------
モーダル
-----------------------------*/
.modal__wrap {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.content {
  margin: 0 auto;
  padding: 40px;
}

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 15;
}

.modal__bg {
  background: rgba(0, 0, 0, 0.6);
  width: 100vw;
  height: 100vh;
  position: absolute;
}

.modal__content {
  background: #fff;
  left: 50%;
  padding: 40px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  z-index: 20;
}

.modal__wrap {
  display: flex;
}

.modal__img {
  padding-right: 20px;
}

.modal__text {
  font-size:14px;
  font-weight: bold;
  line-height: 1.2em;
}

.modal__text--catch {
  font-size: 24px;
  line-height: 1.2em;
}

.modal__text p {
  margin-bottom: 20px;
}

.modal__text span {
  font-size: 18px;
  font-weight: normal;
}

.modal__dl {
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  white-space: normal;
  justify-content: center;
}

.modal__dl dt {
  width: 20%;
  padding: 5px 10px;
  background: #f5f4f0;
  border: #ebe9e4 1px solid;
  text-align: center;
  margin: 0 -1px -1px 0;
}

.modal__dl dd {
  width: 20%;
  padding: 5px 10px;
	background:#fff;
  border: #ebe9e4 1px solid;
  text-align: center;
  margin: 0 -1px -1px 0;
}

.modal__close {
  position: absolute;
  top: 5px;
  right: 20px;
  font-size: 30px;
}

@media (max-width: 820px) {
  .modal__dl dt {
    width: 40%;
  }

  .modal__dl dd {
    width: 40%;
  }
}


@media screen and (max-width:480px) {
  .modal__content {
    top: 56%;
    padding: 50px 20px 20px 20px;
  }

  .modal__wrap {
    flex-direction: column;
  }

  .modal__img {
    margin: 0 auto;
    padding: 0px;
  }

  .modal__text {
    font-size: 18px;
    margin-bottom: 10px;
  }

  .modal__text p {
    line-height: 1.4em;
    margin-bottom: 10px;
  }

  .modal__dl {}

  .modal__dl dt {
    width: 40%;
  }

  .modal__dl dd {
    width: 40%;
    text-align: left;
  }

  .modal__close {
    top: 0px;
    right: 8px;
  }

  .modal__scroll {
    height: 350px;
    overflow-y: auto;
  }

  .modal__scroll::-webkit-scrollbar {
    width: 5px;
    height: 80%;
  }

  .modal__scroll::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 50, .5);
    border-radius: 10px;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .3);
  }

  .modal__scroll::-webkit-scrollbar-track-piece {
    border-radius: 10px;
    box-shadow: inset 0 0 5px rgba(0, 0, 0, .1);
  }
}

/*-----------------------------
content image
-----------------------------*/
.content {
  max-width: 1200px;
  margin: 0 auto 60px;
}

.content__catch {
  position: relative;
  max-width: 1200px;
  margin: 20px auto 40px;
  padding-left: 20px;
	font-size:1.2rem;
	line-height:160%;
	font-weight:bold;
}

@media screen and (max-width:800px) {
  .content {
    padding: 20px;
  }

  .content__catch {
    margin: 20px 0;
  }
}

@media screen and (max-width:480px) {
  .content__catch {
    margin: 18px 0;
	font-size:0.8rem;
  }

  .content__catch span {
	font-size:0.8rem;
  }
}

/*-------------------------------
コンタクト
-------------------------------*/
#contact {
  padding-top: 100px;
  margin-top: -100px;
}

/*電話*/
.contact__tel {
  max-width: 1200px;
  margin: 0 auto 80px;
}

.contact__tel__line {

}

.contact__tel__h2 {
  margin: 40px;
  padding-top: 40px;
  font-size: 24px;
  text-align: center;
}

.contact__tel__number {
  margin-bottom: 30px;
  font-size: 40px;
  text-align: center;
}

.contact__tel__number:before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background: url(../img/phone.png) no-repeat;
  background-size: contain;
}

.contact__tel__text {
  margin-bottom: 10px;
  font-size: 18px;
  text-align: center;
}

.contact__tel__small {
  font-size: 16px;
  text-align: center;
}

/*メールフォーム*/
.contact__form {
  margin: 0 auto;
  padding: 40px;
  background: #014694;
  color: #FFF;
}

.contact__form__wrap {
  width: 600px;
  margin: 0 auto;
}

.contact__form__h2 {
  margin-bottom: 40px;
  font-size: 36px;
  text-align: center;
}

.contact__form__small {
  float: right;
  font-size: 14px;
  margin-right: 36px;
}

.contact__form__link {
  text-align: center;
}

.contact__form__link:after {
  content: ">";
}

.contact__form__small span {
  color: #c40885;
}

.contact__form form dl {
  margin: auto;
}

.contact__form form dl dt {
  width: 165px;
  margin-top: 18px;
  float: left;
  clear: both;
}

.contact__form form dl dt span {
  color: #c40885;
}

.contact__form form dl dd {
  display: inline-block;
  padding: 15px 0;
}

.contact__form form dl dd input,
.contact__form form dl dd textarea {
  background: #FFF;
}

.contact__form form .companyname,
.contact__form form .address,
.contact__form form .name,
.contact__form form .email,
.contact__form form .tel {
  width: 400px;
  border-radius: 6px;
}

.contact__form form .message {
  width: 400px;
  height: 150px;
  border-radius: 6px;
}

.contact__form form button {
  display: block;
  margin: 0 auto 30px;
  background-color: #f5ad4b;
  color: #ffffff;
  font-size: 16px;
  width: 220px;
  text-align: center;
  line-height: 40px;
  border-radius: 5px;
}

.contact__form form button:hover {
  background: #f5c32c;
  cursor: pointer;
  transition: 0.6s;
}

input, textarea {
  padding: 10px;
  color: #222;
}

input::placeholder {
  color: #bbb;
  font-size: 14px;
}

/*IE*/
input:-ms-input-placeholder {
  color: #bbb;
  font-size: 14px;
}

@media screen and (max-width:480px) {

  /*電話*/
  .contact__tel {
    padding: 0 20px;
  }

  .contact__tel__h2 {
    margin: 0 0 40px;
    font-size: 22px;
    text-align: center;
  }

  .contact__tel__number {
    margin-bottom: 30px;
    font-size: 30px;
    text-align: center;
  }

  .contact__tel__text {
    margin-bottom: 20px;
  }

  /*メールフォーム*/
  .contact__form {
    /*width: 100%;*/
    padding: 20px;
  }

  .contact__form__wrap {
    width: 100%;
  }

  .contact__form__h2 {
    font-size: 23px;
  }

  .contact__form__small {
    float: right;
    margin-right: 0;
  }

  .contact__form__link {
    text-align: center;
  }

  .contact__form__link:after {
    content: ">";
  }

  .contact__form form dl {
    margin: auto;
  }

  .contact__form form dl dt {
    margin-top: 18px;
    float: none;
		width:90%;
  }

  .contact__form form dl dd {
    display: inline-block;
    padding: 15px 0;
  }

  .contact__form form .companyname,
  .contact__form form .address,
  .contact__form form .name,
  .contact__form form .email,
  .contact__form form .tel {
    width: 70vw;
  }

  .contact__form form .message {
    width: 70vw;
  }

  input::placeholder {
    line-height: 1.5em;
  }
}

/*-------------------------------
footer
-------------------------------*/
.footer {
  padding: 20px 100px;
  background: #fff;
}

/*コピーライト*/
.footer__copy {
  font-size: 12px;
  text-align: center;
}

/*topへ戻る*/
.pagetop {
  position: fixed;
  bottom: 45px;
  right: 45px;
  width: 60px;
  height: 60px;
  line-height: 60px;
  background: #4f7ee0;
  border-radius: 60px;
  z-index: 2
}

.pagetop a:before {
  display: block;
  content: '';
  border-top: solid 2px;
  border-right: solid 2px;
  transform: rotate(-45deg);
  position: absolute;
  top: 10px;
  bottom: 0;
  left: 0;
  right: 0;
  width: 20px;
  height: 20px;
  margin: auto;
  color: #fff;
}

.pagetop p a {
  display: block;
  color: #fff;
  text-decoration: none;
}

.pagetop p a:hover {
  background: #6792eb;
  color: #fff;
  border-radius: 60px;
}

@media screen and (max-width:800px) {
  .footer {
    /*width: 100%;*/
    padding: 20px;
  }

  .footer__bnr__wrap {
    justify-content: center;
    align-items: center;
  }

  .footer__bnr {
    height: 60px;
    margin-right: 0px;
    padding: 0 0 20px;
  }

  /*コピーライト*/
  .footer__copy {
    font-size: 12px;
    text-align: center;
  }

  /*コピーライト*/
  .footer__copy {
    font-size: 12px;
    text-align: center;
  }

  .footer__bnr {
    height: 60px;
    margin-right: 10px;
  }

  .pagetop {
    position: fixed;
    bottom: 20px;
    right: 6vw;
    width: 60px;
    height: 60px;
    line-height: 60px;
    background: #4f7ee0;
    border-radius: 60px;
    z-index: 9999;
  }
}

@media only screen and (max-width: 480px) {
  .footer__bnr__wrap {
    flex-direction: column;
  }

  .pagetop {
    bottom: 28px;
    right: 6vw;
    width: 50px;
    height: 50px;
    line-height: 50px;
    background: #4f7ee0;
    border-radius: 60px;
    z-index: 9999;
  }
}

/*pc sp　切り替え*/
/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc {
  display: inline-block;
}

.sp {
  display: none;
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 750px) {
  .pc {
    display: none;
  }

  .sp {
    display: inline-block;
  }
}
