@charset "UTF-8";

/*　共通設定--------------------------------　*/

html, body, header, section, article, nav, footer,
div, span, p, h1, h2, h3, h4, ul, ol, li, dl, dt, dd,
table, tr, th, td, tbody, thead, tfoot {
	margin: 0;
	padding: 0;}

img { border: 0; vertical-align:bottom }

body {
	width: 100%;
	background-color: #fff;
/*	font: 14px/1.231 'ヒラギノ角ゴ pro W3', "Hiragino KaKu Gothic Pro", Osaka, sans-serif; */
	font-size: 14px;
	line-height: 1.8;
	-webkit-text-size-adjust: 100%;
	}

table td {
	line-height:1.8em }

table td hr {
	margin:0 0 1em 0;
    border: 0;
    height: 1px;
    background: url(../img/hr.gif) repeat-x ;
}

.pc-only{
	display: none;
}
.sp-only{
	display: block;
}
.float-l{
	float: none;
}
.float-r{
	float: none;
}
.mt6em {
    margin-top: 3em;
}

.flex{
	display: block;
}

.flex.remain{
	display: flex;
	display:-ms-flexbox;
}

.ct-half > * {
    width: 100%;
}
.ct-half_gap > * {
    width: 100%;
}

.pd-left {
    padding-left: 0;
}


#back {
}

/*　ヘッダー・スライドバー--------------------------------　*/

/* slimmenu.js内の .menu-collapseに上書き */
.menu-collapser {
	height:60px;
	text-align:left;
}
/* menu内のロゴ画像設定 */
.menu-collapser img#spHeadLogo{
	margin:10px 0 0 0;
	width: auto;
	max-height:35px;
	}


/*　ヘッダー--------------------------------　*/
#head {
    height: 60px;
}
.head_inner {
    padding: 12px 0;
}
#head h1 {
    padding-left: 20px;
    width: auto;
	max-width: 230px;
}
#head .header-contact {
    padding-right: 60px;
}
#head .header-contact > div {
    margin-left: 0;
}
.header-contact_line a::before {
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
	margin-right: 12px;
	margin-left: 10px;
}
.header-contact_tel a::before {
    content: "";
    display: inline-block;
    width: 32px;
    height: 32px;
	margin-right: 12px;
}

/*　ナビ表示--------------------------------　*/

/*ハンバーガーメニュー*/
#head .drawer-hamburger {
    width: 32px;
    right: 10px;
    margin-top: 6px;
    padding: 12px 0.75em 24px;
}
.header-contact_line span,
.header-contact_tel span {
	display: none;
}
#head .drawer-hamburger-icon:before {
    top: -12px;
}
#head .drawer-hamburger-icon:after {
    top: 12px;
}
#head .drawer-menu {
    margin-top: 50px;
}
#head .drawer-nav {
    padding: 5%;
    width: 100%;
}
.drawer--right #head .drawer-nav {
    right: -100%;
}
.drawer-nav .contact-box .shikaku a {
    font-size: 100%;
    padding: 5% 2%;
}
.drawer-nav .contact-box .shikaku a img {
    width: 12%;
    min-width: 18px;
    margin-right: 5px;
    vertical-align: middle;
}
.drawer-nav .contact-box .shikaku strong {
    white-space: nowrap;
    letter-spacing: -0.01em;
}
.navi-logo{
    position: absolute;
    top: 12px;
    left: 20px;
    max-width: 210px;
    transition-timing-function: cubic-bezier(0.1, 0.57, 0.1, 1);
    transition-duration: 0ms;
    transform: translate(0px, 0px) translateZ(0px);
}

/*　背景　*/

/* ナビ下のborder */

/*　スクロール時のナビ固定　jquery連動*/
.fixed {
	position: fixed;
	top: 0px;}





/*　パンくずリスト--------------------------------　*/
#bread {
	width:96%;
	}



/* ビジュアル--------------------------------　*/

#visual {
    height: auto;
}
#visual .visual_01{
	background: url(../img/top_bl_shape.png) no-repeat bottom 16% left -14%, url(../img/top_visual_bg_sp.png) no-repeat top left;
    background-size: 50% auto, 100% 90%;
    position: relative;
    height: auto;
}
#visual .visual_01 .object-left {
    width: 94%;
    position: relative;
    left: inherit;
    top: inherit;
    margin: 0 auto;
    padding-top: 16%;
}
#visual .visual_01 .object-right {
    width: 80%;
    position: relative;
    right: inherit;
    top: inherit;
    bottom: inherit;
    margin: -3% -20% 0 auto;
}
#visual .area-ttl {
    position: relative;
    top: inherit;
    left: inherit;
    transform: translateX(0);
    -webkit-transform: translateX(0);
    width: 100%;
    margin-top: 3%;
}
#visual .object-center {
    width: 64%;
    margin: 0 auto;
    padding-left: 0;
}
#visual .visual_01 .object-left::before,
#visual .visual_01 .object-right::before {
    display: none;
}


