@charset "utf-8";
/* CSS Document */

html{
scroll-padding-top: 100px;
}
/* 会社案内 //--------------------------------------------------*/


.company{
}
.menu_sub{
width: 100%;
margin-bottom: 50px;
}
.menu_sub ul{
text-align: center;
display: flex;
justify-content: space-between;
}
.menu_sub li{
width:100%;
padding: 8px 25px;
font-weight: 600;
}
.menu_sub a {
padding:8px 10px;
display:block;
position:relative;
text-align:center;
border-bottom: 1px solid #cccccc;
padding-bottom: 20px;
}
.menu_sub a:before {
content:"";
display:block;
position:absolute;
left:100%;
right:100%;
bottom:0;
height:2px;
background-color:#000e56;
-webkit-transition:left 0.2s ease, right 0.2s ease;
-moz-transition:left 0.2s ease, right 0.2s ease;
-o-transition:left 0.2s ease, right 0.2s ease;
transition:left 0.2s ease, right 0.2s ease;
}
.menu_sub a:hover:before {
left:0;
right:0;
}

/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.menu_sub ul{
display: block;
}
.menu_sub li{
width:100%;
padding: 8px 25px;
font-weight: 600;
}
.menu_sub a {
padding:0px 10px;
display:block;
position:relative;
text-align:center;
border-bottom: 1px solid #cccccc;
padding-bottom: 15px;
}
}




.company{
width: 100%;
max-width: 1000px;
margin: 0 auto;
margin-bottom: 100px;
}
.company section h3{
font-size: 2em;
font-weight: bold;
line-height: 3;
}
/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.company section h3{
font-size: 1.6em;
font-weight: bold;
line-height: 3;
}
}



.company section p{
font-size: 1.4em;
font-weight: bold;
line-height: 1.5;
margin-bottom: 20px;
}

.massage{
line-height: 2;
}
.massage span{
width: 100%;
display: block;
text-align: right;
margin-top: 30px;
}

.company dl{
display: flex;
flex-wrap: wrap;
width: 100%;
}
.company dt{
font-weight: bold;
width: 20%;
padding: 20px;
border-bottom: 2px solid #000e56;
}
.company dd{
width: 80%;
padding: 20px;
border-bottom: 1px solid #000e56;
line-height: 1.4;
}


/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.company dl{
display: block;
flex-wrap: wrap;
width: 100%;
}
.company dt{
width: 100%;
padding: 15px 0 10px 10px;
border-bottom: none;
}
.company dd{
width: 100%;
padding: 10px 0 15px 10px;
border-bottom: 1px solid #000e56;
line-height: 1.4;
}
}













.company section .access{
font-size: 12px;
font-weight: normal;
}

.maplink{
color: #FF6700;
}
 .g-map{
 width: 1000px;
 max-width: 100%;
 }

/* 取扱製品 //--------------------------------------------------*/



.product{
width: 100%;
max-width: 1200px;
margin: 0 auto;
margin-bottom: 100px;
}

.product ul{
display: flex;
flex-wrap:wrap;
justify-content: space-between;
} 

.product ul li{
margin-bottom: 30px;
}

.content_ttl_product h2{
background: #000e56;
text-align: center;
color: #fff;
font-size: 1.6em;
font-weight:600;
letter-spacing: 1px;
padding: 10px 0;
margin-bottom: 50px;
}

/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.product{
width: 100%;
max-width: 1200px;
margin: 0 auto;
margin-bottom: 50px;
}
.product ul{
display: block;
} 

.product ul li{
margin-bottom: 10px;
}

.content_ttl_product h2{
background: #000e56;
text-align: center;
color: #fff;
font-size: 1.1em;
font-weight:600;
letter-spacing: 1px;
padding: 10px 0;
margin-bottom: 50px;
}
}

/* ---------------------- 01  */
.product_1 .sec1 ul,
.product_2 .sec1 ul{
max-width: 1000px;
margin: 0 auto;
}
.product_1 .sec1 li,
.product_2 .sec1 li{
font-size: 1.5em;
font-weight: 600;
margin-bottom: 50px;
}
/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.product_1 .sec1 li,
.product_2 .sec1 li{
line-height: 1.5;
font-size: 1em;
text-indent: -1.2em;
padding-left: 1.2em;
margin-bottom: 20px;
}
}


.product_1 .sec2 ul,
.product_2 .sec2 ul{
max-width: 1000px;
margin: 0 auto;
text-align: center;

}

.product_1 .sec2 li,
.product_2 .sec2 li{
font-size: 1.2em;
font-weight: 600;
margin-bottom: 50px;
}

.product_1 .sec2 li .img2,
.product_2 .sec2 li .img2{
width: 50%;
margin: 0 auto;
}
/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.product_1 .sec2 li .img2,
.product_2 .sec2 li .img2{
width: 100%;
margin: 0 auto;
}
}



.product_1 .sec3,
.product_2 .sec3{
text-align: center;
width: 100%;
margin: 0 auto;
margin-bottom: 50px;
}


/* ---------------------- 02  */

.product_2 section{
display: flex;
justify-content: space-around;
}

