@media screen and (max-width: 767.999px) {
  #contents_wapper .migrate {
    margin-top: 0;
    margin-bottom: -40px;
  }
  #contents_wapper .migrate ul {
    margin: 0 -20px;
  }
  #contents_wapper .migrate ul li {
    text-align: center;
    font-weight: 600;
    border-bottom: 1px solid rgba(0, 0, 0, 0.5);
  }
  #contents_wapper .migrate ul li a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    color: #fff;
    text-decoration: none;
    padding: 32px 30px;
  }
  #contents_wapper .migrate ul li.merit a {
    background: url("../../image/business/merit_base.jpg") no-repeat center center;
    background-size: cover;
  }
  #contents_wapper .migrate ul li.achievement a {
    background: url("../../image/business/achievement_base.jpg") no-repeat center center;
    background-size: cover;
  }
  #contents_wapper .migrate ul li.subsidy a {
    background: url("../../image/business/subsidy_base.jpg") no-repeat center center;
    background-size: cover;
  }
  #contents_wapper .migrate ul li strong {
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 0.08em;
  }
  #contents_wapper .migrate ul li span.btn {
    font-size: 13px;
    border: 1px solid #fff;
    border-radius: 100px;
    width: 180px;
    height: 38px;
    margin-top: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
  }
  #contents_wapper .migrate ul li span.btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 14px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    width: 5px;
    height: 5px;
    transform: translateY(-50%) rotate(45deg);
  }
  #page-business .intro .img,
  #page-merit .intro .img,
  #page-achievement .intro .img,
  #page-subsidy .intro .img {
    margin: 10px 0 30px;
    text-align: center;
  }
  #page-business .intro h3,
  #page-merit .intro h3,
  #page-achievement .intro h3,
  #page-subsidy .intro h3 {
    font-size: 18px;
    margin-bottom: 10px;
    text-align: center;
  }
  #page-business .intro .description,
  #page-merit .intro .description,
  #page-achievement .intro .description,
  #page-subsidy .intro .description {
    text-align: justify;
  }
  #page-business .intro .link a,
  #page-merit .intro .link a,
  #page-achievement .intro .link a,
  #page-subsidy .intro .link a {
    margin: 20px auto 0;
  }
  #page-business #method {
    margin-top: 50px;
  }
  #page-business #method .pictarea {
    background: #ebf7fd;
    padding: 20px;
    box-sizing: border-box;
    margin: 20px auto 0;
    border-radius: 10px;
    overflow: hidden;
  }
  #page-business #method .pictarea .img {
    margin: -30px -40px -10px;
  }
  #page-business #method .pictarea .beforeafter li {
    background: #fff;
    box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    padding: 24px 16px;
  }
  #page-business #method .pictarea .beforeafter li:nth-of-type(n+2) {
    margin-top: 8px;
  }
  #page-business #method .link {
    padding: 0 30px;
    margin-top: 20px;
  }
  #page-business #reason .reasons dl,
  #page-business #reduction .reasons dl {
    display: flex;
    flex-direction: column;
  }
  #page-business #reason .reasons dl:nth-of-type(n+2),
  #page-business #reduction .reasons dl:nth-of-type(n+2) {
    margin-top: 40px;
  }
  #page-business #reason .reasons dl dt,
  #page-business #reduction .reasons dl dt {
    border-radius: 10px;
    margin-bottom: 10px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #page-business #reason .reasons dl dt.graph,
  #page-business #reduction .reasons dl dt.graph {
    border: 2px solid #edf4f5;
    padding: 15px;
  }
  #page-business #reason .reasons dl dt.photo,
  #page-business #reduction .reasons dl dt.photo {
    border: none;
  }
  #page-business #reason .reasons dl dt.photo img,
  #page-business #reduction .reasons dl dt.photo img {
    border-radius: 10px;
  }
  #page-business #reason .reasons dl dd,
  #page-business #reduction .reasons dl dd {
    display: contents;
  }
  #page-business #reason .reasons dl dd h3,
  #page-business #reduction .reasons dl dd h3 {
    font-size: 18px;
    line-height: 1.5;
    margin-bottom: 12px;
    padding-left: 27px;
    margin-left: -3px;
    position: relative;
    align-self: center;
    order: -1;
  }
  #page-business #reason .reasons dl dd h3::before,
  #page-business #reduction .reasons dl dd h3::before {
    content: "";
    background: url("../../image/business/icon_point_mark_sp.png") no-repeat;
    background-size: 18px auto;
    width: 18px;
    height: 23px;
    position: absolute;
    left: 0;
    top: calc(50% - 12px);
  }
  #page-business #reason .reasons dl dd h3 span,
  #page-business #reduction .reasons dl dd h3 span {
    background: linear-gradient(0deg, #f9be00 30%, transparent 30%);
  }
  #page-business #reason .reasons .notearea,
  #page-business #reduction .reasons .notearea {
    background: #edf4f5;
    border-radius: 10px;
    margin-top: 20px;
    padding: 20px 10px;
  }
  #page-business #reason .reasons .notearea h4,
  #page-business #reduction .reasons .notearea h4 {
    font-size: 18px;
    text-align: center;
    margin-bottom: 12px;
  }
  #page-business #reason .reasons .notearea h4 span.mini,
  #page-business #reduction .reasons .notearea h4 span.mini {
    font-size: 12px;
  }
  #page-business #reason .reasons .notearea .formula,
  #page-business #reduction .reasons .notearea .formula {
    margin-bottom: 16px;
  }
  #page-business #reason .reasons .notearea .formula li,
  #page-business #reduction .reasons .notearea .formula li {
    background: #fbe8a9;
    border: 2px solid #f9be00;
    padding: 8px 10px;
    font-weight: 600;
    flex-grow: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  #page-business #reason .reasons .notearea .formula li:nth-of-type(n+2),
  #page-business #reduction .reasons .notearea .formula li:nth-of-type(n+2) {
    margin-top: 20px;
  }
  #page-business #reason .reasons .notearea .formula li:nth-of-type(n+2)::before,
  #page-business #reduction .reasons .notearea .formula li:nth-of-type(n+2)::before {
    content: "";
    background: url("../../image/business/icon_plus.png") no-repeat center center;
    background-size: 10px 10px;
    width: 10px;
    height: 10px;
    display: block;
    position: absolute;
    left: calc(50% - 5px);
    top: -17px;
  }
  #page-business #reason .reasons .notearea .formula li .waku,
  #page-business #reduction .reasons .notearea .formula li .waku {
    border: 1px solid #f9be00;
    background: #fff;
    border-radius: 4px;
    padding: 4px 16px;
    margin-top: 4px;
    font-size: 12px;
  }
  #page-business #reason .reasons .notearea .formula li .unit,
  #page-business #reduction .reasons .notearea .formula li .unit {
    font-size: 11px;
  }
  #page-business #reason .reasons .notearea .formula li .kakeru,
  #page-business #reduction .reasons .notearea .formula li .kakeru {
    margin: 0 0.3em;
    font-weight: normal;
  }
  #page-business #reason .reasons .notearea p,
  #page-business #reduction .reasons .notearea p {
    line-height: 1.65;
  }
  #page-business #reason .reasons .notearea .komenote,
  #page-business #reduction .reasons .notearea .komenote {
    margin-top: 10px;
  }
  #page-business #reason .reasons .notearea .komenote li,
  #page-business #reduction .reasons .notearea .komenote li {
    font-size: 11px;
    line-height: 1.65;
    margin-top: 3px;
    display: flex;
  }
  #page-business #reason .reasons .notearea .komenote li .kome,
  #page-business #reduction .reasons .notearea .komenote li .kome {
    flex-shrink: 0;
  }
  #page-business #reason .link a,
  #page-business #reduction .link a {
    margin: 30px auto 0;
  }
  #page-business .graphs {
    margin: 40px 0 20px;
    text-align: center;
  }
  #page-business .graphs li {
    margin-top: 40px;
  }
  #page-business #other .list > dl {
    padding: 30px 30px;
    background: #fff;
    box-shadow: 0 1px 8px 0px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
  }
  #page-business #other .list > dl:nth-of-type(n+2) {
    margin-top: 20px;
  }
  #page-business #other .list > dl dt {
    margin-bottom: 10px;
  }
  #page-business #other .list > dl dt img {
    width: 100%;
  }
  #page-business #other .list > dl dd {
    display: contents;
  }
  #page-business #other .list > dl dd h2 {
    color: inherit;
    font-size: 18px;
    line-height: 1.5;
    margin-bottom: 28px;
    order: -1;
  }
  #page-business #other .list > dl dd p {
    text-align: justify;
  }
  #page-merit #merit-demerit {
    margin-top: 50px;
  }
  #page-merit #merit-demerit #merit-list,
  #page-merit #merit-demerit #demerit-list {
    background: #ebf7fd;
    padding: 20px;
    box-sizing: border-box;
    margin: 20px auto 0;
    border-radius: 10px;
    overflow: hidden;
  }
  #page-merit #merit-demerit #merit-list .box,
  #page-merit #merit-demerit #demerit-list .box {
    background: #fff;
    box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    margin: 0 -10px;
    padding: 30px 20px;
  }
  #page-merit #merit-demerit #merit-list .img img,
  #page-merit #merit-demerit #demerit-list .img img {
    border-radius: 10px;
  }
  #page-merit #merit-demerit #merit-list h3,
  #page-merit #merit-demerit #demerit-list h3 {
    font-size: 18px;
    text-align: center;
    margin: 50px 0 20px;
  }
  #page-merit #merit-demerit #merit-list h3:first-of-type,
  #page-merit #merit-demerit #demerit-list h3:first-of-type {
    margin-top: 30px;
  }
  #page-merit #merit-demerit #merit-list h3 strong,
  #page-merit #merit-demerit #demerit-list h3 strong {
    background: #029ae8;
    color: #fff;
    font-size: 14px;
    line-height: 1;
    height: 36px;
    padding: 0 24px 0 16px;
    border-radius: 100px;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #page-merit #merit-demerit #merit-list h3 strong::before,
  #page-merit #merit-demerit #demerit-list h3 strong::before {
    content: "";
    display: block;
    background: url("../../image/business/thumbs-up.png") no-repeat center center;
    background-size: 18px auto;
    width: 18px;
    height: 22px;
    margin-right: 6px;
    flex-shrink: 0;
  }
  #page-merit #merit-demerit #merit-list h3 span,
  #page-merit #merit-demerit #demerit-list h3 span {
    background: linear-gradient(0deg, #f9be00 24%, transparent 24%);
    letter-spacing: 0.04em;
  }
  #page-merit #merit-demerit #merit-list p,
  #page-merit #merit-demerit #demerit-list p {
    text-align: justify;
  }
  #page-merit #merit-demerit #merit-list p + p,
  #page-merit #merit-demerit #demerit-list p + p {
    margin-top: 1em;
  }
  #page-merit #merit-demerit #merit-list ul,
  #page-merit #merit-demerit #demerit-list ul {
    margin-top: 1em;
  }
  #page-merit #merit-demerit #merit-list ul li,
  #page-merit #merit-demerit #demerit-list ul li {
    margin-top: 0.5em;
    position: relative;
    padding-left: 16px;
  }
  #page-merit #merit-demerit #merit-list ul li::before,
  #page-merit #merit-demerit #demerit-list ul li::before {
    content: "";
    display: block;
    width: 6px;
    height: 6px;
    background: #029ae8;
    border-radius: 10px;
    position: absolute;
    left: 0;
    top: 0.6em;
  }
  #page-merit #merit-demerit #demerit-list {
    margin-top: 20px;
  }
  #page-merit #merit-demerit #demerit-list h3 strong {
    background: #efefef;
    color: #484848;
  }
  #page-merit #merit-demerit #demerit-list h3 strong::before {
    background: url("../../image/business/thumbs-down.png") no-repeat left center;
    background-size: 20px auto;
    width: 20px;
    height: 22px;
  }
  #page-achievement #achievement-list {
    margin-top: 50px;
  }
  #page-achievement #achievement-list .casearea {
    background: #ebf7fd;
    padding: 20px;
    box-sizing: border-box;
    margin: 20px auto 0;
    border-radius: 10px;
    overflow: hidden;
  }
  #page-achievement #achievement-list .casearea dl.case {
    background: #fff;
    box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    margin: 0 -10px;
    padding: 30px 20px;
  }
  #page-achievement #achievement-list .casearea dl.case > dt {
    padding-left: 22px;
    font-size: 12px;
    margin-bottom: 20px;
  }
  #page-achievement #achievement-list .casearea dl.case > dt strong {
    border-left: 4px solid #029ae8;
    padding-left: 12px;
    margin-left: -16px;
    margin-bottom: 5px;
    display: block;
    font-size: 20px;
    line-height: 1.25;
    letter-spacing: 0.04em;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .img {
    border-radius: 10px;
    border: 2px solid #edf4f5;
    padding: 20px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea {
    flex-grow: 1;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction {
    background: #edf4f5;
    border-radius: 8px;
    display: flex;
    justify-content: space-evenly;
    padding: 16px 0 12px;
    margin-bottom: 8px;
    text-align: center;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl dt {
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
    margin-top: 10px;
    margin-bottom: 8px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl dd {
    font-size: 18px;
    font-weight: 600;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl dd .num {
    font-size: 30px;
    line-height: 1;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl.cost::before {
    content: "";
    display: block;
    background: url("../../image/business/achievements_illust_cost_sp.png") no-repeat center center;
    background-size: 36px auto;
    width: 36px;
    height: 34px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl.cost dd {
    background: linear-gradient(0deg, #f9be00 20%, transparent 20%);
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea .reduction dl.co2::before {
    content: "";
    display: block;
    background: url("../../image/business/achievements_illust_co2_sp.png") no-repeat center center;
    background-size: 43px auto;
    width: 43px;
    height: 34px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea dl.info {
    border-bottom: 1px solid #efefef;
    padding: 10px 0 8px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea dl.info dt {
    font-size: 12px;
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 3px;
  }
  #page-achievement #achievement-list .casearea dl.case > dd .infoarea dl.info dd {
    font-size: 14px;
    line-height: 1.5;
    padding-left: 1em;
  }
  #page-achievement .komenote {
    margin: 10px auto 0;
  }
  #page-achievement .komenote li {
    font-size: 11px;
    line-height: 1.5;
    margin-top: 8px;
    display: flex;
  }
  #page-achievement .komenote li .kome {
    flex-shrink: 0;
  }
  #page-subsidy .intro h2 {
    white-space: nowrap;
  }
  #page-subsidy #subsidy-list {
    margin-top: 50px;
  }
  #page-subsidy #subsidy-list .list {
    background: #ebf7fd;
    padding: 20px;
    box-sizing: border-box;
    margin: 20px auto 0;
    border-radius: 10px;
    overflow: hidden;
  }
  #page-subsidy #subsidy-list .list > dl {
    background: #fff;
    box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    margin: 0 -10px;
    padding: 30px 20px 20px;
  }
  #page-subsidy #subsidy-list .list > dl:nth-of-type(n+2) {
    margin-top: 10px;
  }
  #page-subsidy #subsidy-list .list > dl > dt {
    margin-bottom: 20px;
  }
  #page-subsidy #subsidy-list .list > dl > dt .date {
    display: block;
    font-size: 12px;
    margin-bottom: 4px;
  }
  #page-subsidy #subsidy-list .list > dl > dt .area {
    display: block;
  }
  #page-subsidy #subsidy-list .list > dl > dt .area strong {
    font-size: 18px;
    line-height: 1.5;
  }
  #page-subsidy #subsidy-list .list > dl > dd h3 {
    display: flex;
    font-size: 13px;
    font-weight: normal;
    line-height: 1.2;
    padding-bottom: 16px;
    margin-bottom: 16px;
    position: relative;
  }
  #page-subsidy #subsidy-list .list > dl > dd h3::after {
    content: "";
    display: block;
    background: linear-gradient(to right, var(--main-gradient-left) 0%, var(--main-gradient-right) 100%);
    height: 1px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
  }
  #page-subsidy #subsidy-list .list > dl > dd h3 .limit {
    background: #db4646;
    color: #fff;
    padding: 6px 8px;
    font-size: 12px;
    line-height: 1;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
  }
  #page-subsidy #subsidy-list .list > dl > dd h3 .num {
    color: #029ae8;
    font-size: 30px;
    font-weight: 600;
    line-height: 1;
    margin-right: 4px;
    flex-shrink: 0;
  }
  #page-subsidy #subsidy-list .list > dl > dd h3 .unit {
    color: #029ae8;
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    flex-shrink: 0;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dt {
    font-weight: 600;
    padding-left: 30px;
    margin-bottom: 12px;
    position: relative;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dt::before {
    content: "";
    display: block;
    background: url("../../image/business/circle-check_sp.png") no-repeat;
    background-size: 22px 22px;
    width: 22px;
    height: 22px;
    position: absolute;
    top: calc(50% - 11px);
    left: 0;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dd {
    font-size: 13px;
    line-height: 1.65;
    text-align: right;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dd ul {
    margin-bottom: 12px;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dd ul li {
    margin: 8px 0;
    text-indent: -1em;
    padding-left: 1em;
    text-align: left;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dd.official_page {
    text-align: right;
    font-size: 14px;
    margin-top: 16px;
  }
  #page-subsidy #subsidy-list .list > dl > dd .requirement dd.official_page a {
    color: #029ae8;
  }
  .contactarea {
    background: url("../../image/top/staff_bg.jpg") no-repeat center top;
    background-size: cover;
    color: #fff;
    text-align: center;
    margin: 0 -20px;
    padding: 50px 50px;
  }
  .contactarea h2 {
    font-size: 24px;
    letter-spacing: 0.04em;
    margin-bottom: 16px;
  }
  .contactarea h2 .en {
    font-size: 12px;
    letter-spacing: 0.008em;
    display: block;
    opacity: 0.8;
  }
  .contactarea .description {
    font-size: 13px;
  }
  .contactarea .link a {
    margin: 20px auto 0;
    background: transparent;
    border: 2px solid #fff;
    font-weight: 600;
  }
}