#visual .area-ttl_text {
    font-size: 120%;
    margin: 0 auto 8px;
}
#visual .area-ttl a {
    padding: 20px 30px;
    font-size: 130%;
	white-space: nowrap;
}

#title {
    margin: 0 auto;
	padding-top: 45%;
	background: url(../img/page-ttl_bg_sp.png) center top / cover no-repeat;
}
#title h2 {
    font-size: 170%;
    height: 1em;
}

/*　コンテンツ　メインカラム--------------------------------　*/

#contents-main{
	width:100%;
	padding: 60px 0 0;
	margin: 0 auto 0px auto;
}
.contents_inner {
	position: inherit;
}
.w1200 #contents-main {
    width: 94%;
    padding: 20px 0 20px 0;
    margin: 10px auto 0px auto;
}
.con-main-box {
    width: 90%;
    margin: 0 auto 60px;
}
.con-main-box_02{
	width:90%;
    margin: 0 auto 60px;
}
.top-con-main-box {
    margin-top: 0;
}


/*見出し*/
#contents-main h2 {
	width:100%;
	padding:0;
	margin: 0 0 1em;
	font-size: 160%;
    line-height: 1.4;
}

#contents-main h2 img{
	max-width:250px;
	width:100%;
	height:auto;
	}

#contents-main h3 {
	padding:0 0 0.3em 0;
	margin: 0 0 1em 0;
    font-size: 120%;
    font-weight: bold;
}

#contents-main p ,
#contents-main ol ,
#contents-main ul {
	font-size:15px ;
}

#contents-main h2 span.en {
    font-size: 10px;
}


/*　フッター--------------------------------　*/
#footer {
    margin: 0 auto 0px auto;
    padding: 56px 0 10px;
}
#footer .footer_ct {
    display: block;
}
#footer .footer-logo a {
    font-size: 150%;
}
#footer .footer-logo {
    margin: 0 0 10px 0;
}
#footer .copyright {
    margin: 2em 0;
}
/* ページトップ（非表示にする設定） */
/* #footer p.pagetop {
	display: none;
}
#footer p.pagetop a {
	display: none;
} */


/* ★縦書きの設定-------------------------------- */

#contents-main .tate {
    top: 27px;
	left: 0;
}

#contents-main .tate:after {
	content: "";
    width: 1px;
    height: 40px;
    margin-top: 10px;
}




/* ★トップページ--------------------------------　*/

body.index #contents-main {
	width: 100%;
}

/*実家じまい専科についてtop-about*/
.top-about {
    margin-top: 0;
}
.top-about .top-about_inner {
    border-radius: 20px;
    padding: 8% 5%;
}
.top-about .ct-img {
    margin-top: 20px;
    padding: 0 15%;
}
.sp-pd{
    padding: 1em 0;
}

/*ボタン*/
#contents-main .btn {
    font-size: 125%;
    padding: 12px 20px;
}

/*私たちにできること*/
.cando_item {
    width: 100%;
}
.cando_item .want-ttl {
    -webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
    font-size: 130%;
}
.cando_item .want-ttl img{
    max-height: 25px; 
}

#contents-main .cando_item h3 {
    font-size: 160%;
    margin-bottom: 0;
}

/*スライド矢印*/
.cando_list {
    position: relative;
}
.arrow_box{
    position: absolute;
    width: 100%;
    top: 40%;
}
.slide-arrow {
    bottom: 0;
    cursor: pointer;
    margin: auto;
    position: absolute;
    top: 0;
    width: 30px;
}
.prev-arrow,
.next-arrow {
    display: block;
    width: 50px;
    height: 50px;
    transition: all .3s ease;
    cursor: pointer;
}
.prev-arrow {
    left: 0;
    transform: rotate(180deg);
    margin-right: 20px;
}
.next-arrow {
    right: 0;
}

.prev-arrow::before,
.next-arrow::before{
    position:absolute;
    content: "";
    width:20px;
    height:20px;
    border-right: 2px solid #ec6018;
    border-top: 2px solid #ec6018;
    top:0;
    bottom:0;
    left:0;
    right:0;
    margin:auto;
    transform:rotate(45deg);
}

/*よくある質問*/

.faq_num span {
    border-radius: 20px 20px 0 0;
    padding: 20px 2.4em 5px;
    font-size: 120%;
}
.faq_box {
    border-radius: 30px;
    padding: 20px 5% 20px;
}
.faq_hitoicon {
    bottom: 96%;
    max-width: 16%;
}
.icon-left .faq_hitoicon {
    left: 4%;
}
.icon-right .faq_hitoicon {
    right: 4%;
}
#contents-main .faq_ttl h3 {
    padding: 10px;
}
#contents-main .readmore-hide h3 {
    padding-bottom: 0;
}
.readmore button {
    font-size: 120%;
    width: 150px;
}
.readmore button::after {
    content: "";
    width: 10px;
    height: 10px;
}
.faq_box .readmore-hide.is_open {
    margin-top: 30px;
}


