﻿/*--- * ---*/
.under #content .red {
    color: #e7211a;
}
.under #footer {
    margin-top: 80px;
}
#town #footer {
    margin-top: 0px;
}
.under #content a {
    color: #000;
}
.under #content a:hover {
    text-decoration: none;
}
.under #content a.no_hover:hover {
    text-decoration: underline;
}
.under #content p.mb05 {
    margin-bottom: 5px;
}
.under #content p.mb10 {
    margin-bottom: 10px;
}
.under #content .image_l {
    float: left;
    margin: 0 60px 20px 0;
}
.under #content .image_r {
    float: right;
    margin: 0 0 20px 60px;
}
.under sup {
    vertical-align: super;
    font-size: smaller;
    font-size: 8px;
}
.under #content .txt_small {
    font-size: 12px;
}
.txt_sub {
    font-size: 65%;
    color: #000000 !important;
}
/*section*/
.under * {
    box-sizing: border-box;
}
.under a:hover {
    text-decoration: none;
}
.under #content p {
    line-height: 2.43em;
    margin-bottom: 2em;
}
.under #content p.em{
    margin-bottom: 1em;
}
.under #content p.narrow_em{
    margin-bottom: 0em;
}
.under #content p:last-child, .under #content table:last-child {
    margin-bottom: 0px;
}
body.under #content {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
}
.under #main .inner {
    width: 1080px;
}

.under .section {
    padding-bottom: 60px;
}
.under .section:last-child {
    padding-bottom: 0px;
}
.under #top_info {
    margin-bottom: 54px;
    background: linear-gradient(to right, rgba(231, 231, 231, 1) 0%, rgba(255, 255, 255, 1) 30%, rgba(231, 231, 231, 1) 100%);
    height: 150px;
    position: relative;
    box-sizing: border-box;
}
#sustainability #top_info {
    margin-bottom: 15px;
}
.under #topic_path {
    margin-bottom: 25px;
    color: #4d4d4d;
}
.under #topic_path li {
    display: inline-block;
    font-size: 13px;
    margin-right: 35px;
    position: relative;
}
.under #topic_path li:before {
    width: 4px;
    height: 4px;
    border-top: 1px #94c62a solid;
    border-right: 1px #94c62a solid;
    transform: rotate(45deg);
    position: absolute;
    content: "";
    right: -20px;
    top: 14px;
}
.under #topic_path li:last-child:before {
    display: none;
}
.under #topic_path a {
    text-decoration: none;
    color: #4d4d4d;
    display: inline-block;
}
.under #topic_path a:hover {
    text-decoration: underline !important;
    opacity: 0.7
}
.under h2, .under h3, .under h4, .under h5 {
    line-height: 1.6em;
    font-weight: 500;
}
.under #top_info .inner {
    height: 100%;
}
.under h2 {
    text-align: center;
    height: 100%;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.3;
}
.under h2 .h2_en {
    font-size: 24px;
    font-family: 'Noto Serif JP', serif;
    letter-spacing: 1px;
    display: none !important;
}
.under h2 .h2_jp {
    font-size: 36px;
    letter-spacing: 4px;
}
.under h2 .h2_jp, .under h3, .under h4, .under h5 {
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-weight: 500;
}
.under h3 {
    text-align: center;
    margin-bottom: 32px;
    font-size: 46px;
    position: relative;
    z-index: 1;
    padding-bottom: 13px;
}
.under h3:after {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background: #e7211a;
    height: 1px;
    width: 170px;
    content: '';
    display: block;
    margin: 0 auto;
}
.under h3 span {
    color: #e7211a;
}
.under h3 span.h3_lg {
    font-size: 140%;
}
.under h3 span.h3_lg01 {
    font-size: 120%;
}
.under h4 span {
    color: #e7211a;
}
.under h4 span.h4_lg {
    font-size: 140%;
}
.under h4 span.h4_lg01 {
    font-size: 120%;
}
.under h4 {
    font-size: 32px;
    padding-left: 20px;
    position: relative;
    margin-bottom: 12px;
}
.under h4:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 28px;
    background: #e7211a;
    left: 0;
    top: 10px;
}
.under h5 {
    font-size: 20px;
    color: #e5001e;
    margin-bottom: 17px;
}
.under .h5_l, .under .h5_r {
    width: 500px;
}
.under .h5_l {
    float: left;
}
.under .h5_r {
    float: right;
}
.under h6 {
    font-size: 18px;
    font-weight: bold;
    color: #4d4d4d;
    position: relative;
    padding-left: 20px;
    margin-bottom: 23px;
    line-height: 1.4;
}
.under h6:before {
    position: absolute;
    content: "";
    width: 10px;
    height: 4px;
    background: #e7211a;
    left: 0;
    top: 10px;
}
/*table*/
.under table {
    margin-bottom: 30px;
    border: #eaeaea 1px solid;
}
.under table.info_tbl {
    border: initial;
}
.under table.mb05 {
    margin-bottom: 5px;
}
.under table th, .under table td {
    padding: 15px;
    border: #dbdbdb 1px solid;
}
.under table.info_tbl th, .under table.info_tbl td {
    border: initial;
}
.under table th {
    background: #f7f7f7;
    color: #333333;
    line-height: 1.5;
    font-weight: 500;
}
.under table.td_top td {
    vertical-align: top;
}
.under table.td_center td {
    text-align: center;
}
.under table.tb_fixed {
    table-layout: fixed;
}
.under table.th_left th {
    text-align: left;
}
/*txt_note*/
.under #content .txt_note {
    display: none;
    font-size: 11px;
    color: #A3A3A3;
    margin-bottom: 5px;
}
.under #content .txt_bold {
    font-weight: bold;
}
.under #content .txt_bold_contact {
    font-weight: bold;
    color: #000;
}

.under .tbl_pt04 th {
    background: #e7211a;
    color: #fff;
}

.under .tbl_pt04 td {
    background: #f7f7f7;
}

/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/* LIST STYLE                                                             */
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.under #content .list01 {
    margin-bottom: 20px;
}
.under #content .list01 li {
    position: relative;
    margin-bottom: 19px;
    text-decoration: none;
    display: block;
    padding-left: 20px;
    line-height: 1.6em;
}
.under #content .list01 li:before {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    background: #e70020;
    border-radius: 50%;
    left: 0;
    top: 8px;
}
.under #content .list01:last-child, .under #content .list01 li:last-child {
    margin-bottom: 0px;
}
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/*                                                                    */
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.under #content .frame01 {
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(247, 247, 247, 0.95) 20px, rgba(247, 247, 247, 0.95) 100%);
    padding: 30px;
    border-top: 2px #ec4d48 solid;
    width: 100%;
    display: inline-block;
}
.under #content .btn01, .under #content .btn03 {
    display: flex;
    padding: 0 50px;
}
.under #content .btn01 li, .under #content .btn03 li {
    flex: 1;
    margin-right: 40px;
    height: 96px;
}
.under #content .btn03 {
    margin-bottom: 60px;
}
.under #content .btn03 li {
    height: 60px;
}
.under #content .btn03 li a {
    font-size: 18px;
}
.under #content .btn01 li a, .under #content .btn03 li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 1px #040000 solid;
    box-shadow: 2px 2px 4px 0px rgba(214, 214, 214, 0.3);
    background: #fff;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    color: #000000;
    line-height: 1.2;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s;
}
.under #content .btn04 {
    margin: 0 auto;
    text-align: center;
}
.under #content .btn04 li {
    float: left;
    width: 24%;
    margin: 5px;
    height: 60px;
}
.under #content .btn04 li a {
    font-size: 18px;
}
.under #content .btn04 li a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 1px #040000 solid;
    box-shadow: 2px 2px 4px 0px rgba(214, 214, 214, 0.3);
    background: #fff;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    color: #000000;
    line-height: 1.2;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s;
}
.under #content .btn01 li a {
    font-size: 24px;
    flex-direction: column;
}
.under #content .btn01 li i {
    position: absolute;
    top: calc(50% - 34px);
    left: 0;
}
/*.under #content .btn01 li i img {
  width: 80px;
}*/
.under #content .btn01 li a:before, .under #content .btn02 a:before, .under #content .btn03 li a:before {
    position: absolute;
    content: "";
    width: 10px;
    height: 10px;
    border-top: 1px #e5001e solid;
    border-right: 1px #e5001e solid;
    transform: rotate(135deg);
    right: 30px;
    top: calc(50% - 5px);
}
.under #content .btn02 a:before {
    right: 20px;
    top: calc(50% - 8px);
}
#demolition #content .btn02 a:before {
    right: 12px;
}
.under #content .btn01 li a span {
    font-size: 13px;
    font-family: 'Noto Serif JP', serif;
    font-weight: 100;
    letter-spacing: 1px;
    color: #4d4d4d;
}
.under #content .btn01 li:last-child {
    margin-right: 0px;
}
.under #content .btn02 a {
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    color: #000000;
    font-size: 18px;
    line-height: 1.2;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s;
    height: 50px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 1px #040000 solid;
    width: 280px;
    margin: 0 auto;
    text-decoration: none;
    padding-top: 2px;
}
.under #content .btn02_2 a {
    width: 350px;
}

