﻿/*----------------------------------------------------------------------
	common
 ---------------------------------------------------------------------*/
body {
	/*
    font-family:'Lucida Grande',
				'メイリオ',
				Meiryo,
				'Hiragino Kaku Gothic ProN',
				'ヒラギノ角ゴ ProN W3',
				sans-serif;
    */
    font-family: "Kosugi Maru", sans-serif;
    font-style: normal;
	color:#000;
	min-width:1200px;
	font-size:16px;
    line-height: 1.7;
    letter-spacing: 1px;
	-webkit-print-color-adjust: exact;/*chrome印刷用*/
	background:#fff;
}
html, body {
	height:100%;
	width:100%;
	margin:0;
	padding:0;
}
body,
table {
	padding:0;
	margin:0;
	overflow:auto;
	font-size:14px;
	-webkit-text-size-adjust:none;
}
b,
strong {
	font-weight: 700;
}
p {
	margin-bottom: 0px;
}
ul,
ol {
	list-style: none;
}
ul {}
ol {}
li > ul,
li > ol {}
img {
	-ms-interpolation-mode: bicubic;
	border: 0;
	vertical-align: middle;
}
button,
input,
select,
textarea {
	-webkit-box-sizing: border-box;
	-moz-box-sizing:    border-box;
	box-sizing:         border-box;
	margin: 0;
	vertical-align: baseline;
}
button,
input {
	line-height: normal;
}
textarea {
	background-image: -webkit-linear-gradient(hsla(0,0%,100%,0), hsla(0,0%,100%,0)); /* Removing the inner shadow, rounded corners on iOS inputs */
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
	border:none;
}

button[disabled],
input[disabled] {
	cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
	padding: 0;
}

input[type="search"] {
	-webkit-appearance: textfield;
}

input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}
textarea {
	overflow: auto;
	vertical-align: top;
	resize:vertical;
}
caption,
th,
td {
	font-weight: normal;
	text-align: left;
}
table {
    border-collapse:collapse;
    border-spacing:0;
}
input, select {
    vertical-align:middle;
}
a { outline:none !important;	text-decoration:none; color:#333; }
a:focus { outline:none !important; color:#333; }
a:active { outline:none !important; color:#333; }
a:visit { color:#333; }
a:hover img {
	opacity: 0.70;
}
img {
	vertical-align:text-bottom;
}
a img {
	border:0;
}

/*---------- flex ----------*/
.head {
    margin-bottom:18px;
	display: -webkit-flex;
    display: flex;
    -webkit-align-items: flex-end;
	        align-items: flex-end;
	-webkit-justify-content: space-between;
			justify-content: space-between;
}

/*---------- NotFound ----------*/
.error404 {
    text-align: center;
    margin:100px auto;
}

/*----------------------------------------------------------------------
	header
 ---------------------------------------------------------------------*/
header {
    position: relative;
    width:100%;
    padding-top:20px;
}
#header {
    position: relative;
    max-width:1200px;
    margin:0 auto;
    padding:0 10px;
}
#header p.desc {
    text-align: right;
    margin-bottom: 5px;
}
.logo {}
.info {
    width:290px;
}
.mail {
    margin:0 0 5px 0;
    line-height: 40px;
    text-align: center;
}
.mail a {
    display:block;
    font-size:25px;
    font-weight: bold;
    padding-left:50px;
    border-radius:5px;
    background:url("../img/parts/ic_mail.png") 50px 50% no-repeat #ff5459;
    color:#fff;
    -webkit-box-sizing:border-box;
			box-sizing:border-box; 
}
.mail a:hover {
    background:url("../img/parts/ic_mail.png") 50px 50% no-repeat rgba(255,84,89,0.70);
}
.tel {
    position: relative;
    color:#3d0019;
    font-size:35px;
    font-weight:bold;
    letter-spacing:3px;
}
.tel span {
    display: inline-block;
    font-size:20px;
    margin-right:5px;
    letter-spacing:3px !important;
}

/*------------------------------ Grobal Nav ----------*/
nav#gnav {
    display: block;
    margin:0 auto;
    padding:17px 0;
    background:#ffc1b8;
}
nav#gnav ul {
	display: -webkit-flex;
    display: flex;
	-webkit-justify-content: center;
			justify-content: center;
}
nav#gnav ul li {
	position:relative;
	font-size: 20px;
	line-height:130%;
    letter-spacing:2px;
    background:#ffc1b8;
}
nav#gnav ul li a,
nav#gnav ul li div {
	position:relative;
	display: block;
	text-align: center;
    color:#3d0019;
    padding:0 35px;
    font-size:20px;
	line-height:130%;
    -webkit-box-sizing:border-box;
			box-sizing:border-box;
}
nav#gnav ul li a:before,
nav#gnav ul li div:before {
    position: absolute;
    content:'';
    top:0;
    left:0;
    height:100%;
    border-left:1px solid #fff;  
}
nav#gnav ul li:first-child a:before,
nav#gnav ul li:first-child div:before {
    display: none !important;
}

/*-- subMenu ------------------------------*/
nav#gnav ul li ul {
	position:absolute;
	top:100%;
	left:0;
	display:block;
	width:150%;
	padding:15px 0 0 0;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
    z-index: 10;
}
nav#gnav ul li ul li {
	position: relative;
	overflow: hidden;
	text-align:left !important;
	height: 0;
	margin:0;
	font-size:16px !important;
	width:100% !important;
	padding: 0 !important;
	-webkit-transition: 0.3s;
			transition: 0.3s;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
nav#gnav ul li ul li a {
	line-height:50px !important;
	padding:0 10px 0 35px;
	font-size:16px !important;
	margin:0;
	display: block !important;
    text-align: left !important;
	-webkit-box-sizing:border-box;
			box-sizing:border-box;
}
nav#gnav ul li ul li:hover a {
	background:#FFD2CC;
}
nav#gnav ul li ul li a:after {
	position: absolute;
	content:'';
	top:50%;
	right:25px;
	width:6px;
	height: 6px;
	margin-top:-3px;
	border-top:2px solid #3d0019;
	border-right:2px solid #3d0019;
	-webkit-transform:rotate(45deg);
			transform:rotate(45deg);
}
nav#gnav ul li:hover ul li {
	overflow: visible;
	height:50px !important;
	border-bottom:1px solid rgba(255,255,255,0.20);
}
nav#gnav ul li ul li a:before,
nav#gnav ul li ul li div:before {
    display: none !important;
}

