@charset "utf-8";

/*========================================
base
========================================*/
* {
    -webkit-text-size-adjust: none;
}

a,
a:hover {
    text-decoration: none !important;
}

.sp {
    display: none;
}

.min {
    font-family: "游明朝 Light", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

h1 {
    text-align: left;
    margin-bottom: 10px;
    color: #155c98;
}

h2.title {
    width: 1000px;
    margin: 0 auto;
    padding: 100px 0 50px 0;
    border-bottom: 1px solid #135998;
    text-align: center;
    color: #135998;
    font-size: 48px;
    font-weight: normal;
    line-height: 1;
}

.h2Line {
    border-bottom: #155c98 1px solid;
}

#top h2.title {
    width: 1000px;
    margin: 0 auto;
    padding: 100px 0 10px 0;
    font-size: 48px;
    color: #000;
    font-weight: bold;
    text-align: left;
    border: none;
}

h3.title {
    width: 1000px;
    margin: 0 auto;
    color: #135998;
    font-size: 34px;
    padding: 50px 0 30px 0;
    text-align: center;
    font-weight: normal;
    line-height: 1.5;
}

h3.title span {
    font-size: 24px;
}

#top h3.title {
    color: #000;
    font-size: 34px;
    padding: 50px 0 10px 0;
    text-align: left;
    font-weight: bold;
    line-height: 1;
}

h4 {
    color: #155c98;
    font-size: 30px;
    margin: 0 0 30px 0;
    line-height: 1.5;
}

.bxslider {
    z-index: 10;
}

.bx-viewport img {
    margin: 0 auto;
}

.btnDetail {}

a.btnDetail {
    color: #fff;
    background: #447dad;
    padding: 8px 20px 8px 40px;
    position: relative;
}

.btnDetail:hover {
    background: #5e94c2;
}

a.btnDetail::before {
    content: "　";
    background: url(../img/common/arrow_white.png) no-repeat;
    background-size: 5px 7px;
    position: absolute;
    top: 50%;
    left: 20px;
    margin: -2px 0 0 0;
}

.btnDetailOrange {
    background: #fa8d00;
    border-radius: 40px;
    text-align: center;
    padding: 10px 0;
    font-size: 28px;
    position: relative;
    padding: 15px 100px;
}

a.btnDetailOrange:link,
a.btnDetailOrange:visited {
    color: #fff;
}

.btnDetailOrange:hover {
    background: #ffa93b;
    text-decoration: none;
}

.btnDetailOrange span.small {
    font-size: 1.2rem;
}

.btnDetailOrange::before {
    content: " ";
    background: url(../img/common/icon_bucket.png) no-repeat;
    background-size: 46px 46px;
    width: 46px;
    height: 46px;
    position: absolute;
    top: 50%;
    left: 10%;
    margin: -23px 0 0 0;
}

.btnDetailOrange::after {
    content: " ";
    background: url(../img/common/arrow.png) no-repeat;
    background-size: 30px 30px;
    width: 30px;
    height: 30px;
    position: absolute;
    top: 50%;
    right: 4%;
    margin: -15px 0 0 0;
}


/*========================================
header
========================================*/
header {
    position: relative;
}

#header {
    width: 1000px;
    position: absolute;
    top: 0;
    left: 50%;
    margin: 0 0 0 -500px;
    z-index: 100;
    padding: 10px 0 0 0;
}

#header02 {
    width: 1000px;
    margin: 0 auto;
    padding: 10px 0 20px 0;
    position: relative;
}

#header h1,
#header02 h1 {
    position: absolute;
    top: 24px;
    left: 0;
}

#header a {
    margin: 35px 0 0 0;
}

#header02 a {
    margin: 18px 0 0 0;
}

#header li,
#header02 li {
    list-style: none;
    padding: 5px 0;
    color: #165c98;
    text-align: right;
}

#header .text,
#header02 .text {
    letter-spacing: 0 !important;
    padding: 3px 3px 3px 0;
}

#header .btn01,
#header02 .btn01 {
    padding: 0 0 5px 0;
    font-size: 24px;
    color: #155c98;
    position: relative;
    display: block;
    margin: 0;
    font-family: "Kozuka Mincho Pro", "Kozuka Mincho Std", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    letter-spacing: 5px;
}

/*#header .btn01::before,
#header02 .btn01::before {
content: " ";
background: url(../img/common/icon_tel.png) no-repeat;
background-size: 26px 26px;
width: 26px;
height: 26px;
position: absolute;
top: 6px;
left: 5px;
}*/

#header .btn02 a,
#header02 .btn02 a {
    background: #fa8d00;
    border-radius: 40px;
    display: inline;
    padding: 5px 50px 5px 70px;
    font-size: 16px;
    vertical-align: middle;
    color: #fff;
    position: relative;
}

#header .btn02 a:hover,
#header02 .btn02 a:hover {
    text-decoration: none;
    opacity: 0.8;
}

#header .btn02 a::before,
#header02 .btn02 a::before {
    content: " ";
    background: url(../img/common/icon_mail.png) no-repeat;
    background-size: 23px 19px;
    width: 23px;
    height: 19px;
    position: absolute;
    top: 6px;
    left: 45px;
}

