@charset "UTF-8";






/*index*/
.index .mainimg {
    width: 100%;
    height: 100vh;
}
.index .mainimg .pic img {
    object-position: top;
}
.index .mainimg h2 {
    width: 100%;/*38%*/
    font-size: 8rem;
    bottom: 22rem;
}
.index .mainimg .cath_01{
    bottom: 32rem;
}
.index .mainimg p {
    font-size: 4rem;
    font-weight: bold;
    color: #fff;
    line-height: 1.7;
    position: absolute;
    bottom: 13rem;
    left: 13.02vw;
    z-index: 3;
}
.index_cnt1 {
    padding: 15rem 0;
    background: url(/system_panel/uploads/images/index_cnt1_bg.jpg);
}
.index_cnt1 .inner {
    max-width: 120rem;
}
.index_cnt1 .inner h3 {
    font-size: 4.7rem;
    margin: 0 0 5rem;
}
.index_cnt1 .inner .col2 {
    display: flex;
    flex-direction: row-reverse;
    gap: 3.125vw;
    /*6*/
}
.index_cnt1 .inner .col2 .left {
    width: 40%;
}
.index_cnt1 .inner .col2 .left img {
    width: 100%;
}
.index_cnt1 .inner .col2 .right {
    width: 60%;
}
.index_cnt1 .inner .col2 .right p:not(.buttonA) {
    margin: 0 0 9rem;
}
.index_cnt1 .inner .col2 .right .buttonA:last-of-type {
    margin: 1.5rem 0 0;
}
.index_cnt2 {
    background: url(/system_panel/uploads/images/index_cnt2_bg.jpg) no-repeat;
    background-size: cover;
    padding: 15rem 0;
}
.index_cnt2 .inner {
    max-width: 120rem;
}
.index_cnt2 .inner .titleA * {
    text-align: left;
    color: #fff;
}
.index_cnt2 .inner .flex {
    display: flex;
    justify-content: space-between;
}
.index_cnt2 .inner .flex .figure {
    width: 25%;
    max-width: 25rem;
    position: relative;
    z-index: 2;
}
.index_cnt2 .inner .flex .figure::before {
    content: "";
    width: 5rem;
    height: 5rem;
    background: linear-gradient(-45deg, #001837 50%, #082140 50%);
    border-radius: 0.5rem;
    display: grid;
    align-items: center;
    text-align: center;
    font-size: 2.7rem;
    color: #fff;
    position: absolute;
    top: -2.5rem;
    left: 1rem;
    z-index: 3;
}
.index_cnt2 .inner .flex .figure:nth-of-type(1)::before {
    content: "01";
}
.index_cnt2 .inner .flex .figure:nth-of-type(2)::before {
    content: "02";
}
.index_cnt2 .inner .flex .figure:nth-of-type(3)::before {
    content: "03";
}
.index_cnt2 .inner .flex .figure:nth-of-type(4)::before {
    content: "04";
}
.index_cnt2 .inner .flex .figure:nth-of-type(1) {
    margin: 5rem 0 -5rem;
}
.index_cnt2 .inner .flex .figure:nth-of-type(3) {
    margin: -9rem 0 9rem;
}
.index_cnt2 .inner .flex .figure:nth-of-type(4) {
    margin: -4.5rem 0 4.5rem;
}
.index_cnt2 .inner .flex .figure .pic {
    width: 100%;
    aspect-ratio: 2.5/4.5;
    overflow: hidden;
    border-radius: 0.5rem;
    box-shadow: 1rem 1rem #1a2c41;
}
.index_cnt2 .inner .flex .figure .pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.index_cnt2 .inner .flex .figure .pic_str2 img {
    object-position: left;
}
.index_cnt2 .inner .flex .figure .figcaption {
    font-size: 1.9rem;
    font-weight: bold;
    background: #fff;
    border-radius: 0.5rem;
    position: absolute;
    left: -1rem;
    bottom: 2.5rem;
    padding: 1rem 2rem;
    z-index: 2;
}
.index_cnt2 .inner .flex .figure .figcaption p {
    line-height: 1.5;
}
.index_cnt2 .inner .buttonB {
    margin: 0 0 0 auto;
}
.index_cnt3 {
    padding: 13rem 0 8rem;
}
.index_cnt3 .inner .col2 {
    width: 100%;
    margin: auto;
    display: flex;
    gap: 2.6vw;
    margin: 0 auto 6rem;
}
.index_cnt3 .inner .col2 :is(.left, .right) {
    width: 50%;
    background: #f1f0f0;
    border-radius: 0.5rem;
    padding: clamp(2rem, 1.5625vw, 3rem) clamp(2rem, 2.34vw, 4.5rem) clamp(2rem, 2.34vw, 4.5rem);
    display: grid;
    grid-auto-rows: auto auto 1fr auto;
    align-content: start;
    gap: 3rem;
}
.index_cnt3 .inner .col2 :is(.left, .right) h4 {
    grid-row: 2/3;
    font-size: 2.7rem;
    text-align: center;
    line-height: 1.5;
}
.index_cnt3 .inner .col2 :is(.left, .right) .pic {
    width: fit-content;
    margin: 0 auto;
}
.index_cnt3 .inner .col2 :is(.left, .right) .buttonA {
    align-self: end;
}
.index_cnt3 .inner .window {
    width: 100%;
    margin: auto;
    /*background: url(/system_panel/uploads/images/index_cnt3_window_bg.png) no-repeat;*/
    background-size: cover;
    padding: clamp(2rem, 2.6vw, 3rem) clamp(2rem, 4.16vw, 8rem);
    /*5 8*/
    display: flex;
    justify-content: space-between;
    align-items: end;
  background-color: #003e8c;
}
.index_cnt3 .inner .window .titleA {
    margin: 0;
}
.index_cnt3 .inner .window .titleA * {
    color: #fff;
}
.index_cnt4 {
    padding: 8rem 0 15rem;
}
.index_cnt4 .inner .webgene-blog {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4.6875vw;
    /*9*/
    margin: 0 auto 8rem
}
.index_cnt4 .inner .webgene-blog .webgene-item .dl {
    display: grid;
    gap: 1rem;
}
.index_cnt4 .inner .webgene-blog .webgene-item .dt {
    grid-row: 3/4;
}
.index_cnt4 .inner .webgene-blog .webgene-item .dt a {
    color: inherit;
}
.index_cnt4 .inner .webgene-blog .webgene-item .day {
    color: #003e8c;
}
.index_cnt4 .inner .webgene-blog .webgene-item .day p {
    line-height: 1;
}
.index_cnt4 .inner .webgene-blog .webgene-item .pic {
    grid-row: 1/2;
    width: 100%;
    aspect-ratio: 3.4/2.8;
    overflow: hidden;
}
.index_cnt4 .inner .webgene-blog .webgene-item .pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.index_cnt4 .inner .buttonA {
    margin: auto;
}
.top_news_list .dd {
    width: calc(100% - 170px);
}
.top_news_list .dt {
    width: 170px;
}
.top_news_list .dl {
    display: flex;
    justify-content: space-between;
    border-top: 1px solid #003d88;
    padding: 20px 20px;
}
.top_news_list {
    overflow-y: auto;
    scrollbar-color: var(--blue_dark) var(--grey);
    max-height: 375px;
    margin-top: 70px;
    padding: 0 30px 30px 0;
}


/*strength*/

.strength .mainimg .pic img {
    object-position: top;
}
.strength_cnt1 {
    padding: 10rem 0 7.5rem;
}
.strength_cnt1 .inner .col2 {
    display: flex;
    gap: 4.6875vw;
    /*9*/
}
.strength_cnt1 .inner .col2:nth-of-type(odd) {
    flex-direction: row-reverse;
}
.strength_cnt1 .inner .col2:not(:last-of-type) {
    margin: 0 0 10rem;
}
.strength_cnt1 .inner .col2 .left {
    width: 50%;
}
.strength_cnt1 .inner .col2 .left h4 {
    font-size: 2.7rem;
    margin: 0 0 4rem;
}
.strength_cnt1 .inner .col2 .right {
    width: 50%;
    aspect-ratio: 4.5/3.1;
    overflow: hidden;
}
.strength_cnt1 .inner .col2 .right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.strength_cnt2 {
    padding: 7.5rem 0 3rem;
}
.strength_cnt2 .inner>p {
    text-align: center;
    margin: 0 auto 5rem;
}
.strength_cnt2 .inner .grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3.125vw;
    /*6*/
}
.strength_cnt2 .inner .grid .dl {
    width: 100%;
    padding: 2rem clamp(2rem, 2.08vw, 4rem);
    display: grid;
    gap: 1rem;
    justify-content: center;
    align-content: start;
    background: #f1f0f0;
    border-radius: 0.5rem;
}
.strength_cnt2 .inner .grid .dt {
    grid-row: 3/4;
    font-size: 2.7rem;
    text-align: center;
}
.strength_cnt2 .inner .grid .dt p {
    line-height: 1.75;
}
.strength_cnt2 .inner .grid .name {
    text-align: center;
}
.strength_cnt2 .inner .grid .pic {
    text-align: center;
}





