/* CSS Document */
@media (min-width: 641px) and (max-width: 1024px) {
  body,
  .nav_wrap.fixed,
  #mainvisual,
  header,
  footer {
    min-width: 1300px;
  }

  .tgl_menu_list ul li.nav_mega_menu .mega_menu_wrap {
    width: 1300px;
  }
}
@media screen and (max-width:640px) {
body {
  font-size: 14px;
}

body,
.nav_wrap.fixed,
#mainvisual .inner,
header,
footer {
  min-width: 100%;
}

/* ナビ展開時スクロール禁止処理 */
body.nav-open {
  overflow: hidden !important;
}

/*============================================================================

  header

============================================================================*/

  header {
    display: none;
  }

/*============================================================================

  nav

============================================================================*/

.nav_wrap {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background: none;
	transition: 0.2s;
	padding:5px;
	background:#fff;
}

.nav_wrap .header_logo {
	position:relative;
	z-index:1000;
  width: calc(100% - 56px);
}

.nav_wrap .header_logo a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
}
.nav_wrap .header_logo a img{
	transition:.1s;
	/* -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1); */
}
.nav_wrap .header_logo a .white{
	opacity:0;
	visibility: hidden;
	display:none;
}

.nav_wrap .header_logo img {
  width: auto;
  height: 55px;
}

/* ハンバーガーボタン */
.btn_tgl_menu {
  position: relative;
  right: 0;
  color: #fff;
  width: 55px;
	height:55px;
	background:#DD8140;
  /* background: rgb(3 ,33, 55); */
  /* background: none; */
  border: none;
  padding: 0;
  margin: 0;
  text-align: center;
  transition: right 0.6s cubic-bezier(.19, 1, .22, 1);
}

.btn_tgl_menu i {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 5px;
  margin: auto;
  font-style: normal;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.1em;
}

.btn_tgl_menu span {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  display: block;
  width: 35px;
  height: 2px;
  background: #fff;
  transition: all 0.6s cubic-bezier(.19, 1, .22, 1);
  opacity: 1;
}

.btn_tgl_menu span:nth-of-type(1) {
  top: 14px;
}

.btn_tgl_menu span:nth-of-type(2) {
  top: 26px;
}

.btn_tgl_menu span:nth-of-type(3) {
  top: 38px;
}

/* MENUボタン押下時 */
.btn_tgl_menu.active {
  /* right: 16.25rem; */
	z-index:10000;
}

.btn_tgl_menu.active span:nth-of-type(1) {
  top: 26px;
  transform: rotate(225deg);
}

.btn_tgl_menu.active span:nth-of-type(2) {
  opacity: 0;
}

.btn_tgl_menu.active span:nth-of-type(3) {
  top: 26px;
  transform: rotate(-225deg);
}

/* ドロップダウンメニュー */
.tgl_menu_list {
  position: fixed;
  top: -100%;
  right: 0;
  z-index: 2;
  overflow: hidden;
  width: 100%;
  height: 100%;
  transition: top 1s cubic-bezier(.19, 1, .22, 1);
  background: #f3eada;
  padding:77px 15px 15px;
}
.tgl_menu_list .header_logo a{
	padding: 3px 0 3px;
}

.tgl_menu_list ul {
  flex-flow: column wrap;
  gap:0;
	padding:20px 0 60px;
}

.tgl_menu_list ul li {
  display: block;
  /* border-bottom: 1px solid #fff; */
  width: 100%;
}

.tgl_menu_list ul li.nav_single_menu > a::after, .tgl_menu_list ul li.nav_single_menu > p::after{
	content:none;
}

/* .tgl_menu_list ul li:first-child {
  border-top: 1px solid #fff;
} */

.tgl_menu_list ul li::after {
  display: none;
}

.tgl_menu_list ul li a,
.tgl_menu_list ul li p {
  display: block;
  text-align: left;
  padding: 15px 10px;
  width: auto;
  font-weight: 600;
	font-size:15px;
	font-family: メイリオ, Meiryo,"游ゴシック体", "Yu Gothic", YuGothic, "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

	.tgl_menu_list ul li a::before,.tgl_menu_list ul li:first-child a::before{
	  position: static;
    display: inline;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f105";
    margin-right: 10px;
    border: none;
    background: none;
	}
.tgl_menu_list ul li p::before,.tgl_menu_list ul li a::after, .tgl_menu_list ul li p::after{
	content:none;
}

.tgl_menu_list ul li a span,
.tgl_menu_list ul li p span {
  display: none;
}

.tgl_menu_list ul li a:hover {
  color: #fff;
}

.tgl_menu_list ul li.sp_btn{
	display:flex;
	gap:5px;
}


.tgl_menu_list ul li a.contact_sp{
	border:none;
	text-align:center;
	padding:25px 10px 10px;
	background:#BF4F00;
	font-size:14px;
	border:none;
	width:100%;
	display:flex;
	align-items: center;
	justify-content: center;
	height:60px;
	color:#fff;
	border-radius:5px;
}
.tgl_menu_list ul li a.contact_sp em{
  position: absolute;
  top: 13px;
  font-size: 10px;
  font-weight: 400;
}
/* .tgl_menu_list ul li a.contact_sp em{
  position: absolute;
  bottom: 13px;
  font-size: 10px;
  font-weight: 400;
} */

.tgl_menu_list ul li a.contact_sp em::before{
	position:absolute;
	top:0;
  right: -4px;
  width: 1px;
  height: 12px;
  transform: rotate(24deg);
	background:#fff;
	content:"";
}

.tgl_menu_list ul li a.contact_sp em::after{
	position:absolute;
	top:0;
  left: -4px;
  width: 1px;
  height: 12px;
  transform: rotate(-24deg);
	background:#fff;
	content:"";
}

.tgl_menu_list ul li a.contact_sp img{
	margin:0 5px 0 0;
	width:20px;
}

.tgl_menu_list ul li a.tel_sp{
	border:none;
	margin:0;
	text-align:center;
	background:#4D8912;
	font-size:17px;
	padding:12px 10px;
	border:none;
	width:100%;
	display:flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height:60px;
	color:#fff;
	gap:3px;
}

.tgl_menu_list ul li a.tel_sp span{
	font-size:14px;
	margin:0 5px 0 0;
	display:inline-block;
}

.tgl_menu_list ul li a.tel_sp small{
	font-size:12px;
}

.tgl_menu_list ul li a.tel_sp::before,.tgl_menu_list ul li a.contact_sp::before{
	content:none;
}

body.nav-open .tgl_menu_list {
  overflow-y: scroll;
  top: 0%;
}


body.nav-open .tgl_menu_list ul li.sp_btn{
	position:fixed;
	bottom:0;
	left:0;
	padding:5px;
}
/* ------- スライドメニュー シングル------- */
.tgl_menu_list ul li.nav_single_menu div {
  position: static;
  opacity: 1;
  visibility: visible;
  width: 100%;
  padding-bottom: 10px;
  box-shadow: none;
	display:flex;
	flex-wrap: wrap;
	margin:0 0 0 10px;
}
.tgl_menu_list ul li.nav_single_menu > a{
	padding: 15px 10px 10px;
}

.tgl_menu_list ul li.nav_single_menu div a {
  margin-left: 15px;
  background: none;
  padding: 3px;
  line-height: 1.5;
  text-indent: -1.2em;
  padding-left: 1.2em;
  border-bottom: none;
	width:calc(50% - 15px);
	font-size:13px;
	border:none;
}

.tgl_menu_list ul li.nav_single_menu div a::before {
  position: static;
  display: inline;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "-";
  margin-right: 10px;
	border:none;
  background:none;
}

.tgl_menu_list ul li.nav_single_menu div a i.nav_arrow {
  display: none;
}

.tgl_menu_list ul li.nav_single_menu div a:hover {
  color: #fff;
  background: none;
}

/* ------- スライドメニュー メガ------- */
.tgl_menu_list .nav_mega_menu {
  position: relative;
}

.tgl_menu_list .nav_mega_menu p::before {
  position: absolute;
  display: flex;
  align-items: center;
  width: auto;
  height: auto;
  border: none;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f067";
  transform:none;
}

.tgl_menu_list .nav_mega_menu .mega_menu_wrap {
  display: none;
  position: static;
  opacity: 0;
  visibility: hidden;
  background: none;
  box-shadow: none;
  transition: height 0.5s cubic-bezier(.19, 1, .22, 1);
}

.tgl_menu_list .nav_mega_menu.active .mega_menu_wrap {
  opacity: 1;
  visibility: visible;
}

.tgl_menu_list .mega_menu_inner {
  display: block;
  padding: 0 0 10px 0;
  width: 100%;
}

.tgl_menu_list .mega_menu_top a {
  padding: 12px 12px 12px 0;
}

.tgl_menu_list .mega_menu_top a::before {
  position: static;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f105";
  border: none;
  margin-right: 10px;
}

.tgl_menu_list .menu_list {
  margin-left: 0;
}

.tgl_menu_list .nav_mega_menu .mega_menu_inner .menu_list p {
  display: none;
}

.tgl_menu_list .nav_mega_menu .mega_menu_inner .menu_list li {
  border: none !important;
}
.tgl_menu_list .nav_mega_menu .mega_menu_inner .menu_list li a{
  padding: 3px;
  padding-left: 1.2em;
}

.tgl_menu_list .nav_mega_menu div a {
  margin-left: 15px;
  background: none;
  padding: 3px;
  line-height: 2;
  text-indent: -1.2em;
  padding-left: 1.2em;
}


/* メガメニュー展開時 */
.tgl_menu_list .nav_mega_menu.active p::before {
  content: "\f068";
}

/* ナビ展開時の後ろの背景 */
.nav_overlay {
  display: none;
  opacity: 0;
  visibility: hidden;
  z-index: 10;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.2);
}