#header .btn02 a::after,
#header02 .btn02 a::after {
    content: " ";
    background: url(../img/common/arrow.png) no-repeat;
    background-size: 18px 18px;
    width: 18px;
    height: 18px;
    position: absolute;
    top: 6px;
    right: 10px;
}

#header .btn01 span,
#header02 .btn01 span {
    font-size: 16px;
}


/*========================================
gnav
========================================*/
#menu {
    background: #165c98;
    color: #fff;
    padding: 10px;
}

#menu div {
    width: 1000px;
    margin: 0 auto;
    display: table;
}

#menu li {
    float: left;
    text-align: center;
}

#menu a {
    color: #fff;
    padding: 10px 30px;
    font-size: 16px;
    vertical-align: middle;
    text-align: center;
    display: flex !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    align-items: center !important;
    -webkit-align-items: center !important;
}

#menu a:hover {
    text-decoration: none;
    background: #447cad;
    border-radius: 5px;
}

#menu .active {
    background: #447cad;
    border-radius: 5px;
}



/*========================================
top
========================================*/
.ct01 {
    background: url(../img/top/bg_awa.png) no-repeat;
    background-size: cover;
}

.ct01Inner,
.ct02Inner,
.ct03Inner,
.ct04Inner,
.ct05Inner,
.ct06Inner,
.ct07Inner,
.youtubeInner {
    width: 1000px;
    margin: 0 auto;
    text-align: left;
    font-size: 18px;
    line-height: 1.75;
}

.ct01Inner p,
.ct02Inner p,
.youtubeInner p {
    font-size: 18px;
    margin: 0 0 30px 0;
}

.ct01Inner ul {
    display: table;
}

.ct01Inner li {
    width: 33%;
    display: table-cell;
}

.ct01Inner li p {
    padding: 10px;
}

.ct02 {
    background: url(../img/top/bg_ozon.png) no-repeat top center;
    margin: 0 0 50px 0;
    height: 590px;
}

.ct02Inner {
    padding: 0 30px 0 240px;
}

.ct02Inner li {
    list-style: disc;
    list-style-position: inside;
    margin: 0 0 20px;
    line-height: 1.75;
    padding: 0 0 0 18px;
    text-indent: -18px;
}

.ct02 h3.green {
    color: #13b5b1 !important;
    margin: 0 0 30px 0;
    width: auto;
    font-size: 38px !important;
}

.ct02 .btnDetail,
.ct03 .btnDetail {
    float: right;
}

.ct03 {
    background: url(../img/top/bg_dryfoggr.png) no-repeat top center;
}

.ct03Inner {
    margin-bottom: 80px;
}

.ct03 h3.orange {
    color: #f19149 !important;
    margin: 0 0 30px 0;
    width: auto;
    font-size: 38px !important;
}

.ct03 h3.blue {
    color: #00a0e9 !important;
    margin: 0 0 30px 0;
    padding: 5px 0 10px 0 !important;
    width: auto;
    font-size: 38px !important;
}

.ct02 h3.green span,
.ct03 h3.orange span,
.ct03 h3.blue span {
    font-size: 32px !important;
}

.ct03Inner ul li:nth-child(1) span {
    color: #3e93c0;
}

.ct03Inner ul li:nth-child(1) span::before {
    background: #3e93c0;
}

.ct03Inner ul li:nth-child(2) span {
    color: #3770a1;
}

.ct03Inner ul li:nth-child(2) span::before {
    background: #3770a1;
}

.ct03Inner ul li:nth-child(3) span {
    color: #155c98;
}

.ct03Inner ul li:nth-child(3) span::before {
    background: #155c98;
}

.ct03Inner ul li span {
    float: left;
    font-size: 140px;
    position: relative;
    padding: 0 0 0 110px;
    line-height: 1;
}

.ct03Inner ul li span::before {
    content: "Point.";
    color: #fff;
    font-size: 24px;
    padding: 33px 12px;
    border-radius: 50px;
    position: absolute;
    top: 24px;
    left: 0;
}

.ct03Inner ul li p {
    float: right;
    width: 780px;
    padding: 20px 0 0 0;
}

.ct04Inner .right {
    width: 660px;
    margin-bottom: 80px;
}

.ct04Inner h4 {
    margin: 0 0 0 0;
}

.ct04Inner p {
    margin: 0 0 30px 0;
}

.ct05 {
    background: url(../img/top/bg_hotel.png) no-repeat;
    background-size: cover;
    padding: 70px 0 40px 0;
}

.ct05Title {
    margin: -30px 0 0 0;
    z-index: 2
}

.ct05Title::before {}

.ct05Inner span {
    color: #fa8d00;
}

.ct05 .box {
    float: left;
    width: 485px;
    min-height: 540px;
    border: #155c98 1px solid;
    background: #fff;
    margin-bottom: 30px;
}

.ct05 .box:nth-child(odd) {
    margin: 0 30px 0 0;
}

.ct05 .box dt {
    display: table;
}

.ct05 .box dt span:nth-child(1) {
    color: #fff;
    background: #447dad;
    font-size: 120px;
    padding: 5px 30px;
    display: table-cell;
    line-height: 1;
}

.ct05 .box dt span:nth-child(2) {
    color: #fff;
    background: #155c98;
    font-size: 30px;
    display: table-cell;
    line-height: 1.5;
    padding: 0 20px;
    vertical-align: middle;
}