.under #content .btn02_3 a::after {
    position: absolute;
    content: "";
    background: url(../images/youtube_logo.png) no-repeat left top/72px;
    background-size: 50px;
    width: 50px;
    height: 50px;
    left: 10px;
    top: 6px;
}

/*stranges*/
.under #content .box_stranges01 {
    display: flex;
}
.under #content .box_stranges01 .img {
    position: relative;
    margin-left: -275px;
    margin-bottom: 50px;
}
.under #content .box_stranges01 .img2 {
    margin-top: 180px;
}
.under #content .list01_stranges {
    display: inline-table;
    width: 820px;
    flex-shrink: 0;
    position: relative;
    margin-left: -245px;
    padding-top: 45px;
    counter-reset: section;
}
.under #content .list01_stranges.list01_stranges02 {
    padding-top: 45px;
}
.under #content .list01_stranges.list01_stranges03 {
    width: 700px;
    margin-left: 30px;
    padding-top: 27px;
}
.under #content .list01_stranges.list01_stranges03 li {
    margin-left: 0px !important;
    margin-bottom: 70px;
}
.under #content .list01_stranges li {
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-weight: 500;
    color: #000000;
    font-size: 24px;
    counter-increment: section;
    padding-left: 115px;
    position: relative;
    line-height: 1.625;
    margin-bottom: 47px;
    letter-spacing: -0.6px
}
.under #content .list01_stranges05 {
    width: 100%;
    counter-reset: item;
    background: #f2f2f2;
    padding: 40px 100px;
    margin-bottom: 100px;
    font-size: 120%;
}
.under #content .list01_stranges05 li {
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    padding-left: 50px;
    position: relative;
}
.under #content .list01_stranges05 li::before {
    counter-increment: item;
    content: counter(item)'.';
    position: absolute;
    top: 0;
    left: 20px;
}
.under #content .list01_stranges li:nth-child(2), .under #content .list01_stranges li:nth-child(3) {
    margin-left: 55px;
}
.under #content .list01_stranges li:nth-child(4) {
    margin-top: -13px;
}
.under #content .list01_stranges.list01_stranges04 li:nth-child(4) {
    letter-spacing: 0px;
}
.under #content .list01_stranges li:last-child {
    margin-bottom: 0px;
}
.under #content .list01_stranges li span {
    color: #e5001e;
}
.under #content .list01_stranges li span.list01_stranges_txt {
    font-size: 16px;
    color: #333333;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, sans-serif;
    display: block;
    line-height: 2.43;
}
.under #content .list01_stranges.list01_stranges02 li:nth-child(2), .under #content .list01_stranges.list01_stranges02 li:nth-child(4) {
    margin-left: 60px;
}
.under #content .list01_stranges li:before {
    content: counter(section);
    width: 91px;
    height: 91px;
    background-color: rgba(242, 242, 242, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: -27px;
    font-size: 58px;
    color: rgba(229, 0, 30, 0.25);
    font-family: 'Noto Serif JP', serif;
    box-sizing: border-box;
    padding-bottom: 10px;
}
.under #content .list01_stranges04 li:nth-child(1):before {
    top: -5px;
}
.under #content .list01_stranges04 li:nth-child(3):before {
    top: -11px;
}
.under #content .list01_stranges.list01_stranges02 li:before {
    top: -8px;
}
.under #content .box_stranges02 {
    background: url("../images/stranges_bg_01.jpg") no-repeat center top/cover;
    height: 210px;
    margin-bottom: 70px;
    position: relative;
}
.under #content #box_stranges02_01 {
    margin-top: 23px;
}
.under #content .box_stranges02 .img {
    margin-right: 50px;
}
.under #content .box_stranges02_list {
    display: flex;
    color: #fff;
    padding-top: 37px;
}
.under #content .box_stranges02_list h5 {
    color: #fff;
    font-size: 28px;
    margin-bottom: 0px;
    line-height: 1.5;
}
.under #content .box_stranges02_list_r {
    flex-direction: row-reverse;
}
.under #content .box_stranges02_list_r .img {
    margin: 3px 0 0 50px;
}
.under #content .box_stranges02_list_sub {
    flex-grow: 1;
}
.under #content .box_stranges02_list_sub > p {
    letter-spacing: -1.5px;
    line-height: 1.8;
}
.under #content .box_stranges02:before {
    left: -100%;
    position: absolute;
    content: "";
    width: 300px;
    height: 1px;
    background: #e7211a;
    top: 60px;
    transition: all 1.2s;
}
.under #content .box_stranges02.active:before {
    left: -110px;
}
.under #content .box_stranges02.box_stranges02_l:before {
    left: auto;
    right: -100%;
}
.under #content .box_stranges02.box_stranges02_l.active:before {
    right: -110px;
}
.under #content .box_stranges04 {
    display: flex;
    justify-content: space-between;
    background: #f2f2f2;
    padding: 40px 100px 40px 70px;
    margin-bottom: 100px;
}
.under #content .box_stranges04_2 {
    margin-bottom: 0px;
}
.under #content .box_stranges04 li + li {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.under #content .box_stranges04_txt {
    margin-bottom: 16px;
}
.under #content .stranges_tt01 {
    background: url("../images/icon_iso.png") no-repeat left top 12px/72px;
    padding-left: 100px;
    color: #e5001e;
    font-size: 20px;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-weight: 500;
    letter-spacing: 0.5px;
    padding-bottom: 36px;
    margin-bottom: 20px;
}
.under #content .box_stranges05 {
    display: flex;
}
.under #content .box_stranges05_2 {
    margin-bottom: 90px;
}
.under #content .box_stranges05 > li + li {
    width: 450px;
    flex-shrink: 0;
    border: 1px #e6e6e6 solid;
    padding: 45px;
    box-sizing: border-box;
    margin-left: 75px;
    margin-top: 7px;
}
.under #content .box_stranges05 > li + li > .list01 > li {
    font-size: 13px;
}
.under #content .box_stranges05 > li + li > .list01 > li:before {
    top: 6px;
}
.under #content .box_stranges05 > li:nth-child(1) > p:nth-child(1) {
    margin-bottom: 16px;
}
.under #content .stranges_txt01 {
    margin-bottom: 11px;
}
.under #content .stranges_img01 {
    margin-bottom: 26px !important;
}
.under #content p.index_btn01_under a {
    color: #000;
}
.under #content .bnr_list, .under #content .bnr_list02 {
    width: 800px;
    background: url("../images/bnr01.jpg") no-repeat center top/cover;
    position: relative;
    z-index: 1;
    padding: 20px 20px 10px 20px;
    margin: 0 auto 30px;
    color: #fff;
}
.under #content .bnr_list dt {
    text-align: center;
    margin-bottom: 20px;
    padding-top: 10px;
}
.under #content .bnr_list dd {
    width: 100%;
}
.under #content .bnr_list dd ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.under #content .bnr_list dd ul li {
    width: 31.5%;
    height: 50px;
    margin-bottom: 20px;
}
.under #content .bnr_list dd ul li a, .under #content .bnr_list02 dd a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-decoration: none;
    border: 1px #fff solid;
    transition: all 0.3s;
    box-sizing: border-box;
    padding-top: 4px;
    font-size: 15px;
}
.under #content .bnr_list dd ul li a {
    position: relative;
}
.under #content .bnr_list dd ul li a:before {
    position: absolute;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 10px;
    border-color: transparent transparent transparent #ec4d48;
    right: 10px;
    top: calc(50% - 5px);
}
.under #content .bnr_list02 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 20px;
}
.under #content .bnr_list02 dt {
    flex-grow: 1;
}
.under #content .bnr_list02 dt > span {
    font-size: 80%;
}
.under #content .bnr_list02 dd {
    padding-right: 20px;
}
.under #content .bnr_list02 dd a {
    height: 40px;
    padding: 5px 20px 3px;
    position: relative;
    transition: all 0.3s;
}
.under #content .bnr_list02 dd a + a {
    margin-top: 10px;
}
.under #content .bnr01 a {
    width: 800px;
    height: 100px;
    margin: 0 auto;
    position: relative;
    background: url("../images/bnr01.jpg") no-repeat center top/800px;
    display: flex;
    align-items: center;
    z-index: 1;
    color: #fff;
    text-decoration: none;
    transition: all 0.3s;
    box-sizing: border-box;
    padding-right: 20px;
}
.under #content .bnr01 a:before, .under #content .bnr_list:before, .under #content .bnr_list02:before {
    position: absolute;
    content: "";
    background-color: rgba(79, 94, 105, 0.9);
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    top: 5px;
    left: 5px;
    z-index: -1;
}
.under #content .bnr01 a > span:nth-child(1) {
    font-size: 20px;
    padding-left: 20px;
    display: flex;
    justify-content: center;
    flex-direction: column;
    box-sizing: border-box;
    flex-shrink: 0;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    padding-top: 3px;
    line-height: 1.25em;
    flex-grow: 1;
}
.under #content .bnr01.bnr01_sm a > span:nth-child(1) {
    font-size: 20px;
    line-height: 1.3;
}
.under #content .bnr01 a > span:nth-child(1) > span {
    display: block;
}
.under #content .bnr01 a > span:nth-child(2) {
    min-width: 220px;
    height: 46px;
    border: 1px #fff solid;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.5px;
    text-decoration: none;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-size: 14px;
    padding: 4px 15px 0 10px;
    flex-shrink: 0;
}
.under #content .bnr01 a > span:nth-child(2):before, .under #content .bnr_list02 dd a:before {
    position: absolute;
    content: "";
    background: url(../images/arr01.png) no-repeat right top;
    background-size: 38px auto;
    width: 38px;
    height: 8px;
    right: -20px;
    top: calc(50% - 7px);
    animation: slide1 1s ease-in-out infinite;
}