.product_1 section .flex-item,
.product_2 section .flex-item{
 width:489px;
 height:869px;
}


/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.product_2 section{
display: block;
}

.product_1 section .flex-item,
.product_2 section .flex-item{
width:100%;

}

}






/* ---------------------- 03  */


hr{
width: 1000px;
margin: 0 auto;
margin-bottom: 50px;
height: 1px;
}

.modal-close{
font-size: 2.5em;
color: #999999;
}

.product_3_top-img{
margin-bottom: 50px;
}
.product_3 .sec1 section{
gap: 40px;
max-width: 1000px;
margin: 0 auto;
margin-bottom: 50px;
}
.product_3 .sec1 li:nth-child(1){
color: #fff;
background: #000e56;
font-size: 1.2em;
font-weight: 600;
line-height: 1.4;
padding: 10px 20px;
}
.product_3 .sec1 li:nth-child(2){
color: #000;
font-size: 1.2em;
font-weight: 600;
line-height: 1.4;
padding: 10px 20px;
}

.product_3 .sec1 li:nth-child(3),
.product_3 .sec1 li:nth-child(4){
text-align: center;
}
.product_3 .sec1 li img{
width: 40%;
margin: 20px;
}

.product_3 .sec1 li:nth-child(4){
color: #003282;
font-size: 1.2em;
font-weight: 600;
border: 1px solid #003282;
letter-spacing: 5px;
}

.product_3 .sec1 li:nth-child(4) a:hover{
background: #003282;
color: #fff;
}


.product_3 .sec2 section{
display: flex;
justify-content: space-between;
gap: 40px;
max-width: 1000px;
margin: 0 auto;
margin-bottom: 50px;
}



.product_3 .sec1 li:nth-child(2),
.product_3 .sec1 li:nth-child(3),
.product_3 .sec2 li:nth-child(2),
.product_3 .sec2 li:nth-child(3){
border-left:1px solid #999999;
border-right:1px solid #999999;
}

/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/

.product_3 .sec2 section{
display: block;
justify-content: space-between;
gap: 40px;
max-width: 1000px;
margin: 0 auto;
margin-bottom: 50px;
}

.item{
margin-bottom: 50px;
}
}





.product_3 .sec2 li{
width: 100%;
max-width: 480px;
}
.product_3 .sec2 li:nth-child(1){
color: #fff;
background: #000e56;
font-size: 1.2em;
font-weight: 600;
line-height: 1.4;
padding: 10px 20px;
}
.product_3 .sec2 li:nth-child(2){
color: #000;
font-size: 1em;
font-weight: 600;
line-height: 1.4;
padding: 10px 20px;
}

.product_3 .sec2 li:nth-child(3),
.product_3 .sec2 li:nth-child(4){
text-align: center;
}
.product_3 .sec2 li img{
width: 60%;
margin: 20px;
}

.product_3 .sec2 li:nth-child(4){
color: #003282;
font-size: 1.2em;
font-weight: 600;
border: 1px solid #003282;
letter-spacing: 5px;
}

.product_3 .sec2 li:nth-child(4) a:hover{
background: #ccc;
color: #003282;
}

.arrow{
    /* ボタンのCSS */
    color: #000e56;
    display: block;
    padding: 15px;
    position: relative; /* position: relative;で矢印の位置を基点とさせます */
    text-align: center;
    text-decoration: none;
    width: 100%;
}

.arrow::after{
    /* 擬似要素で矢印アイコンをつくる */
    content: '';
    border: 0;
    border-top: solid 2px #000e56;
    border-right: solid 2px #000e56;
    display: inline-block;
    width: 10px;
    height: 10px;
    /* 矢印アイコンの位置を設定 */
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg); /* rotate(45deg)で矢印を回転（向きを変更）させる */
}
















/* 取扱関連企業 //--------------------------------------------------*/

.maker{
width: 100%;
max-width: 1000px;
margin: 0 auto;
margin-bottom: 100px;
}
.maker dl{
display: flex;
flex-wrap: wrap;
width: 100%;
}
.maker dt{
width: 0%;
padding: 20px;
border-bottom: 2px solid #000e56;
}
.maker dd{
width: 100%;
padding: 20px;
border-bottom: 1px solid #000e56;
line-height: 1.4;
}
.maker section .access{
font-size: 12px;
font-weight: normal;
}






/* 取扱関連企業 //--------------------------------------------------*/

.privacy {
width: 800px;
max-width: 100%;
margin: 0 auto;
}

.privacy h3{
font-size: 1.1em;
font-weight: bold;
margin: 10px 0;
}

.privacy,
.contact p{
line-height: 2;
margin-bottom: 50px;
}


.privacy li{
margin: 20px 0;
line-height: 1.5;
text-indent: -1.5em;
padding-left: 1.5em;
}

.contact {
width: 1000px;
max-width: 100%;
margin: 0 auto;
}
.contact a{
color: #E07810;
}

.contact_ml250{margin-left: 240px;}
/*--------------------------------------*/
@media screen and (max-width: 768px) {
/*--------------------------------------*/
.contact_ml250{margin-left: 0px;}
}


.masse{
text-align: center;
font-size: 1.2em;
margin: 200px 0 150px;


}