body.nav-open .nav_overlay {
  display: block;
  opacity: 1;
  visibility: visible;
}

/* ヘッダー固定ボタンエリア */
.btn_area {
	position:fixed;
	bottom:0;
	left:0;
  width: 100%;
	z-index:1000;
}

.btn_area ul {
  display: flex;
  background: #fff;
}

.btn_area li.btn {
  width: 100%;
}

.btn_area li.btn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: #fff;
  text-align: center;
  font-weight: bold;
  padding: 15px 2%;
  /* gap:5px; */
  gap:3px;
	line-height:1.4;
	font-size:13px;
}

.btn_area li.btn a img{
	width:20px;
}

.btn_area li.btn a i {
  width: 15px;
  margin-right: 3px;
}

.btn_area li.btn_tel {
  background: #4D8912;
}

.btn_area li.btn_tel a{
}

.btn_area li.btn_tel a small{
	position:absolute;
	top:11px;
	font-size:12px;
	font-weight:normal;
}


.btn_area li.btn_mitsumori {
  background: #BF4F00;
}
.btn_area li.btn_mitsumori a{
}

.btn_area li.btn_mitsumori em{
	position:absolute;
	top:11px;
	font-size:10px;
	font-weight:normal;
}

.btn_area li.btn_mitsumori em::before{
	position:absolute;
	top:0;
  right: -4px;
  width: 1px;
  height: 12px;
  transform: rotate(24deg);
	background:#fff;
	content:"";
}

.btn_area li.btn_mitsumori em::after{
	position:absolute;
	top:0;
  left: -4px;
  width: 1px;
  height: 12px;
  transform: rotate(-24deg);
	background:#fff;
	content:"";
}

.btn_area li.btn_soudan {
  background: #125383;
}

/* 準備中用のクラス */
.btn_area li.btn.coming {
  background: #aaa !important;
}

.btn_area li.btn.coming a {
  pointer-events: none;
  padding: 2px 2% 18px;
}

.btn_area li.btn.coming a::before {
  content: "（準備中）";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
  font-size: 90%;
}
	
	.nav_wrap.fixed{
		padding:5px;
		background:#fff;
	}

/*============================================================================

#mainvisual

============================================================================*/

#mainvisual {
	position:relative;
	background-image:url(../images/mv_sp.jpg);
	background-position: bottom;
	background-size: cover;
  height: 249px;
	margin:101px 0 0;
}
#mainvisual.usa-shrine{
  background-image:url(../images/mv_usajingu_sp.jpg);
}
#mainvisual.strength{

}
/* #mainvisual.service{
  background-image:url("../images/service_mv_sp.jpg");
}
#mainvisual.works{
	background-image:url("../images/works_mv_sp.jpg");
}
#mainvisual.soudan{
	background-image:url("../images/soudan_mv_sp.jpg");
}
#mainvisual.about{
	background-image:url("../images/about_mv_sp.jpg");
}
#mainvisual.flow{
	background-image:url("../images/flow_mv_sp.jpg");
}
#mainvisual.contact{
	background-image:url("../images/contact_mv_sp.jpg");
}
#mainvisual.soudan{
	background-image:url("../images/soudan_mv_sp.jpg");
}
#mainvisual.voice{
	background-image:url("../images/voice_mv_sp.jpg");
}
#mainvisual.wall,#mainvisual.roof{
	background-image:url("../images/price_mv_sp.jpg");
}
#mainvisual.blog{
	background-image:url("../images/blog_mv_sp.jpg");
}
#mainvisual.paint{
	background-image:url("../images/paint_mv_sp.jpg");
}
#mainvisual.quality{
	background-image:url("../images/quality_mv_sp.jpg");
}
#mainvisual.failure{
	background-image:url("../images/mv_sp.jpg");
  background-position: 100% 30%;
} */

.mainvisual_wrap{
	width:100%;
	background:none;
}

#mainvisual .inner {
  width: auto;
  height: inherit;
}

/* 下層ページヘッドライン */
.mainvisual_headline p.headline {
  font-size: 28px;
	line-height:1.6;
}

/*============================================================================

#contents

============================================================================*/
	
	.box{
		width:auto;
		padding:0 4% 50px;
	}

	footer .box{
		margin:0 4%;
	}

.box1 {
  width: auto;
  padding: 0 4% 50px;
}

.box2 {
  width: auto;
  margin: 0 7% 50px;
}
	
	.box3{
		width:auto;
		margin:0 4% 50px;
	}
	.box4{
		width:auto;
		margin:0 7% 50px;
	}
	.box p, .box2 p, .box3 p,.box4 p{
		font-size:14px;
		line-height:2;
	}

#contents {
  width: auto;
}

#contents_left {
  width: auto;
  float: none;
  margin-right: 0;
}

#contents_right {
  width: auto;
  padding: 0 6%;
  float: none;
}

/*============================================================================

footer

============================================================================*/
	.footer_work .top_work_item{
		width:48%;
	}
	.footer_work .top_work_img figure{
		height:22vw;
	}
	.footer_work .top_work_img figure img{
		height:22vw;
	}
	.footer_banner{
		padding:50px 0;
	}
	
	.work_list{
		flex-wrap: wrap;
		gap:30px 0;
		margin:0 0 40px;
	}

	.work_list .work_item:nth-child(4){
		display:none;
	}
	.work_item a{
		width:45vw;
		padding:5px;
		box-shadow:0 8px 20px rgba(0,0,0,0.18);
	}
	.work_img{
		gap:3px;
	}
	.work_img figure img{
		width: 100%;
		height: 25vw;
		object-fit: cover;
		object-position: center;
	}
	.work_img .work_conatct{
		font-size:11px;
	}
	.work_info{
		gap:1vw;
	}
	.work_info li{
		font-size:12px;
		padding:5px;
	}
	.footer_contact{
		padding:50px 5%;
	}
	.footer_contact ul{
		flex-direction: column;
		align-items: center;
	}
	.footer_contact li{
		width:100%;
		font-size:4vw;
	}
	.footer_contact li a{
		width:90%;
		font-size:4vw;
	}
	.footer_contact li .contact_tit{
		font-size:5vw;
	}

.footer_info {
  width: auto;
  padding: 40px 6% 80px;
}
	.footer_inner{
		width:100%;
		padding:0;
	}

.footer_info_left {
  width: 100%;
}

.footer_info_left {
  margin-bottom: 20px;
	text-align:center;
}

	.footer_logo a{
		font-size:24px;
		font-weight:bold;
		letter-spacing: 0.1em;
		color:#fff;
		font-family: "Yu Kyokasho New M";
	}
	.footer_overview p{
		font-size:12px;
		line-height:1.7;
	}
	.footer_overview p span{
		font-size:14px;
	}
	.footer_tel a{
		font-size:32px;
	}
	.footer_tel a span{
		font-size:20px;
	}
	.footer_tel em{
		font-size:4vw;
		width:69vw;
	}
	.footer_tel em::before{
		left:-11vw;
		width:8vw;
	}
	.footer_tel em::after{
		right:-11vw;
		width:8vw;
	}

	.footer_area{
		padding:60px 20px 50px;
	}
	.footer_area_inner{
		position:relative;
		width:100%;
		flex-direction: column;
		padding:40px 30px 30px;
	}
	.footer_area .footer_area_tit{
		position:absolute;
		top:-15px;
		left:0;
		right:0;
		margin:auto;
		transform: translateY(0);
		display: table;
	}

.copy {
	padding:30px 0 80px;
}

.loading p{
	font-size:4vw;
}
.loading img{
	width:70vw;
}

.g-review{
	position:fixed;
	top:60px;
	background:#fff;
	width:100%;
	padding:5px 0;
	z-index:500;
	box-shadow:0 5px 5px rgba(0, 0, 0, 0.05);
}
.g-review .g-review_wrap{
	padding:0 20px;
	border:none;
}
.g-review .wp-gr.wpac .wp-google-left img{
	width:40px !important;
	height:40px !important;
}
.g-review .wp-gr .wp-google-right{
	/* flex-direction: column; */
	align-items: center;
}
.g-review .wp-gr .wp-google-rating{
	font-size:18px !important;
}
.g-review .wp-gr .wp-google-place .wp-star svg{
	width:14px !important;
	height:14px !important;
}
.g-review .wp-gr .wp-google-powered{
	margin:0 !important;
}
.g-review .wp-gr .wp-google-powered img{
	max-width:100px !important;
}
.g-review_btn a{
	/* display:none; */
}

