@charset "utf-8";
@media screen and (max-width: 1199px) {
	.maincopy{
        width: 180px;
        height: calc(180px * 2.00513636363636);
	    top: 11%;
	    right: 7.5%;
	}
	.gnav li{
		width: 46px;
		height: 72px;
	}
	.gnav a{
		overflow: hidden;
	}
	.gnav img{
		width: 60px;
		margin-left: -8px;
	}
}
@media screen and (max-width: 991px) {
	body{
		font-size: 13px;
		line-height: 2.1;
	}
	.maincopy{
        width: 180px;
        height: calc(180px * 2.00513636363636);
	    top: 10%;
	    right: 5%;
	}

	/*-------------------------
	base
	--------------------------*/
	body {
	    margin-bottom: 50px;
	}
	h3 {
    	margin-bottom: 0.5em;
	}
	.dl-horizontal dt {
	    width: 110px;
	    font-size: 1em;
	    overflow: auto;
	    position: relative;
	}
	.dl-horizontal dd {
	    margin-left: 100px;
	}
	.dl-horizontal + .dl-horizontal{
		margin-left: 0;
		margin-right: 0;
		padding-left: 0;
		padding-right: 0;
	}
	dt:first-child {
	    margin-top: 0;
	}
	.dl--horizontal-small dt{
		font-weight: bold;
	}
	.dl--horizontal-small dt,
	.dl--horizontal-small dd{
		float: none;
		margin-left: 0;
	}
	.dl--horizontal-small dt.thumb-col{
		float: left;
		margin-left: 0;
	}
	.dl--horizontal-small dd.txt-col{
		margin-left: 125px;
	}
	/*-------------------------
	common
	--------------------------*/
	.lineBox:before {
    	left:  22px;
	}
	.lineBox:after {
    	right:  22px;
	}
	/*.lineBox__inner {
	    margin: 0 24px;
	}*/
	.bg-scale{
		width: 12px;
	}
	.bg-scale--right{
		background:url(../img/scale_sp-right-gray.png) repeat-y top right;
	}
	.bg-scale--left{
		background:url(../img/scale_sp-left-gray.png) repeat-y top left;
	}
	/*-------------------------
	box
	--------------------------*/
	.box--section {
	    margin-bottom: 60px;
	}
	.box--img-section {
	    margin-bottom: 100px;
	}
	.box--text {
	    padding: 60px 0 100px;
	}
	.box--summary {
	    border-right: 1px solid #dedede;
	    padding: 2.4em 2em 2em;
	}
	.box--summary{
		margin-top: 0;
		margin-bottom: 0;
	}
	.box--summary:last-child{
		margin-bottom: 40px;
	}
	.box--summary + .box--summary{
		border-top: none;
	}
	.box--halfway {
	    margin-top: 0;
    	margin-bottom: 50px;
    	padding: 200px 0;
    	position: relative;
	}
	.box--halfway:before{
		width: 6px;
	    height: 6px;
		top: 0;
	    left: -4px;
	    background-color: #ccc;
	}
	.box--halfway:after{
	    width: 0;
		height: 0;
		bottom: 0;
	    left: -5px;
		border-style: solid;
		border-width: 20px 4px 0 4px;
		border-color: #ccc transparent transparent transparent;
	}
	.box--halfway:before,
	.box--halfway:after{
	    content: "";
	    position: absolute;
	}
	.box--img-grid + .box--img-grid {
    	border:none;
	}
	.box--column {
	    column-count: 1;
	    column-gap: 0;
	    -moz-column-count: 1;
	    -moz-column-gap: 0;
	    -webkit-column-count: 1;
	    -webkit-column-gap: 0;
	    -o-column-count: 1;
	    -o-column-gap: 0;
	    -ms-column-count: 1;
	    -ms-column-gap: 0;
	    margin-bottom: 70px;
	}
	#PCP .box--ttl{
		margin-bottom: 0;
	}
	.copy--box,
	.copy--box.align--left,
	.copy--box.align--right{
		margin: 40px 0 30px;
	    width: 100%;
	    text-align: center;
	}
	.tool-modal {
	    width: 90%;
	    margin: 30px 0;
	    padding: 30px;
	    background: #fff;
	}
	.modal-close {
	    padding: 8px;
	    top: 30px;
	    right: 18px;
	}
	/*-------------------------
	typo
	--------------------------*/
	.ttl--subpage .ttl--border-box {
		font-size: 0.8em;
	    letter-spacing: 0.1em;
	    display: block;
	}
	.subttl {
	    margin-top: 30px;
	}
	.subttl--timeline {
		margin-top: 0;
		padding: 0;
		margin-bottom:  25px;
		border: 1px solid #419271;
	}
	.subttl--timeline-L {
	    text-align: center;
	    margin-left: 0;
	}
	.subttl--timeline-R {
	    text-align: center;
	    margin-right: 0;
	}
	.subttl--basic{
		padding: 1em;
		margin-bottom: 0.5em;
	}
	.copy--vertical{
		margin-bottom: 40px;
		margin-top: 0;
	}
	.copy--vertical img {
	    margin: 0 auto;
    	width: 85%;
	}
	.txt--flow {
	    margin-bottom: 3%;
    	margin-top: -7%;
	}
	.txt--flow p {
	    position: relative;
	}
	/*.button--img__text{
		display: block;
	}*/
	.txt--story:first-child {
    	padding-top: 2em;
	}
	.txt--story {
	    /*padding-left: 16.66666667%;
	    padding-right: 16.66666667%;*/
	    padding-bottom: 30px;
	    margin-bottom: 0;
	    background-color: transparent;
	}
	.button--large {
	    margin: 20px auto 30px;
	    padding: 1.5em;
	    font-size: 1em;
	    letter-spacing: 0.2em;
	}

	/*-------------------------
	index
	--------------------------*/
	.js_img-parallax{
		display: none;
	}
	.img--circle-right{
		display: none;
	}
	.img--triangle-right {
	    margin: -19% -10% -18% 0;
	}
	.img--triangle-left {
    	margin: -12% 0 -27% -10%;
	}
	.img--triangle-left img, .img--triangle-right img, .img--circle img {
	    width: 35%;
	}
	/*-------------------------
	mri
	--------------------------*/
	#piper img{
		width: 100px;
		display: block;
		margin: 0 auto 30px;
		float:none;
		padding-right: 0;
	}
	.box--dialog {
	    padding: 2.5em 2em 2.5em 3.5em;
	}
	.box--stage section {
	    padding-left: 30px;
	}
	.figure--half{
		width: 100%;
		padding: 0;
		float: none;
	}
	/*-------------------------
	check
	--------------------------*/
	.box--col-inner--center {
	    margin-left:0;
	}
	.box--avatar.box--col-inner--center {
	    margin-left: -50%;
	}
	/*-------------------------
	staff
	--------------------------*/
	.img--family{
		display: none;
	}
	.img_staff{
		margin-bottom: 30px;
	}
	.box--staff{
		padding: 60px 0;
    	margin-bottom: 0;
	}
	.staff_01,
	.staff_02{
		background-attachment:scroll;
	}
	.staff_01{
		background-image:url(../img/staff/img_staff01_sp.jpg);
	}
	.staff_02{
		background-image:url(../img/staff/img_staff02_sp.jpg);
	}
	/*-------------------------
	outline
	--------------------------*/
	.box--contact{
		border-bottom:1px solid #dedede;
	}
	.box--policy{
		padding: 120px 0;
	}
	.ttl--policy{
		width: 85%;
		margin-bottom: 80px;
	}
	.box--policy__inner{
		margin-bottom: 60px;
		font-size: 1em
	}
	.box--policy__inner h2{
		margin-bottom: 10px;
	}
	.box--policy__inner img{
		width:  90%;
		/*min-width: 350px;*/
	}
	.box--policy__inner p{
		padding: 0 10%;
	}
	/*-------------------------
	contact
	--------------------------*/
	.mailform li input[type=text] {
	    width: 100%;
	}
	.btn_radio label{
		width: 50%;
	}
	.mailform .btn_submit, .mailform .btn_reset {
	    width: 100%;
	}
	.mailform{ padding-top: 30px; }
	.mailform dl {
	    padding-bottom: 40px;
	    margin-bottom: 40px;
	}
	/*-------------------------
	footer nav
	--------------------------*/
	#footer{
		display: none;
	}
	#footer-sp{
		display: block;
	}
	.sitelogo img{
		width: 160px;
	}
	.sitelogo a {
	    padding-left: 5px;
	}
	.tel_sp{
		width: 120px;
		padding-top: 2px;
	}
	/*navigation*/
    .navicon-wrap {
        display: block;
    }
    .gnav,
    .subnav{
        display: none;
    }
    .box_tel{
    	display: none;
    }
    /*-------------------------
	button
	--------------------------*/
	.button--img{
		padding:0.5em;
		/*display: block;*/
	}
	.button--img img {
	    /*width: 100%;*/
	    display: inline;
    }
    
    
    /*-------------------------
	grid
	--------------------------*/
	.grid_sp{
		display: block;
	}
	#access_map{
	    height: 350px;
	}
	.bnr_column{
		width: 240px;
		left: 18px;
    	bottom: 65px;
    }
    .button_baloon_wrap.is--subpage {
        left: auto;
        right: 10px;
        top: 40px;
        position: fixed;
        bottom: 65px;
        left: auto;
        top: auto;
        animation: unset;
    }
    .button_baloon_wrap.is--subpage .button--img-small img {
        width: 45px;
    }
    .button_baloon_wrap.is--subpage .button--img-small {
        border-radius: 0px;
    }
	/*-------------------------
	utility
	--------------------------*/
	.sp-noPadding{ padding: 0 !important; }
	.sp-noPad-T{ padding-top: 0 !important; }
	.sp-noPad-B{ padding-bottom: 0 !important; }
	.sp-noPad-L{ padding-left: 0 !important; }
	.sp-noPad-R{ padding-right: 0 !important; }
	.sp-noMargin{ padding: 0 !important; }
	.sp-noMar-T{ padding-top: 0 !important; }
	.sp-noMar-B{ padding-bottom: 0 !important; }
	.sp-noMar-L{ padding-left: 0 !important; }
	.sp-noMar-R{ padding-right: 0 !important; }
}
@media screen and (max-width: 767px){
	.maincopy{
        width: 120px;
        height: calc(120px * 2.00513636363636);
	    top: 8%;
	    right:6%;
	}
    .bnr_column {
        width: 150px;
        left: 18px;
        bottom: 56px;
        top: 9px;
        padding: 5px 10px 5px;
        bottom: auto;
        right: 10px;
        left: auto;
    }
    
    .button_baloon_wrap.is--subpage {
        left: auto;
        right: auto;
        bottom: 50px;
        left: 0;
        top: auto;
        width: 100%;
    }
    .button_baloon_wrap.is--subpage .button--img-small img {
        width: 30px;
    }
    .button_baloon_wrap.is--subpage .button--img-small {
        border-radius: 0px;
        width: 100%;
        border-right: none;
        border-left: none;
    }
	.content_acc p{
		border: none;
		padding-left: 0;
		padding-right: 0;
	}
}
@media screen and (max-width: 767px) and (orientation: landscape) {
	.maincopy{
	    width: 130px;
	    top: 8%;
	    right: 5%;
	}
}
@media (max-device-width: 480px){
    .button_baloon_wrap{
        top: 80px;
        left: 7vw;
    }
    .button_baloon {
        padding: 5px 5px 0.6em 5px;
    }
    .button_baloon:after{
        bottom: 15px;
        right: -15px;
        left: auto;
        border-top: 5px solid transparent;
        border-right: 0 solid transparent;
        border-bottom: 5px solid transparent;
        border-left: 14px solid #099c7f;
        -webkit-transform-origin: right center;
                transform-origin: right center;
        -webkit-transform: rotate(0);
                transform: rotate(0);
    }
    @-webkit-keyframes moveUp{
        from{
            -webkit-transform:translate3d(0, 0, 0);
                    transform:translate3d(0, 0, 0);
        }
        50%{
            -webkit-transform:translate3d(0, -2%, 0);
                    transform:translate3d(0, -2%, 0);
        }
        100%{
            -webkit-transform:translate3d(0, 2%, 0);
                    transform:translate3d(0, 2%, 0);
        }
    }
    @keyframes moveUp{
        from{
            -webkit-transform:translate3d(0, 0, 0);
                    transform:translate3d(0, 0, 0);
        }
        50%{
            -webkit-transform:translate3d(0, -2%, 0);
                    transform:translate3d(0, -2%, 0);
        }
        100%{
            -webkit-transform:translate3d(0, 2%, 0);
                    transform:translate3d(0, 2%, 0);
        }
    }
    .bnr_column {
        width: 100px;
        padding: 3px 0;
    }
    .button--img__text.is--style_maru {
        padding-top: 0;
    }
    .button_baloon.button--img-small img {
        width: 32px;
    }
    .button--img__text.is--style_maru{
        font-size: 15px;
        letter-spacing: 0.1rem;
    }
}
@media (max-device-width: 320px){
	.overlay nav {
	    top: 57%;
	}
	.overlay ul li a {
	    padding: 1px;
	}
}


@media print {
    .a{
        a: 200px
    }
}