.under #content .bnr01.bnr01_sm.bnr01_history{
     display: block;   
}

/*sustainability*/
.under #content .sustainability_tt01 {
    text-align: center;
    font-size: 32px;
    color: #231815;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-weight: 500;
    margin-top: 75px;
}
.under #content .sustainability_box01, .under #content .sustainability_box03 {
    display: flex;
}
.under #content .sustainability_box03 {
    justify-content: center;
}
.under #content .sustainability_box03 > li {
    background: url("../images/rose_bg.png") no-repeat center top;
    width: 320px;
    height: 320px;
    margin: 0 20px;
    padding: 60px 40px 0;
    box-sizing: border-box;
}
.under #content .sustainability_box03 > li > h5 {
    text-align: center;
    margin-bottom: 0px;
}
.under #content .sustainability_box01 .img {
    margin-left: 100px;
}
.under .section02 h4 {
    margin-bottom: 10px;
}
.under #content .sustainability_box02 {
    display: flex;
    flex-wrap: wrap;
    width: 1176px;
    margin-top: 83px;
    margin-bottom: 85px;
}
.under #content .sustainability_box02 li {
    background: url("../images/sustainability_round.png") no-repeat center top/420px;
    width: 420px;
    height: 420px;
    padding: 0 70px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.under #content .sustainability_box02 li h5 {
    text-align: center;
    margin-bottom: 15px;
}
.under #content .sustainability_box02 li:nth-child(2) {
    margin-left: -53px;
    margin-top: 130px;
}
.under #content .sustainability_box02 li:nth-child(9) h5 {
    letter-spacing: -3px;
}
.under #content .sustainability_box02 li:nth-child(3) {
    margin-left: -46px;
}
.under #content .sustainability_box02 li:nth-child(4) {
    margin-top: 20px;
}
.under #content .sustainability_box02 li:nth-child(5) {
    margin-left: -50px;
    margin-top: 100px;
}
.under #content .sustainability_box02 li:nth-child(6) {
    margin-left: -52px;
    margin-top: 20px;
}
.under #content .sustainability_box02 li:nth-child(7) {
    margin-top: 83px;
}
.under #content .sustainability_box02 li:nth-child(8) {
    margin-top: 163px;
    margin-left: -52px;
}
.under #content .sustainability_box02 li:nth-child(9) {
    margin-left: -52px;
    margin-top: 166px;
}
.under #content .inner02 {
    width: 1180px;
}
.under #content .sustainability_txt {
    font-size: 15px;
    line-height: 2.13;
    display: inline-table;
}
.under #content .sustainability_icon {
    margin-bottom: 24px;
    margin-top: -30px;
}
.under #content .sustainability_box02 li:nth-child(2) .sustainability_icon {
    margin-top: -75px;
}
.under #content .sustainability_box02 li:nth-child(7) .sustainability_icon, .under #content .sustainability_box02 li:nth-child(8) .sustainability_icon {
    margin-top: -20px;
}
.under #content .sustainability_box02 li:nth-child(9) .sustainability_icon {
    margin-top: -100px;
}
/*map*/
.under .map_bg01 {
    background: url("../images/map.png") no-repeat center top/cover;
    height: 900px;
    position: relative;
    margin-top: 70px;
    margin-bottom: 40px;
    padding-bottom: 40px;
}
.under .map_notes {
	font-size: 14px;
	text-align: right;
	margin-bottom: 0 !important;
	margin-top: -20px;
}
.under .map_notes2 {
	margin-top: -10px;
}