/*----------------------------------------------------------------------
	Footer
 ---------------------------------------------------------------------*/
footer {
    position: relative;
    padding-top:65px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
#footer {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: flex-end;
            align-items: flex-end;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    padding:0 10px 25px 10px;
    max-width:1200px;
    margin:0 auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
#footer .logo-f {
    width:495px;
}
#footer .logo-f img {
    width:100%;
    height:auto;
}
#footer .address {
    font-size:17px;
}
#footer .address span {
    display: inline-block;
    margin-right:25px;
}
small {
    position: relative;
    display: block;
    text-align: center;
    padding:20px 0;
}
small br {
    display: none;
}

/*---------- pageUp ----------*/
#pageUp {
    position:absolute;
    top:0;
    left:50%;
    margin-left:-19px;
	width:39px;
	height:39px;
	background:#ffc1b8;
	border-radius:50%;
    text-align: center;
    z-index:2;
}
#pageUp:after {
	position: absolute;
	content:'';
	top:17px;
	left:13px;
	width:10px;
	height:10px;
	border-top:2px solid #fff;
	border-right:2px solid #fff;
	-webkit-transform: rotate(-45deg);
			transform: rotate(-45deg);
}
#pageUp:hover {
	cursor: pointer;
}

/*---------- link ----------*/
/*------------------------------ Grobal Nav ----------*/
nav#fnav {
    display: block;
    margin:0 auto;
    padding:17px 0;
    background:#ffc1b8;
}
nav#fnav ul {
	display: -webkit-flex;
    display: flex;
	-webkit-justify-content: center;
			justify-content: center;
}
nav#fnav ul li {
	position:relative;
	font-size: 18px;
	line-height:130%;
    letter-spacing:2px;
    background:#ffc1b8;
}
nav#fnav ul li a,
nav#fnav ul li div {
	position:relative;
	display: block;
	text-align: center;
    color:#3d0019;
    padding:0 35px;
    font-size:20px;
	line-height:130%;
    -webkit-box-sizing:border-box;
			box-sizing:border-box;
}
nav#fnav ul li a:before,
nav#fnav ul li div:before {
    position: absolute;
    content:'';
    top:0;
    left:0;
    height:100%;
    border-left:1px solid #fff;  
}
nav#fnav ul li:first-child a:before,
nav#fnav ul li:first-child div:before {
    display: none !important;
}

/*------------------------------ フッター固定ボタン ----------*/
#fBtn {
	display: none;
}

/*----------------------------------------------------------------------
	top page
 ---------------------------------------------------------------------*/
#wrap-top {
    position: relative;
    padding:0 10px;
    max-width:1200px;
    margin:0 auto;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
#wrap-top section {
    padding-bottom:0 !important;
}
#wrap-top section h1 {
    font-weight: 700;
    position: relative;
    background: url("../img/parts/ic_ttl.png") 10px 50% no-repeat;
    border-bottom:3px solid #ff5459;
    padding:5px 0 5px 60px;
    margin-bottom:40px;
    color:#3d0019;
    font-size:32px;
    letter-spacing:1px;
}

/*---------- realestate ------------------------------*/
/*---------- tab ----------*/
.tab {
	display:flex;
	flex-wrap:wrap;
	justify-content:flex-start;
	max-width:1200px;
	margin:0 auto;
}
.tab li {
    position: relative;
	width:392px;
	color:#3d0019;
    background:url("../img/parts/tab.png") 0 0 no-repeat;
	text-align:center;
	opacity:1;
    line-height: 50px;
	cursor:pointer;
	font-size:1.3em;
	font-weight:500;
}
.tab li.select {
	background:url("../img/parts/tab_select.png") 0 0 no-repeat;
	color:#3d0019;
}
.tab li h3 {
	position: relative;
	font-size:1.3em;
    font-weight:500;
	vertical-align: middle;
}

.content {
	position:relative;
    background-color:#ffcec7;
    min-height:300px;
}
.content .box {
	padding:30px 45px 0 45px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.content .hide {
	visibility:hidden;
	position:absolute;
	height:0;
	overflow:hidden;
}

/*---------- recommend ----------*/
#recommend,
#recommend_buy {
	width:100%;
	position:relative;
}
#recommend .ttl:before,
#recommend_buy .ttl:before {}

#recommend .ttl,
#recommend_buy .ttl {}
#recommend .ttl span,
#recommend_buy .ttl span {
	height:140px;
	display:inline-block;
	line-height:140px;
	position:relative;
	left:0;
	z-index:5;
}
#recommend .tbl,
#recommend_buy .tbl{
	display:block;
	overflow:hidden;
	width:100%;
}
#recommend tbody,
#recommend tr,
#recommend_buy tbody,
#recommend_buy tr{
	display:block;
}
#recommend .tbl td,
#recommend_buy .tbl td{
	width:33.33333333% !important;
	margin:0;
    padding:20px;
    box-sizing: border-box;
	position:relative;
}
#recommend .tbl td.none,
#recommend_buy .tbl td.none{
	border:0;
	background-color:transparent;
	background-image:none;
}
#recommend .tbl td .loading,
#recommend_buy .tbl td .loading{
	padding:15px;
	text-align:center;
	vertical-align:middle;
	color:#999;
}
#recommend .tbl td .loading img,
#recommend_buy .tbl td .loading img{
	vertical-align:middle;
	margin-right:10px;
}

#recommend .tbl td .inner,
#recommend_buy .tbl td .inner{
	width:100%;
    min-height:300px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
			box-sizing: border-box;
}
#recommend .tbl td .photo,
#recommend_buy .tbl td .photo {
    position: relative;
	width:100%;
    height:200px;
	/*height:230px;*/
	overflow:hidden;
	text-align:center;
}
#recommend .tbl td .photo img,
#recommend_buy .tbl td .photo img{
	max-width:100%;
	width:auto;
	height:auto;
	transform: scale(1);
    transition:0.3s;
}
#recommend .tbl td .photo img:hover,
#recommend_buy .tbl td .photo img:hover{
	transform: scale(1.2);
}
#recommend .tbl td .txt,
#recommend_buy .tbl td .txt{
	margin:10px 0 0 0;
}
#recommend .tbl td .txt .add,
#recommend_buy .tbl td .txt .add{
	margin-top: 0.5em;
	line-height:130%;
	clear:both;
}

