@charset "UTF-8";
/* CSS Document */

.modal_content,
.modal_content button {
	font-family: 'Open Sans', 'Noto Sans JP' !important;
}

h2 {
    font-size: 190%;
    text-align: center;
    font-weight: 500;
    color: #333;
}
h2::after {
    content: "";
    display: block;
    width: 40px;
    height: 1px;
    border-bottom: 2px solid #808080;
    margin: 0.25em auto 1em;
}
.modal_content h3{
	color: #fff;
	margin-bottom: 3em;
}
section.ask-phone .a-phone:before {
	font-family: "Font Awesome 5 Free";
	content: '\f2a0';
	font-weight: 900;
	margin-right: 0.2em;
}
section.ask-form .a-form:before {
	font-family: "Font Awesome 5 Free";
	content: '\f0e0';
	font-weight: 900;
	margin-right: 0.2em;
}
section.office-map button {
	font-size: 110%;
	font-weight: 500;
	margin: 0;
	padding: 0.25em;
	height: auto;
	width: 160px;
	background: #fff;
    color: #333;
}
section.office-map button:before {
	margin-right: 0.5em;
}
section.office-map ul li a:hover{
	color: #fff;
}
section.office-map .map-inner{
	position: relative;
}
section.office-map .map-inner ul li a{
	display: block;
}
.office-map ul li {
	position: absolute;
}
.office-map ul li.pin_sapporo {
    top: 1%;
    right: 6%;
    z-index: 1;
}
.office-map ul li.pin_kashima {
    top: 46%;
    right: 1%;
    z-index: 1;
}
.office-map ul li.pin_chiba {
    top: 57%;
    right: 1%;
    z-index: 1;
}
.office-map ul li.pin_tokyo {
    top: 78%;
    right: 6%;
    z-index: 1;
}
.office-map ul li.pin_nagoya {
    top: 82%;
    right: 23%;
    z-index: 1;
}
.office-map ul li.pin_osaka {
    top: 3%;
    right: 56%;
    z-index: 1;
}
.office-map ul li.pin_plant {
    top: 11%;
    right: 56%;
    z-index: 1;
}
.office-map ul li.pin_oversea {
    top: 11%;
    right: 56%;
    z-index: 1;
}
.office-map ul li.pin_mcscenter {
    top: 19.5%;
    right: 56%;
    z-index: 1;
}
.office-map ul li.pin_kurashiki {
    top: 36%;
    right: 58%;
    z-index: 1;
}
.office-map ul li.pin_hiroshima {
    top: 36%;
    right: 76%;
    z-index: 1;
}
.office-map ul li.pin_hiroshima-p {
    top: 42%;
    right: 78%;
    z-index: 1;
}
.office-map ul li.pin_syunan {
    top: 86%;
    right: 64%;
    z-index: 1;
}
.office-map ul li.pin_syunan-p {
    top: 92%;
    right: 66%;
    z-index: 1;
}
.office-map ul li.pin_niihama {
    top: 82%;
    right: 44%;
    z-index: 1;
}
.office-map ul li.pin_fukuoka {
    top: 66%;
    right: 82%;
    z-index: 1;
}
.map-inner .subtxt{
	font-size: 90%;
    position: absolute;
    bottom: -20px;
}

