@charset "utf-8";

/*
源ノゴシック
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Noto Serif JP', serif;
*/

html {
    font-family: 'Noto Sans JP', sans-serif;
}
body {
    background: #fff;
    color: #1e1e1e;
}
.inner {max-width: 1080px;width: 100%;margin: 0 auto;box-sizing: border-box;}
.inner_s {max-width: 1080px;width: 100%;margin: 0 auto;box-sizing: border-box;}

.marker {background: linear-gradient(transparent 60%, rgba(249, 240, 78, 0.8) 60%);}

.tel_bloc {
    align-items: center;
    justify-content: space-between;
    gap: 0.5em;
}
.tel_bloc i {
    display: block; 
}
.tel_bloc i img {
    display: block; 
}

.tel_bloc a {
    display: block;
    font-size: 1.6em;
    line-height: 1em;
    font-weight: bold;
    text-decoration: none;
    color: #1e1e1e;  
}
.tel_bloc a:hover {
    
}

.banner {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    right: 0;
}
.banner ul {

}
.banner ul li {

}
.banner ul li + li {
    margin-top: 1em;
}
.banner ul li a {
    display: block;
    background: #fff;
    border-top-left-radius: 0.5em;
    border-bottom-left-radius: 0.5em;
}
.banner ul li a img {
    display: block;
}
.banner ul li a:hover img {
    opacity:0.8;
}
/* **************************************************************** */
/* ヘッダー
*/
header {
    padding: 0.5em 0;
}
header .inner {
    align-items: center;
    justify-content: space-between;
}

header .logo {
    
}


/* **************************************************************** */
/* フッター
*/
footer {
    background: #063a89;
    padding: 1em 0;
}
footer .inner {
    align-items: flex-end;
    justify-content: space-between;
}
footer .logo {

}

footer .copy {
    display: block;
    color: #fff;
    font-size: 12px;
    line-height: 1;
}


/* **************************************************************** */
/* コンタクト
*/
.contact {
    background: #fbf8ee;
    padding: 2em 0;
}
.contact_bloc dl dt.required:after {
    background: #fe0000;
}
.btn_bloc button {
    background: none;
    box-shadow: none;
    padding: 0;
    max-width: none;
    display: inline-block;
}
.btn_bloc button:hover img {
    opacity:0.8;
}

.contact_upper {

}
.contact_upper h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
}



.address_dl {
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1em;
}
select.contact_select.fmctr {
    min-width: 12em;
}







