@charset "UTF-8";
/*==========================================================                      C U S T O M
==========================================================*/
/* MB */
.under main .mb0 {
    margin-bottom: 0px !important;
}
.under main .mb5 {
    margin-bottom: 5px !important;
}
.under main .mb10 {
    margin-bottom: 10px !important;
}
.under main .mb15 {
    margin-bottom: 15px !important;
}
.under main .mb20 {
    margin-bottom: 20px !important;
}
.under main .mb25 {
    margin-bottom: 25px;
}
.under main .mb30 {
    margin-bottom: 30px !important;
}
.under main .mb40 {
    margin-bottom: 40px;
}
.under main .mb50 {
    margin-bottom: 50px !important;
}
.under main .mb60 {
    margin-bottom: 60px;
}
.under main .mb70 {
    margin-bottom: 70px;
}
.under main .mb80 {
    margin-bottom: 80px;
}
.under main .mb90 {
    margin-bottom: 90px;
}
/* MT */
.under main .mt10 {
    margin-top: 10px;
}
.under main .mt15 {
    margin-top: 15px;
}
.under main .mt20 {
    margin-top: 20px;
}
.under main .mt25 {
    margin-top: 25px;
}
.under main .mt30 {
    margin-top: 30px;
}
.under main .mt40 {
    margin-top: 40px;
}
.under main .mt50 {
    margin-top: 50px;
}
.under main .mt60 {
    margin-top: 60px;
}
.under main .mt70 {
    margin-top: 70px;
}
.under main .mt80 {
    margin-top: 80px;
}
.under main .mt90 {
    margin-top: 90px;
}
/* MAX_W */
.under main .max_w200 {
    width: 100%;
    max-width: 200px;
}
.under main .max_w250 {
    width: 100%;
    max-width: 250px;
}
.under main .max_w300 {
    width: 100%;
    max-width: 300px;
}
.under main .max_w350 {
    width: 100%;
    max-width: 350px;
}
.under main .max_w500 {
    width: 100%;
    max-width: 500px;
}
.under main .max_w600 {
    width: 100%;
    max-width: 600px;
}
.under main .max_w700 {
    width: 100%;
    max-width: 700px;
}
.under main .max_w800 {
    width: 100%;
    max-width: 800px;
}
.under main .max_w900 {
    width: 100%;
    max-width: 900px;
}
/* MIN-W */
.under main .min_w200 {
    min-width: 200px;
}
.under main .min_w250 {
    min-width: 250px;
}
.under main .min_w300 {
    min-width: 300px;
}
.under main .min_w350 {
    min-width: 350px;
}
.under main .min_w500 {
    min-width: 500px;
}
.under main .w70 {
    width: 70%;
}
.under main .w20{width: 20%;}
.under main .w30{width: 30%;}
/*==========================================================                      FONT FAMILY
==========================================================*/
.under main h2, .under main h3, .under main h4, .under main h5, .under main h6, .under main table th, .under main .list_faq dt, .under main .list_step dt {
    font-family: var(--f-nts);
}
/*==========================================================                      H E A D I N G
==========================================================*/
.under main .title_page .ttl, .under main h2, .under main h3, .under main h4, .under main h5, .under main h6 {
    font-weight: bold;
    margin-bottom: 30px;
}
.under main .title_page .ttl {
    font-size: 42px;
    text-align: center;
    margin-bottom: 0;
    font-family: var(--f-nts);
    line-height: 1.5em;
    margin-bottom: 0;
}
.under main .title_page .en {
    letter-spacing: 0.1em;
    position: absolute;
    opacity: 0.4;
    line-height: 1;
    text-shadow: 0px 1px 8px rgba(81, 81, 81, 0);
    position: absolute;
    line-height: 1;
    font-family: var(--f-arial);
    font-size: 8rem;
    font-weight: 600;
    right: 0;
    bottom: 0;
    text-transform: uppercase;
    z-index: -1;
}
.under main h2 {
    font-size: 40px;
    text-align: center;
}
.under main h3 {
    font-size: 36px;
    background-color: var(--mcolor);
    color: #fff;
    display: block;
    padding: 8px 15px 11px;
    margin-bottom: 30px;
}
.under main .uh3 {
    font-size: 36px;
    font-weight: bold;
    text-align: center;
    line-height: 1.5em;
}
.under main h4:not([class]) {
    font-size: 30px;
    position: relative;
    padding-left: 15px;
}
.under main h4:not([class])::before {
    content: "";
    position: absolute;
    width: 4px;
    height: 100%;
    background-color: var(--mcolor);
    left: 0;
    top: 2px;
}
.under main h5 {
    font-size: 24px;
    color: var(--mcolor);
    margin-bottom: 20px;
    border-bottom: 1px solid var(--mcolor);
    padding-bottom: 10px;
}
.under main h6 {
    font-size: 20px;
    position: relative;
    overflow: hidden;
    padding-bottom: 10px;
}
.under main h6::before, .under main h6::after {
    content: "";
    position: absolute;
    height: 3px;
    left: 0;
    bottom: 0;
}
.under main h6::before {
    background-color: var(--mcolor);
    width: 50px;
    left: 0;
    z-index: 2;
}
.under main h6::after {
    background-color: #ccc;
    width: 100%;
}
.under main h2 {
    position: relative;
}
.under main h2 > span {
    display: inline-block;
    padding: 0 130px;
    position: relative;
}
.under main h2 > span::before {
    content: '';
    position: absolute;
    background: url('../images/../images/secbnn_icon1.png') center no-repeat;
    background-size: cover;
    width: 120px;
    height: 134px;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}
.under main h2 > span::after {
    content: '';
    position: absolute;
    background: url('../images/../images/secbnn_icon2.png') center no-repeat;
    background-size: cover;
    width: 120px;
    height: 64px;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}