.ct05 .box dd {
    padding: 15px;
}

.ct06 {
    height: 600px;
    background: url(../img/top/bg_mugai.png) no-repeat top center, linear-gradient(rgba(76, 168, 216, 1), rgba(148, 213, 232, 1));
    border-bottom: #447dad 20px solid;
    padding: 230px 0 0 0;
    color: #fff;
}

.ct06Inner {
    padding: 0 100px 0 50px;
    text-align: center;
}

.ct06Inner p {
    font-size: 20px;
    line-height: 2;
    margin: 0 0 30px 0;
}

.ct06Inner .btnDetailOrange {
    margin: 0 -50px 0 0;
}

.ct07 {
    padding: 60px 0;
}

.ct07 h3.woman {
    color: #155c98 !important;
    background: url(../img/top/ico_woman.png) no-repeat;
    padding: 9px 0 5px 40px !important;
    border-bottom: #155c98 1px solid;
    width: auto !important;
}

.ct07Inner .left {
    border: #155c98 1px solid;
    padding: 15px;
}

.ct07Inner .right {
    width: 630px;
}

.ct07Inner .right img {
    margin: 15px 0 0 0;
}

.ct07Inner p {
    padding: 15px 0;
}

.youtubeInner {
    padding: 30px 0 31px 0;
}

.youtubeInner h3 {
    margin: 0 0 20px 0;
}

.youtubeInner .right img {
    margin: 0 0 20px 0;
}

.youtubeInner .right {
    width: 490px;
}

.youtube {
    background: url(../img/top/yt_bg.png) no-repeat top center;
    border-bottom: #155c98 5px solid;
    padding: 70px 0 0 0;
}

#top .youtube h2.title {
    background: url(../img/top/ico_movie.png) no-repeat;
    border-bottom: #155c98 1px solid;
    color: #155c98;
    padding: 10px 0 15px 60px;
}

.youtube iframe {
    border: #e5e5e5 1px solid;
}



/*========================================
maintitle
========================================*/
#mainImg {
    background: url(../img/common/main_bg.png) no-repeat top center;
    height: 250px;
}

.mainTitle {
    width: 1000px;
    height: 250px;
    position: relative;
    margin: 0 auto;
}

.mainTitle h1.title {
    font-size: 36px;
    color: #175b9a;
    position: absolute;
    top: 48%;
    right: 10px;
}


/*========================================
breadcrumb
========================================*/
#pan {
    background: #d0dee9;
}

#pan ol {
    width: 1000px;
    margin: 0 auto;
    list-style: none;
}

#pan ol li {
    float: left;
    padding: 10px 10px 10px 0;
}

#pan ol li::after {
    content: ">";
    padding: 0 0 0 10px;
}

#pan ol li:last-child::after {
    content: "";
}

/*========================================
flow
========================================*/
.flowBg {
    width: 100%;
    background: url(../img/flow/flow_bg.png) no-repeat center;
}



/*========================================
qa
========================================*/
.qaTop {
    width: 1000px;
    margin: 0 auto;
}

.qaTable {
    margin: 0 0 0 60px;
    border: #e5e5e5 1px solid;
    font-size: 14px;
}

.qaTable th,
.qaTable td {
    padding: 10px;
    border: #e5e5e5 1px solid;
}

.qaTable thead th {
    text-align: center;
    background: #447dad;
    color: #fff;
}

.qaTable tbody {}

.qaTable tbody th {
    width: 20%;
    background: #f5f5f5;
}

.qaTable tbody tr:nth-child(even) th {
    background: #eeeeee;
}

.qaTable tbody tr:nth-child(even) td {
    background: #fafafa;
}

/*========================================
company
========================================*/
.campanyTable {
    width: 1000px;
    margin: 0 auto;
    margin-top: 50px;
    margin-bottom: 100px;
    font-size: 16px;
    line-height: 2;
}

.campanyTable tr:nth-child(odd) th,
.campanyTable tr:nth-child(odd) td {
    background: #f1f6fa;
}

.campanyTable th,
.campanyTable td {
    padding: 20px;
    line-height: 1.5;
}

.campanyTable th {
    width: 20em;
    color: #125896;
    font-weight: bold;
    text-align: left;
    padding: 0 0 0 50px;
}

.campanyTable td {
    text-align: left;
}

#gmap {
    margin-top: 50px;
    margin-bottom: 100px;
}


/*========================================
form
========================================*/
#form {
    margin: 50px 0 0 0;
    font-size: 16px;
    color: #135998;
    line-height: 2;
}

#form dl {
    width: 1000px;
    margin: 0 auto;
    margin-bottom: 3px;
    display: table;
}

#form dt,
#form dd {
    padding: 10px;
    background: #f1f6fa;
    vertical-align: top;
    text-align: left;
}

#form dt {
    display: table-cell;
    width: 324px;
    padding: 25px 0 20px 40px;
    position: relative;
    font-weight: bold;
}

#form dd {
    display: table-cell;
    position: relative;
    padding: 20px;
}

#form dt span {
    position: absolute;
    right: 50px;
    color: #a8140a;
    font-size: 14px;
}

#form dd span {
    font-size: 14px;
}

