@charset "utf-8";
@import url("root.css");
/***************************************
------------- TOP MAIN IMG -------------
***************************************/

#mv {
width: 100%;
margin:0 auto 20px;
background: var(--sub-color01);
overflow: hidden;
}

#mv .top_box{
  display: flex;
  justify-content: space-between;
  max-width: 1200px;
  padding:30px 0 60px 0;
  margin:0 auto;
}

#mv p{
  font-size: 18px;
  line-height: 1.8;
}

#mv img{
max-width:100%;
width: auto;
}

#mv .reverse{flex-direction: row-reverse;}

/*右側へ要素を広げる（2カラム）*/
#mv .column-outside-right{
    flex: 1;
    margin-right: calc(50% - 50vw);
    margin-left: 6%;
	background: url(../img/top_bg.png) top left no-repeat ;
	min-height: 504px;
}

#mv .column{
  width:360px;
  padding:20px 0;
}

#mv .column h2{
font-size:27px;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.2;
}

#mv .column p{
text-align:left;
width: 100%;
padding:20px 0;
}

#mv .column_box{
background-color: var(--base-color03);
border-radius: 8px;
text-align: center;
}

#mv .column_box p{
text-align: center;
}


#mv .column_box i{
color: var(--base-color01);
padding: 0 5px 0 0;
}

#mv .column_box p{padding:15px 0;}
#mv .link_a{padding:20px 0;}


@media screen and (max-width: 768px) {
#mv {
width: 100%;
margin:0 auto 0;
background: var(--sub-color01);
overflow: hidden;
}

#mv .top_box{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width:100%;
  padding:70px 0 20px 0;
  margin: auto;
}

#mv p{
  font-size: 18px;
  line-height: 1.8;
}

#mv img{
max-width:100%;
width: auto;
border-radius: 10px;
}

#mv .reverse{flex-direction:column;}

/*右側へ要素を広げる（2カラム）*/
#mv .column-outside-right{
    flex: 1;
    margin-right:0;
    margin-left: 6%;
	background: url() top left no-repeat ;
	min-height:auto;
}

#mv .column{
  width:90%;
  padding:20px 0 0 0;
  margin: 0 auto;
}

#mv .column h2{
font-size:30px;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.2;
text-align: center;
}

#mv .column p{
text-align:left;
width: 100%;
padding:10px 0;
}

#mv .column_box{
background-color: var(--base-color03);
border-radius: 8px;
text-align: center;
}

#mv .column_box i{
color: var(--base-color01);
padding: 0 5px 0 0;
}

#mv .column_box p{padding:10px 0;text-align: center;}
#mv .link_a{padding:20px 0;}


}


/***************************************
------------- about ------------
***************************************/

#about{}
#about .box {padding: 90px 0 50px 0;}

#about h2{
font-size:30px;
text-align: left;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.4;
margin: 0 auto 20px;
}
#about .col img{
display: block;
margin-left: auto;
}


#about dl {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
width: 100%;
border-top: 1px solid var(--base-color01);
margin: 40px auto 80px;
}


#about dt {
width: 25%;
color: var(--base-color01);
border-bottom: 1px solid var(--base-color03);
border-right: 1px solid var(--base-color03);
padding:15px 10px;
font-weight:700;
text-align: center;
background-color: var(--base-color01);
color: var(--base-color03);
display: flex;
align-items: center;
justify-content: center;
}

#about dt:nth-child(5) {
border-bottom: 1px solid var(--base-color01);

}

#about dd {
width: 75%;
background-color: var(--base-color03);
border-bottom: 1px solid var(--base-color01);
border-right: 1px solid var(--base-color01);
padding:20px 20px;
text-align:left;
}

@media screen and (max-width: 768px) {
#about{}
#about .box {padding: 40px 0 0 0;}

#about h2{
font-size:28px;
margin: 0 auto 20px;
}
#about .col img{
display: block;
margin-left: auto;
}
.child01{order: 1;}
.child02{order: 2;}

#about dl {
margin: 20px auto 40px;
border-left: 1px solid var(--base-color01);
}

#about dt {
width: 100%;
padding:10px 10px;
border-bottom: 0 solid var(--base-color03);
border-right: 0 solid var(--base-color03);
}

#about dt:nth-child(5) {
border-bottom: 1px solid var(--base-color01);

}