/* **************************************************************** */
/* 個別CSS
*/
.mv {
    background: url(../images/bg_mv.jpg) no-repeat center top;
    background-size: cover;
}
.mv .inner {
    align-items: center;
    justify-content: space-between;
}
.mv_bloc {
    position: relative;
}
.mv_bloc h1 {
    background: url(../images/bg_mv_detail.png) no-repeat;
    background-size: contain;
    margin-bottom: 0.5em;
}
.mv_bloc h1 img {
    filter: drop-shadow(2px 2px 2px #fff);
}

.mv_bloc p {
    font-size: 1.2em;
    line-height: 1.4em;
    font-weight: bold;
    margin-bottom: 0.5em;
    text-shadow: 2px 2px 2px #fff;
}
.mv_bloc ul {
    align-items: flex-start;
    justify-content: center;
    gap: 1em;
}
.mv_bloc ul li {
    
}
.mv_bloc ul li + li {
    
}

.mv .inner figure {
    flex: 1 0 0%;
    padding-top: 7.2em;
    margin-left: -1em;
}

.cv {

}
.cv_upper {
    background: #bea239;
    color: #fff;
    padding: 1em 0;
}
.cv_upper p {
    align-items: center;
    justify-content: center;
    gap: 0.5em;
}
.cv_upper p .free {
    
}
.cv_upper p .txt {
    display: block;
    font-size: 1.4em;
    line-height: 1.4em;
    font-weight: bold;
}
.cv_content {
    background: #fbf8ee;
    padding: 2em 0;
}
.cv_content .inner {
    align-items: center;
    justify-content: space-between;
}

.cv_content .tel_bloc {
    width: 50%;
    align-items: center;
    justify-content: center;
}
.cv_content .tel_bloc a {
    font-size: 2.4em;
}

.cv_content .btn_bloc {
    width: 50%;
}
.cv_content .btn_bloc a {

}
.cv_content .btn_bloc a img {

}
.cv_content .btn_bloc a:hover img {
    opacity:0.8;
}

.caution {
    background: url(../images/bg_caution.jpg) no-repeat center;
    background-size: cover;
    padding: 2em 0 0;
    overflow: hidden;
}
.caution h2 {
    font-family: 'Noto Serif JP', serif;
    color: #f9f600;
    font-size: 2.4em;
    line-height: 1.2em;
    font-weight: 900;
    margin-bottom: 0.5em;
}
.caution_bloc {
    margin-bottom: 2em;
}
.caution_bloc > * + * {
    margin-top: 1em;
}
.caution_bloc ul {
    align-items: flex-start;
    justify-content: center;
    gap: 1em;
}
.caution_bloc ul li {
    background: #fff;
    max-width: 420px;
    width: 100%;
    padding: 0.5em;
    font-size: 1.2em;
    font-weight: 900;
    text-align: left;
    padding-left: 2.4em;
    position: relative;
    box-sizing: border-box;
}
.caution_bloc ul li + li {

}
.caution_bloc ul li:before {
    content: "";
    background: url(../images/icon_check.png) no-repeat;
    width: 30px;
    height: 26px;
    position: absolute;
    top: 0.8em;
    left: 0.8em;
}

.caution_bloc p {
    font-family: 'Noto Serif JP', serif;
    color: #fff;
    font-size: 1.4em;
    line-height: 1.4em;
    font-weight: bold;
}

.caution figure {
    
}

.trouble {
    padding: 2em 0;
}
.trouble_content {

}
.trouble_bloc {
    align-items: center;
    justify-content: space-between;
}
.trouble_bloc + .trouble_bloc {
    margin-top: 2em; 
}

.trouble_bloc .item {
    flex: 1 0 0%;
    text-align: left;
    padding: 1em;
}
.trouble_bloc .item h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    font-weight: 900;
    margin-bottom: 0.5em;
}
.trouble_bloc .item p {

}
.trouble_bloc .item p em {
    background: linear-gradient(transparent 60%, #fafd07 60%);
    color: #fb0303;
    padding: 0 0.2em;
    font-weight: bold;
}

.trouble_bloc figure {

}

.trouble_bloc:nth-child(even) {
    flex-direction: row-reverse;
}

.resolution {
    background: #1aa5f8;
    color: #fff;
    padding: 4em 0 2em;
    position: relative;
}
.resolution:before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 40px 20px 0 20px;
    border-color: #ffffff transparent transparent transparent;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.resolution h2 {
    font-family: 'Noto Serif JP', serif;
    color: #f9f600;
    font-size: 2.4em;
    line-height: 1.2em;
    font-weight: 900;
    margin-bottom: 1em;
}

.resolution_bloc {
    margin-bottom: 2em;
}
.resolution_bloc p {
    text-align: left;
}
.resolution_bloc p em {
    color: #f6f900;
    font-size: 1.1em;
    font-weight: bold;
    margin: 0 0.1em;
}
.resolution_bloc p img {
    float: right;
    shape-outside: padding-box;
    padding: 1em;
}
.resolution_bloc p + p {
    margin-top: 2em;
}

.resolution_figure {

}