#form .hissu {
    background: #a8140a;
    color: #fff;
    font-size: 14px;
    padding: 2px 8px;
    position: absolute;
    right: 0;
}

input[type="text"],
input[type="tel"],
input[type="email"],
textarea,
select,
button {
    border: none;
    font-size: 18px;
    padding: 8px;
    width: 600px;
}

textarea {
    height: 200px;
}

#form .formBtn {
    margin: 50px 0 200px 0;
    text-align: center;
}

#form .formBtn .txt01 {
    text-align: center;
    padding: 0 0 10px;
}

#form .formBtn .txt01 a {
    color: #fb8d00;
}

#form .formBtn input {
    margin: 0 10px;
    padding: 15px 120px;
    font-size: 28px;
    color: #fff;
    border-radius: 40px;
    background-repeat: no-repeat;
    background-size: 35px 35px;
}

#form .formBtn input:last-child {
    margin-left: 25px;
}

#form .formBtn input[type="submit"] {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    background-color: #fb8d00;
    background-image: url(../img/common/arrow.png);
    background-position: 95% 50%;
}

#form .formBtn input[type="submit"]:hover {
    background-color: #ffa93b;
    background-image: url(../img/common/arrow.png);
    background-position: 95% 50%;
}

#form .formBtn #back {
    background-color: #bbb;
    background-image: url(../img/common/arrow_rev.png);
    background-position: 6% 50%;
}

#form .formBtn #back:hover {
    background-color: #ccc;
    background-image: url(../img/common/arrow_rev.png);
    background-position: 6% 50%;
}

input[type="text"].adSiza01 {
    margin: 0 10px 10px 10px;
    width: 120px;
}

input[type="text"].adSiza02 {
    margin: 0 10px;
    width: 80px;
}

#form .checkKoumoku {
    line-height: 2;
}

#form .checkKoumoku label {
    white-spce: nowrap;
    display: block;
    width: 40%;
    float: left;
    padding: 0 0 0 10px;
}

#form span.error {
    position: absolute;
    bottom: 5px;
    left: 25px;
    display: inline-block;
    padding: 0 15px;
    width: auto;
    min-width: 115px;
    height: 40px;
    color: #fff;
    line-height: 40px;
    text-align: center;
    background: #a8140a;
    z-index: 10;
    border-radius: 3px;
}

#form span.error:after {
    content: "";
    position: absolute;
    top: -8px;
    left: 20px;
    margin-left: -10px;
    display: block;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 0 8px 8px 8px;
    border-color: transparent transparent #a8140a transparent;
}

#form .checkKoumoku span.error {
    top: 125px;
}

#form .formEnd {
    width: 800px;
    background: #f1f6fa;
    margin: 0 auto;
    margin-bottom: 200px;
    padding: 50px 100px;
    text-align: center;
}

#form .formEnd p {
    font-size: 24px;
}

#form .formEnd p:first-child {
    font-size: 30px;
    margin-bottom: 15px;
}

/*========================================
accordion
========================================*/
.switch {
    font-size: 18px;
    line-height: 2;
    margin: 0 auto;
    padding: 20px 0;
}

.switch ul {
    list-style: none;
}

.switch ul li {
    margin-bottom: 50px;
}

.child {
    display: none;
    width: 960px;
}

.switch a {
    cursor: pointer;
    background: #f5f5f5;
    padding: 7px 15px;
    margin: 0 0 0 50px;
    display: inline-block;
    position: relative;
    width: 95%;
    color: #133131;
    text-align: left;
    color: #155c98;
}

.switch a::before {
    position: absolute;
    content: "";
    width: 30px;
    height: 2px;
    margin: -1px 0 0 0;
    background: #d2d2d2;
    top: 50%;
    right: 20px;
}

.switch a::after {
    position: absolute;
    content: "";
    width: 2px;
    height: 30px;
    margin: -15px 0 0 0;
    background: #d2d2d2;
    top: 50%;
    right: 34px;
    transition: all, 0.25s, linear;
}

.switch a.active::after {
    transform: rotate(-90deg);
}

.switch a:hover {
    text-decoration: none;
    background: #f0f0f0;
}

.switch ul li {
    width: 100%;
}

.switch ul li a span {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    background: #155c98;
    color: #fff;
    width: 50px;
    padding: 7px 0;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    position: absolute;
    top: 0;
    left: -50px;
}

.switch p {
    cursor: pointer;
    padding: 7px 15px 7px 65px;
    display: inline-block;
    position: relative;
    cursor: default;
}

.switch p span {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    background: #447dad;
    color: #fff;
    width: 50px;
    padding: 7px 0;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    position: absolute;
    top: 0;
    left: 0;
}

/*========================================
memento
========================================*/
#memento article {
    position: relative;
}

#memento article .btnBase {
    position: absolute;
    bottom: 130px;
    left: 50%;
    margin: 0 0 0 56px;
    background: #447dad;
    padding: 8px 20px 8px 40px;
    color: #fff;
}

#memento article .btnBase span.about {
    background: none;
    color: #f9d4a3;
    padding-left: 0;
    padding-right: 5px;
}

#memento article .btnBase::before {
    content: "　";
    background: url(../img/common/arrow_white.png) no-repeat;
    background-size: 5px 7px;
    position: absolute;
    top: 50%;
    left: 20px;
    margin: -3px 0 0 0;
}