/*============================================================================

$top

============================================================================*/
.top_batch{
  padding:20px 0;
}
.batch_list{
  display:flex;
  gap:2vw;
  justify-content: center;
}
.batch_list li{
  width:28vw;
}
	.top_contact_flex{
		flex-direction: column;
		gap:21px;
	}
	.contact_list{
		width:100%;
		padding:0 16px;
	}
	.contact_list li{
		padding:13px 0 11px;
		font-size:14px;
		margin-right:15px;
	}
	.concept_list h3{
		font-size:4.5vw;
	}
	.contact_list li span{
		margin-right:5px;
	}
	.contact_list li em{
		margin:0;
	}
	.concept_list li,.concept_list li:nth-child(even){
		position:relative;
		flex-direction: column-reverse;
		gap:0;
		width:100%;
		margin:0 0 50px;
		padding:0;
	}
	.concept_list li::before{
		position: absolute;
    top: 0;
		bottom:20px;
		left:0;
    right: 0;
		margin:auto;
    /* width: calc(100% - 30px);
    height: calc(100% - 30px); */
		width:calc(100% - 20px);
		height:100%;
    border: 2px solid #f7c5a1;
    border-radius: 4px;
    content: "";
    z-index: -1;
	}
	.concept_text,.concept_list li:nth-child(even) .concept_text{
		/* padding:40px 20px 20px 10px; */
		padding:20px;
		width:calc(100% - 20px);
		margin:-20px 0 0 auto;
	}
	.concept_list li figure{
		position: static;
		width:94%;
		height:auto;
	}
	.concept_list li figure::before,.concept_text::before{
		content:none;
	}
	
	.top_price{
		padding: 60px 0 30px;
	}
	.top_price .tit01{
		margin:0 auto 20px;
	}
	.top_price_plan{
		flex-direction: column;
		gap:40px;
	}
	.top_price_item{
		position:relative;
		width:100%;
		height:205px;
		padding:0 0 0px;
	}
	.top_price_item figure{
		top:0;
		height:205px;
		width:90%;
	}
	.top_price_item figure img{
		width: 100%;
		height:100%;
		object-fit: cover;
		object-position: center;
	}
	.plan_img h3{
		font-size:12vw;
	}
	.plan_img h3 span{
		font-size:10vw;
	}
	.price_text{
		padding:20px 0 0;
		width: 220px;
    height: 205px;
	}
	.price_text::before{
		width: 220px;
    height: 205px;
	}
	.price_text h3{
		font-size:18px;
		margin:0 0 15px;
		padding:0 30px 0 0;
		line-height:1.3;
	}
	.price_text h3 span{
		font-size:25px;
	}
	.price_text_box{
		width:175px;
		margin:0 0 0 16px;
	  padding:5px 0;
	}
	.price_text p{
		font-size:18px;
	}
	.price_text p span{
		font-size:46px;
	}
	.price_text p.price_btn{
		position:relative;
		font-size:13px;
		text-align:left;
		padding:10px 20px 5px;
		color:#4a4a4a;
		font-weight:bold;
	}
	.price_text p.price_btn::before{
		position:absolute;
		right: 20px;
		top:5px;
		bottom:0;
    margin: auto;
    width: 58px;
    height: 6px;
    background: url(../images/arr_icon01.png);
    content: "";
		content:"";
	}
	.top_price_item .btn01{
		position:absolute;
		left:0;
		bottom:0;
		width:100%;
	}
	.top_price_item .btn01 p{
		width:100%;
		line-height:30px;
		text-align:center;
		background:#db7f40;
		color:#fff;
		font-size:16px;
	}
	.top_work{
		padding:35px 0 0;
	}
	.top_work_list{
		justify-content: space-between;
		flex-wrap: wrap;
		gap:20px 0;
		margin:0 0 40px;
		padding:0;
	}
	.top_work_list .top_work_item:nth-child(4){
		display:none;
	}
	.top_work_item{
		width:100%;
	}
	.top_work_item a{
		width:100%;
		height:100%;
		padding:5px;
	}
	.top_work_img{
		gap:3px;
		margin:0 0 5px;
	}
	.top_work_img figure{
		height:45vw;
	}
	.top_work_img figure img{
		width: 100%;
		height: 45vw;
		object-fit: cover;
		object-position: center;
	}
	.top_work_img .work_conatct{
		font-size:14px;
	}
	.top_work_info{
		gap:1vw;
	}
	.top_work_info li{
		font-size:13px;
		padding:5px;
	}
	.top_work_info li.date{
		width:100%;
	}
	.cate_list{
		padding:0;
		margin:0 0 40px;
		gap:20px;
	}
	.cate_block{
		display:none;
	}
	.cate_col{
		gap:0;
	}
	.cate_item{
		padding:20px 10px;
		align-items: center;
		flex-direction: column;
		gap:0;
	}
	.cate_item:first-child{
		margin:0 0 20px;
	}
	.cate_item:nth-child(odd)::before{
		content:none;
	}
	.cate_item,.cate_item:nth-child(even){
		width:100%;
	}
	.cate_item .cate_tit{
		font-size:4.5vw;
		margin:0 0 20px;
		line-height:1.3;
	}
	.cate_item .cate_tit em{
		font-size:3vw;
	}
	.cate_item li a{
		width:100%;
		font-size:3.5vw;
		min-width:auto;
	}
	.cate_item ul{
		justify-content: space-between;
		gap:5px 0;
		width:100%;
	}
	.cate_item ul li{
		width:49%;
	}
	.cate_item.cate_build ul{
		justify-content: flex-start;
		gap:10px 2%;
	}
	.cate_item.cate_build ul li{
		width:auto;
	}
	.cate_item.cate_color li a{
		width:100%;
		min-width:auto;
		font-size:3.5vw;
	}
	.works .cate_item li a{
		width:100%;
	}
	.works .cate_item.cate_color li a{
		width:100%;
		font-size:3.5vw;
	}
	.cate_item.cate_build li a{
		width:auto;
	}
	.works .cate_more_btn{
		font-size:16px;
	}


	.top_feature_list{
		flex-direction: column;
		align-items: center;
		gap:30px;
		padding:0 5%;
	}
	.top_feature_list li{
		width:100%;
	}
	.top_feature_list li img{
		width:100%;
	}
	.top_voice{
		padding:48px 0 0;
	}
	.top_voice .box1{
		padding:0 4% 50px;
	}
	.top_voice::before,.top_voice::after{
		width:80%;
	}
	.top_voice::before{
		z-index:-1;
		height:430px;
	}
	.top_voice::after{
		z-index:-2;
		bottom:-40px;
	}
	.top_voice_list{
		flex-wrap: wrap;
		gap:30px 0;
		margin:38px 0 48px;
	}
	.top_voice_list .top_voice_item:nth-child(4){
		display:block;
	}
	.voice_cate{
		flex-wrap: wrap;
		gap:5px 2%;
	}
	.voice_cate li{
		font-size:3vw;
		width:49%;
	}
	.top_voice_item a{
		width:45vw;
		padding:5px;
		height:100%;
	}
	.voice_point{
		right: 1px;
    top: -7px;
		width:55px;
		height:55px;
		font-size:8px;
		line-height:1.2;
		padding:10px 0 0 ;
	}
	.voice_point span{
		font-size:16px;
	}
	.top_voice_item a figure{
		height:32vw;
	}
	.voice_tit{
		flex-direction: column;
		align-items: flex-start;
		gap:5px;
	}
	.voice_tit h3{
		font-size:16px;
	}
	.voice_tit ul{
		display:none;
	}
	.voice_tit .cate{
		font-size:12px;
		padding:5px;
	}
	.top_info_flex{
		flex-direction: column;
	}
	.blog_wrap{
		width:100%;
		height:350px;
	}
	.info_blog .btn01 a{
		margin:0 auto;
	}
	.top_banner_list{
		flex-wrap: wrap;
	}
	.top_banner_list li{
		width:50%;
	}
	.top_banner_list li a{
		border-top:2px solid #ddd;
		border-right:2px solid #ddd;
		border-left:none;
		border-bottom:none;
		height:30vw;
		font-size:4vw;
	}
	.top_banner_list li:nth-child(even) a{
		border-right:none;
	}
	.top_banner_list li:nth-child(5) a,.top_banner_list li:last-child a{
		border-bottom:2px solid #ddd;
	}
	.top_greeting{
		padding:60px 0 30px;
	}
	.top_greeting .tit01{
		text-align:center;
	}
	.top_greeting_flex{
		flex-direction: column-reverse;
		gap:30px;
		padding:20px;
	}
	.top_greeting_text{
		width:100%;
	}
	.top_greeting_text p{
		line-height:29px;
		font-size:14px;
	}
	.top_greeting_img{
		margin:0;
		width:100%;
	}
	.top_greeting_img h3,.top_greeting .top_greeting_text h3,.top_greeting_text h3{
		padding: 8px 15px;
		font-size: 4.5vw;
		display: table;
		letter-spacing: 0.1em;
		margin: 0 auto 33px;
		line-height:34px;
		text-align:center;
	}
	.top_greeting .top_greeting_text h3{
		display: block;
	}
	.top_greeting .btn01 a{
		margin:0;
	}
	.top_blog{
		padding:40px 0 13px;
	}
	.top_blog .tit01{
		font-size:30px;
		margin:0 0 35px;
	}
	.blog_list{
		flex-wrap: wrap;
		gap:15px 0;
		padding:0;
		margin:0 0 40px;
	}
	.blog_list li{
		width:48%;
	}
	.blog_list li a{
		width:100%;
		height:auto;
		padding:6px;
		box-shadow:0 8px 20px rgb(0 0 0 / 18%);
	}
	.blog_list li figure img{
		height:100px;
	}
	.blog_info{
		font-size:12px;
		line-height:20px;
		margin:0 0 7px;
	}
	.blog_info span{
		margin:0 5px 0 0;
		display:inline-block;
	}
	.blog_info em{
		min-width:70px;
	}
	.blog_tit{
		font-size:14px;
	}

/*============================================================================

$breadcrumbs ぱんくず

============================================================================*/

.breadcrumbs {
  width: 90%;
  margin: 0 5% 26px;
  font-size:14px;
}

.breadcrumbs li {
  display: inline-block;
	float:none;
}

