@charset "UTF-8";
@media screen and (min-width: 769px), print {
  a[href^=tel] {
    pointer-events: none;
    text-decoration: none;
    cursor: default !important;
  }
  .show_sp {
    display: none !important;
  }
  .container {
    overflow: hidden;
  }
  .row {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .row {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .inner {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  .hvr-pop {
    display: inline-block;
    vertical-align: middle;
    -webkit-transform: perspective(1px) translateZ(0);
    -moz-transform: perspective(1px) translateZ(0);
         transform: perspective(1px) translateZ(0);
    -moz-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
         box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  }
  .hvr-pop:hover, .hvr-pop:focus, .hvr-pop:active {
    -webkit-animation-name: hvr-pop;
    -moz-animation-name: hvr-pop;
         animation-name: hvr-pop;
    -webkit-animation-duration: 0.3s;
    -moz-animation-duration: 0.3s;
         animation-duration: 0.3s;
    -webkit-animation-timing-function: linear;
    -moz-animation-timing-function: linear;
         animation-timing-function: linear;
    -webkit-animation-iteration-count: 1;
    -moz-animation-iteration-count: 1;
         animation-iteration-count: 1;
  }
  .text_cm {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
  }
  body {
    padding-top: 100px;
  }
  body.NoPd {
    padding-top: 0;
  }
  .header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 99;
    padding: 62px 58px 10px 37px;
    height: 135px;
    -webkit-transition: background 0.3s;
    -moz-transition: background 0.3s;
    transition: background 0.3s;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
       -moz-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .header {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .header.header--type02 {
    height: 100px;
    background-color: #fff;
    -moz-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.08);
         box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.08);
  }
  .header.header--type02 h1 a {
    background-image: url(../img/ft_logo.png);
  }
  .header.header--type02 .header_menuSub .header_menuSub_main > li > a, .header.header--type02 .header_menuSub .header_menuSub_main > li > span {
    color: #403535;
  }
  .header.header--type02 .h_ex li a {
    color: #403535;
  }
  .header.header--type02 .h_ex li a.h_ct::before {
    background-image: url(../img/ic_mail2.png);
  }
  .header.header--type02 .h_ex li.ic_social.ic_ig a {
    background-image: url(../img/ft_ig.png);
  }
  .header.header--type02 .h_ex li.ic_social.ic_fb a {
    background-image: url(../img/ft_fb.png);
  }
  .header.header--type02 .h_ex li.ic_social.ic_yt a {
    background-image: url(../img/ft_yt.png);
  }
  .header.header--type02 .h_ex {
    top: 10px;
  }
  .header.header--type02 .header_menuSub .header_menuSub_main > li.h_shop span {
    min-height: 44px;
  }
  .header.changeBg {
    background-color: #fff;
    -moz-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.08);
         box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.08);
  }
  .header.changeBg h1 a {
    background-image: url(../img/ft_logo.png);
  }
  .header.changeBg .header_menuSub .header_menuSub_main > li > a, .header.changeBg .header_menuSub .header_menuSub_main > li > span {
    color: #403535;
  }
  .header.changeBg .h_ex li a {
    color: #403535;
  }
  .header.changeBg .h_ex li a.h_ct::before {
    background-image: url(../img/ic_mail2.png);
  }
  .header.changeBg .h_ex li.ic_social.ic_ig a {
    background-image: url(../img/ft_ig.png);
  }
  .header.changeBg .h_ex li.ic_social.ic_fb a {
    background-image: url(../img/ft_fb.png);
  }
  .header.changeBg .h_ex li.ic_social.ic_yt a {
    background-image: url(../img/ft_yt.png);
  }
  .header h1 {
    font-size: 0;
    line-height: 0;
  }
  .header h1 a {
    display: block;
    text-indent: -9999px;
    width: 114px;
    height: 63px;
    background-image: url(../img/logo.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  .header .h_ex {
    position: absolute;
    right: 58px;
    top: 30px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    z-index: 9;
  }
  .header .h_ex li:not(:last-child) {
    margin-right: 18px;
  }
  .header .h_ex li:nth-of-type(4) {
    margin-right: 36px;
    margin-left: 18px;
  }
  .header .h_ex li.ic_social a {
    display: block;
    width: 29px;
    height: 29px;
    text-indent: -9999px;
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  .header .h_ex li.ic_social.ic_ig a {
    background-image: url(../img/ic_ig.png);
  }
  .header .h_ex li.ic_social.ic_fb a {
    background-image: url(../img/ic_fb.png);
  }
  .header .h_ex li.ic_social.ic_yt a {
    width: 32px;
    height: 24px;
    background-image: url(../img/ic_yt.png);
  }
  .header .h_ex li a {
    font-weight: bold;
    font-size: 15px;
    letter-spacing: 0.05em;
    color: #fff;
  }
  .header .h_ex li a.h_ct {
    position: relative;
    padding-left: 31px;
  }
  .header .h_ex li a.h_ct::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 21px;
    height: 17px;
    background-image: url(../img/ic_mail.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    display: block;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  .header .header_menuSub {
    margin-left: auto;
  }
  .header .header_menuSub .header_menuSub_main {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 15px;
  }
  .header .header_menuSub .header_menuSub_main > li {
    position: relative;
  }
  .header .header_menuSub .header_menuSub_main > li:not(:last-child) {
    margin-right: 20px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .header .header_menuSub .header_menuSub_main > li:not(:last-child) {
    margin-right: 8px;
  }
}

@media screen and (min-width: 769px), print {
  .header .header_menuSub .header_menuSub_main > li > a, .header .header_menuSub .header_menuSub_main > li > span {
    display: block;
    font-weight: bold;
    font-size: 15px;
    letter-spacing: 0.05em;
    color: #fff;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .header .header_menuSub .header_menuSub_main > li > a, .header .header_menuSub .header_menuSub_main > li > span {
    letter-spacing: 0;
    font-size: 13px;
  }
}

@media screen and (min-width: 769px), print {
  .header .header_menuSub .header_menuSub_main > li.h_shop:hover ul {
    opacity: 1;
    visibility: visible;
  }
  .header .header_menuSub .header_menuSub_main > li.h_shop span {
    /* min-width: 231px; */
    min-width: 215px;
    min-height: 50px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #cc2929;
    -moz-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.05);
         box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.05);
    position: relative;
    padding-left: 19px;
    font-weight: bold;
    font-size: 15px;
    letter-spacing: 0.05em;
    color: #fff;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    cursor: pointer;
  }
  .header .header_menuSub .header_menuSub_main > li.h_shop span::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 13px;
    height: 8px;
    background: url(../img/ic_arb.png) center/100% 100% no-repeat;
    display: block;
  }
  .header .header_menuSub .header_menuSub_main > li ul {
    position: absolute;
    right: 0;
    top: -webkit-calc(100% + 8px);
    top: -moz-calc(100% + 8px);
    top: calc(100% + 8px);
    /* width: 255px; */
    width: 300px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    overflow: hidden;
    background: #fff;
    -moz-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
         box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  .header .header_menuSub .header_menuSub_main > li ul li:not(:last-child) {
    border-bottom: 1px solid #e2e2e2;
  }
  .header .header_menuSub .header_menuSub_main > li ul li.nL {
    border-bottom: 0;
    padding: 13px 20px;
  }
  .header .header_menuSub .header_menuSub_main > li ul li.lg a {
    background-color: #fff;
    font-size: 16px;
    padding: 20px;
  }
  .header .header_menuSub .header_menuSub_main > li ul li.lg a::after {
    width: 33px;
    height: 33px;
  }
  .header .header_menuSub .header_menuSub_main > li ul li a {
    background: #f2f3f4;
    font-weight: bold;
    font-size: 15px;
    letter-spacing: 0.1em;
    display: block;
    padding: 10px 38px;
    position: relative;
  }
  .header .header_menuSub .header_menuSub_main > li ul li a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 27px;
    height: 27px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: #cc2929 url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 15px 6px;
         background-size: 15px 6px;
  }
  .footer {
    background-color: #EFEDE7;
    padding: 43px 0 54px;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .footer::after {
    content: "";
    position: absolute;
    right: -67px;
    bottom: -107px;
    width: 659px;
    height: 312px;
    background: url(../img/ft_bg.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .footer .row {
    max-width: 1330px;
  }
  .footer .ft_main {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .footer .ft_main .ft_l {
    width: 180px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    text-align: center;
  }
  .footer .ft_main .ft_l > a {
    display: inline-block;
    width: 142px;
    margin-bottom: 22px;
  }
  .footer .ft_main .ft_l ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .footer .ft_main .ft_l ul li {
    width: 29px;
    margin: 0 13px;
  }
  .footer .ft_main .ft_l ul li.ft_yt {
    width: 32px;
  }
  .footer .ft_main .ft_r {
    width: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding-left: 100px;
  }
  .footer .ft_main .ft_r div {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .footer .ft_main .ft_r div:not(:last-child) {
    margin-right: 20px;
  }
  .footer .ft_main .ft_r div.st2 ul:nth-of-type(2) {
    width: 305px;
  }
  .footer .ft_main .ft_r ul {
    width: 220px;
  }
  .footer .ft_main .ft_r ul:not(:last-child) {
    margin-right: 20px;
  }
  .footer .ft_main .ft_r ul li + li {
    margin-top: 26px;
  }
  .footer .ft_main .ft_r ul li a {
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.05em;
  }
  .footer .copyright {
    text-align: right;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.05em;
    color: #5c504d;
    margin-top: 30px;
  }
  .ttl {
    position: relative;
  }
  .ttl figure, .ttl picture {
    height: 552px;
  }
  .ttl figure img, .ttl picture img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ttl .txt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
       -moz-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: 80px;
    z-index: 2;
    background: rgba(29, 41, 81, 0.5);
  }
  .ttl .txt h2 {
    font-weight: bold;
    font-size: 38px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #fff;
    margin-bottom: 20px;
  }
  .ttl .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #fff;
  }
  .ttl2 {
    background-image: url(../img/ttl_bg.png);
    background-repeat: no-repeat;
    -moz-background-size: cover;
         background-size: cover;
    padding: 50px 0 70px;
    text-align: center;
    color: #fff;
  }
  .ttl2.st2 {
    background-image: url(../img/ttl_bg2.png);
    color: #333;
  }
  .ttl2.st2 h2 small {
    color: #E83828;
  }
  .ttl2 h2 {
    margin-bottom: 10px;
  }
  .ttl2 h2 small {
    display: block;
    font-weight: normal;
    font-size: 20px;
    letter-spacing: 0.1em;
    margin-bottom: 4px;
  }
  .ttl2 h2 span {
    display: block;
    font-weight: bold;
    font-size: 38px;
    letter-spacing: 0.1em;
  }
  .ttl2 p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
  }
  #t02 {
    margin-top: 47px;
  }
  .wp-pagenavi, .pagination {
    margin-top: 44px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .wp-pagenavi + .tl2, .pagination + .tl2 {
    margin-top: 47px;
  }
  .wp-pagenavi .pages, .pagination .pages {
    display: none;
  }
  .wp-pagenavi .page, .wp-pagenavi .page-numbers, .pagination .page, .pagination .page-numbers {
    margin: 0 4px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 44px;
    height: 44px;
    -moz-border-radius: 6px;
         border-radius: 6px;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
  }
  .wp-pagenavi .page:hover, .wp-pagenavi .page-numbers:hover, .pagination .page:hover, .pagination .page-numbers:hover {
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
    border-color: #cc2928;
  }
  .wp-pagenavi .dots, .pagination .dots {
    background-color: transparent;
    border: none;
    width: auto;
  }
  .wp-pagenavi .dots:hover, .pagination .dots:hover {
    background-color: transparent;
    color: #333;
  }
  .wp-pagenavi .current, .pagination .current {
    margin: 0 4px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 44px;
    height: 44px;
    -moz-border-radius: 6px;
         border-radius: 6px;
    background: #fff;
    border: 1px solid #cc2928;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: center;
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
  }
  .wp-pagenavi .nextpostslink, .wp-pagenavi .next, .pagination .nextpostslink, .pagination .next {
    margin: 0 4px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 44px;
    height: 44px;
    -moz-border-radius: 6px;
         border-radius: 6px;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    text-indent: -9999px;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .wp-pagenavi .nextpostslink.disabled, .wp-pagenavi .next.disabled, .pagination .nextpostslink.disabled, .pagination .next.disabled {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    pointer-events: none;
  }
  .wp-pagenavi .prevpostslink, .wp-pagenavi .prev, .pagination .prevpostslink, .pagination .prev {
    margin: 0 4px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 44px;
    height: 44px;
    -moz-border-radius: 6px;
         border-radius: 6px;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    text-indent: -9999px;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
  }
  .wp-pagenavi .prevpostslink.disabled, .wp-pagenavi .prev.disabled, .pagination .prevpostslink.disabled, .pagination .prev.disabled {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    pointer-events: none;
  }
  .pagi {
    margin-top: 44px;
  }
  .pagi + .tl2 {
    margin-top: 47px;
  }
  .pagi .paginationjs ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .pagi .paginationjs ul li {
    margin: 0 4px;
  }
  .pagi .paginationjs ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 44px;
    height: 44px;
    -moz-border-radius: 6px;
         border-radius: 6px;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    cursor: pointer;
  }
  .pagi .paginationjs ul li a:hover {
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
    border-color: #cc2928;
  }
  .pagi .paginationjs ul li.paginationjs-ellipsis a {
    background-color: transparent;
    border: none;
    width: auto;
  }
  .pagi .paginationjs ul li.paginationjs-ellipsis a:hover {
    background-color: transparent;
    color: #333;
  }
  .pagi .paginationjs ul li.paginationjs-page.active a {
    color: #fff;
    background-color: #cc2928;
  }
  .pagi .paginationjs ul li .paginationjs-next a {
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .pagi .paginationjs ul li .paginationjs-next.disabled a {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    pointer-events: none;
  }
  .pagi .paginationjs ul li .paginationjs-prev a {
    text-indent: -9999px;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
  }
  .pagi .paginationjs ul li .paginationjs-prev.disabled a {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 8px 13px;
         background-size: 8px 13px;
    pointer-events: none;
  }
  a.btn, button.btn {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: #403535;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    position: relative;
    padding-right: 60px;
    min-height: 42px;
    display: -webkit-inline-box;
    display: -moz-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  a.btn::after, button.btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 42px;
    height: 42px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: #cc2929 url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 15px 6px;
         background-size: 15px 6px;
  }
  a.btn.st2, button.btn.st2 {
    padding-right: 0;
    padding-left: 60px;
  }
  a.btn.st2::after, button.btn.st2::after {
    left: 0;
    right: initial;
    -webkit-transform: translateY(-50%) rotate(180deg);
       -moz-transform: translateY(-50%) rotate(180deg);
        -ms-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }
  .breadcrumb {
    padding: 5px 0;
    font-size: 16px;
  }
  .breadcrumb ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .breadcrumb ul li:not(:last-child) {
    position: relative;
    margin-right: 20px;
  }
  .breadcrumb ul li:not(:last-child)::after {
    content: ">";
    position: absolute;
    top: 50%;
    right: -15px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .faq_list dl {
    border-bottom: 1px solid #d8d8d8;
  }
  .faq_list dl dt {
    font-weight: normal;
    font-size: 20px;
    letter-spacing: 0.1em;
    padding: 27px 40px;
    position: relative;
    cursor: pointer;
    -webkit-transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .faq_list dl dt:hover {
    opacity: 0.7;
  }
  .faq_list dl dt::before {
    content: "Q.";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    line-height: 1;
    left: 5px;
    font-size: 24px;
  }
  .faq_list dl dt i {
    position: absolute;
    width: 20px;
    height: 20px;
    right: 5px;
    top: 50%;
    margin-top: -10px;
    display: block;
  }
  .faq_list dl dt i:before, .faq_list dl dt i:after {
    content: "";
    position: absolute;
    background-color: #403535;
    -webkit-transition: -webkit-transform 0.25s ease-out;
    transition: -webkit-transform 0.25s ease-out;
    -moz-transition: transform 0.25s ease-out, -moz-transform 0.25s ease-out;
    transition: transform 0.25s ease-out;
    transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out, -moz-transform 0.25s ease-out;
  }
  .faq_list dl dt i:before {
    top: 0;
    left: 50%;
    width: 2px;
    height: 100%;
    margin-left: -1px;
  }
  .faq_list dl dt i:after {
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    margin-top: -1px;
  }
  .faq_list dl dt.is_active i:before {
    -webkit-transform: rotate(90deg);
       -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .faq_list dl dd {
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height 0.3s ease-out;
    -moz-transition: max-height 0.3s ease-out;
    transition: max-height 0.3s ease-out;
    font-family: "Source Han Sans JP";
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.93333;
  }
  .faq_list dl dd .accCt {
    padding-bottom: 30px;
  }
  .p_top .mv {
    position: relative;
  }
  .p_top .mv .mv-slider .swiper-slide {
    height: 800px;
  }
  .p_top .mv .mv-slider .swiper-slide picture {
    height: 100%;
  }
  .p_top .mv .mv-slider .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_top .mv .txt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    z-index: 2;
    background: rgba(29, 41, 81, 0.5);
  }
  .p_top .mv .txt h2 {
    font-weight: bold;
    font-size: 43px;
    letter-spacing: 0.1em;
    line-height: 1.69767;
    color: #fff;
    text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
    margin-bottom: 27px;
  }
  .p_top .mv .txt p {
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.1em;
    color: #fff;
    line-height: 2;
    text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  }
  .p_top .intro {
    background-color: #EFEDE7;
    padding: 87px 0;
  }
  .p_top .intro_main {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-right: 10.83333%;
  }
  .p_top .intro_l {
    width: 37.83333%;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .intro_l::before {
    content: "";
    position: absolute;
    top: -23px;
    left: -86px;
    width: 414px;
    height: 121px;
    background: url(../img/intro_bg1.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .intro_r {
    width: 40.83333%;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    min-width: 506px;
    padding-left: 15px;
  }
  .p_top .intro_r::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: -567px;
    width: 733px;
    height: 229px;
    background: url(../img/intro_bg2.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .intro_r .intro_btn {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 66px;
    height: 202px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: #cc2929;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.45em;
    line-height: 1.38889;
    color: #fff;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: mixed;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-top: 12px;
  }
  .p_top .intro_r .intro_btn::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 14px;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 42px;
    height: 42px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: rgba(0, 0, 0, 0.2) url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 15px 6px;
         background-size: 15px 6px;
  }
  .p_top .what {
    padding: 102px 0 93px;
  }
  .p_top .what_head {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .what_head h2 {
    font-size: 36px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #403535;
    white-space: nowrap;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what_head h2 {
    white-space: initial;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what_head p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #403535;
    padding-left: 104px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what_head p {
    padding-left: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what .what_list {
    margin-top: 74px;
    display: -ms-grid;
    display: grid;
    gap: 36px;
    -ms-grid-columns: (minmax(0, 1fr))[3];
        grid-template-columns: repeat(3, minmax(0, 1fr));
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what .what_list {
    gap: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what .what_list::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 80px;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 1620px;
    height: 227px;
    background: url(../img/what_bg.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .what .what_list li {
    text-align: center;
  }
  .p_top .what .what_list li figure {
    position: relative;
    aspect-ratio: 1 / 1;
    margin: 0 27px 25px;
    -moz-border-radius: 50%;
         border-radius: 50%;
    overflow: hidden;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what .what_list li figure {
    margin-left: 10px;
    margin-right: 10px;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what .what_list li figure picture {
    height: 100%;
  }
  .p_top .what .what_list li figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .p_top .what .what_list li figure figcaption {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    line-height: 1.5;
    background: rgba(29, 41, 81, 0.5);
  }
  .p_top .what .what_list li figure figcaption h3 {
    font-weight: normal;
    font-size: 25px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #fff;
    margin-bottom: 12px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what .what_list li figure figcaption h3 {
    font-size: 20px;
    letter-spacing: 0;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what .what_list li figure figcaption p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 2.5625;
    text-align: center;
    color: #fff;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .what .what_list li figure figcaption p {
    font-size: 14px;
    letter-spacing: 0;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .what .what_list li p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #403535;
  }
  .p_top .what .what_list li .btnWr {
    text-align: right;
    margin-top: 10px;
  }
  .p_top .tl {
    margin-bottom: 34px;
  }
  .p_top .tl small {
    display: block;
    font-weight: normal;
    font-size: 20px;
    letter-spacing: 0.1em;
    color: #e83828;
    margin-bottom: 12px;
  }
  .p_top .tl span {
    display: block;
    font-weight: normal;
    font-size: 32px;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .p_top .topics {
    padding: 72px 0 65px;
    background: #f8f8f4;
  }
  .p_top .topics_main {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
  .p_top .topics_main .btn {
    position: absolute;
    left: 0;
    top: 160px;
  }
  .p_top .topics_r {
    padding-left: 47px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .topics_r {
    padding-left: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .topics_r ul li + li {
    margin-top: 21px;
  }
  .p_top .topics_r ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .topics_r ul li a iframe {
    width: 179px;
    height: 126px;
    object-fit: cover;
  }
  .p_top .topics_r ul li a figure {
    width: 179px;
    height: 135px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -moz-border-radius: 5px;
         border-radius: 5px;
    overflow: hidden;
  }
  .p_top .topics_r ul li a figure img {
    -moz-border-radius: 5px;
         border-radius: 5px;
    overflow: hidden;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_top .topics_r ul li a .txt {
    width: 100%;
    padding-left: 29px;
  }
  .p_top .topics_r ul li a .txt h3 {
    font-size: 20px;
    letter-spacing: 0.1em;
    line-height: 1.8;
    text-align: left;
    color: #403535;
    margin-bottom: 11px;
  }
  .p_top .topics_r ul li a .txt p {
    font-family: "Source Han Sans JP";
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #403535;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }
  .p_top .shop {
    background: url(../img/shop_bg.png) center/100% 100% no-repeat;
    padding: 111px 0 97px;
    -moz-background-size: cover;
         background-size: cover;
  }
  .p_top .shop .row {
    max-width: 1016px;
  }
  .p_top .shop .box {
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #fff;
    padding: 54px 50px 60px;
    position: relative;
  }
  .p_top .shop .box::before {
    content: "";
    position: absolute;
    top: -68px;
    right: -124px;
    width: 401px;
    height: 223px;
    background: url(../img/shop_img.png) center/100% 100% no-repeat;
    display: block;
  }
  .p_top .shop .box .tl {
    text-align: center;
  }
  .p_top .shop .box ul {
    display: -ms-grid;
    display: grid;
    gap: 8px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .p_top .shop .box ul a {
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #f2f3f4;
    display: block;
    padding: 25px 65px 65px 25px;
    position: relative;
  }
  .p_top .shop .box ul a::after {
    content: "";
    position: absolute;
    right: 15px;
    bottom: 15px;
    width: 42px;
    height: 42px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background-image: url(../img/ic_arr02.png);
    background-repeat: no-repeat;
    background-color: #cc2929;
    display: block;
    -moz-background-size: 11px 11px;
         background-size: 11px 11px;
    background-position: center;
  }
  .p_top .shop .box ul a.st2::after {
    background-color: transparent;
    border: 1px solid #cc2929;
    background-image: url(../img/ic_plus.svg);
    -moz-background-size: 16px 16px;
         background-size: 16px 16px;
  }
  .p_top .shop .box ul a h3 {
    font-size: 24px;
    letter-spacing: 0.1em;
    margin-bottom: 12px;
  }
  .p_top .shop .box ul a p {
    font-family: "Source Han Sans JP";
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.86667;
  }
  .p_top .faq {
    padding: 74px 0 82px;
    background: #EFEDE7;
  }
  .p_top .faq_main {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
  .p_top .faq_main .btn {
    position: absolute;
    left: 0;
    top: 160px;
  }
  .p_top .faq_l {
    width: 376px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    padding-right: 15px;
  }
  .p_top .faq_r {
    width: 100%;
  }
  .p_top .contact {
    background: #a58f62;
  }
  .p_top .contact .tl {
    color: #fff;
  }
  .p_top .contact .tl small {
    color: #fff;
  }
  .p_top .contact_main {
    padding-top: 67px;
    padding-bottom: 67px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .contact_main::after {
    content: "";
    position: absolute;
    left: 120px;
    bottom: 63px;
    width: 324px;
    height: 147px;
    background: url(../img/contact_bg.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .contact_main ul li + li {
    margin-top: 17px;
  }
  .p_top .contact_main ul li a {
    width: 581px;
    min-height: 123px;
    -moz-border-radius: 8px;
         border-radius: 8px;
    background: #cc2929;
    max-width: 100%;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #fff;
    padding: 0 80px;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_top .contact_main ul li a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 38px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 27px;
    height: 22px;
    background-image: url(../img/ic_mail.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    display: block;
  }
  .p_top .contact_main ul li a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 28px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 42px;
    height: 42px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 15px 6px;
         background-size: 15px 6px;
    border: 1px solid #fff;
  }
  .p_top .contact_main ul li a.st2 {
    background-color: #b51722;
  }
  .p_top .contact_main ul li a.st2::before {
    width: 29px;
    height: 29px;
    background-image: url(../img/ic_tel.png);
  }
  .p_top .f_info {
    background-color: #EFEDE7;
  }
  .p_top .f_info .row {
    max-width: 1330px;
  }
  .p_top .f_info .f_info_main {
    padding: 55px 0 32px;
    border-bottom: 1px solid #b9b9b9;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .f_info .f_info_main .f_info_l {
    width: 370px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_top .f_info .f_info_main .f_info_r {
    width: 100%;
    padding-left: 59px;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn {
    text-align: right;
    margin-top: 10px;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn .btn {
    font-size: 16px;
    padding-right: 53px;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn .btn:after {
    width: 33px;
    height: 33px;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it:not(:last-child) {
    margin-right: 160px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_top .f_info .f_info_main .f_info_r .dlist .it:not(:last-child) {
    margin-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    line-height: 1.53333;
    letter-spacing: 0.05em;
    text-align: left;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl + dl {
    margin-top: 13px;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl dt {
    width: 114px;
    min-height: 27px;
    -moz-border-radius: 3px;
         border-radius: 3px;
    background: #dedbcd;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.05em;
    text-align: center;
    color: #5c504d;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl dd {
    width: 100%;
    padding-left: 17px;
  }
  .boxoverlay {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1900;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    background: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    transition: all 0.5s;
  }
  .modal {
    position: fixed;
    top: 50%;
    left: 50%;
    width: 50%;
    width: 473px;
    height: auto;
    z-index: 2000;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(-50%);
       -moz-transform: translateX(-50%) translateY(-50%);
        -ms-transform: translateX(-50%) translateY(-50%);
            transform: translateX(-50%) translateY(-50%);
  }
  .modal.open {
    visibility: visible;
  }
  .modal.open .m_in {
    opacity: 1;
  }
  .modal .wrap_modal {
    max-height: 60vh;
    overflow: auto;
  }
  .modal .wrap_modal h3 {
    text-align: center;
    font-weight: normal;
    font-size: 24px;
    letter-spacing: 0.1em;
    color: #403535;
    margin-bottom: 24px;
  }
  .modal .wrap_modal ul {
    margin-bottom: 19px;
  }
  .modal .wrap_modal ul li {
    margin-bottom: 3px;
  }
  .modal .wrap_modal ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    min-height: 68px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #f2f3f4;
    padding: 0 50px 0 23px;
    font-weight: 400;
  }
  .modal .wrap_modal ul li a:after {
    right: 22px;
  }
  .modal .wrap_modal .md_desc {
    position: relative;
    font-weight: normal;
    font-size: 20px;
    letter-spacing: 0.1em;
    line-height: 1.9;
    text-align: left;
    color: #403535;
    padding-left: 12px;
    padding-bottom: 20px;
    position: relative;
  }
  .modal .wrap_modal .md_desc::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 137px;
    height: 60px;
    background: url(../img/md_bg.png) center/100% 100% no-repeat;
    display: block;
  }
  .modal .m_in {
    opacity: 0;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    padding: 36px 36px 26px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #fff;
  }
  .modal .m_area {
    position: relative;
  }
  .modal .btn_close {
    position: absolute;
    top: -26px;
    right: -26px;
    width: 33px;
    height: 33px;
    cursor: pointer;
  }
  .bg_cm {
    background: url(../img/brand/intro_bg.png) center no-repeat;
    -moz-background-size: 5174px auto;
         background-size: 5174px auto;
  }
  .p_brand .brand .intro {
    padding: 84px 0 107px;
  }
  .p_brand .brand .intro_t {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-right: 47px;
    margin-bottom: 47px;
  }
  .p_brand .brand .intro_t figure {
    width: 500px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_brand .brand .intro_t .txt {
    width: 100%;
    padding-right: 15px;
  }
  .p_brand .brand .intro_t .txt h2 {
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    line-height: 73px;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_t .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_m {
    background: #f8fdff url(../img/brand/intro_img2.png) center right no-repeat;
    -moz-border-radius: 10px;
         border-radius: 10px;
    -moz-box-shadow: 0px 3px 26px rgba(0, 0, 0, 0.05);
         box-shadow: 0px 3px 26px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    -moz-background-size: auto 100%;
         background-size: auto 100%;
    padding: 55px 50px;
    margin-bottom: 51px;
  }
  .p_brand .brand .intro_m p {
    /* width: 656px; */
    width: auto;
    max-width: 100%;
  }
  .p_brand .brand .intro_m h3 {
    margin-bottom: 20px;
  }
  .p_brand .brand .intro_m h3 span {
    display: block;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 5px;
  }
  .p_brand .brand .intro_m h3 small {
    display: block;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list {
    display: -ms-grid;
    display: grid;
    margin-bottom: 81px;
    gap: 38px 56px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .p_brand .brand .intro_list li {
    padding: 25px 30px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    background: #fff;
  }
  .p_brand .brand .intro_list li .it_head {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 20px;
  }
  .p_brand .brand .intro_list li .it_head figure {
    height: 73px;
    height: 73px;
    -moz-border-radius: 9999px;
         border-radius: 9999px;
    overflow: hidden;
  }
  .p_brand .brand .intro_list li .it_head figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    -moz-border-radius: 9999px;
         border-radius: 9999px;
    overflow: hidden;
  }
  .p_brand .brand .intro_list li .it_head h4 {
    padding-left: 19px;
  }
  .p_brand .brand .intro_list li .it_head h4 span {
    display: block;
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list li .it_head h4 span em {
    font-style: normal;
    font-size: 16px;
  }
  .p_brand .brand .intro_list li .it_head h4 small {
    display: block;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list li p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_btn {
    display: -ms-grid;
    display: grid;
    gap: 50px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 1000px;
    max-width: 100%;
    margin: 0 auto;
  }
  .p_brand .brand .intro_btn a {
    min-height: 127px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    background: #cc2928;
    max-width: 100%;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.1em;
    color: #fff;
    padding: 0 80px 0 25px;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
  }
  .p_brand .brand .intro_btn a span {
    display: block;
    color: rgba(255, 255, 255, 0.74);
  }
  .p_brand .brand .intro_btn a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 42px;
    height: 42px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    background: rgba(0, 0, 0, 0.2) url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 15px 6px;
         background-size: 15px 6px;
  }
  .p_brand .brand .intro_btn a.st2 {
    font-size: 18px;
  }
  .p_brand .brand .what {
    padding-bottom: 116px;
  }
  .p_brand .brand .what_top {
    background: url(../img/brand/what_bg.png) center bottom no-repeat;
    -moz-background-size: cover;
         background-size: cover;
    padding-top: 82px;
    padding-bottom: 151px;
    text-align: center;
    -moz-border-radius: 10px;
         border-radius: 10px;
  }
  .p_brand .brand .what_top h2 {
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    color: #fff;
    margin-bottom: 20px;
  }
  .p_brand .brand .what_top p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    color: #fff;
  }
  .p_brand .brand .what_bot {
    margin-top: -84px;
    position: relative;
    z-index: 2;
  }
  .p_brand .brand .what_bot .box {
    padding: 84px 15px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    background: #fff;
  }
  .p_brand .brand .what_bot .box ul {
    width: 1000px;
    margin: 0 auto;
    max-width: 100%;
  }
  .p_brand .brand .what_bot .box ul li {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_brand .brand .what_bot .box ul li + li {
    margin-top: 60px;
  }
  .p_brand .brand .what_bot .box ul li figure {
    width: 400px;
    overflow: hidden;
    -moz-border-radius: 10px;
         border-radius: 10px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_brand .brand .what_bot .box ul li figure img {
    overflow: hidden;
    -moz-border-radius: 10px;
         border-radius: 10px;
  }
  .p_brand .brand .what_bot .box ul li .txt {
    width: 100%;
    padding-left: 58px;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 {
    margin-bottom: 20px;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 5px;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 small {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    display: block;
  }
  .p_brand .brand .what_bot .box ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_faq .faq {
    padding: 86px 0 150px;
    background-color: #fff;
  }
  .p_faq .faq .row {
    max-width: 1000px;
  }
  .p_faq .faq_head {
    margin-bottom: 35px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_faq .faq_head ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_faq .faq_head ul li {
    margin-right: 16px;
  }
  .p_faq .faq_head ul li a {
    min-height: 41px;
    -moz-border-radius: 999px;
         border-radius: 999px;
    border: 1px solid #d1d1d1;
    padding: 0 45px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_faq .faq_head ul li a.active {
    background: #cc2928;
    border-color: #cc2928;
    color: #fff;
  }
  .p_faq .faq_head .faq_search {
    position: relative;
    margin: 15px 0;
  }
  .p_faq .faq_head .faq_search button {
    position: absolute;
    top: 0;
    left: 0;
    padding: 0;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    width: 50px;
    height: 44px;
    display: -webkit-inline-box;
    display: -moz-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: url(../img/ic_search.svg) center no-repeat;
    -moz-background-size: 21px 21px;
         background-size: 21px 21px;
  }
  .p_faq .faq_head .faq_search input {
    padding: 0 15px;
    outline: none;
    font-size: 15px;
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    width: 323px;
    height: 44px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    background: #fafafa;
    border: 1px solid #e8e8e8;
    padding-left: 50px;
  }
  .p_faq .faq_head .faq_search input::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq .faq_bd .it {
    padding-top: 30px;
  }
  .p_faq .faq .faq_bd .it + .it {
    margin-top: 80px;
  }
  .p_faq .faq .faq_list {
    color: #333;
  }
  .p_faq .faq .faq_list dl dt {
    font-size: 18px;
    padding-left: 32px;
  }
  .p_faq .faq .faq_list dl dt:before {
    /* top: 30px; */
    font-size: 18px;
    top: 50%;
    transform: translateY(-50%);
  }
  .p_faq .faq .faq_list dl dd .accCt {
    background: #fafafa;
    padding: 20px 20px 27px;
  }
  .tl2 {
    font-weight: bold;
    font-size: 28px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 10px;
  }
  .p_contact {
    background-color: #EFEDE7;
  }
  .p_contact .contact {
    padding: 100px 0 65px;
  }
  .p_contact .contact .row {
    max-width: 1000px;
  }
  .p_contact .contact .f_btn {
    padding: 0;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    -moz-border-radius: 30px;
         border-radius: 30px;
    width: 394px;
    height: 66px;
    -moz-border-radius: 3px;
         border-radius: 3px;
    background: #cc2928;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.05em;
    text-align: center;
    color: #fff;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 75px auto 0;
  }
  .p_contact .contact .f_btn[name="btn_back"] {
    margin-top: 40px;
  }
  .p_contact .contact .f_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 22px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 8px;
    height: 13px;
    background: url(../img/ic_arr2.svg) center/100% 100% no-repeat;
    display: block;
  }
  .p_contact .contact .form {
    -moz-border-radius: 9px;
         border-radius: 9px;
    background: #fff;
    padding: 90px 60px;
  }
  .p_contact .contact .form .f_txtError {
    font-size: 14px;
    letter-spacing: 0.07em;
    margin-bottom: 4px;
    color: #f00;
  }
  .p_contact .contact .form dl {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
       -moz-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .p_contact .contact .form dl + dl {
    margin-top: 32px;
  }
  .p_contact .contact .form dl dt {
    width: 174px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    font-weight: bold;
    font-size: 15px;
    letter-spacing: 0.1em;
    color: #203153;
  }
  .p_contact .contact .form dl dt span {
    color: #D53030;
    margin-left: 3px;
    margin-top: 3px;
  }
  .p_contact .contact .form dl dd {
    width: 100%;
  }
  .p_contact .contact .form dl dd .select label {
    display: block;
    position: relative;
    -webkit-perspective: 1px;
       -moz-perspective: 1px;
            perspective: 1px;
    width: 400px;
    height: 52px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #fff;
    border: 1px solid #e8e8e8;
    max-width: 100%;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd .select label::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 18px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 11px solid #333;
  }
  .p_contact .contact .form dl dd .select label select {
    width: 100%;
    height: 100%;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    outline: none;
    border: none;
    padding: 0 35px 0 20px;
    background: transparent;
    font-weight: 400;
    font-size: 16px;
    color: #333;
    cursor: pointer;
    position: relative;
    z-index: 3;
  }
  .p_contact .contact .form dl dd .select label select::-ms-expand {
    display: none;
  }
  .p_contact .contact .form dl dd input {
    width: 100%;
    padding: 0 20px;
    outline: none;
    font-size: 16px;
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    height: 52px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #f4f4f4;
    border: 1px solid #e8e8e8;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd input::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input.sm {
    width: 400px;
    max-width: 100%;
  }
  .p_contact .contact .form dl dd textarea {
    width: 100%;
    padding: 10px 20px;
    outline: none;
    font-size: 16px;
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    height: 164px;
    -moz-border-radius: 5px;
         border-radius: 5px;
    background: #f4f4f4;
    border: 1px solid #e8e8e8;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd textarea::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd .checkboxWr {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_contact .contact .form dl dd .checkboxWr div, .p_contact .contact .form dl dd .checkboxWr .mwform-checkbox-field {
    display: inline-block;
    margin-bottom: 5px;
    margin-right: 30px;
    margin-left: 0;
  }
  .p_contact .contact .form dl dd .checkboxWr label {
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    display: inline-block;
    color: #333;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.05em;
    color: #203153;
  }
  .p_contact .contact .form dl dd .checkboxWr label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
  }
  .p_contact .contact .form dl dd .checkboxWr label span {
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    display: inline-block;
    padding: 0 0 0 30px;
    position: relative;
  }
  .p_contact .contact .form dl dd .checkboxWr label span::before {
    position: absolute;
    content: "";
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 0;
    width: 21px;
    height: 21px;
    -moz-border-radius: 4px;
         border-radius: 4px;
    /* background: #cc2928; */
    border: solid 1px #cc2928;
  }
  .p_contact .contact .form dl dd .checkboxWr label span::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 2px;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 17px;
    height: 12px;
    background: url(../img/ic_check_red.svg) center/100% 100% no-repeat;
    display: none;
  }
  .p_contact .contact .form dl dd .checkboxWr label input:checked ~ span:after {
    display: block;
  }
  .p_contact .contact .form dl dd .list_rd {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_contact .contact .form dl dd .list_rd .rd, .p_contact .contact .form dl dd .list_rd .mwform-radio-field {
    margin-top: 8px;
    margin-bottom: 8px;
  }
  .p_contact .contact .form dl dd .list_rd .rd:not(:last-child), .p_contact .contact .form dl dd .list_rd .mwform-radio-field:not(:last-child) {
    margin-right: 20px;
    width: 100%;
  }
  .p_contact .contact .form dl dd .list_rd .rd label, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label {
    display: block;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    line-height: 20px;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    color: #203153;
    letter-spacing: 0.02em;
  }
  .p_contact .contact .form dl dd .list_rd .rd label input, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
  }
  .p_contact .contact .form dl dd .list_rd .rd span, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span {
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    display: inline-block;
    padding: 0 0 0 30px;
  }
  .p_contact .contact .form dl dd .list_rd .rd span::before, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    -moz-border-radius: 50%;
         border-radius: 50%;
    width: 20px;
    height: 20px;
    border: 1px solid #cecece;
  }
  .p_contact .contact .form dl dd .list_rd .rd span::after, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span::after {
    top: 4px;
    left: 4px;
    width: 12px;
    height: 12px;
    background: #cc2928;
    -moz-border-radius: 50%;
         border-radius: 50%;
    content: "";
    position: absolute;
    display: none;
  }
  .p_contact .contact .form dl dd .list_rd .rd label input:checked ~ span:after, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label input:checked ~ span:after {
    display: block;
  }
  .p_initiatives .initiatives .thoughts {
    background: #EFF7F8 url(../img/initiatives/thoughts_bg.png) center top no-repeat;
    -moz-background-size: cover;
         background-size: cover;
    /* padding: 76px 0 71px; */
    padding: 15vh 0;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_initiatives .initiatives .thoughts {
    background-position: right top;
  }
}

@media screen and (min-width: 769px), print {
  .p_initiatives .initiatives .thoughts_main {
    position: relative;
  }
  .p_initiatives .initiatives .thoughts_main .author {
    position: absolute;
    top: 70px;
    left: 67%;
  }
  .p_initiatives .initiatives .thoughts_main .author small {
    display: block;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 3px;
  }
  .p_initiatives .initiatives .thoughts_main .author span {
    display: block;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_initiatives .initiatives .thoughts_main h2 {
    margin-bottom: 25px;
  }
  .p_initiatives .initiatives .thoughts_main h2 span {
    display: block;
    font-weight: bold;
    font-size: 38px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 25px;
  }
  .p_initiatives .initiatives .thoughts_main h2 small {
    display: block;
    font-weight: bold;
    font-size: 22px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .thoughts_main p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 2.25;
    text-align: left;
    color: #333;
    width: 67%;
  }
  .p_initiatives .initiatives .sdg {
    padding: 110px 0 140px;
  }
  .p_initiatives .initiatives .sdg .sdg_head {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 80px;
  }
  .p_initiatives .initiatives .sdg .sdg_head figure {
    width: 210px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_initiatives .initiatives .sdg .sdg_head .txt {
    width: 100%;
    padding-right: 200px;
  }
  .p_initiatives .initiatives .sdg .sdg_head .txt h2 {
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 25px;
  }
  .p_initiatives .initiatives .sdg .sdg_head .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .sdg .sdg_list li {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 28px 46px 28px 57px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    background: #fff;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_initiatives .initiatives .sdg .sdg_list li {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_initiatives .initiatives .sdg .sdg_list li + li {
    margin-top: 32px;
  }
  .p_initiatives .initiatives .sdg .sdg_list li figure {
    width: 188px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt {
    width: 100%;
    padding-right: 15px;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 {
    margin-bottom: 25px;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 5px;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 span em {
    font-style: normal;
    font-size: 18px;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 small {
    display: block;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence {
    padding-bottom: 160px;
  }
  .p_coexistence .coexistence .coexistence_top {
    padding: 100px 0 65px;
    text-align: center;
  }
  .p_coexistence .coexistence .coexistence_top h2 {
    margin-bottom: 37px;
  }
  .p_coexistence .coexistence .coexistence_top h2 span {
    display: block;
    font-weight: bold;
    font-size: 38px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 25px;
  }
  .p_coexistence .coexistence .coexistence_top h2 small {
    display: block;
    font-weight: bold;
    font-size: 22px;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_top p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 2.25;
    text-align: center;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_top .c-video {
    display: -ms-grid;
    display: grid;
    gap: 54px;
    -ms-grid-columns: (minmax(0, 1fr))[3];
        grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 80px;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a {
    display: block;
    position: relative;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
       -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 77px;
    height: 77px;
    background: url(../img/coexistence/ic_play.png) center/100% 100% no-repeat;
    display: block;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a figure {
    height: 205px;
    overflow: hidden;
    -moz-border-radius: 10px;
         border-radius: 10px;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a figure img {
    overflow: hidden;
    -moz-border-radius: 10px;
         border-radius: 10px;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_coexistence .coexistence .coexistence_mid ul li {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 40px 100px 40px 60px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    background: #fff;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_coexistence .coexistence .coexistence_mid ul li {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_coexistence .coexistence .coexistence_mid ul li + li {
    margin-top: 40px;
  }
  .p_coexistence .coexistence .coexistence_mid ul li:nth-child(odd) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
       -moz-box-orient: horizontal;
       -moz-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    padding-right: 68px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_coexistence .coexistence .coexistence_mid ul li:nth-child(odd) {
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_coexistence .coexistence .coexistence_mid ul li:nth-child(odd) .txt {
    padding-left: 0;
    padding-right: 60px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_coexistence .coexistence .coexistence_mid ul li:nth-child(odd) .txt {
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_coexistence .coexistence .coexistence_mid ul li figure {
    width: 370px;
    -moz-border-radius: 10px;
         border-radius: 10px;
    overflow: hidden;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_coexistence .coexistence .coexistence_mid ul li figure img {
    -moz-border-radius: 10px;
         border-radius: 10px;
    overflow: hidden;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt {
    width: 100%;
    padding-left: 67px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_coexistence .coexistence .coexistence_mid ul li .txt {
    padding-left: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 {
    margin-bottom: 25px;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 26px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 5px;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 small {
    display: block;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_bot {
    margin-top: 130px;
  }
  .p_coexistence .coexistence .coexistence_bot h3 {
    text-align: center;
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 60px;
  }
  .carousel {
    width: 100%;
    overflow: hidden;
  }
  .carousel .main_carousel {
    height: 237px;
    overflow: hidden;
    position: relative;
  }
  .carousel .main_carousel ul {
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
  }
  .carousel .main_carousel ul:after {
    content: '';
    display: table;
    clear: both;
  }
  .carousel .main_carousel ul li {
    float: left;
    width: 342px;
    padding-right: 14px;
  }
  .carousel .main_carousel ul li img {
    width: 100%;
    height: 237px;
    object-fit: cover;
    overflow: hidden;
    -moz-border-radius: 10px;
         border-radius: 10px;
  }
  .p_company .company {
    background-color: #fff;
    padding-bottom: 100px;
  }
  .p_company .company .infor {
    padding: 90px 0 116px;
  }
  .p_company .company .infor .tl2 {
    margin-bottom: 25px;
  }
  .p_company .company .infor .dlist {
    margin-bottom: 35px;
    display: -ms-grid;
    display: grid;
    gap: 60px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .p_company .company .infor .dlist dl {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 25px 0;
    border-bottom: 1px solid #DBDBDB;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_company .company .infor .dlist dl dt {
    width: 123px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    padding-right: 15px;
    font-size: 14px;
  }
  .p_company .company .infor .dlist dl dd {
    width: 100%;
  }
  .p_company .company .philosophy .box {
    padding: 102px 15px 110px;
    background: #f2f2f2 url(../img/company/philosophy_bg.png) center no-repeat;
    -moz-background-size: 100% auto;
         background-size: 100% auto;
    text-align: center;
  }
  .p_company .company .philosophy .box .tl2 {
    text-align: center;
    margin-bottom: 45px;
  }
  .p_company .company .philosophy .box .p-numWr {
    display: inline-block;
    text-align: left;
    margin-bottom: 45px;
  }
  .p_company .company .philosophy .box .p-numWr .p-num {
    display: -ms-grid;
    display: grid;
    gap: 30px 80px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.1em;
    line-height: 2;
    color: #333;
  }
  .p_company .company .philosophy .box .list-circle {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_company .company .philosophy .box .list-circle li {
    width: 332px;
    height: 332px;
    background: #f8f8f8;
    -moz-border-radius: 9999px;
         border-radius: 9999px;
    margin: 22px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p_company .company .philosophy .box .list-circle li h3 {
    position: relative;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: #333;
    padding-bottom: 25px;
    margin-bottom: 20px;
  }
  .p_company .company .philosophy .box .list-circle li h3::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 43px;
    height: 1px;
    background: #c9c9c9;
    display: block;
  }
  .p_company .company .philosophy .box .list-circle li p {
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: center;
    color: #333;
  }
  .p_company .company .decisions {
    padding: 67px 0 116px;
  }
  .p_company .company .decisions .box {
    border: 1px solid #BCBCBC;
    text-align: center;
    padding: 65px 0 80px;
  }
  .p_company .company .decisions .box .tl2 {
    margin-bottom: 40px;
  }
  .p_company .company .decisions .box ol {
    display: inline-block;
    text-align: left;
  }
  .p_company .company .decisions .box ol li {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    line-height: 2.27778;
    color: #333;
  }
  .p_company .company .decisions .box ol li + li {
    margin-top: 15px;
  }
  .p_company .company .certification ul li {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 30px 20px;
  }
  .p_company .company .certification ul li:not(:last-child) {
    border-bottom: 1px solid rgba(112, 112, 112, 0.33);
  }
  .p_company .company .certification ul li figure {
    width: 416px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_company .company .certification ul li .txt {
    width: 100%;
    padding-right: 73px;
  }
}

@media screen and (min-width: 769px) and (max-width: 1199px) and (min-width: 769px) {
  .p_company .company .certification ul li .txt {
    padding-right: 15px;
  }
}

@media screen and (min-width: 769px), print {
  .p_company .company .certification ul li .txt h3 {
    margin-bottom: 15px;
    font-weight: bold;
    font-size: 22px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 15px;
  }
  .p_company .company .certification ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #333;
  }
  .p_topics .topics {
    padding-bottom: 0;
  }
  .p_topics .topics .row {
    max-width: 1200px;
  }
  .p_topics .topics .topics_it {
    padding: 114px 0;
  }
  .p_topics .topics .topics_it:nth-of-type(1) {
    padding-top: 35px;
  }
  .p_topics .topics .topics_it:nth-child(even) {
    background: #fafafa;
  }
  .p_topics .topics .topics_it .list_topics {
    display: -ms-grid;
    display: grid;
    gap: 66px;
    -ms-grid-columns: (minmax(0, 1fr))[3];
        grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 27px;
  }
  .p_topics .topics .topics_it .list_topics li a {
    display: block;
  }
  .p_topics .topics .topics_it .list_topics li a figure {
    /* height: 214px; */
    height: 245px;
    margin-bottom: 8px;
  }
  .p_topics .topics .topics_it .list_topics li a figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_topics .topics .topics_it .list_topics li a iframe {
    margin-bottom: 8px;
  }
  .p_topics .topics .topics_it .list_topics li a .meta {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 11px;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span {
    display: inline-block;
    padding: 3px 10px;
    -moz-border-radius: 999px;
         border-radius: 999px;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st2 {
    background-color: #cc2928;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st3::before {
    content: "";
    width: 13px;
    height: 13px;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 4px;
    vertical-align: middle;
  }
  .p_topics .topics .topics_it .list_topics li a .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_topics .topics .topics_it .list_topics li a h4 {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 9px;
  }
  .p_topics .topics .topics_it .list_topics li a p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 1.85714;
    text-align: left;
    color: #403535;
  }
  .p_topics .topics .topics_it .list_topics02 {
    display: -ms-grid;
    display: grid;
    gap: 40px 54px;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 40px;
  }
  .p_topics .topics .topics_it .list_topics02 li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_topics .topics .topics_it .list_topics02 li a figure {
    width: 180px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    height: 108px;
  }
  .p_topics .topics .topics_it .list_topics02 li a figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_topics .topics .topics_it .list_topics02 li a .txt {
    width: 100%;
    padding-left: 26px;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-bottom: 11px;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span {
    display: inline-block;
    padding: 3px 10px;
    -moz-border-radius: 999px;
         border-radius: 999px;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st2 {
    background-color: #cc2928;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st3::before {
    content: "";
    width: 13px;
    height: 13px;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 4px;
    vertical-align: middle;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_topics .topics .topics_it .list_topics02 li a h4 {
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 9px;
  }
  .p_topics .topics .topics_it .list_topics02 li a p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 1.85714;
    text-align: left;
    color: #403535;
  }
  .p_detail .detail {
    padding-top: 67px;
    padding-bottom: 160px;
  }
  .p_detail .detail .row {
    max-width: 1000px;
  }
  .p_detail .detail .post_ctrl {
    margin-top: 28px;
  }
  .p_detail .detail .box {
    -moz-border-radius: 9px;
         border-radius: 9px;
    background: #fff;
    padding: 47px 56px;
  }
  .p_detail .detail .box .meta {
    padding-bottom: 25px;
    margin-bottom: 35px;
    border-bottom: 1px solid #d0d0d0;
  }
  .p_detail .detail .box .meta span {
    display: inline-block;
    padding: 3px 10px;
    -moz-border-radius: 999px;
         border-radius: 999px;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_detail .detail .box .meta span.st2 {
    background-color: #cc2928;
  }
  .p_detail .detail .box .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_detail .detail .box .meta span.st3::before {
    content: "";
    width: 13px;
    height: 13px;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 4px;
    vertical-align: middle;
  }
  .p_detail .detail .box .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 14px;
    letter-spacing: 0.1em;
    color: #333;
    margin-left: 16px;
  }
  .p_detail .detail .box .meta h1 {
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 0.1em;
    color: #333;
    margin-top: 10px;
  }
  .p_detail .detail .box .dt_ctn {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 16px;
    letter-spacing: 0.1em;
    line-height: 30px;
    text-align: left;
    color: #403535;
  }
  .p_detail .detail .box .dt_ctn p {
    margin-bottom: 30px;
  }
  .p_detail .detail .box .dt_ctn figure {
    margin-bottom: 37px;
  }
}

@media screen and (max-width: 768px) {
  img {
    width: 100%;
    height: auto;
  }
  .container {
    overflow: hidden;
  }
  .show_pc {
    display: none !important;
  }
  .row {
    padding-left: 5.33333vw;
    padding-right: 5.33333vw;
  }
  .inner {
    padding-left: 5.33333vw;
    padding-right: 5.33333vw;
  }
  .txt_en {
    font-family: "Outfit", serif;
  }
  .text_cm {
    font-size: 4.26667vw;
    line-height: 1.75;
  }
  body {
    /* padding-top: 32.53333vw; */
    padding-top: 22vw;
  }
  body.NoPd {
    padding-top: 0;
  }
  .header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%;
    /* height: 32.53333vw; */
    height: 22vw;
    padding: 0 5.33333vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .header.header--type02 {
    background-color: #fff;
  }
  .header.header--type02 h1 a {
    background-image: url(../img/ft_logo.png);
  }
  .header.active {
    background-color: #fff !important;
  }
  .header.active h1 a {
    background-image: url(../img/ft_logo.png);
  }
  .header .row {
    padding: 0;
  }
  .header h1 {
    font-size: 0;
    line-height: 0;
  }
  .header h1 a {
    width: 26.66667vw;
    height: 14.66667vw;
    display: block;
    background-image: url(../img/logo.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    text-indent: -9999px;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  .header .h_copyright {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    text-align: center;
    color: #5c504d;
    margin-top: 8vw;
  }
  .header .h_contact {
    margin: 8.53333vw 0;
  }
  .header .h_contact ul li + li {
    margin-top: 2.13333vw;
  }
  .header .h_contact ul li a {
    height: 23.73333vw;
    -moz-border-radius: 2.13333vw;
         border-radius: 2.13333vw;
    background: #cc2929;
    max-width: 100%;
    font-size: 4.53333vw;
    letter-spacing: 0.05em;
    text-align: left;
    color: #fff;
    padding: 0 19.73333vw 0 13.33333vw;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .header .h_contact ul li a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 4vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 6.13333vw;
    height: 4.8vw;
    background-image: url(../img/ic_mail.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    display: block;
  }
  .header .h_contact ul li a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 4vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 11.2vw;
    height: 11.2vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 4vw 1.6vw;
         background-size: 4vw 1.6vw;
    border: 1px solid #fff;
  }
  .header .h_contact ul li a.st2 {
    background-color: #b51722;
  }
  .header .h_contact ul li a.st2::before {
    width: 5.33333vw;
    height: 5.33333vw;
    background-image: url(../img/ic_tel.png);
  }
  .header .h_ex {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .header .h_ex li {
    margin: 0 3.46667vw;
  }
  .header .h_ex li.ic_social a {
    display: block;
    width: 7.73333vw;
    height: 7.73333vw;
    text-indent: -2666.4vw;
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    background-color: transparent;
    padding: 0;
  }
  .header .h_ex li.ic_social a::before, .header .h_ex li.ic_social a::after {
    display: none;
  }
  .header .h_ex li.ic_social.ic_ig a {
    background-image: url(../img/ft_ig.png);
  }
  .header .h_ex li.ic_social.ic_fb a {
    background-image: url(../img/ft_fb.png);
  }
  .header .h_ex li.ic_social.ic_yt a {
    width: 8.53333vw;
    height: 6.4vw;
    background-image: url(../img/ft_yt.png);
  }
  .header .header_menuSub {
    position: fixed;
    height: 0;
    opacity: 0;
    /* top: 32.53333vw; */
    top: 22vw;
    left: 0;
    visibility: hidden;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    overflow-y: auto;
    width: 100%;
    z-index: 1001;
    background-color: #fff;
    padding: 0vw 5.33333vw 26.66667vw;
  }
  .header .header_menuSub.active {
    opacity: 1;
    visibility: visible;
  }
  .header .header_menuSub .header_menuSub_main > li a, .header .header_menuSub .header_menuSub_main > li > span, .header .header_menuSub .header_menuSub_main > li .nL {
    display: block;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #403535;
    position: relative;
    border-bottom: 1px solid #ddd;
    padding: 4vw 8vw 4vw 2.66667vw;
  }
  .header .header_menuSub .header_menuSub_main > li a::after, .header .header_menuSub .header_menuSub_main > li > span::after, .header .header_menuSub .header_menuSub_main > li .nL::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 2.66667vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 4vw;
    height: 1.6vw;
    background: url(../img/ic_arr03.png) center/100% 100% no-repeat;
    display: block;
  }
  .header .header_menuSub .header_menuSub_main > li > span, .header .header_menuSub .header_menuSub_main > li .nL {
    position: relative;
  }
  .header .header_menuSub .header_menuSub_main > li > span::after, .header .header_menuSub .header_menuSub_main > li .nL::after {
    display: none;
  }
  .header .header_menuSub .header_menuSub_main > li > span i, .header .header_menuSub .header_menuSub_main > li .nL i {
    position: absolute;
    width: 4.26667vw;
    height: 4.26667vw;
    right: 2.66667vw;
    top: 50%;
    margin-top: -2.13333vw;
    display: block;
  }
  .header .header_menuSub .header_menuSub_main > li > span i:before, .header .header_menuSub .header_menuSub_main > li > span i:after, .header .header_menuSub .header_menuSub_main > li .nL i:before, .header .header_menuSub .header_menuSub_main > li .nL i:after {
    content: "";
    position: absolute;
    background-color: #cc2929;
    -webkit-transition: -webkit-transform 0.25s ease-out;
    transition: -webkit-transform 0.25s ease-out;
    -moz-transition: transform 0.25s ease-out, -moz-transform 0.25s ease-out;
    transition: transform 0.25s ease-out;
    transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out, -moz-transform 0.25s ease-out;
  }
  .header .header_menuSub .header_menuSub_main > li > span i:before, .header .header_menuSub .header_menuSub_main > li .nL i:before {
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%;
    margin-left: -0.5px;
  }
  .header .header_menuSub .header_menuSub_main > li > span i:after, .header .header_menuSub .header_menuSub_main > li .nL i:after {
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px;
    margin-top: -0.5px;
  }
  .header .header_menuSub .header_menuSub_main > li > span.is_active i:before, .header .header_menuSub .header_menuSub_main > li .nL.is_active i:before {
    -webkit-transform: rotate(90deg);
       -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .header .header_menuSub .header_menuSub_main > li .nL {
    border-bottom: 0;
  }
  .header .header_menuSub .header_menuSub_main > li .nL ~ li a {
    background: #f2f3f4;
  }
  .header .header_menuSub .header_menuSub_main > li .nL ~ li:last-child a {
    border-bottom: 0;
  }
  .header .header_menuSub .header_menuSub_main > li.h_shop > ul {
    background: #fafafa;
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height 0.3s ease-out;
    -moz-transition: max-height 0.3s ease-out;
    transition: max-height 0.3s ease-out;
  }
  .header .menu_icon {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    cursor: pointer;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    position: fixed;
    /* top: 9.33333vw; */
    top: 5vw;
    right: 5.33333vw;
    z-index: 9999;
    width: 13.86667vw;
    height: 13.86667vw;
    background-color: #cc2929;
    -moz-border-radius: 9999px;
         border-radius: 9999px;
  }
  .header .menu_icon.active .menu_icon_in .menu-trigger span:nth-of-type(1) {
    -webkit-transform: translate(-0.53333vw, 0vw) rotate(-35deg);
       -moz-transform: translate(-0.53333vw, 0vw) rotate(-35deg);
        -ms-transform: translate(-0.53333vw, 0vw) rotate(-35deg);
            transform: translate(-0.53333vw, 0vw) rotate(-35deg);
  }
  .header .menu_icon.active .menu_icon_in .menu-trigger span:nth-of-type(2) {
    opacity: 0;
  }
  .header .menu_icon.active .menu_icon_in .menu-trigger span:nth-of-type(3) {
    -webkit-transform: translate(-0.53333vw, 0vw) rotate(35deg);
       -moz-transform: translate(-0.53333vw, 0vw) rotate(35deg);
        -ms-transform: translate(-0.53333vw, 0vw) rotate(35deg);
            transform: translate(-0.53333vw, 0vw) rotate(35deg);
  }
  .header .menu_icon_in {
    width: 6.4vw;
    height: 4.26667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .header .menu_icon_in .menu-trigger,
  .header .menu_icon_in .menu-trigger span {
    display: inline-block;
    -webkit-transition: all .4s;
    -moz-transition: all .4s;
    transition: all .4s;
    -moz-box-sizing: border-box;
         box-sizing: border-box;
  }
  .header .menu_icon_in .menu-trigger {
    position: relative;
    width: 100%;
    height: 4.26667vw;
  }
  .header .menu_icon_in .menu-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 0.53333vw;
    min-height: 1px;
    background-color: #fff;
    -webkit-transform-origin: 100% 0;
       -moz-transform-origin: 100% 0;
        -ms-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  .header .menu_icon_in .menu-trigger span:nth-of-type(1) {
    top: 0;
  }
  .header .menu_icon_in .menu-trigger span:nth-of-type(2) {
    top: 1.86667vw;
  }
  .header .menu_icon_in .menu-trigger span:nth-of-type(3) {
    bottom: 0;
    width: 100%;
  }
  .footer {
    background-color: #EFEDE7;
    padding: 10.66667vw 0 8.8vw;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .footer::after {
    content: "";
    position: absolute;
    left: -4.26667vw;
    bottom: 12.53333vw;
    width: 67.79923vw;
    height: 32.12355vw;
    background: url(../img/ft_bg.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .footer .row {
    max-width: 354.66667vw;
  }
  .footer .ft_main .ft_l {
    text-align: center;
    margin-bottom: 10.66667vw;
  }
  .footer .ft_main .ft_l > a {
    display: inline-block;
    width: 37.86667vw;
    margin-bottom: 5.86667vw;
  }
  .footer .ft_main .ft_l ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .footer .ft_main .ft_l ul li {
    width: 7.73333vw;
    margin: 0 3.46667vw;
  }
  .footer .ft_main .ft_l ul li.ft_yt {
    width: 8.53333vw;
  }
  .footer .ft_main .ft_r {
    width: 100%;
  }
  .footer .ft_main .ft_r div + div {
    margin-top: 12vw;
  }
  .footer .ft_main .ft_r div.st2 {
    display: -ms-grid;
    display: grid;
    gap: 4.26667vw 0;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .footer .ft_main .ft_r div.st2 ul {
    display: block;
  }
  .footer .ft_main .ft_r div.st2 ul li + li {
    margin-top: 4.26667vw;
  }
  .footer .ft_main .ft_r ul {
    display: -ms-grid;
    display: grid;
    gap: 4.26667vw 0;
    margin-bottom: 4.26667vw;
    -ms-grid-columns: (minmax(0, 1fr))[2];
        grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .footer .ft_main .ft_r ul li a {
    font-weight: bold;
    font-size: 3.46667vw;
    letter-spacing: 0;
  }
  .footer .copyright {
    text-align: center;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.2vw;
    letter-spacing: 0.05em;
    color: #5c504d;
    margin-top: 9.86667vw;
  }
  .ttl {
    position: relative;
  }
  .ttl figure, .ttl picture {
    height: 120vw;
  }
  .ttl figure img, .ttl picture img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ttl .txt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
       -moz-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: 5.33333vw;
    z-index: 2;
    background: rgba(29, 41, 81, 0.5);
  }
  .ttl .txt h2 {
    font-weight: bold;
    font-size: 7.46667vw;
    line-height: 1.5;
    text-align: left;
    color: #fff;
    margin-bottom: 6.13333vw;
    letter-spacing: 0.1em;
  }
  .ttl .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #fff;
  }
  .ttl2 {
    background-image: url(../img/ttl_bg.png);
    background-repeat: no-repeat;
    -moz-background-size: cover;
         background-size: cover;
    padding: 13.33333vw 5.33333vw 18.66667vw;
    text-align: center;
    color: #fff;
  }
  .ttl2.st2 {
    background-image: url(../img/ttl_bg2.png);
    color: #333;
  }
  .ttl2.st2 h2 small {
    color: #E83828;
  }
  .ttl2 h2 {
    margin-bottom: 2.66667vw;
  }
  .ttl2 h2 small {
    display: block;
    font-weight: normal;
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    margin-bottom: 1.06667vw;
  }
  .ttl2 h2 span {
    display: block;
    font-weight: bold;
    /* font-size: 8.44444vw; */
    font-size: 6.5vw;
  }
  .ttl2 p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    /* font-size: 4.26667vw; */
    letter-spacing: 0.1em;
    line-height: 1.875;
    font-size: 3.5vw;
    text-align: left;
  }
  #t02 {
    margin-top: 12.53333vw;
  }
  .wp-pagenavi, .pagination {
    margin-top: 11.73333vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
       -moz-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .wp-pagenavi + .tl2, .pagination + .tl2 {
    margin-top: 12.53333vw;
  }
  .wp-pagenavi .pages, .pagination .pages {
    display: none;
  }
  .wp-pagenavi .page, .wp-pagenavi .page-numbers, .pagination .page, .pagination .page-numbers {
    margin: 0 1.06667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 9.33333vw;
    height: 9.33333vw;
    -moz-border-radius: 1.6vw;
         border-radius: 1.6vw;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
  }
  .wp-pagenavi .page:hover, .wp-pagenavi .page-numbers:hover, .pagination .page:hover, .pagination .page-numbers:hover {
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
    border-color: #cc2928;
  }
  .wp-pagenavi .dots, .pagination .dots {
    background-color: transparent;
    border: none;
    width: auto;
  }
  .wp-pagenavi .dots:hover, .pagination .dots:hover {
    background-color: transparent;
    color: #333;
  }
  .wp-pagenavi .current, .pagination .current {
    margin: 0 1.06667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 9.33333vw;
    height: 9.33333vw;
    -moz-border-radius: 1.6vw;
         border-radius: 1.6vw;
    background: #fff;
    border: 1px solid #cc2928;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: center;
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
  }
  .wp-pagenavi .nextpostslink, .wp-pagenavi .next, .pagination .nextpostslink, .pagination .next {
    margin: 0 1.06667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 9.33333vw;
    height: 9.33333vw;
    -moz-border-radius: 1.6vw;
         border-radius: 1.6vw;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    text-indent: -2666.4vw;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .wp-pagenavi .nextpostslink.disabled, .wp-pagenavi .next.disabled, .pagination .nextpostslink.disabled, .pagination .next.disabled {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    pointer-events: none;
  }
  .wp-pagenavi .prevpostslink, .wp-pagenavi .prev, .pagination .prevpostslink, .pagination .prev {
    margin: 0 1.06667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 9.33333vw;
    height: 9.33333vw;
    -moz-border-radius: 1.6vw;
         border-radius: 1.6vw;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    text-indent: -2666.4vw;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
  }
  .wp-pagenavi .prevpostslink.disabled, .wp-pagenavi .prev.disabled, .pagination .prevpostslink.disabled, .pagination .prev.disabled {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    pointer-events: none;
  }
  .pagi {
    margin-top: 11.73333vw;
  }
  .pagi + .tl2 {
    margin-top: 12.53333vw;
  }
  .pagi .paginationjs ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .pagi .paginationjs ul li {
    margin: 0 1.06667vw;
  }
  .pagi .paginationjs ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    width: 9.33333vw;
    height: 9.33333vw;
    -moz-border-radius: 1.6vw;
         border-radius: 1.6vw;
    background: #fff;
    border: 1px solid #d1d1d1;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: center;
    color: #333;
    cursor: pointer;
  }
  .pagi .paginationjs ul li a:hover {
    background-color: #cc2928;
    opacity: 1;
    color: #fff;
    border-color: #cc2928;
  }
  .pagi .paginationjs ul li.paginationjs-ellipsis a {
    background-color: transparent;
    border: none;
    width: auto;
  }
  .pagi .paginationjs ul li.paginationjs-ellipsis a:hover {
    background-color: transparent;
    color: #333;
  }
  .pagi .paginationjs ul li.paginationjs-page.active a {
    color: #fff;
    background-color: #cc2928;
  }
  .pagi .paginationjs ul li .paginationjs-next a {
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    -webkit-transform: rotate(180deg);
       -moz-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  .pagi .paginationjs ul li .paginationjs-next.disabled a {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    pointer-events: none;
  }
  .pagi .paginationjs ul li .paginationjs-prev a {
    text-indent: -9999px;
    -webkit-transition: background-color .3s ease-out;
    -moz-transition: background-color .3s ease-out;
    transition: background-color .3s ease-out;
    background-image: url("../img/page_ar.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
  }
  .pagi .paginationjs ul li .paginationjs-prev.disabled a {
    background: #f2f2f2;
    border: 1px solid #d1d1d1;
    background-image: url("../img/page_ar2.svg");
    background-repeat: no-repeat;
    background-position: center;
    -moz-background-size: 2.13333vw 3.46667vw;
         background-size: 2.13333vw 3.46667vw;
    pointer-events: none;
  }
  a.btn, button.btn {
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    color: #403535;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    position: relative;
    padding-right: 16vw;
    min-height: 11.2vw;
    display: -webkit-inline-box;
    display: -moz-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  a.btn::after, button.btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 11.2vw;
    height: 11.2vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: #cc2929 url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 4vw 1.6vw;
         background-size: 4vw 1.6vw;
  }
  a.btn.st2, button.btn.st2 {
    padding-right: 0;
    padding-left: 16vw;
  }
  a.btn.st2::after, button.btn.st2::after {
    left: 0;
    right: initial;
    -webkit-transform: translateY(-50%) rotate(180deg);
       -moz-transform: translateY(-50%) rotate(180deg);
        -ms-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }
  .breadcrumb {
    padding: 1.33333vw 0;
    font-size: 4.26667vw;
  }
  .breadcrumb ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .breadcrumb ul li:not(:last-child) {
    position: relative;
    margin-right: 5.33333vw;
  }
  .breadcrumb ul li:not(:last-child)::after {
    content: ">";
    position: absolute;
    top: 50%;
    right: -4vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .faq_list dl {
    border-bottom: 1px solid #d8d8d8;
  }
  .faq_list dl dt {
    font-weight: normal;
    /* font-size: 4.26667vw; */
    font-size: 3.8vw;
    letter-spacing: 0.1em;
    padding: 4vw 10.66667vw;
    position: relative;
    cursor: pointer;
    -webkit-transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }
  .faq_list dl dt:hover {
    opacity: 0.7;
  }
  .faq_list dl dt::before {
    content: "Q.";
    position: absolute;
    /* top: 7.2vw; */
    line-height: 1;
    left: 1.33333vw;
    font-size: 4.8vw;
  }
  .faq_list dl dt i {
    position: absolute;
    width: 5.33333vw;
    height: 5.33333vw;
    right: 1.33333vw;
    top: 50%;
    margin-top: -2.66667vw;
    display: block;
  }
  .faq_list dl dt i:before, .faq_list dl dt i:after {
    content: "";
    position: absolute;
    background-color: #403535;
    -webkit-transition: -webkit-transform 0.25s ease-out;
    transition: -webkit-transform 0.25s ease-out;
    -moz-transition: transform 0.25s ease-out, -moz-transform 0.25s ease-out;
    transition: transform 0.25s ease-out;
    transition: transform 0.25s ease-out, -webkit-transform 0.25s ease-out, -moz-transform 0.25s ease-out;
  }
  .faq_list dl dt i:before {
    top: 0;
    left: 50%;
    width: 0.53333vw;
    height: 100%;
    margin-left: -0.26667vw;
  }
  .faq_list dl dt i:after {
    top: 50%;
    left: 0;
    width: 100%;
    height: 0.53333vw;
    margin-top: -0.26667vw;
  }
  .faq_list dl dt.is_active i:before {
    -webkit-transform: rotate(90deg);
       -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .faq_list dl dd {
    max-height: 0;
    overflow: hidden;
    -webkit-transition: max-height 0.3s ease-out;
    -moz-transition: max-height 0.3s ease-out;
    transition: max-height 0.3s ease-out;
    font-family: "Source Han Sans JP";
    font-weight: normal;
    /* font-size: 4vw; */
    font-size: 3.8vw;
    letter-spacing: 0.1em;
    line-height: 1.93333;
  }
  .faq_list dl dd .accCt {
    padding-bottom: 8vw;
  }
  .p_top {
    padding-top: 0;
  }
  .p_top .header {
    background-color: transparent;
  }
  .p_top .mv {
    position: relative;
  }
  .p_top .mv .mv-slider .swiper-slide {
    height: 153.33333vw;
  }
  .p_top .mv .mv-slider .swiper-slide picture {
    height: 100%;
  }
  .p_top .mv .mv-slider .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_top .mv .txt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
       -moz-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: 9.33333vw;
    z-index: 2;
    background: rgba(29, 41, 81, 0.5);
  }
  .p_top .mv .txt h2 {
    font-weight: bold;
    /* font-size: 7.46667vw; */
    font-size: 6.5vw;
    letter-spacing: 0.1em;
    line-height: 1.69767;
    color: #fff;
    text-shadow: 0vw 0.8vw 1.6vw rgba(0, 0, 0, 0.16);
    margin-bottom: 2.66667vw;
  }
  .p_top .mv .txt p {
    font-weight: bold;
    /* font-size: 3.73333vw; */
    font-size: 3.5vw;
    letter-spacing: 0.1em;
    color: #fff;
    line-height: 2;
    text-shadow: 0vw 0.8vw 1.6vw rgba(0, 0, 0, 0.16);
  }
  .p_top .intro {
    background-color: #EFEDE7;
    padding: 14.93333vw 0 16.8vw;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .intro::before {
    content: "";
    position: absolute;
    top: 5.33333vw;
    right: -41.33333vw;
    width: 98.01481vw;
    height: 28.68148vw;
    background: url(../img/intro_bg1.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .intro::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: -43.46667vw;
    width: 91.92157vw;
    height: 28.67451vw;
    background: url(../img/intro_bg2.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .intro_l {
    position: relative;
    margin-bottom: 8.53333vw;
  }
  .p_top .intro_l h2 {
    margin-bottom: 6.4vw;
  }
  .p_top .intro_l h2 small {
    display: block;
    font-weight: normal;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #403535;
    margin-bottom: 2.13333vw;
  }
  .p_top .intro_l h2 span {
    display: block;
    font-weight: normal;
    font-size: 7.46667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #403535;
  }
  .p_top .intro_r {
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: left;
    color: #403535;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .intro_r figure {
    margin-bottom: 15px;
  }
  .p_top .intro_r .intro_btn {
    width: 53.06667vw;
    height: 13.6vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: #cc2929;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 1.38889;
    color: #fff;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-left: auto;
    padding: 0 13.33333vw 0 5.33333vw;
    position: relative;
  }
  .p_top .intro_r .intro_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 3.73333vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 9.06667vw;
    height: 9.06667vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: rgba(0, 0, 0, 0.2) url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 4vw 1.6vw;
         background-size: 4vw 1.6vw;
  }
  .p_top .what {
    padding: 14.93333vw 0 17.06667vw;
  }
  .p_top .what_head h2 {
    /* font-size: 7.46667vw; */
    font-size: 6vw;
    line-height: 1.71429;
    letter-spacing: 0.1em;
    text-align: center;
    color: #403535;
    margin-bottom: 6.66667vw;
  }
  .p_top .what_head p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #403535;
  }
  .p_top .what .what_list {
    margin-top: 6.66667vw;
    display: -ms-grid;
    display: grid;
    gap: 8.53333vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .what .what_list::after {
    content: "";
    position: absolute;
    left: 62%;
    top: 0;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 171.2vw;
    height: 384.8vw;
    background: url(../img/what_bg_sp.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .what .what_list li {
    text-align: center;
  }
  .p_top .what .what_list li figure {
    position: relative;
    width: 74.66667vw;
    height: 74.66667vw;
    -moz-border-radius: 50%;
         border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 3.2vw;
  }
  .p_top .what .what_list li figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .p_top .what .what_list li figure figcaption {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    line-height: 1.5;
    background: rgba(29, 41, 81, 0.5);
  }
  .p_top .what .what_list li figure figcaption h3 {
    font-weight: normal;
    font-size: 6.66667vw;
    letter-spacing: 0.1em;
    text-align: center;
    color: #fff;
    margin-bottom: 3.2vw;
  }
  .p_top .what .what_list li figure figcaption p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 2.5625;
    text-align: center;
    color: #fff;
  }
  .p_top .what .what_list li p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #403535;
  }
  .p_top .what .what_list li .btnWr {
    text-align: right;
    margin-top: 2.66667vw;
  }
  .p_top .tl {
    margin-bottom: 8.53333vw;
  }
  .p_top .tl small {
    display: block;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    color: #e83828;
    margin-bottom: 2.13333vw;
  }
  .p_top .tl span {
    display: block;
    font-weight: normal;
    font-size: 6.93333vw;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .p_top .topics {
    padding: 14.93333vw 0 17.33333vw;
    background: #f8f8f4;
  }
  .p_top .topics_main {
    position: relative;
  }
  .p_top .topics_main .btn {
    margin-top: 8.53333vw;
  }
  .p_top .topics_main .topics_btn {
    text-align: right;
  }
  .p_top .topics_r ul li + li {
    margin-top: 6.4vw;
  }
  .p_top .topics_r ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .topics_r ul li a figure {
    width: 31.73333vw;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    overflow: hidden;
  }
  .p_top .topics_r ul li a figure img {
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    overflow: hidden;
  }
  .p_top .topics_r ul li a iframe {
    width: 31.73333vw;
    height: 33.6vw;
    object-fit: cover;
  }
  .p_top .topics_r ul li a .txt {
    width: 100%;
    padding-left: 2.93333vw;
  }
  .p_top .topics_r ul li a .txt h3 {
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 1.5;
    text-align: left;
    color: #403535;
    margin-bottom: 2.13333vw;
  }
  .p_top .topics_r ul li a .txt p {
    font-family: "Source Han Sans JP";
    font-size: 3.46667vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #403535;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
  }
  .p_top .shop {
    background: url(../img/shop_bg_sp.png) center/100% 100% no-repeat;
    padding: 21.33333vw 0;
    -moz-background-size: cover;
         background-size: cover;
  }
  .p_top .shop .box {
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #fff;
    padding: 14.93333vw 4.8vw;
    position: relative;
  }
  .p_top .shop .box::before {
    content: "";
    position: absolute;
    top: -15.2vw;
    right: -14.66667vw;
    width: 59.40741vw;
    height: 33.03704vw;
    background: url(../img/shop_img.png) center/100% 100% no-repeat;
    display: block;
  }
  .p_top .shop .box .tl {
    text-align: center;
  }
  .p_top .shop .box ul {
    display: -ms-grid;
    display: grid;
    gap: 2.13333vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p_top .shop .box ul a {
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #f2f3f4;
    display: block;
    padding: 5.33333vw 4.8vw 13.33333vw;
    position: relative;
  }
  .p_top .shop .box ul a::after {
    content: "";
    position: absolute;
    right: 4vw;
    bottom: 4vw;
    width: 8.8vw;
    height: 8.8vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background-image: url(../img/ic_arr02.png);
    background-repeat: no-repeat;
    background-color: #cc2929;
    display: block;
    -moz-background-size: 2.93333vw 2.93333vw;
         background-size: 2.93333vw 2.93333vw;
    background-position: center;
  }
  .p_top .shop .box ul a.st2::after {
    background-color: transparent;
    border: 1px solid #cc2929;
    background-image: url(../img/ic_plus.svg);
    -moz-background-size: 4.26667vw 4.26667vw;
         background-size: 4.26667vw 4.26667vw;
  }
  .p_top .shop .box ul a h3 {
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    margin-bottom: 2.13333vw;
  }
  .p_top .shop .box ul a p {
    font-family: "Source Han Sans JP";
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
  }
  .p_top .faq {
    padding: 14.93333vw 0 17.06667vw;
    background: #EFEDE7;
  }
  .p_top .faq_main {
    position: relative;
  }
  .p_top .faq_main .faq_btn {
    margin-top: 8.53333vw;
    text-align: right;
  }
  .p_top .faq_r {
    width: 100%;
  }
  .p_top .contact {
    padding: 14.93333vw 0 17.06667vw;
    background: #a58f62;
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
  }
  .p_top .contact::after {
    content: "";
    position: absolute;
    right: -25.33333vw;
    top: 8.53333vw;
    width: 69.01333vw;
    height: 31.25333vw;
    background: url(../img/contact_bg.png) center/100% 100% no-repeat;
    display: block;
    z-index: -1;
  }
  .p_top .contact .tl {
    color: #fff;
  }
  .p_top .contact .tl small {
    color: #fff;
  }
  .p_top .contact_main {
    position: relative;
  }
  .p_top .contact_main ul li + li {
    margin-top: 2.13333vw;
  }
  .p_top .contact_main ul li a {
    min-height: 23.73333vw;
    -moz-border-radius: 2.13333vw;
         border-radius: 2.13333vw;
    background: #cc2929;
    max-width: 100%;
    font-size: 4.53333vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #fff;
    padding: 0 18.66667vw 0 13.33333vw;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_top .contact_main ul li a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 4vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 6.13333vw;
    height: 4.8vw;
    background-image: url(../img/ic_mail.png);
    background-repeat: no-repeat;
    -moz-background-size: 100% 100%;
         background-size: 100% 100%;
    display: block;
  }
  .p_top .contact_main ul li a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 4vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 11.2vw;
    height: 11.2vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 4vw 1.6vw;
         background-size: 4vw 1.6vw;
    border: 1px solid #fff;
  }
  .p_top .contact_main ul li a.st2 {
    background-color: #b51722;
  }
  .p_top .contact_main ul li a.st2::before {
    width: 5.33333vw;
    height: 5.33333vw;
    background-image: url(../img/ic_tel.png);
  }
  .p_top .f_info {
    background-color: #EFEDE7;
  }
  .p_top .f_info .f_info_main {
    padding: 14.66667vw 0 10.66667vw;
    border-bottom: 1px solid #b9b9b9;
  }
  .p_top .f_info .f_info_main .f_info_l {
    margin-bottom: 6.4vw;
  }
  .p_top .f_info .f_info_main .f_info_r {
    width: 100%;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn {
    text-align: right;
    margin-top: 6.4vw;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn .btn {
    font-size: 4.26667vw;
    padding-right: 14.13333vw;
  }
  .p_top .f_info .f_info_main .f_info_r .f_btn .btn:after {
    width: 8.8vw;
    height: 8.8vw;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    line-height: 1.53333;
    letter-spacing: 0.05em;
    text-align: left;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl + dl {
    margin-top: 2.66667vw;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl dt {
    width: 30.4vw;
    min-height: 7.2vw;
    -moz-border-radius: 0.8vw;
         border-radius: 0.8vw;
    background: #dedbcd;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-weight: normal;
    font-size: 3.46667vw;
    letter-spacing: 0.05em;
    text-align: center;
    color: #5c504d;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .p_top .f_info .f_info_main .f_info_r .dlist .it dl dd {
    width: 100%;
    padding-left: 4.53333vw;
  }
  .boxoverlay {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1900;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    background: rgba(0, 0, 0, 0.2);
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    transition: all 0.5s;
  }
  .modal {
    position: fixed;
    top: 50%;
    left: 50%;
    width: 50%;
    width: 90vw;
    height: auto;
    z-index: 99999;
    visibility: hidden;
    -webkit-transform: translateX(-50%) translateY(-50%);
       -moz-transform: translateX(-50%) translateY(-50%);
        -ms-transform: translateX(-50%) translateY(-50%);
            transform: translateX(-50%) translateY(-50%);
  }
  .modal.open {
    visibility: visible;
  }
  .modal.open .m_in {
    opacity: 1;
  }
  .modal .wrap_modal {
    max-height: 60vh;
    overflow: auto;
  }
  .modal .wrap_modal h3 {
    text-align: center;
    font-weight: normal;
    font-size: 6.4vw;
    letter-spacing: 0.1em;
    color: #403535;
    margin-bottom: 6.4vw;
  }
  .modal .wrap_modal ul {
    margin-bottom: 5.06667vw;
  }
  .modal .wrap_modal ul li {
    margin-bottom: 0.8vw;
  }
  .modal .wrap_modal ul li a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    min-height: 18.13333vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #f2f3f4;
    padding: 0 13.33333vw 0 6.13333vw;
    font-weight: 400;
  }
  .modal .wrap_modal ul li a:after {
    right: 5.86667vw;
  }
  .modal .wrap_modal .md_desc {
    position: relative;
    font-weight: normal;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    line-height: 1.9;
    text-align: left;
    color: #403535;
    padding-left: 3.2vw;
    padding-bottom: 5.33333vw;
    position: relative;
  }
  .modal .wrap_modal .md_desc::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 29.22667vw;
    height: 12.8vw;
    background: url(../img/md_bg.png) center/100% 100% no-repeat;
    display: block;
  }
  .modal .m_in {
    opacity: 0;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    padding: 4vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #fff;
  }
  .modal .m_area {
    position: relative;
  }
  .modal .btn_close {
    position: absolute;
    top: -6.93333vw;
    right: -6.93333vw;
    width: 8.8vw;
    height: 8.8vw;
    cursor: pointer;
  }
  .bg_cm {
    background: url(../img/brand/intro_bg_sp.png) center no-repeat;
    -moz-background-size: 366.93333vw auto;
         background-size: 366.93333vw auto;
  }
  .p_brand .brand .intro {
    padding: 14.93333vw 0 17.06667vw;
  }
  .p_brand .brand .intro_t {
    margin-bottom: 8.53333vw;
  }
  .p_brand .brand .intro_t figure {
    margin-top: 7.46667vw;
  }
  .p_brand .brand .intro_t .txt {
    width: 100%;
  }
  .p_brand .brand .intro_t .txt h2 {
    font-weight: bold;
    font-size: 7.46667vw;
    line-height: 1.71429;
    text-align: left;
    color: #333;
    margin-bottom: 8.53333vw;
  }
  .p_brand .brand .intro_t .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_m {
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    -moz-box-shadow: 0vw 0.8vw 6.93333vw rgba(0, 0, 0, 0.05);
         box-shadow: 0vw 0.8vw 6.93333vw rgba(0, 0, 0, 0.05);
    overflow: hidden;
    padding: 10.66667vw 5.33333vw 45.6vw;
    margin-bottom: 8.53333vw;
    background: #F8FDFF url(../img/brand/intro_img2_sp.png) center bottom no-repeat;
    -moz-background-size: 100% auto;
         background-size: 100% auto;
  }
  .p_brand .brand .intro_m p {
    width: 174.93333vw;
    max-width: 100%;
    font-size: 4vw;
    line-height: 1.73333;
  }
  .p_brand .brand .intro_m h3 {
    margin-bottom: 6.13333vw;
  }
  .p_brand .brand .intro_m h3 span {
    display: block;
    font-weight: bold;
    font-size: 6.4vw;
    line-height: 1.66667;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 1.33333vw;
  }
  .p_brand .brand .intro_m h3 small {
    display: block;
    font-weight: bold;
    font-size: 4.8vw;
    line-height: 1.77778;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list {
    display: -ms-grid;
    display: grid;
    margin-bottom: 8.53333vw;
    gap: 8.53333vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p_brand .brand .intro_list li {
    padding: 6.66667vw 5.33333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    background: #fff;
  }
  .p_brand .brand .intro_list li .it_head {
    margin-bottom: 4.26667vw;
  }
  .p_brand .brand .intro_list li .it_head figure {
    width: 17.06667vw;
    height: 17.06667vw;
    -moz-border-radius: 2666.4vw;
         border-radius: 2666.4vw;
    overflow: hidden;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 3.2vw;
  }
  .p_brand .brand .intro_list li .it_head figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    -moz-border-radius: 2666.4vw;
         border-radius: 2666.4vw;
    overflow: hidden;
  }
  .p_brand .brand .intro_list li .it_head h4 span {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list li .it_head h4 span em {
    font-style: normal;
    font-size: 4.26667vw;
  }
  .p_brand .brand .intro_list li .it_head h4 small {
    display: block;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_list li p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #333;
  }
  .p_brand .brand .intro_btn {
    display: -ms-grid;
    display: grid;
    gap: 3.73333vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    width: 266.66667vw;
    max-width: 100%;
    margin: 0 auto;
  }
  .p_brand .brand .intro_btn a {
    min-height: 26.93333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    background: #cc2928;
    max-width: 100%;
    font-size: 4.26667vw;
    font-weight: bold;
    letter-spacing: 0.1em;
    color: #fff;
    padding: 0 21.33333vw 0 5.33333vw;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .p_brand .brand .intro_btn a span {
    color: rgba(255, 255, 255, 0.74);
    margin-left: 1.33333vw;
  }
  .p_brand .brand .intro_btn a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 2.66667vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 11.2vw;
    height: 11.2vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    background: rgba(0, 0, 0, 0.2) url(../img/ic_arr.png) center/100% 100% no-repeat;
    display: block;
    -moz-background-size: 4vw 1.6vw;
         background-size: 4vw 1.6vw;
  }
  .p_brand .brand .what {
    padding-bottom: 26.66667vw;
  }
  .p_brand .brand .what_top {
    background: url(../img/brand/what_bg_sp.png) center bottom no-repeat;
    -moz-background-size: cover;
         background-size: cover;
    padding-top: 13.33333vw;
    padding-bottom: 24.26667vw;
  }
  .p_brand .brand .what_top h2 {
    font-weight: bold;
    font-size: 7.46667vw;
    letter-spacing: 0.1em;
    color: #fff;
    margin-bottom: 8.53333vw;
  }
  .p_brand .brand .what_top p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 1.875;
    color: #fff;
  }
  .p_brand .brand .what_bot {
    margin-top: -14.66667vw;
    position: relative;
    z-index: 2;
  }
  .p_brand .brand .what_bot .box {
    padding: 10.66667vw 5.33333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    background: #fff;
  }
  .p_brand .brand .what_bot .box ul {
    width: 266.66667vw;
    margin: 0 auto;
    max-width: 100%;
  }
  .p_brand .brand .what_bot .box ul li + li {
    margin-top: 8.53333vw;
  }
  .p_brand .brand .what_bot .box ul li figure {
    overflow: hidden;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 4.26667vw;
  }
  .p_brand .brand .what_bot .box ul li figure img {
    overflow: hidden;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 {
    margin-bottom: 5.33333vw;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 2.13333vw;
  }
  .p_brand .brand .what_bot .box ul li .txt h3 small {
    font-weight: bold;
    font-size: 4.26667vw;
    line-height: 1.75;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    display: block;
  }
  .p_brand .brand .what_bot .box ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #333;
  }
  .p_faq .faq {
    padding: 13.33333vw 0 20vw;
    background-color: #fff;
  }
  .p_faq .faq .row {
    max-width: 266.66667vw;
  }
  .p_faq .faq_head {
    margin-bottom: 9.33333vw;
  }
  .p_faq .faq_head ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 4vw;
  }
  .p_faq .faq_head ul li {
    margin-right: 1.33333vw;
  }
  .p_faq .faq_head ul li a {
    min-height: 10.93333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    border: 1px solid #d1d1d1;
    padding: 0 2.66667vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 3.73333vw;
  }
  .p_faq .faq_head ul li a.active {
    background: #cc2928;
    border-color: #cc2928;
    color: #fff;
  }
  .p_faq .faq_head .faq_search {
    position: relative;
  }
  .p_faq .faq_head .faq_search button {
    position: absolute;
    top: 0;
    left: 0;
    padding: 0;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    width: 13.33333vw;
    height: 11.73333vw;
    display: -webkit-inline-box;
    display: -moz-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: url(../img/ic_search.svg) center no-repeat;
    -moz-background-size: 5.6vw 5.6vw;
         background-size: 5.6vw 5.6vw;
  }
  .p_faq .faq_head .faq_search input {
    padding: 0 4vw;
    outline: none;
    font-size: 4vw;
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    width: 100%;
    height: 11.73333vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    background: #fafafa;
    border: 1px solid #e8e8e8;
    padding-left: 13.33333vw;
  }
  .p_faq .faq_head .faq_search input::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq_head .faq_search input::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_faq .faq .faq_bd .it {
    padding-top: 8vw;
  }
  .p_faq .faq .faq_bd .it + .it {
    margin-top: 10.66667vw;
  }
  .p_faq .faq .faq_list {
    color: #333;
  }
  .p_faq .faq .faq_list dl dt {
    /* font-size: 4.8vw; */
    font-size: 3.8vw;
    padding-left: 8.53333vw;
  }
  .p_faq .faq .faq_list dl dt:before {
    /* top: 8vw; */
    font-size: 3.8vw;
  }
  .p_faq .faq .faq_list dl dd .accCt {
    background: #fafafa;
    padding: 5.33333vw 5.33333vw 7.2vw;
  }
  .p_faq .faq .faq_list dl dd .accCt p {
    font-size: 3.8vw;
  }
  .tl2 {
    font-weight: bold;
    font-size: 6.93333vw;
    color: #333;
    margin-bottom: 2.66667vw;
  }
  .p_contact {
    background-color: #EFEDE7;
  }
  .p_contact .contact {
    padding: 13.33333vw 0;
  }
  .p_contact .contact .row {
    max-width: 266.66667vw;
  }
  .p_contact .contact .f_btn {
    padding: 0;
    outline: none;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border: 0;
    cursor: pointer;
    background-color: #000644;
    color: #fff;
    font-size: 4.26667vw;
    -moz-border-radius: 8vw;
         border-radius: 8vw;
    height: 17.6vw;
    -moz-border-radius: 0.8vw;
         border-radius: 0.8vw;
    background: #cc2928;
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.05em;
    text-align: center;
    color: #fff;
    position: relative;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 10vw auto 0;
    width: 100%;
  }
  .p_contact .contact .f_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 5.86667vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 2.13333vw;
    height: 3.46667vw;
    background: url(../img/ic_arr2.svg) center/100% 100% no-repeat;
    display: block;
  }
  .p_contact .contact .form {
    -moz-border-radius: 2.4vw;
         border-radius: 2.4vw;
    background: #fff;
    padding: 5.33333vw;
  }
  .p_contact .contact .form .f_txtError {
    font-size: 3.73333vw;
    letter-spacing: 0.07em;
    margin-bottom: 1.06667vw;
    color: #f00;
  }
  .p_contact .contact .form dl + dl {
    margin-top: 8.53333vw;
  }
  .p_contact .contact .form dl dt {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    font-weight: bold;
    font-size: 4vw;
    letter-spacing: 0.1em;
    color: #203153;
    margin-bottom: 2.66667vw;
  }
  .p_contact .contact .form dl dt span {
    color: #D53030;
    margin-left: 0.8vw;
    margin-top: 0.8vw;
  }
  .p_contact .contact .form dl dd {
    width: 100%;
  }
  .p_contact .contact .form dl dd .select label {
    display: block;
    position: relative;
    -webkit-perspective: 0.26667vw;
       -moz-perspective: 0.26667vw;
            perspective: 0.26667vw;
    width: 106.66667vw;
    height: 13.86667vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #fff;
    border: 1px solid #e8e8e8;
    max-width: 100%;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd .select label::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 4.8vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 0;
    height: 0;
    border-left: 1.86667vw solid transparent;
    border-right: 1.86667vw solid transparent;
    border-top: 2.93333vw solid #333;
  }
  .p_contact .contact .form dl dd .select label select {
    width: 100%;
    height: 100%;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    outline: none;
    border: none;
    padding: 0 9.33333vw 0 5.33333vw;
    background: transparent;
    font-weight: 400;
    font-size: -webkit-calc(max(4.26667vw, 16px));
    font-size: -moz-calc(max(4.26667vw, 16px));
    font-size: calc(max(4.26667vw, 16px));
    color: #333;
    cursor: pointer;
    position: relative;
    z-index: 3;
  }
  .p_contact .contact .form dl dd .select label select::-ms-expand {
    display: none;
  }
  .p_contact .contact .form dl dd input {
    width: 100%;
    padding: 0 5.33333vw;
    outline: none;
    font-size: -webkit-calc(max(4.26667vw, 16px));
    font-size: -moz-calc(max(4.26667vw, 16px));
    font-size: calc(max(4.26667vw, 16px));
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    height: 13.86667vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #f4f4f4;
    border: 1px solid #e8e8e8;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd input::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd input.sm {
    width: 106.66667vw;
    max-width: 100%;
  }
  .p_contact .contact .form dl dd textarea {
    width: 100%;
    padding: 2.66667vw 5.33333vw;
    outline: none;
    font-size: -webkit-calc(max(4.26667vw, 16px));
    font-size: -moz-calc(max(4.26667vw, 16px));
    font-size: calc(max(4.26667vw, 16px));
    color: #000;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    height: 43.73333vw;
    -moz-border-radius: 1.33333vw;
         border-radius: 1.33333vw;
    background: #f4f4f4;
    border: 1px solid #e8e8e8;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  }
  .p_contact .contact .form dl dd textarea::-webkit-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea::-moz-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea:-ms-input-placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd textarea::placeholder {
    color: rgba(51, 51, 51, 0.4);
    opacity: 1;
    letter-spacing: 0.1em;
  }
  .p_contact .contact .form dl dd .checkboxWr {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_contact .contact .form dl dd .checkboxWr div, .p_contact .contact .form dl dd .checkboxWr .mwform-checkbox-field {
    display: inline-block;
    margin-bottom: 1.33333vw;
    margin-right: 8vw;
    margin-left: 0;
  }
  .p_contact .contact .form dl dd .checkboxWr label {
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    display: inline-block;
    color: #333;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.05em;
    color: #203153;
  }
  .p_contact .contact .form dl dd .checkboxWr label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
  }
  .p_contact .contact .form dl dd .checkboxWr label span {
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    display: inline-block;
    padding: 0 0 0 8vw;
    position: relative;
  }
  .p_contact .contact .form dl dd .checkboxWr label span::before {
    position: absolute;
    content: "";
    top: 50%;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 0;
    width: 5.6vw;
    height: 5.6vw;
    -moz-border-radius: 1.06667vw;
         border-radius: 1.06667vw;
    /* background: #cc2928; */
    border: solid 1px #cc2928;
  }
  .p_contact .contact .form dl dd .checkboxWr label span::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0.53333vw;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 4.53333vw;
    height: 3.2vw;
    background: url(../img/ic_check_red.svg) center/100% 100% no-repeat;
    display: none;
  }
  .p_contact .contact .form dl dd .checkboxWr label input:checked ~ span:after {
    display: block;
  }
  .p_contact .contact .form dl dd .list_rd .rd, .p_contact .contact .form dl dd .list_rd .mwform-radio-field {
    margin-top: 2.13333vw;
    margin-bottom: 2.13333vw;
  }
  .p_contact .contact .form dl dd .list_rd .rd label, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label {
    display: block;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    line-height: 5.33333vw;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    color: #203153;
    letter-spacing: 0.02em;
  }
  .p_contact .contact .form dl dd .list_rd .rd label input, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
  }
  .p_contact .contact .form dl dd .list_rd .rd span, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span {
    position: relative;
    -webkit-transform: translateZ(0);
       -moz-transform: translateZ(0);
            transform: translateZ(0);
    display: inline-block;
    padding: 0 0 0 8vw;
  }
  .p_contact .contact .form dl dd .list_rd .rd span::before, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    -moz-border-radius: 50%;
         border-radius: 50%;
    width: 5.33333vw;
    height: 5.33333vw;
    border: 1px solid #cecece;
  }
  .p_contact .contact .form dl dd .list_rd .rd span::after, .p_contact .contact .form dl dd .list_rd .mwform-radio-field span::after {
    top: 1.06667vw;
    left: 1.06667vw;
    width: 3.2vw;
    height: 3.2vw;
    background: #cc2928;
    -moz-border-radius: 50%;
         border-radius: 50%;
    content: "";
    position: absolute;
    display: none;
  }
  .p_contact .contact .form dl dd .list_rd .rd label input:checked ~ span:after, .p_contact .contact .form dl dd .list_rd .mwform-radio-field label input:checked ~ span:after {
    display: block;
  }
  .p_initiatives .initiatives .thoughts {
    background: #EFF7F8 url(../img/initiatives/thoughts_bg_sp.png) bottom center no-repeat;
    /* -moz-background-size: 177.73333vw auto;
         background-size: 177.73333vw auto; */
      -moz-background-size: 100% auto;
        background-size: 100% auto;
    padding: 15.46667vw 0 74.13333vw;
  }
  .p_initiatives .initiatives .thoughts_main {
    position: relative;
  }
  .p_initiatives .initiatives .thoughts_main .author {
    margin-top: 13.86667vw;
  }
  .p_initiatives .initiatives .thoughts_main .author small {
    display: block;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 1.86667vw;
  }
  .p_initiatives .initiatives .thoughts_main .author span {
    display: block;
    font-weight: bold;
    font-size: 6.4vw;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_initiatives .initiatives .thoughts_main h2 {
    margin-bottom: 8.53333vw;
  }
  .p_initiatives .initiatives .thoughts_main h2 span {
    display: block;
    font-weight: bold;
    font-size: 8vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 6.4vw;
  }
  .p_initiatives .initiatives .thoughts_main h2 small {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    line-height: 1.8;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .thoughts_main p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .sdg {
    padding: 14.93333vw 0;
  }
  .p_initiatives .initiatives .sdg .sdg_head {
    margin-bottom: 8.53333vw;
  }
  .p_initiatives .initiatives .sdg .sdg_head figure {
    margin-top: 3.2vw;
    text-align: center;
  }
  .p_initiatives .initiatives .sdg .sdg_head figure img {
    width: 44vw;
    display: inline-block;
  }
  .p_initiatives .initiatives .sdg .sdg_head .txt h2 {
    font-weight: bold;
    font-size: 7.46667vw;
    line-height: 1.71429;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 8.53333vw;
  }
  .p_initiatives .initiatives .sdg .sdg_head .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .sdg .sdg_list li {
    padding: 8.53333vw 5.33333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    background: #fff;
  }
  .p_initiatives .initiatives .sdg .sdg_list li + li {
    margin-top: 8.53333vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li figure {
    margin-top: 3.2vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li figure.sm img {
    width: 50.13333vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 {
    margin-bottom: 4.26667vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 2.13333vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 span em {
    font-style: normal;
    font-size: 4.26667vw;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt h3 small {
    display: block;
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_initiatives .initiatives .sdg .sdg_list li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.86667;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence {
    padding-bottom: 26.66667vw;
  }
  .p_coexistence .coexistence .coexistence_top {
    padding: 14.93333vw 0;
  }
  .p_coexistence .coexistence .coexistence_top h2 {
    margin-bottom: 8.53333vw;
  }
  .p_coexistence .coexistence .coexistence_top h2 span {
    display: block;
    font-weight: bold;
    font-size: 8vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 6.4vw;
  }
  .p_coexistence .coexistence .coexistence_top h2 small {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    line-height: 1.8;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_top p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 2;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_top .c-video {
    display: -ms-grid;
    display: grid;
    gap: 4.26667vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-top: 7.46667vw;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a {
    display: block;
    position: relative;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
       -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 20.53333vw;
    height: 20.53333vw;
    background: url(../img/coexistence/ic_play.png) center/100% 100% no-repeat;
    display: block;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a figure {
    height: 50.4vw;
    overflow: hidden;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
  }
  .p_coexistence .coexistence .coexistence_top .c-video li a figure img {
    overflow: hidden;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_coexistence .coexistence .coexistence_mid ul li {
    padding: 5.33333vw;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    background: #fff;
  }
  .p_coexistence .coexistence .coexistence_mid ul li + li {
    margin-top: 8.53333vw;
  }
  .p_coexistence .coexistence .coexistence_mid ul li figure {
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    overflow: hidden;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 5.33333vw;
    height: 39.2vw;
  }
  .p_coexistence .coexistence .coexistence_mid ul li figure img {
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
    overflow: hidden;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 {
    margin-bottom: 4.26667vw;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 span {
    display: block;
    font-weight: bold;
    font-size: 5.33333vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 1.33333vw;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt h3 small {
    display: block;
    font-weight: bold;
    font-size: 4vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_mid ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 1.73333;
    text-align: left;
    color: #333;
  }
  .p_coexistence .coexistence .coexistence_bot {
    margin-top: 21.33333vw;
  }
  .p_coexistence .coexistence .coexistence_bot h3 {
    text-align: center;
    font-weight: bold;
    font-size: 7.11111vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 8vw;
  }
  .carousel {
    width: 100%;
    overflow: hidden;
  }
  .carousel .main_carousel {
    height: 42.13333vw;
    overflow: hidden;
    position: relative;
  }
  .carousel .main_carousel ul {
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
  }
  .carousel .main_carousel ul:after {
    content: '';
    display: table;
    clear: both;
  }
  .carousel .main_carousel ul li {
    float: left;
    width: 60.26667vw;
    padding-right: 2.4vw;
  }
  .carousel .main_carousel ul li img {
    width: 100%;
    height: 42.13333vw;
    object-fit: cover;
    overflow: hidden;
    -moz-border-radius: 2.66667vw;
         border-radius: 2.66667vw;
  }
  .p_company .company {
    background-color: #fff;
    padding-bottom: 13.33333vw;
  }
  .p_company .company .infor {
    padding: 13.33333vw 0;
  }
  .p_company .company .infor .tl2 {
    margin-bottom: 6.66667vw;
  }
  .p_company .company .infor .map iframe {
    height: 66.66667vw;
  }
  .p_company .company .infor .dlist {
    margin-bottom: 9.33333vw;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .p_company .company .infor .dlist dl {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 6.66667vw 0;
    border-bottom: 1px solid #DBDBDB;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
  }
  .p_company .company .infor .dlist dl dt {
    width: 32.8vw;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    padding-right: 4vw;
    font-size: 3.73333vw;
  }
  .p_company .company .infor .dlist dl dd {
    width: 100%;
  }
  .p_company .company .philosophy .box {
    padding: 13.6vw 5.33333vw;
    background: #f2f2f2 url(../img/company/philosophy_bg.png) center no-repeat;
    -moz-background-size: 100% auto;
         background-size: 100% auto;
    text-align: center;
  }
  .p_company .company .philosophy .box .tl2 {
    text-align: center;
    margin-bottom: 6vw;
  }
  .p_company .company .philosophy .box .p-numWr {
    display: inline-block;
    text-align: left;
    margin-bottom: 12vw;
  }
  .p_company .company .philosophy .box .p-numWr .p-num {
    display: -ms-grid;
    display: grid;
    gap: 5.33333vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_company .company .philosophy .box .list-circle li {
    width: 77.33333vw;
    height: 77.33333vw;
    background: #f8f8f8;
    -moz-border-radius: 2666.4vw;
         border-radius: 2666.4vw;
    margin: 0 auto 8vw;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
       -moz-box-orient: vertical;
       -moz-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p_company .company .philosophy .box .list-circle li h3 {
    position: relative;
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    color: #333;
    padding-bottom: 6.66667vw;
    margin-bottom: 5.33333vw;
  }
  .p_company .company .philosophy .box .list-circle li h3::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 11.46667vw;
    height: 0.26667vw;
    background: #c9c9c9;
    display: block;
  }
  .p_company .company .philosophy .box .list-circle li p {
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    line-height: 2;
    text-align: center;
    color: #333;
  }
  .p_company .company .decisions {
    padding: 13.33333vw 0;
  }
  .p_company .company .decisions .box {
    border: 1px solid #BCBCBC;
    text-align: center;
    padding: 5.33333vw;
  }
  .p_company .company .decisions .box .tl2 {
    margin-bottom: 5.33333vw;
  }
  .p_company .company .decisions .box ol {
    display: inline-block;
    text-align: left;
  }
  .p_company .company .decisions .box ol li {
    font-weight: bold;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 2.27778;
    color: #333;
  }
  .p_company .company .decisions .box ol li + li {
    margin-top: 4vw;
  }
  .p_company .company .certification ul li {
    padding: 8vw 0;
  }
  .p_company .company .certification ul li:not(:last-child) {
    border-bottom: 1px solid rgba(112, 112, 112, 0.33);
  }
  .p_company .company .certification ul li figure {
    margin-top: 8vw;
  }
  .p_company .company .certification ul li .txt h3 {
    margin-bottom: 4vw;
    font-weight: bold;
    font-size: 5.86667vw;
    letter-spacing: 0.1em;
    text-align: left;
    color: #333;
    margin-bottom: 4vw;
  }
  .p_company .company .certification ul li .txt p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    line-height: 1.875;
    text-align: left;
    color: #333;
  }
  .p_topics .faq_head ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p_topics .faq_head ul li {
    margin-bottom: 1.33333vw;
    width: 100%;
  }
  .p_topics .topics {
    padding-bottom: 0;
  }
  .p_topics .topics .topics_it {
    padding: 15.2vw 0;
  }
  .p_topics .topics .topics_it:nth-of-type(1) {
    padding-top: 9.33333vw;
  }
  .p_topics .topics .topics_it:nth-child(even) {
    background: #fafafa;
  }
  .p_topics .topics .topics_it .list_topics {
    display: -ms-grid;
    display: grid;
    gap: 17.6vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-top: 7.2vw;
  }
  .p_topics .topics .topics_it .list_topics li a {
    display: block;
  }
  .p_topics .topics .topics_it .list_topics li a figure {
    height: 57.06667vw;
    margin-bottom: 4.8vw;
  }
    .p_topics .topics .topics_it .list_topics li a iframe {
    margin-bottom: 4.8vw;
  }
  .p_topics .topics .topics_it .list_topics li a figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_topics .topics .topics_it .list_topics li a .meta {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 2.93333vw;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span {
    display: inline-block;
    padding: 0.8vw 2.66667vw;
    -moz-border-radius: 266.4vw;
         border-radius: 266.4vw;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.2vw;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st2 {
    background-color: #cc2928;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_topics .topics .topics_it .list_topics li a .meta span.st3::before {
    content: "";
    width: 3.46667vw;
    height: 3.46667vw;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 1.06667vw;
    vertical-align: middle;
  }
  .p_topics .topics .topics_it .list_topics li a .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_topics .topics .topics_it .list_topics li a h4 {
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 2.4vw;
  }
  .p_topics .topics .topics_it .list_topics li a p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    line-height: 1.85714;
    text-align: left;
    color: #403535;
  }
  .p_topics .topics .topics_it .list_topics02 {
    display: -ms-grid;
    display: grid;
    gap: 10.66667vw;
    -ms-grid-columns: (minmax(0, 1fr))[1];
        grid-template-columns: repeat(1, minmax(0, 1fr));
    margin-top: 10.66667vw;
  }
  .p_topics .topics .topics_it .list_topics02 li a figure {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 4vw;
    width: 100%;
    height: 57.06667vw;
  }
  .p_topics .topics .topics_it .list_topics02 li a figure img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .p_topics .topics .topics_it .list_topics02 li a .txt {
    width: 100%;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 2.93333vw;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span {
    display: inline-block;
    padding: 0.8vw 2.66667vw;
    -moz-border-radius: 266.4vw;
         border-radius: 266.4vw;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.2vw;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st2 {
    background-color: #cc2928;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta span.st3::before {
    content: "";
    width: 3.46667vw;
    height: 3.46667vw;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 1.06667vw;
    vertical-align: middle;
  }
  .p_topics .topics .topics_it .list_topics02 li a .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    color: #333;
  }
  .p_topics .topics .topics_it .list_topics02 li a h4 {
    font-weight: bold;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-bottom: 2.4vw;
  }
  .p_topics .topics .topics_it .list_topics02 li a p {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    line-height: 1.85714;
    text-align: left;
    color: #403535;
  }
  .p_detail .detail {
    padding-top: 13.33333vw;
    padding-bottom: 21.33333vw;
  }
  .p_detail .detail .row {
    max-width: 266.66667vw;
  }
  .p_detail .detail .post_ctrl {
    margin-top: 7.46667vw;
  }
  .p_detail .detail .box {
    -moz-border-radius: 2.4vw;
         border-radius: 2.4vw;
    background: #fff;
    padding: 5.33333vw;
  }
  .p_detail .detail .box .meta {
    padding-bottom: 3.33333vw;
    margin-bottom: 4.66667vw;
    border-bottom: 1px solid #d0d0d0;
  }
  .p_detail .detail .box .meta span {
    display: inline-block;
    padding: 0.8vw 2.66667vw;
    -moz-border-radius: 266.4vw;
         border-radius: 266.4vw;
    background: #a58f62;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.2vw;
    letter-spacing: 0.1em;
    color: #fff;
  }
  .p_detail .detail .box .meta span.st2 {
    background-color: #cc2928;
  }
  .p_detail .detail .box .meta span.st3 {
    background-color: #cc2928;
    position: relative;
  }
  .p_detail .detail .box .meta span.st3::before {
    content: "";
    width: 3.46667vw;
    height: 3.46667vw;
    background: url(../img/topics/ic_play.png) center/100% 100% no-repeat;
    display: inline-block;
    margin-right: 1.06667vw;
    vertical-align: middle;
  }
  .p_detail .detail .box .meta time {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 3.73333vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-left: 4.26667vw;
  }
  .p_detail .detail .box .meta h1 {
    font-weight: bold;
    font-size: 8.53333vw;
    letter-spacing: 0.1em;
    color: #333;
    margin-top: 2.66667vw;
  }
  .p_detail .detail .box .dt_ctn {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: normal;
    font-size: 4.26667vw;
    letter-spacing: 0.1em;
    line-height: 8vw;
    text-align: left;
    color: #403535;
  }
  .p_detail .detail .box .dt_ctn p {
    margin-bottom: 8vw;
  }
  .p_detail .detail .box .dt_ctn figure {
    margin-bottom: 9.86667vw;
  }
}