#memento article .btnBase:hover {
    background: #5e94c2;
}

#memento .movieBox {
    width: 95%;
    margin: 0 auto;
}

#memento .movieBox div {
    padding: 20px 0 80px 0;
    text-align: center;
}

#memento .box04:nth-last-of-type(1) {
    margin: 20px auto 200px;
}

#memento .mainImg {
    background: url(../img/common/main_memento_bg.png) no-repeat top center;
    height: 250px;
}


/*========================================
footer
========================================*/
.contact div,
.footerBox02 div,
.footerBox03 div {
    text-align: center;
}

.contact {
    background: #447dad;
    padding: 80px 0 40px 0;
    position: relative;
    z-index: 1;
}

.contactInner {
    /*width: 915px;*/
    margin: 0 auto;
}

.contactInner .innerTxt {
    font-size: 14px;
    margin: 0 0 30px 0;
}

.contact::before {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border: 40px solid transparent;
    border-top: 30px solid #fff;
    top: 0;
    left: 50%;
    margin: 0 0 0 -40px;
}

.contact p,
.contact h3 {
    margin: 0 0 10px 0;
    font-size: 30px;
    color: #fff;
    text-align: center;
}

.contact .btn01 {
    background: #6997bd;
    color: #fff;
    padding: 10px 0 8px 0;
    font-size: 56px;
    font-weight: bold;
    text-align: center;
    font-family: "Kozuka Mincho Pro", "Kozuka Mincho Std", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    line-height: 30px;
}

.contact .btn01 span {
    font-size: 18px;
    font-weight: normal;
}

/*.contact .btn01 {
background: #fff;
border-radius: 40px;
padding: 26px 25px 21px 90px;
font-size: 23px;
font-weight: bold;
color: #155c98;
position: relative;
text-align: right;
font-family: "Kozuka Mincho Pro", "Kozuka Mincho Std", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}*/

/*.contact .btn01::before {
content: " ";
background: url(../img/common/icon_tel.png) no-repeat;
width: 38px;
height: 38px;
position: absolute;
top: 24%;
left: 6%;
}*/

/*.contact .btn01::after {
content: "お電話でのお問い合わせ　月～金　9:00～17:30";
color: #fff;
font-size: 14px;
font-weight: normal;
position: absolute;
bottom: -25px;
left: 50%;
margin: 0 0 0 -170px;
}*/

.contact .btn02 {}

.contact .btn02 a {
    width: 500px;
    display: block;
    background: #fa8d00;
    border-radius: 40px;
    padding: 27px 90px 25px 100px;
    font-size: 28px;
    color: #fff;
    position: relative;
    margin: 0 auto;
    margin-top: 30px;
}

.contact .btn02 a:hover {
    background: #ffa93b;
}

.contact .btn02 a:hover {
    text-decoration: none;
}

.contact .btn02 a span {
    font-size: 24px;
}

.contact .btn02 a::before {
    content: " ";
    background: url(../img/common/icon_mail.png) no-repeat;
    width: 46px;
    height: 38px;
    position: absolute;
    top: 25%;
    left: 10%;
}

.contact .btn02 a::after {
    content: " ";
    background: url(../img/common/arrow.png) no-repeat;
    background-size: 40px 40px;
    width: 40px;
    height: 40px;
    position: absolute;
    top: 23%;
    right: 4%;
}

.footerBox02 {
    color: #447dad;
    padding: 20px;
    text-align: center;
}

.footerBox02 table {
    margin: 0 auto;
}

.footerBox02 table th,
.footerBox02 table td {
    padding: 3px 20px;
    font-weight: bold;
}

.footerBox03 {
    background: #155c98;
    padding: 20px;
}

.footerBox03,
.footerBox03 a {
    color: #fff;
}

.footerBox03 p {
    padding-bottom: 20px;
    text-align: center;
}

@media screen and (-webkit-min-device-pixel-ratio:0) {

    /*chromハック*/
    .contact .btn01 {
        padding: 30px 0 15px 0;
    }
}

@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {

    /*IEハック*/
    #header .btn01,
    #header02 .btn01 {
        padding: 25px 0 0 35px;
    }

    #header li,
    #header02 li {
        padding: 0 0 10px 0;
    }

    #header .btn02 a,
    #header02 .btn02 a {
        padding: 5px 70px 0 80px;
    }

    .contact .btn01 {
        padding: 49px 25px 4px 90px;
    }

    .contact .btn01::after {
        bottom: -30px;
    }

    .contact .btn02 a {
        padding: 31px 90px 21px 110px;
    }
}

/*2016.4.1追記*/

/*========================================
flow
========================================*/
.flow {
    width: 1008px;
    margin: 0 auto;
}

.flow ol {
    position: relative;
    height: 1943px;
    background: url(../img/flow/botbg.png) no-repeat;
    margin: 30px 0 50px 0;
}

.flow ol li.flow01 {
    position: absolute;
    top: 0;
    left: 0;
    background: url(../img/flow/bg01.png) no-repeat;
    width: 511px;
    height: 455px;
}