/*============================================================================

$共通

============================================================================*/
	#container{
		padding:0;
	}
#contents {
  padding-bottom: 70px;
  padding-top:10px;
}

.box {
  width: auto;
}

.text {
  float: none;
  width: auto;
  padding: 0;
  border: none;
}

.img_flex{
	gap:20px;
	flex-direction: column-reverse;
}
.img_flex figure{
	width:100%;
}

/*============================================================================

$見出し

============================================================================*/

h1 {
  font-size: 11px;
  width: auto;
  padding: 5px 15px;
  text-align: center;
  position: static;
  margin-top: 0 !important;
}
	
	.tit01{
		font-size:6vw;
		line-height:1.4;
	}
	.tit_en{
		font-size:10vw;
	}
	.tit02{
		font-size:22px;
		line-height:30px;
		margin:0 auto 30px;
	}
	.tit02 small{
		font-size:18px;
		margin:0 0 5px;
	}
	.tit03{
		font-size:26px;
		line-height:1.4;
	}
	.tit04{
		font-size:22px;
		line-height:32px;
		margin:0 0 20px;
	}
	.h3_tit01{
		line-height:1.4;
		font-size:20px;
		margin:0 0 15px;
	}
	.h3_tit01::before{
		top:6px;
		bottom:auto;
	}

.nowrap {
  white-space: normal;
}



/* テーブル */
.tb01 {
  white-space: inherit;
}

.tb01 th {
  width: 30%;
  font-size: 14px;
}

.tb01 td {
  font-size: 14px;
  text-align: center;
}

	.tb03{
		margin:0 0 30px;
	}
.tb03,
.tb03 th {
  white-space: inherit;
}
	.tb03 th{
		width:calc(50% - 16px);
		font-size:16px;
	}
	.tb03 td{
		font-size:11px;
		padding:10px 5px;
		line-height:2;
		letter-spacing: 0;
	}
	.tb03 td img{
		padding:10px;
		max-width:200px;
		width:100%;
	}
	
	.tb03 tr td:first-child{
		width:32px;
	}

.tb03.w075par {
  width: 100%;
}

/* 横スクロール */
.scroll_tb {
  overflow-x: scroll;
}

.scroll_tb table {
  width: 816px;
}

.scroll_tb table th {
  position: sticky;
  left: 0;
}

.scroll_tb table th::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  border: 1px solid #00408f;
}

.tb04,
.tb04 th {
  white-space: normal;
}

.tb04 th {
  font-size: 13px;
}

.tb04 td,
.tb04 th {
  padding: 2%;
}

	.btn01 a{
		margin:0 auto;
		width:260px;
		height:60px;
		font-size:15px;
	}


/* アンカーリンク */
	[class^="ank0"] li a{
		font-size:14px;
		line-height:20px;
		padding:0 10px;
	}
.ank02 {
  width: 100%;
}

.ank02 li {
  width: 100%;
	height:46px;
}
	.ank02 li::before{
		height:46px;
		line-height: 46px;
	}

.ank03 {
  width: 86%;
	margin:0 auto 40px;
	gap:2%;
}

.ank03 li {
  width: 49%;
}

.ank03 li a{
	height:50px;
	padding:0 0 5px;
}
.ank03 li a::before{
	bottom:5px;
}

.ank04 {
  width: 100%;
}

.ank04 li {
  width: 100%;
}



/* 画像右寄せ */
.img_fr {
  float: none;
  margin-left: 0;
  text-align: center;
  max-width: 100%;
}

.img_fr img {
  margin-bottom: 15px;
}


.list08{
	padding:25px 20px 20px 25px;
}

/*============================================================================

$service

============================================================================*/

	.service_item{
		flex-direction: column-reverse;
		gap:20px;
	}
	.service_text{
		width:100%;
	}
	.service_text h3{
		font-size:20px;
		margin:10px 0;
		line-height:32px;
	}
	.service_text p{
		font-size:12px;
		line-height:24px;
	}
	.service_img figure{
		width:100%;
	}

	.service_check{
		gap:30px;
	}
	.service_check li{
		width:100%;
	}
	.service_reason_info h3{
		font-size:20px;
		margin:0 0 20px;
		line-height:36px;
	}
	.service_reason_info h3 span{
		width:36px;
		line-height:36px;
		margin:0 10px 0 0;
	}

	.caulking_work_list{
		flex-direction: column;
		gap:30px;
	}
	.caulking_work_item{
		width:100%;
	}


/*==================================================================

  $about （下層）

==================================================================*/
.greeting{
	padding:0;
}

.staff_list{
	flex-wrap: wrap;
	gap:20px 0;
}
.staff_item{
	width:49%;
}

.profile_tb{
  width:100%;
}
.profile_tb tr{
	border-bottom:1px solid #eee;
}
.profile_tb th{
	padding:15px 0 0;
	font-weight:bold;
	display: block;
  width:100%;
	border:none;
	text-align:left;
	font-size:16px;
}
.profile_tb td{
	display: block;
  width:100%;
  padding:0 0 15px;
	font-size:14px;
	line-height:28px;
}


/*============================================================================

$works

============================================================================*/
	.works .top_work_list{
		gap:25px 0;
	}
	.works .top_work_item{
		width:100%;
	}
	.works .top_work_item a{
		width:100%;
		padding:0;
		box-shadow:none;
	}
	.works .top_work_img figure{
		height:45vw;
	}
	.works .top_work_img figure img{
		height:45vw;
	}
	
/*============================================================================

$works-item

============================================================================*/
	
	.works_item_img{
		flex-direction: column;
		gap:80px;
		margin:0 0 50px;
	}
	.works_item_img::before{
		content:none ;
	}
	.works_item_img a{
		width:100%;
	}
	.work_before{
		position:relative;
	}
	.work_before::before{
		position:absolute;
		right:0;
		left:0;
		bottom:-45px;
		margin:auto;
		width: 0;
    height: 0;
    border-style: solid;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-top: 20px solid #555555;
    border-bottom: 0;
		content:"";
	}
	.works_text{
		flex-direction: column;
		margin:0 0 40px;
	}
	.works_text_box{
	}
	.works_text_box h3{
		font-size:24px;
	}
	.works_text_box p{
		font-size:14px;
		line-height:28px;
	}
	.works_info_box{
		padding:20px 20px 50px;
		margin:0 0 50px;
	}
	.works_info_box h3{
		margin:0 0 15px;
	}
	.works_item_info dl{
		width:100%;
	}
	.works_item_info dl:nth-child(2){
		border-top:none;
	}
	.works_item_info dl:nth-child(5){
	  border-bottom:1px solid #c7c7c7;
	}
	.works_item_info dt{
		width:85px;
		line-height:40px;
		font-size:14px;
		padding:0 15px 0 10px;
	}
	.works_item_info dd{
		padding:0 10px 0 0;
		font-size:14px;
		letter-spacing: 0;
	}
	.works_item_info dl:nth-child(5) dd,.works_item_info dl:nth-child(6) dd{
		font-size:12px;
	}
	.other_works_item h3{
		font-size:20px;
	}
	.other_img{
		flex-direction: column;
		gap:20px;
	}
	.other_img::before{
		content:none;
	}
	.other_img div{
		max-width:100%;
	}
	.other_img a{
		width:100%;
  height:200px;
  overflow: hidden;
	}
	.other_img a img{
		width:100%;
		max-height:none;
	}
	.other_img p{
		font-size:18px;
		width:100px;
		line-height:30px;
	}
	
	.post_link01{
		flex-wrap: wrap;
		gap:25px 10%;
	}
	.post_link01 a{
		width:35%;
		text-align:center;
		padding:18px 30px;
	}
	.post_link01 .return{
		width:80%;
	}
	.post_link02{
		flex-wrap: wrap;
		gap:10px 5%;
		width:60%;
		margin:0 auto;
	}
	.post_link02 a{
		width:47%;
		text-align:center;
		padding:10px 0;
		font-size:14px;
	}
	.post_link02 .return{
		width:100%;
	}
