﻿/*----------------------------------------------------------------------
	common
 ---------------------------------------------------------------------*/
body {
    font-family:'Lucida Grande',
				'メイリオ',
				Meiryo,
				'Hiragino Kaku Gothic ProN',
				'ヒラギノ角ゴ ProN W3',
				sans-serif;
	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;
}

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

/*----------------------------------------------------------------------
	header
 ---------------------------------------------------------------------*/
header {
    position: fixed;
    top:0;
    left:0;
    background:rgba(255,255,255,0.99);
    width:100%;
    margin-bottom:30px;
    z-index:10;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}
header h1 {
    margin:40px 0 0 60px;
}

/*------------------------------ Grobal Nav ----------*/
nav#gnav {
    display: block;
}
nav#gnav ul {
	display: -webkit-flex;
    display: flex;
	-webkit-justify-content: space-between;
			justify-content: space-between;
}
nav#gnav ul li {
	position:relative;
	font-size: 18px;
	line-height:100%;
    letter-spacing:2px;
}
nav#gnav ul li a {
	position:relative;
	display: block;
	text-align: center;
    margin-top:60px;
    padding:0 25px;
    font-size:18px;
	line-height:130%;
    -webkit-box-sizing:border-box;
			box-sizing:border-box;
}
nav#gnav ul li a:before {
    position: absolute;
    content:'';
    top:0;
    left:0;
    height:100%;
    border-left:1px solid #000;  
}
nav#gnav ul li:first-child a:before,
nav#gnav ul li:last-child a:before {
    display: none !important;
}
.mail {
    margin-left:60px;
}
.mail a {
    display:block;
    font-size:18px;
    margin-top:0 !important;
    padding:60px 25px 20px 70px !important;
    background:url("../img/parts/ic_mail.png") 15px 57px no-repeat #0080cb;
    color:#fff;
    -webkit-box-sizing:border-box;
			box-sizing:border-box; 
}
.mail a:hover {
    background:url("../img/parts/ic_mail.png") 15px 57px no-repeat rgba(0,128,203,0.70);
}

/*----------------------------------------------------------------------
	Footer
 ---------------------------------------------------------------------*/
footer {
    position: relative;
}
.bx-footer {
    padding:35px 10px 50px 10px;
    background:#e5f2fa;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.bx-footer p {
    margin:0 auto 10px auto;
    width:920px;
}
.bx-footer .fx {
    width:920px;
    margin:0 auto;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
            align-items: center;
    -webkit-justify-content: space-between !important;
            justify-content: space-between !important;
}
.bx-footer .fx p {
    marginn:0 !important;
    width:auto !important;
}
.bx-footer .fx .logo-f {
    max-width:315px;
    width:100%;
    height:auto;
}
.bx-footer .fx address {
    display: inline-block;
    font-style: normal;
    margin:0 35px;
}
.bx-footer .fx address span {
    display: inline-block;
    margin-right:25px;
}

.bx-footer .fx .mail-f {}
.bx-footer .fx .mail-f a {
    display:block;
    font-size:16px;
    padding:10px 20px 10px 60px !important;
    background:url("../img/parts/ic_mail.png") 15px 50% no-repeat #0080cb;
    background-size:25px auto;
    color:#fff;
    -webkit-box-sizing:border-box;
			box-sizing:border-box; 
}
.bx-footer .fx .mail-f a:hover {
    background:url("../img/parts/ic_mail.png") 15px 50% no-repeat rgba(0,128,203,0.70);
    background-size:25px auto;
}
small {
    position: relative;
    display: block;
    text-align: center;
    font-size:12px;
    margin-bottom:15px;
}
small br {
    display: none;
}

/*---------- link ----------*/
/*------------------------------ Grobal Nav ----------*/
nav#fnav {
    margin:25px 0 50px 0;
}
nav#fnav ul {
	display: -webkit-flex;
    display: flex;
	-webkit-justify-content: center;
			justify-content: center;
}
nav#fnav ul li {
	position:relative;
	line-height:130%;
    letter-spacing:1px;
}
nav#fnav ul li a {
	position:relative;
	display: block;
	text-align: center;
    padding:0 20px;
    font-size: 16px;
	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 #000;  
}
nav#fnav ul li:first-child a:before,
nav#fnav ul li:first-child div:before {
    display: none !important;
}

