﻿/*----------------------------------------
全体
----------------------------------------*/
.wrapper{
	width: 96%;
}
.pc {
	display: none;
}

.pc.tab {
	display: block;
}

.pc.tab.mobi {
	display: block;
}

.tab {
	display: block;
}

.tab.mobi {
	display: block;
}

.pc.mobi {
	display: none;
}

.mobi {
	display: none;
}

.tab-s{
	display: block !important;
}
.pc.tab-s {
	display: none !important;
}

/*----------------------------------------
header
----------------------------------------*/
header{
	overflow: hidden;
	height: 80px;
}
.head-in{
	padding: 0;
}
#sp-menu-box{
	position: fixed;
	top:0;
	right: 0;
	width: 80px;
	z-index: 8888;
}
#sp-menu-box .inner{
	align-items: center;
	flex-wrap: nowrap;
	height: 80px;
	line-height: 80px;
}
.sp-menu .inner li {
	flex-grow: 1;
	text-align: center;
}
#sp-menu-box .tel{
	flex-grow: 1;
	flex-basis: auto;
	background: rgb(215,23,21);
	background: -moz-linear-gradient(287deg, rgba(215,23,21,1) 0%, rgba(180,8,7,1) 51%, rgba(215,23,21,1) 100%);
	background: -webkit-linear-gradient(287deg, rgba(215,23,21,1) 0%, rgba(180,8,7,1) 51%, rgba(215,23,21,1) 100%);
	background: linear-gradient(287deg, rgba(215,23,21,1) 0%, rgba(180,8,7,1) 51%, rgba(215,23,21,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#d71715",endColorstr="#d71715",GradientType=1);
}
#sp-menu-box .mail{
	flex-grow: 1;
	flex-basis: auto;
	background: rgb(0,155,99);
	background: -moz-linear-gradient(287deg, rgba(0,155,99,1) 0%, rgba(108,164,121,1) 51%, rgba(0,155,99,1) 100%);
	background: -webkit-linear-gradient(287deg, rgba(0,155,99,1) 0%, rgba(108,164,121,1) 51%, rgba(0,155,99,1) 100%);
	background: linear-gradient(287deg, rgba(0,155,99,1) 0%, rgba(108,164,121,1) 51%, rgba(0,155,99,1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#009b63",endColorstr="#009b63",GradientType=1);
}
#sp-menu-box a{
	display: block;
	text-align: center;
	text-decoration: none;
	color: #fff;
}
#sp-menu-btn{
	flex-basis: 80px;
	width: 80px;
	height: 80px;
	background: #303f9f;
	color: #fff;
	text-align: center;
}
#sp-menu-btn.active .menu-trigger::before {
	transform: rotate(45deg) scaleX(1);
	transition-delay: .2s;
}
#sp-menu-btn.active .menu-trigger::after {
	transform: rotate(-45deg) scaleX(1);
	transition-delay: .2s;
}
#sp-menu-btn.active .menu-trigger span {
	transform: scaleX(0);
	transition-delay: 0s;
}
.sp-menu{
	position: fixed;
	top:80px;
	width: 100vw;
	text-align: center;
	background: #fff;
	z-index: 9999;
}
.sp-menu li{
	padding: 2vw 0;
	border-bottom: solid 1px #0058a4;
}
.sp-menu li a{
	text-decoration: none;
	color: #000;
}
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 50px;
	height: 44px;
	background: none;
	border: none;
	appearance: none;
	cursor: pointer;
	top:22px;
}
.menu-trigger:focus:not(:focus-visible) {
	outline: none;
}
.menu-trigger::before,
.menu-trigger::after {
	content: '';
}
.menu-trigger::before,
.menu-trigger::after,
.menu-trigger span {
	position: absolute;
	width: 100%;
	height: 2px;
	background: #fff;
	border-radius: 4px;
	transform-origin: 50% 50%;
	transition: .2s;
}
.menu-trigger::before {
	top: 15px;
	left: 0;
	transform: rotate(45deg) scaleX(0);
}
.menu-trigger::after {
	top: 15px;
	right: 0;
	transform: rotate(-45deg) scaleX(0);
}
.menu-trigger span:nth-of-type(1) {
	top: 0;
	left: 0;
	transition-delay: .2s;
}
.menu-trigger span:nth-of-type(2) {
	top: 12px;
	left: 0;
	transition-delay: .2s;
}
.menu-trigger span:nth-of-type(3) {
	top: 25px;
	left: 0;
	transition-delay: .2s;
}
.menu-trigger span:nth-of-type(4){
	top: 34px;
	left: 0;
	right: 0;
	margin: auto;
	background: none;
	color: #fff;
	font-size: 14px;
	letter-spacing: 2px;
	font-weight: 400;
} 
#sp-menu-btn.active .menu-trigger::before {
	transform: rotate(45deg) scaleX(1);
	transition-delay: .2s;
}
#sp-menu-btn.active .menu-trigger::after {
	transform: rotate(-45deg) scaleX(1);
	transition-delay: .2s;
}
#sp-menu-btn.active .menu-trigger span {
	transform: scaleX(0);
	transition-delay: 0s;
}