#recommend .tbl td .txt .add span{
	font-size: 0.85rem;
	margin-bottom: 0.2em;
}
#recommend .tbl td .txt .madori,
#recommend_buy .tbl td .txt .madori{
	margin-top:0.8em;
	font-size: 1.2em;
	line-height:1;
	font-weight: normal;
	display:inline-block;
	color:#333;
}
#recommend .tbl td .txt .price,
#recommend_buy .tbl td .txt .price{
	margin-top:0.8em;
	line-height:1;
	font-size: 0.9rem;
	font-weight:bold;
	display:inline-block;
}
#recommend .tbl td .txt .price strong,
#recommend_buy .tbl td .txt .price strong{
	font-size: 1.5rem;
	font-weight: normal;
	vertical-align: baseline;
	color: #DD2A50;
	line-height: 100%;
}

#recommend .tbl td .name,
#recommend_buy .tbl td .name{
	padding:0;
	font-size:1rem;
	font-weight:bold;
	line-height:130%;
}

#recommend .tbl td .name a:hover,
#recommend_buy .tbl td .name a:hover {
	opacity: 0.5;
}

#recommend .tbl td .copy,
#recommend_buy .tbl td .copy{
	line-height:130%;
	margin-top: 0.2em;
	font-size: 0.80rem;
}

/*---------- News ------------------------------*/
.bx-news {
    max-width:1080px;
    margin:0 auto;
    font-size:14px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.bx-news dl {
    overflow-x: hidden;
    height:310px;
}
.bx-news dl div {
    padding:10px 0;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.bx-news dl div dt {
    color:#ff5459;
    width:250px;
}
.bx-news dl div dd {
    width:800px;
}
.bx-news dl div dd a {
    color:#ff5459;
    text-decoration: underline;
}
.ct {
    display: inline-block;
    border:1px solid #ff5459;
    width:100px;
    line-height:23px;
    color:#ff5459;
    text-align: center;
    font-size:12px;
    border-radius:3px;
    margin:0 0 0 25px;
}

/*---------- work ------------------------------*/
#work p {
    font-size:20px;
    margin-bottom:40px;
}
.li-content {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content:space-between;
            justify-content:space-between;
    -webkit-flex-wrap: nowrap;
            flex-wrap: nowrap;
    margin-bottom:35px;
}
.li-content div {
    position: relative;
    width:32%;
    background:#ffded9;
    padding:20px 20px 160px 20px;
    border-radius: 5px;
    text-align: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.li-content div dt {
    font-weight: 700;
    font-size: 33px;
    margin-bottom:10px;
    letter-spacing:3px;
}
.li-content div dd {
    font-size: 17px;
    line-height:30px;
    margin-bottom:10px;
    background:#fff;
    width:200px;
    display: inline-block;
}
.li-content div:after {
    position: absolute;
    content:"";
    left:50%;
}
.cont-01:after {
    bottom:-30px;
    margin-left:-119px;
    background:url("../img/parts/content01.png") 0 0 no-repeat;
    width:237px;
    height:168px;
}
.cont-02:after {
    bottom:-56px;
    margin-left:-88px;
    background:url("../img/parts/content02.png") 0 0 no-repeat;
    width:175px;
    height:196px;
}
.cont-03:after {
    bottom:-44px;
    margin-left:-96px;
    background:url("../img/parts/content03.png") 0 0 no-repeat;
    width:192px;
    height:171px;
}

/*---------- company ------------------------------*/
.company-info {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    margin-bottom:30px !important;
}
#company dl div {
    display: -webkit-flex;
    display: flex;
    font-size:18px;
}
#company dl div br {
    display:none;
}
#company dl div dt {
    width:100px;
    text-align-last: justify;
}
#company dl div dd {
    width:420px;
    border-left:1px solid #000;
    margin-left:15px;
    padding-left:15px;
}
#company p {
    font-size:18px;
    margin-bottom:60px;
}

/*----------------------------------------------------------------------
	common
 ---------------------------------------------------------------------*/

article {
    position: relative;
    overflow: hidden;
    max-width:1200px;
    margin:0 auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
section {
    position: relative;
    padding:70px 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.bx {
    position: relative;
    max-width:1080px;
    margin:0 auto;
}

/*----------------------------------------------------------------------
	assessment
 ---------------------------------------------------------------------*/

#assessment h1 {
    font-weight: 700;
    position: relative;
    background: url("../img/parts/ic_ttl.png") 10px 50% no-repeat;
    border-bottom:3px solid #ff5459;
    padding:5px 0 5px 60px;
    margin-bottom:40px;
    color:#3d0019;
    font-size:32px;
    letter-spacing:1px;
}
.txt-assessment {
    position: relative;
    margin:0 auto 40px auto;
    text-align: center;
    font-size:20px;
    line-height:200%;
    max-width:1200px;
}

.bx-form {
    position: relative;
    max-width:1100px;
    margin:0 auto 20px auto;
}
.bx-form p {
    width:840px;
    margin:0 auto 40px auto;
    
}
.bx-form img {
    display: block;
    margin:0 auto 40px auto;
}
/*---------- form ------------------------------*/
table.default {
	width: 100%;
	margin-bottom:20px;
}
table.default th {
    position: relative;
	width: 25%;
    line-height: 100%;
    padding:30px 20px 25px 20px;
	font-weight: 700;
	border-bottom:1px solid #909090;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td {
	background:#fff;
	border-bottom:1px solid #909090;
	line-height: 100%;
    padding:17px 20px;
	font-size: 14px;
	vertical-align: top;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td input[type="text"],
table.default td input[type="email"],
table.default td input[type="tel"],
table.default td textarea {
	font-size: 16px;
	-webkit-appearance: none;
			border-radius: 0;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td select {
	border-radius: 5px;
    background:#e5e5e5;
    border:1px solid #ccc;
    padding: 8px;
	margin:0;
	width:30%;
	font-size:16px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td input[type="text"],
table.default td input[type="email"],
table.default td input[type="tel"] {
	border:1px solid #ccc;
    border-top:1px solid #ccc;
    border-left:1px solid #ccc;
	padding: 8px;
	margin:0;
	width:50%;
	font-size:16px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td textarea {
	border:1px solid #ccc;
    border-top:1px solid #ccc;
    border-left:1px solid #ccc;
	line-height: 150%;
	padding: 8px;
	width:80%;
	-webkit-appearance: none;
			border-radius: 0;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default div.contact input {
    width:83%;
}
table.default div.tel input {
    width:25%;
}
#submit {
	position:relative;
	claer:both;
	overflow: hidden;
	display: block;
	background:#fff;
    border:2px solid #ff5459;
	margin: 0 auto;
	line-height: 65px;
	width:400px;
    font-size:16px;
    font-weight:700;
	border-radius:15px;
	color:#ff5459;
	-webkit-appearance: button;
  			appearance: button;
}
#submit::-webkit-search-decoration,
#button::-webkit-search-decoration {
  display: none;
}
#submit::focus {
  outline-offset: -2px;
}
#submit:hover{
	cursor: pointer;
}
#complete {
	padding: 20px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	min-height: 300px;
	text-align: center;
}
#complete p strong {
	margin-bottom:20px;
	display: block;
}
#complete .ttl-sendmail {
    font-size:20px;
    font-weight:700;
    margin-bottom:40px;
    color:#ff5459;
}
.h:before {
	position: absolute;
	content:'必須';
	top:22px;
	right:20px;
	margin:0;
	color:#fff;
	width:55px;
	font-size:12px;
    line-height: 30px;
	background:#ff5459;
    border-radius:5px;
	text-align: center;
}
.error {
	display: block;
	margin:15px 0 0 0;
    font-weight:700;
	color:#ff0000;
}
.bx-error {
	border:1px solid #ff5459;
	line-height:45px;
	text-align:center;
	color:#ff5459;
	margin:80px auto;
	background:rgba(255,0,4,0.05);
}
.bx-error br {
    display: none;
}
.confirm td {
    line-height: 150% !important;
    vertical-align: middle !important;
}
.txt_submit {
    text-align: center;
}