.li_bnr {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
            justify-content: center;
    border-top:1px dotted #666;
    padding:25px 10px 40px 10px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.li_bnr li {
    margin:0 10px;
}

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

/*----------------------------------------------------------------------
	top page
 ---------------------------------------------------------------------*/
/*---------- slider ------------------------------*/
#slider {
    position: relative;
    width: 100%;
    height: 100%;
}
.swiper-slide {
    text-align: center;
    font-size: 18px;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}
.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.swiper-pagination {
    margin:0 auto;
    bottom:15px !important;
}
.swiper-pagination-bullet {
  width: 23px;
  height: 3px !important;
}

/*---------- section ------------------------------*/
section {
    position: relative;
    padding:60px 10px;
    border-bottom:1px dotted #666;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.bx {
    max-width:1200px;
    margin:0 auto;
}
.bx h1 {
    position:relative;
    border-left:8px solid #0080cb;
    padding:20px 0 20px 30px;
    margin-bottom:30px;
    font-size:30px;
    line-height: 150%;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.bx h1 span {
    display:inline-block;
    margin-left:40px;
    color:#80bfe5;
    font-size:26px;
    letter-spacing: 4px;
}
.bx h1:after {
    position: absolute;
    content:'';
    left:-8px;
    bottom:0;
    border-left:8px solid #80bfe5;
    height:40%;
}

/*---------- users ------------------------------*/
.li_customer {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}
.li_customer div {
    position: relative;
    width:32%;
    padding-top:185px;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.li_customer div dt {
    position: relative;
    font-size:18px;
    font-weight:700;
    color:#fff;
    padding:10px 20px;
    letter-spacing:2px;
    display: inline-block;
    background:#0080cb;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.li_customer div dd {
    position: relative;
    font-size:14px;
    font-weight:700;
    margin:20px 20px 10px 20px;
}
.u01 {
    background:url("../img/content/img-custmer01.jpg") 50% 50% no-repeat;
    background-size: cover;
}
.u02 {
    background:url("../img/content/img-custmer02.jpg") 50% 50% no-repeat;
    background-size: cover;
}
.u03 {
    background:url("../img/content/img-custmer03.jpg") 50% 50% no-repeat;
    background-size: cover;
}
.li_customer div:before {
    position: absolute;
    content:'';
    left:0;
    bottom:0;
    width:100%;
    height:100%;
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.85) 75%);
}

/*---------- service ------------------------------*/
#service p {
    font-size:20px;
    margin-bottom:60px;
}
.li_service {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}
.li_service div {
    position: relative;
    width:32%;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.li_service div img {
    display: block;
    width:100%;
    height:auto;
    margin-bottom:15px;
}
.li_service div dt {
    position: relative;
    font-size:20px;
    font-weight:700;
    color:#0080cb;
    margin-bottom:10px;
}
.li_service div dd {
    position: relative;
    font-size:16px;
}

/*---------- news ------------------------------*/
#news {
    border:0 !important;
}
.bx-news {
    max-width:1200px;
    margin:0 auto;
    padding:20px 20px 20px 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}
.bx-news dl {
    overflow-x: hidden;
    height:240px;
}
.bx-news dl div {
    padding:18px 24px;
    border-bottom:1px dotted #666;
    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:last-child {
    border-bottom:none;
    margin-bottom:0;
}
.bx-news dl div dt {
    color:#0080cb;
    width:240px;
}
.bx-news dl div dd {
    width:850px;
}
.bx-news dl div dd a {
    text-decoration: underline;
}
.ct {
    display: inline-block;
    width:100px;
    line-height:25px;
    color:#fff;
    background:#0080cb;
    text-align: center;
    font-size:12px;
    margin:0 25px 0 0;
}
#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;
}

