@charset "utf-8";
@media screen and (max-width: 800px) {
    a.telephone[href*="tel:"] {
        pointer-events: auto;
        cursor: pointer;
        color: #1EAA39;
    }
	
	.for-pc { display:none; }
	.for-sp { display:block; }


	
    .sp_none {
        display: none;
    }
    .pc_none {
        display: block;
    }
    .menu>li:hover>a {
        color: #1EAA39;
        background: transparent;
    }

    header>div {
        display: block;
        padding-top: 10px;
    }
    header>div>div>h2.h_company {
        text-align: center;
    }
    header>div>div>h2.h_company img {
        max-width: 380px;
        width: 80%;
    }
    header>div>address {
        width: 80%;
        margin: 0 auto;
        text-align: left;
    }
    header>div>address .tel {
        font-weight: bold;
        color: #1EAA39;
        text-align: center;
    }
    .menu {
        display: flex;
        justify-content: space-between;
        text-align: center;
    }
    .menu>li {
        float: none;
        /* width: 90%; */
        height: 30px;
        line-height: 30px;
        border-right: none;
        font-size: 12px;
        padding: 8px 0;
        letter-spacing: 0;
        text-align: center;
        margin: 0 auto;
        box-sizing: content-box;
    }
    .menu>li.menu__single {
        position: initial;
    }
    li.menu__single ul.menu__second-level {
        position: absolute;
        top: 45px;
        width: 180px;
        background: #fafafa;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        line-height: 1.5;
        font-size: 14px;
    }
    li.menu__single:hover ul.menu__second-level {
        top: 45px;
        visibility: visible;
        opacity: 1;
    }
    .menu__second-level li a {
        min-height: initial;
        padding: 5px 0;
    }
    .init-bottom:after {
        display: none;
    }
    section#newsWrap .news_itiran {
        width: 80%;
        margin-right: auto;
    }
    #jigyou .manzoku {
        width: auto;
        margin-left: 10px;
        margin-right: 10px;
    }
    section#jigyou>div.flex {
        display: block;
        width: auto;
        padding-bottom: 10px;
    }
    section#jigyou>div>section {
        margin-bottom: 20px;
        width: auto;
    }
    section#rnp div {
        width: auto;
        display: block;
        padding-bottom: 10px;
    }
    section#rnp div a {
        display: block;
    }
    footer>div#footer_info>section {
        width: auto;
        display: block;
    }
    footer>div#footer_info>section h2 {
        padding-left: 10px;
        padding-right: 10px;
        width: auto;
    }
    footer>div#footer_info>section address {
        padding-left: 10px;
        padding-right: 10px;
        width: auto;
    }
    #pageheader #catch {
        height: 100px;
        align-items: center;
    }
    main #catch h2 {}
    main #catch {
        width: auto;
        height: auto;
        align-items: center;
    }
	#pageheader #catch2 {
        height: 100px;
        align-items: center;
    }
    main #catch2 h2 {}
    main #catch2 {
        width: auto;
        height: auto;
        align-items: center;
    }
    main#company .company_info {
        width: auto;
        margin: 50px auto 50px;
    }
    main#company .company_info table tr {
        display: flex;
        flex-direction: column;
    }
    main#company .company_info table th {
        margin-right: 0;
        justify-content: flex-start;
        padding: 10px 15px;
    }
    main#company .company_info table td {
        padding: 10px 10px;
        margin-left: 0;
        margin-bottom: 1.5rem;
    }
    main#company .company_info table tr:nth-child(odd) th,
    main#company .company_info table tr:nth-child(odd) td {
        background: #fff;
    }
    main#company .company_info table tr th {
        background: #F2F2F2!important;
    }
    main#contact .formTable tr {}
    main#contact .formTable th {
        width: auto;
        display: block;
        text-align: left;
        padding-left: 10px;
        padding-right: 10px;
        padding-top: 0;
        padding-bottom: 0;
    }
    main#contact .formTable td {
        width: auto;
        display: block;
        padding-top: 0px;
        padding-bottom: 0px;
        padding-left: 10px;
        padding-right: 10px;
        margin-bottom: 15px;
    }
    main#contact .formTable td select {
        margin-bottom: 5px;
    }
    main#contact article#policy .policy_wrap {
        border-right: none;
        border-left: none;
        width: auto;
    }
    main div.area p {
        padding-left: 0;
        padding-right: 20px;
    }
    main div.area {
        width: 90%;
    }
    footer>div#footercopy>p.to_top {
        right: 10px;
    }
    .subpage_contents .d-flex {
        flex-direction: column;
    }
    .subpage_contents .d-flex figure {
        padding-bottom: 1rem;
    }
    .step {
        width: auto;
        align-items: center;
    }
    .step>span {
        font-size: 7rem;
        padding-left: 1rem;
    }
    .flow_box:nth-child(odd) {
        flex-direction: column;
        text-align: center;
    }
    .flow_box:nth-child(odd) .step {
        border-right: none;
        border-bottom: 1px solid #fff;
    }
    .flow_box:nth-child(even) {
        flex-direction: column;
        text-align: center;
    }
    .flow_box:nth-child(even) .step {
        border-left: none;
        border-bottom: 1px solid #fff;
    }
    .subpage_contents .d-flex_02 {
        flex-direction: column;
        flex-wrap: wrap;
    }
    .subpage_contents .d-flex_03 {
        flex-direction: column;
        flex-wrap: wrap;
    }
    .subpage_contents .d-flex_03 div {
        padding-top: 2rem;
    }
    .subpage_contents .business03 {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column;
        align-items: flex-start;
    }
    .subpage_contents .business03>div {
        width: 100%;
        padding-bottom: 2rem;
    }
    .flow_box:nth-child(odd):before {
        left: 50%;
    }
    .flow_box:nth-child(even):before {
        left: 50%;
    }
    .swiper-container {
        width: 100%;
    }
    .main_image_text {
        text-align: center;
        line-height: 2;
        font-size: 20px;
    }
    .subpage_contents p {
        line-height: 1.7;
    }
    .subpage_contents .textbox {
        line-height: 1.7;
    }
    .subpage_contents dl dd {
        line-height: 1.7;
    }
    .subpage_contents .pointlist li {
        padding: 0.25rem 0;
        padding-left: 1rem;
    }
    .subpage_contents .pointlist li:before {
        top: 0.25rem;
    }
    .subpage_contents .bg_nyuukyo {
        position: relative;
        padding-right: 0;
    }
    .subpage_contents .bg_nyuukyo:after {
        padding-top: 50px;
        position: relative;
        width: 100%;
        background-position: bottom center;
    }
    .renovation-flow .d-flex figure:first-child {
        padding-right: 0;
        padding-bottom: 2rem;
    }
    .renovation-flow .d-flex figure:last-child {
        padding-left: 0;
        padding-top: 5rem;
    }
    .case_wrap .arrow {
        transform: rotate(90deg);
        width: 50px;
        top: -50px;
    }
    .pt60 {
        padding-top: 3rem;
    }
    .pb60 {
        padding-bottom: 3rem;
    }
    .square span {
        font-size: 1.4rem;
        padding: 0.5rem 0.5rem;
        margin-right: 0.5rem;
        margin-left: 0.5rem;
    }
    #newsList li {
        padding: 15px 0px;
    }
    main#recruit #boshu {
        padding: 0 20px;
    }
    main#recruit #boshu dl {
        display: block;
    }
    main#recruit #boshu dl dt {
        border-bottom: 1px solid #ccc;
    }
    main#recruit #boshu dl dd {
        border-bottom: 10px solid #fff;
    }
    main#recruit #form {
        padding: 60px 20px;
    }
    main#recruit #form table {
        max-width: initial;
    }
    main#recruit #form table th,
    main#recruit #form table td {
        display: block;
        padding: 0;
    }
    main#recruit #form table th {
        text-align: left;
        padding: 20px 0 10px;
        min-width: 300px;
    }
    main#recruit #form table td {
        padding: 0px 0 20px;
    }
	
    .sdgs {
        width: 100%;
    }
    .sdgs-container {
        margin-left: auto;
        margin-right: auto;
    }
    .sdgs-top {
        text-align: center;
    }
    .sdgs-title {
        font-size: 30px;
    }
    .sdgs-image {
        align-items: center;
        margin-top: 2rem;
        margin-bottom: 2rem;
    }
    .sdgs-border {
        margin-left: auto;
        margin-right: auto;
        background-color: #1eaa39;
        height: 3px;
        width: 410px;
        border: none;
        
    }
    .sdgs-title {
        color: #1eaa39;
    }
    
    .sdgs-image-1 {
		width: 400px;
    }
    .sdgs-text {
        font-size: 12px;
        margin-bottom: 2rem;
    }
    .sdgs-text-br {
        display: inline;
    }
    .sdgs-subtitle {
        margin-left: auto;
        margin-right: auto;
        width: 410px;
        background-color: #1eaa39;
        font-size: 21px;
        color: #fff;
        margin-bottom: 2rem;
    }
    .sdgs-outer {
        text-align: center;
    }
    .sdgs-middle {
    }
    .sdgs-inner {
        text-align: center;
        font-size: 30px;
        margin-bottom: 1rem;
		margin-top: 1rem;
    }
    .sdgs-wrapper-1 {
        display: flex;
        justify-content: center;
        column-gap: 40px;
        margin-bottom: 2rem;
    }
    .sdgs-image-2 {}
    .sdgs-wrapper-2 {
        flex-direction: column;
        align-items: center;
        column-gap: 2rem;
        margin-bottom: 2rem;
    }
    .sdgs-left {
		margin-bottom: 1rem
	}
    .sdgs-right {}
    .sdgs-content-1 {
        background-color: rgba(29,177,69,0.1);
        width: 240px;
        font-size: 15px;
        border: 2px solid #1DB145;
        color: #1DB145;
        padding: 0.5rem 0.2rem;
        margin-bottom: 1rem;
		text-align: center;
    }
    .sdgs-text-1 {
        font-size: 13px;
        line-height: 1.5;
    }
    .sdgs-content-2 {
        background-color: rgba(255,195,74,0.1);
        ;
        width: 240px;
        font-size: 15px;
        border: 2px solid #FFC34A;
        color: #FFC34A;
        padding: 0.5rem 0.2rem;
        margin-bottom: 1rem;
		text-align: center;
    }
    .sdgs-text-2 {
        font-size: 13px;
        line-height: 1.5;
    }
    .sdgs-span-1 {
        color: #1DB145;
    }
    .sdgs-span-2 {
        color: #FFC34A;
    }
    
}
	