#about dd {
width: 100%;
background-color: var(--base-color03);
border-bottom: 1px solid var(--base-color01);
border-right: 1px solid var(--base-color01);
padding:10px 10px;
text-align:left;
}



}
/***************************************
-------------- service --------------
***************************************/
#service {

padding: 0;
}

#service .box{
margin: 0 auto;
width: 1200px;
border-radius: 20px;
padding: 50px 0 30px 0;
}

#service h2 {
    font-size: 38px;
    text-align:center;
    font-weight: 500;
    font-family: ten-mincho, serif;
    line-height: 1.4;
    margin: 0 auto 20px;
	border-bottom: 4px solid var(--base-color01);
	padding: 0 0 10px 0;
}
#service span {
font-size: 16px;
padding: 0 0 0 20px;
}

#service dl {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
width: 1200px;
margin:50px auto;
}


#service dt {
width: 30%;
padding:15px 10px;
font-weight:700;
text-align: center;
margin: 0 auto 20px;
}

#service dt img {
    box-shadow: 5px 5px 5px 0px rgba(127, 127, 127, 0.3);
}


#service dd {
width: 70%;
padding:15px 10px 15px 40px;
text-align:left;
margin: 0 auto 20px;
}



#service h3{
color: var(--base-color01);
font-size: 20px;
font-weight: 700;
padding: 0 0 5px 0;
margin: 0 auto 10px;
}

#service p{
padding: 0 0 20px 0;
}



#service .box_01{
  display: grid;
  grid-template-columns: 50% auto; /* 左側50%、右側を可変 */
  width: 100%;
  position: relative;
  margin:0 auto 50px;
}

#service .box_01_wrapper {
  grid-column: 1 / -1; /* グリッド全体にまたがる */

}


#service .left-wrapper {
display: flex;
justify-content: flex-end;
height: 630px;
padding-right: 0;
}

#service .left-box {
width: 520px;
height: 630px;
background: var(--sub-color01);
border-radius: 20px 0 0 20px;
box-shadow: 5px 5px 5px 0px rgba(127, 127, 127, 0.3);
}

#service .right-box {
box-shadow: 5px 5px 5px 0px rgba(127, 127, 127, 0.3);
background: var(--sub-color01);
height: 630px;
}


#service .box_01_in{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 1200px;
}

#service .box_01_in h2{
font-size:38px;
text-align: left;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.4;
margin: 40px auto 0;
}


@media screen and (max-width: 768px) {
#service {
background-color: var(--sub-color01);
padding: 20px 0 0 0;
}

#service .box{
margin: 0 auto;
width: 100%;
border-radius: 20px;
padding:20px;
}

#service h2 {
    font-size: 24px;
    text-align:left;
    font-weight: 500;
    font-family: ten-mincho, serif;
    line-height: 1.4;
    margin: 0 auto 20px;
	border-bottom: 4px solid var(--base-color01);
	padding: 0 0 10px 0;
	
}
#service span {
font-size: 14px;
padding: 0 0 0 20px;
}

#service dl {
    width: 90%;
    margin: 0 auto;
	flex-wrap: wrap;
}


#service dt {width: 100%;padding: 10px 0;}
#service dd {width: 100%;padding: 0 0;}



#service h3{
color: var(--base-color01);
font-size: 20px;
font-weight: 700;
padding: 0 0 5px 0;
margin: 0 auto 10px;
}

#service p{
padding: 0 0 20px 0;
}

#service .box_01{
  display: grid;
  grid-template-columns: auto; /* 左側50%、右側を可変 */
  width: 100%;
  position:static;
  margin:0 auto 20px;
}

#service .box_01_wrapper {
  grid-column: 1; /* グリッド全体にまたがる */
}


#service .left-wrapper {
display: flex;
justify-content: flex-end;
height:auto;
padding-right: 0;
flex-wrap: wrap;
}

#service .left-box {
width:100%;
height:auto;
background: var(--sub-color01);
border-radius: 20px 0 0 20px;
box-shadow: 5px 5px 5px 0px rgba(127, 127, 127, 0.3);
}

#service .right-box {
box-shadow: 5px 5px 5px 0px rgba(127, 127, 127, 0.3);
background: var(--sub-color01);
height:auto;
}


#service .box_01_in{
  position:static;
  left: 100%;
  transform: translateX(0);
  width:100%;
}