/*.under .map {
  background: url("../images/map.png") no-repeat left -58px top 19px;
  width: 100%;
  height: 736px;
  position: relative;
  margin-top: -60px;
}
.map svg .map1 {
  transform: translate(0px, 0px);
}
.map svg .map2 {
  transform: translate(3px, 8px);
}
.map svg .map3 {
  transform: translate(0px, 18px);
}
.map svg .map4 {
  transform: translate(-2px, 23px);
}
.map svg .map5 {
  transform: translate(-12px, 38px);
}
.map svg .map6 {
  transform: translate(-11px, 28px);
}
.map svg .map7 {
  transform: translate(-23px, 33px);
}
.map .img_map04 {}
.map .img_map05 {}
.st0 {
  fill: none;
  stroke: #8C8C8C;
  stroke-width: 1.1927;
  stroke-miterlimit: 10;
}
.st1 {
  fill: none;
}
.st4 {
  font-size: 16px;
}
.st5 {
  fill: #E7211A;
}
*/
.map01 {
    width: 200px;
}
.under #content .en_tt {
    margin: 0 auto;
    font-size: 152px;
    font-family: 'Noto Serif JP', serif;
    text-align: center;
    position: relative;
    top: -64px;
    color: #dfe6f1;
    mix-blend-mode: multiply;
    margin-bottom: 0px;
    line-height: 0.58;
}
.under #content .map02 {
    background: url("../images/map_bg02.jpg") no-repeat center top/cover;
    height: 750px;
}
.under #content .map02 .inner {
    height: 100%;
}
.under #content .map02 ul {
    display: inline-block;
    height: 100%;
    position: relative;
    width: 100%;
}
.under #content .map02 ul li {
    background: linear-gradient(-45deg, transparent 0px, transparent 38px, rgba(255, 255, 255, 1) 38px, rgba(255, 255, 255, 1) 100%);
    width: 360px;
    /*height: 260px;*/
    border-top: 1px #e7211a solid;
    padding: 22px 23px 20px 37px;
    box-sizing: border-box;
    position: absolute;
}
.under #content .map02 ul li .btn02 a {
    width: 180px;
    padding-right: 30px;
    box-sizing: border-box;
    margin-top: 10px;
    font-size: 14px;
    height: 40px;
    margin-right: 30px;
    margin-left: auto;
}
.under #content .map02 ul li:nth-child(1) {
    left: 130px;
    top: 65px;
}
.under #content .map02 ul li:nth-child(2) {
    bottom: 25px;
    left: -50px;
}
.under #content .map02 ul li:nth-child(3) {
    right: 0px;
    top: 412px;
}
.under #content .map02_tt {
    margin-bottom: 15px;
    width: 120px;
    height: 22px;
    line-height: 24px;
    background: #000;
    color: #fff;
    font-weight: bold;
    text-align: center;
}
.under #content .map_logo_wrap {
    display: flex;
    align-items: center;
}
.under #content .map_logo01 {
    margin-left: auto;
    position: relative;
    margin-top: -25px;
}
.under #content .map02_txt {
    font-size: 15px;
    line-height: 2.12;
    margin-bottom: 0px;
}
.under h4.h4_map01 {
    position: relative;
    bottom: -20px;
}
.under #content .en_tt_map {
    top: 15px;
}
/*company*/
.company_boxf {
    border: solid 1px #DFD8D9;
    padding: 30px !important;
    margin-bottom: 60px;
}
.under #content .company_box01 {
    background: url("../images/company_img_01.png")#fff no-repeat right bottom;
    -webkit-background-size: auto 300px;
    background-size: auto 300px;
    /* height: 300px; */
    /* display: flex; */
    align-items: center;
    padding: 10px 350px 0px 0px;
    box-sizing: border-box;
}
.under #content .company_tt01 {
    text-align: right;
    font-weight: 700;
    line-height: 1.7;
    margin-top: 25px;
    color: #000;
    margin-right: 10px;
}
.under #content .company_tt01 span {
    font-size: 110%;
}
.under #content .info_pl {
    padding-left: 20px;
}
/*rose*/
.under #content .rose_bg {
    background: url("../images/rose_img_02_bg.png")#f7f1d5 no-repeat center center/cover;
    padding: 50px;
}
/*family*/
.under #content .family_bg {
    background: url("../images/family_img_02_bg.png") no-repeat center top/cover;
    padding: 50px 50px 30px 50px;
}
.under #content .family_list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.under #content .family_list li {
    width: 196px;
    height: 196px;
    background: #fff;
    color: #333;
    font-weight: bold;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 10px;
    box-sizing: border-box;
    text-align: center;
    position: relative;
    margin-left: -10px;
}
.under #content .family_list li:nth-child(n+6) {
    margin-top: -30px;
}
.under #content .family_list li:nth-child(1) {
    border: 3px #ed6a02 solid;
}
.under #content .family_list li:nth-child(2) {
    border: 3px #427935 solid;
}
.under #content .family_list li:nth-child(3) {
    border: 3px #d39200 solid;
}
.under #content .family_list li:nth-child(4) {
    border: 3px #e5001e solid;
}
.under #content .family_list li:nth-child(5) {
    border: 3px #28a838 solid;
}
.under #content .family_list li:nth-child(6) {
    border: 3px #003067 solid;
}
.under #content .family_list li:nth-child(7) {
    border: 3px #970b31 solid;
}
.under #content .family_list li:nth-child(8) {
    border: 3px #004c88 solid;
}
.under #content .family_list li:nth-child(9) {
    border: 3px #f5a200 solid;
}
.under #content .list_1col li {
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(247, 247, 247, 0.95) 20px, rgba(247, 247, 247, 0.95) 100%);
    padding: 30px;
    flex: 1;
    border-top: 2px #ec4d48 solid;
}
.under #content .list_2col {
    display: flex;
}
.under #content .list_2col li {
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(247, 247, 247, 0.95) 20px, rgba(247, 247, 247, 0.95) 100%);
    padding: 30px;
    flex: 1;
    border-top: 2px #ec4d48 solid;
}
.under #content .list_2col.list_3col li {
    margin-right: 30px;
    margin-left: 0px !important;
}
.under #content .list_2col.list_3col li:nth-child(3n) {
    margin-right: 0px;
}
.under #content .list_2col.list_2col_wrap {
    flex-wrap: wrap;
}
.under #content .list_2col.list_2col_wrap li, .under #content .list_2col.list_2col_wrap li {
    width: 49%;
    flex: inherit;
    margin: 0 2% 30px 0px;
}
.under #content .list_2col.list_2col_wrap li:nth-child(2n) {
    margin-right: 0px;
    margin-left: 0px;
}
.under #content .list_2col li:nth-child(2n) {
    margin-left: 30px;
}
.under #content .list_2col.list_2col_wrap.list_2col_1col li {
    width: 49%;
    flex: inherit;
    margin: 0 auto;
}
.under #content .step01 {
    padding: 120px 50px 70px;
    background: #f4f8fb;
}
/* #flow #content .step01 {
	margin-bottom: 80px;
} */
.under #content .step01 dl {
    display: flex;
    padding-bottom: 20px;
    background: linear-gradient(45deg, transparent 0px, transparent 32px, rgba(255, 255, 255, 1) 32px, rgba(255, 255, 255, 1) 100%);
    margin-bottom: 150px;
    position: relative;
}
.under #content .step01 dl:last-child {
    margin-bottom: 0px;
}
.under #content .step01 dl:last-child:before {
    display: none;
}
.under #content .step01 dl:before {
    position: absolute;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 30px 0 30px;
    border-color: #004c88 transparent transparent transparent;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: -30px;
}
.under #content .step01 dl dt {
    padding: 0px 30px 40px;
}
.under #content .step01 dl dd {
    position: relative;
    margin-top: -60px;
    margin-right: -20px;
}
.under #content .step01 dl dd p {
    margin-bottom: 0px;
}
.under #content .step01 dl:nth-child(2n) {
    flex-direction: row-reverse;
    background: linear-gradient(-45deg, transparent 0px, transparent 32px, rgba(255, 255, 255, 1) 32px, rgba(255, 255, 255, 1) 100%);
}
.under #content .step01 dl:nth-child(2n) dd {
    margin-right: 0px;
    margin-left: -20px;
}
.under #content .step_icon {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 10px;
    margin-top: -25px;
    display: flex;
    align-items: center;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    line-height: 1.5;
}
.under #content .step_icon > span {
    color: #fff;
    background: linear-gradient(135deg, transparent 3px, #004c88 0) top left, linear-gradient(-135deg, transparent 3px, #004c88 0) top right, linear-gradient(-45deg, transparent 3px, #004c88 0) bottom right, linear-gradient(45deg, transparent 3px, #004c88 0) bottom left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    width: 60px;
    height: 50px;
    margin-right: 25px;
    flex-shrink: 0;
    letter-spacing: 0px !important;
}
/*contents product*/
.under #content .list_product {
    display: flex;
    flex-wrap: wrap;
}
.under #content .list_product li {
    margin-right: 2%;
    width: 32%;
    margin-bottom: 30px;
}
.under #content .list_product li a {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(247, 247, 247, 0.95) 20px, rgba(247, 247, 247, 0.95) 100%);
    padding: 30px;
    border-top: 2px #ec4d48 solid;
    text-decoration: none;
    font-weight: 700;
    color: #333;
    text-align: center;
    transition: all 0.3s;
}
.under #content .list_product li a .list_product_img {
    margin-bottom: 10px;
}
.under #content .list_product li:nth-child(3n) {
    margin-right: 0px;
}
/*service*/
.under #content .service_bg01 {
    background: url("../images/service_img_02.png") no-repeat center top/cover;
    padding: 50px;
}
.under #content .service_bg01 .frame01 {
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(255, 255, 255, 0.95) 20px, rgba(255, 255, 255, 0.95) 100%);
}
.under #content .box_flex01 {
    display: flex;
}
/*person*/
.under #content .person_box {
    margin: -100px auto 0;
    background-color: rgba(255, 255, 255, 0.95);
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
    padding: 30px;
    box-sizing: border-box;
    width: calc(100% - 100px);
    position: relative;
    z-index: 9;
}
.under #content .person_list_img {
    display: flex;
    overflow: hidden;
}
/*guest*/
.under #content .guest_box01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.under #content .guest_box01 li {
    width: 47%;
    margin-bottom: 50px;
    position: relative;
}
.under #content .guest_box01 li:last-child {
    margin: 0 auto;
}
.under #content .guest_bg {
    background: #fff;
    padding: 30px;
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.2);
    width: 90%;
    margin: -70px 0 0 -20px;
    z-index: 1;
    position: relative;
}
.under #content .guest_bg:before {
    position: absolute;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 10px 10px;
    border-color: transparent transparent #e5001e transparent;
    right: 10px;
    bottom: 10px;
}
.under #content .recruit_box dt {
    background-color: rgba(79, 94, 105, 1);
    color: #fff;
    height: 60px;
    display: flex;
    align-items: center;
    padding: 3px 20px 0;
    font-weight: bold;
}
.under #content .recruit_box dd {
    padding: 30px;
    background: #f4f7fa;
}
.under #content .recruit_box dd table {
    background: #fff;
    border: none;
}
.under #content .recruit_box dd table tr {
    border-bottom: 1px #efefef solid;
}
.under #content .recruit_box dd table th, .under #content .recruit_box dd table td {
    border: none;
}
.under #content .td_01 {
    padding: 20px 25px;
    background: #f4f7fa;
}
.under #content .recruit_box dd table th {
    background: none;
    color: #000;
    font-weight: bold;
    vertical-align: top;
    padding-top: 20px;
    position: relative;
    text-align: left;
}
.under #content .recruit_box dd table th:before {
    position: absolute;
    content: "";
    width: 28px;
    height: 1px;
    background: #e5001e;
    left: 15px;
    top: 50px;
}
.under #content .recruit_box dd table td {
    font-weight: 500;
}
.under #content .color01 {
    color: rgba(79, 94, 105, 1);
    font-weight: bold;
}
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/* ACC                                                                    */
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
.acc_box {
    padding-bottom: 1px;
}
.acc_box dt {
    position: relative;
    cursor: pointer;
    transition: all 0.3s;
    box-sizing: border-box;
}
.acc_box dt:before, .acc_box dt:after {
    width: 20px;
    height: 1px;
    background: #fff;
    right: 20px;
    top: calc(50% - 0px);
    transition: all 0.3s;
    position: absolute;
    content: "";
    z-index: 5;
}
.acc_box dt:after {
    transform: rotate(90deg);
}
.acc_box dd {
    display: none
}
.acc_box.active dd {
    display: block;
}
.acc_box dt.active:after {
    transform: rotate(0deg);
}
.acc_box dl dt:before, .acc_box dl dt:after {
    right: 12px;
}
.under #content .success_tt02 {
    color: #8ac8da;
    font-weight: bold;
    font-size: 18px;
}
.under #content .success_img {
    background: linear-gradient(-45deg, transparent 0px, transparent 20px, rgba(239, 239, 239, 1) 20px, rgba(239, 239, 239, 1) 100%);
    padding: 50px;
    text-align: center;
    border-top: 2px #ec4d48 solid;
}
.under #content .box_success01 {
    display: flex;
    align-items: center;
    margin-bottom: 30px;
}
.under #content .box_success01 p {
    margin-bottom: 0px;
}
.under #content .success_label {
    background: linear-gradient(135deg, transparent 3px, #cc6d69 0) top left, linear-gradient(-135deg, transparent 3px, #cc6d69 0) top right, linear-gradient(-45deg, transparent 3px, #cc6d69 0) bottom right, linear-gradient(45deg, transparent 3px, #cc6d69 0) bottom left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    color: #fff;
    font-size: 14px;
    width: 150px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 40px;
    margin-right: 40px;
}
.under #content .success_tt01 span {
    font-weight: bold;
}
.under #content .success_table {
    display: flex;
}
.under #content .success_table li:nth-child(1) {
    width: 580px;
}
.under #content .success_table li:nth-child(2) {
    width: 500px;
}
.under #content .success_txt01 {
    display: flex;
    justify-content: space-between;
}
.under #content .news_list dl {
    padding: 14px 0 13px;
    border-bottom: 1px #e5e5e5 solid;
    display: flex;
}
.under #content .news_list dl dt {
    font-size: 12px;
    flex-shrink: 0;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
	margin-right: 17px;
}
.under #content .news_list dl > dd {
    flex-grow: 1;
    font-size: 18px;
}
.under #content .news_list dl > dd a {
    color: #3e3a39;
    text-decoration: none;
}
.under #content .box06_cate {
    margin-left: 25px;
}
/*--------------pagination----------------------*/
.under #content ul.pagination {
    text-align: center;
    padding: 0px 0 20px 0;
}
.under #content ul.pagination li {
    display: inline-block;
    margin-bottom: 5px;
}
.under #content ul.pagination li a {
    padding: 3px 12px;
    text-decoration: none;
    display: block;
    color: #333;
    background: #ddd;
    transition: all 0.3s;
    line-height: 1.7;
}
.under #content ul.pagination li.active a, .under #content ul.pagination li.active a:hover {
    background: #e8211a;
    cursor: pointer;
    color: #fff;
}
.under #content ul.pagination li.disabled a {
    display: none;
}
.under #content .btn_right {
    width: 100%;
    display: inline-block;
}
.under #content .btn_right a {
    text-decoration: none;
    font-weight: bold;
    background: #e8211a;
    padding: 7px 45px;
    color: #fff;
    display: inline-block;
    transition: all 0.3s;
}
.under #content .bg_none a {
    background: initial;
	padding: 7px 15px;
}
.under #content .tb_recal td, .under #content .tb_recal th {
    line-height: 1.7
}
.under #content .pl20 {
    padding-left: 20px;
}
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/* 2020.03.22 追加                                                         */
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
@media all and (-ms-high-contrast: none) {
    #recruit_staff .staff_list li {
        width: 16%;
        height: 250px;
        margin-left: .8%;
        margin-bottom: .8%;
        padding: 5px;
        display: flex;
        flex-direction: column;
        border: 1px solid #ddd;
    }
}
#recruit_staff .staff_list {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 80px;
}
#recruit_staff .staff_list li {
    width: 16%;
    margin-left: .8%;
    margin-bottom: .8%;
    padding: 5px;
    display: flex;
    flex-direction: column;
    border: 1px solid #ddd;
}
#recruit_staff .staff_list li:nth-child(6n+1) {
    margin-left: 0;
}
#recruit_staff .staff_list li a {
    text-decoration: none;
    color: #333;
    -webkit-transition: opacity .3s;
    -o-transition: opacity .3s;
    transition: opacity .3s;
}
#recruit_staff .staff_list li a:hover {
    opacity: .7;
}
#recruit_staff .staff_list li img {
    width: 100%;
    height: auto;
    flex-shrink: 0;
}
#recruit_staff .staff_list li p {
    font-size: 14px;
    line-height: 1.5;
    margin-top: 10px;
    text-align: left;
}
#recruit_staff .section h5 {
    color: #333;
    font-weight: bold;
}
#recruit_staff .section .image_l, #recruit_staff .section .image_r {
    max-width: 45%;
}
#recruit_staff .section .image_l img, #recruit_staff .section .image_r img {
    display: block;
    width: 100%;
}
.prof_ph {
    width: 30%;
}
#recruit_staff .section p.q {
    color: #e5001e;
    font-size: 26px;
    margin-top: -20px;
    margin-bottom: 10px;
}
#recruit_staff .section p.q::before {
    content: "Q";
    margin-right: 5px;
}
#fan p img {
    max-width: 100%;
}
#fan .fan_list {
    display: flex;
    flex-wrap: wrap;
}
#fan .fan_list li {
    width: 23.5%;
    margin-left: 2%;
    margin-bottom: 2%;
}
#fan .fan_list li:nth-child(4n+1) {
    margin-left: 0;
}
#fan .fan_list li a {
    display: block;
    text-decoration: none;
    color: #333;
    -webkit-transition: opacity .3s;
    -o-transition: opacity .3s;
    transition: opacity .3s;
}
#fan .fan_list li a:hover {
    opacity: .8;
}
#fan .fan_list li img {
    display: block;
    width: 100%;
}
#fan .fan_list li a p {
    line-height: 1.4;
    font-size: 16px;
    margin-top: 10px;
    word-break: break-word;
}
#demolition.under #content .list_2col.list_2col_wrap li {
    position: relative;
    margin-top: 50px;
}
#demolition.under #content .list_2col.list_2col_wrap li h5 {
    position: absolute;
    top: -50px;
    left: 0;
}
#rose .rose_title {
    display: flex;
    align-items: center;
    flex-direction: column;
}
#rose .rose_title_inner {
    text-align: center;
    position: relative;
}
#rose .rose_title_inner::before, #rose .rose_title_inner::after {
    content: "";
    width: 60px;
    height: 60px;
    background: url('../images/rose_bg.png') no-repeat center center;
    -webkit-background-size: contain;
    background-size: contain;
    position: absolute;
    bottom: 0;
}
#rose .rose_title_inner::before {
    right: calc(100% + 10px);
}
#rose .rose_title_inner::after {
    left: 100%;
}
#rose .rose_title_inner h5 {
    margin-bottom: 0;
}
#rose .rose9 img {
    display: block;
    width: 700px;
    height: auto;
    margin: 0 auto;
}
#rose .rose_txt {
    font-size: 400%;
}
#rose #content .section img, #safety #content .section img {
    max-width: 100%;
}
#info .map02 {
    margin-bottom: 50px;
}
#recruit span.btn02 {
    display: block;
    margin-top: 10px;
}
#map .base_map iframe {
    width: 100%;
    height: 500px;
    border: none;
}
#map .base_description {
    margin-bottom: 80px;
}
.image_map img {
    width: 100%;
}
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/* 2020.03.28 追加                                                         */
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#inherit #content .box_flex01 {
    margin-bottom: 50px;
}
#inherit #content .box_flex01 .table_box {
    max-width: 100%;
    width: 300px;
    flex-shrink: 0;
    margin-left: 5%;
}
#inherit #content .box_flex01 table {
    width: 100%;
    margin-bottom: 10px;
}
#inherit #content .box_flex01 table td {
    text-align: center;
    padding: 5px 15px;
}
#inherit #content .box_flex01 table + p {
    line-height: 1.2;
}
#company #content .company_box01 p.center {
    text-align: center;
}
#company #content .company_box01 em {
    font-size: 1.15em;
    font-weight: bold;
    font-style: normal;
}
#news .section img, #product .box_flex01 figure img {
    display: block;
    width: 100%;
    height: auto;
}
#service .box_flex02 {
    display: flex;
    justify-content: center;
    margin: 0 0 30px;
}
#service .box_flex01 {
    margin: 0 0 30px;
}
#service .box_flex01, #product .box_flex01 {
    justify-content: space-between;
}
#service .box_flex01 a, #service .box_flex02 a, #product .box_flex01 figure {
    width: 48%;
    position: relative;
    margin: 0;
}
#product .box_flex01 figure p.note {
    position: absolute;
    bottom: calc(100% + 10px);
    right: 0;
    margin: 0;
    line-height: 1.2;
}
#service .box_flex01 a, #service .box_flex02 a, #product .box_flex01 a {
    display: block;
    -webkit-transition: opacity .3s;
    -o-transition: opacity .3s;
    transition: opacity .3s;
}
#service .box_flex01 a {
    display: initial;
}
#service .box_flex01 a:hover, #service .box_flex02 a:hover, #product .box_flex01 a:hover {
    opacity: .7;
}
#catalog .section p.title {
    font-size: 20px;
    color: #e5001e;
    margin-bottom: 17px;
    font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, 'メイリオ', Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-weight: 500;
    line-height: 1.6em;
    text-align: center;
}
.under #content .h4style {
    font-size: 32px;
    padding-left: 20px;
    position: relative;
    margin-bottom: 12px;
    line-height: 1.5;
    text-align: left;
}
.under #content .h4style::before {
    position: absolute;
    content: "";
    width: 6px;
    height: 28px;
    background: #e7211a;
    left: 0;
    top: 10px;
}
.under #content .h4style::after {
    content: none;
}
#town #content {
    padding-bottom: 100px;
}
#town .image_map {
    position: relative;
}
#town .image_map img[usemap] {
    position: relative;
    z-index: 1;
}
#town .image_map img.highlight {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    display: none;
    /* opacity: 0;
	-webkit-transition: opacity .3s;
	-o-transition: opacity .3s;
	transition: opacity .3s; */
}
#town .image_map map[name="image-map"] {
    position: relative;
    z-index: 3;
}
.under .h5_print {
    display: flex;
}
.under .h5_print01 {
    width: 500px;
    margin: 0 auto 30px;
}
.under .btn_print {
    margin-left: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 1px #040000 solid;
    box-shadow: 2px 2px 4px 0px rgba(214, 214, 214, 0.3);
    font-size: 14px;
    padding: 7px 20px 5px;
    cursor: pointer;
    transition: all 0.3s;
    outline: none;
    font-weight: bold;
    background: #333;
    color: #fff;
}
.under .btn_print01 {
    position: absolute;
    top: -50px;
    right: 0;
}
.under .box_flex01_p li {
    position: relative;
}
.under .box_flex01_p li:nth-child(1) {
    margin-right: 40px;
}
.under .img_w {
    max-width: 1200px;
}
.under #content .link_icon01 {
    background: url("../images/icon01.png") no-repeat left center/25px;
    padding-left: 32px;
    text-decoration: none;
    color: #333;
    font-weight: bold;
    display: block;
    padding-top: 4px;
}
.under #content .link_icon01:hover {
    text-decoration: underline;
}
.under #content .mb30 {
    margin-bottom: 30px;
}
.under #content .tt01 {
    font-size: 20px;
    color: #e5001e;
    margin-bottom: 17px;
    font-weight: 500;
    line-height: 1.6em;
}
.under #content .section03 {
    padding-bottom: 30px;
}
.under #content .section03:last-child {
    padding-bottom: 0px;
}
.under #content .kid_tt01 {
    margin-bottom: 20px;
    font-weight: bold;
}
.under #content .kid_tt01 p {
    margin-bottom: 0px;
    display: flex;
}
.under #content .kid_tt01 p > span:nth-child(1) {
    display: inline-block;
    width: 80px;
    flex-shrink: 0;
}
.under #content .kid_tt01 p > span:nth-child(2) {
    text-indent: -14px;
    padding-left: 10px;
}
.under #content .box04_list01 {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}
.under #content .box04_list01 > li {
    width: 50%;
    display: flex;
    flex-direction: column;
    margin-bottom: 50px;
}
.under #content .box04_list01 > li:nth-child(n+3) {
    margin-bottom: 0px;
}
.under #content .box04_info01 {
    width: calc(100% - 50px);
    flex-grow: 1;
    padding: 20px 35px 20px;
    background: linear-gradient(-45deg, transparent 0px, transparent 32px, rgba(247, 247, 247, 0.95) 32px, rgba(247, 247, 247, 0.95) 100%);
    height: 100%;
    margin: 0px auto 0px;
    position: relative;
    z-index: 1;
}
.under #content .box04_img01 img {
    width: 540px;
    margin-top: 30px;
    margin-bottom: 20px
}
.under #content .box04_info01 > li {
    position: relative;
    display: flex;
    flex-direction: column;
}
.under #content .h4_tt03 {
    padding-bottom: 0px;
    margin-bottom: 15px !important;
    line-height: 1.8;
}