/*---------- attention ----------*/
.attention {
    position: relative;
    display: block;
    margin-bottom:20px;
    color:#ff0000;
    width:auto !important;
    padding-left:20px;
}
.attention:before {
    position: absolute;
    content:'※';
    top:0;
    left:0;
}

/*---------- radio, checkbox ----------*/
table.default td label {
    line-height: 35px !important;
    margin-right:20px;
}
table.default td label:hover {
	cursor: pointer;
}
table.default td input[type="radio"],
table.default td input[type="checkbox"] {
    position: relative;
    right: 0;
    bottom: 0;
    left: 0;
    top:-10px !important;
    height: 20px;
    width: 20px;
    vertical-align: -100%;
    transition:all .15s ease-out 0s;
    cursor: pointer;
    display: inline-block;
    margin: 0 10px 0 0;
    outline: none;
    border-radius: 10%;
	opacity:1 !important;
	-webkit-appearance: none;
    		appearance: none;
}
table.default td input[type="radio"] {
    border-radius: 50%;
}
table.default td input[type="radio"]:checked:before,
table.default td input[type="checkbox"]:checked:before {
    transform: scale(0.5);
}
table.default td input[type="radio"]:before {
    content: '';
	margin:-2px 0 0 -2px;
    width: 22px;
    height: 22px;
	display: block;
    border-radius: 50%;
    transform: scale(0);
    -webkit-transition: 0.2s;
			transition: 0.2s;
}
table.default td input[type="checkbox"]:before {
    content: '';
	margin:-2px 0 0 -2px;
    width: 22px;
    height: 22px;
	display: block;
    transform: scale(0);
    -webkit-transition: 0.2s;
			transition: 0.2s;
}
table.default td input[type="radio"],
table.default td input[type="checkbox"] {
    border: 1px solid #999;
	background:#fff;
}
table.default td input[type="radio"]:checked:before,
table.default td input[type="checkbox"]:checked:before {
    background: #c8c8c8;
}
table.default td input[type="checkbox"] {
	position: relative;
	width:20px;
	height:20px;
	top:5px;
	-webkit-transform:scale(1.1);
			transform:scale(1.1);
}

/*---------- flex ----------*/
table.default dl div {
    margin-bottom:15px;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
            align-items: center;
}
table.default dl div:last-child {
    margin-bottom:0;
}
table.default dl div dt {
    width:140px;
}
table.default dl div dd {
    width:450px;
}

/*---------- input width ----------*/
input.w20 {
    width:20% !important;
    margin-right:20px !important;
}

/*---------- label vertical ----------*/
.int_blk label {
    display: block;
}

/*------------------------------ privacy policy ----------*/
#privacy {
    position: relative;
	max-width:1100px;
	margin:0 auto 20px auto;
}
#privacy p.ttl-privacy {
    color:#ff0000;
    margin-bottom:10px;
    text-align: left;
}
.bx-agree {
	border:1px solid #c8c8c8;
	background:#fff;
	padding:40px;
	height:235px;
	width:100%;
	overflow-x: hidden;
	-webkit-box-sizing:border-box;
			box-sizing:border-box;
}
#privacy h2 {
    font-size:16px;
    font-weight:700;
    margin-bottom:10px;
}
#privacy p {
    font-size:14px;
    margin-bottom:20px;
}
#privacy ul,
#privacy ol {
    margin-bottom:20px;
}
#privacy ul li {
    font-size:14px;
    list-style:disc;
    margin-left:25px;
}
#privacy ol li {
    font-size:14px;
}
.txt_privacy {
    max-width:1100px;
    margin:0 auto;
}
.ttl-privacy {
    font-family: "Kosugi Maru", sans-serif;
    font-weight: 400;
    font-style: normal;
    position: relative;
    margin-bottom:70px;
    text-align: center;
    font-size:36px;
    letter-spacing:5px;
}
/*---------- send box -----------------------------*/
.bx-send {
    position: relative;
    margin:80px auto 0 auto;
    width:400px;
}
.dl a:hover{
    color: silver;
}
/* お知らせ NEW アイコン */
#news dl .new {
  color: #fff;
  font-size: 0.6rem;
  background: #ffb46d;
  border-radius: 20px;
  width: 45px;
  text-align: center;
  display: inline-block;
  margin-left: 15px;
  vertical-align: middle;
}