/*============================================================================

$soudan

============================================================================*/
.consultation .tit03{
	font-size:24px;
}
	.soudan_tit.tit01{
		font-size:24px;
		margin:0 auto 30px;
	}
	.soudan_text p{
		line-height:28px;
	}
	.soudan_form_box{
		width:100%;
		padding:15px 15px 25px;
	}
	.soudan_form_box h3{
		font-size:18px;
		line-height:28px;
  	margin:20px 0 15px;
	}
	.soudan_form input[type="text"]{
		height:38px;
		font-size:12px;
		padding:0 15px;
	}
	.soudan_form label{
		font-size:14px;
	}
	.soudan_form label small{
		font-size:11px;
		letter-spacing: 0;
	}
	.soudan_form input[type="file"]{
		font-size:12px;
	}
	.soudan_form textarea{
		font-size:12px;
		padding:15px;
		height:100px;
	}
	.soudan_form .submit_btn{
		width:180px;
	}
	.soudan_form .submit_btn input[type="submit"]{
		font-size:14px;
		height:50px;
	}
	.soudan_form_box p{
		text-align:left;
	}
	.soudan_form{
		width:100%;
	}
	.search_sec{
		padding:140px 0 0;
	}
	.search_sec::before{
	  position:absolute;
	  top:95px;
	  left:calc((100% - 100vw) / 2);
	  min-width:auto;
		height:2px;
	}
	.search_sec::after{
	  position:absolute;
	  top:40px;
	  right:20px;
		width: 90px;
    height: 57px;
		background-size:cover;
	  content:"";
	}
	.search_sec .soudan_tit.tit01{
		margin:0 0 10px;
	}
	.search_box{
		min-width:270px;
		width:80%;
		margin:0 auto 35px;
		gap:0;
	}
	.search_box input[type="text"]{
		width:80%;
		height:30px;
		padding:0 10px;
		font-size:14px;
	}
	.search_box input[type="submit"]{
		width:20%;
		height:30px;
		font-size:16px;
	}
	.soudan_cate{
		width:96%;
		margin:0 auto 45px;
	}
	.soudan_cate h3{
		font-size:20px;
	}
	.soudan_cate_list{
		gap:10px;
		justify-content: flex-start;
	}
	.soudan_cate_list li a{
		font-size:14px;
		letter-spacing: 0;
		padding:0 47px 0 18px;
	}
	.soudan_cate_list li a::before{
		width:23px;
		height:4px;
		right:14px;
		background-position:right;
	}
	.ranking .ranking_tit{
		font-size:22px;
		margin:0 auto 34px;
	}
	.ranking{
		position:relative;
		padding:40px 0 20px;
		margin: 0 0 40px;
		background:none;
		width:100%;
	}
	.ranking:before{
		position:absolute;
		top:0;
		width:100vw;
		height:100%;
		left:calc(50% - 50vw);
		background:#DEEBF7;
		content:"";
		z-index:-1;
	}
	.soudan_list ul{
		width:90%;
	}
	.soudan_list ul li{
		position:relative;
		background:#fff;
		padding:15px 15px 40px;
		border:1px solid #032137;
		margin:0 0 20px;
	}
	.soudan_list .soudan_tit{
		margin:0 0 10px;
		transition:.5s;
	}
	.soudan_list .soudan_tit.open{
		/* margin:0 0 30px; */
	}
	.soudan_tit .soudan_content_text p:first-child{
		max-height:50px;
	}
	.soudan_list .soudan_tit h3{
		font-size:14px;
		font-weight:bold;
		line-height:20px;
		padding:5px 60px 10px 17px
	}
	.soudan_list .soudan_tit h3::before{
		top:4px;
		bottom:auto;
		width:6px;
		height:20px;
	}
	.soudan_list .soudan_tit p{
		font-size:12px;
		line-height:2;
	}
	.soudan_list .soudan_tit .view{
		font-size:12px;
		letter-spacing: 0;
		line-height:1;
	}
	.soudan_list .soudan_tit .view img{
		width:20px;
		margin:0 5px 0 0;
	}
	.soudan_content{
		display:none;
	}
	.soudan_content h4{
		font-size:14px;
		line-height:2;
		font-weight:bold;
	}
	.soudan_content h4::before{
		width:6px;
		height:20px;
		top:3px;
	}
	.soudan_content h4 span{
		display:block;
		margin:0;
	}
	.soudan_content p{
		font-size:12px;
		line-height:2;
	}
	.soudan_content p.cate{
		width:100%;
		display:block;
		padding:5px;
		text-align:center;
		font-size:11px;
		letter-spacing: 0;
	}
	.read_more_btn{
		position:absolute;
		bottom:0;
		left:0;
		width:100%;
		line-height:30px;
		text-align:center;
		background:#032137;
		color:#fff;
		font-size:14px;
		letter-spacing: 0.14em;
		cursor: pointer;
	}
	.read_more_btn.close{
		background:#626262;
	}
	
	
/*============================================================================

$strength

============================================================================*/
.strength .box{
	margin:0;
}
	.strength_list{
		margin:57px 0 0;
		width:100%;
	}
	.strength_flex{
		padding:0 9%;
		width:100%;
		flex-direction: column-reverse;
	}
	.strength_item:first-child{
		margin:0 0 125px;
	}
	.strength_item:nth-child(2){
		margin:0 0 20px;
	}
	.strength_item:nth-child(4){
		padding:16px 0 50px;
		margin:0;
	}
	.strength_item:first-child::before, .strength_item:nth-child(3)::before, .strength_item:nth-child(4)::before {
		min-width: 100%;
		left:0;
	}
	.strength_item:first-child::before{
		top:-50px;
		height: calc(100% + 84px);
		clip-path: polygon(0% 0%,100% 0%, 100% 100%, 0% 100%);
	}
	.strength_item:first-child::after{
		position: absolute;
    top: -50px;
    width: 100%;
    height: 45px;
    background: url(../images/strength_bg_sp03.png);
    background-size: 100% 100%;
    content: "";
	}
	.strength_item:nth-child(2)::before{
		position: absolute;
    top: -92px;
    width: 100%;
    height: 45px;
    background: url(../images/strength_bg_sp01.png);
    background-size: 100% 100%;
    content: "";
	}
	.strength_item:nth-child(2)::after{
		position: absolute;
    bottom: -96px;
    width: 100%;
    height: 45px;
    background: url(../images/strength_bg_sp03.png);
    background-size: 100% 100%;
    content: "";
	}
	.strength_item:nth-child(3)::before{
		top:32px;
		height:calc(100% + 90px);
		clip-path: polygon(0% 0%,100% 0%, 100% 100%, 0% 100%);
	}
	.strength_item:nth-child(3)::after{
		position: absolute;
    bottom: 14px;
    width: 100%;
    height: 45px;
    background: url(../images/strength_bg_sp02.png);
    background-size: 100% 100%;
    content: "";
	}
	.strength_item:nth-child(4)::before{
		top:-15px;
		height:calc(100% + 50px);
		clip-path: polygon(0% 0%,100% 0%, 100% 100%, 0% 100%);
	}
	.strength_item:nth-child(4)::after{
		position: absolute;
    bottom: -35px;
    width: 100%;
    height: 45px;
    background: url(../images/banner_bg_sp.png);
    background-size: 100% 100%;
    transform: rotate(180deg);
    content: "";
	}
	.strength_item:nth-child(even) .strength_flex{
		flex-direction: column-reverse;
	}
	.strength_text{
		width:100%;
		padding:35px 15px;
	}
	.strength_item:nth-child(even) .strength_text{
		margin:0;
	}
	.strength_text h3{
		text-align:center;
		padding:53px 0 0;
		font-size:18px;
		line-height: 1.8;
	}
	.strength_text h3 span{
		font-size:136%;
	}
	.strength_text h3::before{
		top:11px;
		left:0;
		right:0;
		bottom:auto;
		margin:auto;
	}
	.strength_text._01 h3{
		margin:0 0 25px;
	}
	.strength_text._03 h3{
		margin:0 0 10px;	
	}
	.strength_text._01 h3::before{
		top:17px;
	}
	.strength_text._01 h3::after{
		top:-5px;
	}
	.strength_text._02 h3::after{
		top:-10px;
	}
	.strength_text._03 h3::after{
		top:-7px;
	}
	.strength_text._04 h3::before{
		top:26px;
	}
	.strength_text h3::after{
		top:0;
		left:0;
		right:0;
		margin:auto;
		font-size:50px;
	}
	.strength_text._04 h3::before{
		top:15px;
	}
	.strength_text._04 h3::after{
		top:-6px;
	}
	.strength_text p{
		padding:0 10px;
	}
	.strength_text li{
		flex-direction: column;
		gap:10px;
		align-items: flex-start;
		font-size:18px;
		margin:0 0 16px 10px;
	}
	.strength_text p{
		font-size:14px;
		line-height:28px;
	}
	.strength_text p a{
		position:relative;
		display:inline-block;
		line-height:38px;
		width:225px;
		padding:0 0 0 10px;
		margin:15px auto 0;
		border:1px solid #BF4F00;
		border:1px solid #BF4F00;
		background:#BF4F00;
		color:#fff;
		font-size:17px;
	}
	.strength_text p a::before{
		position:absolute;
		top:0;
		bottom:0;
		margin:auto;
		right:20px;
		width:33px;
		height:4px;
		background:url("../images/arr_icon04.png");
		-webkit-filter: brightness(0) invert(1);
		filter: brightness(0) invert(1);
		transition:.4s;
		content:"";
	}
	.strength_img{
		width:100%;
		height:auto;
		margin:0;
	}
	.strength_graph{
		width:100%;
	}
	.guarantee{
		margin:55px 0 0;
		padding:0 9%;
	}
	.guarantee h4{
		font-size:24px;
	}
	.guarantee_list{
		gap:10px;
		justify-content: center;
	}
	.guarantee_list li{
		width:48%;
		height:auto;
		gap:10px 0;
	}
	.strength_banner{
		padding:0 9%;
		flex-direction: column;
	}
	.strength_banner li a{
		width: 100%;
		max-width: 400px;
		margin: 0 auto;
		height: 180px;
		padding: 20px;
		font-size: 24px;
	}
	.promise{
		padding: 0;
		margin: 0;
	}
	.promise::before{
		top:85px;
		height:2px;
	}
	.promise::after{
		right:20px;
		top:30px;
		left:auto;
		width: 90px;
		height: 57px;
		background-size: cover;
	}
	.promise_list{
		flex-direction:column;
		gap:0;
	}
	.promise_list li{
		padding:50px 20px 30px;
		width:100%;
	}
	.promise_list li:not(:last-child){
		margin:0 0 70px;
	}
	.promise_list li::before{
		top:-30px;
		left:0;
		right:0;
		margin:auto;
	}
	.promise_list li h3{
		text-align:center;
		font-size:20px;
		line-height:1.8;
		margin:0 0 13px;
	}
	.promise_list li p{
		font-size:14px;
		line-height:2;
	}
	