/*career*/
.career .mainimg .pic img {
    object-position: top;
    width: 80%;
    margin: 0 0 0 20%;
}
.career_cnt1 {
    padding: 13rem 0;
}
.career_cnt1 .inner .col2 {
    display: flex;
    flex-direction: row-reverse;
    gap: 4.16vw;
    /*8*/
}
.career_cnt1 .inner .col2 .left {
    width: 50%;
    aspect-ratio: 4.5/3.1;
    overflow: hidden;
}
.career_cnt1 .inner .col2 .left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.career_cnt1 .inner .col2 .right {
    width: 50%;
}
.career_cnt2 {
    background: #f1f0f0;
    padding: 10rem 0;
}
.career_cnt2 .inner .col2 {
    display: flex;
    flex-direction: row-reverse;
    gap: 4.16vw;
    /*8*/
}
.career_cnt2 .inner .col2 .left {
    width: 48%;
}
.career_cnt2 .inner .col2 .left img {
    width: 100%;
}
.career_cnt2 .inner .col2 .right {
    width: 62%;
}
.career_cnt3 {
    padding: 15rem 0;
}
.career_cnt3 .inner>p {
    margin: 0 auto 3rem;
}
.career_cnt3 .inner .window {
    background: #f1f0f0;
    padding: clamp(2rem, 1.5625vw, 3rem) clamp(2rem, 2.08vw, 4rem);
    margin: 0 auto 7rem;
}
.career_cnt3 .inner .window h4 {
    font-size: 1.7rem;
    color: #003e8c;
    margin: 0 0 3rem;
}
.career_cnt3 .inner .col2 {
    display: flex;
    flex-direction: row-reverse;
    gap: 3.64vw;
    /*7*/
}
.career_cnt3 .inner .col2:nth-of-type(even) {
    flex-direction: initial;
}
.career_cnt3 .inner .col2:not(:last-of-type) {
    margin: 0 auto 5rem;
}
.career_cnt3 .inner .col2 .left {
    width: 50%;
    background: #f1f0f0;
    padding: 1rem;
}
.career_cnt3 .inner .col2 .left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.career_cnt3 .inner .col2 .right {
    width: 50%;
}
.career_cnt3 .inner .col2 .right .dt {
    font-weight: bold;
    margin: 0 0 3rem;
}
.career_cnt3 .inner .col2 .right .li {
    font-weight: bold;
    list-style: inside;
}
.career_cnt3 .inner .col2 .right .li p::before {
    content: "●";
}