.under #content .box05_list01 {
     color: #e7211a;
     font-size: 18px;
}

.under #content .box05_list01 li {
     line-height: 1.7em;
}

.under #content .box05_list01_small {
     margin-top: 10px;
     line-height: 1.7em;
}

.white-popup-block {
    background: #FFF;
    padding: 20px 30px;
    text-align: left;
    max-width: 650px;
    margin: 40px auto;
    position: relative;
}
/*map popup*/
body.active {
    overflow: hidden;
}
.iframe_map {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: scale(1);
    transition: all ease 0.3s;
    opacity: 0;
    visibility: hidden;
    z-index: -2;
}
.iframe_map.active {
    visibility: visible;
    opacity: 1;
    transform: scale(1);
    z-index: 999999999;
}
.iframe_map::after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 0;
    content: ''
}
.iframe_map_ct {
    background: #fff;
    width: 1000px;
    height: 80vh;
    margin: 10vh auto;
    position: relative;
    z-index: 2;
}
.close_modal {
    position: absolute;
    top: 15px;
    right: 15px;
    cursor: pointer;
    z-index: 2;
}
.iframe_map_ct iframe {
    width: 100%;
    height: 100%;
    border: none;
}
.under #content .open_map {
    background: rgba(79, 94, 105, 1);
    width: 50px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    display: block;
    font-size: 13px;
    color: #fff;
    transition: all 0.3s;
    margin: 0 auto;
}
.under #content .tbl_pt03 th, .under #content .tbl_pt03 td {
    padding: 15px 10px;
}
.under #content .btn_youtube a {
    background: url("../images/movie_mark01.png") no-repeat left center/32px;
    color: #333;
    font-size: 17px;
    padding: 15px 0 15px 40px;
    margin: 0 auto;
    display: table;
}
.under #content .btn02.mb10 {
    margin-bottom: 10px;
}
.under #content .clip_youtube {
    text-align: center;
}
.under #content .resp-container {
    text-align: center;
}
.under #content .list_product_sub {
    position: relative;
}
.under #content .list_product_sub_box {
    position: absolute;
    width: 712px;
    /*background: #fff;*/
    left: 0;
    z-index: 9;
    justify-content: space-between;
    display: none;
}
.under #content .list_product_sub_box ul {
    display: flex;
    width: 100%;
}
.under #content .list_product_sub_box > ul > li {
    width: 48%;
    margin-right: 25px;
    margin-bottom: 0px;
}
.under #content .list_col04 {
    display: flex;
}
.under #content .list_col04 dl {
    flex: 1;
}
.under #content .list_col04 dl dt, .under #content .list_col04 dl dd {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.under #content .list_col04 dl dt {
    background-color: rgba(79, 94, 105, 1);
    color: #fff;
    height: 100px;
    font-size: 17px;
}
.under #content .list_col04 dl dd {
    flex-direction: column;
    height: calc(100% - 100px);
    padding: 25px 5px;
    box-sizing: border-box;
    border: 1px #ddd solid;
}
.under #content .list_col04 dl dd p {
    font-size: 17px;
    line-height: 1.8;
    letter-spacing: -0.7px;
    margin-bottom: 15px;
}
.under #content .list_col04 dl dd p:last-child {
    margin-bottom: 0px;
}
.under #content .list_col04 dl:not(:last-of-type) {
    margin-right: 10px;
}
.under #content .link_out, .under #content .link_out:hover {
    color: #333;
    text-decoration: underline;
}