/*お知らせ モーダル*/
div.news_modal_body {
    border-radius:10px;
    max-width:960px !important;
    box-shadow: 0 0 7px rgba(0,0,0,0.30);
}
div.modal_title {
    padding: 1rem 0.3rem;
    font-size: 1.2rem;
    margin-bottom: 1rem;
    font-weight:700;
    border-bottom: 1px solid #efefef;
}
div.modal_date{
    text-align: center;
    width:120px;
    line-height:30px;
    background:#f5f5f5;
    border-radius:30px;
    color: #6c757d;
}
div.modal_text{
    padding:15px 10px 50px 10px;
    line-height:220%;
    font-size:18px;
    box-sizing:border-box;
}
hr.modal_hr{
    margin-bottom: 15px;
    background-color: #6c757d;
}
.remodal{
    padding: 20px 45px 45px 45px !important;
}
.remodal a{
    border-bottom:1px solid silver;
}
.remodal a:hover{
    color: silver;
}

.remodal-cancel {
    border-radius: 10vh;
    transition: 0.5s;
    height: 30px;
    padding: 0px  !important;
}
.remodal img{
    max-width: 100%;
}

@media only screen and (max-width:800px) {
    .dl a:hover{
        color:#0A7F40 !important;
    }
    div.news_modal_body {
        border-radius:7px !important;
        max-width:96% !important;
    }
    div.modal_title {
        padding: 1rem 0.3rem;
        font-size: 1.2rem;
        margin-bottom: 1.5rem;
        font-weight:700;
        text-align: left;
    }
    div.modal_date{
        font-size:12px;
    }
    div.modal_text{
        padding:10% 0 10% 0;
        line-height:180%;
        font-size:16px;
        text-align: left;
        box-sizing:border-box;
    }
    .remodal{
        padding: 5% 6% 10% 6% !important;
    }
    div.modal_text{
        padding-left: 5px;
        padding-right: 5px;
    }
    .remodal img{
        max-width: 100%;
    }
}

/*-----------------------------------------------------------------------------------------
	SP
-----------------------------------------------------------------------------------------*/