/*お知らせ*/
/* .top-news .news-contents {
    width: 100%;
    padding-left: 17%;
}
.top-news .news-contents::before {
    content: "";
    display: inline-block;
    width: 83%;
    margin-left: 17%;
}
.top-news .con-main-box {
    padding: 20px 0 64px;
}
.news-contents .topics {
    padding: 1em 0;
}
#contents-main .news .news-contents .topics .date {
    font-size: 90%;
    margin: 4px 0 0;
    line-height: 1.4;
}
#contents-main .news .news-contents .topics .title {
    margin: 0 0 0;
} */


/*お問い合わせ*/
.top-contact {
    padding-bottom: 80px;
}
.top-contact_inner{
    position: relative;
}
.top-contact_inner {
    border-radius: 20px;
    padding: 6% 5%;
}
.top-contact_left {
    position: absolute;
    z-index: 0;
    bottom: 5%;
}
.top-contact_right {
    width: 37.5%;
    margin-left: auto;
}

/**/

/* ★プロフィール-------------------------------- */







/* ★ワークス-------------------------------- */


/* ★ニュース-------------------------------- */
.newsblog{
	display: block;
}

.newsblog .leftSide{
	width: 100%;
}
.newsblog .rightSide{
	width: 100%;
	margin-left: 0;
	margin-top: 3em;
}
.newsblog .rightSide h3{
    text-align: center !important;
}
.post{
	position: relative;
}
.detail .post{
    padding-top: 0;
}




/* ★ブログページのみ--------------------------------　*/


/* 画像下　影の設定を削除 */
body #contents-main .entry p img{
	padding-bottom:0px;
	background:none;
	width:100%;
	margin:0 0 1em 0;
	max-width:680px;
	height:auto;
/* 画像下にmarginを追加 */
	margin-bottom:1em;
}

.entry div {
    font-size: 100%;
}

#contents-main .news-detail .post .title a {
    font-size: 80%;
}

#contents-main .post h2.title {
    line-height: 1.4;
    padding-bottom: 0;
}
#contents-main .post h2 .newsdate {
    text-align: right;
    display: block;
    margin-top: 0.5em;
}
#contents-main .post .to-blogtop {
    margin: 2em 0;
}



/* ★会社概要--------------------------------　*/
.about-text .ct-text{
	width: 100%;
	text-align: left;
}
.about-text .ct-img{
	width: 100%;
	margin-left: 0;
    padding: 0 15%;
}
.case_inner {
    border-radius: 20px;
    padding: 8% 5%;
}
.case_data {
    margin-bottom: 2em;
}
.about .about-text{
	width: 100%;
}
.company-profile_inner {
    padding: 6% 5%;
    border-radius: 20px;
}
#contents-main table.com-profile-table th {
    padding: 10px 10px 10px 0;
    font-size: 100%;
}
#contents-main table.com-profile-table td {
    padding: 10px;
    font-size: 100%;
}


/* ★お問い合わせ-------------------------------- */
.contactform {
    margin-left: 0;
}

#contents-main table {
    margin: 0 0 1em 0;
}
#contents-main table th {
	text-align: left;
    padding: 5px;
    font-size: 16px;
}
#contents-main table td {
    padding: 10px;
    font-size: 16px;
}

/* お問い合わせ　テーブル設定 */
body #contents-main table#inquiry_form  th {
	width:100%;
	display: block;
	box-sizing: border-box;
    white-space: wrap;
}

/* nest table用 */
body #contents-main table#inquiry_form table{
	width:100%;
}

body #contents-main table#inquiry_form td {
	display: block;
	width: 100%;
	box-sizing: border-box;
}

/*iosのフォーム拡大を防ぐ*/
body #contents-main table#inquiry_form  td input {
	font-size: 16px;
	/* transform: scale(0.8); */
}
body #contents-main table.soyinquiry_address_form td input{
    width: 10em;
}
body #contents-main table.soyinquiry_address_form td {
    padding: 5px 0;
    line-height: 1;
}

/* テキストボックスなどの長さ */

body #contents-main table#inquiry_form  td input.name{
	width:100%}
body #contents-main table#inquiry_form  td input.mail{
	width:100%}
body #contents-main table#inquiry_form  td input.address{
	width:100%}
body #contents-main table#inquiry_form  td input.tel{
	width:100%}
body #contents-main table#inquiry_form  td input.text{
	width:100%}
body #contents-main table#inquiry_form  td textarea {
	font-size: 16px;
	width:100%;}

@media screen and (max-width:480px) {
		/*　画面サイズが480pxからはここを読み込む　*/
}