/*お知らせ モーダル*/
#news_modal {
    border:0 !important;
    padding:0 !important;
}
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;
    /*
    background: #f4f4f4;
    background: #DDFFDD;
    */
    /* color: white; */
    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:#0080cb !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%;
    }
}

/*----------------------------------------------------------------------
	2nd page
 ---------------------------------------------------------------------*/

article {
    margin-top:150px;
}
.ttl {
    max-width:1200px;
    margin:80px auto 0 auto;
}
.ttl h1 {
    position:relative;
    border-left:8px solid #0080cb;
    padding:20px 0 20px 30px;

    font-size:30px;
    line-height: 150%;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.ttl h1 span {
    display:inline-block;
    margin-left:40px;
    color:#80bfe5;
    font-size:26px;
    letter-spacing: 4px;
}
.ttl h1:after {
    position: absolute;
    content:'';
    left:-8px;
    bottom:0;
    border-left:8px solid #80bfe5;
    height:40%;
}

.ttl_m {
    background:#0080cb;
    padding:20px;
    line-height:100%;
    color:#fff;
    font-size:26px;
    margin:0 0 40px 0;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}

/*----------------------------------------------------------------------
	comapany page
 ---------------------------------------------------------------------*/

/*---------- message ------------------------------*/

.txt-message {
    padding:0 20px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}
.txt-message p:first-child {
    width:550px;
    font-size:20px;
}
.txt-message p:last-child {
    padding-left:50px;
}

/*---------- profile ------------------------------*/
#profile .fx {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}

/*---------- profile list ----------*/
.li_profile {
    border-top:1px solid #cacaca;
    width:48%;
}
.li_profile div {
    display: -webkit-flex;
    display: flex;
    border-bottom:1px solid #cacaca;
}
.li_profile div dt,
.li_profile div dd {
    padding:10px 10px 10px 50px;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.li_profile div dt {
    width:30%;
    font-weight:700;
    background:#f0f0f0;
}
.li_profile div dd {
    width:70%;
}
.li_profile div dd span {
    display: inline-block;
    margin-right:25px;
}

.accessmap {
    width:48%;
}
.accessmap .ttl-access {
    display:inline-block;
    color:#80bfe5;
    font-size:30px;
    letter-spacing: 4px;
}
.accessmap p {
    margin-bottom:10px;
    font-size:20px;
}
.accessmap iframe {
    width:100%;
    height:500px;
}

/*----------------------------------------------------------------------
	inquiry page
 ---------------------------------------------------------------------*/

/*---------- tel ------------------------------*/
#tel {
    font-size:20px;
}
#tel .fx-tel {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
            align-items: center;
}
#tel .telephone {
    font-size:26px;
    font-weight:700;
}
#tel .telephone a {
    color:#0080cb !important;
}
#tel .telephone strong {
    font-size:40px;
    margin-left:20px;
}
#tel .fx-tel span {
    display: block;
    font-size:16px;
    margin-left:45px;
}
#tel .fx-tel span br {
        display: none;
    }

/*---------- form ------------------------------*/
.bx-form {
    position: relative;
    max-width:1200px;
    margin:0 auto 20px auto;
}
.bx-form p {
    font-size: 18px;
    margin-bottom:40px;
}
.bx-form img {
    display: block;
    margin:0 auto 40px auto;
}