.under main h2 > span span {
    padding:4px 20px 10px;
    display: inline-block;
    margin: 10px 0;
    border: solid 3px var(--mcolor);
    position: relative;
    text-align: center;
    border-radius: 3px;
    background: #fff;
    max-width: 100%;
}
.under main h2 > span span:after, .under main h2 > span span:before {
    content: "";
    position: absolute;
    bottom: -7px;
    background: var(--mcolor);
    border: solid 2px var(--mcolor);
    width: 25px;
    height: 20px;
    z-index: -1;
}
.under main h2 > span span:after {
    left: 2px;
    transform: rotate(120deg);
}
.under main h2 > span span:before {
    right: 2px;
    transform: rotate(60deg);
}
/*==========================================================                    MAIN - CONTENT
==========================================================*/
.under main #content {
    padding: 0 0 80px;
}
.under main section {
    padding: 0 0 90px;
    margin-bottom: 0;
}
.under main section section {
    padding: 0 0 50px;
    margin-bottom: 0 !important;
}
.under main section:last-child {
    padding: 0;
}
.under main ol li {
    list-style: decimal;
}
.under main section > *:last-child {
    margin-bottom: 0;
}
.under main .image_c {
    text-align: center;
}
.under main p {
    margin-bottom: 30px;
}
.under main .d_flex {
    display: flex;
    gap: 50px;
}
.under main .d_flex.col3 {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px 27px
}
/* LINK + BUTTON TOP */
.under main .link {
    text-decoration: underline;
    color: var(--mcolor);
}
/*============ TOP INFO ============ */
.under main #top_info {
    background: url(../images/umainvs.jpg) no-repeat center;
    background-size: cover;
    position: relative;
    z-index: 1;
    min-height: 392px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding-top: 22px;
    padding-bottom: 22px;
    margin-bottom: 0;
}
.under#blog main #top_info{ background-image: url(../images/umainvs_blog.jpg);}
.under main #top_info .inner {
    position: static;
    ;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
}
/*==========================================================                  T O P I C   P A T H
==========================================================*/
.under main #topic_path {
    margin-bottom: 0;
}
.under main #topic_path ul {
    display: block;
    padding: 15px 0 30px;
}
.under main #topic_path li {
    display: inline;
    position: relative;
}
.under main #topic_path li:not(:last-child)::after {
    content: ">";
    position: relative;
    display: inline-block;
    margin: 0 5px 0 10px;
    top: -1px;
    pointer-events: none;
}
.under main #topic_path li {
    color: var(--mcolor);
}
/*============ LIST ANCHOR LINK ============ */
.under main .list_anchor {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    margin-bottom: 0;
}
.under main .list_anchor .btn a {
    height: 50px;
    font-size: 16px;
}
.under main .list_anchor .btn {
    margin: 0 10px;
}
.under main .list_anchor .btn a.active {
    background-color: #fff;
    color: var(--mcolor);
    border: 1px solid var(--mcolor);
}
.under main .list_anchor:last-child {
    margin-bottom: -15px;
}
/*==========================================================                      T A B L E
==========================================================*/
.under main table.td_top td {
    vertical-align: top;
}
.under main table.tb_fix {
    table-layout: fixed;
}
.under main table {
    margin-bottom: 30px;
}
.under main table.mailform th, .under main table th {
    background: var(--mcolor);
    color: #fff;
    font-weight: 700;
    font-size: 18px;
}
.under main table.mailform th span {
    color: #fff;
}
.under main table.mailform td .info {
    color: var(--mcolor);
}
.under main table td {
    border-color: var(--mcolor);
    background: #fff;
}
.under main .tb_scroll table td.bg_blue {
    background: var(--mcolor);
    color: #fff;
    border-top: 1px solid #fff;
}
.under main .tb_scroll.col10 table {
    width: 1200px;
}
.under main table .bg_blue {
    border-color: var(--mcolor);
    border-top: 1px solid #fff;
    border-bottom: 0;
}
.under main .tb_scroll table tr:last-child .bg_blue {
    border-bottom: 1px solid var(--mcolor);
}
.under main table .bb_none {
    border-bottom: 0;
}
.under main table th, .under main table td {
    padding: 15px 10px;
}
.under main table img {
    display: block;
    margin: auto;
}
.under main table th {
    border-color: var(--mcolor);
    border-right-color: #fff;
}
.under main table tr th:first-child {
    border-left-color: var(--mcolor);
}
.under main table tr th:last-child {
    border-right-color: var(--mcolor);
}
.under main table.mailform th, .under main table.tb_block th {
    border-color: var(--mcolor);
    border-bottom-color: #fff;
}
.under main table.mailform tr:first-child th, .under main table.tb_block tr:first-child th {
    border-top-color: var(--mcolor);
}
.under main table.mailform tr:last-child th, .under main table.tb_block tr:last-child th {
    border-bottom-color: var(--mcolor);
}
/*============ LIST ============ */
/* LIST 01 */
.under main .list01 {
    margin-bottom: 20px;
}
.under main .list01.list01_bg {
    background-color: #eeeeee;
    padding: 20px;
}
.under main .list01 li {
    display: block;
    padding-left: 35px;
    margin-bottom: 5px;
    position: relative;
}
ul.list01 {
    list-style: none;
}
ul.list01 li {
    position: relative;
    padding: 0;
    margin-bottom: 5px;
    line-height: 1.8em;
}
ul.list01 li:after, ul.list01 li:before {
    position: absolute;
    content: "";
    transform: rotate(45deg);
}
ul.list01 li:before {
    top: 7px;
    left: 2px;
    width: 12px;
    height: 12px;
    border: 2px solid var(--mcolor);
}
ul.list01 li:after {
    top: 9px;
    left: 10px;
    width: 14px;
    height: 14px;
    background: rgba(0, 70, 128, 0.5);
    transform: rotate(60deg);
}
/* LIST 02 */
.under main .list02 {
    margin-bottom: 20px;
}
.under main .list02 li {
    counter-increment: li;
    padding-left: 30px;
    position: relative;
    margin-bottom: 10px;
}
.under main .list02 li::before {
    content: counter(li);
    position: absolute;
    width: 22px;
    height: 22px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    left: 0;
    top: 2px;
    background-color: var(--mcolor);
    font-size: 12px;
    font-weight: bold;
    color: #FFF;
    line-height: 22px;
}
/* LIST CHECK */
.under main .list_check {
    margin-bottom: 30px;
}
.under main .list_check li {
    display: block;
    padding-left: 25px;
    margin-bottom: 5px;
    position: relative;
}
.under main .list_check li::before {
    content: "";
    display: block;
    position: absolute;
    top: 5px;
    left: 5px;
    width: 7px;
    height: 15px;
    border: solid var(--mcolor);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
/* LIST FAQ */
.under main .list_faq {
    margin-bottom: 30px;
}
.under main .list_faq dl {
    background: #FFF;
    padding: 15px;
    box-shadow: 0px 4px 13px rgba(0, 0, 0, 0.2);
    margin-bottom: 50px;
}
.under main .list_faq dt {
    position: relative;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.5em;
    margin-bottom: 10px;
    border-bottom: 1px dotted var(--mcolor);
    display: flex;
    align-items: center;
    display: flex;
    align-items: center;
    padding-bottom: 15px;
}
.under main .list_faq dt span {
    width: 40px;
    height: 40px;
    font-weight: bold;
    text-align: center;
    line-height: 1em;
    background: #fff;
    border: 1px solid var(--mcolor);
    color: var(--mcolor);
    margin-right: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding-bottom: 5px;
    flex-shrink: 0;
}
.under main .list_faq dd {
    position: relative;
    padding-left: 55px;
    min-height: 62px;
    padding-top: 9px;
}
.under main .list_faq dd span {
    position: absolute;
    top: 5px;
    left: 0;
    width: 40px;
    height: 40px;
    font-weight: bold;
    text-align: center;
    line-height: 1em;
    color: #fff;
    background: var(--mcolor);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding-bottom: 5px;
    flex-shrink: 0;
}
/* LIST STEP */
.under main .list_step dl {
    margin-bottom: 35px;
    padding-bottom: 50px;
    position: relative;
}
.under main .list_step dl:not(:last-child)::before {
    background: url("../images/ic-step.png") center/cover no-repeat;
    width: 80px;
    height: 30px;
    position: absolute;
    bottom: -10px;
    left: calc(50% - 40px);
    content: "";
}
.under main .list_step dl:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
}
.under main .list_step dt {
    background: var(--mcolor);
    color: #fff;
    font-weight: 500;
    padding: 10px;
}
.under main .list_step dd {
    padding: 15px;
    background: #fff;
    box-shadow: 0 5px 8px rgba(0, 0, 0, 0.15);
}
/*============ FRAME ============ */
/* FRAME 01 */
.under main .frame01 {
    border: 3px solid var(--mcolor);
    padding: 30px;
    background: url("../images/frame01_bg.jpg") repeat;
    border-radius: 10px;
    margin-bottom: 50px;
}
.under main .frame01 .ttl {
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 10px;
}
.under main .fs2px {
    font-size: 19px;
}
/* FRAME 02 */
.under main .frame02 {
    border: 1px solid #e6e6e6;
    padding: 25px;
    margin-bottom: 30px;
    background-color: #fff;
}
.under main .frame02.have_bg {
    background: url('../images/sell_img13.jpg') center bottom -40px no-repeat;
    background-size: cover;
    min-height: 280px;
    display: flex;
}
/* FRAME PICKUP */
.under main .frame_pick {
    padding: 25px;
    background: #e6e6e6;
    margin-bottom: 50px;
}
.under main .frame_pick .pick_ttl {
    font-size: 24px;
}
.under main .frame_pick .pick_ttl span {
    font-size: 36px;
    display: block;
}
/* IFRAME BOX */
.under main .box_map {
    width: 100%;
    height: 400px;
}
.under main .box_ytb {
    width: 900px;
    height: auto;
    margin: 0 auto;
    aspect-ratio: 16/9;
    max-width: 100%;
}
.under main .box_map iframe, .under main .box_ytb iframe {
    width: 100%;
    height: 100%;
    border: none;
    outline: none;
}
/* ===========  KIJIKAKU ===========  */
.under main .kiji_list {
    margin-top: 50px;
}
.under main .kiji_list dl {
    display: flex;
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px dashed #ccc;
}
.under main .kiji_list dt {
    display: flex;
    align-items: center;
    width: 150px;
}
.under main .kiji_list dt img {
    margin-right: 10px;
    position: relative;
    top: -2px;
}
.under main .kiji_list dd {
    width: calc(100% - 150px);
    display: flex;
    align-items: center;
}
.under main .kiji_list dd a {
    display: inline-block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}