@media only screen and (max-width:800px) {
    body {
        min-width:100%;
        font-size:16px;
    }
    html, body {}
    body,
    table {}
    b,
    strong {}
    p {}
    ul,
    ol {}
    ul {}
    ol {}
    li > ul,
    li > ol {}
    img {}
    button,
    input,
    select,
    textarea {}
    button,
    input {}
    textarea {}

    button,
    html input[type="button"],
    input[type="reset"],
    input[type="submit"] {}

    button[disabled],
    input[disabled] {}

    input[type="checkbox"],
    input[type="radio"] {}

    input[type="search"] {}

    input[type="search"]::-webkit-search-decoration {}

    button::-moz-focus-inner,
    input::-moz-focus-inner {}
    textarea {}
    caption,
    th,
    td {}
    table {}
    input, select {}
    a {}
    a:focus {}
    a:active {}
    a:visit {}
    a:hover img {
        opacity: 1 !important;
    }
    img {}
    a img {}


    /*---------- flex ----------*/
    .head {
        display:block;
        padding: 0;
    }

    /*---------- NotFound ----------*/
    .error404 {
        margin:15% auto;
    }

    /*----------------------------------------------------------------------
        header
     ---------------------------------------------------------------------*/
    header {
        position:fixed;
        top:0;
        left:0;
        width:100%;
        height:60px;
        padding:0;
        z-index: 1000;
        background:#fff;
    }
    #header {
        max-width:100%;
        margin:0;
        padding:10px;
    }
    #header p.desc {
        display: none;
    }
    .logo h1 {
        width:240px;
        height:auto;
        margin-top:1%;
    }
    .logo h1 img {
        width:100%;
        height:auto;
    }
    .info {
        display: none;
    }
    .mail {}
    .mail a {}
    .mail a:hover {}
    .tel {}
    .tel span {}
    
    /*------------------------------ global Nav, Menu ----------*/
	#panel-btn {
		display: inline-block;
		position: fixed;
		top:0;
		right:0;
		width:60px;
		max-width:60px;
		min-width:60px;
		height:60px;
		margin-top:0;
		z-index:7000;
	}
	#panel-btn:after {
		position: absolute;
		content:'menu';
		top:35px;
		left:18px;
		font-size:13px;
		font-weight:700;
		color:#ff5459;
	}
	#panel-btn-icon {
		display: block;
		position: absolute;
		top: 35%;
		left: 14px;
		width: 35px;
		height: 2px;
		background: #ff5459;
		border-radius:50px;
		-webkit-transition: 0.2s;
				transition: 0.2s;
	}
	#panel-btn-icon:before,
	#panel-btn-icon:after {
		position: absolute;
		content: "";
		top: 50%;
		left: 0;
		display: block;
		width: 35px;
		height: 2px;
		background: #ff5459;
		-webkit-transition: 0.3s;
				transition: 0.3s;
	}
	#panel-btn-icon:before {
		margin-top: -8px;
	}
	#panel-btn-icon:after {
		margin-top: 6px;
	}
	#panel-btn .close {
		background: transparent;
	}
	#panel-btn .close:before,
	#panel-btn .close:after {
		margin-top: 0;
		background: #ff5459;
	}
	#panel-btn .close:before{
	  -webkit-transform: rotate(-45deg);
			  transform: rotate(-45deg);
	}
	#panel-btn .close:after{
	  -webkit-transform: rotate(-135deg);
			  transform: rotate(-135deg);
	}
	.dr_on {
		top:60px;
		left:0 !important;
		visibility:visible !important;
		opacity:1 !important;
		z-index:9999 !important;
		-webkit-transition: .7s;
				transition: .7s;
	}
	.dr_off {
		top:60px;
		visibility:hidden;
		opacity:0;
		-webkit-transition: .7s;
				transition: .7s;
	}
	.over_hide {
    	overflow: hidden !important;
	}

    /*------------------------------ Grobal Nav ----------*/
    nav#gnav {
        padding:0;
		position: fixed;
		top:60px;
		left:0;
		width:100%;
		max-width:100%;
		height:100%;
		visibility:hidden;
		opacity:0;
		margin:0;
		z-index: 9999 !important;
    }
    nav#gnav ul {
        display:block;
		margin:5% auto;
		height:68%;
		width:80%;
		overflow-x: hidden;
    }
    nav#gnav ul li {
		font-size: 20px;
		line-height:100%;
        text-align: left;
		margin:0;
        width:100%;
		border-bottom:1px solid rgba(255,255,255,0.30);
        border-left:0;
        letter-spacing:0;
    }
    nav#gnav ul li a,
    nav#gnav ul li div {
		position: relative;
		padding:4% 1%;
        border:0 !important;
        font-size:20px !important;
        text-align: left;
        line-height:100% !important;
    }
    nav#gnav ul li a:before,
    nav#gnav ul li div:before {
        display: none;  
    }
    nav#gnav ul li:first-child a:before,
    nav#gnav ul li:first-child div:before {}

    /*-- subMenu ------------------------------*/
    nav#gnav ul li ul {
		position:relative !important;
		top:0;
		right:0;
		left:0;
		width:100%;
		border:0;
		margin:0 !important;
		padding:0 0 5% 0;
        display: none;
        z-index: 10;
    }
    nav#gnav ul li ul li {
        position:relative;
        display: block !important;
		height:50px;
		font-size:16px !important;
		width: 100% !important;
		background:none;
		margin:0 0 0 17px !important;
		border:0 !important;
		-webkit-transition: 0.3s;
				transition: 0.3s;
        overflow: hidden;
        text-align:left !important;
    }
    nav#gnav ul li ul li a {
		position:relative;
        display: block !important;
		height:50px;
		line-height:auto !important;
        font-size:16px !important;
		width: 100% !important;
		background:none;
		margin:0 0 0 17px !important;
        padding:0 !important;
		border:0 !important;
		-webkit-transition: 0.3s;
				transition: 0.3s;
    }
    nav#gnav ul li ul li:hover a {
        background:#ffc1b8;
    }
    nav#gnav ul li ul li a:after {
        position: absolute;
        content:'';
        top:50%;
        right:auto;
        left:80%;
        width:6px;
        height: 6px;
        margin-top:-3px;
        border-top:2px solid #3d0019;
        border-right:2px solid #3d0019;
        -webkit-transform:rotate(45deg);
                transform:rotate(45deg);
    }
    nav#gnav ul li:hover ul li {
        border-bottom:none;
    }
    nav#gnav ul li ul li a:before,
    nav#gnav ul li ul li div:before {
        display: none !important;
    }

    /*----------------------------------------------------------------------
        Footer
     ---------------------------------------------------------------------*/
    footer {
        padding:10% 0 80px 0;
        display: inline-block;
        background:#ffe5e1;
    }
    #footer {
        display:block;
        padding:0 2% 4% 2%;
        max-width:100%;
        margin:0;
    }
    #footer .logo-f {
        width:60%;
        margin:0 auto 4% auto;;
    }
    #footer .logo-f img {}
    #footer .address {
        font-size:15px;
        text-align: center;
    }
    #footer .address span {
        display: inline-block;
        margin-right:5%;
    }
    small {
        padding:5% 0;
    }
    small br {
        display:block;
    }

    /*---------- pageUp ----------*/
    #pageUp {
        position:fixed;
        top:auto;
        left:auto;
        right:20px;
        bottom:100px;
        margin-left:auto;
    }
    #pageUp:after {}
    #pageUp:hover {}

    /*---------- link ----------*/
    /*------------------------------ Grobal Nav ----------*/
    nav#fnav {
        display:none;
    }
    nav#fnav ul {}
    nav#fnav ul li {}
    nav#fnav ul li a,
    nav#fnav ul li div {}
    nav#fnav ul li a:before,
    nav#fnav ul li div:before {}
    nav#fnav ul li:first-child a:before,
    nav#fnav ul li:first-child div:before {}

    /*------------------------------ フッター固定ボタン ----------*/
    #fBtn {
		display: block;
		position: fixed;
		left:0;
		bottom:0;
		z-index: 5000;
	}
	#fBtn ul {
		position: fixed;
		left:0;
		bottom:0;
		display: -webkit-flex;
    	display: flex;
		width: 100%;
		-webkit-box-shadow: 0 0 4px rgba(0,0,0,0.10);
				box-shadow: 0 0 4px rgba(0,0,0,0.10);
		
	/*	border-top:1px solid #492611;	*/
	}
	#fBtn ul li {
		width: 33.33333333%;
		font-weight: 700;
		-webkit-box-sizing: border-box;
				box-sizing: border-box;
		text-align: center;
		color:#ff5459;
        background:#fff;
	}
	#fBtn ul li:last-child { border-right:none; }
	#fBtn ul li span {
		display: block;
		font-size: 12px;
		height: 20px;
		margin-top:2%;
	}
	#fBtn ul li a {
		display: block;
		padding:12px 0 7px 0;
		color:#ff5459;
	}
	#fBtn ul li i {
		display: none !important;
	}
	#fBtn ul li img {
		width:80px;
		height: auto;
		margin-top:2%;
	}

    /*----------------------------------------------------------------------
        top page
     ---------------------------------------------------------------------*/
    #wrap-top {
        padding:5% 2%;
        max-width:100%;
        margin:0;
    }
    #wrap-top section {}
    #wrap-top section h1 {
        background: url("../img/parts/ic_ttl.png") 10px 50% no-repeat;
        background-size:20px auto;
        padding:1% 0 1% 40px;
        margin-bottom:4%;
        font-size:22px;
    }

    /*---------- realestate ------------------------------*/
    /*---------- tab ----------*/
    .tab {
        max-width:100%;
    }
    .tab li {
        width:50%;
        line-height: 30px;
        font-size:1em;
        background-size:100%;
    }
    .tab li.select {
        background:url("../img/parts/tab_select.png") 0 0 no-repeat;
        background-size:100%;
    }
    .tab li h3 {
        font-size:1em;
    }
    .content {
        min-height:300px;
    }
    .content .box {
        padding:4% 4% 0 4%;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }
    .content .hide {
        visibility:hidden;
        position:absolute;
        height:0;
        overflow:hidden;

    }

    /*---------- recommend ----------*/
    #recommend,
    #recommend_buy {}
    #recommend .ttl:before,
    #recommend_buy .ttl:before {}

    #recommend .ttl,
    #recommend_buy .ttl {}
    #recommend .ttl span,
    #recommend_buy .ttl span {
        height:140px;
        display:inline-block;
        line-height:140px;
        position:relative;
        left:0;
        z-index:5;
    }
    #recommend .tbl,
    #recommend_buy .tbl{
        display:block;
        overflow:hidden;
        width:90%;
        margin:4% auto 0 auto;
    }
    #recommend tbody,
    #recommend tr,
    #recommend_buy tbody,
    #recommend_buy tr{
        display:block;
    }
    #recommend .tbl td,
    #recommend_buy .tbl td{
        width:100% !important;
        margin:0 0 8% 0;
        padding:0 0 8% 0;
        display: block;
        border-bottom:1px solid #feaa9e;
    }
    #recommend .tbl td:last-child,
    #recommend_buy .tbl td:last-child {
        margin:0;
        padding:0 0 8% 0;
        display: block;
        border-bottom:none;
    }
    #recommend .tbl td.none,
    #recommend_buy .tbl td.none{}
    #recommend .tbl td .loading,
    #recommend_buy .tbl td .loading{}
    #recommend .tbl td .loading img,
    #recommend_buy .tbl td .loading img{
        margin-right:0;
    }

    #recommend .tbl td .inner,
    #recommend_buy .tbl td .inner{
        width:100%;
        min-height:auto;
    }
    #recommend .tbl td .photo,
    #recommend_buy .tbl td .photo {
        position: relative;
        width:100%;
        height:250px;
        margin-bottom:5%;
        /*height:230px;*/
        overflow:hidden;
        text-align:center;
    }
    #recommend .tbl td .photo img,
    #recommend_buy .tbl td .photo img{
        max-width:100%;
        width:auto;
        height:auto;
        transform: scale(1);
        transition:0s !important;
    }
    #recommend .tbl td .photo img:hover,
    #recommend_buy .tbl td .photo img:hover{
        transform: scale(1) !important;
    }
    #recommend .tbl td .txt,
    #recommend_buy .tbl td .txt{
        margin:10px 0 0 0;
    }
    #recommend .tbl td .txt .add,
    #recommend_buy .tbl td .txt .add{
        margin-top: 0.5em;
        line-height:130%;
        clear:both;
    }

    #recommend .tbl td .txt .add span{
        font-size: 0.85rem;
        margin-bottom: 0.2em;
    }
    #recommend .tbl td .txt .madori,
    #recommend_buy .tbl td .txt .madori{
        margin-top:0.8em;
        font-size: 1.2em;
        line-height:1;
        font-weight: normal;
        display:inline-block;
        color:#333;
    }
    #recommend .tbl td .txt .price,
    #recommend_buy .tbl td .txt .price{
        margin-top:0.8em;
        line-height:1;
        font-size: 0.9rem;
        font-weight:bold;
        display:inline-block;
    }
    #recommend .tbl td .txt .price strong,
    #recommend_buy .tbl td .txt .price strong{
        font-size: 1.5rem;
        font-weight: normal;
        vertical-align: baseline;
        color: #DD2A50;
        line-height: 100%;
    }

    #recommend .tbl td .name,
    #recommend_buy .tbl td .name{
        padding:0;
        font-size:1.2rem;
        margin-top:4%;
    }

    #recommend .tbl td .name a:hover,
    #recommend_buy .tbl td .name a:hover {
        opacity: 0.5;
    }

    #recommend .tbl td .copy,
    #recommend_buy .tbl td .copy{
        line-height:130%;
        margin-top: 0.2em;
        font-size: 0.80rem;
    }

    /*---------- News ------------------------------*/
    .bx-news {
        max-width:100%;
        margin:0 auto;
        padding:2% 2% 2% 4%;
        border:1px solid #ccc;
    }
    .bx-news dl {
        overflow-x: hidden;
        height:350px;
    }
    .bx-news dl div {
        padding:5% 0;
        display:block;
    }
    .bx-news dl div:last-child {}
    .bx-news dl div dt {
        color:#ff5459;
        width:100%;
        margin-bottom:4%;
    }
    .bx-news dl div dd {
        width:100%;
    }
    .ct {
        display: inline-block;
        border:1px solid #ff5459;
        width:90px;
        line-height:23px;
        color:#ff5459;
        text-align: center;
        font-size:12px;
        border-radius:3px;
        margin:0 0 0 20px;
    }

    /*---------- work ------------------------------*/
    #work p {
        font-size:16px;
        margin-bottom:10%;
    }
    .li-content {
        display:block;
        margin-bottom:8%;
    }
    .li-content div {
        width:100%;
        padding:4% 4% 150px 4%;
        margin-bottom:15%;
    }
    .li-content div dt {
        font-size: 28px;
        margin-bottom:5%;
    }
    .li-content div dd {
        font-size: 16px;
        line-height:40px;
        margin-bottom:10px;
        background:#fff;
        width:80%;
        display: inline-block;
    }
    .li-content div:after {}
    .cont-01:after {
        bottom:-30px;
        margin-left:-110px;
        background:url("../img/parts/content01.png") 0 0 no-repeat;
        background-size:100% auto;
        width:220px;
        height:160px;
    }
    .cont-02:after {
        bottom:-56px;
        margin-left:-88px;
        background:url("../img/parts/content02.png") 0 0 no-repeat;
        width:175px;
        height:196px;
    }
    .cont-03:after {
        bottom:-44px;
        margin-left:-96px;
        background:url("../img/parts/content03.png") 0 0 no-repeat;
        width:192px;
        height:171px;
    }

    /*---------- company ------------------------------*/
    .company-info {
        display:block;
        margin-bottom:4% !important;
    }
    #company dl {
        margin-bottom:8%;
    }
    #company dl div br {
        display: block;
    }
    #company dl div {
        display: -webkit-flex;
        display: flex;
        font-size:16px;
    }
    #company dl div dt {
        width:30%;
        padding:1%;
    }
    #company dl div dd {
        width:70%;
        margin-left:4%;
        padding:1% 1% 1% 4%;
    }
    #company dl div dt,
    #company dl div dd {}
    #company p {
        font-size:16px;
        margin-bottom:15%;
    }
    #company iframe {
        width:100%;
        height:450px;
    }

    /*----------------------------------------------------------------------
        common
     ---------------------------------------------------------------------*/

    article {
        position: relative;
        overflow: hidden;
        max-width:1200px;
        margin:0 auto;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }
    section {
        position: relative;
        padding:70px 0;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }
    .bx {
        position: relative;
        max-width:1080px;
        margin:0 auto;
    }

    /*----------------------------------------------------------------------
        assessment
     ---------------------------------------------------------------------*/

    #assessment h1 {
        padding-top:60px;
        margin-bottom:10%;
        font-size:26px;
        letter-spacing:3px;
    }
    .ttl-assessment {
        background: url("../img/parts/ttl-assessment.png") 50% 0 no-repeat;
        background-size:70px auto;
    }
    .txt-assessment {
        margin:0 auto 15% auto;
        font-size:16px;
        line-height:200%;
        max-width:90%;
        text-align: left;
    }
    .bx-form {
        max-width:90% !important;
        margin:0 auto 20px auto;
    }
    .bx-form p {
        width:100%;
        margin:0 auto 10% auto;

    }
    .bx-form img {
        display: block;
        margin:0 auto 10% auto;
        width:100%;
        height: auto;
    }
    /*---------- form ------------------------------*/
    table.default {
        width: 100% !important;
        margin-bottom:4%;
    }
    table.default th {
        display: block;
        width: 100%;
        line-height: 150%;
        padding:3% 2%;
        font-weight: 700;
        border-right:0;
        border-bottom:0;
        text-align: left;
    }
    table.default td {
        display: block;
        border-bottom:2px dotted #ccc;
        line-height: 100%;
        padding:3% 0;
        font-size: 14px;
        width: 100%;
        margin-bottom:3%;
    }
    table.default td input[type="text"],
    table.default td input[type="email"],
    table.default td input[type="tel"],
    table.default td textarea {}
    table.default td select {
        border-radius: 5px;
        background:#e5e5e5;
        padding: 2%;
        margin:0;
        width:60%;
        font-size:16px;
    }
    table.default td input[type="text"],
    table.default td input[type="email"],
    table.default td input[type="tel"] {
        padding: 2%;
        width:100%;
        font-size:16px;
        height:45px;
        line-height: 45px;
    }
    table.default td textarea {
        line-height: 150%;
        padding: 2%;
        width:100%;
    }
    table.default div.contact input {
        width:100% !important;
    }
    table.default div.tel input {
        width:25% !important;
    }
    #submit {
        width:90%;
    }
    #submit:after {

    }
    #submit::-webkit-search-decoration,
    #button::-webkit-search-decoration {
      display: none;
    }
    #submit::focus {
      outline-offset: -2px;
    }
    #submit:hover{
        cursor: pointer;
    }
    #complete {
        padding: 20px;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
        min-height: 300px;
        text-align: center;
    }
    #complete p strong {
        margin-bottom:20px;
        display: block;
    }
    .h {
        padding-left:80px !important;
    }
    .h:before {
        top:5px;
        left:0;
    }
    .error {
        margin:4% 0 0 0;
    }
    .bx-error {
        border:1px solid #ff0000;
        line-height:150%;
        padding:2%;
        text-align:center;
        color:#ff0000;
        margin:0 auto 8% auto;
        font-size:14px !important;
        background:rgba(255,0,4,0.05);
    }
    .bx-error br {
        display:block !important;
    }

    /*---------- attention ----------*/
    .attention {
        position: relative;
        display: block;
        margin-bottom:4%;
        font-size:14px;
        color:#d20f14;
        width:auto !important;
        padding-left:20px;
    }
    .attention:before {
        position: absolute;
        content:'※';
        top:0;
        left:0;
    }

    /*---------- radio, checkbox ----------*/
    table.default td label {
        line-height: 35px !important;
        margin-right:20px;
    }
    table.default td label:hover {
        cursor: pointer;
    }
    table.default td input[type="radio"],
    table.default td input[type="checkbox"] {
        position: relative;
        right: 0;
        bottom: 0;
        left: 0;
        top:-10px !important;
        height: 20px;
        width: 20px;
        vertical-align: -100%;
        transition:all .15s ease-out 0s;
        cursor: pointer;
        display: inline-block;
        margin: 0 10px 0 0;
        outline: none;
        border-radius: 10%;
        opacity:1 !important;
        -webkit-appearance: none;
                appearance: none;
    }
    table.default td input[type="radio"] {
        border-radius: 50%;
    }
    table.default td input[type="radio"]:checked:before,
    table.default td input[type="checkbox"]:checked:before {
        transform: scale(0.5);
    }
    table.default td input[type="radio"]:before {
        content: '';
        margin:-2px 0 0 -2px;
        width: 20px;
        height: 20px;
        display: block;
        border-radius: 50%;
        transform: scale(0);
        -webkit-transition: 0.2s;
                transition: 0.2s;
    }
    table.default td input[type="checkbox"]:before {
        content: '';
        margin:-2px 0 0 -2px;
        width: 20px;
        height: 20px;
        display: block;
        transform: scale(0);
        -webkit-transition: 0.2s;
                transition: 0.2s;
    }
    table.default td input[type="radio"],
    table.default td input[type="checkbox"] {
        border: 2px solid #999;
        background:#fff;
    }
    table.default td input[type="radio"]:checked:before,
    table.default td input[type="checkbox"]:checked:before {
        background: #333;
    }
    table.default td input[type="checkbox"] {
        position: relative;
        width:20px;
        height:20px;
        top:5px;
        -webkit-transform:scale(1.1);
                transform:scale(1.1);
    }

    /*---------- flex ----------*/
    table.default dl div {
        margin-bottom:15px;
        display: -webkit-flex;
        display: flex;
        -webkit-align-items: center;
                align-items: center;
    }
    table.default dl div:last-child {
        margin-bottom:0;
    }
    table.default dl div dt {
        width:30%;
    }
    table.default dl div dd {
        width:70%;
    }

    /*---------- input width ----------*/
    input.w20 {
        width:40% !important;
        margin-right:20px !important;
    }

    /*---------- label vertical ----------*/
    .int_blk label {
        display: block;
    }
    table.default td label {
        display: block;
    }

    /*------------------------------ privacy policy ----------*/
    #privacy {
        width:90%;
        margin:0 auto 5% auto;
    }
    .bx-agree {
        padding:4%;
        width:100%;
    }
    #privacy h2 {
        font-size:16px;
        font-weight:700;
        margin-bottom:2%;
    }
    #privacy p {
        font-size:14px;
        margin-bottom:4%;
    }
    #privacy ul,
    #privacy ol {
        margin-bottom:4%;
    }
    #privacy ul li {
        font-size:14px;
        list-style:disc;
        margin-left:25px;
    }
    #privacy ol li {
        font-size:14px;
    }
    .txt_privacy {
        max-width:90%;
        margin:0 auto;
    }
    .ttl-privacy {
        margin-bottom:10%;
        font-size:20px;
        letter-spacing:3px;
    }

    /*---------- send box -----------------------------*/
    .bx-send {
        margin:10% auto 0 auto;
        width:100%;
    }
    .inline {
        display: inline-block !important;
    }
    .mrg20 {
        margin-bottom:4% !important;
    }
}