/*============================================================================

$flow

============================================================================*/
	
	.flow_top_text{
		font-size:14px;
		line-height:2;
	}
	
	.flow_list{
		width:100%;
	}
	.flow_item{
		padding:35px 20px 20px;
		flex-direction: column;
		gap:20px;
	}
	.flow_item:not(:last-child){
		margin:0 0 40px;
	}
	.flow_item:not(:last-child)::after{
		bottom:-40px;
		height:40px;
	}
	.flow_item h3{
		padding:0;
		font-size:20px;
		margin:0 0 10px;
		text-align:center;
	}
	.flow_item p{
		font-size:12px;
		line-height:2;
	}
	.flow_item_contact .btn_flex{
		align-items: center;
		flex-direction: column;
		gap:15px;
		margin:10px 0 0;
	}
	.flow_item_contact .btn_flex a{
		flex-direction: column;
		width:100%;
		max-width:240px;
	}
	.flow_item picture{
		width:100%;
	}
	

/*==================================================================

  $contact （下層）

==================================================================*/
	.contact_top_text{
		font-size:14px;
		text-align:left;
		line-height:2;
		margin:0 0 40px;
	}
	.contact_form{
		width:100%;
	}
	.contact_form dl{
		align-items: flex-start;
		flex-direction: column;
	}
	.contact_form dd{
		width:100%;
	}
	.contact_form dd input[type="text"]{
		height:50px;
	}
	
	

/*==================================================================

  $thanks （下層）

==================================================================*/
	
	.flag{
		width:50%;
		margin:0 auto 20px;
	}
	.thanks .tit03{
		font-size:16px;
	}
	.thanks p{
		font-size:14px;
		line-height:2;
	}
	

/*==================================================================

  $voice （下層）

==================================================================*/
	

	.voice_list{
		gap:30px 0;
	}
	.voice_list li{
		width:48%;
	}
	.voice_item a{
		width:100%;
		padding:5px;
		box-shadow:0 0 14px rgba(0,0,0,0.08);
	}
	.voice_item a figure{
		height:210px;
		margin:0 0 5px;
	}
	.voice_item a .voice_point{
		padding:8px 0 0;
		font-size:8px;
		line-height:1.3;
	}
	.voice .voice_tit{
		margin:0;
	}
	
	

/*==================================================================

  $voice-item （下層）

==================================================================*/
	.voice .tit02{
		font-size:26px;
	}
	.voice_info {
		flex-direction: column;
		margin:0 0 30px;
	}
	.voice_info a{
		width:100%;
	}
	.voice_item_text{
		width:100%;
	}
	.voice_item_text h3{
		font-size:17px;
	}
	.voice_item_text p{
		font-size:14px;
	}
	.voice_item_point dt{
		font-size:18px;
		line-height:40px;
	}
	.voice_item_point dd{
		font-size:40px;
	}
	.voice_table{
		margin:0 0 40px;
	}
	.voice_table dl{
		width:48%;
		gap:8px;
		padding:8px 0;
	}
	.voice_table dt{
		font-size:15px;
		width:45%;
		line-height:40px;
	}
	.voice_table dd{
		font-size:14px;
		flex:1;
	}
	.voice_qa dl{
		font-size:14px;
		padding:10px 0;
	}
	.voice_qa dt{
		font-size:14px;
	}
	.voice_qa dd{
		font-size:14px;
	}
	.voice_qa dd li{
		font-size:14px;
		padding:0 40px 0 0;
	}
	.voice_qa dd li .ans{
		width:auto;
	}
	.voice_qa dd li.column{
		padding:0;
		flex-direction: column;
	}
	
	
/*============================================================================

$price

============================================================================*/
	.price_top_text{
		text-align:left;
		margin:0 0 60px;
	}
	.top_price_info p{
		margin:0 0 50px;
	}
	.plan_list{
		width:100%;
	}
	.plan_list li a{
		width:100%;
	}
	.plan_img{
		margin:0;
	}
	.plan_img p{
		position:static;
		text-align:center;
		font-size:3.8vw;
		letter-spacing: 0.1em;
		padding:5px 0;
	}
	.plan_img .batch{
		width:110px;
	}
	.plan_info{
		flex-direction: column;
		padding:10px 10px 25px;
	}
	.plan_text{
		text-align:center;
	}
	.plan_text h3{
		font-size:24px;
		margin:0;
	}
	.plan_text p{
		font-size:4vw;
	}
	.plan_text span{
		font-size:6vw;
	}
	.plan_text p::before{
		bottom:-12px;
		top:auto;
		right:0;
		left:0;
		width: 17px;
		height: 15px;
		background:url(../images/double_arr.png);
		border:none;
		transform: rotate(0deg);
	}
	.plan_money{
		text-align:center;
		padding:10px 20px 15px;
	}
	.plan_money p{
		font-size:3vw;
	}
	.plan_money .big{
		font-size:16vw;
	}
	.plan_money .tax{
		font-size:7vw;
	}
	.plan_money .tax em{
		font-size:5vw;
	}
	.plan_list li a .btn01 p{
		width:100%;
		line-height:40px;
		text-align:center;
		background:#db7f40;
		color:#fff;
		font-size:16px;
	}
	.plan_info .price_btn{
		position:relative;
		text-align:center;
		font-size:4vw;
		padding:20px 0 5px;
		font-weight:bold;
		border-bottom:2px solid #BF4F00;
	}
	
	
/*============================================================================

$price-item	

============================================================================*/
	.price{
		margin:0;
	}
	.plan_item{
		flex-direction: column;
	}
	
	.plan_item_img{
		width:100%;
	}
	.plan_item_img figure{
		width:100%;
		height:auto;
		overflow: hidden;
	}
	.plan_item_copy{
		position:static;
		font-size: 3.5vw;
		letter-spacing: 0.1em;
		line-height:46px;
		padding:5px 0;
		text-align:center;
	}
	.plan_item_info{
		width:100%;
		padding:15px 15px 10px;
	}
	.plan_item .plan_item_yaer{
		line-height:1;
		font-size:5.5vw;
	}
	.plan_item .plan_item_yaer span{
		font-size:12vw;
	}
	.plan_item_feature li{
		width:48%;
		font-size:5vw;
	}
	.plan_item .plan_item_money .mon{
		font-size:22vw;
	}
	.plan_item .plan_item_money .tax{
		font-size:9vw;
	}
	.plan_item .plan_item_money .tax em{
		font-size:5vw;
	}
	.plan_item_money{
		position:static;
		background:none;
	}
	.plan_item_img .plan_money{
		position: relative;
		top:auto;
		bottom:auto;
		left:auto;
		right:auto;
		margin:-40px auto 0;
		width:70vw;
	}
	.plan_item_img .plan_money .tax{
		right:8vw;
		font-size:7vw;
	}
	.plan_cont{
		width:100%;
	}
	.plan_in p.tit{
		font-size:20px;
		width:200px;
	}
	.plan_in ul{
		justify-content:flex-start;
		flex-wrap: wrap;
		gap:18px 32px;
	}
	.plan_in li{
		padding:10px 15px;
		font-size:14px;
	}
	.plan_in li:not(:last-child)::before{
		top:3px;
		right:-22px;
		font-size:16px;
	}
	.plna_cont_info p{
		font-size:16px;
		line-height:1.6;
	}
	.plan_paint table{
		width:100%;
		margin:0 auto 10vw;
		background:#E7F2F8;
	}
	.plan_flow{
		width:100%;
	}
	.plan_flow h3{
		text-align:center;
		padding:0;
		border:none;
	}
	.plan_flow ul{
		justify-content: space-between;
		gap:35px 0;
	}
	.plan_flow li{
		width:48%;
	}

	.plan_contact h2{
		font-size:26px;
		padding:10px 20px;
		line-height:1.6;
	}
	
/*============================================================================

$failure

============================================================================*/
	
	.failure01 p{
		margin:0 0 35px;
	}
	.failure02 figure{
		width:80%;
	}
	.failure03 a{
		width:100%;
	}
	.failure_box{
		flex-direction: column;
		gap:40px;
	}
	.failure_flex{
		flex-direction: column;
	}
	.failure_flex dl{
		width:100%;
	  padding: 20px 30px 10px;
	}
	.failure_flex .failure_flex_bef,.failure_flex .failure_flex_af{
  height:auto;
}
	.failure_flex dt{
		font-size:16px;
		flex-direction: column;
		height:auto;
	}
	.failure_flex dt p{
		display:block;
		margin:0 0 5px;
	}
	.failure_flex dd{
		font-size:13px;
		line-height:28px;
		padding:18px 0;
	}
	.failure_box .arr_text{
		margin:10px 0;
		flex-direction: column;
		text-align:center;
	}
	.faulure_flex_box{
		margin:40px 0 0;
	}
	.faulure_flex_box .failure_flex{
		gap:0;
		margin:0 0 40px;
	}
	.faulure_flex_box h3{
		margin:0 0 20px;
		font-size:20px;
	}
	
	