/*----------------------------------------
リスト
----------------------------------------*/
.list-common ul{
	width: 48%;
}

/*----------------------------------------
メインイメージ
----------------------------------------*/
#main-img{
	padding: 20px 0 0;
}

/*----------------------------------------
お問い合わせ
----------------------------------------*/
.contact-tel-mail-box{
	justify-content: space-between;
	margin: 10px auto;
	width: 96%;
}
.contact-tel, .contact-mail{
	width: 47%;
}
.contact-tel-num{
	letter-spacing: -0.1rem;
}

/*211228 改修 ここから*/
.contact-tel-p {
    left: -5vw;
}
.contact-tel-p img{
	width: 23vw;
    height: auto;
}
/*211228 改修 ここまで*/
/*----------------------------------------
ご安心ください
----------------------------------------*/
#omakase-mm{
	background-position: center;
}

/*----------------------------------------
メリット
----------------------------------------*/
.merit-list li{
	width: 48%;
}

/*----------------------------------------
ポイント
----------------------------------------*/
.point-ex-box-contents{
	flex-wrap: wrap;
}
.point-ex-box-contents .img{
	margin: 20px auto;
}
.point-ex-box-contents{
	align-items: flex-start;
}
.point-ex-box .arrow{
	white-space: nowrap;
	text-align: center;
	margin: 30px 5px;
}
.point-ex-box .arrow::after{
	left: 10%;
}
.point-ex-explain{
	max-width: calc(96% - 100px);
}
.point-ex-explain::before {
	left: 10px;
}

/*----------------------------------------
事務所のご案内
----------------------------------------*/
#profile .wrapper{
	width: 96%;
}
#fee .attention dt{
	padding: 20px;
}

/*----------------------------------------
よくあるご質問
----------------------------------------*/
#qa dt .q-text {
    width: calc(92% - 65px);
}
/*----------------------------------------
footer
----------------------------------------*/
#footer_fixed{
	display: block;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100vw;
	height: 55px;
	display: flex;
	flex-wrap: nowrap;
	z-index: 9999;
}
#footer_fixed .tel{
	background: #8dcdf1;
	color: #303f9f;
	text-align: center;
	line-height: 55px;
	font-size: 15.5px;
	text-decoration: none;
	display: block;
	width: 50vw;
	letter-spacing: -0.05em;
}
#footer_fixed .mail{
	background:rgb(186,116,24);
	color: #fff;
	text-align: center;
	line-height: 55px;
	font-size: 15.5px;
	text-decoration: none;
	display: block;
	width: 50vw;
	letter-spacing: -0.05em;
}
#footer_fixed .tel span{
	position: relative;
	padding-left: 20px;
}
#footer_fixed .tel span::before{
    content: '';
    position: absolute;
    background: url(images/tel.png) no-repeat;
    width: 18px;
    height: 26px;
    top: 4px;
    left: 0px;
    background-size: 100%;
}
#footer_fixed .mail span{
	position: relative;
	padding-left: 18px;
}
#footer_fixed .mail span::before {
    position: absolute;
    content: "";
    top: 8px;
    left: 0;
    background: url(images/mail.png) no-repeat;
    background-size: 100%;
    width: 16px;
    height: 15px;
}
#copyright{
	padding-bottom:40px;
}
.pagetop {
	bottom: 34px !important;
}



/*----------------------------------------
Edge CSSハック
----------------------------------------*/

@supports (-ms-ime-align: auto) {



}

/*----------------------------------------
IE11以下 CSSハック
----------------------------------------*/

@media screen\0 {



}

/*----------------------------------------
Firefox CSSハック
----------------------------------------*/

@-moz-document url-prefix() {



}

/*----------------------------------------
Safari CSSハック
----------------------------------------*/

_::-webkit-full-page-media, _:future, :root .num-list li {
	margin-left: 30px !important;
}

_::-webkit-full-page-media, _:future, :root .num-list li:nth-child(n+10) {
	margin-left: 40px !important;
}