.under main .kiji_detail_ct img {
    max-width: 800px;
    max-height: 600px;
}
/* ===========  PAGINATION ===========  */
.under main .pagination {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    text-align: center;
    margin: 30px auto 0;
}
.under main .pagination li {
    margin: 0 10px;
}
.under main .pagination li a {
    width: 40px;
    height: 40px;
    text-align: center;
    border: 1px solid var(--mcolor);
    background: #fff;
    display: flex;
    color: var(--mcolor);
    justify-content: center;
    align-items: center;
    border-radius: 5px;
}
.under main .pagination li:hover a, .under main .pagination li.active a {
    background: var(--mcolor);
    color: #fff;
}
.under main .pagination li.active a {
    pointer-events: none;
}
.under main .pagination li.disabled {
    display: none;
}
/* ===========  PAGINATION WP ===========  */
.under main .wp_pagination {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 40px;
}
.under main .wp_pagination > span, .under main .wp_pagination a {
    min-width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    color: #fff;
    margin: 5px;
    text-align: center;
    font-weight: 500;
    line-height: 1em;
    transition: all 0.3s;
    padding: 5px;
    border: 1px #ccc solid;
    font-size: 14px;
    background: #ccc;
}
.under main .wp_pagination a {
    color: var(--txt);
}
.under main .wp_pagination > span {
    background: var(--mcolor);
    border: 1px var(--mcolor) solid;
    color: #fff;
}
/*==========================================================                   EDITOR WORDPRESS + ovn
==========================================================*/
.u_editor::after {
    content: "";
    display: table;
    clear: both;
}
.u_editor div {
    font-size: 16px;
}
.u_editor div p {
    font-size: 100%;
    font-family: var(--f-nts) !important;
}
.u_editor div p s {
    text-decoration: none;
}
.u_editor div p s span {
    text-decoration: line-through;
    background-color: transparent !important;
}
.u_editor .clearfix:not(:last-child) {
    margin-bottom: 40px;
}
/* Blockquote */
.u_editor blockquote {
    border-left: 4px solid #ccc;
    padding-left: 1em;
    margin: 1em 0;
    color: var(--txt);
    font-style: italic;
}
.u_editor blockquote cite {
    display: block;
    font-style: normal;
    margin-top: 0.5em;
    color: #999;
}
/* Caption */
.u_editor .wp-caption {
    max-width: 100%;
    text-align: center;
    margin-bottom: 1.5em;
}
.u_editor .wp-caption:last-child {
    margin-bottom: 0;
}
.u_editor .wp-caption img {
    margin: 0 auto;
    border: 0;
}
.u_editor .wp-caption-text {
    font-size: 16px;
    color: var(--txt);
    margin-top: 0.5em;
    font-weight: 500;
}
/* Horizontal line */
.u_editor hr {
    border: none;
    border-top: 1px solid #ccc;
    margin: 2em 0;
}
/* Text align */
.u_editor .has-text-align-center {
    text-align: center;
}
.u_editor .has-text-align-right {
    text-align: right;
}
.u_editor .has-text-align-left {
    text-align: left;
}
/* Gutenberg-specific */
.u_editor .wp-block-image {
    margin: 1.5em 0;
}
.u_editor .wp-block-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
    margin: 1.5em 0;
}
.u_editor .wp-block-quote {
    border-left: 4px solid #ccc;
    padding-left: 1em;
    color: #555;
    font-style: italic;
}
.u_editor .wp-block-quote cite {
    display: block;
    font-style: normal;
    margin-top: 0.5em;
    color: #999;
}
.u_editor .wp-block-table td, .u_editor .wp-block-table th {
    border: 1px solid #ccc;
    padding: 0.5em;
}
.u_editor .list02 li {
    list-style-type: none;
    line-height: 1em;
}
.u_editor .list01 li {
    line-height: 1em;
}
.u_editor .list02 li::before {
    top: 7px !important;
}
.u_editor ul.list01 li:before {
    top: 10px;
}
.u_editor ul.list01 li:after {
    top: 10px;
}
.alignright, .alignleft {
    margin-bottom: 30px;
    max-width: 300px !important;
}
.aligncenter {
    display: block !important;
    margin: 0 auto;
}
@media screen and (min-width: 751px) {
    .alignleft {
        float: left;
        margin-right: 30px;
    }
    .alignright {
        float: right;
        margin-left: 30px;
    }
}
@media screen and (max-width: 750px) {
    .alignleft, .alignright {
        margin-left: auto;
        margin-right: auto;
        display: block;
    }
}
/* RESET */
.under main table:last-child, .under main .list_faq:last-child, .under main .list_faq dl:last-child, .under main .list01:last-child, .under main .list01 li:last-child, .under main .list02:last-child, .under main .list02 li:last-child, .under main .list_check:last-child, .under main .list_check li:last-child, .under main .list_step:last-child, .under main .list_step dl:last-child, .under main section p:last-child, .under main p:last-child, .under main .frame01:last-child, .under main .frame02:last-child, .under main .frame_pick:last-child {
    margin-bottom: 0;
}
.under main p {
    margin-bottom: 20px;
}
.under main #top_info * {
    color: #fff;
}
.under main .tb_block h5 {
    display: block;
    color: #fff;
    margin-bottom: 10px;
    padding-bottom: 0;
}
.under main .tb_block.left th {
    text-align: left;
}
.under main .tb_block.column2 tbody {
    display: flex;
}
.under main .tb_block.column2 tr {
    display: flex;
    flex-direction: column;
    width: 50%;
}
.under main .tb_block.column2 tr th {
    width: 100%;
    border-bottom: 0;
}
.under main .col2, .under main .col3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 60px;
    max-width: 940px;
    margin: 0 auto;
}
.under main .col2 .img, .under main .col3 .img {
    margin-bottom: 20px;
    text-align: center;
}
.under main .col2 .ttl, .under main .col3 .ttl {
    font-size: 20px;
    margin-bottom: 20px;
    color: #004680;
    text-align: center;
    font-weight: 700;
}
.under main .col3.circle_img img {
    width: 300px;
    border-radius: 50%;
}
.under main .col3.circle_img.shop_staff img {
    width: 270px;
    border-radius: 0;
}
.under main .shop_staff .item .img {
    transition: 0.3s ease-in-out;
}
.under main .shop_staff .item .item_ttl span {
    font-size: 80%;
}
.under main .shop_staff .item .desc {
    display: none;
    margin-top: 15px;
}
.under main .col3.circle_img h5 {
    font-size: 21px;
    text-align: center;
    border-bottom: 0;
}
.under main .col3.circle_img .item_ttl {
    font-size: 18px;
    color: var(--mcolor);
    margin-bottom: 0;
    line-height: 1.4;
    font-weight: bold;
    font-family: var(--f-nts);
    text-align: center;
}
.under main .col3.circle_img {
    max-width: 1080px;
}
.under main .circle_img .item > *:last-child {
    margin-bottom: 0;
}
.under main .col2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}
.under main .title_page {
    max-width: 1000px;
    margin: 0 auto;
}
.under main .tb_block h4 {
    padding-left: 0;
    margin-bottom: 10px;
}
.under main .tb_block td > *:not(:last-child) {
    margin-bottom: 10px;
}
.under main .toc-002 {
    margin-bottom: 0;
    border: 2px solid var(--mcolor);
    border-radius: 3px;
    position: relative;
}
.under main .toc-002 div {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 10px 0;
    background-color: var(--mcolor);
    color: #fff;
    font-weight: 600;
    font-size: 1.1em;
    cursor: pointer;
    transition: 0.2s ease-in-out;
}
.under main .toc-002 div::before {
    display: inline-block;
    width: 1.8em;
    height: 1.8em;
    margin-right: 5px;
    background-image: url(../images/toc.svg);
    content: "";
}
.under main .toc-002 ol {
    list-style-type: decimal;
    margin: 0;
    overflow: hidden;
    position: relative;
}
.under main .toc-002 ol ol {
    margin-top: 5px;
    padding-left: 1.1em;
}
.under main .toc-002 ol ol li {
    font-weight: 500;
    font-size: 0.9em;
}
.under main .toc-002 ol ol li a::before {
    width: 6px;
    height: 6px;
    top: 8px;
}
.under main .toc-002 li {
    padding: 5px 0;
    font-weight: 600;
    list-style-type: none;
    line-height: 1.5em;
}
.under main .toc-002 > ol {
    background-color: #fff;
    padding: 1.5em 1em 1.5em 10em;
    display: none;
}
.under main .toc-002 > ol li a {
    position: relative;
    padding-left: 15px;
    display: inline-block;
}
.under main .toc-002 > ol li a::before {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    background-color: var(--mcolor);
    left: 0;
    border-radius: 50%;
    top: 9px;
}
.under main .toc-002 a {
    color: #333;
    text-decoration: none;
}
.under main .toc-button {
    pointer-events: none;
    margin: 0;
    position: absolute;
    right: 10px;
    top: 9px;
    background: #fff;
    width: 70px;
    text-align: center;
    border-radius: 5px;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 14px;
    font-weight: 700;
    padding: 6px 5px 5px;
    overflow: hidden;
}
.under main .toc-button.active:before {
    content: "閉じる";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-family: var(--font-family);
    background: #fff;
}
.under main .uFlex {
    --width-img: 392px;
    --space-cnt: 60px;
    display: flex;
    position: relative;
    justify-content: center;
    z-index: 1;
    min-height: 252px;
    width: 100%;
    padding-right: calc(var(--width-img) + var(--space-cnt));
    margin-bottom: 50px;
    flex-direction: column;
}
.under main .uFlex_wrap {
    padding-right: 0;
    padding-left: calc(var(--width-img) + var(--space-cnt));
}
.under main .uFlex_wrap .img {
    right: unset !important;
    left: 0;
}
.under main .uFlex .img {
    position: absolute;
    height: max-content;
    width: calc(var(--width-img));
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    text-align: center;
}