.flow ol li.flow02 {
    position: absolute;
    top: 246px;
    right: 40px;
    background: url(../img/flow/bg02.png) no-repeat;
    width: 456px;
    height: 455px;
}

.flow ol li.flow03 {
    position: absolute;
    top: 488px;
    left: 0;
    background: url(../img/flow/bg03.png) no-repeat;
    width: 453px;
    height: 455px;
}

.flow ol li.flow04 {
    position: absolute;
    top: 745px;
    right: 0;
    background: url(../img/flow/bg04.png) no-repeat;
    width: 492px;
    height: 455px;
}

.flow ol li.flow05 {
    position: absolute;
    top: 988px;
    left: 0;
    background: url(../img/flow/bg05.png) no-repeat;
    width: 453px;
    height: 455px;
}

.flow ol li.flow06 {
    position: absolute;
    top: 1249px;
    right: 40px;
    background: url(../img/flow/bg06.png) no-repeat;
    width: 451px;
    height: 452px;
}

.flow ol li.flow07 {
    position: absolute;
    top: 1487px;
    left: 0;
    background: url(../img/flow/bg07.png) no-repeat;
    width: 453px;
    height: 456px;
}

.flow ol li dt {
    color: #135997;
    font-size: 36px;
    text-decoration: underline;
    padding-top: 40px;
    margin-left: 160px;
    margin-bottom: 60px;
    line-height: 1.3em;
    text-align: left;
}

.flow ol li.flow01 dt,
.flow ol li.flow02 dt,
.flow ol li.flow03 dt,
.flow ol li.flow06 dt {
    margin-top: 20px;
}

.flow ol li dd {
    line-height: 1.6em;
    text-align: left;
    font-size: 18px;
    text-shadow: 1px 0px 0px #fff, 0px 1px 0px #fff, -1px 0px 0px #fff, 0px -1px 0px #fff;
}

.flow ol li.flow01 dd {
    width: 300px;
    margin-left: 60px;
}

.flow ol li.flow02 dd {
    width: 390px;
    margin-left: 45px;
    margin-top: -10px;
    letter-spacing: -1px;
}

.flow ol li.flow03 dd {
    width: 260px;
    margin-left: 60px;
}

.flow ol li.flow04 dd {
    width: 260px;
    margin-left: 30px;
}

.flow ol li.flow05 dd {
    width: 260px;
    margin-left: 30px;
}

.flow ol li.flow06 dd {
    width: 260px;
    margin-left: 30px;
}

.flow ol li.flow07 dd {
    width: 260px;
    margin-left: 60px;
}

/*========================================
memento
========================================*/
.memento {
    text-align: left;
    width: 1000px;
    margin: 0 auto;
    position: relative;
}

.memento h3 {
    color: #135997;
    font-size: 24px;
    margin-bottom: 10px;
    margin-bottom: 15px;
}

.memento p {
    font-size: 16px;
    line-height: 1.8em;
}

.memento .box01 {
    width: 1000px;
    margin: 0 auto 100px auto;
    position: relative;
    background-color: #F4F7FA;
    padding: 20px;
    margin-top: 20px;
    min-height: 170px;
}

.memento .box01 .photo {
    position: absolute;
    top: 20px;
    right: 20px;
}

.memento .box01 p {
    width: 650px;
}

.memento .box02 {
    width: 1000px;
    margin: 0 auto 120px auto;
    position: relative;
    background-color: #F4F7FA;
    padding: 20px;
    margin-top: 20px;
    min-height: 230px;
}

.memento .box02 .photo {
    position: absolute;
    top: 20px;
    left: 20px;
}

.memento .box02 p {
    width: 740px;
    margin-left: 230px;
}

.memento .box02 h3 {
    margin-left: 230px;
}


.memento .box03 {
    width: 1000px;
    margin: 0 auto 60px auto;
    position: relative;
    background-color: #F4F7FA;
    padding: 20px;
    margin-top: 20px;
    min-height: 200px;
}

.memento .box03 .photo {
    position: absolute;
    top: -35px;
    right: 20px;
}

.memento .box03 p {
    width: 650px;
}

.memento .box04 {
    margin: 20px auto 100px auto;
    position: relative;
}

.memento .box04 p {
    margin-left: 400px;
    margin-bottom: 30px;
}

.memento .box04 .photo {
    position: absolute;
    left: 0;
    top: -110px;
}

#memento article .memento .btnBase {
    position: absolute;
    bottom: -60px;
    right: 0;
    margin: 0 0 0 56px;
    background: #447dad;
    padding: 8px 20px 8px 40px;
    color: #fff;
}

#memento article .memento .btnBase span.about {
    background: none;
    color: #f9d4a3;
    padding-left: 0;
    padding-right: 5px;
}

#memento article .memento .btnBase::before {
    content: "　";
    background: url(../img/common/arrow_white.png) no-repeat;
    background-size: 5px 7px;
    position: absolute;
    top: 50%;
    left: 20px;
    margin: -3px 0 0 0;
}

#memento article .memento .btnBase:hover {
    background: #5e94c2;
}

/*========================================
mechanism
========================================*/
.mechanism {
    text-align: left;
    width: 1000px;
    line-height: 1.8em;
    font-size: 16px;
    margin: 0 auto;
}

.mechanism h2 {
    margin-bottom: 15px;
}