.difference {
    padding: 2em 0;
}
.difference_upper {
    margin-bottom: 1em;
}
.difference_upper h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    font-weight: 900;
    margin-bottom: 0.5em;
}
.difference_upper p {
    font-size: 1.2em;
    line-height: 1.4em;
    font-weight: bold; 
}
.difference_upper p em {
    color: #fe0000;
    font-size: 1.2em;
    font-weight: 900;
}

.difference_menu {
    margin-bottom: 2em;
}
.difference_menu ul {
    align-items: flex-start;
    justify-content: center;
    gap: 2em;
}
.difference_menu ul li {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    font-weight: bold;
    color: #fff;
    width: 320px;
    padding: 0.2em 0.5em;
    border-radius: 0.2em;
}
.difference_menu ul li + li {
    
}
.difference_menu ul li:nth-child(1) {
    background:#1aa5f8;
}
.difference_menu ul li:nth-child(2) {
    background:#bea239;
}

.difference_content {
    margin-bottom: 2em;
}
.difference_bloc {
    border-radius: 0.5em;
    overflow: hidden;
}
.difference_bloc + .difference_bloc {
    margin-top: 2em;
}
.difference_bloc h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.8em;
    line-height: 1.2em;
    padding: 0.5em;
    color: #fff;
}
.difference_bloc:nth-child(1) h3 {
    background:#1aa5f8;
}
.difference_bloc:nth-child(2) h3 {
    background:#bea239;
}

.difference_bloc:nth-child(1) .box {
    background: #daf0fd;
    padding: 1.5em;
}
.difference_bloc:nth-child(2) .box {
    background: #fbf8ee;
    padding: 1.5em;
}

.difference_bottom {
    border: solid 4px #1aa5f7;
    border-radius: 0.5em;
    padding: 1.5em;
}
.difference_bottom h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.8em;
    line-height: 1.2em;
    margin-bottom: 1em;
    color: #1aa5f7;
}
.difference_bottom ol {
    
}
.difference_bottom ol li {
    width: 24%;
}
.difference_bottom ol li + li {
    
}
.difference_bottom ol li figure {
    margin-bottom: 0.5em;
}
.difference_bottom ol li p {
    text-align: left;
    font-size: 1em;
    line-height: 1.4em;
    font-weight: bold;
}

.flow {
    background: #fbf8ee;
    padding: 2em 0;
}
.flow h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    margin-bottom: 0.5em;
}
.flow_bloc {

}
.flow_bloc p {

}

.forte {
    background: #1aa5f8;
    color: #fff;
    padding: 2em 0 0;
}

.forte h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    margin-bottom: 0.5em;
}

.forte_content {
    align-items: center;
    justify-content: space-between;
    gap: 2em;
}
.forte figure {
    
}
.forte_bloc {
    flex: 1 0 0%;
    text-align: left;
}

.forte_bloc h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.8em;
    line-height: 1.2em;
    margin-bottom: 0.5em; 
}
.forte_bloc p {
    
}

.BeCareful {
    background: url(../images/bg_BeCareful.jpg) no-repeat center;
    background-size: cover;
    padding: 2em 0;
}
.BeCareful_upper {
    margin-bottom: 1em;
}
.BeCareful_upper h2 {
    display: inline-block;
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    background: #000;
    color: #d0e043;
    padding: 0.2em 0.5em 0.3em;
    margin-bottom: 0.5em;
}
.BeCareful_upper p {
    font-size: 1em;
    line-height: 1.6em;
}
.BeCareful_bloc {
    position: relative;
    margin-bottom: 2em;
}
.BeCareful_bloc figure {
    
}
.BeCareful_bloc p:nth-child(1) {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.4em;
    line-height: 1.2em;
    color: #fc0505;
    font-weight: 900;
    position: absolute;
    top: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    right: 50%;
    margin-right: 6em;
}
.BeCareful_bloc p:nth-child(2) {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.4em;
    line-height: 1.2em;
    color: #fc0505;
    font-weight: 900;
    position: absolute;
    top: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    left: 50%;
    margin-left: 6em;
}