/*============================================================================

$quality

============================================================================*/
	.quality_tit{
		width:100%;
	}
	.quality_tit h2{
		text-align:left;
		font-size:14px;
		line-height:2;
	}
	.quality_nav{
		flex-direction: column;
		gap:20px;
	}
	.quality_nav h3{
		width:25%;
		font-size:16px;
	}
	.quality_nav div{
		width:100%;
	}
	.quality_nav .nav_list{
		width:75%;
	}
	.quality_nav div a{
		width:100%;
		font-size:16px;
		padding:10px;
	}
	.nav01 a,.nav02 a{
		height:auto;
	}
	.quality_item{
		padding:20px;
	}
	.quality_flex{
		flex-direction: column;
		gap:20px;
	}
	.qualit_img{
		width:100%;
	}
	.qualit_img h3{
		line-height:44px;
		font-size:20px;
	}
	.quality01_box{
		width:100%;
		padding:17px 15px;
	}
	.quality01_box h3{
		margin:0 0 15px;
		padding:14px 13px;
		font-size:18px;
		line-height:26px;
		height:auto;
	}
	.quality01_box ul{
		gap:15px;
	}
	.quality01_box li{
		width:100%;
	}
	.quality_list{
		width:100%;
	}

	.quality_paint{
		flex-direction: column;
		gap:30px;
	}
	.quality_paint li{
		width:100%;
		flex-direction: column;
	}
	.quality_paint figure{
		width:100%;
	}
	.quality_paint img{
		border-radius:10px 10px 0 0;
	}
	.quality_paint_info{
		padding:20px;
		border-radius:0 0 10px 10px;
	}


	.usa_tit h2{
		font-size:18px;
		line-height:2;
	}
	#infinitySlider .splide__slide{
		width:300px !important;
	}
	.usa_text h3{
		font-size:20px;
		margin:0 0 20px;
	}
	.usa_img{
		width:100%;
		margin:0 0 20px;
	}
	.usa_flex{
		flex-direction: column;
		gap:30px;
	}
	.usa_flex_item{
		width:100%;
	}
	.history{
		flex-direction: column;
	}
	.history dl{
		width:100%;
		flex-direction: column;
		border-left:1px solid #DC803F;
	}
	.history dt{
		font-size:24px;
		padding:10px 0 5px 20px;
		width:100%;
		border:none;
	}
	.history dt::before{
		top:19px;
		right:auto;
		left:-9px;
	}
	.history dt span{
		font-size:32px;
	}
	.history dd{
		width:100%;
		padding:0 0 10px 20px;
	}
	.history dd p{
		line-height:1.5;
	}
	.history_img{}

	
/*============================================================================

$paint

============================================================================*/
	.paint_tit{
	}
	.paint_tit h2{
		font-size:18px;
		line-height:2;
	}
	.paint_kinds{
		padding:0;
		gap:10px 4%;
	}
	.paint_kinds_item{
		width:48%;
	}
	.paint_kinds_item a{
		padding:15px 10px;
	}
	.paint_kinds_item p{
		font-size:16px;
		padding:0 0 10px;
	}
	.paint_kinds_item span{
		line-height:1;
		display:block;
	}
	.paint_kinds_item p.paint_kinds_year{
		font-size:14px;
		padding:10px 0 0;
	}
	.paint_kinds_item strong{
		font-size:24px;
		letter-spacing: 0;
	}

	.paint_kinds_info li{
		flex-direction: column;
		padding:20px;
	}
	.paint_kinds_info li h3{
		padding:0 0 10px;
	}
	.paint_kinds_info li p{
		border-left:none;
		line-height:2;
		padding:20px 0 0;
		border-top:1px solid #DC803F;
	}
	



	.paint_performance_list dl{
		width:100%;
		height:auto;
	}
	.paint_performance_list dl:nth-child(2){
		border-top:none;
	}
	.paint_performance_list dt{
		width:33%;
		text-align:center;
		flex-direction: column;
		justify-content: center;
		gap:5px;
		line-height:1;
		padding:10px 0;
		font-size:14px;
		height:100%;
	}
	.paint_performance_list dt figure{
		width:40px;
	}
	.paint_performance_list dd{
		width:67%;
		padding:10px;
		line-height:1.5;
	}
	.paint03 .paint_list_text{
		line-height:32px;
	}
	.paint_item h3{
		font-size:18px;
		line-height:32px;
		letter-spacing: 0.1em;
		height:auto;
	}
	.paint_item figure{
		margin:0 auto 30px;
		width:200px;
	}
	.paint_feature_list{
		flex-wrap: wrap;
		flex:1;
		gap:7px;
	}
	.paint_feature_list figure,.paint_feature_list .year_icon figure{
		height:80px;
	}
	.paint_item{
		margin:0 0 54px;
	}
	.paint_info{
		margin:0 0 50px;
	}
	.paint_item .text_box01{
		margin:20px 0;
	}
	.paint_item .paint_performance_list dl{
		width:48%;
	}
	.paint_item .paint_performance_list dt{
		width:50%;
		gap:6px;
	}
	.paint_item .paint_performance_list dt p{
		font-size:13px;
		line-height:1;
	}
	.paint_item .paint_performance_list dd{
		width:50%;
		padding:0 5px;
		font-size:12px;
	}
	.paint_item .paint_performance_list dd small{
		font-size:11px;
		text-align:center;
		width:100%;
		left:0;
	}
	.paint_work_list{
		flex-direction: column;
		gap:20px;
	}
	.paint_work_list li{
		width:100%;
	}
	.paint_item h4{
		font-size:18px;
		line-height:2;
		margin:0 0 20px;
	}

/*============================================================================

$blog

============================================================================*/
.blog_box{
	gap:9px;
}
.blog_box h2.blog_tit{
	font-size:16px;
	margin:0 0 5px;
}
.blog_box .blog_cate a{
	width:82px;
	line-height:26px;
	font-size:12px;
}
.blog_box .blog_class li{
	font-size:12px;
	margin:0;
}
.blog_box li.blog_cate{
	margin:0 10px 0 0;
}
.blog_thumbnail{
	width:110px;
}
.thumbnail img{
	height:150px;
}
.blog_box .blog_excerpt{
  /* overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; */
	font-size:13px;
	margin:0 0 10px;
}
.blog_box .btn01 a{
	font-size:12px;
	width:135px;
	padding: 5px 9px 5px 10px;
}
.blog_box .btn01 a::after{
	right:10px;
	width:27px;
	background-position: right;;
}

.blog_top_cate .side_area{
	padding:30px 0 20px;
}
.blog_top_cate .side_area ul{
	display:flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.blog_top_cate .side_area ul li a{
	width:44vw;
	line-height:38px;
	border:1px solid #333;
	font-size:14px;
	text-align:center;
}

.recent ul{
	height:120px;
}

.blog_single h2{
	font-size:22px;
	padding:12px;
}
.blog_single h3{
	font-size:18px;
	line-height:1.4;
}
.blog_single h4{
	font-size:16px;
}

.blog_box .blog_text p{
	font-size:14px;
	line-height:2;
}
	
/*==================================================================

.text_box

==================================================================*/


/*==================================================================

.timing 塗装のタイミング

==================================================================*/
.check_point{
	flex-direction: column;
	gap:30px;
}
.check_point li{
	width:100%;
}

/*==================================================================

.layout

==================================================================*/
.layout_tit {
  font-size: 18px;
}

.layout_tit em {
  font-size: 24px;
}

/* 1つ並びのレイアウト。画像は無し、左にタイトル、右に文章 */
.layout01 .layout01_box {
  display: block;
}

.layout01 .layout01_title {
  width: 100%;
}

.layout01 .layout01_text {
  width: 100%;
}

.layout01 .layout01_text img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

/* 2つ並びのレイアウト。最初(dt)にタイトル、画像がその下(dd)、画像の下に文章 */
.layout02 {
  display: block;
}

.layout02 .layout02_box {
  width: 100%;
}

.layout02 .layout02_box img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

/* 1つ並びのレイアウト。画像が左、右にタイトル、タイトル下に文章 */
.layout03 {
  margin: 0 0 15px;
}

.layout03 .layout03_box {
  display: block;
}

.layout03 .layout03_title {
  width: 100%;
}

.layout03 .layout03_title img {
  width: 70%;
  margin: 0 auto;
  display: block;
  padding: 0;
}

.layout03 .layout03_text {
  width: 100%;
  padding: 15px 3% 1%;
}


/* 1つ並びのレイアウト。画像が左、右にタイトル、タイトル下に文章、タイトルと文章のエリア(dd)は背景色が別の色 */
.layout04 .layout04_box {
  display: block;
}

.layout04 .layout04_title {
  width: 100%;
  padding: 2%;
}

.layout04 .layout04_title img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

.layout04 .layout04_text {
  width: 100%;
}


/* 1つ並びで3列に区切られたレイアウト。画像が左、画像の下にタイトル、右に文章 */
.layout05 .layout05_box {
  display: block;
}

.layout05 .layout05_title {
  width: 100%;
  text-align: center;
  display: block;
}

.layout05 .layout05_title img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

.layout05 .layout05_text1:nth-child(2) {
  width: 100%;
  margin-top: 10px;
}

.layout05 .layout05_text1:nth-child(3) {
  width: 100%;
  border-left: none;
}

/* 1つ並びで3列に区切られたレイアウト。左がタイトル、真ん中と右に文章 */
.layout06 {
  margin: 0 0 15px;
}

.layout06 .layout06_box {
  display: block;
}

.layout06 .layout06_title {
  width: 100%;
  padding: 3%;
  display: block;
  text-align: center;
}

.layout06 .layout06_title img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

/* 数字 */
.layout06 .layout06_text1:nth-child(2) {
  width: 100%;
  margin-top: 10px;
}

.layout06 .layout06_text1:nth-child(3) {
  width: 100%;
  border-left: none;
}

/* 3つ並びのレイアウト。 */
.layout07 {
  display: block;
}

.layout07 .layout07_box {
  display: block;
  width: 100%;
}

/* layout09 */
.layout09 .layout09_box {
  display: block;
}

.layout09 .layout09_title {
  width: 100%;
  text-align: center;
  display: block;
}

.layout09 .layout09_title img {
  width: 70%;
  margin: 0 auto;
  display: block;
}

.layout09 .layout09_text1 {
  width: 100%;
  margin-top: 10px;
}

/* layout10 */
.layout10 .flow_box {
  justify-content: space-between;
  padding: 6%;
}

.layout10 .flow_box::before {
  display: none;
}

.layout10 .flow_box .number {
  width: 42px;
  height: 42px;
  margin-right: 0;
  font-size: 20px;
}

.layout10 .flow_box .layout10_box {
  width: 80%;
}

.layout10 .flow_box .layout10_text .title {
  font-size: 14px;
  line-height: 1.4;
}

.layout10 .flow_box .layout10_text .title span {
  display: block;
  padding-bottom: 8px;
  font-weight: bold;
}

.layout10 .flow_box .layout10_text .title span::after {
  display: none;
}

.course_ablation::before {
  display: none;
}

/* layout11 */
[class^="layout11_text"] dl dt,
[class^="layout11_text"] dl dd {
  margin-left: 0;
  width: 100%;
}

[class^="layout11_text"] dl dt {
  margin-bottom: 0;
}

[class^="layout11_text"] dl dd {
  margin-bottom: 10px;
}

.layout11_image02 {
  flex-wrap: wrap;
}

.layout11_image02 span {
  width: 100%;
}

.layout11_image02 span:last-child {
  margin-top: 40px;
}

.layout11_image02 span:last-child::before {
  top: -32px;
  bottom: auto;
  left: 0;
  right: 0;
  justify-content: center;
  content: "\f078";
}

/*============================================================================

$news

============================================================================*/

.news_list li a {
  display: block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.lightbox{
	margin-top:50px;
	min-width:375px;
}

/*============================================================================

ローディング

============================================================================*/

.loading_tit{
	width:85vw;
	font-size:3.5vw;
}


/*============================================================================

倉庫LP warehouse

============================================================================*/
.lp_box{
	width:100%;
	padding:0 4%;
}

.tit_wrap h2{
	font-size:20px;
}


.warehouse_work_list{
	flex-direction: column;
	align-items: center;
	gap:40px;
}
.warehouse_work_item{
	width:100%;
}

.warehouse_importance_list{
	padding:20px;
}
.warehouse_importance_item{
	padding:20px;
	flex-direction: column-reverse;
	gap:20px;
}
.warehouse_importance_item figure{
	width:100%;
}
.warehouse_importance_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 10px;
}
.warehouse_importance_info h3 strong{
	font-size:20px;
}

.warehouse_feature_list{
	flex-direction: column;
}
.warehouse_feature_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 5px;
}