.under #content .contact_last {
    margin-top: 10px;
    text-align: center;
    border: 1px #ddd solid;
    font-size: 17px;
}
/*25/12*/
.under #content .contact_bnr_wrap {
    position: relative;
}

.under #content .contact_bnr {
    background: #e3f0fb ;
    padding: 20px;
    border: 1px rgba(79, 94, 105, 1) solid;
}
.under #content .contact_bnr_tt {
    font-weight:bold;
    font-size:24px;
    text-align: center;
    display: block;
    margin-bottom: 10px;
}
.under #content .contact_bnr_tt a {

    text-decoration: none;
    
}
.under #content  .contact_bnr_txt {
    font-size:15px;
        line-height: 2.2;
    display: block;
}
.under #content .list_2img {
    display:flex;
    justify-content: center;
}
.under #content .list_2img li:not(:last-child) {
    margin-right: 25px;
}
.under #content .list_2col_c {
    justify-content: center
}
.under #content .bre {
    word-break: break-all;
}
.under #content .fs_sm th, .under #content .fs_sm td {
    font-size: 15px;
    padding: 12px 7px;
}

.under #content  .w8 {
    width: 8%;
}
.under #content  .w24 {
    width: 24%;
}
.under #content .link02 {
   
    background: rgba(79, 94, 105, 1);
    color:#fff;
    text-decoration: none;
    display: inline-block;
    height: 40px;
    line-height: 51px;
    width: 90px;
    font-size: 13px;
    text-align: center;
    margin-left: 30px;
    position: relative;
}
.under #content h3 .link02 {
    top: -9px;
    height: 30px;
    line-height: 31px;
}
.under #content h4 .link02 {
    top:-5px;

}