.mechanism .orange_b {
    color: #FA8C00;
    font-weight: bold;
}

.mechanism .box {
    background-color: #F3F7FA;
    padding: 30px;
    margin: 40px 0 0 0;
}

.mechanism .box h3 {
    margin-bottom: 50px;
}

.mechanism ul.list01 {
    border: #AFC7DC 3px solid;
    padding: 15px 5px;
    font-size: 14px;
    width: 370px;
    margin-top: 10px;
    color: #135998;
}

.mechanism ul.list01 li {
    list-style: disc;
    margin-left: 15px;
}

.mechanism .img_l {
    float: left;
    margin-right: 10px;
    margin-bottom: 10px;
    text-align: left;
}

.mechanism .img_r {
    float: right;
    margin-left: 10px;
    margin-bottom: 10px;
    text-align: left;
}

.mechanism .lr {
    background: url(../img/mechanism/line.jpg) no-repeat bottom;
    margin-bottom: 20px;
}

.mechanism .lr:last-child {
    background: none;
}

.mechanism .lr h4 {
    width: 350px;
    float: left;
}

.mechanism .lr .right {
    width: 520px;
    float: right;
    text-align: left;
}

.mechanism .lr .right ul.list02 li {
    padding-left: 65px;
}

.mechanism .lr .right ul.list02 li:first-child {
    background-image: url(../img/mechanism/point01.gif);
    background-repeat: no-repeat;
    background-position: 1px 0.4em;
}

.mechanism .lr .right ul.list02 li:nth-child(2) {
    background-image: url(../img/mechanism/point02.gif);
    background-repeat: no-repeat;
    background-position: 1px 0.4em;
}

.mechanism .lr .right ul.list02 li:nth-child(3) {
    background-image: url(../img/mechanism/point03.gif);
    background-repeat: no-repeat;
    background-position: 1px 0.4em;
}

.mechanism .lr .right ul.list02 li:last-child {
    background-image: url(../img/mechanism/point04.gif);
    background-repeat: no-repeat;
    background-position: 1px 0.4em;
}

.mechanism .lr .right ul.list03 li {
    padding-left: 15px;
    background-image: url(../img/mechanism/circle.jpg);
    background-repeat: no-repeat;
    background-position: 1px 0.6em;
}

.mechanism .lr .right h5 {
    font-size: 25px;
    margin-top: 5px;
    color: #306CA5;
}

.mechanism .human table {
    margin: 15px 0px 20px;
    border-collapse: collapse;
    width: 100%;
    border: 1px solid #F1F6FA;
}

.mechanism .human table td {
    padding: 8px;
    vertical-align: middle;
}

.mechanism .human table thead th {
    padding: 8px;
    text-align: left;
    border-left: none;
    border-right: none;
    font-weight: bold;
    vertical-align: middle;
    font-size: 18px;
    color: #fff;
    background: url(../img/mechanism/th_bg.jpg);
}

.mechanism .human table th {
    font-weight: bold;
}

.mechanism .human table tr:nth-child(even) {
    background: #F1F6FA;
}

.mechanism .human .text {
    border: 1px #5A8BB7 solid;
    padding: 20px;
    margin-bottom: 40px;
}

.mechanism .safety .left {
    float: left;
    width: 300px;
}

.mechanism .safety .right {
    float: right;
    width: 630px;
    text-align: left;
}

.mechanism .safety .right p {
    margin-bottom: 30px;
}

.mechanism .safety .right .blue14 {
    font-size: 14px;
    color: #135998;
}

.mechanism .safety .text {
    background-color: #F3F7FA;
    padding: 20px;
    margin-bottom: 40px;
}

.mechanism .safety .text h4 {
    font-size: 20px;
    color: #135998;
    margin-bottom: 10px;
    font-weight: normal;
}

.mechanism .introduction {
    background-image: url(../img/mechanism/bobble_bg.jpg);
    background-repeat: no-repeat;
    width: 1000px;
    min-height: 900px;
    margin: 30px auto 50px auto;
    padding: 20px 20px 20px 450px;
}

.mechanism .introduction h3 {
    background-color: #135998;
    color: #fff;
    margin-top: 30px;
    margin-bottom: 5px;
    text-align: center;
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    padding: 10px 0;
    font-size: 25px;
}

.mechanism .introduction p {}

.mechanism .specification {
    margin-top: 70px;
}

.mechanism .specification table {
    margin: 15px 0px 20px;
    border-collapse: collapse;
    width: 100%;
}

.mechanism .specification table td {
    padding: 8px;
    border: 1px solid #F1F6FA;
    vertical-align: middle;
}

.mechanism .specification table th {
    padding: 8px;
    text-align: left;
    border-bottom: 1px solid #B8CEE0;
    font-weight: bold;
    vertical-align: middle;
    font-size: 18px;
    color: #fff;
    background-color: #CBDBE8;
}

.newsBox {
    background: rgba(255, 255, 255, .6);
    border: #ff2222 2px solid;
    color: #ff2222;
    font-size: 12px;
    padding: 1px 10px;
    width: 100%;
    top: 5px;
}

.newsBox p {
    text-align: center;
}

/*------------------------------------------------------------
個人情報
------------------------------------------------------------*/
.mainBox {
    width: 1000px;
    margin: auto;
    padding: 50px 0;
    font-size: 16px;
    line-height: 1.75;
    text-align: justify;
}