#service .box_01_in h2{
font-size:38px;
text-align: left;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.4;
margin: 40px auto 0;
}

}



/***************************************
---------------- news ----------------
***************************************/
#news{
margin:100px auto;
width: 1200px;
background-color: var(--sub-color02);
border-radius: 20px;
padding: 50px;
}

#news .title{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#news h2{
font-size: 38px;
text-align: left;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.4;
margin: 0 auto 0;
width: 50%;
}

#news .link_a{
width: 50%;
display: flex;
justify-content: flex-end;
}
#news .link_a a {
width: 230px;
margin: 0 0 0 auto;
}

.tab01 {
  width: 100%;
  margin: 0 auto 50px;
}

.tab_container {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  margin: 30px auto 0;
}

/*タブ切り替えの中身のスタイル*/
.tab_contents {
  width: 100%;
  margin: 50px auto 0;
}

.tab_contents dl{
display: flex;
flex-wrap: wrap;
border-bottom: 2px dotted var(--base-color02);
margin: 0 auto 10px;
}

.tab_contents dt{
width: 120px;
font-family: ten-mincho, serif;
padding: 0 0 0 0;
line-height: 2;
text-align: center;
}
.tab_contents dd{
padding:0;
}
.tab_contents .w_cate{
width: 100px;
background-color: var(--base-color01);
color: var(--base-color03);
padding: 5px 10px;
line-height: 1.4;
text-align: center;
font-size: 14px;
margin:0 auto 10px;
display: flex;
align-items: center;
justify-content: center;
}

.tab_contents .w_txt{
width:880px;
padding: 0 0 10px 10px;
line-height: 1.8;
}

.w_txt a:hover {color:  var(--base-color01)}


/*選択されているタブを表示*/
#menu01:checked ~ #menu01,
#menu02:checked ~ #menu02,
#menu03:checked ~ #menu03,
#menu04:checked ~ #menu04,
#menu05:checked ~ #menu05,
#menu06:checked ~ #menu06,
#menu07:checked ~ #menu07,
#menu08:checked ~ #menu08 {
  display: block;
}
/*選択されているタブのスタイル*/
.tab01 input:checked + .tab_menu {
  background-color: var(--base-color01);
  color: #fff;
  border: 1px solid var(--base-color01);
}

@media screen and (max-width: 768px) {
#news{
margin:40px auto;
width:90%;
background-color: var(--sub-color02);
border-radius: 20px;
padding: 20px;
}

#news .title{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
}
#news h2{
font-size:24px;
text-align: left;
font-weight: 500;
font-family: ten-mincho, serif;
line-height: 1.4;
margin: 0 auto 0;
width: 50%;
}

#news .link_a{
width:50%;
display: flex;
justify-content: flex-end;
}
#news .link_a a {
width:80%;
margin: 0 0 0 auto;
font-size: 14px;
}

.tab01 {
  width: 100%;
  margin: 0 auto 50px;
}

.tab_container {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  margin: 30px auto 0;
}
/*タブのスタイル*/
.tab_menu {
flex-grow: 1;  /* 文字の幅に応じて伸縮 */
flex-basis: auto; /* 基本サイズは文字サイズに応じる */
padding: 5px 5px; /* 上下と左右の余白を適用 */
text-align: center;
color:var(--base-color02);
border: 0.5px solid var(--base-color02);
background-color: var(--base-color03);
font-weight:400;
transition: all 0.2s ease;
font-family: ten-mincho, serif;
font-size: 14px;
margin: 0 0 5px 0;
line-height: 1.4;
width: 100%;
}

.tab_menu:nth-child(16){
margin:0 0 5px 0;
}

.tab_menu:hover {
  opacity: 0.75;
}
/*ラジオボタンを全て消す*/
input[name="tab_menu"] {
  display: none;
}
/*タブ切り替えの中身のスタイル*/
.tab_contents {
  padding: 0;
  clear: both;
  transition: .5s opacity;
  width: 100%;
  margin: 20px auto 0;
}


.tab_contents dl{
display: flex;
flex-wrap: wrap;
border-bottom: 2px dotted var(--base-color02);
margin: 0 auto 10px;
}

.tab_contents dt{
width: 70%;
padding: 0 0 0 0;
line-height: 2;
text-align: right;
}
.tab_contents dd{
padding:0;
}