.under #content p.indent{
    margin-left: 1em;    
}

/* 210611 */
body.active{overflow: hidden;}
#history.under #footer{margin-top: 0}
#history.under #topic_path{margin-bottom: 5px}
.under .history_page{background: url('../images/history_bg.jpg') top center  no-repeat;padding-bottom: 145px}
.under #main .history_page .inner{width: 1300px;padding-top: 175px}

.under #content .history_box01{background: url('../images/history_box01_bg.png') center /cover no-repeat;width: 648px;height: 316px;content: '';position: relative;left: -35px;padding: 55px 0 0 100px}
.under #content .history_box01 p{font-weight: bold;font-size: 23px;line-height: 1.73em;color: #3b2511}
.under #content .history_box01::before{background: url('../images/history_box01_ic1.png') center /cover no-repeat;width: 284px;height: 242px;content: '';position: absolute;top: -125px;right: -150px;}
.under #content .history_box01::after{background: url('../images/history_box01_ic2.png') center /cover no-repeat;width: 184px;height: 184px;content: '';position: absolute;top: -125px;left: 5px;}

.under #content .history_cloud{}
.under #content .history_cloud .year{font-size: 100px;color: #a2958d;font-weight: 500;line-height: 1em;margin-bottom: 0;position: relative;text-shadow: #fff 2px 0px 0px, #fff 1.75517px 0.958851px 0px, #fff 1.0806px 1.68294px 0px, #fff 0.141474px 1.99499px 0px, #fff -0.832294px 1.81859px 0px, #fff -1.60229px 1.19694px 0px, #fff -1.97998px 0.28224px 0px, #fff -1.87291px -0.701566px 0px, #fff -1.30729px -1.5136px 0px, #fff -0.421592px -1.95506px 0px, #fff 0.567324px -1.91785px 0px, #fff 1.41734px -1.41108px 0px, #fff 1.92034px -0.558831px 0px;z-index: 1}
.under #content .history_cloud .year::before{content: '';position: absolute;z-index: -1}
.under #content .history_cloud ul{position: relative;z-index: 2;display: flex;flex-direction: column;align-items: flex-start;}
.under #content .history_cloud ul li{position: relative;margin-bottom: 35px;}
.under #content .history_cloud ul li a{display: flex;align-items: center;font-weight: bold;font-size: 32px;line-height: 1.25em;letter-spacing: 0.04em;padding-right: 80px;position: relative;cursor: pointer;text-decoration: none;color: #3b2511}
.under #content .history_cloud ul li:last-child{margin-bottom: 0;}
.under #content .history_cloud ul li span{width: 110px;height: 45px;background: #452c1c;color: #fff;display: flex;align-items: center;justify-content: center;letter-spacing: 0.025em;border-radius: 5px;flex-shrink: 0;margin-right: 20px;font-size: 18px;text-align: center;}
.under #content .history_cloud ul li::before{width: 72px;height: 52px;background: url('../images/history_ic_txt.png') center /cover no-repeat;position: absolute;top:calc(50% - 26px);right: 0;content: '';transition: all linear 0.3s}
.under #content .history_cloud ul li::after{width: 100%;height: 5px;background: url('../images/ic_cloud_list.png') left repeat;position: absolute;bottom: -20px;left: 0;content: ''}