section.ask-phone .attop, section.ask-form .attop{
	text-align: center;
    margin: 2em 0;
}
section.ask-form button.member_btn {
	width: 350px;
    margin: 0 auto 1em;
}
section.ask-form button::before{
	margin-right: 0.2em;
}
section.ask-form .attention{
	font-size: 90%;
	color: #f00;
}
section.ask-form .form-elements{
	margin-bottom: 2em;
}
section.ask-form .form-elements button {
	width: 400px;
}
.form-inner{
	width: 760px;
	margin: 0 auto;
}
.form-inner ul{
	display: flex;
    margin-bottom: 0.5em;
}
.form-inner ul li{
	padding: 0.5em;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.form-inner ul li:first-child{
    display: flex;
    align-items: center;
    justify-content: flex-end;
	width: 40%;
	margin-right: 1em;
    font-weight: 500;
    color: #727171;
}
.form-inner ul li .two-column:first-child {
    margin-right: 0.5em;
}
.form-inner ul li .two-column:last-child {
    margin-left: 0.5em;
}
.form-inner ul li.display-block {
    display: block;
}
input.txtarea, textarea.txtarea {
    padding: 0.6em;
    outline: none;
    border: 1px solid #ccc;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    font-size: 85%;
	width: 98%;
}
input.two-column {
    padding: 0.6em;
    outline: none;
    border: 1px solid #ccc;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    font-size: 85%;
	width: 49%;
}
input.two-column.address {
    width: 47%;
}
input.two-column + span {
    display: inline-block;
    text-align: center;
}
.office_select_btn{
	border: 1px solid #ccc;
    border-radius: 30px;
    background: none;
    width: 288px;
    position: relative;
}
.office_select_btn select {
    width: 100%;
    padding: 8px 48px 8px 18px;
    cursor: pointer;
    text-indent: 0.01px;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
}
.office_select_btn select::-ms-expand {
	display: none;
}
.office_select_btn::after {
    position: absolute;
    top: calc(50% - 3px);
    right: 0.8em;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #ccc;
    pointer-events: none;
}


/***input radio***/
.box-input-radio {
    padding-top: 17px;
}
.box-input-radio li {
    padding: 0!important;
    margin: 0;
    color: #333;
    display: block;
    position: relative;
    float: left;
    width: 100%;
    height: auto;
}
.box-input-radio li:first-child {
    color: #333!important;
}
.box-input-radio li input[type=radio] {
    position: absolute;
    visibility: hidden;
}
.box-input-radio li label {
    display: block;
    position: relative;
    width: 120px;
    padding: 0 0 0 25px;
    margin: 0;
    font-size: 100%;
    font-weight: 400;
    height: 30px;
    cursor: pointer;
    -webkit-transition: all 0.25s linear;
}
.box-input-radio li .check {
    display: block;
    position: absolute;
    border: 2px solid #333;
    border-radius: 100%;
    height: 20px;
    width: 20px;
    left: 0;
    top: 0;
    pointer-events: none;
    transition: border .25s linear;
    -webkit-transition: border .25s linear;
}
.box-input-radio li .check::before {
    display: block;
    position: absolute;
    content: '';
    border-radius: 100%;
    height: 12px;
    width: 12px;
    top: 2px;
    left: 2px;
    margin: auto;
    transition: background 0.25s linear;
    -webkit-transition: background 0.25s linear;
}
.box-input-radio input[type=radio]:checked ~ label {
    color: #3CA062;
}
.box-input-radio input[type=radio]:checked ~ .check {
    border: 2px solid #3CA062;
}
.box-input-radio input[type=radio]:checked ~ .check::before {
    background: #3CA062;
}


/***modal***/
.modal_content{
    position: relative;
    align-self: center;
    width: 60%;
    max-width: 800px;
    padding: 30px 30px 15px;
    box-sizing: border-box;
    background: #333;
	color: #fff;
    line-height: 1.4em;
    transition: 0.5s;
	text-align: center;
	margin: 0 auto;
}
.modal_content .modal-elements{
	margin-bottom: 1em;
}
.modal_content ul{
	display: flex;
	justify-content:center;
	align-items: center;
}
.modal_content ul li{
	margin: 0 0.5em;
}
.modal_content ul li h4{
	font-size: 250%;
    margin: 0 auto;
}
.modal_content ul li h4 a{
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
}
.modal_content ul li button{
	background: #fff;
    border: 2px solid #fff;
    color: #333;
	cursor: default;
	border-radius: 40px;
    padding: 0 1em;
    height: 5.5em;
    width: 270px;
}
.modal_content ul li button::before{
	display: none;
}
/*input.to-form-btn reset*/
input.to-form-btn {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
	color: #fff;
	font-size: 14px;
	width: 220px;
    height: 100%;
	cursor: pointer;
}
input.to-form-btn:hover{
	color: #3ca062;
}

.modal_btn{
	border-radius: 40px;
    padding: 0 1em;
  position: relative;
    height: 3.5em;
  width: 220px;
  transition: 0.5s;
	color: #fff;
	background: #3ca062;
	margin: 3em auto;
	border: none;
}
.modal_btn:hover {
    color: #3ca062;
    background: #fff;
    border: 2px #3ca062 solid;
}
.modal_btn::before{
	content: url("../img/arrow_w.svg");
	display: block;
    width: 7px;
    margin-left: 1.5em;
    position: absolute;
    top: 16px;
    left: 0;
}
.modal_btn:hover::before {
    content: url("../img/arrow_g.svg");
}

#target {
	margin-top: 200vh;
}

