@media screen and (min-width: 751px) {
  .lightbox,
  .lightboxOverlay {
    min-width: var(--container);
  }
  .under main .image_l {
    float: left;
    margin: 0 3.6% 0 -5%;
    max-width: 52%;
  }
  .under main .image_r {
    float: right;
    margin: 0 -5% 0 3.6%;
    max-width: 52%;
  }
  .under main .ttl_l, .under main .ttl_l ~ .u_float_box {
    float: left;
  }
  .under main .ttl_r, .under main .ttl_r ~ .u_float_box {
    float: right;
  }
  .under main .ttl_r, .under main .ttl_l {
    margin-top: 7px;
  }
  .under main .ttl_r, .under main .ttl_l,
  .under main .ttl_l ~ .u_float_box, .under main .ttl_r ~ .u_float_box {
    width: 49.33%;
    max-width: 700px;
  }
  /* BUTTON OVN DETAIL */
  .under main .btn_list {
    display: flex;
    justify-content: center;
    position: relative;
  }
  .under main .btn_list .is_prev {
    position: absolute;
    top: 0;
    left: 150px;
  }
  .under main .btn_list .is_next {
    position: absolute;
    top: 0;
    right: 150px;
  }
  /* HOVER */
  .under main #topic_path li a:hover {
    text-decoration: underline
  }
  .under main .bnn a:hover {
    opacity: 0.7;
  }
  .under main .link:not(a[target=_blank]):hover {
    color: var(--scolor);
  }
  #news .news_list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
  }
  #news .box_bf_af dl {
    gap: 100px;
  }
  #news .box_bf_af dl p:not(.img) {
    font-size: 20px;
  }
  #news .navigation .btn_ovn .btn {
    width: 32%;
  }
  #news .navigation .btn_ovn .btn a {
    width: 100%;
    max-width: 330px;
    margin: 0 auto;
  }
  .under main .ttl_full {
    margin-left: -30px;
    margin-right: -30px;
  }
  .under main .sec03_h3 {
    font-size: 50px;
  }
}
@media screen and (min-width: 751px) and (max-width: 1700px) {
  .under main .u_3col dl dd .tt,
  .under main .u_2col dl dt {
    font-size: 24px;
  }
}
@media screen and (min-width: 751px) and (max-width: 1500px) {
  .under main .top_info_box {
    min-width: 580px;
  }
  .under main h2 {
    font-size: 30px;
  }
  .under main h3 {
    font-size: 32px;
  }
  .under main h4 {
    font-size: 26px;
  }
  .under main .u_3col dl dd .tt, .under main .u_3col dl dt, .under main .u_2col dl dt {
    font-size: 19px;
  }
  .under main .u_2col dl dd {
    font-size: 15px;
  }
}
@media screen and (max-width: 750px) {
  .under main #content {
    padding: 0 0 80px
  }
  .under main section {
    padding: 0 0 60px;
  }
  .under main .image_r,
  .under main .image_l {
    float: none;
    display: inline-block;
    width: 100%;
    text-align: center;
    margin: 0 auto 30px !important
  }
  /*==========================================================
                  C U S T O M
  ==========================================================*/
  /*  TOP INFO  */
  .under main #content::before {
    width: 400px;
    height: 400px;
    right: -150px;
  }
  .under main #top_info {
    height: 200px;
    margin-bottom: 10px;
  }
  .under main .top_info_box {
    padding: 10px 10px 10px 5px;
    border-top-right-radius: 10px;
    min-width: 200px;
  }
  .under main #topic_path {
    margin-bottom: 10px
  }
  .under main #topic_path li,
  .under main #topic_path li a {
    font-size: 14px;
  }
  #profile main #top_info {
    background: url('../images/top_info_bg_profile_sp.jpg') no-repeat center /cover;
  }
  /*============ HEAD TITLE ============ */
  .under main h2 {
    font-size: 26px;
  }
  .under main h3 {
    font-size: 24px;
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  .under main .u_h3 .en {
    font-size: 20px;
  }
  .under main .u_box section:first-child h3 {
    padding-top: 15px;
  }
  .under main h4 {
    font-size: 22px;
    padding-bottom: 15px;
    padding-left: 20px;
  }
  .under main h4::before {
    top: 11px;
  }
  .under main h4::after {
    height: 4px;
  }
  .under main h5 {
    font-size: 20px;
  }
  .under main h6 {
    font-size: 18px;
  }
  /*============ TABLE ============ */
  .under main table {
    margin-bottom: 30px
  }
  .under main table td,
  .under main table th {
    padding: 10px 15px
  }
  .under main table.tb_block tr {
    display: flex;
    flex-direction: column
  }
  .under main table.tb_block tr:not(:last-child) th {
    border-bottom: none
  }
  .under main table.tb_block td + td {
    border-top: none;
  }
  .under main table.tb_block th,
  .under main table.tb_block td {
    width: 100%;
  }
  .under main table.mailform th, .under main table th {
    font-size: 16px;
  }
  /* TABLE SCROLL */
  .under main .tb_scroll {
    overflow: scroll;
  }
  .under main .tb_scroll:not(:last-child) {
    margin-bottom: 30px;
  }
  .under main .tb_scroll table {
    width: 800px;
  }
  .under main .tb_note {
    margin-bottom: 10px;
    color: #999;
  }
  .under main .u_box {
    padding: 30px 0;
  }
  .under main .u_box:not(:last-child) {
    margin-bottom: 50px;
  }
  .under main .u_float_box {
    padding: 25px 15px;
  }
  .under main .u_float_box .btn a {
    margin-left: auto;
    margin-right: auto;
  }
  .under main .u_3col, .under main .u_2col {
    grid-template-columns: repeat(1, 1fr);
    grid-gap: 30px;
  }
  .under main .u_3col dl dt, .under main .u_2col dl dt {
    font-size: 20px;
  }
  .under main .u_3col dl dd {
    padding: 30px 15px;
  }
  .under main .u_3col dl dd .tt {
    font-size: 20px;
    margin-bottom: 10px;
  }
  /*============ LIST ============ */
  .under main .list01 {}
  .under main .list01 li {}
  .under main .list02 li::before {
    top: 4px;
  }
  /* LIST FAQ */
  .under main .list_faq dl {
    margin-bottom: 30px;
    padding: 15px
  }
  .under main .list_faq dt span {
    top: 3px;
  }
  .under main .list_faq dt {
    font-size: 16px;
    min-height: 50px;
    padding-bottom: 3px;
  }
  /* List STEP */
  .under main .list_step dl {
    margin-bottom: 20px;
    padding-bottom: 40px
  }
  /*============ FRAME ============ */
  .under main .frame01 {
    padding: 30px 15px
  }
  .under main .frame02 {
    padding: 30px 15px
  }
  /*============ ORTHER ============ */
  .under main .box_map {
    height: 250px
  }
  #news .news_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px 0;
    padding-top: 0;
  }
  #news .news_list .ite {
    max-width: 320px;
    width: 48%;
  }
  .news_list .img {
    margin-bottom: 12px;
  }
  .news_list .cate_date {
    margin-bottom: 12px;
  }
  .news_list .cate_date .cate {
    margin-right: 20px;
  }
  .under main .list_anchor .btn a {
    min-width: 250px;
  }
  #news .box_bf_af dl {
    gap: 40px;
  }
  #news .box_bf_af dl p:not(.img) {
    font-size: 18px;
  }
  #news .navigation .btn_ovn {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  #news .navigation .btn_ovn .btn a {
    min-width: 250px;
  }
  #news .navigation .btn_ovn p {
    margin-bottom: 0;
  }
  .under main .ttl_full {
    margin-left: -15px;
    margin-right: -15px;
  }
  .news_box {
    grid-template-columns: 1fr;
  }
  .news_box .img {
    max-height: 200px;
  }
  .news_box .img img {
    height: auto;
    max-height: 200px !important;
  }
}
@container post (max-width: 499px) {
  #news .news_list {
    justify-content: center;
  }
  #news .news_list .ite {
    width: 100%;
  }
}
@container post (max-width: 499px) {
  #news .news_list {
    justify-content: center;
  }
  #news .news_list .ite {
    width: 100%;
  }
}
@container post-content (max-width: 499px) {
  #news .box_bf_af dl {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }
  #news .box_bf_af dl .img {
    height: 200px;
  }
}
/* IPHONE 14 */
@media screen and (max-width: 440px) {
  .under main .u_2col dl dt {
    font-size: 17px;
  }
}
/* IPHONE 6 */
@media screen and (max-width: 360px) {
  .under main h2 {
    font-size: 23px
  }
  .under main h3 {
    font-size: 21px;
  }
  .under main h4 {
    font-size: 20px;
  }
}
/* IPHONE 14 */
@media screen and (475px < width < 750px) {
  .news_box {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .news_box .img {
    max-height: 27vw;
  }
  .news_box .img img {
    max-height: 27vw !important;
  }
}
/* FIREFOX ONLY */
@-moz-document url-prefix() {}
/* Safari 10.1+ (which is the latest version of Safari at this time) */
@media not all and (min-resolution: 0.001dpcm) {}