/* 2020 */
.under #content .cloud_2020{margin: 235px 0 0 330px;}
.under #content .cloud_2020 .year{margin-left: 50px}
.under #content .cloud_2020 .year::before{background: url('../images/history_cloud_2020.png') center /cover no-repeat;width: 674px;height: 210px;top: -85px;left: -345px;}
.under #content .cloud_2020 ul{margin-top: 60px;}
.under #content .cloud_2020 ul li:nth-child(2){left: 40px;}

/* 2010 */
.under #content .cloud_2010{margin: 180px 0 0 500px;}
.under #content .cloud_2010 .year{margin-left: 115px}
.under #content .cloud_2010 .year::before{background: url('../images/history_cloud_2010.png') center /cover no-repeat;width: 528px;height: 204px;top: -85px;right: 230px;}
.under #content .cloud_2010 ul{margin: 40px 0 0 105px;}
.under #content .cloud_2010 ul li:nth-child(2){left: -40px;}

/* 2000 */
.under #content .cloud_2000{margin: 95px 0 0 70px}
.under #content .cloud_2000 .year{margin-left: 125px}
.under #content .cloud_2000 .year::before{background: url('../images/history_cloud_2000.png') center /cover no-repeat;width: 588px;height: 234px;top: -95px;left: -260px;}
.under #content .cloud_2000 ul{margin: 55px 0 0 125px}
.under #content .cloud_2000 ul li:nth-child(2){left: -30px;}
.under #content .cloud_2000 ul li:nth-child(3){left: -50px;}
.under #content .cloud_2000 ul li:nth-child(4){left: -50px;}
.under #content .cloud_2000 ul li:nth-child(5){left: 10px;}

/* 1990 */
.under #content .cloud_1990{margin: 245px 0 0 480px;}
.under #content .cloud_1990 .year{margin-left: 95px}
.under #content .cloud_1990 .year::before{background: url('../images/history_cloud_1990.png') center /cover no-repeat;width: 528px;height: 204px;top: -70px;right: 275px;}
.under #content .cloud_1990 ul{margin: 90px 0 0 75px;}

/* 1980 */
.under #content .cloud_1980{margin: 225px 0 0 40px}
.under #content .cloud_1980 .year{margin-left: 125px}
.under #content .cloud_1980 .year::before{background: url('../images/history_cloud_1980.png') center /cover no-repeat;width: 614px;height: 232px;top: -100px;left: -275px;}
.under #content .cloud_1980 ul{margin: 50px 0 0 145px}
.under #content .cloud_1980 ul li:nth-child(2){left: 40px;}
.under #content .cloud_1980 ul li:nth-child(4){left: -50px;}

/* 1970 */
.under #content .cloud_1970{margin: 205px 0 0 435px;}
.under #content .cloud_1970 .year{margin-left: 125px}
.under #content .cloud_1970 .year::before{background: url('../images/history_cloud_1970.png') center /cover no-repeat;width: 452px;height: 176px;top: -55px;right: 325px;}
.under #content .cloud_1970 ul{margin: 65px 0 0 130px;}

/* 1960 */
.under #content .cloud_1960{margin: 175px 0 0 80px}
.under #content .cloud_1960 .year{margin-left: 125px}
.under #content .cloud_1960 .year::before{background: url('../images/history_cloud_1960.png') center /cover no-repeat;width: 620px;height: 228px;top: -95px;left: -295px;}
.under #content .cloud_1960 ul{margin: 80px 0 0 115px}
.under #content .cloud_1960 ul li:nth-child(2){left: -10px;}
.under #content .cloud_1960 ul li:nth-child(3){left: 30px;}
.under #content .cloud_1960 ul li:nth-child(4){left: 70px;}

/* 1910 */
.under #content .cloud_1910{margin: 175px 0 0 90px}
.under #content .cloud_1910 .year{margin-left: 125px}
.under #content .cloud_1910 .year::before{background: url('../images/history_cloud_1910.png') center /cover no-repeat;width: 440px;height: 170px;top: -40px;left: -30px;}
.under #content .cloud_1910 ul{margin: 75px 0 0 35px;}
.under #content .cloud_1910 ul li{padding-left: 100px}
.under #content .cloud_1910 ul li span{width: 170px}

/* HISTORY YOUTUBE */
.under #content .youtube{margin: 365px 0 0;display: flex;justify-content: flex-end;}
.under #content .youtube .frame{width: 560px;height: 260px;position: relative;right: -240px}
.under #content .youtube .frame iframe{width: 100%;height: 100%;}
.under #content .youtube .frame::before{position: absolute;top: -80px;right: -50px;background: url('../images/history_ytb.png') center /cover no-repeat;width: 680px;height: 460px;content: '';pointer-events: none;}
.under #content .youtube .frame::after{position: absolute;top: 180px;left: -320px;background: url('../images/history_ytb_ic.png') center /cover no-repeat;width: 272px;height: 194px;content: ''}

@media screen\0 {
    .under #content .bnr01 a > span:nth-child(1) {
        padding-top: 10px;
    }
    .under #content .btn01 li a, .under #content .btn03 li a {
        box-sizing: border-box;
        padding-top: 10px;
    }
    .under #content .recruit_box dt {
        padding-top: 7px;
    }
    .under #content .box06_cate {
        padding-top: 3px;
    }
    .under #content ul.pagination li a {
        padding: 5px 12px 0px;
    }
    .under #content .btn_right a {
        padding: 7px 45px 2px;
    }
    .under #content .btn02 a {
        padding-top: 4px;
    }
    .under #content .list_product li a {
        line-height: 1.7;
    }
    .under #content .list_product_tt {
        display: table;
    }
    .under #content .step_icon > span {
        box-sizing: border-box;
        padding-top: 6px;
    }
    .under #content .bnr_list dd ul li a {
        padding-top: 7px;
    }
    .under #content .bnr_list02 dd a {
        padding-top: 10px;
    }
    .under #content .link_icon01 {
        padding-top: 9px;
    }
    .under #content .open_map {
        padding-top: 3px;
        height: 32px;
    }
    .under #content .fs_sm tr:nth-child(2) th {
        padding-top: 5px !important;
    }
    .under #content .fs_sm th, .under #content .fs_sm td {
        padding: 12px 7px 5px;
    }

    .under #content .history_cloud ul li span{padding-top: 5px;position: relative;top: -5px;}
    .under #content .history_cloud ul li a{padding-top: 10px;}

    .under #content .youtube{margin: 335px 0 0}
    .under #content .cloud_2020 .year::before{top: -95px;left: -355px;}
    .under #content .cloud_2000 .year::before{top: -105px;}
    .under #content .cloud_1990 .year::before{top: -80px;right: 265px;}
    .under #content .cloud_1980{margin: 165px 0 0 40px}
    .under #content .cloud_1980 .year::before{top: -115px;left: -290px;}
    .under #content .cloud_1970 .year::before{top: -65px;}
    .under #content .cloud_1960{margin: 125px 0 0 80px}
    .under #content .cloud_1960 .year::before{top: -110px}
    .under #content .cloud_1910{margin: 150px 0 0 90px}
    .under #content .cloud_1910 .year::before{top: -60px;}
}

.honbun {
  font-size: 18px;
  line-height: 2em;
}