/*---------- form ------------------------------*/
table.default {
	width: 100%;
	margin-bottom:50px;
    background:#efefef;
}
table.default th {
    position: relative;
	width: 350px;
    line-height: 100%;
    padding:37px 40px 20px 40px;
	font-size: 18px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default th span {
	font-size: 12px;
    margin-left:15px;
    color:#0080cb;
}
table.default td {
	line-height: 100%;
    padding:20px 40px 20px 20px;
	font-size: 16px;
	vertical-align: middle;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}

table.default tr.notice th,
table.default tr.notice td {
    display: block;
    width:100%;

}
table.default tr.notice td {
    padding:0 40px 30px 40px;
}
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: 10px;
    background:#e5e5e5;
    border:1px solid #ccc;
    padding: 10px;
	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;
	padding: 10px;
	margin:0;
	width:100%;
	font-size:16px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
table.default td textarea {
	border:1px solid #ccc;
	line-height: 150%;
	padding: 10px;
	width:98%;
    margin:0 0 0 2%;
	-webkit-appearance: none;
			border-radius: 0;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
}
#submit {
	position:relative;
	claer:both;
	overflow: hidden;
	display: block;
	background:#0080cb;
	margin: 0 auto;
	line-height: 65px;
	width:400px;
    font-size:18px;
    font-weight:700;
	color:#fff;
	-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:#0080cb;
}
.h:before {
	position: absolute;
	content:'必須';
	top:27px;
	right:100px;
	margin:0;
	color:#fff;
	width:55px;
	font-size:12px;
    line-height: 30px;
	background:#0080cb;
	text-align: center;
}
.error {
	display: block;
	margin:15px 0 0 0;
    font-weight:700;
	color:#d20f14;
}
.bx-error {
	border:1px solid #ff0000;
	line-height:45px;
	text-align:center;
	color:#ff0000;
	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;
}

/*---------- radio, checkbox ----------*/
table.default td label {
    line-height: 45px !important;
    margin-right:40px;
}
table.default td label:hover {
	cursor: pointer;
}
table.default td.consul label,
div#agree input[type="checkbox"] {
    line-height: 45px !important;
    margin-right:30px;
    display: inline-block;
}
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:140px;
}
table.default dl div dd {
    width:450px;
}

/*------------------------------ privacy policy ----------*/
.bx-privacy {
    position: relative;
    background:#fff;
    border-radius:10px;
    border:2px solid #efefef;
    padding:40px 20px;
    max-width:1200px;
    margin:80px auto;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}
.bx-privacy h2 {
    position: relative;
    text-align: center;
    font-size:18px;
    font-weight:700;
    margin:40px 0;
}
.bx-privacy h3 {
    font-size:14px;
    font-weight:700;
}
.bx-privacy p {
    font-size:14px;
    margin-bottom:20px;
}
.bx-privacy ul {
    margin-bottom:20px;
}
.bx-privacy ul li {
    font-size:14px;
    list-style:disc;
    margin-left:20px;
}
.bx-privacy div {
    position: relative;
    height: 350px;
    overflow-x:hidden;
    padding:0 40px;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
}

/*------------------------------ agree ----------*/
#agree {
    display: block;
    text-align: center;
    width:400px;
    margin: 0 auto;
    font-size:18px;
}
#agree input[type="checkbox"],
#agree input[type="radio"] {
    border:1px solid #ccc;
    margin-right:10px;
    -webkit-transform: scale(2.5, 2.5);
            transform: scale(2.5, 2.5);
}
/*---------- send box -----------------------------*/
.bx-send {
    position: relative;
    margin:40px auto 0 auto;
    width:400px;
}
.confirm table.default th {
    padding:30px 40px 30px 40px !important;
    line-height:150%;
}
.confirm table.default td {
    padding-top:22px !important;
    line-height:150%;
}

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