.mainBox p {
    padding: 0 0 10px;
    text-align: justify;
}

.mainBox p.right {
    float: none;
    text-align: right;
}

.mainBox dt {
    font-weight: bold;
}

.mainBox dd {
    padding: 0 0 20px 31px;
}

.mainBox li {
    padding: 0 0 10px 30px;
    text-indent: -32px;
}

.mainBox table th,
.mainBox table td {
    width: auto;
    vertical-align: top;
}

.table01,
.table02 {
    width: 100%;
    margin: 0 0 30px;
}

.table01 thead th {
    text-align: center;
    color: #125896;
    background: #f1f6fa;
}

.table01 th,
.table01 td:first-child {
    width: 18%;
}

.table01 th,
.table01 td {
    padding: 15px;
    border: #ced9e4 1px solid;
}

.table01 tr th {
    background: #f1f6fa;
}

.table01 td {}

.table02 thead th {
    color: #165c98;
    background: #f1f6fa;
    padding: 5px 15px;
    border: #ced9e4 1px solid;
    width: 50%;
    text-align: center;
}

.table02 tbody td {
    padding: 15px;
    border: #ced9e4 1px solid;
}

.btnBox {
    margin: 50px 0 0;
}

.btnBox ul {
    display: flex;
    justify-content: space-evenly;
}

.mainBox .btnBox li {
    padding: 0;
    text-indent: 0;
}

.btnBox a {
    background: #f1f6fa;
    padding: 20px 10px 20px 20px;
    display: block;
    text-align: center;
    text-decoration: none;
    color: #165c98;
}

.btnBox a::after {
    content: "≫";
    padding: 0 0 0 20px;
}

.btnBox a:hover {
    text-decoration: none;
    opacity: .8;
}

.btnBox .active {
    background: #165c98;
    color: #fff;
}


/*------------------------------------------------------------
プライバシーマーク
------------------------------------------------------------*/


#gFooter .fPrivacyBox {
    width: 1082px;
    margin: 40px auto 0;
    padding: 20px 0 50px;
}

#gFooter .fPrivacyBox .fPrivacyL {
    width: 67%;
    display: inline-block;
}

#gFooter .fPrivacyBox .privacyImg {
    float: left;
}

#gFooter .fPrivacyBox .fCardR {
    float: right;
    width: 28%;
}

#gFooter .fPrivacyBox .fPrivacyL .fPrivacyBoxR {
    padding-left: 160px;
    margin-top: 12px;
}

#gFooter .fPrivacyBox .fPrivacyL .fPrivacyBoxR h2 {
    color: #155c98;
    font-size: 21px;
    width: auto;
    padding: 0;
    letter-spacing: 4px;
    font-family: "游明朝 Light", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-weight: normal;
}

#gFooter .fPrivacyBox .fPrivacyL .fPrivacyBoxR p {
    font-size: 14px;
    line-height: 1.8;
    margin-top: 18px;
}

#gFooter .fPrivacyBox .fCardR .visaImg {
    float: left;
    margin-top: 16px;
}

#gFooter .fPrivacyBox .fCardR .masterImg {
    float: right;
    margin-bottom: 15px;
}

#gFooter .fPrivacyBox .fCardR .fCardText {
    clear: both;
    font-size: 14px;
    text-align: center;

}


.cardpay {
    width: 24%;
    margin: 0 auto;
}

.cardpay .visaImg {
    display: inline-block;
    margin-top: 13px;
}

.cardpay .visaImg img {
    width: 80%;
}

.cardpay .masterImg {
    float: right;
}

.cardpay .masterImg img {
    width: 84%;
}

@media all and (min-width: 0) and (max-width: 767px) {
    #gFooter .fPrivacyBox {
        width: 100%;
        margin: 0;
        padding: 30px 0;
    }

    #gFooter .fPrivacyBox .fPrivacyL {
        width: 94%;
        margin: 0 4%;
    }

    #gFooter .fPrivacyBox .fPrivacyL .fPrivacyBoxR h2 {
        font-size: 22px;
        line-height: 1.5;
    }

    #gFooter .fPrivacyBox .fCardR {
        float: none;
        width: 69%;
        margin: 0 auto;
    }

    #gFooter .fPrivacyBox .fPrivacyL .sp {
        clear: both;
        padding-top: 10px;
        line-height: 1.7;
        padding-bottom: 30px;
    }

    .cardpay {
        width: 73%;
        margin: 0 auto;
    }

    #price #main .subList.newPay {
        margin-top: 40px;
    }

    .cardpay .visaImg {
        width: 50%;
    }

    .cardpay .masterImg {
        width: 43%;
    }

    #gFooter .fPrivacyBox .fPrivacyL .fPrivacyBoxR {
        padding-left: 150px;
    }

    #gFooter .fPrivacyBox .fCardR .visaImg {
        width: 45%;
    }

    #gFooter .fPrivacyBox .fCardR .visaImg img {
        width: 100%;
    }

    #gFooter .fPrivacyBox .fCardR .masterImg {
        width: 40%;
    }

    #gFooter .fPrivacyBox .fCardR .masterImg img {
        width: 100%;
    }
}