.warehouse_greeting_flex{
	flex-direction: column-reverse;
}
.warehouse_greeting_img{
	width:100%;
}
.warehouse_greeting_img01{
	width:90%;
}
.warehouse_greeting_img02{
	margin:-120px 0 0;
	width:50%;
}
.warehouse_greeting_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 20px;
}

.warehouse_promise_list{
	flex-direction: column;
}
.warehouse_promise_item{
	width:100%;
	padding:30px;
}
.warehouse_promise_item h3{
	font-size:20px;
	gap:10px;
}
.warehouse_promise_item h3 span{
	width:40px;
	height:40px;
}

.warehouse_cta{
	padding:50px 20px;
}
.warehouse_cta h2{
	line-height:1.5;
	font-size:28px;
}

.warehouse_flow_list{
	padding:20px;
}
.warehouse_flow_item{
	flex-direction: column;
}
.warehouse_flow_item::before{
	left:0;
	right:0;
	margin:auto;
}
.warehouse_flow_num{
	width:100%;
	display: block;
	font-size:20px;
	padding:10px 0;
	text-align:center
}
.warehouse_flow_num{
	font-size:20px;
}
.warehouse_flow_info{
	padding:20px;
}
.warehouse_flow_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 5px;
}


/*============================================================================

アパートLP apartment

============================================================================*/
.apartment_work_list{
	flex-direction: column;
	align-items: center;
	gap:60px;
}
.apartment_work{
	padding:50px 0 30px;
}
.apartment_work_item{
	width:100%;
}
.apartment_work_item .build_name{
	font-size:5vw;
	border:2px solid #ff6600;
	padding:2vw 8vw;
	margin:-7vw auto 5vw;
}
.apartment_work_img li p{
	top:4vw;
	font-size:4vw;
	padding:2vw 5vw;
}
.apartment_work_info{
	padding:5vw;
}
.apartment_work_info .work_tit{
	font-size:4vw;
}
.apartment_work_info h3{
	font-size:4vw;
}
.apartment_work_comment{
	padding:4vw;
}

.apartment_trouble{
	padding:0 0 20px;
}
.apartment_trouble h2{
	font-size:6vw;
}
.apartment_trouble_list{
	width:100%;
	border-radius:15px;
	padding:20px;
}
.apartment_trouble_list li{
	padding:0 0 0 10vw;
	font-size:4vw;
}
.apartment_trouble_list li::before{
	top:1vw;
	bottom:auto;
	width:7vw;
	height:5vw;
}
.apartment_trouble .apartment_trouble_read{
	font-size:5vw;
}
.apartment_trouble .service_check{
	gap:10px 4%;
	justify-content: space-between;
}
.apartment_trouble .service_check li {
	width:48%;
	padding:14px;
}
.apartment_trouble .service_check li h3{
	font-size:3.5vw;
}

.apartment_greeting{
	padding:50px 0;
}

.apartment_importance_list{
	border-radius:15px;
	padding:20px;
}
.apartment_importance_item{
	padding:20px;
	flex-direction: column-reverse;
	gap:20px;
	border-radius:10px;
}
.apartment_importance_item figure{
	width:100%;
}
.apartment_importance_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 10px;
}
.apartment_importance_info h3 strong{
	font-size:20px;
}

.apartment_feature_list{
	flex-direction: column;
}
.apartment_feature_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 5px;
}


.apartment_greeting_flex{
	flex-direction: column-reverse;
}
.apartment_greeting_img{
	width:100%;
}
.apartment_greeting_img01{
	width:90%;
}
.apartment_greeting_img02{
	margin:-120px 0 0;
	width:50%;
}
.apartment_greeting_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 20px;
}

.apartment_promise_list{
	flex-direction: column;
}
.apartment_promise_item{
	width:100%;
	margin:0 0 40px;
	padding:0;
}
.apartment_promise_item:last-child{
	margin:0;
}
.apartment_promise_item figure{
	width:100%;
}
.apartment_promise_item h3{
	font-size:20px;
	line-height:1.4;
}
.apartment_promise_item h3 span{
	width:40px;
	height:40px;
}

.apartment_cta{
	padding:20px 0;
}
.apartment .footer_contact{
	border-radius:15px;
}
.apartment .footer_contact .tit01{
	font-size:5vw;
}

.apartment_flow_list{
	padding:20px;
	border-radius:15px;
}
.apartment_flow_item{
	flex-direction: column;
}
.apartment_flow_item::before{
	left:0;
	right:0;
	margin:auto;
}
.apartment_flow_num{
	width:100%;
	display: block;
	font-size:20px;
	padding:10px 0;
	text-align:center;
	border-radius:10px 10px 0 0;
}
.apartment_flow_num{
	font-size:20px;
}
.apartment_flow_info{
	padding:20px;
	border-radius: 0 0 10px 10px;
}
.apartment_flow_info h3{
	font-size:20px;
	line-height:1.5;
	margin:0 0 5px;
}


/*============================================================================

.wordpress関係

============================================================================*/

.contents {
    width: 100%;
  }

	.contents.strength{
		margin:0 auto;
	}

  .wrapper {
    width: 100%;
    display: block;
    padding: 10px 0 0;
  }

  .wrapper main {
    width: 100%;
    margin-bottom: 40px;
    padding: 0 20px 0;
  }

  :is(.blog,.single-post,.archive,.category):not(.tax-cate_menu,.tax-cate_disease,.tax-cate_symptom,.tax-cate_case) .wrapper main{
    width: 100%;
  }

  body.home .wrapper main {
    padding-left: 0;
    padding-right: 0;
  }

  .medical_single {
    padding: 0 !important;
  }

  .body_single p img {
    display: block;
    margin: 0 auto;
  }

	/*--------------------サイドバー--------------------*/
  .side_area {
    width: 100%;
    margin: auto;
    padding: 30px 20px 20px;
  }


.pager{
	gap:10px;
}

.current {
	width: 46px;
	height: 46px;
  font-size:22px;
	line-height:46px;
}

.pager a {
	width: 46px;
	height: 46px;
  font-size:22px;
	line-height:46px;
}


/*common*/
.pc{display:none!important}.sp{display:block!important}.pc_inline{display:none!important}.sp_inline{display:inline!important}.pc_table{display:table!important}.sp_table{display:table!important}img{max-width:100%;height:auto}.sp_mb00{margin-bottom:0!important}.sp_mr00{margin-right:0!important}.sp_ml00{margin-left:0!important}.sp_mt00{margin-top:0!important}.sp_pb00{padding-bottom:0!important}.sp_pr00{padding-right:0!important}.sp_pl00{padding-left:0!important}.sp_pt00{padding-top:0!important}.sp_center{text-align:center}


}

@media screen and (max-width:320px) {

.sp_inline_iP {
  display: inline !important
}
}