.BeCareful_bottom {

}
.BeCareful_bottom p {
    display: inline-block;
    background: #fff;
    padding: 1em;
    border-radius: 0.5em;
    box-shadow: 0 3px 3px #ccc;
    text-align: left;
}

.method {
    background: #1aa5f8;
    color: #fff;
    padding: 2em 0;
}
.method h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    margin-bottom: 1em;
}
.method_content {
    position: relative;
}
.method_bloc {
    text-align: left;
}
.method_bloc dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1em;
    font-family: 'Noto Serif JP', serif;
}
.method_bloc dl + dl {
    margin-top: 1em;
}
.method_bloc dl dt {
    font-size: 1.4em;
    line-height: 1em;
    border: solid 1px #fff;
    border-radius: 50px;
    padding: 0.2em 1em 0.3em;
    box-sizing: border-box;
    width: 240px;
    text-align: center;
}
.method_bloc dl dd {
    
}

.method_bloc dl:nth-child(1) dd {
    color: #f9f000;
    font-size: 1.6em;
    line-height: 1.2em;
    font-weight: bold;
}
.method_bloc dl:nth-child(2) dd {
    color: #f9f000;
    font-size: 1.6em;
    line-height: 1.2em;
    font-weight: bold;   
}
.method_bloc dl:nth-child(3) dd {
    font-size: 1.2em;
    line-height: 1.4em;
}
.method_bloc dl:nth-child(3) dd em {
    color: #f9f000;
    font-size: 1.2em;
    line-height: 1.4em;
    font-weight: bold;  
}
.method_bloc dl:nth-child(4) dd {
    
}

.method_content figure {
    position: absolute;
    /* top: 50%; */
    /* transform: translateY(-50%); */
    /* -webkit-transform: translateY(-50%); */
    top: 0;
    right: 0;
}

.company {
    padding: 2em 0;
}
.company h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    margin-bottom: 1em;
}
.company_content {
    align-items: center;
    justify-content: space-between;
    gap: 2em;
    margin-bottom: 2em;
}
.company_content figure {

}
.company_content .item {
    flex: 1 0 0%;
    text-align: left;
}

.company_content .item .upper {
    margin-bottom: 2em;
}
.company_content .item .upper dl {

}
.company_content .item .upper dl + dl {
    margin-top: 1em;
}
.company_content .item .upper dl dt {
    color: #1aa5f8;
    text-decoration: underline;
    font-size: 1.2em;
    line-height: 1.2em;
    font-weight: bold;
    margin-bottom: 0.5em;
}
.company_content .item .upper dl dd {
    font-size: 1em;
    line-height: 1.4em;
    margin: 0;
}
.company_content .item .upper dl dd a {
    color: #1e1e1e;
}

.company_content .item .upper dl dd em {
    font-weight: bold;;
}

.company_content .item .bottom {

}
.company_content .item .bottom dl {
    font-size: 0.9em;
    line-height: 1.4em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
}
.company_content .item .bottom dl + dl {
    margin-top:1em;
}
.company_content .item .bottom dl dt {
    color: #1aa5f8;
    text-decoration: underline;
    font-weight: bold;
    width: 6em;
}
.company_content .item .bottom dl dd {

}

.company_map {

}
.company_map iframe {
    width: 100%;
    aspect-ratio: 16/9;
  
}

.message {
    background: url(../images/bg_message.jpg) no-repeat center bottom;
    background-size: cover;
    padding: 2em 0 20em;
}
.message .upper {
    margin-bottom: 2em;
}
.message .upper i {
    display: inline-block;
    margin-bottom: 1em;
}
.message .upper h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 2.4em;
    line-height: 1.2em;
    color: #fff;
}

.message_bloc {

}
.message_bloc .text {
    text-align: justify;
    font-size: 1em;
    color: #fff;
}
.message_bloc .name {
    text-align: right;
    margin-top: 1em;
}