.tab_contents .w_cate{
width:30%;
padding: 5px 10px;
line-height: 1.4;
text-align: center;
font-size: 14px;
margin:0 0 5px auto;
display: flex;
align-items: center;
justify-content: center;
}

.tab_contents .w_txt{
width:100%;
padding: 0 0 10px 0;
line-height: 1.6;
}

}

/***************************************
-------------- products --------------
***************************************/
#products{
}

#products .box{
width: 1200px;
padding: 0 0 80px 0;
}

#products .row{
justify-content: flex-start;
align-items: stretch;
}

#products .col03{
width: 100%;
margin:0 0 0 0;

}

#products .col03:nth-child(4n){margin:0 0 0 0;}

#products .products_box_01{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size: 24px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_01.png) top left no-repeat var(--base-color03);

}

#products .products_box_02{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size: 20px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_02.png) top left no-repeat var(--base-color03);
}

#products .products_box_03{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size: 20px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_03.png) top left no-repeat var(--base-color03);
}

#products .products_box_04{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size: 20px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_04.png) top left no-repeat var(--base-color03);
}

#products .products_box_05{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size: 20px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_05.png) top left no-repeat var(--base-color03);
}


@media screen and (max-width: 768px) {
#products{
}

#products .box{
width: 100%;
padding: 0 0 40px 0;
}

#products .row{
justify-content: flex-start;
align-items: stretch;
}

#products .col03{
width: 90%;
margin:0 auto;}

#products .col03:nth-child(4n){margin:0 auto;}

#products .products_box_01{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 45%;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size:18px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_01.png) top left no-repeat var(--base-color03);
}

#products .products_box_02{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size:18px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_02.png) top left no-repeat var(--base-color03);
}

#products .products_box_03{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size:18px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_03.png) top left no-repeat var(--base-color03);
}

#products .products_box_04{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size:18px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_04.png) top left no-repeat var(--base-color03);
}

#products .products_box_05{
border-radius: 10px;
box-shadow: 0px 0px 15px -5px rgba(127, 127, 127, 0.7);
padding: 0 0 0 150px;
width: 100%;
height: 100px;
display: flex;
justify-content: center;
align-items:center;
font-size:18px;
font-weight: 700;
color: var(--base-color01);
margin: 0 auto 20px;
line-height: 1.4;
background: url(../img/products_box_05.png) top left no-repeat var(--base-color03);
}
}

/***************************************
-------------- Information --------------
***************************************/
#information {
    margin:0 auto 80px;
    width: 1200px;
    background-color: var(--sub-color02);
    border-radius: 20px;
    padding: 50px;
}

#information h2 {
    font-size: 38px;
    text-align: center;
    font-weight: 500;
    font-family: ten-mincho, serif;
    line-height: 1.4;
    margin: 0 auto 0;
}
#information .row {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin: 20px auto 0;
}

#information .col {
width: 48%;
margin: 0 4% 0 0;
}

#information .col:nth-child(2n) {margin: 0 0 0 0;}

#information .col_box{
width: 100%;
margin: 0 auto 20px;
background-color: var(--base-color03);
border-radius: 10px;
padding:20px;
color: var(--base-color01);
font-size: 28px;
display: flex;
justify-content:center;
align-items: center;
font-weight: 700;
}

#information .col_box img{
padding: 0 20px 0 0;
}
@media screen and (max-width: 768px) {
#information {
    margin:0 auto 40px;
    width:90%;
    background-color: var(--sub-color02);
    border-radius: 10px;
    padding: 20px;
}

#information h2 {
    font-size:24px;
    text-align: center;
    font-weight: 500;
    font-family: ten-mincho, serif;
    line-height: 1.4;
    margin: 0 auto 0;
}
#information .row {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin: 20px auto 0;
}

#information .col {
width: 100%;
margin:0 auto 20px;
}

#information .col:nth-child(2n) {margin:0 auto 20px;}

#information .col_box{
width: 100%;
margin: 0 auto;
background-color: var(--base-color03);
border-radius: 10px;
padding:10px 10px;
color: var(--base-color01);
font-size: 18px;
display: flex;
justify-content:center;
align-items: center;
font-weight: 700;
}

#information .col_box img{
padding: 0 20px 0 0;
}
}