/***end modal***/


.map-sp{display: none;}

@media screen and (max-width: 999px) {
	.map-pc{
		display: none;
	}
	.map-sp{
		display: block;
	}
	.map-inner img{
		width: 100%;
	}
	section.office-map .map-inner {
		width: 100vw;
		max-width: none;
		margin: 0 0 4em calc(-50vw + 50%);
	}
	section.office-map button {
		font-size: 95%;
		width: 138px;
	}
	.office-map ul li.pin_sapporo {
		bottom: 95.5%;
		left: 59%;
		top: auto;
	}
	.office-map ul li.pin_kashima {
	    bottom: 84.5%;
		right: 9.2%;
		top: auto;
	}
	.office-map ul li.pin_chiba {
		top: 95%;
		right: 11%;
		}
	.office-map ul li.pin_tokyo {
		top: 87%;
		right: 14%;
	}
	.office-map ul li.pin_nagoya {
		top: 76.5%;
		right: 19%;
	}
	.office-map ul li.pin_osaka {
		top: auto;
		bottom: 96%;
		right: 57%;
	}
	.office-map ul li.pin_plant {
		top: auto;
		bottom: 89%;
		right: 57%;
	}
	.office-map ul li.pin_oversea {
		top: auto;
		bottom: 87%;
		right: 57%;
	}
	.office-map ul li.pin_mcscenter {
		top: auto;
		bottom: 77.5%;
		right: 57%;
	}
	.office-map ul li.pin_kurashiki {
		top: 61%;
		right: auto;
		left: 27%;
	}
	.office-map ul li.pin_hiroshima {
		top: auto;
		right: 56%;
		bottom: 64%;
	}
	.office-map ul li.pin_hiroshima-p {
		top: 36%;
		right: 56%;
	}
	.office-map ul li.pin_syunan {
		top: 80%;
		right: auto;
		left: 8%;
	}
	.office-map ul li.pin_syunan-p {
		top: 85%;
		right: auto;
		left: 8%;
	}
	.office-map ul li.pin_niihama {
		top: 68.5%;
		left: 23%;
		right: auto;
	}
	.office-map ul li.pin_fukuoka {
		top: 80%;
		right: auto;
		left: 8%;
	}
	.modal_content{
		width: 100%;
		padding: 30px 2% 15px;
		margin-top: 60px;
	}
    section.ask-form {
        max-width: 500px;
    }
	section.ask-form button.member_btn {
		width: 100%;
}
	.form-inner {
		width: 100%;
	}
	.form-inner ul {
		display: block;
        margin-bottom: 1em;
	}
    .form-inner ul li {
        padding: 0.5em 0;
    }
	.form-inner ul li:first-child {
        justify-content: flex-start;
        align-items: baseline;
		width: auto;
        padding-bottom: 0;
	}
	.office_select_btn{
		width: 100%;
	}
    section.ask-form .form-elements{
        margin-bottom: 3em;
    } 
    input.txtarea, textarea.txtarea {
        width: 100%;
    }
}

div.ppolicy{
    line-height: 1.25em;
    margin-bottom: 1.5em;
}
div.ppolicy p:first-child{
    font-weight: bold;
}
div.ppolicy p:not(:first-child) {
    margin-left: 1.2rem;
}