/*flow*/
.flow .mainimg .pic img {
    object-position: top;
}
.flow_cnt1 {
    padding: 9rem 0;
}
.flow_cnt1 .inner .flex {
    display: flex;
    justify-content: center;
    gap: 2rem;
}
.flow_cnt2 {
    background: #f1f0f0;
    /*padding: 2rem 0;*/
  padding: 15rem 0 4rem;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl {
    position: relative;
    padding: 0 0 5rem 8rem;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl::before {
    content: "";
    width: 0.1rem;
    height: 100%;
    background: #fff;
    display: block;
    position: absolute;
    left: 2.2rem;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl::after {
    content: "●";
    font-size: 4.4rem;
    color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    line-height: 1;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dt {
    font-size: 2.7rem;
    margin: 0 0 3rem;
    display: flex;
    align-items: center;
    gap: 2.5rem;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dt p {
    line-height: 1;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dt::before {
    content: "";
    background: url(/system_panel/uploads/images/step_bg.png) no-repeat;
    width: 14.8rem;
    height: 4.1rem;
    display: inline-grid;
    align-items: center;
    text-align: center;
    font-size: 2.3rem;
    color: #fff;
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(2) .dt::before {
    content: "STEP1";
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(3) .dt::before {
    content: "STEP2";
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(4) .dt::before {
    content: "STEP3";
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(5) .dt::before {
    content: "STEP4";
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(6) .dt::before {
    content: "STEP5";
}
:is(.flow_cnt2, .flow_cnt3) .inner .dl:nth-of-type(7) .dt::before {
    content: "STEP6";
}
.flow_cnt3 {
    padding: 15rem 0 4rem;
}
.flow_cnt3 .inner .dl::before {
    background: #f1f0f0;
}
.flow_cnt3 .inner .dl::after {
    color: #f1f0f0;
}
.flow_title h4 {
    font-size: 2.7rem;
    text-align: center;
}




/*products*/
.products .mainimg .pic img {
    object-position: top;
}
.products_cnt1 {
    padding: 9rem 0;
}
.products_cnt1 .inner>p {
    text-align: center;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set:not(:last-of-type) {
    margin: 0 0 10rem;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 {
    display: flex;
    gap: 3.64vw;
    /*7*/
    margin: 0 0 3rem;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .left {
    width: 46.5%;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .left img {
    width: 100%;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .right {
    width: 53.5%;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .right .dt {
    font-size: 2.7rem;
    line-height: 1.75;
    margin: 0 0 1rem;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .right .dt p {
    line-height: 1;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .right .sub {
    color: #003e8c;
    font-size: 1.7rem;
    margin: 0 0 2rem;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set .col2 .right .detail {
    border-bottom: 0.1rem solid #d6d6d6;
    padding: 0 0 2rem;
    margin: 0 0 2rem;
}
:is(.products_cnt2, .products_cnt3, .products_cnt4) .inner .set>p {
    background: #fff;
    padding: clamp(2rem, 1.5625vw, 3rem) clamp(2rem, 2.08vw, 4rem);
}
.products_cnt2 {
    padding: 10rem 0;
    background: #f1f0f0;
}
.products_cnt3 {
    padding: 10rem 0;
}
.products_cnt3 .inner .set>p {background: #f1f0f0;}
.products_cnt4 {
    padding: 10rem 0;
    background: #f1f0f0;
}
.products_cnt4 .inner {
    max-width: 120rem;
}
.products_cnt4 .inner .set {
    max-width: 100rem;
    margin: 0 auto 10rem !important;
}
.products_cnt4 .inner h4 {
    font-size: 2.7rem;
    margin: 0 0 2rem;
}
.products_cnt4 .inner .grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(2rem, 5.2vw, 10rem);
    align-content: start;
}
.products_cnt4 .inner .grid:not(:last-of-type) {
    margin: 0 0 8rem;
}
.products_cnt4 .inner .grid .figure {
    display: grid;
    align-content: start;
    gap: 1rem;
}
.products_cnt4 .inner .grid .figure .pic {
    width: 100%;
    border-radius: 0.5rem;
    overflow: hidden;
}
.products_cnt4 .inner .grid .figure .pic img {
    width: 100%;
}
.products_cnt4 .inner .grid .figure .figcaption {}



/*workshop*/

.workshop_cnt1 .window {
    background: url(/system_panel/uploads/images/philosophy_cnt1_windowbg.png) no-repeat;
    background-size: cover;
    padding: clamp(2rem, 2.6vw, 5rem) clamp(2rem, 4.16vw, 8rem);
}
.workshop_cnt1 {
    padding: 0 0 10rem 0;
}
.workshop_cnt1 .window h3 {
    font-size: 4rem;
    text-align: center;
    margin: 0 auto 5rem;
}
.workshop_cnt1 .window * {
    color: #fff;
}
.workshop_cnt1-2 {
    padding: 0rem 0 7.5rem;
    background: #f1f0f0;
}
.workshop_cnt2 {
    padding: 10rem 0 3rem;
}
.workshop_cnt2 .inner .grid {
    display: block;
}
.workshop_cnt3 {
    padding: 10rem 0;
}
.workshop_cnt3 .inner .col2 {
    display: flex;
    flex-direction: initial;
    gap: 3.64vw;
}
.workshop_cnt3 .inner .col2 .right,.workshop_cnt1-2 .inner .col2 .left {
    width: 50%;
}
.workshop_cnt3 .inner .col2 .left {
    width: 50%;
    background: #f1f0f0;
    padding: 1rem;
}
.workshop_cnt3 .inner .col2 .left img,.workshop_cnt1-2 .inner .col2 .right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.workshop_cnt1-2 .inner .col2 .right {
    width: 50%;
    aspect-ratio: 3.5 / 3.1;
    overflow: hidden;
}
.workshop_cnt1-2 .inner .col2:not(:last-of-type) {
    margin: 0 0 10rem;
}
.workshop_cnt1-2 .inner .col2 {
    display: flex;
    gap: 4.6875vw;
}
.workshop_cnt1-2 .inner .col2:nth-of-type(odd) {
    flex-direction: row-reverse;
}
/*philosophy*/
.philosophy .mainimg .pic img {
    object-position: top;
    width: 80%;
    margin: 0 0 0 20%;
}
.philosophy_cnt1 {
    padding: 10rem 0 8rem;
}
.philosophy_cnt1 .inner .window {
    background: url(/system_panel/uploads/images/philosophy_cnt1_windowbg.png) no-repeat;
    background-size: cover;
    padding: clamp(2rem, 2.6vw, 5rem) clamp(2rem, 4.16vw, 8rem);
}
.philosophy_cnt1 .inner .window * {
    color: #fff;
}
.philosophy_cnt1 .inner .window h3 {
    font-size: 4rem;
    text-align: center;
    margin: 0 auto 5rem;
}
.philosophy_cnt2 {
    padding: 8rem 0 14rem;
}
.philosophy_cnt2 .inner .col2 {
    display: flex;
    gap: 2.08vw;
    /*4*/
    margin: 0 auto 5rem;
}
.philosophy_cnt2 .inner .col2 .left {
    width: 45%;
    aspect-ratio: 4.3/3.1;
    overflow: hidden;
}
.philosophy_cnt2 .inner .col2 .left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.philosophy_cnt2 .inner .col2 .right {
    width: 55%;
}
.philosophy_cnt2 .inner .col2 .right p {}
.philosophy_cnt3 {
    padding: 12rem 0;
    background: #f1f0f0;
}
.philosophy_cnt3 .inner .col2 {
    display: flex;
    gap: 2.08vw;
    /*4*/
    margin: 0 auto 5rem;
}
.philosophy_cnt3 .inner .col2 .left {
    width: 45%;
    aspect-ratio: 4.3/3.1;
    overflow: hidden;
}
.philosophy_cnt3 .inner .col2 .left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.philosophy_cnt3 .inner .col2 .right {
    width: 55%;
}
.philosophy_cnt3 .inner .grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3.125vw;
    /*6*/
}
.philosophy_cnt3 .inner .grid .dl {
    align-self: stretch;
}
.philosophy_cnt3 .inner .grid .dt {
    width: 100%;
    background: #003e8c;
    padding: 1rem 2rem;
    font-size: 2.3rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
    border-radius: 0.5rem 0.5rem 0 0;
}
.philosophy_cnt3 .inner .grid .dt p {
    line-height: 1;
}
.philosophy_cnt3 .inner .grid .dd {
    padding: 2rem;
    background: #d2dae3;
    border-radius: 0 0 0.5rem 0.5rem;
    /*height: 100%;*/
}
.philosophy_cnt4 {
    padding: 2rem 0 0rem;
}
.philosophy_cnt4_1 {
    padding: 8rem 0 0;
}
.philosophy_cnt4 .inner .window {
    /*background: url(/system_panel/uploads/images/philosophy_cnt4_windowbg.png) no-repeat;*/
    background-size: cover;
    padding: clamp(2rem, 1vw, 5rem) clamp(2rem, 4.16vw, 8rem);
  background-color: #003e8c;
}
.philosophy_cnt4 .inner .window * {
    color: #fff;
}
.philosophy_cnt4 .inner .window .col2 {
    display: flex;
    align-items: end;
}
.philosophy_cnt4 .inner .window .col2 .left {
    width: 55%;/*50*/
}
.philosophy_cnt4 .inner .window .col2 .left .titleA {
    margin: 0;
}
.philosophy_cnt4 .inner .window .col2 .left .titleA * {
    text-align: left;
}
.philosophy_cnt4 .inner .window .col2 .left .titleA p {
    font-size: 4rem;
}
.philosophy_cnt4 .inner .window .col2 .right {
    width: 40%;/*50*/
}
.philosophy_cnt5 {
    padding: 12rem 0;/*20*/
}
.philosophy_cnt5 .inner .col2 {
    display: flex;
    gap: 2.08vw;
    /*4*/
    margin: 0 auto 5rem;
}
.philosophy_cnt5 .inner .col2 .left {
    width: 45%;
    aspect-ratio: 4.3/3.1;
    overflow: hidden;
}
.philosophy_cnt5 .inner .col2 .left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.philosophy_cnt5 .inner .col2 .right {
    width: 55%;
}
.philosophy_cnt5 .inner .col2 .right h4 {
    font-size: 2.3rem;
    margin: 0 0 3rem;
}








/*blog&blogdetail共通*/
:is(.blog, .blogdetail) .mainimg .pic img {
    object-position: top;
}
:is(.blog_cnt1, .blogdetail_cnt1) {
    padding: 9rem 0;
}
:is(.blog_cnt1, .blogdetail_cnt1) .inner {}
:is(.blog_cnt1, .blogdetail_cnt1) .inner .webgene-blog {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-around;
}
:is(.blog_cnt1, .blogdetail_cnt1) .inner .webgene-blog .webgene-item {}
:is(.blog_cnt1, .blogdetail_cnt1) .inner .webgene-blog .webgene-item .buttonB {
    min-width: 19rem;
    text-align: center;
}
:is(.blog_cnt1, .blogdetail_cnt1) .inner .webgene-blog .webgene-item a {}


/*blog*/
.blog_cnt2 {
    padding: 0 0 14rem;
}
.blog_cnt2 .inner .webgene-blog {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4.166vw;
    /*8rem*/
}
.blog_cnt2 .inner .webgene-blog .webgene-item {}
.blog_cnt2 .inner .webgene-blog .webgene-item .dl {
    display: grid;
    gap: 1rem;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .dt {
    grid-row: 3/4;
    grid-column: 1/2;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .dt a {
    color: inherit;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .pic {
    grid-row: 1/2;
    grid-column: 1/2;
    aspect-ratio: 2.8/2.1;
    width: 100%;
    border-radius: 0.5rem;
    overflow: hidden;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .day {
    grid-row: 2/3;
    grid-column: 1/2;
    width: fit-content;
    min-height: 2.3rem;
    display: grid;
    align-items: center;
    color: #003e8c;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .day p {
    line-height: 1;
}

.blog_cnt2 .inner .webgene-blog .webgene-item .cate {
    grid-row: 2/3;
    grid-column: 1/2;
    margin: 0 0 0 auto;
    width: fit-content;
    min-height: 2.3rem;
    background: #003e8c;
    padding: 0 1em;
    border-radius: 0.5rem;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    display: grid;
    align-items: center;
    color: #fff;
}
.blog_cnt2 .inner .webgene-blog .webgene-item .cate p {
    line-height: 1;
}

.webgene-pagination {
    grid-column: 1/4;
    /*display: flex;
    width: 100%;
    padding: 7rem 26.5%;
    align-content: center;
    justify-content: space-between;
    margin:auto;*/
}

.webgene-pagination ul {
    width: fit-content;
    display: flex;
    margin: 12rem auto 0;
}
.webgene-pagination ul li {
    font-size: 1.7rem;
}
.webgene-pagination :is(.prev, .next) {
    width: 3em;
    height: 3em;
    list-style: none;
}
.webgene-pagination .prev {
    margin: 0 5rem 0 0;
}
.webgene-pagination .next {
    margin: 0 0 0 5rem;
}
.webgene-pagination :is(.prev a, .next a) {
    display: grid;
    justify-content: center;
    align-content: center;
    width: inherit;
    height: inherit;
    color: inherit;
    text-decoration: none;
    font-size: 1.7rem;
    font-weight: 500;
}
.webgene-pagination ul .number {
    list-style: none;
    background: #d2dae3;
    border-radius: 50%;
    width: 3em;
    height: 3em;
    margin: 0 0.5em;
}
.webgene-pagination ul .number.selected {
    list-style: none;
    background: #003e8c;
    width: 3em;
    height: 3em;
    margin: 0 0.5em;
}
.webgene-pagination ul .number.selected a {
    color: #fff;
}
.webgene-pagination ul .number a {
    display: grid;
    justify-content: center;
    align-content: center;
    width: inherit;
    height: inherit;
    color: inherit;
    text-decoration: none;
    font-size: 1.7rem;
    font-weight: 500;
    color: #fff;
}





/*blogdetail*/
.blogdetail_cnt2 {
    padding: 0 0 15rem;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item {
    margin: 0 auto 6rem;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .dl {
    display: grid;
    gap: 2rem;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .dt {
    grid-row: 2/3;
    grid-column: 1/2;
    display: grid;
    align-items: center;
    font-size: 2.7rem;
    padding: 0 0 2rem;
    border-bottom: 0.1rem solid #454545;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .day {
    grid-row: 1/2;
    grid-column: 1/2;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .day p {
    line-height: 1;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .cate {
    grid-row: 1/2;
    grid-column: 1/2;
    margin: 0 0 0 10em;
    width: fit-content;
    min-height: 2.3rem;
    background: #003e8c;
    padding: 0 1em;
    border-radius: 0.5rem;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1;
    display: grid;
    align-items: center;
    color: #fff;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .cate p {
    line-height: 1;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .cmt {
    line-height: 3;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .pic {
    grid-column: 1/2;
    width: 100%;
    border-radius: 0.5rem;
    overflow: hidden;

}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .pic .slider {}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .pic .slick-img {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .pic .thumbnail-img {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    margin: 0.5rem;
}
.blogdetail_cnt2 .inner .webgene-blog .webgene-item .pic img {
    width: 100%;
    height: 100%;
    /*object-fit: cover;*/
    object-fit: cover;
    object-position: center;
}
.blogdetail_cnt2 .inner .buttonA {
    text-align: center;
    margin: auto;
}





/*company*/
.company .mainimg .pic img {
    object-position: top;
}
.company_cnt1 {
    padding: 11rem 0 8rem;
}
.company_cnt1 .inner .titleA * {
    text-align: left;
}
.company_cnt2 {
    padding: 8rem 0 11rem;
}
.company_cnt2 .inner .dl {
    display: flex;
    width: 100%;
    min-height: 7rem;
    gap: 1rem;
}
.company_cnt2 .inner .dt {
    width: 20%;
    min-width: 6em;
    min-height: inherit;
    display: grid;
    align-items: center;
    padding: 1em;
    border-bottom: 0.1rem solid #003e8c;
}
.company_cnt2 .inner .dd {
    width: 80%;
    min-height: inherit;
    display: grid;
    align-items: center;
    padding: 1em;
    border-bottom: 0.1rem solid #d2dae3;
}
.company .map {
    width: 100%;
    height: 30rem;
}
.company .map iframe {
    width: 100%;
    height: inherit;
    border: none;
}




/*contact*/
.qa-8 dt {
    margin-bottom: 1em;
    color: #333333;
    font-weight: 600;
  display: flex;
    align-items: center;
}

.qa-8 dt::before,
.qa-8 dd::before {
    margin-right: .4em;
}

.qa-8 dt::before {
    content: "Q.";
}

.qa-8 dd {
    margin: 0 0 2.5em;
    padding: 1em 1.5em;
    background-color: #f1f0f0;
    color: #333333;
  display: flex;
    align-items: baseline;
}

.qa-8 dd::before {
    content: "A.";
}
.contact .mainimg .pic img {
    object-position: top;
}
.contact_cnt1 {
    padding: 9rem 0 8rem;
}
.contact_cnt1 .inner .window {
    width: 100%;
    background: #f1f0f0;
    padding: clamp(2rem, 2.08vw, 4rem);
}
.contact_cnt1 .inner .window .titleA {
    margin: 0 auto 3rem;
}
.contact_cnt1 .inner .window>p {
    font-size: 1.7rem;
    text-align: center;
}
.contact_cnt1 .inner .window .tel a {
    font-size: 2.9rem;
    color: inherit;
    line-height: 1;
}
.contact_cnt2 {
    padding: 8rem 0 15rem;
}
form .dl {
    display: flex;
    width: 100%;
    min-height: 7rem;
    gap: 1rem;
}
form .dl .dt {
    width: 20%;
    min-width: 14em;
    min-height: inherit;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 1em;
    border-bottom: 0.1rem solid #003e8c;
}
form .dt .required {
    width: fit-content;
    height: 2.3rem;
    background: #003e8c;
    border-radius: 0.5rem;
    padding: 0 0.5em;
    font-size: 1.4rem;
    color: #fff;
    display: grid;
    align-items: center;
    text-align: center;
    line-height: 1;
}
form .dl .dd {
    width: 80%;
    min-height: inherit;
    display: grid;
    align-items: center;
    padding: 0.5rem 0 0.5rem 1em;
    border-bottom: 0.1rem solid #d2dae3;
}
form input[type="text"],
form input[type="email"],
form textarea {
    width: 100%;
    height: 6rem;
    background: #f5f3f3;
    border: 0.1rem solid #0c0c0c;
}
form textarea {
    height: 18rem;
}
form input.zipInput {
    width: 40%;
}
form input[type="text"],
form input[type="email"],
form input[type="checkbox"],
form textarea {
    padding: 0 1em;
    border: 0.1rem solid #dedee4;
}
form select {}
form .dl .dd .checkArea {
    display: flex;
    gap: 1rem;
    align-items: center;
}
form .dl .dd .addArea {
    padding: 0.25rem 0;
}
form .dl .dd .selectArea {}
form .dl .dd .selectArea div {
    width: fit-content;
    display: inline-block;
}
form .terms {
    background: #f5f3f3;
    padding: clamp(2rem, 2.08vw, 4rem);
    height: 36rem;
    overflow-y: scroll;
    margin: 0.5rem 0 5rem 0;
}
form .terms p {
    line-height: 2.35;
}
form .col {

    width: 100% !important;
    display: flex;
    justify-content: center;
    margin: 0 auto 5rem;
}
form .col label {
    width: fit-content;
}
form .privacyLabel {
    width: 100%;
    text-align: center;
}
form button {
    -webkit-appearance: none;
    display: block;
    margin: auto;
}