@media only screen and (max-width:800px) {
    body {
        min-width:100%;
    }
    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;
    }
    img {}
    a img {}

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

    /*----------------------------------------------------------------------
        header
     ---------------------------------------------------------------------*/
    header {
        position: fixed;
        top:0;
        left:0;
        height:50px;
        display:block;
        width:100%;
        margin-bottom:0;
        padding:13px 10px 0 10px;
        background:rgba(255,255,255,0.98);
        z-index:10;
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }
    header h1 {
        margin:0;
        width:70%;
    }
    header h1 img {
        width:100%;
        height:auto;
    }

    /*------------------------------ global Nav, Menu ----------*/
	#panel-btn {
		display: inline-block;
		position: fixed;
		top:0;
		right:10px;
		width:50px;
		max-width:50px;
		min-width:50px;
		height:50px;
		margin-top:0;
		z-index:7000;
	}
	#panel-btn:after {
		position: absolute;
		content:'menu';
		top:30px;
		right:3px;
		font-size:10px;
		font-weight:700;
		color:#0080cb;
	}
	#panel-btn-icon {
		display: block;
		position: absolute;
		top: 35%;
		right: 5px;
		width: 20px;
		height: 2px;
		background: #0080cb;
		border-radius:50px;
		-webkit-transition: 0.2s;
				transition: 0.2s;
	}
	#panel-btn-icon:before,
	#panel-btn-icon:after {
		position: absolute;
		content: '';
		top: 50%;
		right: 0;
		display: block;
		height: 2px;
		background: #0080cb;
		-webkit-transition: 0.3s;
				transition: 0.3s;
	}
	#panel-btn-icon:before {
		margin-top: -8px;
		width: 30px;
	}
	#panel-btn-icon:after {
		margin-top: 6px;
		width: 10px;
	}
	#panel-btn .close {
		background: transparent;
	}
	#panel-btn .close:before,
	#panel-btn .close:after {
		margin-top: 0;
		background: #0080cb;
	}
	#panel-btn .close:before{
      -webkit-transform: rotate(-45deg);
			  transform: rotate(-45deg);
	}
	#panel-btn .close:after{
	  width:30px;
	  -webkit-transform: rotate(-135deg);
			  transform: rotate(-135deg);
	}
	.dr_on {
		top:50px !important;
		left:0 !important;
		visibility:visible !important;
		opacity:1 !important;
		z-index:9999 !important;
		-webkit-transition: .7s;
				transition: .7s;
	}
	.dr_off {
		top:50px;
		left:-100%;
		visibility:hidden;
		opacity:0;
		-webkit-transition: .7s;
				transition: .7s;
	}
	.over_hide {
    	overflow: hidden !important;
	}

    /*------------------------------ Grobal Nav ----------*/
    nav#gnav {
        position: fixed;
        padding:0;
		background:#fff;
		top:50px;
		left:-100%;
		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 {
        position:relative;
        font-size: 16px;
        line-height:100%;
        letter-spacing:2px;
        border-bottom:1px dotted #ccc;
    }
    nav#gnav ul li a {
        position:relative;
        display: block;
        text-align: left;
        margin-top:0;
        padding:7% 2%;
        font-size:16px;
        line-height:100%;
    }
    nav#gnav ul li a:before {
        display: none; 
    }
    nav#gnav ul li:last-child {
        border-bottom:none;
    }
    nav#gnav ul li:first-child a:before,
    nav#gnav ul li:last-child a:before {}
    nav#gnav ul li a:after {
        position: absolute;
        content:'';
        top:50%;
        right:10px;
        height:10px;
        width:10px;
        margin-top:-5px;
        border-top:1px solid #333;
        border-right:1px solid #333;
        -webkit-transform: rotate(45deg);
                transform: rotate(45deg);
    }
    .mail {
        margin:20% auto 0 auto;
        width:90%;
    }
    .mail a {
        font-size:16px;
        margin-top:0 !important;
        padding:0 !important;
        border-radius: 60px;
        line-height:60px !important;
        background:url("../img/parts/ic_mail.png") 25px 50% no-repeat #0080cb;
        background-size:25px auto;
        text-align: center !important;
        -webkit-box-shadow: 0 5px 0 rgba(0,0,0,0.05);
                box-shadow: 0 5px 0 rgba(0,0,0,0.05);
    }
    .mail a:hover {
        background:url("../img/parts/ic_mail.png") 25px 50% no-repeat #0080cb;
        background-size:25px auto;
    }
    nav#gnav ul li.mail a:after {
        display: none;
    }

    /*----------------------------------------------------------------------
        Footer
     ---------------------------------------------------------------------*/
    footer {}
    .bx-footer {
        padding:15% 1% 10% 1%;
        text-align: center;
        margin-bottom:5%;
    }
    .bx-footer p {
        margin:0 auto 1% auto;
        width:80%;
    }
    .bx-footer .fx {
        width:80%;
        margin:0 auto;
        display:block;
    }
    .bx-footer .fx p {
        marginn:0 !important;
        width:auto !important;
    }
    .bx-footer .fx .logo-f {
        max-width:70%;
        width:70%;
        height:auto;
        margin-bottom:10%;
    }
    .bx-footer .fx address {
        margin:0 0 10% 0;
    }
    .bx-footer .fx address span {
        display: block;
        margin:0;
    }

    .bx-footer .fx .mail-f {
        display: none;
    }
    .bx-footer .fx .mail-f a {}
    .bx-footer .fx .mail-f a:hover {}
    small {
        margin-bottom:4%;
    }

    /*---------- link ----------*/
    /*------------------------------ Grobal Nav ----------*/
    nav#fnav {
        display: none;
    }
    nav#fnav ul {}
    nav#fnav ul li {}
    nav#fnav ul li a {}
    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 {}

    .li_bnr {
        display: block;
        padding:6% 0 100px 0;
    }
    .li_bnr li {
        width:50%;
        margin:0 auto 4% auto;
    }
    .li_bnr li img {
        width:100%;
        height:auto;
    }
    .li_bnr li:last-child {
        margin-bottom:0;
    }
    
    /*------------------------------ フッター固定ボタン ----------*/
    #fBtn {
		position: fixed;
		left:0;
		bottom:0;
		z-index: 10;
        width:100% !important;
        background:#0080cb;
        display: -webkit-flex;
    	display: flex;
        -webkit-align-items: center;
		        align-items: center;
	}
    #fBtn p {
        position: relative;
        width:50%;
        padding:6% 3%;
        color:#fff;
        font-weight:700;
		background:#80bfe5;
    }
    #fBtn p:after {
        position: absolute;
        content:'';
        top:50%;
        right:25px;
        border-top:2px solid #fff;
        border-right:2px solid #fff;
        height:8px;
        width:8px;
        margin-top:-4px;
        -webkit-transform: rotate(45deg);
                transform: rotate(45deg);
    }
	#fBtn ul {
		display: -webkit-flex;
    	display: flex;
        width:50%;
	}
	#fBtn ul li {
        vertical-align: middle;
		width: 50%;
        line-height: 100%;
		font-weight: 700;
        -webkit-box-sizing: border-box;
				box-sizing: border-box;
		text-align: center;
		color:#fff;
        border-right:1px solid rgba(255,255,255,0.10);
	}
    #fBtn ul li a {
        display: block;
        padding:8% 2%;
    }
    #fBtn ul li:first-child {
        width:50%;
    }
	#fBtn ul li:last-child { border-right:none; }
	#fBtn ul li span {
		font-size: 14px;
		margin-left:10%;
	}
	#fBtn ul li a {
		color:#fff;
        width:100%;
        line-height: 100%;
	}

    /*----------------------------------------------------------------------
        top page
     ---------------------------------------------------------------------*/
    /*---------- slider ------------------------------*/
    #slider {
        margin:50px 0 8% 0;
    }
    .swiper-slide {}
    .swiper-slide img {}
    .swiper-pagination {}
    .swiper-pagination-bullet {}

    /*---------- section ------------------------------*/
    section {
        position: relative;
        padding:10% 0;
        border-bottom:none;
    }
    section:nth-child(2n-1) {
        background:#f9f9f9;
    }
    .bx {
        max-width:94%;
        margin:0 auto;
    }
    .bx h1 {
        border-left:none;
        padding:8% 0;
        margin-bottom:0;
        font-size:24px;
        line-height:150%;
        text-align: center;
    }
    .bx h1 br {
        display: none;
    }
    .bx h1 span {
        text-align: center;
        display:block;
        margin-left:0;
        font-size:14px;
        letter-spacing: 4px;
    }
    .bx h1:before {
        position: absolute;
        content:'';
        left:50%;
        top:0;
        width:60px;
        margin-left:-30px;
        border-top:3px solid #0080cb;
        
    }
    .bx h1:after {
        position: absolute;
        content:'';
        left:50%;
        top:0;
        bottom:auto;
        border-left:none;
        border-top:3px solid #80bfe5;
        height:auto;
        width:30px;
    }
    
    #customer h1 {
        text-align: left !important;
    }

    /*---------- users ------------------------------*/
    .li_customer {
        display:block;
    }
    .li_customer div {
        width:100%;
        padding-top:50%;
        margin-bottom:12%;
    }
    .li_customer div dt {
        width:60%;
        font-size:18px;
        padding:2% 3%;
    }
    .li_customer div dd {
        font-size:16px;
        margin:0;
        padding:6% 4%;
    }
    .u01 {}
    .u02 {}
    .u03 {}
    .li_customer div:before {}

    /*---------- service ------------------------------*/
    #service p {
        font-size:16px;
        margin-bottom:15%;
    }
    #service p br {
        display: none;
    }
    .li_service {
        display:block;
    }
    .li_service div {
        position: relative;
        width:100%;
        margin-bottom:12%;
    }
    .li_service div img {
        margin-bottom:4%;
        border-radius:10px;
    }
    .li_service div dt {
        font-size:20px;
        margin-bottom:4%;
        text-align: center;
    }
    .li_service div dd {
        position: relative;
        font-size:16px;
    }

    /*---------- news ------------------------------*/
    #news {}
    .bx-news {
        max-width:100%;
        margin:0 auto;
        padding:4%;
        border:2px solid #ccc !important;
        border-radius:5px;
    }
    .bx-news dl {
        overflow-x: hidden;
        height:300px;
    }
    .bx-news dl div {
        padding:5% 2%;
        border-bottom:1px dotted #666;
    }
    .bx-news dl div:last-child {
        border-bottom:none;
        margin-bottom:0;
    }
    .bx-news dl div dt {
        color:#0080cb;
        width:240px;
    }
    .bx-news dl div dd {
        width:850px;
    }
    .bx-news dl div dd a {
        text-decoration: underline;
    }
    .ct {
        display: inline-block;
        width:100px;
        line-height:25px;
        color:#fff;
        background:#0080cb;
        text-align: center;
        font-size:12px;
        margin:0 25px 0 0;
    }
    #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;
    }

    /*----------------------------------------------------------------------
        2nd page
     ---------------------------------------------------------------------*/

    article {
        margin-top:10%;
    }
    .ttl h1 {
        border-left:none;
        padding:8% 0;
        margin:20% 0 0 0;
        font-size:24px;
        line-height:150%;
        text-align: center;
    }
    .ttl h1 br {
        display: none;
    }
    .ttl h1 span {
        text-align: center;
        display:block;
        margin-left:0;
        font-size:14px;
        letter-spacing: 4px;
    }
    .ttl h1:before {
        position: absolute;
        content:'';
        left:50%;
        top:0;
        width:60px;
        margin-left:-30px;
        border-top:3px solid #0080cb;
        
    }
    .ttl h1:after {
        position: absolute;
        content:'';
        left:50%;
        top:0;
        bottom:auto;
        border-left:none;
        border-top:3px solid #80bfe5;
        height:auto;
        width:30px;
    }
    .ttl_m {
        padding:4%;
        font-size:20px;
        margin:0 0 4% 0;
        -webkit-box-sizing:border-box;
                box-sizing:border-box;
    }

    /*----------------------------------------------------------------------
        comapany page
     ---------------------------------------------------------------------*/

    /*---------- message ------------------------------*/

    .txt-message {
        padding:4%;
        flex-direction:column-reverse;
    }
    .txt-message p:first-child {
        width:100%;
        font-size:18px;
        
        
        text-align: right;
    }
    .txt-message p:last-child {
        font-size:16px;
        line-height:180%;
        padding-left:0;
        margin-bottom:10%;
    }

    #message {
        border-bottom:1px dotted #666;
    }
    #profile {
        background:#fff !important;
    }

    /*---------- profile ------------------------------*/
    #profile .fx {
        display:block;
    }

    /*---------- profile list ----------*/
    .li_profile {
        width:100%;
        margin-bottom:10%;
    }
    .li_profile div {}
    .li_profile div dt,
    .li_profile div dd {
        padding:4%;
    }
    .li_profile div dt {
        text-align: center;
    }
    .li_profile div dd {
        background:#fff;
    }
    .li_profile div dd span {
        display:block;
        margin:0;
    }

    .accessmap {
        width:100%;
    }
    .accessmap .ttl-access {
        font-size:24px;
        letter-spacing: 2px;
    }
    .accessmap p {
        margin-bottom:2%;
        font-size:16px;
    }
    .accessmap iframe {
        width:100%;
        height:500px;
    }

    /*----------------------------------------------------------------------
        inquiry page
     ---------------------------------------------------------------------*/

    /*---------- tel ------------------------------*/
    #tel {
        font-size:16px;
        text-align: center;
    }
    #tel .fx-tel {
        display:block;
    }
    #tel .telephone {
        font-size:22px;
    }
    #tel .telephone strong {
        font-size:30px;
        margin-left:2%;
    }
    #tel .fx-tel span {
        display: block;
        font-size:16px;
        margin:4% 0 0 0;
    }
    #tel .fx-tel span br {
        display: block;
    }

    /*---------- form ------------------------------*/
    .bx-form {
        max-width:100% !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:4% 4% 0 6%;
        margin-bottom:4%;
        font-weight: 700;
        border-right:0;
        border-bottom:0;
        text-align: left;
    }
    table.default th span {
        font-size: 14px;
        margin:2% 0 0 0;
        display: block;
    }
    table.default td {
        display: block;
        line-height: 100%;
        padding:2% 4%;
        font-size: 14px;
        width: 100%;
        margin-bottom:3%;
    }
    table.default tr.notice th,
    table.default tr.notice td {}
    table.default tr.notice td {
        padding:3%;
    }
    table.default td input[type="text"],
    table.default td input[type="email"],
    table.default td input[type="tel"],
    table.default td textarea {
        margin:0;
        width:100%;
    }
    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%;
    }
    #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:100px !important;
    }
    .h:before {
        top:15px;
        left:20px;
    }
    .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;
    }

    /*---------- radio, checkbox ----------*/
    table.default td label {
        line-height: 40px !important;
        margin-right:20px;
        font-size: 16px;
    }
    table.default td label:hover {
        cursor: pointer;
    }
    table.default td.consul label {
        line-height: 45px !important;
        margin-right:0;
        display: block;
    }
    div#agree input[type="checkbox"] {
        margin-right:8%;
    }
    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 ----------*/
    .bx-privacy {
        border-radius:5px;
        padding:5% 3%;
        max-width:90%;
        margin:10% auto;
    }
    .bx-privacy h2 {
        position: relative;
        text-align: center;
        font-size:18px;
        font-weight:700;
        margin:10% 0;
    }
    .bx-privacy h3 {
        font-size:14px;
        font-weight:700;
    }
    .bx-privacy p {
        font-size:14px;
        margin-bottom:4%;
    }
    .bx-privacy ul {
        margin-bottom:4%;
    }
    .bx-privacy ul li {
        font-size:14px;
        list-style:disc;
        margin-left:20px;
    }
    .bx-privacy div {
        position: relative;
        height: 350px;
        overflow-x:hidden;
        padding:0 8%;
        -webkit-box-sizing:border-box;
                box-sizing:border-box;
    }

    /*------------------------------ agree ----------*/
    #agree {
        width:90%;
        font-size:16px;
    }
    #agree input[type="checkbox"],
    #agree input[type="radio"] {}
    /*---------- send box -----------------------------*/
    .bx-send {
        position: relative;
        margin:15% auto 0 auto;
        width:80%;
    }
    .confirm table.default th {
        padding:4% 4% 0 4% !important;
        line-height:150%;
    }
    .confirm table.default th.h {
        padding-left:100px !important;
    }
    .confirm table.default td {
        position: relative;
        padding:4% 4% 4% 6% !important;
        line-height:150%;
        font-size:18px;
    }
    .confirm table.default td:after {
        position: absolute;
        content:'';
        bottom:0;
        left:4%;
        width:92%;
        border-bottom:1px solid #ccc;
    }
}



