.under main .uFlex .img.image_c_bnr {
    width: 450px;
}
.under main .cnt > *:not(:last-child) {
    margin-bottom: 30px;
}
.under main .cnt p a {
    color: var(--mcolor);
    text-decoration: underline;
}
.under main .cnt p + section {
    margin-top: 50px;
}
.under main .uPoint {
    --space-left: 170px;
    counter-reset: section;
    padding-left: var(--space-left);
    position: relative;
    z-index: 1;
    width: 1040px;
    margin: 0 auto;
    max-width: 100%;
}
.under main .uPoint::before {
    content: "";
    width: 15px;
    height: 100%;
    background: #eee;
    margin-left: -8px;
    display: block;
    position: absolute;
    top: 0;
    left: var(--space-left);
}
.under main .uPoint .item .ttl {
    margin-bottom: 15px;
    line-height: 1.4em;
    border-bottom: 0 !important;
}
.under main .uPoint .item:not(:last-child) {
    padding-bottom: 45px;
    margin-bottom: 23px;
}
.under main .uPoint.no-arrow .item::before {
    display: none;
}
.under main .uPoint.no-arrow .item {
    padding-bottom: 0 !important;
}
.under main .uPoint.only_title .item .ttl {
    border-bottom: 0;
    padding-bottom: 0;
}
.under main .uPoint.only_title .item {
    padding-top: 6px;
    margin-bottom: 10px !important;
    min-height: 47px;
}
.under main .uPoint.only_title .item::before, .under main .uPoint.only_title .item::after {
    top: 24px;
}
.under main .uPoint.only_title .item > *:last-child {
    margin-bottom: 0;
}
.under main .uPoint.have_dc {
    padding-right: 120px;
}
.under main .uPoint.have_dc::after {
    content: '';
    position: absolute;
    background: url('../images/souzoku_img10.png') center no-repeat;
    background-size: cover;
    right: 0;
    bottom: 0;
    width: 110px;
    height: 106px;
}
.under main .uPoint .item {
    position: relative;
    z-index: 1;
    padding-left: 70px;
}
.under main .uPoint .item::before, .under main .uPoint .item::after {
    content: "";
    display: block;
    position: absolute;
    top: 22px;
}
.under main .uPoint .item::before {
    width: 9px;
    height: 9px;
    margin-top: 0;
    background: var(--mcolor);
    border-radius: 50%;
    left: -5px;
    margin-top: -4px;
}
.under main .uPoint .item::after {
    width: 50px;
    border-bottom: 1px dashed #999;
    position: absolute;
    left: 5px;
}
.under main .uPoint .item .ttl {
    display: flex;
    font-size: 26px;
    letter-spacing: 0.1em;
    font-weight: 600;
    color: var(--mcolor);
    padding-bottom: 10px;
    border-bottom: 1px solid var(--mcolor);
    margin-bottom: 10px;
}
.under main .uPoint .item .ttl strong span {
    font-weight: 400;
}
.under main .uPoint .item .ttl > span {
    display: block;
    width: 128px;
    height: 47px;
    background-color: var(--mcolor);
    font-weight: 400;
    font-family: var(--f-arial);
    font-size: 16px;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px 7px;
    letter-spacing: 0.1em;
    position: absolute;
    z-index: 1;
    top: 0;
    left: calc(var(--space-left) * -1);
}
/* .under main .uPoint .item p.ttl > span {top: 5px;} */
.under main .uPoint .item .ttl > span::before {
    content: "";
    border-style: solid;
    border-width: 10px 0 10px 15px;
    border-color: transparent transparent transparent var(--mcolor);
    position: absolute;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.under main .uPoint .item .ttl > span .num {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    top: -1px;
}
.under main .uPoint .item .ttl > span .num::before {
    counter-increment: section;
    content: "0"counter(section);
    font-size: 24px;
    font-family: var(--f-arial);
    color: #fff;
    margin-left: 4px;
}
.under main .uPoint .item:nth-child(n+10) .ttl > span .num::before {
    content: counter(section);
}
.under main .uPoint .item:not(:last-child) {
    padding-bottom: 15px;
    margin-bottom: 15px;
}
.under main .frame03 {
    background: var(--mcolor);
    padding: 0 30px 30px;
}
.under main .frame03_ct {
    background: #fff;
    padding: 30px 30px 30px;
}
.under main .frame03 h3 {
    text-align: center;
    color: #fff;
    margin: -30px -30px 30px;
    background: var(--mcolor);
    padding: 30px;
    display: block;
}
.under main .frame03 .big_ttl {
    background: rgba(0, 70, 128, 0.5);
    padding: 10px 20px;
    font-weight: bold;
    font-size: 20px;
    margin-bottom: 20px;
    color: #fff;
}
.under main .frame_bg {
    background: rgba(0, 70, 128, 0.5);
    padding: 30px;
}
.under main .under_col_list {
    max-width: 880px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    justify-content: center;
    counter-reset: col;
    gap: 30px;
}
.under main .under_col_list dl {
    width: calc((100% - 40px) / 2);
    background: #fff;
    border: 5px solid var(--mcolor);
    position: relative;
    padding: 20px;
    text-align: center;
}
.under main .under_col_list dl:before {
    counter-increment: col;
    content: counter(col);
    position: absolute;
    left: -1px;
    top: -1px;
    font-size: 30px;
    font-weight: 700;
    background: var(--mcolor);
    color: #fff;
    width: 80px;
    height: 70px;
    clip-path: polygon(0 0, 0 100%, 100% 0);
    text-align: left;
    padding: 0 0 0 13px;
}
.under main .under_col_list dt {
    margin: 0 auto;
    max-width: 180px;
}
.under main .ttl_big {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
}
.under main .balloon_frame {
    display: flex;
    align-items: center;
    gap: 80px;
    margin: 0 auto;
}
.under main .balloon_frame:not(:last-child) {
    margin-bottom: 50px;
}
.under main .balloon_frame_wrap {
    flex-direction: row-reverse;
}
.under main .balloon_frame_wrap .mes::before {
    transform: rotate(138deg) !important;
    left: calc(100% - 18px);
}
.under main .balloon_frame .img {
    flex-shrink: 0;
    margin-bottom: 0;
}
.under main .balloon_frame .box {
    background-color: var(--mcolor);
    color: #fff;
    font-weight: bold;
    padding: 2px 10px;
    width: auto;
    margin-top: -50px;
}
.under main .balloon_frame .mes {
    padding: 30px;
    border: 2px solid var(--mcolor);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    border-radius: 50px;
    position: relative;
    z-index: 1;
}
.under main .balloon_frame .mes::before {
    content: "";
    position: absolute;
    width: 37px;
    height: 36px;
    background-color: #fff;
    border-left: 2px solid var(--mcolor);
    border-top: 2px solid var(--mcolor);
    transform: rotate(-48deg);
    right: calc(100% - 18px);
    bottom: 30%;
}
.under main .list-river {
    width: max(100vw, 1260px);
}
.under main .list-river img {
    width: 477px;
}
.under main .list-river li {
    margin: 0 !important;
}
.under main .umap iframe {
    width: 100%;
    height: 300px;
}
.under main .ovn_list dl {
    display: flex;
}
.under main .hidden {
    display: none;
}
#notfound .btn a {
    height: 50px;
    font-size: 16px;
}
.under main table th {
    font-size: 16px;
}
.under main .udr_post {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}
.under main .udr_post dl {
    width: calc(33.3333333333% - 20px);
    border: 1px solid #f5f5f5;
    box-shadow: 5px 5px 0 var(--mcolor);
    padding: 15px;
    border-radius: 15px;
    transition: 0.2s linear;
}
.under main .udr_post dl dt {
    margin-bottom: 10px;
    text-align: center;
    overflow: hidden;
}
.under main .udr_post img {
    max-height: 233px;
    width: auto;
}
.under main .udr_post .cat_date {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
    gap: 10px;
}
.under main .udr_post .cat_date span {
    font-size: 14px;
}
.under main .udr_post .cat_date .cate {
    background-color: var(--mcolor);
    padding: 1px 8px 2px;
    color: #fff;
}
.under main .udr_post .tt {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}
.under main .img-center {
    text-align: center;
    width: 560px;
    max-width: 100%;
    margin: 0 auto 30px;
}
.under main .img-center img {
    margin: 0 auto;
    max-height: 400px;
}
.under main .btn_ovn {
    display: flex;
    justify-content: center;
    gap: 30px;
}
.under main .btn_ovn p a {
    height: 50px;
    font-size: 16px;
}
.under main .btn_ovn p {
    margin-bottom: 0;
}
.under main .prevPage a {
    background: url(../images/icon_btn_back.png) no-repeat left 20px center/8px 16px var(--mcolor);
}
.under main .nextPage a {
    background: url(../images/ic-right.png) no-repeat right 20px center/8px 16px var(--mcolor);
}
.under main .uTable_block h4 {
    margin-bottom: 0;
    padding-left: 0;
    font-size: 28px;
}
.under main .uTable_block h4::before {
    display: none;
}
.under main .list_anchor .btn a {
    height: 50px;
    font-size: 16px;
}
.under main .uTable_block .tb_block th {
    text-align: center;
}
#change.under main #top_info {
    background: url(../images/umainvs_change.jpg) no-repeat center;
    background-size: cover;
}
#rental.under main #top_info {
    background: url(../images/umainvs_rental.jpg) no-repeat center;
    background-size: cover;
}
#loan.under main #top_info {
    background: url(../images/umainvs_loan.jpg) no-repeat center;
    background-size: cover;
}
#price.under main #top_info {
    background: url(../images/umainvs_price.jpg) no-repeat center;
    background-size: cover;
}
#souzoku.under main #top_info {
    background: url(../images/umainvs_souzoku.jpg) no-repeat center;
    background-size: cover;
}
#case.under main #top_info {
    background: url(../images/umainvs_case.jpg) no-repeat center;
    background-size: cover;
}
#advantage.under main #top_info {
    background: url(../images/umainvs_advantage.jpg) no-repeat center;
    background-size: cover;
}
#shop.under main #top_info {
    background: url(../images/umainvs_shop.jpg) no-repeat center;
    background-size: cover;
}
#sell.under main #top_info {
    background: url(../images/umainvs_sell.jpg) no-repeat center;
    background-size: cover;
}
#contact.under main #top_info {
    background: url(../images/umainvs_contact.jpg) no-repeat center;
    background-size: cover;
}
#recruit.under main #top_info {
    background: url(../images/umainvs_recruit.jpg) no-repeat center;
    background-size: cover;
}
#knowledge.under main #top_info {
    background: url(../images/umainvs_knowledge.jpg) no-repeat center;
    background-size: cover;
}
#point.under main #top_info {
    background: url(../images/umainvs_point.jpg) no-repeat center;
    background-size: cover;
}
#empty.under main #top_info {
    background: url(../images/umainvs_empty.jpg) no-repeat center;
    background-size: cover;
}
.under main .intro {
    text-align: center;
}
.under main .list_img.col4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
.under main .list_img.col4 .item a {
    display: block;
    border: 1px solid #000;
    transition: .2s ease-in-out;
    margin-bottom: 10px;
}
.under main .list_img.col4 .item p {
    text-align: center;
    line-height: 1.5em;
}
.under main .list01_custom {
    justify-content: center;
    gap: 100px;
}
.under main .sec_bg {
    position: relative;
    z-index: 1;
    padding: 30px 0 !important;
}
.under main .sec_bg::before {
    content: '';
    position: absolute;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px, #e9f4ff 3px, #e9f4ff 7px);
    ;
    width: 100vw;
    height: 100%;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.under main .list_link {
    display: flex;
    gap: 100px;
    justify-content: center;
}
.under main .list_link_frame ul {
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.under main .list_link a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    line-height: 1.5em;
}
.under main .list_link a .img {
    width: 120px;
    flex-shrink: 0;
}
.under main .list_link a .txt {
    text-decoration: underline;
    text-underline-offset: 5px;
}
.under main .frame_bnn {
    margin-top: 80px;
}
.under main .frame_bnn .btn a {
    height: 50px;
    font-size: 16px;
}
.under main .staff_anc {
    max-width: 800px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px 10px;
    margin: 0 auto 50px;
}
.under main .staff_anc .item {
    width: calc((100% / 4) - 40px);
}
.under main .staff_anc .img {
    text-align: center;
    margin-bottom: 10px;
    display: block;
}
.under main .staff_anc .img img {
    width: 100px;
    aspect-ratio: 1/1;
    border-radius: 50%;
    object-fit: cover;
}
.under main .staff_anc .name {
    text-align: center;
    display: block;
    font-size: 16px;
    font-weight: bold;
}
.under main .image_c_bnr {
    position: relative;
    z-index: 1;
    ;
    text-align: center;
    width: max-content;
    margin: 0 auto;
}
.under main .image_c_bnr a {
    position: absolute;
    bottom: 0;
    left: 150px;
    width: 300px;
    border: 1px solid var(--mcolor);
    display: block;
    padding: 10px;
    border-radius: 10px;
}
/* .under main .case_box_table {
    width: calc(100% + 15px);
    max-height: 1027px;
    overflow-y: auto;
} */
.under main .box_col3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}
.under main .box_col3 .img {
    text-align: center;
    height: 200px;
}
.under main .box_col3 .img img {
    width: auto;
    height: 100%;
}
.under main .box_col3 h4 {
    font-size: 22px;
    letter-spacing: -0.05em;
    text-align: center;
    margin-bottom: 15px;
}
.under main .box_col3 h4::before {
    display: none;
}

