@charset "UTF-8";
/********************************
DEFAULT
*********************************/
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video {
    margin: 0px;
    padding: 0px;
    outline: 0;
}
article,aside,details,figcaption,figure,footer,header,main,menu,nav,section {
    display: block;
}
h1,h2,h3,h4,h5,h6,caption,address,th {
    font-weight: normal;
    margin: 0;
    padding: 0;
    font-size: 100%;
}
ul,ol,li,dl,dt,dd {
    list-style: none;
}
img,iframe {
    vertical-align: middle;
    border: 0px;
}
img {
    line-height: 0;
    font-size: 0;
    -webkit-backface-visibility: hidden;
}
table {
    border-collapse: collapse;
}
th {
    font-weight: normal;
    text-align: left;
}
button,fieldset,form,input,label,legend,select,textarea {
    font-style: inherit;
    font-weight: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
}
select {
    padding: 2px;
}
select::-ms-expand {
    display: none;
}
input,select {
    font-size: 100%;
    vertical-align: middle;
}
input[type="text"],input[type="password"],textarea,select {
    outline: none;
}
textarea {
    font-size: 100%;
}
input {
    vertical-align: middle;
}
::-webkit-input-placeholder {
    color: #B3B3B4;
}
::-webkit-input-placeholder {
    color: #B3B3B4;
}
:placeholder-shown {
    color: #B3B3B4;
}
::-webkit-input-placeholder {
    color: #B3B3B4;
}
:-moz-placeholder {
    color: #B3B3B4; opacity: 1;
}
::-moz-placeholder {
    color: #B3B3B4; opacity: 1;
}
:-ms-input-placeholder {
    color: #B3B3B4;
}
label {
    padding: 0 0 0 2px;
}
hr {
    display: none;
}
a {
    transition: opacity 0.3s ease-in-out , all 0.3s ease-in-out;
    -ms-transition: opacity 0.3s ease-in-out , all 0.3s ease-in-out;
    -moz-transition: opacity 0.3s ease-in-out , all 0.3s ease-in-out;
    -webkit-transition: opacity 0.3s ease-in-out , all 0.3s ease-in-out;
}
a,a:link {
    color: #c3012f;
    text-decoration: none;
    word-break: break-all;
}
a:visited {
    color: #c3012f;
}
a:hover,a:active {
    color: #c3012f;
    text-decoration: underline;
}
*:focus {
    outline: none;
}
.m_b0 {
    margin-bottom: 0px !important;
}
.m_b1 {
    margin-bottom: 1px !important;
}
.m_b2 {
    margin-bottom: 2px !important;
}
.m_b3 {
    margin-bottom: 2px !important;
}
.m_b5 {
    margin-bottom: 5px !important;
}
.m_b7 {
    margin-bottom: 7px !important;
}
.m_b8 {
    margin-bottom: 8px !important;
}
.m_b10 {
    margin-bottom: 10px !important;
}
.m_b11 {
    margin-bottom: 11px !important;
}
.m_b12 {
    margin-bottom: 12px !important;
}
.m_b13 {
    margin-bottom: 13px !important;
}
.m_b15 {
    margin-bottom: 15px !important;
}
.m_b20 {
    margin-bottom: 20px !important;
}
.m_b25 {
    margin-bottom: 25px !important;
}
.m_b30 {
    margin-bottom: 30px !important;
}
.m_b35 {
    margin-bottom: 35px!important;
}
.m_b40 {
    margin-bottom: 40px !important;
}
.m_b45 {
    margin-bottom: 45px !important;
}
.m_b50 {
    margin-bottom: 50px !important;
}
.m_b55 {
    margin-bottom: 55px !important;
}
.a_center {
    text-align: center;
}
.a_left {
    text-align: left;
}
.a_right {
    text-align: right;
}
.f_bold {
    font-weight: bold;
}
.f_red {
    color: #c3012f;
}
.f_line {
    text-decoration: underline;
}
.c_fix:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    font-size: .01em;
    height: 0;
    overflow: hidden;
}
.c_fix {
    min-height: 1px;
}
html {
    height: 100%;
}
body {
    font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN","ヒラギノ角ゴ Pro","Helvetica Neue",Arial,Meiryo,sans-serif;
    line-height: 1.8;
    color: #434343;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
    min-width: 1240px;
    min-height: 100%;
    height: auto !important;
    position: relative;
    -webkit-text-size-adjust: none;
    -webkit-font-smoothing: antialiased;
    background: #ffffff;
    box-sizing: border-box;
    -ms-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    padding: 140px 0 0;
}
/********************************
mv
*********************************/
.mv_warp {
    background: #f9faf4;
    width: 1200px;
    margin: 0 auto;
}
.mv_in {
    display: table;
    table-layout: fixed;
    letter-spacing: -.4em;
    height: 340px;
    width: 100%;
}
.mv_ttl {
    display: table-cell;
    letter-spacing: normal;
    vertical-align: middle;
    text-align: center;
    font-size: 28px;
    line-height: 1.5;
    font-weight: bold;
}
.mv_ttl.is-clr {
    color: #c3012f;
}
body.family .mv_warp {
    background:#f9faf4 url(../img/mv_family.jpg) center center no-repeat;
}
/********************************
HEADER
*********************************/
header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    background: rgba(255,255,255,0.9);
    width: 100%;
    z-index: 999;
}
.header_wrap {
    width: 1200px;
    margin: 0 auto;
    padding: 18px 0 19px 0;
}
.head-logo {
    float: left;
    padding: 10px 0 0 0;
}
.head-logo a {
    display: block;
}
@media (min-width: 896px) {
    .head-logo a:hover {
        opacity: 0.7;
    }
}
.head-tnis {
    float: right;
}
.head-btn {
    float: right;
    margin: 0 36px 0 0;
    width: 180px;
}
.head-btn a {
    display: table;
    width: 100%;
    height: 38px;
    border: 1px solid #707070;
    box-sizing: border-box;
    background: #ffffff url(../img/dec_arw_red.png) no-repeat right 12px center;
    text-align: center;
    font-size: 12px;
    font-weight: bold;
    text-decoration: none;
    color: #434343;
}
.head-btn.is-rd a {
    border: 1px solid #c3012f;
    background:#c3012f url(../svg/dec_arw_r_01.svg) no-repeat right 12px center;
    background-size: 6px auto;
    color: #fff;
}
@media (min-width: 896px) {
    .head-btn a:hover {
        background: #e4e2e2 url(../img/dec_arw_red.png) no-repeat right 12px center;
    }
    .head-btn.is-rd a:hover {
        background:#c3012f url(../svg/dec_arw_r_01.svg) no-repeat right 12px center;
        background-size: 6px auto;
        opacity: 0.7;
    }
}
.head-btn a span {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}
.headMenu_wrap {
    padding: 24px 0 0 0;
}
.menu_btn {
    display: none;
}
.headMenu_in ul {
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-left: 1px solid #707070;
}
.headMenu_in ul li {
    font-weight: bold;
    padding: 0 20px;
    border-right: 1px solid #707070;
    width: 19%;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
}
@media (min-width: 896px) {
    .headMenu_in ul li.c-sp {
        display: none;
    }
}
.headMenu_in ul li a {
    font-size: 14px;
    text-decoration: none;
    font-weight: bold;
    color: #434343;
    width: 100%;
    text-align: center;
    line-height: 1.3;
}
.hMenu_sub {
    display: none;
}
.hMenu_sub.on {
    display: block;
    position: absolute;
    top: 140px;
    background: rgba(255,255,255,0.9);
    width: 100%;
    left: 0;
    padding: 0 0 20px;
}
.hMenu_subWrap {
    display: flex;
    flex-wrap: wrap;
    width: 1200px;
    margin: -20px auto 0;
}
.hMenu_subIn {
    margin-top: 20px;
    margin-right: 10px;
    width: 24%;
    background: #fff;
    border-radius: 5px;
    border:  solid 2px #c3012f;
}
.hMenu_subIn.n4 {
    margin-right: 0;
}
.hMenu_subIn.ver2 {
    width: 49.2%;
}
.hMenu_subIn.ver3 {
    width: 32.4%;
}
.hMenu_subIn:last-of-type {
    margin-right: 0;
}
.hMenu_subIn a {
    display: block;
    padding: 50px 0 10px;
    font-size: 16px !important;
}
.hMenu_subIn.n5 a,
.hMenu_subIn.n6 a {
    padding: 25px 0;
}