.under main .contact_btn .custom_tel .time::before {
    display: none;
}
.under main .contact_btn .h_contact_tel {
    margin-bottom: 0;
}
.under main .contact_btn .h_contact_tel * {
    color: var(--mcolor);
}
.under main .contact_btn .h_contact_tel a {
    font-size: 45px;
}
.under main .contact_btn .h_contact_tel .time {
    font-size: 16px;
    letter-spacing: 0.05em;
}
.under main .contact_btn .h_contact_tel .tel_sub {
    line-height: 1.5em;
}
.under main .contact_btn .h_contact_tel a span {
    background: url(../images/ic_tel_clr.png)left top 9px / 48px 31px no-repeat;
    padding-left: 50px;
}
.under main .contact_btn .h_contact_line a {
    width: 320px;
    height: 80px;
    font-size: 22px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.under main .contact_btn .h_contact_line a::before {
    left: 50px;
}
.under main .contact_btn .h_btn .box {
    padding: 2px 10px 4px;
}
.under main .contact_btn.sec_bg::before {
    width: 100%;
}
.under main .link_normal {
    text-decoration: underline;
    text-underline-offset: 5px;
}
.under main .intro_custom {
    text-align: left;
}
.under main .have_decore {
    position: relative;
    z-index: 1;
}
.under main .have_decore .sell_dc {
    position: absolute;
    top: -80px;
    right: 0;
}
.under main .box_col3_empty section {
    border: 4px solid var(--mcolor);
}
.under main .uPoint_type2 {
    counter-reset: section_sel;
    width: 1040px;
    max-width: 100%;
    margin: 0 auto
}
.under main .uPoint_type2 .item {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 30px;
    border: 2px solid var(--mcolor);
    padding: 20px;
    border-radius: 10px;
    background-color: #fff;
}
.under main .uPoint_type2 .item::before {
    content: '';
    position: absolute;
    background-color: #fff;
    width: 30px;
    height: 30px;
    transform: rotate(45deg);
    border: 2px solid var(--mcolor);
    border-top: 0;
    border-left: 0;
    left: 0;
    right: 0;
    bottom: -16px;
    margin: auto;
    z-index: -1;
}
.under main .uPoint_type2 .item::after {
    content: '';
    position: absolute;
    background-color: #fff;
    width: 50px;
    height: 30px;
    left: 0;
    right: 0;
    bottom: 0px;
    margin: auto;
    z-index: -1;
}
.under main .uPoint_type2 .item:not(:last-child) {
    margin-bottom: 50px;
}
.under main .uPoint_type2 .item:last-child::before {
    display: none;
}
.under main .uPoint_type2 .item .ttl {
    width: 200px;
    max-width: 100%;
    text-align: center;
    font-size: 18px;
    margin-bottom: 0;
    flex-shrink: 0;
}
.under main .uPoint_type2 .item h4 > span {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background-color: var(--mcolor);
    text-align: center;
    padding: 1px 10px 3px;
    border-radius: 60px;
    margin-bottom: 8px;
}
.under main .uPoint_type2 .item h4 span .num::before {
    counter-increment: section_sel;
    content: counter(section_sel);
    font-size: 20px;
    font-family: var(--f-arial);
    color: #fff;
    margin-left: 4px;
}

.under main .sec01 {
    background-color: transparent;
    padding-bottom: 0;
    margin-top: 50px;
}

.under main .sec01::before {
    display: none;
}

.under main .sec01 .sec01_tab .btn span {
    background-color: var(--mcolor);
    color: #fff;
}

.under main .sec01 .sec01_tab .btn.active span {
    background-color: var(--scolor);
    color: var(--mcolor);
}


/*==========================================================================*/
/*                 F O R   S P E C I F I E D   B R O W S E R                */
/*==========================================================================*/
/* EDGE  */
/* FIREFOX */
@-moz-document url-prefix() {}
/* Safari 10.1+ (which is the latest version of Safari at this time) */
@supports (-webkit-touch-callout: none) { /* CSS specific to iOS devices */
}
/*# sourceMappingURL=under.css.map */
.under main .cnt_flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.under main .cnt_flex ul.list01 {
    margin-bottom: 0;
}
.under main .txt_arrow {
    margin: 0 0 0 20px;
    position: relative;
    padding: 0 0 0 40px;
}
.under main .txt_arrow::before {
    content: '';
    position: absolute;
    top: calc((100% - 25px)/2);
    left: 0;
    width: 24px;
    height: 24px;
    background: var(--mcolor);
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.txt_arrow p {
    padding: 10px;
    background-color: #EEEEEE;
}

.under main .sys_min{font-size: 50%;transform: translateY(-90%);display: inline-block;}
.under main .txt_min{font-size: 60%;display: inline-block;transform: translateY(-7%);}
.under main .txt_min.top{transform: translateY(-30%);}
.under main .contact_cta_tt{color: #FFF;background-color: var(--mcolor);font-size: 20px;font-weight: bold;text-align: center;margin-bottom: 0;padding: 10px 10px;}
.under main .bg_green .contact_cta_tt{background-color: #00BA00;}
.under main .bg_green .contact_cta_box{border-color: #00BA00;}
.under main .contact_cta_box{padding: 20px;display: flex;flex-direction: column;justify-content: center;align-items: center;min-height: 120px;border: 1px solid var(--mcolor);border-top: 0;background-color: #FFF;}
.under main .contact_cta_box .time{display: flex;align-items: center;justify-content: space-between;}
[data-lightbox]:hover{opacity: 0.7;}
.under main .contact_sec_bg{padding: 30px 20px;position: relative;overflow: hidden;}