.hMenu_subIn.n1 a {
    background: url(../svg/icn_img07.svg) no-repeat center top 17px / 35px auto;
}
.hMenu_subIn.n2 a {
    background: url(../svg/icn_img08.svg) no-repeat center top 12px / 35px auto;
}
.hMenu_subIn.n3 a {
    background: url(../svg/icn_img04.svg) no-repeat center top 15px / 40px auto;
}
.hMenu_subIn.n4 a {
    background: url(../svg/icn_img09.svg) no-repeat center top 15px / 35px auto;
}
.hMenu_subIn.n5 a {
    background: url(../svg/icn_img17.svg) no-repeat left 190px center / 30px auto;
    padding-left: 20px;
}
.hMenu_subIn.n6 a {
    background: url(../svg/icn_img12.svg) no-repeat left 150px center / 48px auto;
    padding-left: 25px;
}
.hMenu_subIn.n7 a {
    background: url(../svg/icn_img04.svg) no-repeat center top 15px / 40px auto;
}
.hMenu_subIn.n8 a {
    background: url(../svg/icn_img18.svg) no-repeat top 8px center / 25px auto;
}
.hMenu_subIn.n9 a {
    background: url(../svg/icn_img16.svg) no-repeat top 8px center / 35px auto;
}
.hMenu_subIn.n10 a {
    background: url(../svg/icn_img11.svg) no-repeat top 10px center / 35px auto;
}
.hMenu_subIn.n11 a {
    background: url(../svg/icn_img02.svg) no-repeat top 10px center / 35px auto;
}
.hMenu_subIn.n12 a {
    background: url(../svg/icn_img12.svg) no-repeat center top 10px / 42px auto;
}
@media (min-width: 896px) {
    .headMenu_in ul li.rt {
        width: 13%;
    }
    .headMenu_in ul li a:hover {
        color: #c3012f;
    }
}
/********************************
FOOTER
*********************************/
footer {
    background: #f0f1f5;
}
.footer_wrap {
    padding: 50px 0;
    width: 1125px;
    margin: 0 auto;
}
.footer_in {
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.fDtl_wrap {
    width: 310px;
    border-top: 1px solid #001f6b;
}
.fDtl_wrap dl {
    padding: 28px 0 0;
}
.fDtl_wrap dt {
    line-height: 1;
    text-align: left;
    margin: 0 0 20px;
}
.fDtl_wrap dt a {
    pointer-events: none;
    line-height: 1;
    font-weight: 600;
    color: #001f6b;
}
.fDtl_wrap dt a span {
    position: relative;
    padding: 0 0 0 30px;
}
.fDtl_wrap dt a span:before {
    content: "";
    width: 18px;
    height: 18px;
    position: absolute;
    top: 50%;
    margin-top: -9px;
    left: 0;
    background: url(../img/arw3_right_blu.png) no-repeat 0 0;
}
.fDtl_lst li {
    line-height: 1;
    text-align: left;
    margin: 0 0 14px;
}
.fDtl_lst li:last-child {
    margin: 0;
}
.fDtl_lst li a {
    line-height: 1;
}
.fDtl_lst li a span {
    position: relative;
    padding: 0 0 0 30px;
}
.fDtl_lst li a span:before {
    content: "";
    width: 8px;
    height: 10px;
    position: absolute;
    top: 50%;
    margin-top: -5px;
    left: 5px;
    background: url(../svg/dec_arw_foot.svg) no-repeat 0 0;
    background-size: 100% auto;
    -ms-background-size: 100% auto;
    -moz-background-size: 100% auto;
    -webkit-background-size: 100% auto;
}
.footer_copy {
    background: #fff;
    line-height: 1;
    padding: 19px 0;
}
.footer_copy small {
    text-align: center;
    font-size: 12px;
    line-height: 1;
    font-weight: 400;
}
.footEx-txt {
    font-size: 14px;
    text-align: left;
    padding: 60px 0 0 0;
}
footer.is-gray {
    background: #434343;
}
footer.is-gray .footer_copy {
    border-top: 2px solid #fff;
    background: #434343;
    padding: 16px 0;
}
footer.is-gray .footer_copy small {
    color: #fff;
}
.ftLink_warp {
    width: 1020px;
    margin: 0 auto;
    padding: 60px 0 50px;
}
.ftLink_in {
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: -40px 0 0;
}
.ftLink_box {
    width: 33.3%;
    text-align: left;
    margin: 40px 0 0;
}
.ftLink_ttl {
    color: #fff;
    font-size: 18px;
    line-height: 1;
    font-weight: bold;
    margin: 0 0 20px;
}
.ftLink_flx {
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.ftLink_flx .ftLink_lst {
    width: 50%;
}
.ftLink_lst li {
    line-height: 1;
    margin: 0 0 15px;
}
.ftLink_lst li:last-child {
    margin: 0;
}
.ftLink_lst li a {
    color: #fff;
    font-size: 14px;
    line-height: 1;
}
/********************************
C系CSS
*********************************/
.c-pc {
    display: block;
}
.c-pc-in {
    display: inline;
}
.c-sp {
    display: none;
}
.c-sp-in {
    display: none;
}
.c-wrap {
    padding: 40px 0 100px;
}
.c-bg {
    background: #f7f7f7;
}
.c-box {
    width: 1020px;
    margin: 0 auto;
}
.c-box.is-ver2 {
    padding: 50px 0 0 0;
}
.c-box.is-ver3 {
    padding: 50px 0 0 0;
}
.c-breadcrumbs {
    padding: 20px 0 0;
}
.c-breadcrumbs ul {
    width: 1020px;
    margin: 0 auto;
    line-height: 1.2;
}
.c-breadcrumbs li {
    display: inline;
    font-size: 12px;
    line-height: 1;
    padding: 0 20px 0 10px;
    position: relative;
}
.c-breadcrumbs li:first-child {
    padding: 0 20px 0 0;
}
.c-breadcrumbs li:before {
    content: '>';
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
.c-breadcrumbs li:last-child:before {
    content: none;
}
.c-ttl_wrap {
    background: #f7f7f7;
    padding: 105px 0;
}
.c-ttl_wrap.is-ver2 {
    padding: 53px 0;
}
.c-ttl-ttl {
    font-size: 30px;
    font-weight: 600;
    text-align: center;
    color: #434343;
}
@media (min-width: 896px) {
    .c-btn {
        background: #ffffff;
    }
    .c-btn.is-line {
        background: transparent;
    }
    .c-btn a:hover {
        opacity: 0.6;
    }
}
.c-btn a {
    display: table;
    table-layout: fixed;
    letter-spacing: -.4em;
    width: 100%;
    height: 50px;
    box-sizing: border-box;
    -ms-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    font-size: 16px;
    line-height: 1;
    font-weight: bold;
    color: #fff;
    background: #c3012f;
    text-decoration: none;
    position: relative;
}
.c-btn.is-ver2 a {
    background: #434343;
}
.c-btn.is-verL a {
    background: #06C755;
}
.c-btn.is-line a {
    background: #06C755;
    max-width: 50%;
    margin: 20px auto;
}
.c-btn a .is-btn {
    display: table-cell;
    letter-spacing: normal;
    vertical-align: middle;
    text-align: center;
}
/*2024/10/10_TNIS井上 contact/index.html でも使いたかったので下記.is-verR の２つを contact2024.css からこちらに移動*/
.is-btn.is-verR {
  background: #FFF;
  color: #c3012f;
  border: 2px solid #c3012f; 
}
.icn-arw.is-verR:before {
    right: 15px;
    width: 6px;
    height: 8px;
    background: url(../svg/dec_arw_r_03.svg) no-repeat 0 0;
    background-size: 100% auto;
    -ms-background-size: 100% auto;
    -moz-background-size: 100% auto;
    -webkit-background-size: 100% auto;
}
.icn {
    display: inline-block;
    position: relative;
}
.icn:before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.icn-arw {
    width: 100%;
}
.icn-arw:before {
    right: 15px;
    width: 6px;
    height: 8px;
    background: url(../svg/dec_arw_r_01.svg) no-repeat 0 0;
    background-size: 100% auto;
    -ms-background-size: 100% auto;
    -moz-background-size: 100% auto;
    -webkit-background-size: 100% auto;
}
.icn-arwR {
    padding: 0 0 0 1.5em;
}
.icn-arwR:before {
    left: 4px;
    width: 8px;
    height: 12px;
    background: url(../svg/dec_arw_r_03.svg) no-repeat center;
    background-size: 100% auto;
    -ms-background-size: 100% auto;
    -moz-background-size: 100% auto;
    -webkit-background-size: 100% auto;
}
.icn-come {
    padding: 0 0 0 1.5em;
}
.icn-come:before {
    content: '※';
    left: 0;
    top: 0;
    transform: none;
}
.icn-point {
    padding: 0 0 0 1.5em;
}
.icn-point:before {
    content: '・';
    left: 0;
    top: 0;
    transform: none;
}
.icn-come.is-ver2 {
    padding: 0 0.5em 0 0;
}
.icn-come.is-ver2:before {
    left: auto;
    right: 0;
    top: 0;
    font-size: 50%;
}
.icn-maru {
    padding: 0 0 0 1.6em;
}
.icn-maru:before {
    content: '';
    width: 20px;
    height: 20px;
    border-radius: 50%;
    -ms-border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    background: #999;
    left: 0;
    top: 5px;
    transform: none;
}
.icn-maru.is-ver2:before {
    background: #c3012f;
}
.line-come {
    display: inline-block;
    position: relative;
    padding: 0 0 0 2em;
}
.icn-nmb {
    position: absolute;
    top: 0;
    left: 0;
}
.acdTab_wrap {
    margin: 20px auto 75px auto;
}
.c-ankTab_wrap ul {
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit--flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.c-ankTab_wrap ul li {
    width: 33.333333%;
    margin: 25px 0 0 0;
    border-left: 1px solid #adadad;
    box-sizing: border-box;
}
.c-ankTab_wrap.is-ver2 ul li {
    width: 25%;
}
/*2023.1.9_TNIS井上_グロナビ５つ⇒６つにするため width: 20%;⇒width: 16.6%;に修正、以下child(5)⇒(6)も対応*/
.c-ankTab_wrap.is-ver3 ul li {
    width: 16.6%;
}
@media (min-width: 896px) {
    .c-ankTab_wrap ul li:nth-child(1) ,
    .c-ankTab_wrap ul li:nth-child(2) ,
    .c-ankTab_wrap ul li:nth-child(3) {
        margin: 0 0 0 0;
    }
    .c-ankTab_wrap.is-ver2 ul li:nth-child(4) {
        margin: 0 0 0 0;
    }
    .c-ankTab_wrap.is-ver3 ul li:nth-child(4) ,
    .c-ankTab_wrap.is-ver3 ul li:nth-child(5) ,
    .c-ankTab_wrap.is-ver3 ul li:nth-child(6) {
        margin: 0 0 0 0;
    }
    .c-ankTab_wrap ul li:nth-child(3n) {
        border-right: 1px solid #adadad;
    }
    .c-ankTab_wrap.is-ver2 ul li:nth-child(3n) {
        border-right: 0;
    }
    .c-ankTab_wrap.is-ver2 ul li:nth-child(4n) {
        border-right: 1px solid #adadad;
    }
    .c-ankTab_wrap.is-ver3 ul li:nth-child(3n) {
        border-right: 0;
    }
    .c-ankTab_wrap.is-ver3 ul li:nth-child(6n) {
        border-right: 1px solid #adadad;
    }
}
.c-ankTab_wrap ul li a {
    text-decoration: none;
    font-size: 18px;
    display: table;
    width: 100%;
    height: 40px;
    color: #434343;
}
.c-ankTab_wrap.is-ver3 ul li a {
    font-size: 15px;
    height: 66px;
    letter-spacing: -0.07em;
    line-height: 1.5;
}
.c-ankTab_wrap ul li.active a {
    color: #c3012f;
}
@media (min-width: 896px) {
    .c-ankTab_wrap ul li a:hover {
        color: #c3012f;
    }
}
.c-ankTab_wrap ul li a span {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}
/********************************
CONTETS
*********************************/
#Contents {
    background: #fff;
    text-align: left;
}
/*pagetop*/
.pagetop {
    position: fixed;
    right: 30px;
    bottom: 100px;
    width: 50px;
    height: 52px;
    z-index: 999;
}
.pagetop.is-ver2 {
    bottom: 190px;
}
.pagetop a {
    display: block;
}
@media (min-width: 896px) {
    .pagetop a:hover {
        opacity: 0.7;
    }
}
.pagetop span {
    width: 100%;
    height: 0;
    display: block;
    overflow: hidden;
    padding: 52px 0 0 0;
    background: url(../svg/pagetop.svg) no-repeat 0 0;
    background-size: 100% auto;
    -ms-background-size: 100% auto;
    -moz-background-size: 100% auto;
    -webkit-background-size: 100% auto;
}
.slick-js .is-ptn {
    position: relative;
}
.bnr_btn02 {
    position: absolute;
    width: 592px;
    height: 43px;
    margin: 0 53px 0 445px;
    bottom: 62px;
    left: 0;
    z-index: 9;
    overflow: hidden;
}
.bnr_btn02 a {
    display: inline-block;
    height: 100%;
    width: 267px;
}
.bnr_btn03 {
    position: absolute;
    width: 420px;
    height: 161px;
    margin: 0 11px 0 703px;
    bottom: 17px;
    left: 0;
    z-index: 9;
    overflow: hidden;
}
.bnr_btn03 a {
    display: block;
    height: 47%;
    width: 100%;
}
.bnr_btn04 {
    position: absolute;
    width: 96.2%;
    height: 28.8%;
    margin: 10% 2% 3% 3.5%;
    bottom: 4px;
    left: 0;
    z-index: 9;
    overflow: hidden;
}
.bnr_btn04 a {
    display: inline-block;
    height: 100%;
    width: 46%;
}
@media (min-width: 897px) {
    .bnr_btn02 a.right {
        float: right;
    }
    .bnr_btn03 a.right {
        margin: 4% 0 0 0;
    }
    .bnr_btn04 a.right {
        margin: 0 0 0 4%;
    }
}
.mv-imgs {
    text-align: center;
}
.c-stx {
    font-size: 12px;
}
/********************************
サイト内検索
*********************************/
.search-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.search-icon {
    display: inline-block;
    width: 38px;
    height: 38px;
    background: url(../svg/icn_search.svg) no-repeat center;
    background-size: 38px;
    padding: 0;
    cursor: pointer;
}
.search-container {
    visibility: hidden;
    position: absolute;
    right: 74px;
    top: 0;
    width: 396px;
    transform: translateX(15px);
    opacity: 0;
    transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out, visibility 0.3s;
    z-index: 9;
}
#search-toggle {
    display: none;
}
#search-toggle:checked ~ .search-icon {
    background: none;
    position: relative;
}
#search-toggle:checked ~ .search-icon::before,
#search-toggle:checked ~ .search-icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 2px;
    background-color: #434343;
    transform-origin: center;
}
#search-toggle:checked ~ .search-icon::before {
    transform: translate(-50%, -50%) rotate(45deg);
}
#search-toggle:checked ~ .search-icon::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}
#search-toggle:checked ~ .search-container {
    visibility: visible;
    transform: translateX(0);
    opacity: 1;
}
/* MARSロゴ非表示 */
.mf-search-results_mars-logo .mf-search-results_mars-logo_link img {
    display: none;
}
/* !importantで上書き */
.mf-search-box .mf-search-bar .mf-search-bar_input {
    height: 38px !important;
    background-color: #f7f7f7 !important;
    border-radius: 0px !important;
    border: 1px solid #adadad !important;
}
/********************************
お問い合わせガイド
*********************************/
.ct-wrap {
    padding: 50px 0 30px;
    margin: 60px 0 30px;
    background: #8b98b9 url(../img/car_bg01.jpg) no-repeat;
    background-size: contain;
}
.ct-nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.8em;
}
.ct-box {
    padding: 1.8em;
    border: 1px solid #adadad;
    background: #FFF;
}
.ct-ttl {
    font-size: 28px;
    font-weight: bold;
}
.ct-txt {
    font-size: 18px;
}
.ct-mb {
    margin-bottom: 50px;
}
@media only screen and (max-width: 896px) {
    body {
        font-size: 12px;
        min-width: 320px;
        width: 100%;
        padding: 50px 0 0;
    }
    /********************************
    mv
    *********************************/
    .mv_warp {
        width: 100%;
    }
    .mv_in {
        height: 242px;
    }
    .mv_ttl {
        vertical-align: top;
        font-size: 17px;
        line-height: 1.2;
        padding-top: 25px;
    }
    body.family .mv_warp {
        background:#f9faf4 url(../img/sp/mv_family.jpg) center center no-repeat;
        background-size: 375px auto;
        -ms-background-size: 375px auto;
        -moz-background-size: 375px auto;
        -webkit-background-size: 375px auto;
    }
    /********************************
    HEADER
    *********************************/
    header {
        background: #ffffff;
    }
    .header_wrap {
        width: 100%;
        padding: 0;
    }
    .head-logo {
        padding: 15px 0 0 10px;
    /*  padding: 17px 0 0 20px; サイト内検索設置に伴い変更_20250220 */
    }
    .head-tnis {
        float: none;
        text-align: center;
        margin: 19px 0 18px 0;
    }
    .head-btn {
        float: none;
        margin: 18px 35px 0 35px;
        width: auto;
    }
    .head-btn.is-rd {
        float: right;
        margin: 0;
        width: 80px;
    }
    .head-btn.is-rd a {
        background:#c3012f;
        height: 50px;
        font-size: 12px;
        line-height: 1.2;
    }
    .head_menu_box {
        display: flex;
        align-items: center;
        justify-content: flex-end;
    }
    .head-btn.is-shop {
        margin: 0 7px 0 0;
    }
    .head-btn.is-shop a {
        border: 0;
        height: auto;
        background: url(../svg/icn_img16.svg) no-repeat center top 2px / 21px auto;
        padding-top: 25px;
        font-size: 10px;
        font-weight: normal;
    }
    .head-btn a {
        display: table;
        width: 100%;
        height: 55px;
        background: #ffffff url(../img/sp/dec_arw.png) no-repeat right 15px center;
        background-size: 9px auto;
        text-align: center;
        font-size: 15px;
    }
    .headMenu_wrap {
        display: none;
        position: fixed;
        top: 50px;
        left: 0;
        z-index: 999;
        width: 100%;
        padding: 0 0 0 0;
        background: #ffffff;
        overflow-y: scroll;
        max-height: calc(100% - 50px);
        height: 100vh;
    }
    .hMenu_sub.on {
        position: relative;
        top:0;
        padding: 15px;
        box-sizing: border-box;
    }
    .hMenu_subWrap {
        width: 100%;
        margin-top: -30px;
    }
    .headMenu_in ul li {
        width: 100%;
    }
    .headMenu_in ul li.rf a {
        background: url(../svg/icn-plus-red.svg) no-repeat center right 15px / 20px auto;
    }
    .headMenu_in ul li.rf.on a {
        background: url(../svg/icn-minus-red.svg) no-repeat center right 15px / 20px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n1 a {
        background: url(../svg/icn_img07.svg) no-repeat center top 17px / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n2 a {
        background: url(../svg/icn_img08.svg) no-repeat center top 12px / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n3 a {
        background: url(../svg/icn_img04.svg) no-repeat center top 15px / 40px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n4 a {
        background: url(../svg/icn_img09.svg) no-repeat center top 15px / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n5 a {
        background: url(../svg/icn_img17.svg) no-repeat top 9px center / 25px auto;
        padding: 14px 8px;
    }
    .headMenu_in ul li .hMenu_subIn.n6 a {
        background: url(../svg/icn_img12.svg) no-repeat center top 9px / 35px auto;
        padding-left: 0;
    }
    .headMenu_in ul li .hMenu_subIn.n7 a {
        background: url(../svg/icn_img04.svg) no-repeat center top 15px / 40px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n8 a {
        background: url(../svg/icn_img18.svg) no-repeat top 9px center / 25px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n9 a {
        background: url(../svg/icn_img16.svg) no-repeat top 12px center / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n10 a {
        background: url(../svg/icn_img11.svg) no-repeat top 13px center / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n11 a {
        background: url(../svg/icn_img02.svg) no-repeat top 12px center / 35px auto;
    }
    .headMenu_in ul li .hMenu_subIn.n12 a {
        background: url(../svg/icn_img12.svg) no-repeat center top 15px / 35px auto;
    }
    .hMenu_subIn.n5 a, .hMenu_subIn.n6 a {
        padding: 14px 8px;
    }
    .menu_btn {
        display: block;
        width: 50px;
        height: 50px;
        cursor: pointer;
        background: url(../img/sp/btn_menu.png) no-repeat center center;
        background-size: 17px auto;
    }
    .menu_btn.is-on {
        background: url(../img/sp/btn_menu_close.png) no-repeat center center;
        background-size: 18px auto;
    }
    .headMenu_in ul {
        display:-webkit-block;
        display:-ms-block;
        display:block;
        border-left: 0;
        border-top: 1px solid #c3012f;
    }
    .headMenu_in ul li {
        font-weight: bold;
        padding: 0 0;
        border-right: 0;
        text-align: left;
        border-bottom: 1px solid #c3012f;
        height: auto;
        display: block;
    }
    .headMenu_in ul li a {
        display: block;
        font-size: 14px !important;
        padding: 14px 30px 14px 20px;
        background: url(../img/sp/dec_arw_red.png) no-repeat right 20px center;
        background-size: 8px auto;
        line-height: 1.3;
        box-sizing: border-box;
        text-align: left;
    }
    .hMenu_subIn {
        margin-top: 15px;
    }
    .headMenu_in ul li .hMenu_subIn a {
        padding: 55px 8px 10px;
        height: 80px;
        font-size: 12px !important;
        text-align: center;
    }
    .headMenu_in ul li .hMenu_subIn.line2 a {
        padding-top: 40px;
    }
    .hMenu_subIn,
    .hMenu_subIn.ver2,
    .hMenu_subIn.ver3 {
        width: 47.3%;
        margin-right: 2.6%;
    }
    .hMenu_subIn:nth-of-type(2n) {
        margin-right: 0;
    }
    /********************************
    FOOTER
    *********************************/
    .footer_wrap {
        padding: 0;
        width: 100%;
    }
    .footer_in {
        display:-webkit-block;
        display:-ms-block;
        display:block;
        border-bottom: 1px solid #838383;
    }
    .fDtl_wrap {
        width: 100%;
        border-top: 1px solid #001f6b;
    }
    .fDtl_wrap dl {
        padding: 0;
    }
    .fDtl_wrap dt {
        margin: 0;
        border-bottom: 1px solid #001f6b;
    }
    .fDtl_wrap dt a {
        display: block;
        pointer-events: none;
        padding: 15px 20px;
    }
    .fDtl_wrap dt a span {
        padding: 0 0 0 30px;
    }
    .fDtl_wrap dt a span:before {
        background: url(../img/arw3_right_blu.png) no-repeat 0 0;
    }
    .fDtl_lst li {
        margin: 0;
        border-top: 1px solid #838383;
    }
    .fDtl_lst li:first-child {
        border: none;
    }
    .fDtl_lst li a {
        display: block;
        padding: 15px 20px;
        text-decoration: none;
    }
    .fDtl_lst li a span {
        padding: 0 0 0 15px;
    }
    .fDtl_lst li a span:before {
        left: 0;
    }
    .footer_copy {
        padding: 14px 0;
    }
    .footer_copy small {
        font-size: 10px;
    }
    .footEx-txt {
        font-size: 12px;
        padding: 20px 20px 20px 20px;
    }
    footer.is-gray .footer_copy {
        padding: 16px 0;
    }
    .ftLink_warp {
        width: 100%;
        box-sizing: border-box;
        -ms-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        margin: 0 auto;
        padding: 25px 15px 30px;
    }
    .ftLink_in {
        display:-webkit-block;
        display:-ms-block;
        display:block;
        margin: 0;
    }
    .ftLink_box {
        width: 100%;
        box-sizing: border-box;
        -ms-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        padding: 0 0 20px;
        margin: 0 0 20px;
        border-bottom: 1px solid #fff;
    }
    .ftLink_box:last-child {
        padding: 0;
        margin: 0;
        border-bottom: none;
    }
    .ftLink_ttl {
        font-size: 14px;
        margin: 0 0 15px;
    }
    .ftLink_flx {
        display:-webkit-block;
        display:-ms-block;
        display:block;
    }
    .ftLink_flx .ftLink_lst {
        width: 100%;
    }
    .ftLink_lst {
        margin: 0 0 15px;
    }
    .ftLink_lst:last-child {
        margin: 0;
    }
    .ftLink_lst li {
        margin: 0 0 15px;
        padding: 0 0 0 0.5em;
    }
    .ftLink_lst li a {
        font-size: 12px;
    }
    /********************************
    C系CSS
    *********************************/
    .c-pc {
        display: none;
    }
    .c-pc-in {
        display: none;
    }
    .c-sp {
        display: block;
    }
    .c-sp-in {
        display: inline;
    }
    .c-wrap {
        padding: 10px 0 40px;
    }
    .c-wrap.is-verSP {
        padding: 10px 15px 40px;
    }
    .c-box {
        width: 100%;
        box-sizing: border-box;
        -ms-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        margin: 0;
    }
    .c-box.is-ver2 {
        padding: 25px 15px 0 15px;
    }
    .c-box.is-ver3 {
        padding: 25px 0 0 0;
    }
    .c-breadcrumbs {
        padding: 15px 15px;
        overflow-x: scroll;
        white-space: nowrap;
    }
    .c-breadcrumbs ul {
        width: 100%;
    }
    .c-ttl_wrap {
        padding: 40px 0;
    }
    .c-ttl_wrap.is-ver2 {
        padding: 27px 0;
    }
    .c-ttl-ttl {
        font-size: 20px;
    }
    .c-btn a {
        height: 55px;
        font-size: 15px;
    }
    .c-btn.is-line a {
        height: 55px;
        font-size: 15px;
        max-width: none;
        margin: 30px 0;
    }
    .icn-maru {
        padding: 0 0 0 1.4em;
    }
    .icn-maru:before {
        width: 15px;
        height: 15px;
        top: 2px;
    }
    .acdTab_wrap {
        margin: 25px auto 45px auto;
    }
    .c-ankTab_wrap ul {
        padding: 0 15px;
    }
    .c-ankTab_wrap ul li {
        width: 50%;
        margin: 15px 0 0 0;
    }
    .c-ankTab_wrap.is-ver2 ul li {
        width: 50%;
    }
    .c-ankTab_wrap.is-ver3 ul li {
        width: 50%;
    }
    .c-ankTab_wrap.is-ver3 ul li.is-wid100 {
        width: 100%;
    }
    .c-ankTab_wrap ul li:nth-child(1) ,
    .c-ankTab_wrap ul li:nth-child(2) {
        margin: 0 0 0 0;
    }
    .c-ankTab_wrap ul li:nth-child(2n) {
        border-right: 1px solid #adadad;
    }
    .c-ankTab_wrap.is-ver3 ul li:nth-child(6) {
        border-right: 1px solid #adadad;
    }
    .c-ankTab_wrap ul li a {
        font-size: 14px;
        font-weight: bold;
    }
    .c-ankTab_wrap.is-ver3 ul li a {
        font-size: 14px;
        height: 40px;
        line-height: 1.3;
    }
    .c-ankTab_wrap ul li.is-fss a {
        font-size: 12px;
    }
    .c-ankTab_wrap ul li a span {
        /*
        padding: 0 10px;
        */
    }
    /********************************
    CONTETS
    *********************************/
    /*pagetop*/
    .pagetop {
        right: 20px;
        bottom: 30px;
        width: 35px;
        height: 35px;
    }
    .pagetop.is-ver2 {
        bottom: 150px;
    }
    .pagetop span {
        padding: 36px 0 0 0;
    }
    .bnr_btn02 {
        width: 47.5%;
        height: 91.7%;
        margin: 0 3% 3% 49.5%;
        bottom: 0;
    }
    .bnr_btn02 a {
        height: 48%;
        width: 100%;
    }
    .bnr_btn02 a.right {
        margin: 2% 0 0 0;
    }
    .bnr_btn03 {
        width: 47.5%;
        height: 91.7%;
        margin: 0 3% 3% 49.5%;
        bottom: 0;
    }
    .bnr_btn03 a {
        height: 48%;
        width: 100%;
    }
    .bnr_btn03 a.right {
        margin: 2% 0 0 0;
    }
    .bnr_btn04 {
        width: 93.5%;
        height: 27.7%;
        margin: 10% 2% 3% 4%;
        bottom: 18px;
    }
    .bnr_btn04 a {
        height: 100%;
        width: 47%;
    }
    .bnr_btn04 a.right {
        margin: 0 0 0 3%;
    }
    .c-stx {
        font-size: 10px;
    }
    /********************************
    サイト内検索
    *********************************/
    .search-container {
        transform: translateY(-5px);
        position: fixed;
        right: 5%;
        left: 5%;
        top: 54px;
        width: 90%;
    }
    .search-container::before {
        content: "";
        position: absolute;
        top: -4px;
        right: -6%;
        width: 112%;
        height: 48px;
        background: #FFF;
        z-index: -1;
    }
    #search-toggle:checked ~ .search-container {
        transform: translateY(0);
    }
    /********************************
    お問い合わせガイド
    *********************************/
	.ct-wrap {
	    padding: 35px 15px 30px;
	    margin: 30px 0 15px;
        background: #8b98b9 url(../img/sp/car_bg01.jpg) no-repeat;
        background-size: contain;
	}
    .ct-nav {
        grid-template-columns: 1fr;
    }
    .ct-ttl {
        font-size: 17px;
    }
    .ct-txt {
        font-size: 14px;
    }
	.ct-mb {
	    margin-bottom: 35px !important;
	}
}
@media only screen and (max-width: 374px) {
    .headMenu_in ul li a {
        font-size: 12px !important;
        padding: 14px 20px 14px 10px;
    }
    .headMenu_in ul li .hMenu_subIn a {
        font-size: 10px !important;
    }
    .headMenu_in ul li .hMenu_subIn.line2 a {
        padding-top: 43px;
    }
}
